The GNUstep Database Library 2 (GDL2) is a set of libraries to map Objective-C objects to rows of relational database management systems (RDBMS). It aims to be compatible with Enterprise Objects Framework (EOF) as released with WebObjects 4.5 from Apple Inc.
Find a file
David Ayers b8cfc601fc * configure.ac (enable-examples): Allow examples to be built from
top-level makefile.
	* GNUmakefile.in: Ditto.
	* configure: Regenerate.


git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gdl2/trunk@27919 72102866-910b-0410-8b05-ffd578937521
2009-02-18 18:50:45 +00:00
config Fixed typo in --with-sqlite3-library=xxx, was setting sqlite3 variable instead of sqlite3_libdir 2009-01-31 20:37:24 +00:00
DBModeler add hack for windows. 2009-02-02 11:47:13 +00:00
Documentation * Documentation/GDL2Intro/Examples: Move to ... 2009-02-18 17:21:05 +00:00
EOAccess * GNUmakefile.in: Add Trading subproject. 2009-02-18 14:47:26 +00:00
EOAdaptors Fixed typo that would prevent the SQLiteAdaptor from linking 2009-01-31 20:41:20 +00:00
EOControl * EOControl/Makefile.postamble 2009-02-18 05:09:35 +00:00
EOInterface * EOControl/Makefile.postamble 2009-02-18 05:09:35 +00:00
EOModeler Updated all project GNUmakefile's to include the local common.make, which will 2008-05-29 14:57:30 +00:00
Examples * Documentation/GDL2Intro/Examples: Move to ... 2009-02-18 17:21:05 +00:00
GDL2Palette link in libGorm. 2009-02-02 09:32:16 +00:00
Tools Updated all project GNUmakefile's to include the local common.make, which will 2008-05-29 14:57:30 +00:00
ANNOUNCE * Version 0.11.0 2007-07-11 18:45:06 +00:00
AUTHORS * Update Email address for Matt Rice. 2007-01-05 16:17:04 +00:00
ChangeLog * configure.ac (enable-examples): Allow examples to be built from 2009-02-18 18:50:45 +00:00
common.make Updated all project GNUmakefile's to include the local common.make, which will 2008-05-29 14:57:30 +00:00
config.h.in * config.h.in (getRCSID): Mark inline to avoid compiler warnings. 2008-10-27 16:59:35 +00:00
configure * configure.ac (enable-examples): Allow examples to be built from 2009-02-18 18:50:45 +00:00
configure.ac * configure.ac (enable-examples): Allow examples to be built from 2009-02-18 18:50:45 +00:00
COPYING.LIB * COPYING.LIB: Update to LGPL 3. 2007-07-12 06:39:22 +00:00
GDL2.gsdoc * Update Email address for Matt Rice. 2007-01-05 16:17:04 +00:00
gdl2.make.in * Makefile.postamble (after-distclean::): Remove generated 2007-10-31 05:32:46 +00:00
GNUmakefile.in * configure.ac (enable-examples): Allow examples to be built from 2009-02-18 18:50:45 +00:00
INSTALL * Version 0.11.0 2007-07-11 18:45:06 +00:00
Makefile.postamble * Makefile.postamble (after-distclean::): Remove generated 2007-10-31 05:32:46 +00:00
NEWS * Version 0.11.0 2007-07-11 18:45:06 +00:00
README * README: Add Trading framework. 2008-06-03 13:29:46 +00:00
TODO * TODO: Add an item. 2008-03-10 12:48:00 +00:00
Version * Version 0.11.0 2007-07-11 18:45:06 +00:00

Readme
******

The GNUstep Database Library 2 (GDL2) is a set of libraries to map
Objective-C objects to rows of relational database management systems
(RDBMS).  It aims to be compatible with Enterprise Objects Framework
(EOF) as released with WebObjects 4.5 from Apple Inc.  It has been tested
against the following package versions:
- the GNUstep Make Package 2.0.0
- the Base Package 1.14.0
- the GUI/Back Package 1.12.0
- the GORM Package 1.2.0

GDL2 consists of the following components:

- EOControl

The fundamental abstraction library which includes many non RDBMS
related extensions such as KeyValueCoding extensions and other
categories.  Most importantly it contains the classes which handle the
coordination of object graphs namely EOEditingContext.

- EOAccess

This library implements the underlying mechanism to retrieve and store
data in RDBMS.  It defines the abstract classes like EOAdaptor which
are subclassed to interface with concrete RDBMS implementations.

- EOInterface

This library implements classes used to synchronize UI components such
as NSTextFields, NSButtons and NSTableViews with the state of objects
which an EOEditingContext contains.

- EOAdaptors

This is a collection of concrete EOAdaptor projects needed to connect
to specific databases.  GDL2 currently supplies Adaptors for
the PostgreSQL and SQLite databases.

   - PostgreSQL: we aim to support PostgreSQL 8.1 and higher API.
   - SQLite: Compatible with SQLite version 3.x

- DBModeler

GDL2 will offers a UI application to create and maintain .eomodel(d)
files.  This is the first release of a preliminary version.

- Trading
 
The Trading framework, provides an example model, and some routines to
create a database from the model, and populate the database with data,
while not an example itself it is indented for use by example applications 
using GDL2 alone, EOInterface or GSWeb, and for higher level tests.

======================
*** Important Note ***
======================

This release is meant for developers who can help test and contribute
the current code or are willing to test the interface.  It is not
ready for general purpose production code.  Having said that, it
should be mentioned that GDL2 is being used in production environments
and has been much tested in those contexts.

Expect the current interface to change especially with respect to
functions and methods not documented in EOF 4.5.  Even the library
names themselves may change.

With respect to EOF, GDL2 is currently missing EOSharedEditingContext,
EOMultiReaderLocks and the EOEvent classes.  Also we currently do not
support the EOSchemaSynchronization methods yet.  But you are likely
to find many more missing implementations within the source.  If you
identify something that you need, please let us know at
<discuss-gnustep@gnu.org> or even better get copyright assignment for
the FSF and post a patch.

Initial reading
===============

   The file `NEWS' has the library's feature history.

   The files `INSTALL' gives instructions for installing the library.

License
=======

   The GNUstep libraries are covered under the GNU Lesser Public
License.  This means you can use these libraries in any program (even
non-free programs).  If you distribute the libraries along with your
program, you must make the improvements you have made to the libraries
available to those you distribute to.  You should read the COPYING.LIB
file for more information.

   GNUstep tools, test programs, and other files are covered under the
GNU General Public License.  This means if you distribute derivative works
of these programs you must distribute them in compliance with the
GPL.  You should read the COPYING file for more information.

How can you help?
=================

   * Give us feedback!  Tell us what you like; tell us what you think
     could be better.

     Please log bug reports on the GNUstep project page
     <http://savannah.gnu.org/support/?group=gnustep> or send bug
     reports to <bug-gnustep@gnu.org>.


     Happy hacking!