~ubuntu-branches/ubuntu/lucid/lablgtk2/lucid

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
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
             LablGTK2 : an interface to the GIMP Tool Kit

Needed:
	ocaml-3.07 or 3.08
	gtk+-2.x (preferably gtk+-2.4.x)
          (avoid gtk+-2.4.0, as the GtkTree widget is broken)
	GNU make (there is no standard for conditionals)

Info/upgrades:
        http://wwwfun.kurims.kyoto-u.ac.jp/soft/olabl/lablgtk.html

Status:
  LablGtk2 is now pretty stable, but it has not been as thoroughly
  tested as LablGtk.
  
  Support for the old text widget has been dropped, but it is
  replaced by a new one, much more powerful (thanks to Benjamin
  Monate).

  Another important change in gtk-2 is the use of unicode (utf8) for
  all strings. If you use non-ascii strings, you must imperatively
  convert them to unicode. This can be done with the
  [Glib.Convert.locale_to_utf8] function. If your input is already in
  utf8, it is still a good idea to validate it with
  Glib.Utf8.validate, as malformed utf8 strings may cause segmentation
  faults.
  Note that setlocale is now always called (except if you set
  GTK_SETLOCALE to 0 in the environment), but LC_NUMERIC is reverted
  to "C" to avoid problems with floating point conversion in Caml.

  There are of course many other changes and additions.

  Note that some widgets are only supported in newer versions of GTK+
  (post 2.3). If you use them in older versions, you will get a runtime
  error:
    Failure "Gobject.unsafe_create : type GtkActionGroup is not yet defined"

How to compile:

  You should normally not need to modify Makefiles.
  
  In case you are using the CVS version first type "aclocal && autoconf".
  
  Type "./configure && make world && make install" to compile 
  with all supported options enabled (libgl, libglade, libgnomecanvas, 
  librsvg, native compilation, thread support).
  
  You may use "./configure --help" to check for the different 
  configuration options.

  Lablgtk2 specific options are:

	--with-libdir=/path: install libs in /path/lablgtk2 
			     and /path/stublibs
	--with-gl --without-gl: override autodetected GtkGLArea support. 
				Requires LablGL
	--with-glade --without-glade: override autodetected libglade support
	--with-rsvg --without-rsvg: override autodetected librsvg support
	--with-gnomecanvas --without-gnomecanvas: 
		override autodetected libgnomecanvas support
	--enable-debug: enable debug mode

  "make install DESTDIR=..." prefixes the installation
  directories with DESTDIR.

  A META file for findlib is provided, but it only handles the
  base library: I have no idea on how to avoid a combinatorial
  explosion with the various extensions.

