Annotation of researchv10no/cmd/sml/src/basics/printutil.sml, revision 1.1

1.1     ! root        1: (* Copyright 1989 by AT&T Bell Laboratories *)
        !             2: structure PrintUtil : PRINTUTIL = struct
        !             3: 
        !             4:   structure Symbol : SYMBOL = Symbol
        !             5: 
        !             6:   fun newline () = print "\n"
        !             7:   fun tab 0 = () | tab n = (print " "; tab(n-1))
        !             8: 
        !             9:   fun printSequence (separator: string) pr elems =
        !            10:       let fun prElems [el] = pr el
        !            11:            | prElems (el::rest) = (pr el; print separator; prElems rest)
        !            12:            | prElems [] = ()
        !            13:        in prElems elems
        !            14:       end
        !            15: 
        !            16:   fun printClosedSequence (front: string, sep, back:string) pr elems =
        !            17:       (print front; printSequence sep pr elems; print back)
        !            18: 
        !            19:   fun printSym(s: Symbol.symbol) = print(Symbol.name s)
        !            20:       (* fix -- maybe this belongs in Symbol *)
        !            21: 
        !            22:   fun formatQid p =
        !            23:     let fun f [s] = [Symbol.name s]
        !            24:           | f (a::r) = Symbol.name a :: "." :: f r
        !            25:      in implode(f p)
        !            26:     end
        !            27: 
        !            28:   val stringDepth = System.Control.Print.stringDepth
        !            29:   local
        !            30:   fun decimal i = let val m = Integer.makestring
        !            31:                  in  m(i div 100)^m((i div 10)mod 10)^m(i mod 10) end
        !            32:   val ctrl_a = 1
        !            33:   val ctrl_z = 26
        !            34:   val offset = ord "A" - ctrl_a
        !            35:   val smallestprintable = ord " "
        !            36:   val biggestprintable = ord "~"
        !            37:   fun ml_char "\n" = "\\n"
        !            38:     | ml_char "\t" = "\\t"
        !            39:     | ml_char "\\" = "\\\\"
        !            40:     | ml_char "\"" = "\\\""
        !            41:     | ml_char c =
        !            42:          let val char = ord c
        !            43:          in  if char >= ctrl_a andalso char <= ctrl_z
        !            44:              then "\\^" ^ chr(char+offset)
        !            45:              else if char >= smallestprintable andalso char <= biggestprintable
        !            46:                   then c
        !            47:              else "\\" ^ decimal char
        !            48:          end
        !            49:   in
        !            50:       fun mlstr s = "\"" ^ implode(map ml_char (explode s)) ^ "\""
        !            51:       fun pr_mlstr s =
        !            52:          let val depth = !stringDepth
        !            53:              fun pr i =
        !            54:                  if i=depth then print "#"
        !            55:                  else (let val ch = substring(s,i,1)
        !            56:                        in  print(ml_char ch); pr (i+1)
        !            57:                        end handle Substring => ())
        !            58:          in print "\""; pr 0; print "\""
        !            59:          end
        !            60: 
        !            61:     fun nlindent n = (newline(); tab n)
        !            62: 
        !            63:     fun printvseq ind (sep:string) pr elems =
        !            64:        let fun prElems [el] = pr el
        !            65:              | prElems (el::rest) = (pr el; nlindent ind; print sep; prElems rest)
        !            66:              | prElems [] = ()
        !            67:         in prElems elems
        !            68:        end
        !            69: 
        !            70:   end (* local *)
        !            71: 
        !            72: end (* structure PrintUtil *)

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.