These are intended to be brief notes supplementing and outlining the course material presented in the course Introduction to Daylight. The Daylight manuals should be considered the text for the course and the authoritative documentation, and should be used in conjunction with these notes for best results!
In particular, the Daylight Toolkit Programmer's Guide and the Daylight Toolkit Reference Manual are the relevant manuals for the toolkit unit.
 
A set of high performance chemical information algorithms with a robust and stable interface.
The Daylight Toolkit is a set of object libraries providing function
calls for C or Fortran toolkit programs.  Perl is also available in the
form of a package DayPerl which must be compiled by the user and acts
as a Perl wrapper to the C functions.   The Toolkit is intended for use
by both expert and novice programmers.  In addition to the libraries
themselves, the Daylight release contains several example toolkit
programs, some of which may be useful in themselves, and some which may
be useful as building blocks for other programs.  These examples are
located in the "contrib" directory, at
$DY_ROOT/contrib/src/ directory.  There are C,
Fortran, and Perl example programs, the most extensive set for C.
The Daylight Toolkit has a strictly defined functional interface. It is defined by the dt_* functions and constants and their prescribed syntax as documented in the man pages. Daylight is committed to supporting this stable interface, thereby allowing forward compatibility of toolkit programs. Thus, features and functions may be added, but not taken away.
| Toolkit | Object library | License entry | Prerequisites | 
|---|---|---|---|
| SMILES | -ldt_smiles | smiles | (none) | 
| SMARTS | -ldt_smarts | smarts | SMILES | 
| Depict | -ldt_depict | depict | SMILES | 
| Fingerprint | -ldt_finger | fingerprint | SMILES | 
| Program Object | -ldt_progob | programobject | SMILES | 
| Thor | -ldt_thor | thor | SMILES | 
| Merlin | -ldt_merlin | merlin | SMILES and SMARTS | 
| Rubicon | -ldc_rube | rubicon | SMILES, SMARTS and Depict | 
| Monomer | -ldt_monomer | monomer | SMILES, Thor | 
| Reaction | -ldt_smiles | reaction | SMILES | 
| Reaction w/ Reaction Transform Capability | -ldt_smiles | reaction | SMILES and SMARTS | 
| Shared object | Static object | 
|---|---|
| (none) | libdu.a (not official toolkit; contrib funtions) | 
| libdw_xvgrins.so | libdw_xvgrins.a | 
| libdw_xvtdt.so | libdw_xvtdt.a | 
| libdw_xview.so | libdw_xview.a | 
| libdl_xview.so | libdl_xview.a | 
| libdt_apputils.so | libdt_apputils.a (only needed by XView apps) | 
| libdt_depict.so | libdt_depict.a | 
| libdl_stubs.so | libdl_stubs.a | 
| libdt_merlin.so | libdt_merlin.a | 
| libdt_thor.so | libdt_thor.a | 
| libdt_ipcx.so | libdt_ipcx.a | 
| libdt_monomer.so | libdt_monomer.a | 
| libdc_rube.so | libdc_rube.a | 
| libdt_progob.so | libdt_progob.a | 
| libdt_finger.so | libdt_finger.a | 
| libdt_smarts.so | libdt_smarts.a | 
| libdt_datatype.so | libdt_datatype.a | 
| libdt_smiles.so | libdt_smiles.a | 
| Toolkit | Object library | License entry | Prerequisites | 
|---|---|---|---|
| Widgets (basic) | -ldw_xview | widgets depictwidget | SMILES and Depict | 
| GrinsWidget | -ldw_xvgrins | grinswidget | SMILES and Depict | 
| TDTWidget | -ldw_xvtdt | tdtwidget | SMILES, Depict and Thor | 
| 3DWidget | -ldw_xview | 3dwidget | SMILES and Depict | 
The SMILES Toolkit is the foundation of the entire set of toolkits and the Daylight software system in general. It might be more precisely termed the "molecule toolkit", since strictly speaking, SMILES is only an external representation of a molecule object, used for input and output.
   In addition, the SMILES Toolkit contains many generic toolkit
   functions not specifically related to molecules but fundamental to
   the general toolkit object mechanism.  Some examples of these
   functions are:
dt_stream(),
dt_copy(),
dt_alloc_string(),
dt_errorsave(), and
dt_dealloc(), just to name a few.
   