Contents:

	gdk.ml		low-level interface to the General Drawing Kit
	gtk.ml		low-level interface to the GIMP Tool Kit
	gtkThread.ml	main loop for threaded version
	g[A-Z]*.ml	object-oriented interface to GTK
	gdkObj.ml	object-oriented interface to GDK

	lablgtk2	toplevel

	examples/*.ml	various examples

        applications/browser    an ongoing port of ocamlbrowser
        applications/unison     a patch for unison-2.9.45

How to run the examples:
  In the examples directory just type:
	lablgtk2 ???.ml

  Before installing lablgtk2 you have to be more explicit:
        setenv CAML_LD_LIBRARY_PATH ../src  (or export CAML..PATH=../src)
	../src/lablgtktop -w s -I ../src ???.ml

How to link them:
  lablgtktop contains an extra module GtkInit, whose only contents is:
        let locale = GtkMain.Main.init ()
  You must either add this line, or add this module to your link,
  before calling any Gtk function.
  ocamlc -I +lablgtk2 -w s lablgtk.cma gtkInit.cmo ???.ml -o ???

How to use the threaded toplevel:

	% lablgtk2 -thread           (or ./lablgtktop_t before installing)
	        Objective Caml version 3.09
	
	# let w = GWindow.window ~show:true ();;
        # let b = GButton.button ~packing:w#add ~label:"Hello!" ();;

  You should at once see a window appear, and then a button.
  The GTK main loop is running in a separate thread. Any command
  is immediately reflected by the system.
  Beware that with bytecode threads, you cannot switch threads within
  a callback. The only thread related command you may use in a
  callback is Thread.create. Calling blocking operations may cause
  deadlocks. On the other hand, all newly created threads will be run
  outside of the callback, so they can use all thread operations.
  There is no such problem for posix and win32 threads, but win32
  threads have problems of their own. See the windows port section
  lower.

  When using threads in a stand-alone application, you must link with
  gtkThread.cmo and call GtkThread.main in place of GMain.main.

Structure of the (raw) Gtk* modules:

  These modules are composed of one submodule for each class.
  Signals specific to a widget are in a Signals inner module.
  A setter function is defined to give access to set_param functions.

Structure of the G[A-Z]* modules:

  These modules provide classes to wrap the raw function calls.
  Here are the widget classes contained in each module:

  GPango        Pango font handling
  GDraw         Gdk pixmaps, etc...
  GObj		gtkobj, widget, style
  GData		data, adjustment, tooltips
  GContainer	container, item_container
  GWindow	window, dialog, color_selection_dialog, file_selection, plug
  GPack		box, button_box, table, fixed, layout, packer, paned, notebook
  GBin  	scrolled_window, event_box, handle_box, frame,
		aspect_frame, viewport, socket
  GButton	button, toggle_button, check_button, radio_button, toolbar
  GMenu		menu_item, tearoff_item, check_menu_item, radio_menu_item,
		menu_shell, menu, option_menu, menu_bar, factory
  GMisc		separator, statusbar, calendar, drawing_area,
		misc, arrow, image, pixmap, label, tips_query,
                color_selection, font_selection
  GTree		tree_item, tree, view (also tree/list_store, model)
  GList		list_item, liste, clist
  GEdit		editable, entry, spin_button, combo
  GRange	progress, progress_bar, range, scale, scrollbar
  GText		view (also buffer, iter, mark, tag, tagtable)

  While subtyping follows the Gtk widget hierarchy, you cannot always
  use width subtyping (i.e. #super is not unifiable with all the
  subclasses of super). Still, it works for some classes, like
  #widget and #container, and allows subtyping without coercion towards
  these classes (cf. #container in examples/pousse.ml for instance).

  Practically, each widget class is composed of:
  * a coerce method, returning the object coerced to the type widget.
  * an as_widget method, returning the raw Gtk widget used for packing, etc...
  * a destroy method, sending the destroy signal to the object.
  * a get_oid method, the equivalent of Oo.id for Gtk objects.
  * a connect sub-object, allowing one to widget specific
    signals (this is what prevents width subtyping in subclasses.)
  * a misc sub-object, giving access to miscellanous functionality of
    the basic gtkwidget class, and a misc#connect sub-object.
  * an event sub-object, for Xevent related functions (only if the widget
    has an Xwindow), and an event#connect sub-object.
  * a drag  sub-object, containing drag and drop functions,
    and a drag#connect sub-object.
  * widget specific methods.

  Here is a diagram of the structure (- for methods, + for sub-objects)
        - coerce : widget
        - as_widget : Gtk.widget obj
        - destroy : unit -> unit
        - get_oid : int
        - ...
        + connect : mywidget_signals
        |   - after
        |   - signal_name : callback:(... -> ...) -> GtkSignal.id
        + misc : misc_ops
        |   - show, hide, disconnect, ...
        |   + connect : misc_signals
        + drag : drag_ops
        |   - ...
        |   + connect : drag_signals
        + event : event_ops
        |   - add, ...
        |   + connect : event_signals

  You create a widget by [<Module>.<widget name> options ... ()].
  Many optional arguments are admitted. The last two of them, packing:
  and show:, allow you respectively to call a function on your newly
  created widget, and to decide wether to show it immediately or not.
  By default all widgets except toplevel windows (GWindow module) are
  shown immediately.

Default arguments:
  For many constructor or method arguments, default values are provided.
  Generally, this default value is defined by GTK, and you must refer
  to GTK's documentation.
  For ML defined defaults, usually default values are either false, 0, None
  or `NONE, according to the expected type.
  Important exceptions are ~show, which default to true in all widgets
  except those in GWindow, and ~fill, which defaults to true or `BOTH.

Note about unit as method argument:

  O'Caml introduces no distinction between methods having side-effects
  and methods simply returning a value. In practice, this is
  confusing, and awkward when used as callbacks. For this reason all
  methods having noticeable side-effects should take arguments, and
  unit if they have no argument.

ML-side signals:

  The GUtil module provides two kinds of utilities: a memo table, to be
  able to dynamically cast widgets to their original class, and more
  interesting ML-side signals.
  With ML-side signals, you can combine LablGTK widgets into your own
  components, and add signals to them. Later you can connect to these
  signals, just like GTK signals. This proved very efficient to
  develop complex applications, abstracting the plumbing between
  various components. Explanations are provided in GUtil.mli.

Comments on some widgets:
  GText has changed a lot since the alpha release. In particular, most
  movements with GText.iter are now functional. You can still modify
  destructively by using the #nocopy interface.

Contributed components:

  The GToolbox module contains contributed components to help you build
  your applications.

Memory management:

  Important efforts have been dedicated to cooperate with Gtk's
  reference counting mechanism. As a result you should generally be
  able to use Gdk/Gtk data structures without caring about memory
  management. They will be freed when nobody points to them any more.
  This also means that you do not need to pay too much attention to
  whether a data structure is still alive or not. If it is not, you
  should get an error rather than a core dump.
  The case of Gtk objects deserves special care. Since they are
  interactive, we cannot just destroy them when they are no longer
  referenced. They have to be explicitely destroyed. If a widget was
  added to a container widget, it will automatically be destroyed when
  its last container is destroyed. For this reason you need only
  destroy toplevel widgets.

  IMPORTANT: Some Gtk data structures are allocated in the Caml heap,
  and there use in signals (Gtk functions internally cally callbacks)
  relies on their address being stable during a function call. For
  this reason automatic compation is disabled in GtkMain. If you need
  it, you may use compaction through Gc.compact where it is safe
  (timeouts, other threads...), but do not enable automatic compaction.

LibGlade support:

  There is support for Glade generated XML UI description files, using
  libglade. You can read in a file, access to widgets, and define
  callbacks.
  A tool for extracting widget definitions from glade description is
  provided. It generates a wrapper class, and you can then generate an
  object corresponding to the intended layout, and access individual
  widgets through its methods. Example:

        % lablgladecc2 project1.glade > project1.ml
        % lablgtk2 -thread
        # #use "project1.ml" ;;
        class window1 : ...
        # let w1 = new window1 () ;;
        # w1#bind ~name:"on_paste1_activate"
            ~callback:(fun () -> w1#text1#insert "some text\n");;

  See lablgladecc2 -help for other features (tracing and source
  embedding).
  The executable must be linked with lablglade.cma.

GL extension:

  You can use lablgtk in combination with LablGL

  * get and install lablGL 1.02 from
      http://wwwfun.kurims.kyoto-u.ac.jp/soft/olabl/lablgl.html
  * get and install gtkglarea-1.99.0.tar.gz from
      ftp://ftp.gnome.org/pub/gnome/sources/gtkglarea/1.99/
    or any other gnome mirror site
  * reconfigure

  You can then use the widget GlGtk.gl_area as an OpenGL window.
  Some examples are in examples/GL, but basically any LablGL example
  can be easily ported.
  The executable must be linked with both lablgl.cma and
  lablgtkgl.cma.

SVG support:

  This binding was contributed by Olivier Andrieu.
  It requires librsvg-2.x (preferably 2.2.x).
  See an example in examples/rsvg.
  The executable must be linked with lablrsvg.cma.

GnomeCanvas support:

  This binding was also contributed by Olivier Andrieu.
  It requires libgnomecanvas-2.x.
  See examples in examples/canvas.
  The executable must be linked with lablgnomecanvas.cma.

Windows port

  See README.win32 for detailed information on installation.

  If you want to use threads, you must be aware of windows specific
  restrictions; see for instance:
     http://groups.yahoo.com/group/gimpwin-dev/message/1828
  I.e. all GTK related calls must occur in the same thread, the one
  that runs the main loop. If you want to call them from other threads
  you need to do some forwarding. Fortunately, with a functional
  language this is easy. Two functions,
    val async : ('a -> unit) -> 'a -> unit
    val sync : ('a -> 'b) -> 'a -> 'b
  are available in the GtkThread module to help you. They will forward
  your call to the main thread (between handling two GUI events). This
  can be either asynchronous or synchronous. In the synchronous case,
  beware of deadlocks (the trivial case, when you are calling from the
  same thread, is properly avoided). Note also that since callbacks
  are always called from the main loop thread, you can freely use GTK
  in them. Also, non-graphical operations are thread-safe.
  Here is an example using the lablgtk toplevel with threads:
	% lablgtk2.bat -thread
	        Objective Caml version 3.09

        # open GtkThread;;	
	# let w = sync (GWindow.window ~show:true) ();;
        # let b = sync (GButton.button ~packing:w#add ~label:"Hello!") ();;
        # b#connect#clicked (fun () -> prerr_endline "Hello");;

Authors:
	Jacques Garrigue <garrigue@math.nagoya-u.ac.jp>
	Benjamin Monate  <benjamin.monate@free.fr>
        Olivier Andrieu  <oandrieu@nerim.net>
	Jun Furuse       <furuse@yl.is.s.u-tokyo.ac.jp>
  For lablgtk1:
	Hubert Fauque  <hubert.fauque@wanadoo.fr>
	Koji Kagawa    <kagawa@eng.kagawa-u.ac.jp>
				   
Bug reports:
	Jacques Garrigue <garrigue@math.nagoya-u.ac.jp>

$Id: README,v 1.84 2005/10/27 00:45:27 garrigue Exp $