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;
|