LibSBML appendAnnotation.java
/**
* @file appendAnnotation.java
* @brief Adds annotation to a model and a species
* @author Akira Funahashi (translated from libSBML C++ examples (using other Java examples provided by Nicolas Rodriguez))
* @author Akiya Jouraku
*
*
*/
import org.sbml.libsbml.libsbmlConstants;
import org.sbml.libsbml.CVTerm;
import org.sbml.libsbml.Date;
import org.sbml.libsbml.ModelCreator;
import org.sbml.libsbml.ModelHistory;
import org.sbml.libsbml.SBMLWriter;
import org.sbml.libsbml.Species;
import org.sbml.libsbml.SBMLDocument;
import org.sbml.libsbml.SBMLReader;
public class appendAnnotation
{
public static void main (String[] args)
{
if (args.length != 2)
{
println("\n usage: java appendAnnotation \n");
System.exit(2);
}
SBMLDocument d;
SBMLReader reader = new SBMLReader();
SBMLWriter writer = new SBMLWriter();
d = reader.readSBML(args[0]);
long errors = d.getNumErrors();
if (errors > 0)
{
println("Read Error(s):");
d.printErrors();
println("Correct the above and re-run.");
}
else
{
String model_history_annotation =
"\n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" Keating\n" +
" Sarah\n" +
" \n" +
" sbml-team@caltech.edu\n" +
" \n" +
" University of Hertfordshire\n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" 1999-11-13T06:54:32Z\n" +
" \n" +
" \n" +
" 2007-11-31T06:54:00-02:00\n" +
" \n" +
" \n" +
" \n" +
"\n";
d.getModel().appendAnnotation(model_history_annotation);
/*
* The above code can be replaced by the following code.
*
ModelHistory h = new ModelHistory();
ModelCreator c = new ModelCreator();
c.setFamilyName("Keating");
c.setGivenName("Sarah");
c.setEmail("sbml-team@caltech.edu");
c.setOrganisation("University of Hertfordshire");
h.addCreator(c);
Date date = new Date("1999-11-13T06:54:32");
Date date2 = new Date("2007-11-31T06:54:00-02:00");
h.setCreatedDate(date);
h.setModifiedDate(date2);
d.getModel().setModelHistory(h);
*
*/
long n = d.getModel().getNumSpecies();
if (n > 0)
{
Species s = d.getModel().getSpecies(0);
String cvterms_annotation =
"\n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
" \n" +
"\n";
s.appendAnnotation(cvterms_annotation);
/*
* The above code can be replaced by the following code.
*
CVTerm cv = new CVTerm();
cv.setQualifierType(libsbmlConstants.BIOLOGICAL_QUALIFIER);
cv.setBiologicalQualifierType(libsbmlConstants.BQB_IS_VERSION_OF);
cv.addResource("http://www.geneontology.org/#GO:0005892");
CVTerm cv2 = new CVTerm();
cv2.setQualifierType(libsbmlConstants.BIOLOGICAL_QUALIFIER);
cv2.setBiologicalQualifierType(libsbmlConstants.BQB_IS);
cv2.addResource("http://www.geneontology.org/#GO:0005895");
CVTerm cv1 = new CVTerm();
cv1.setQualifierType(libsbmlConstants.BIOLOGICAL_QUALIFIER);
cv1.setBiologicalQualifierType(libsbmlConstants.BQB_IS_VERSION_OF);
cv1.addResource("http://www.ebi.ac.uk/interpro/#IPR002394");
s.addCVTerm(cv);
s.addCVTerm(cv2);
s.addCVTerm(cv1);
*
*/
}
}
writer.writeSBML(d, args[1]);
}
static void println (String msg)
{
System.out.println(msg);
}
/**
* Loads the SWIG-generated libSBML Java module when this class is
* loaded, or reports a sensible diagnostic message about why it failed.
*/
static
{
try
{
System.loadLibrary("sbmlj");
// For extra safety, check that the jar file is in the classpath.
Class.forName("org.sbml.libsbml.libsbml");
}
catch (UnsatisfiedLinkError e)
{
System.err.println("Error encountered while attempting to load libSBML:");
System.err.println("Please check the value of your "
+ (System.getProperty("os.name").startsWith("Mac OS")
? "DYLD_LIBRARY_PATH" : "LD_LIBRARY_PATH") +
" environment variable and/or your" +
" 'java.library.path' system property (depending on" +
" which one you are using) to make sure it list the" +
" directories needed to find the " +
System.mapLibraryName("sbmlj") + " library file and" +
" libraries it depends upon (e.g., the XML parser).");
System.exit(1);
}
catch (ClassNotFoundException e)
{
System.err.println("Error: unable to load the file 'libsbmlj.jar'." +
" It is likely that your -classpath command line " +
" setting or your CLASSPATH environment variable " +
" do not include the file 'libsbmlj.jar'.");
e.printStackTrace();
System.exit(1);
}
catch (SecurityException e)
{
System.err.println("Error encountered while attempting to load libSBML:");
e.printStackTrace();
System.err.println("Could not load the libSBML library files due to a"+
" security exception.\n");
System.exit(1);
}
}
}