lyx_mirror/src/frontends/gnome
Angus Leeming 02e9472374 doxygen fixes.
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@5347 a592a061-630c-0410-9148-cb99ea01b6c8
2002-09-26 08:57:43 +00:00
..
dialogs
.cvsignore
accessors.py
ChangeLog doxygen fixes. 2002-09-26 08:57:43 +00:00
Dialogs.C doxygen fixes. 2002-09-26 08:57:43 +00:00
FileDialog.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GAbout.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GAbout.h doxygen fixes. 2002-09-26 08:57:43 +00:00
GError.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GError.h doxygen fixes. 2002-09-26 08:57:43 +00:00
GERT.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GERT.h doxygen fixes. 2002-09-26 08:57:43 +00:00
GFloat.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GFloat.h doxygen fixes. 2002-09-26 08:57:43 +00:00
GLog.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GLog.h doxygen fixes. 2002-09-26 08:57:43 +00:00
gnome_helpers.C Copyright notices 2002-09-25 14:26:13 +00:00
gnome_helpers.h Copyright notices 2002-09-25 14:26:13 +00:00
GnomeBase.C Copyright notices 2002-09-25 14:26:13 +00:00
GnomeBase.h doxygen fixes. 2002-09-26 08:57:43 +00:00
gnomeBC.C Copyright notices 2002-09-25 14:26:13 +00:00
gnomeBC.h Copyright notices 2002-09-25 14:26:13 +00:00
GPreamble.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GPreamble.h doxygen fixes. 2002-09-26 08:57:43 +00:00
GTabularCreate.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GTabularCreate.h doxygen fixes. 2002-09-26 08:57:43 +00:00
GUIRunTime.C Copyright notices 2002-09-25 14:26:13 +00:00
GUrl.C doxygen fixes. 2002-09-26 08:57:43 +00:00
GUrl.h doxygen fixes. 2002-09-26 08:57:43 +00:00
Makefile.am
pixbutton.h Copyright notices 2002-09-25 14:26:13 +00:00
README
support.c
support.h
Timeout_pimpl.C Copyright notices 2002-09-25 14:26:13 +00:00
Timeout_pimpl.h Copyright notices 2002-09-25 14:26:13 +00:00

GNOME FRONT END
===============

Firstly, this stuff is pre-alpha.  I don't use it so you shouldn't
either.  At all, no exceptions :). Secondly I'm no c++ guru, I'm
learning as I go along so if something looks stupid, there's a good
chance it is.

Adding Dialogs
--------------

The GNOME frontend of LyX uses libglade to draw the dialogs.  The base
(GnomeBase.C) class handles the drawing and activating of the Dialogs,
for an example of contructing a simple dialog see GUrl.[Ch]

FormUrl::FormUrl(ControlUrl & c)
	: FormCB<ControlUrl>(c, "FormUrl")
{}



To manipulate a widget you extract a pointer using getWidget(string).

If you look at FormUrl you'll see that there are a number of
helper functions at the bottom of the .C file.  These are
automatically generated by accessors.py

For accessors.py to work glade files now must adhere to the following
conventions: 

 * The root widget and the file should be named after the form (i.e
   FormTabularCreate & FormTabularCreate.glade)  
 * Functional widgets, those actually used rather than the filler
   widgets like Gtk::HBox etc,  should have an r_ as the first two
   characters of their name. (see below)

To make the build system include your new dialog edit Makefile.am as
follows:
 1) make clean in src/frontends/gnome/
 2) Add GX.C and GX.h to libgnome_la_SOURCES
 3) Remove FormX.lo and form_x.lo (if applicable) from xforms_objects
 4) make clean && make in src/frontends/
 5) make in src/


Using accessors.py
------------------

Usage:

python accessors.py glade_ui_file DialogClass

e.g

python accessors.py FormTabularCreate.glade GTabularCreate

Accessors.py will write the helper functions to DialogClass.C_gen and
the function declarations to DialogClass.g_gen.  To ensure the widgets
you're interested in are made available using this method, prefix the
widgets name with r_ when you build the dialog in Glade.