aboutsummaryrefslogtreecommitdiffstats
path: root/help/devel
diff options
context:
space:
mode:
authorFederico Mena Quintero <federico@helixcode.com>2000-07-18 05:08:41 +0800
committerFederico Mena Quintero <federico@src.gnome.org>2000-07-18 05:08:41 +0800
commite38c9ea0ed0f14ce563d355a0cea24460df26363 (patch)
treea54e0ce7fc2887466d6c37df39ac478f2aaa2c93 /help/devel
parentfab3b8e23e8ded8e8dba0c2300e49914e35d9145 (diff)
downloadgsoc2013-evolution-e38c9ea0ed0f14ce563d355a0cea24460df26363.tar.gz
gsoc2013-evolution-e38c9ea0ed0f14ce563d355a0cea24460df26363.tar.zst
gsoc2013-evolution-e38c9ea0ed0f14ce563d355a0cea24460df26363.zip
New <book> toplevel for the Evolution Developer's Guide.
2000-07-17 Federico Mena Quintero <federico@helixcode.com> * evolution-devel-guide.sgml: New <book> toplevel for the Evolution Developer's Guide. * calendar/evolution-calendar.sgml: New <part> for the calendar developer's documentation. * calendar/architecture.sgml: New <chapter> for the calendar architecture. * calendar/reference.sgml: New <reference> for the calendar API reference. svn path=/trunk/; revision=4191
Diffstat (limited to 'help/devel')
-rw-r--r--help/devel/.cvsignore4
-rw-r--r--help/devel/ChangeLog13
-rw-r--r--help/devel/Makefile.am64
-rw-r--r--help/devel/calendar/.cvsignore2
-rw-r--r--help/devel/calendar/Makefile.am6
-rw-r--r--help/devel/calendar/architecture.sgml17
-rw-r--r--help/devel/calendar/cal-client/.cvsignore3
-rw-r--r--help/devel/calendar/cal-client/Makefile.am76
-rw-r--r--help/devel/calendar/cal-client/evolution-cal-client-decl.txt127
-rw-r--r--help/devel/calendar/cal-client/evolution-cal-client-sections.txt36
-rw-r--r--help/devel/calendar/cal-client/evolution-cal-client.args0
-rw-r--r--help/devel/calendar/cal-client/evolution-cal-client.hierarchy2
-rw-r--r--help/devel/calendar/cal-client/evolution-cal-client.signals21
-rw-r--r--help/devel/calendar/cal-client/evolution-cal-client.types4
-rw-r--r--help/devel/calendar/cal-client/tmpl/cal-client.sgml205
-rw-r--r--help/devel/calendar/cal-client/tmpl/evolution-cal-client-unused.sgml0
-rw-r--r--help/devel/calendar/evolution-calendar.sgml51
-rw-r--r--help/devel/calendar/public-reference.sgml20
-rw-r--r--help/devel/calendar/reference.sgml20
-rw-r--r--help/devel/evolution-devel-guide.sgml44
20 files changed, 715 insertions, 0 deletions
diff --git a/help/devel/.cvsignore b/help/devel/.cvsignore
new file mode 100644
index 0000000000..c24a54fbcc
--- /dev/null
+++ b/help/devel/.cvsignore
@@ -0,0 +1,4 @@
+Makefile
+Makefile.in
+html
+evolution-devel-guide.html
diff --git a/help/devel/ChangeLog b/help/devel/ChangeLog
new file mode 100644
index 0000000000..b273c5c657
--- /dev/null
+++ b/help/devel/ChangeLog
@@ -0,0 +1,13 @@
+2000-07-17 Federico Mena Quintero <federico@helixcode.com>
+
+ * evolution-devel-guide.sgml: New <book> toplevel for the
+ Evolution Developer's Guide.
+
+ * calendar/evolution-calendar.sgml: New <part> for the calendar
+ developer's documentation.
+
+ * calendar/architecture.sgml: New <chapter> for the calendar
+ architecture.
+
+ * calendar/reference.sgml: New <reference> for the calendar API
+ reference.
diff --git a/help/devel/Makefile.am b/help/devel/Makefile.am
new file mode 100644
index 0000000000..63f190c190
--- /dev/null
+++ b/help/devel/Makefile.am
@@ -0,0 +1,64 @@
+SUBDIRS = calendar
+
+# The name of the module.
+DOC_MODULE=evolution-devel-guide
+
+# The top-level SGML file.
+DOC_MAIN_SGML_FILE=evolution-devel-guide.sgml
+
+HTML_DIR=$(datadir)/gnome/html
+
+TARGET_DIR=$(HTML_DIR)/$(DOC_MODULE)
+
+evolution_devel_guidedir = $(HTML_DIR)
+evolution_devel_guide_DATA = \
+ evolution-devel-guide.html
+
+content_files = \
+ evolution-devel-guide.sgml
+
+EXTRA_DIST = \
+ $(evolution_devel_guide_DATA) \
+ $(content_files)
+
+if ENABLE_GTK_DOC
+evolution-devel-guide.html: html/book1.html
+ -cd $(srcdir) && cp html/book1.html evolution-devel-guide.html
+else
+evolution-devel-guide.html:
+endif
+
+html/book1.html: $(content-files)
+ $(MAKE) html
+
+html:
+ test -d $(srcdir)/html || mkdir $(srcdir)/html
+ -cd $(srcdir)/html && gtkdoc-mkhtml $(DOC_MODULE) ../$(DOC_MAIN_SGML_FILE)
+
+clean-local:
+ rm -f *~ *.bak *.signals *-unused.txt
+
+maintainer-clean-local: clean
+ cd $(srcdir) && rm -rf html
+
+install-data-local:
+ $(mkinstalldirs) $(DESTDIR)$(TARGET_DIR)
+ (installfiles=`echo $(srcdir)/html/*.html`; \
+ if test "$$installfiles" = '$(srcdir)/html/*.html'; \
+ then echo '-- Nothing to install' ; \
+ else \
+ for i in $$installfiles; do \
+ echo '-- Installing '$$i ; \
+ $(INSTALL_DATA) $$i $(DESTDIR)$(TARGET_DIR); \
+ done; \
+ echo '-- Installing $(srcdir)/html/index.sgml' ; \
+ $(INSTALL_DATA) $(srcdir)/html/index.sgml $(DESTDIR)$(TARGET_DIR); \
+ echo '-- Fixing Crossreferences' ; \
+ gtkdoc-fixxref --module=$(DOC_MODULE) --html-dir=$(HTML_DIR)|| true; \
+ fi)
+
+dist-hook:
+ mkdir $(distdir)/html
+ -cp $(srcdir)/html/*.html $(srcdir)/html/*.css $(distdir)/html
+
+.PHONY: html
diff --git a/help/devel/calendar/.cvsignore b/help/devel/calendar/.cvsignore
new file mode 100644
index 0000000000..282522db03
--- /dev/null
+++ b/help/devel/calendar/.cvsignore
@@ -0,0 +1,2 @@
+Makefile
+Makefile.in
diff --git a/help/devel/calendar/Makefile.am b/help/devel/calendar/Makefile.am
new file mode 100644
index 0000000000..7efde02896
--- /dev/null
+++ b/help/devel/calendar/Makefile.am
@@ -0,0 +1,6 @@
+SUBDIRS = cal-client
+
+EXTRA_DIST = \
+ architecture.sgml \
+ evolution-calendar.sgml \
+ reference.sgml
diff --git a/help/devel/calendar/architecture.sgml b/help/devel/calendar/architecture.sgml
new file mode 100644
index 0000000000..b174965fc3
--- /dev/null
+++ b/help/devel/calendar/architecture.sgml
@@ -0,0 +1,17 @@
+ <chapter>
+ <title>Overview of the Calendar</title>
+
+ <para>
+ This chapter gives an overview of the Evolution Calendar
+ architecture. It describes the model/view split of the calendar
+ into a personal calendar server (PCS) and the GUI clients that
+ appear inside the Evolution shell.
+ </para>
+ </chapter>
+
+<!--
+Local variables:
+mode: sgml
+sgml-parent-document: ("../evolution-devel-guide.sgml" "book" "part" "")
+End:
+-->
diff --git a/help/devel/calendar/cal-client/.cvsignore b/help/devel/calendar/cal-client/.cvsignore
new file mode 100644
index 0000000000..0842a93f7a
--- /dev/null
+++ b/help/devel/calendar/cal-client/.cvsignore
@@ -0,0 +1,3 @@
+sgml
+Makefile
+Makefile.in
diff --git a/help/devel/calendar/cal-client/Makefile.am b/help/devel/calendar/cal-client/Makefile.am
new file mode 100644
index 0000000000..44d43639a8
--- /dev/null
+++ b/help/devel/calendar/cal-client/Makefile.am
@@ -0,0 +1,76 @@
+## Process this file with automake to produce Makefile.in
+
+# The name of the module.
+DOC_MODULE=evolution-cal-client
+
+# The top-level SGML file.
+DOC_MAIN_SGML_FILE=evolution-cal-client.sgml
+
+# The directory containing the source code (if it contains documentation).
+DOC_SOURCE_DIR=$(EVOLUTION_DIR)/calendar/cal-client
+
+CFLAGS =" \
+ -I$(top_srcdir)/calendar \
+ -I$(top_srcdir) \
+ -I$(top_builddir) \
+ -I$(top_builddir)/libical/src/libical \
+ -I$(top_srcdir)/libical/src/libical \
+ $(BONOBO_VFS_GNOME_CFLAGS) \
+ "
+
+LDFLAGS=" \
+ $(BONOBO_VFS_GNOME_LIBS) \
+ $(top_builddir)/calendar/cal-client/.libs/libcal-client.a \
+ $(top_builddir)/calendar/cal-util/.libs/libcal-util.a \
+ $(top_builddir)/libical/src/libical/libical.a \
+ $(top_builddir)/libversit/.libs/libversit.al \
+ "
+
+HTML_DIR=$(datadir)/gnome/html
+
+TARGET_DIR=$(HTML_DIR)/$(DOC_MODULE)
+
+tmpl_sources = \
+ tmpl/cal-client.sgml \
+ tmpl/evolution-cal-client-unused.sgml
+
+evolution_cal_client_docdir = $(HTML_DIR)
+evolution_cal_client_doc_DATA = \
+ evolution-cal-client.hierarchy \
+ evolution-cal-client.types \
+ evolution-cal-client-decl.txt \
+ evolution-cal-client-sections.txt
+
+EXTRA_DIST = \
+ $(evolution_cal_client_doc_DATA)
+
+sgml/evolution-cal-client-doc.bottom: $(tmpl_sources)
+ $(MAKE) sgml
+
+scan:
+ -(cd $(srcdir) \
+ && env CFLAGS=$(CFLAGS) LDFLAGS=$(LDFLAGS) \
+ gtkdoc-scanobj --module=$(DOC_MODULE) \
+ && gtkdoc-scan --module=$(DOC_MODULE) --source-dir=$(DOC_SOURCE_DIR) --ignore-headers="cal-listener.h evolution-calendar.h" )
+
+templates: scan
+ cd $(srcdir) && gtkdoc-mktmpl --module=$(DOC_MODULE)
+
+sgml:
+ cd $(srcdir) \
+ && gtkdoc-mkdb --module=$(DOC_MODULE) --source-dir=$(DOC_SOURCE_DIR)
+
+clean-local:
+ rm -f *~ *.bak *.signals *-unused.txt
+
+maintainer-clean-local: clean
+ cd $(srcdir) && rm -rf sgml $(DOC_MODULE)-decl-list.txt $(DOC_MODULE)-decl.txt
+
+dist-hook:
+ mkdir $(distdir)/sgml
+ mkdir $(distdir)/tmpl
+ -cp $(srcdir)/tmpl/*.sgml $(distdir)/tmpl
+ -cp $(srcdir)/sgml/*.sgml $(distdir)/sgml
+ -cp $(srcdir)/sgml/*.bottom $(srcdir)/sgml/*.top $(distdir)/sgml
+
+.PHONY : sgml templates scan
diff --git a/help/devel/calendar/cal-client/evolution-cal-client-decl.txt b/help/devel/calendar/cal-client/evolution-cal-client-decl.txt
new file mode 100644
index 0000000000..9fffd4c201
--- /dev/null
+++ b/help/devel/calendar/cal-client/evolution-cal-client-decl.txt
@@ -0,0 +1,127 @@
+<MACRO>
+<NAME>CAL_CLIENT_TYPE</NAME>
+#define CAL_CLIENT_TYPE (cal_client_get_type ())
+</MACRO>
+<MACRO>
+<NAME>CAL_CLIENT</NAME>
+#define CAL_CLIENT(obj) (GTK_CHECK_CAST ((obj), CAL_CLIENT_TYPE, CalClient))
+</MACRO>
+<MACRO>
+<NAME>CAL_CLIENT_CLASS</NAME>
+#define CAL_CLIENT_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), CAL_CLIENT_TYPE, CalClientClass))
+</MACRO>
+<MACRO>
+<NAME>IS_CAL_CLIENT</NAME>
+#define IS_CAL_CLIENT(obj) (GTK_CHECK_TYPE ((obj), CAL_CLIENT_TYPE))
+</MACRO>
+<MACRO>
+<NAME>IS_CAL_CLIENT_CLASS</NAME>
+#define IS_CAL_CLIENT_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((klass), CAL_CLIENT_TYPE))
+</MACRO>
+<STRUCT>
+<NAME>CalClient</NAME>
+</STRUCT>
+<STRUCT>
+<NAME>CalClientClass</NAME>
+</STRUCT>
+<ENUM>
+<NAME>CalClientLoadStatus</NAME>
+typedef enum {
+ CAL_CLIENT_LOAD_SUCCESS,
+ CAL_CLIENT_LOAD_ERROR,
+ CAL_CLIENT_LOAD_IN_USE,
+ CAL_CLIENT_LOAD_METHOD_NOT_SUPPORTED
+} CalClientLoadStatus;
+</ENUM>
+<ENUM>
+<NAME>CalClientGetStatus</NAME>
+typedef enum {
+ CAL_CLIENT_GET_SUCCESS,
+ CAL_CLIENT_GET_NOT_FOUND,
+ CAL_CLIENT_GET_SYNTAX_ERROR
+} CalClientGetStatus;
+</ENUM>
+<STRUCT>
+<NAME>CalClient</NAME>
+struct CalClient {
+ GtkObject object;
+
+ /* Private data */
+ gpointer priv;
+};
+</STRUCT>
+<FUNCTION>
+<NAME>cal_client_get_type</NAME>
+<RETURNS>GtkType </RETURNS>
+void
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_construct</NAME>
+<RETURNS>CalClient *</RETURNS>
+CalClient *client
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_new</NAME>
+<RETURNS>CalClient *</RETURNS>
+void
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_load_calendar</NAME>
+<RETURNS>gboolean </RETURNS>
+CalClient *client, const char *str_uri
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_create_calendar</NAME>
+<RETURNS>gboolean </RETURNS>
+CalClient *client, const char *str_uri
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_n_objects</NAME>
+<RETURNS>int </RETURNS>
+CalClient *client, CalObjType type
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_object</NAME>
+<RETURNS>CalClientGetStatus </RETURNS>
+CalClient *client,const char *uid,iCalObject **ico
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_uid_by_pilot_id</NAME>
+<RETURNS>CalClientGetStatus </RETURNS>
+CalClient *client,unsigned long pilot_id,char **uid
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_update_pilot_id</NAME>
+<RETURNS>void </RETURNS>
+CalClient *client, char *uid,unsigned long pilot_id,unsigned long pilot_status
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_uids</NAME>
+<RETURNS>GList *</RETURNS>
+CalClient *client, CalObjType type
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_events_in_range</NAME>
+<RETURNS>GList *</RETURNS>
+CalClient *client, time_t start, time_t end
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_alarms_in_range</NAME>
+<RETURNS>GList *</RETURNS>
+CalClient *client, time_t start, time_t end
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_get_alarms_for_object</NAME>
+<RETURNS>gboolean </RETURNS>
+CalClient *client, const char *uid,time_t start, time_t end,GList **alarms
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_update_object</NAME>
+<RETURNS>gboolean </RETURNS>
+CalClient *client, iCalObject *ico
+</FUNCTION>
+<FUNCTION>
+<NAME>cal_client_remove_object</NAME>
+<RETURNS>gboolean </RETURNS>
+CalClient *client, const char *uid
+</FUNCTION>
diff --git a/help/devel/calendar/cal-client/evolution-cal-client-sections.txt b/help/devel/calendar/cal-client/evolution-cal-client-sections.txt
new file mode 100644
index 0000000000..5496f2f0f2
--- /dev/null
+++ b/help/devel/calendar/cal-client/evolution-cal-client-sections.txt
@@ -0,0 +1,36 @@
+<INCLUDE>cal-client/cal-client.h</INCLUDE>
+
+<SECTION>
+<FILE>cal-client</FILE>
+CAL_CLIENT
+<TITLE>CalClient</TITLE>
+
+CalClientLoadStatus
+CalClientGetStatus
+cal_client_new
+cal_client_load_calendar
+cal_client_create_calendar
+cal_client_get_n_objects
+cal_client_get_object
+cal_client_get_uid_by_pilot_id
+cal_client_update_pilot_id
+cal_client_get_uids
+cal_client_get_events_in_range
+cal_client_get_alarms_in_range
+cal_client_get_alarms_for_object
+cal_client_update_object
+cal_client_remove_object
+
+<SUBSECTION Standard>
+
+CAL_CLIENT_TYPE
+IS_CAL_CLIENT
+CAL_CLIENT_CLASS
+IS_CAL_CLIENT_CLASS
+cal_client_get_type
+cal_client_construct
+
+<SUBSECTION Private>
+CalClient
+
+</SECTION>
diff --git a/help/devel/calendar/cal-client/evolution-cal-client.args b/help/devel/calendar/cal-client/evolution-cal-client.args
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/help/devel/calendar/cal-client/evolution-cal-client.args
diff --git a/help/devel/calendar/cal-client/evolution-cal-client.hierarchy b/help/devel/calendar/cal-client/evolution-cal-client.hierarchy
new file mode 100644
index 0000000000..88efa3e673
--- /dev/null
+++ b/help/devel/calendar/cal-client/evolution-cal-client.hierarchy
@@ -0,0 +1,2 @@
+GtkObject
+ CalClient
diff --git a/help/devel/calendar/cal-client/evolution-cal-client.signals b/help/devel/calendar/cal-client/evolution-cal-client.signals
new file mode 100644
index 0000000000..97e360b6a2
--- /dev/null
+++ b/help/devel/calendar/cal-client/evolution-cal-client.signals
@@ -0,0 +1,21 @@
+<SIGNAL>
+<NAME>CalClient::cal-loaded</NAME>
+<RETURNS>void</RETURNS>
+CalClient *calclient
+GtkEnum arg1
+</SIGNAL>
+
+<SIGNAL>
+<NAME>CalClient::obj-updated</NAME>
+<RETURNS>void</RETURNS>
+CalClient *calclient
+GtkString arg1
+</SIGNAL>
+
+<SIGNAL>
+<NAME>CalClient::obj-removed</NAME>
+<RETURNS>void</RETURNS>
+CalClient *calclient
+GtkString arg1
+</SIGNAL>
+
diff --git a/help/devel/calendar/cal-client/evolution-cal-client.types b/help/devel/calendar/cal-client/evolution-cal-client.types
new file mode 100644
index 0000000000..84d65a6637
--- /dev/null
+++ b/help/devel/calendar/cal-client/evolution-cal-client.types
@@ -0,0 +1,4 @@
+#include <gnome.h>
+#include <cal-client/cal-client.h>
+
+cal_client_get_type
diff --git a/help/devel/calendar/cal-client/tmpl/cal-client.sgml b/help/devel/calendar/cal-client/tmpl/cal-client.sgml
new file mode 100644
index 0000000000..7fdc69bfdc
--- /dev/null
+++ b/help/devel/calendar/cal-client/tmpl/cal-client.sgml
@@ -0,0 +1,205 @@
+<!-- ##### SECTION Title ##### -->
+CalClient
+
+<!-- ##### SECTION Short_Description ##### -->
+
+
+<!-- ##### SECTION Long_Description ##### -->
+<para>
+
+</para>
+
+
+<!-- ##### SECTION See_Also ##### -->
+<para>
+
+</para>
+
+
+<!-- ##### MACRO CAL_CLIENT ##### -->
+<para>
+
+</para>
+
+@obj:
+
+
+<!-- ##### ENUM CalClientLoadStatus ##### -->
+<para>
+
+</para>
+
+@CAL_CLIENT_LOAD_SUCCESS:
+@CAL_CLIENT_LOAD_ERROR:
+@CAL_CLIENT_LOAD_IN_USE:
+@CAL_CLIENT_LOAD_METHOD_NOT_SUPPORTED:
+
+<!-- ##### ENUM CalClientGetStatus ##### -->
+<para>
+
+</para>
+
+@CAL_CLIENT_GET_SUCCESS:
+@CAL_CLIENT_GET_NOT_FOUND:
+@CAL_CLIENT_GET_SYNTAX_ERROR:
+
+<!-- ##### FUNCTION cal_client_new ##### -->
+<para>
+
+</para>
+
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_load_calendar ##### -->
+<para>
+
+</para>
+
+@client:
+@str_uri:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_create_calendar ##### -->
+<para>
+
+</para>
+
+@client:
+@str_uri:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_get_n_objects ##### -->
+<para>
+
+</para>
+
+@client:
+@type:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_get_object ##### -->
+<para>
+
+</para>
+
+@client:
+@uid:
+@ico:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_get_uid_by_pilot_id ##### -->
+<para>
+
+</para>
+
+@client:
+@pilot_id:
+@uid:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_update_pilot_id ##### -->
+<para>
+
+</para>
+
+@client:
+@uid:
+@pilot_id:
+@pilot_status:
+
+
+<!-- ##### FUNCTION cal_client_get_uids ##### -->
+<para>
+
+</para>
+
+@client:
+@type:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_get_events_in_range ##### -->
+<para>
+
+</para>
+
+@client:
+@start:
+@end:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_get_alarms_in_range ##### -->
+<para>
+
+</para>
+
+@client:
+@start:
+@end:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_get_alarms_for_object ##### -->
+<para>
+
+</para>
+
+@client:
+@uid:
+@start:
+@end:
+@alarms:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_update_object ##### -->
+<para>
+
+</para>
+
+@client:
+@ico:
+@Returns:
+
+
+<!-- ##### FUNCTION cal_client_remove_object ##### -->
+<para>
+
+</para>
+
+@client:
+@uid:
+@Returns:
+
+
+<!-- ##### SIGNAL CalClient::cal-loaded ##### -->
+<para>
+
+</para>
+
+@calclient: the object which received the signal.
+@arg1:
+
+<!-- ##### SIGNAL CalClient::obj-updated ##### -->
+<para>
+
+</para>
+
+@calclient: the object which received the signal.
+@arg1:
+
+<!-- ##### SIGNAL CalClient::obj-removed ##### -->
+<para>
+
+</para>
+
+@calclient: the object which received the signal.
+@arg1:
+
diff --git a/help/devel/calendar/cal-client/tmpl/evolution-cal-client-unused.sgml b/help/devel/calendar/cal-client/tmpl/evolution-cal-client-unused.sgml
new file mode 100644
index 0000000000..e69de29bb2
--- /dev/null
+++ b/help/devel/calendar/cal-client/tmpl/evolution-cal-client-unused.sgml
diff --git a/help/devel/calendar/evolution-calendar.sgml b/help/devel/calendar/evolution-calendar.sgml
new file mode 100644
index 0000000000..f3936d9bbc
--- /dev/null
+++ b/help/devel/calendar/evolution-calendar.sgml
@@ -0,0 +1,51 @@
+ <part>
+ <docinfo>
+ <authorgroup>
+ <author>
+ <firstname>Federico</firstname>
+ <surname>Mena Quintero</surname>
+ <affiliation>
+ <address>
+ <email>federico@helixcode.com</email>
+ </address>
+ </affiliation>
+ </author>
+ </authorgroup>
+ </docinfo>
+
+ <title>Developing Applications for the Evolution Calendar</title>
+
+ <partintro>
+ <para>
+ This part of the Evolution Developer's Guide describes how to
+ write applications for the Evolution Calendar by using its
+ public interfaces. The Evolution Calendar exports its
+ functionality through a number of interfaces, including CORBA,
+ GTK+ wrappers for Bonobo objects, and other utility libraries.
+ </para>
+
+ <para>
+ You should read this part of the Evolution Developer's guide
+ if you intend to write client applications that use the
+ functionality of the Evolution Calendar.
+ </para>
+
+ <para>
+ This part does not describe the internal interfaces of the
+ Evolution Calendar; for that you should read the Evolution
+ Internals Guide. You should only need to read that guide if
+ you are interested in the way the calendar works internally or
+ if you want to make changes directly to the Evolution Calendar
+ code.
+ </para>
+ </partintro>
+
+ &calendar-architecture;
+ </part>
+
+<!--
+Local variables:
+mode: sgml
+sgml-parent-document: ("../evolution-devel-guide.sgml" "book" "book" "")
+End:
+-->
diff --git a/help/devel/calendar/public-reference.sgml b/help/devel/calendar/public-reference.sgml
new file mode 100644
index 0000000000..afe3b85628
--- /dev/null
+++ b/help/devel/calendar/public-reference.sgml
@@ -0,0 +1,20 @@
+ <reference>
+ <title>Calendar Public API Reference</title>
+
+ <partintro>
+ <para>
+ This part presents the class and function reference for the
+ public APIs of the different components of the Evolution
+ Calendar.
+ </para>
+ </partintro>
+
+ &CalClient;
+ </reference>
+
+<!--
+Local variables:
+mode: sgml
+sgml-parent-document: ("../evolution-devel-guide.sgml" "book" "part" "")
+End:
+-->
diff --git a/help/devel/calendar/reference.sgml b/help/devel/calendar/reference.sgml
new file mode 100644
index 0000000000..afe3b85628
--- /dev/null
+++ b/help/devel/calendar/reference.sgml
@@ -0,0 +1,20 @@
+ <reference>
+ <title>Calendar Public API Reference</title>
+
+ <partintro>
+ <para>
+ This part presents the class and function reference for the
+ public APIs of the different components of the Evolution
+ Calendar.
+ </para>
+ </partintro>
+
+ &CalClient;
+ </reference>
+
+<!--
+Local variables:
+mode: sgml
+sgml-parent-document: ("../evolution-devel-guide.sgml" "book" "part" "")
+End:
+-->
diff --git a/help/devel/evolution-devel-guide.sgml b/help/devel/evolution-devel-guide.sgml
new file mode 100644
index 0000000000..e1637cde3c
--- /dev/null
+++ b/help/devel/evolution-devel-guide.sgml
@@ -0,0 +1,44 @@
+<!doctype book PUBLIC "-//Davenport//DTD DocBook V3.0//EN" [
+<!entity evolution-calendar SYSTEM "calendar/evolution-calendar.sgml">
+<!entity calendar-architecture SYSTEM "calendar/architecture.sgml">
+<!entity calendar-reference SYSTEM "calendar/reference.sgml">
+<!entity CalClient SYSTEM "calendar/cal-client/sgml/cal-client.sgml">
+]>
+
+<book>
+ <bookinfo>
+ <title>Evolution Developer's Guide</title>
+
+ <authorgroup>
+ <corpauthor>
+ Helix Code, Inc.
+ </corpauthor>
+ </authorgroup>
+
+ <copyright>
+ <year>2000</year>
+ <holder>Helix Code, Inc.</holder>
+ </copyright>
+ </bookinfo>
+
+ <!-- DocBook parts for each individual component -->
+
+ &evolution-calendar;
+
+ <!-- API Reference part -->
+
+ <part>
+ <title>Evolution Public API Reference</title>
+
+ <partintro>
+ <para>
+ This part presents the class and function reference for the
+ different libraries and interfaces that Evolution provides.
+ Classes are described together with their methods; individual
+ functions are grouped by functional group.
+ </para>
+ </partintro>
+
+ &calendar-reference;
+ </part>
+</book>