File: FlagPrint.sml

package info (click to toggle)
polyml 5.7.1-5
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid
  • size: 40,616 kB
  • sloc: cpp: 44,142; ansic: 26,963; sh: 22,002; asm: 13,486; makefile: 602; exp: 525; python: 253; awk: 91
file content (54 lines) | stat: -rw-r--r-- 2,133 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
(*
    Copyright (c) 2001, 2015
        David C.J. Matthews

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License version 2.1 as published by the Free Software Foundation.
    
    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    Lesser General Public License for more details.
    
    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*)
functor FlagPrint(structure BITS: BIT_FLAGS) =
struct
    (* Auxiliary function to create a function to print out bit flags.
       The function must actually be installed by the caller because
       it has to be called with the type itself. *)
    fun createFlagPrinter (flagTable: (BITS.flags * string) list) =
    let
        fun accumulateFlags _ [] = []
         |  accumulateFlags f ((w, s)::t) =
            if BITS.allSet(w, f) then s :: accumulateFlags(BITS.clear(w, f)) t
            else accumulateFlags f t
    
        fun printFlags depth _ x =
            (* This is just the code to print a list. *)
            let
                open PolyML
              val stringFlags = accumulateFlags x flagTable
              fun plist [] _ = []
               |  plist _ 0 = [PrettyString "..."]
               |  plist [h]    _ = [PrettyString h]
               |  plist (h::t) depth =
                        PrettyString(h ^ ",") ::
                        PrettyBreak (1, 0) ::
                        plist t (depth - 1)
            in
              PrettyBlock (3, false, [],
                PrettyString "[" ::
                    ((if depth <= 0 then [PrettyString "..."]
                          else plist stringFlags depth) @
                    [PrettyString "]"]
                    )
                )
            end
    in
        printFlags
    end;
end;