The Rubicon Toolkit is a set of function calls not fully conforming to the object paradigm, thus prefixed "dc_", since it is a C interface.
The Daylight system has integrated web capabilities which allow access to Daylight tools via web browser. The "DayCGI toolkit" is not a rigorously defined API as is the dt_ function libraries, the true Daylight Toolkit. Rather, DayCGI programming means combining an assortment of Daylight and non-Daylight tools to deliver Daylight database and computational services via the web.
JavaGRINS is a full function molecular (and SMARTS) editor for use in web applications. This tool is incorporated in Daylight web applications and provided for use in custom user applications.
The Reaction Toolkit doesn't have a separate object library, because it's capabilities are integrated into the SMILES and SMARTS Toolkits. There are some examples available:
The Remote Toolkit is a system for providing toolkit services to personal computers by means of the DayToolserver, which runs on a unix machine. Remote Toolkit programs are identical to normal toolkit programs except for a few functions which must be called to make the client/server connection. In this way, native Mac and Windows applications may be written using Daylight toolkit calls.
   The contrib directory contains several functions not part of
   the toolkit but rather built upon toolkit functions.  They have
   been compiled into one library libdu.a
   for convenience.
   
The toolkit doesn't know anything about the existance of output devices for drawing structures (rendering). Hence, there is an intermediate interface which allows the toolkit to draw structures. This drawing library is called by the toolkit when it needs to performs drawing operations. The functions in the drawing library are simple drawing primitives such as: "draw line", "move to", "draw circle", etc.
A drawing library must be supplied at link-time to any application which uses the depict toolkit. Contrib contains several examples:
The API (Application Programming Interface) comprised by the toolkit possesses object oriented features but is not a complete object-oriented language such as Smalltalk or Java. The concept of an object is essential to the toolkit interface, however, and atoms, bonds, molecules, datatrees, reactions, and many other things are toolkit objects. They may be created, manipulated, and destroyed easily using the toolkit interface. The Daylight Toolkit manages the objects for you - you need not be concerned with details of how the Toolkit represents the molecule or depiction.
An object is identified by its "handle" which is a simple and lightweight integer datatype. The handles themselves contain no information - they are not pointers to complex structures. Handles are opaque in that they cannot be dereferenced -- no access to the internal data structures is allowed. Handles are unique. Only one handle refers to one object. Handles are valid when they refer to an existing object, or invalid if they have been deallocated by the program, revoked by the toolkit or never assigned.
Because objects are managed by the Daylight Toolkit, the interface to various programming languages is straightforward: the Daylight Toolkit works equally well with C, FORTRAN, Pascal, or LISP.
Objects are self-describing: Each object "knows" what it is. Many toolkit functions are polymorphic: they will take a variety of different object types The function "asks" the object what type it is and performs the appropriate action.
| Object | Description | 
|---|---|
| atom | atom in a molecule | 
| bond | bond in a molecule | 
| column | column of data in a pool | 
| conformation | 3-D conformation | 
| cycle | ring in a molecule | 
| database | database object | 
| datafield | datum in a dataitem | 
| dataitem | dataitem in a TDT | 
| datatree | a THOR datatree (TDT) | 
| datatype | datatype definition | 
| depiction | 2-D coordinates of a molecule | 
| fieldtype | one datafield's type | 
| fingerprint | fingerprint object | 
| hitlist | search/sort results in a Merlin database | 
| integer | intger object | 
| merserver | Merlin server connection | 
| molecule | molecule object | 
| monomer | monomer object | 
| monomerset | set of monomers | 
| monomertable | table of monomer definitions | 
| monopattern | search pattern for a monomer | 
| multimer | multimer object (CHUCKLES) | 
| path | results of a structural search | 
| pathset | set of path objects | 
| pattern | structural pattern (SMARTS) | 
| pool | Merlin database ("pool") | 
| program | external program object | 
| reaction | reaction object | 
| real | real number object | 
| sequence | ordered list of objects | 
| server | THOR server connection | 
| stream | enumerated constituents of another object | 
| string | string object | 
| substruct | substructure object | 
| transform | generic reaction | 
| varimer | varimer object (CHORTLES) | 
| varipattern | varimer pattern (CHARTS) | 
| vbind | object providing faster evaluation of a match | 
   The toolkit function dt_stream is able to 
   derive streams of constituent objects from parent objects.  Streams
   of atoms or bonds can be derived from a molecule, streams of 
   datatrees can be derived from a database, streams of molecules
   can be derived from a reaction.  Streams are easily obtained and
   used, but may be revoked if the parent object is modified. Deallocating
   a stream does not affect its member objects.
   
Sequences behave like streams but are not deallocated if a member object is modified. The are simply ordered lists of objects. Objects may be added or deleted from a sequence. Deallocating a sequence does not affect its member objects.
Named properties were introduced with version 4.51, superceding the previous dt_adjunct/dt_setadjunct mechanism. Any number of properties of any types may be associated with any toolkit object.
 
   
      Children of a parent are normally accessed with dt_stream().
      
      The parent of a child is accessed with dt_parent().
         
Modification of the base object causes any derivatives to be deallocated.
      One can't get access to all of the derivatives of a given base object
      (eg. all depictions of a molecule).
      
      The base of any given derivative object is accessed with
      dt_base(). 
