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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
|
(**************************************************************************)
(* Cameleon *)
(* *)
(* Copyright (C) 2002 Institut National de Recherche en Informatique et *)
(* en Automatique. All rights reserved. *)
(* *)
(* This program is free software; you can redistribute it and/or modify *)
(* it under the terms of the GNU General Public License as published by *)
(* the Free Software Foundation; either version 2 of the License, or *)
(* any later version. *)
(* *)
(* This program 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 General Public License for more details. *)
(* *)
(* You should have received a copy of the GNU General Public License *)
(* along with this program; if not, write to the Free Software *)
(* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA *)
(* 02111-1307 USA *)
(* *)
(* Contact: Maxence.Guesdon@inria.fr *)
(**************************************************************************)
(** This module is the interface of the Configwin library. *)
(** {2 Types} *)
(** This type represents the different kinds of parameters. *)
type parameter_kind;;
(** This type represents the structure of the configuration window. *)
type configuration_structure =
| Section of string * parameter_kind list
(** label of the section, parameters *)
| Section_list of string * configuration_structure list
(** label of the section, list of the sub sections *)
;;
(** To indicate what button pushed the user when the window is closed. *)
type return_button =
Return_apply
(** The user clicked on Apply at least once before
closing the window with Cancel or the window manager. *)
| Return_ok
(** The user closed the window with the ok button. *)
| Return_cancel
(** The user closed the window with the cancel
button or the window manager but never clicked
on the apply button.*)
(** {2 The key option class (to use with the {!Uoptions} library)} *)
module KeyOption : sig
val string_to_key : string -> (Gdk.Tags.modifier list * int)
val key_to_string : (Gdk.Tags.modifier list * int) -> string
val t : (Gdk.Tags.modifier list * int) Uoptions.option_class
end
(** {2 Functions to create parameters} *)
(** [string label value] creates a string parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val string : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) -> string -> string -> parameter_kind
(** [bool label value] creates a boolean parameter.
@param editable indicate if the value is editable (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val bool : ?editable: bool -> ?help: string ->
?f: (bool -> unit) -> string -> bool -> parameter_kind
(** [strings label value] creates a string list parameter.
@param editable indicate if the value is editable (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
@param add the function returning a list of strings when the user wants to add strings
(default returns an empty list).
@param eq the comparison function, used not to have doubles in list. Default
is [Pervasives.(=)]. If you want to allow doubles in the list, give a function
always returning false.
*)
val strings : ?editable: bool -> ?help: string ->
?f: (string list -> unit) ->
?eq: (string -> string -> bool) ->
?add: (unit -> string list) ->
string -> string list -> parameter_kind
(** [list label f_strings value] creates a list parameter.
[f_strings] is a function taking a value and returning a list
of strings to display it. The list length should be the same for
any value, and the same as the titles list length. The [value]
is the initial list.
@param editable indicate if the value is editable (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
@param eq the comparison function, used not to have doubles in list. Default
is [Pervasives.(=)]. If you want to allow doubles in the list, give a function
always returning false.
@param edit an optional function to use to edit an element of the list.
The function returns an element, no matter if element was changed or not.
When this function is given, a "Edit" button appears next to the list.
@param add the function returning a list of values when the user wants to add values
(default returns an empty list).
@param titles an optional list of titles for the list. If the [f_strings]
function returns a list with more than one element, then you must give
a list of titles.
@param color an optional function returning the optional color for a given element.
This color is used to display the element in the list. The default function returns
no color for any element.
*)
val list : ?editable: bool -> ?help: string ->
?f: ('a list -> unit) ->
?eq: ('a -> 'a -> bool) ->
?edit: ('a -> 'a) ->
?add: (unit -> 'a list) ->
?titles: string list ->
?color: ('a -> string option) ->
string ->
('a -> string list) ->
'a list ->
parameter_kind
(** [color label value] creates a color parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val color : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) -> string -> string -> parameter_kind
(** [font label value] creates a font parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val font : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) -> string -> string -> parameter_kind
(** [combo label choices value] creates a combo parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
@param new_allowed indicate if a entry not in the list of choices is accepted
(default is [false]).
@param blank_allowed indicate if the empty selection [""] is accepted
(default is [false]).
*)
val combo : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) ->
?new_allowed: bool -> ?blank_allowed: bool ->
string -> string list -> string -> parameter_kind
(** [text label value] creates a text parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the box for the text must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val text : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) -> string -> string -> parameter_kind
(** Same as {!Configwin.text} but html bindings are available
in the text widget. Use the [configwin_html_config] utility
to edit your bindings.
*)
val html : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) -> string -> string -> parameter_kind
(** [filename label value] creates a filename parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val filename : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: (string -> unit) -> string -> string -> parameter_kind
(** [filenames label value] creates a filename list parameter.
@param editable indicate if the value is editable (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
@param eq the comparison function, used not to have doubles in list. Default
is [Pervasives.(=)]. If you want to allow doubles in the list, give a function
always returning false.
*)
val filenames : ?editable: bool -> ?help: string ->
?f: (string list -> unit) ->
?eq: (string -> string -> bool) ->
string -> string list -> parameter_kind
(** [date label value] creates a date parameter.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
@param f_string the function used to display the date as a string. The parameter
is a tupe [(day,month,year)], where [month] is between [0] and [11]. The default
function creates the string [year/month/day].
*)
val date : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: ((int * int * int) -> unit) ->
?f_string: ((int * int * int -> string)) ->
string -> (int * int * int) -> parameter_kind
(** [hotkey label value] creates a hot key parameter.
A hot key is defined by a list of modifiers and a key code.
@param editable indicate if the value is editable (default is [true]).
@param expand indicate if the entry widget must expand or not (default is [true]).
@param help an optional help message.
@param f the function called to apply the value (default function does nothing).
*)
val hotkey : ?editable: bool -> ?expand: bool -> ?help: string ->
?f: ((Gdk.Tags.modifier list * int) -> unit) ->
string -> (Gdk.Tags.modifier list * int) -> parameter_kind
val modifiers : ?editable: bool -> ?expand: bool -> ?help: string ->
?allow:(Gdk.Tags.modifier list) ->
?f: (Gdk.Tags.modifier list -> unit) ->
string -> Gdk.Tags.modifier list -> parameter_kind
(** [custom box f expand] creates a custom parameter, with
the given [box], the [f] function is called when the user
wants to apply his changes, and [expand] indicates if the box
must expand in its father.
@param label if a value is specified, a the box is packed into a frame.
*)
val custom : ?label: string -> GPack.box -> (unit -> unit) -> bool -> parameter_kind
(** {2 Functions creating configuration windows and boxes} *)
(** This function takes a configuration structure and creates a window
to configure the various parameters.
@param apply this function is called when the apply button is clicked, after
giving new values to parameters.
*)
val edit :
?apply: (unit -> unit) ->
string ->
?width:int ->
?height:int ->
configuration_structure list ->
return_button
(** This function takes a configuration structure and creates a window used
to get the various parameters from the user. It is the same window as edit but
there is no apply button.*)
val get :
string ->
?width:int ->
?height:int ->
configuration_structure list ->
return_button
(** This function takes a list of parameter specifications and
creates a window to configure the various parameters.
@param apply this function is called when the apply button is clicked, after
giving new values to parameters.*)
val simple_edit :
?apply: (unit -> unit) ->
string ->
?width:int ->
?height:int ->
parameter_kind list -> return_button
(** This function takes a list of parameter specifications and
creates a window to configure the various parameters,
without Apply button.*)
val simple_get :
string ->
?width:int ->
?height:int ->
parameter_kind list -> return_button
(** Create a [GPack.box] with the list of given parameters,
and the given list of buttons (defined by their label and callback).
Before calling the callback of a button, the [apply] function
of each parameter is called.
*)
val box : parameter_kind list ->
(string * (unit -> unit)) list -> GPack.box
(** Create a [GPack.box] with the list of given configuration structure list,
and the given list of buttons (defined by their label and callback).
Before calling the callback of a button, the [apply] function
of each parameter is called.
*)
val tabbed_box : configuration_structure list ->
(string * (unit -> unit)) list -> GPack.box
|