/* @source ajobodb ************************************************************ ** ** AJAX OBODB (OBO database) functions ** ** These functions control all aspects of AJAX obo database access ** ** @author Copyright (C) 2010 Peter Rice ** @version $Revision: 1.15 $ ** @modified Sep 2010 pmr first version ** @modified $Date: 2012/04/26 17:36:15 $ by $Author: mks $ ** @@ ** ** This library is free software; you can redistribute it and/or ** modify it under the terms of the GNU Lesser General Public ** License as published by the Free Software Foundation; either ** version 2.1 of the License, or (at your option) any later version. ** ** This library is distributed in the hope that it will be useful, ** but WITHOUT ANY WARRANTY; without even the implied warranty of ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ** Lesser General Public License for more details. ** ** You should have received a copy of the GNU Lesser General Public ** License along with this library; if not, write to the Free Software ** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, ** MA 02110-1301, USA. ** ******************************************************************************/ #include "ajlib.h" #include "ajobodb.h" #include "ajoboread.h" #include "ajcall.h" #include #include #include #ifndef WIN32 #include #include #include #include #include #include #include #include #else #include #include #endif /* @funclist oboAccess ******************************************************** ** ** Functions to access each database or obo access method ** ******************************************************************************/ static AjOOboAccess oboAccess[] = { /* Name AccessFunction FreeFunction Qlink, Description Alias Entry Query All Chunk Padding */ { NULL, NULL, NULL, NULL, NULL, AJFALSE, AJFALSE, AJFALSE, AJFALSE, AJFALSE, AJFALSE }, { NULL, NULL, NULL, NULL, NULL, AJFALSE, AJFALSE, AJFALSE, AJFALSE, AJFALSE, AJFALSE } }; /* @func ajObodbInit ********************************************************** ** ** Initialise obo database internals ** ** @return [void] ** ** @release 6.4.0 ******************************************************************************/ void ajObodbInit(void) { AjPTable table; ajuint i = 0; table = ajOboaccessGetDb(); while(oboAccess[i].Name) { ajCallTableRegister(table, oboAccess[i].Name, (void*) &oboAccess[i]); i++; } return; } /* @func ajObodbPrintAccess *************************************************** ** ** Reports the internal data structures ** ** @param [u] outf [AjPFile] Output file ** @param [r] full [AjBool] Full report (usually ajFalse) ** @return [void] ** ** @release 6.4.0 ** @@ ******************************************************************************/ void ajObodbPrintAccess(AjPFile outf, AjBool full) { ajint i = 0; ajFmtPrintF(outf, "\n"); ajFmtPrintF(outf, "# Obo term access methods\n"); ajFmtPrintF(outf, "# Name Alias Entry Query All Description\n"); ajFmtPrintF(outf, "\n"); ajFmtPrintF(outf, "method {\n"); for(i=0; oboAccess[i].Name; i++) if(full || !oboAccess[i].Alias) ajFmtPrintF(outf, " %-10s %5B %5B %5B %5B \"%s\"\n", oboAccess[i].Name, oboAccess[i].Alias, oboAccess[i].Entry, oboAccess[i].Query, oboAccess[i].All, oboAccess[i].Desc); ajFmtPrintF(outf, "}\n\n"); return; } /* @func ajObodbExit ********************************************************** ** ** Cleans up obo database processing internal memory ** ** @return [void] ** ** @release 6.4.0 ** @@ ******************************************************************************/ void ajObodbExit(void) { return; }