A parent/child example (molecule/atoms):
void do_stuff(dt_Handle ob)
{
  dt_Handle atoms, atom, myparent;
  atoms = dt_stream(ob, TYP_ATOM);
  while (NULL_OB != (atom = dt_next(atoms)
    {
       /*** perform operations on each atom ***/
       ...
       myparent = dt_parent(atom);
    }
  dt_dealloc(atoms);
  return;
}
   A base/derivative example (molecule/depiction):
void do_other_stuff(dt_Handle ob)
{
  dt_Handle depiction, mybase;
  depiction = dt_alloc_depiction(ob);
  ...
  dt_calcxy(depiction);
  dt_depict(depiction);
  ...
  mybase = dt_base(depiction);
  return;
}
   
Regardless of the programming language used to access the toolkit, the toolkit will use dynamic memory allocation in creating objects. The implication of this is that the process size of an executable program will grow as objects are allocated and care must be taken that it doesn't grow uncontrollably. If a "memory leak" is present in a loop, the process size will increase until the program crashes or the computer is paralyzed. So the issue becomes how and when to reliably deallocate objects to avoid memory leaks.
   In general, the essential task is to deallocate objects which
   are allocated inside loops.  For example, if a new molecule is
   allocated for each iteration of a loop, either by
   dt_alloc_mol or dt_smilin,
   it must be deallocated inside the loop.  When a molecule is 
   deallocated, all atoms and bonds beloning to the parent molecule,
   and any streams over the molecule, are deallocated.  Likewise,
   if each iteration of a loop allocates a TDT object, it must
   be deallocated.  Objects which are allocated only once in a
   program need not be deallocated, but it is considered good
   form to do so.
   
SMILES is a language for representing a molecule as an ASCII string. The toolkit can parse a SMILES into a molecule and express a molecule as a SMILES. But it should be noted that the molecule object is not itself a SMILES. This correspondence between a toolkit object and a linguistic representation is common in the toolkit.
| Object | Language | 
|---|---|
| datatree | TDT | 
| fingerprint | FP datum | 
| molecule | SMILES | 
| monomer | Monomer SMILES | 
| multimer | CHUCKLES | 
| pattern | SMARTS | 
| reaction | Reaction SMILES | 
| transform | SMIRKS | 
| varimer | CHORTLES | 
| varipattern | CHARTS | 
Objects persist until they are deallocated by the program, revoked by the toolkit, or until the program terminates. In contrast, in C, a returned string is a (char *) pointer to a location in memory containing the string, managed by the toolkit, and not guaranteed to persist after the next toolkit function call.
C is the native language of the toolkit and so the overhead required is least when programming in C. Thus, the speed of C programs may be superior to Fortran. C compilers are readily available on all machines, including Free Software Foundation GNU C (gcc). Most of the contrib code available from Daylight is in C, providing a head start for many programming tasks. But many programmers, expecially novice programmers, find C to be hazardous and cryptic.
Fortran compilers are readily available thanks to the historical importance and proliferation of Fortran code. Limitations in Fortran-77 were corrected in Fortran-90, but F90 is not as widely used and not supported by Daylight. Much less contrib code is available in F77.
An interpreted scripting language, Perl programs will generally be slower than C or Fortran equivalents. However, ease of use and no-compilation are advantages far outweighing performance loss for many users. The amount of contrib code is small but growing, and C programs are generally easily translated to Perl. The DayPerl package was written and contributed by Alex Wong.
A Python wrapper "PyDaylight" has been written and contributed by Andrew Dalke. PyDaylight is more than simply a wrapper; a set of object classes is defined which provides a more truly object oriented programming interface.
It is possible to construct wrappers for various other compiled and scripting languages, including Pascal, LISP, C++, Java, tcl, and guile. These are not currently available or supported by Daylight, however.
Debugging is essential to any project. In addition to usual debugging methods, the Daylight Toolkit provides error handling functions which can be used to debug, and "vigilance". The vigilant toolkit monitors handles and can report whether a handle is valid or not.
The following functions comprise this facility:
dt_invalid
       dt_vh_stop_here
       dt_vh_count (unsupported)
       
Purify is a useful tool for discovering memory leaks in applications. We use Purify extensively for our internal development. There are other tools which perform similar functions (e.g., Insure, Sun Developer Workshop).
A well-behaved toolkit program shows a common set of behaviors on completion:
See the Daylight Toolkit Reference Manual, for the complete functional definitions of all the toolkit functions.
There is no Daylight toolkit for web development in any strict sense, with an integrated and consistent developer environment. However, there are several tools in the Daylight suite which are useful for web development
    Contributed source code can be found in the distribution in
    $DY_ROOT/contrib/src and on the 
    Daylight
    website.  Contrib serves multiple purposes: useful
    applications and functions, and example code illustrating
    toolkit function syntax and usage.
    
 Daylight Chemical Information Systems Inc.
Daylight Chemical Information Systems Inc.