author | haftmann |
Wed, 21 Jan 2009 23:40:23 +0100 | |
changeset 29609 | a010aab5bed0 |
parent 29581 | b3b33e0298eb |
child 29617 | b36bcbc1be3a |
permissions | -rw-r--r-- |
28941 | 1 |
(* Title: Pure/General/binding.ML |
2 |
Author: Florian Haftmann, TU Muenchen |
|
3 |
||
4 |
Structured name bindings. |
|
5 |
*) |
|
6 |
||
7 |
signature BASIC_BINDING = |
|
8 |
sig |
|
29581 | 9 |
type binding |
28941 | 10 |
val long_names: bool ref |
11 |
val short_names: bool ref |
|
12 |
val unique_names: bool ref |
|
13 |
end; |
|
14 |
||
15 |
signature BINDING = |
|
16 |
sig |
|
17 |
include BASIC_BINDING |
|
18 |
type T |
|
28965 | 19 |
val name_pos: string * Position.T -> T |
20 |
val name: string -> T |
|
21 |
val empty: T |
|
22 |
val map_base: (string -> string) -> T -> T |
|
23 |
val qualify: string -> T -> T |
|
28941 | 24 |
val add_prefix: bool -> string -> T -> T |
25 |
val map_prefix: ((string * bool) list -> T -> T) -> T -> T |
|
28965 | 26 |
val is_empty: T -> bool |
29006 | 27 |
val base_name: T -> string |
28965 | 28 |
val pos_of: T -> Position.T |
29 |
val dest: T -> (string * bool) list * string |
|
29338 | 30 |
val separator: string |
31 |
val is_qualified: string -> bool |
|
28941 | 32 |
val display: T -> string |
33 |
end |
|
34 |
||
35 |
structure Binding : BINDING = |
|
36 |
struct |
|
37 |
||
38 |
(** global flags **) |
|
39 |
||
40 |
val long_names = ref false; |
|
41 |
val short_names = ref false; |
|
42 |
val unique_names = ref true; |
|
43 |
||
44 |
||
29338 | 45 |
(** qualification **) |
46 |
||
47 |
val separator = "."; |
|
48 |
val is_qualified = exists_string (fn s => s = separator); |
|
49 |
||
50 |
fun reject_qualified kind s = |
|
51 |
if is_qualified s then |
|
52 |
error ("Attempt to declare qualified " ^ kind ^ " " ^ quote s) |
|
53 |
else s; |
|
54 |
||
55 |
||
28941 | 56 |
(** binding representation **) |
57 |
||
58 |
datatype T = Binding of ((string * bool) list * string) * Position.T; |
|
59 |
(* (prefix components (with mandatory flag), base name, position) *) |
|
60 |
||
28965 | 61 |
fun name_pos (name, pos) = Binding (([], name), pos); |
62 |
fun name name = name_pos (name, Position.none); |
|
63 |
val empty = name ""; |
|
28941 | 64 |
|
65 |
fun map_binding f (Binding (prefix_name, pos)) = Binding (f prefix_name, pos); |
|
66 |
||
28965 | 67 |
val map_base = map_binding o apsnd; |
68 |
||
69 |
fun qualify_base path name = |
|
70 |
if path = "" orelse name = "" then name |
|
29338 | 71 |
else path ^ separator ^ name; |
28965 | 72 |
|
73 |
val qualify = map_base o qualify_base; |
|
29006 | 74 |
(*FIXME should all operations on bare names move here from name_space.ML ?*) |
28941 | 75 |
|
29208
b0c81b9a0133
Use prefix component of bindings for locale prefixes.
ballarin
parents:
29006
diff
changeset
|
76 |
fun add_prefix sticky "" b = b |
29338 | 77 |
| add_prefix sticky prfx b = (map_binding o apfst) |
78 |
(cons ((*reject_qualified "prefix"*) prfx, sticky)) b; |
|
28941 | 79 |
|
80 |
fun map_prefix f (Binding ((prefix, name), pos)) = |
|
28965 | 81 |
f prefix (name_pos (name, pos)); |
82 |
||
83 |
fun is_empty (Binding ((_, name), _)) = name = ""; |
|
29006 | 84 |
fun base_name (Binding ((_, name), _)) = name; |
28965 | 85 |
fun pos_of (Binding (_, pos)) = pos; |
86 |
fun dest (Binding (prefix_name, _)) = prefix_name; |
|
28941 | 87 |
|
88 |
fun display (Binding ((prefix, name), _)) = |
|
89 |
let |
|
90 |
fun mk_prefix (prfx, true) = prfx |
|
91 |
| mk_prefix (prfx, false) = enclose "(" ")" prfx |
|
92 |
in if not (! long_names) orelse null prefix orelse name = "" then name |
|
93 |
else space_implode "." (map mk_prefix prefix) ^ ":" ^ name |
|
94 |
end; |
|
95 |
||
29581 | 96 |
type binding = T; |
97 |
||
28941 | 98 |
end; |
99 |
||
100 |
structure Basic_Binding : BASIC_BINDING = Binding; |
|
101 |
open Basic_Binding; |