/* BioJavaEntrySource.java * * created: Tue Apr 10 2001 * * This file is part of Artemis * * Copyright (C) 2001 Genome Research Limited * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * * $Header: //tmp/pathsoft/artemis/uk/ac/sanger/artemis/components/BioJavaEntrySource.java,v 1.1 2004-06-09 09:46:06 tjc Exp $ */ package uk.ac.sanger.artemis.components; import java.net.*; import java.io.*; import java.util.*; import java.lang.RuntimeException; import org.biojava.bio.program.das.*; import org.biojava.bio.BioException; import org.biojava.bio.seq.io.SequenceBuilderFactory; import org.biojava.bio.seq.io.EmblProcessor; import org.biojava.bio.seq.io.SmartSequenceBuilder; import org.biojava.bio.seq.io.SymbolTokenization; import org.biojava.bio.seq.io.StreamReader; import org.biojava.bio.seq.io.SequenceFormat; import org.biojava.bio.seq.io.EmblLikeFormat; import org.biojava.bio.seq.SequenceIterator; import org.biojava.bio.symbol.Alphabet; import org.biojava.bio.seq.DNATools; import uk.ac.sanger.artemis.util.*; import uk.ac.sanger.artemis.io.BioJavaEntry; import uk.ac.sanger.artemis.io.EntryInformation; import uk.ac.sanger.artemis.io.SimpleEntryInformation; import uk.ac.sanger.artemis.*; import uk.ac.sanger.artemis.sequence.*; /** * This is an EntrySource that reads Entry objects from a BioJava Sequence * object. * * @author Kim Rutherford <kmr@sanger.ac.uk> * @version $Id: BioJavaEntrySource.java,v 1.1 2004-06-09 09:46:06 tjc Exp $ **/ public class BioJavaEntrySource implements EntrySource { /** * Create a new BioJavaEntrySource. **/ public BioJavaEntrySource () { } /** * Get an Entry object from this source (by reading from a file, reading * from a CORBA server, or whatever). * @param bases The Bases object to pass to the Entry constructor. * @param show_progress If true a InputStreamProgressDialog will be shown * while loading. (Not implemented) * @exception OutOfRangeException Thrown if one of the features in * the Entry is out of range of the Bases object. * @return null if and only if the read is cancelled by the user or if the * read fails. **/ public Entry getEntry (final Bases bases, final ProgressThread progress_thread, final boolean show_progress) throws OutOfRangeException, IOException { final String fileName = "/nfs/team81/kmr/pow/java2/AB000095.embl"; final FileDocument document = new FileDocument (new File (fileName)); final BioJavaEntry emblEntry = new BioJavaEntry (document, new EmblLikeFormat ()); return new Entry (bases, emblEntry); } /** * Get an Entry object from this source (by reading from a file, reading * from a CORBA server, or whatever). * @param bases The Bases object to pass to the Entry constructor. * @param show_progress If true a InputStreamProgressDialog will be shown * while loading. (Not implemented) * @exception OutOfRangeException Thrown if one of the features in * the Entry is out of range of the Bases object. * @return null if and only if the read is cancelled by the user or if the * read fails. **/ public Entry getEntry (final Bases bases, final boolean show_progress) throws OutOfRangeException, IOException { return getEntry(bases, null, show_progress); } /** * Get an Entry object from this source (by reading from a file, reading * from a CORBA server, or whatever). A Bases object will be created for * the sequence of the new Entry. * @param show_progress If true a InputStreamProgressDialog will be shown * while loading. (Not implemented) * @exception OutOfRangeException Thrown if one of the features in * the Entry is out of range of the Bases object. * @exception NoSequenceException Thrown if the entry that we read has no * sequence. * @return null if and only if the user cancels the read or if the read * fails. **/ public Entry getEntry(final boolean show_progress, final ProgressThread progress_thread) throws OutOfRangeException, NoSequenceException, IOException { return getEntry(show_progress); } /** * Get an Entry object from this source (by reading from a file, reading * from a CORBA server, or whatever). A Bases object will be created for * the sequence of the new Entry. * @param show_progress If true a InputStreamProgressDialog will be shown * while loading. (Not implemented) * @exception OutOfRangeException Thrown if one of the features in * the Entry is out of range of the Bases object. * @exception NoSequenceException Thrown if the entry that we read has no * sequence. * @return null if and only if the user cancels the read or if the read * fails. **/ public Entry getEntry (final boolean show_progress) throws OutOfRangeException, NoSequenceException, IOException { // DASSequence dasSeq = null; // try { // final URL dbURL = // new URL("http://genome.ornl.gov/das/das.cgi/ecoli"); // // new URL("http://genome.cse.ucsc.edu:80/cgi-bin/das/cb1"); // // new URL("http://servlet.sanger.ac.uk:8080/das/ens1131cds/"); // final DASSequenceDB dasDB = new DASSequenceDB (dbURL); // final Set ids = dasDB.ids(); // for (Iterator i = ids.iterator(); i.hasNext(); ) { // System.out.println(i.next().toString()); // } // // dasSeq = (DASSequence) dasDB.getSequence((String) ids.iterator().next()); // SequenceIterator si = dasDB.sequenceIterator(); // if (si.hasNext()) { // dasSeq = (DASSequence) si.nextSequence(); // System.err.println("Got: " + dasSeq); // final BioJavaEntry bioJavaEntry = new BioJavaEntry (dasSeq); // return new Entry (bioJavaEntry); // } else { // System.err.println("No more sequences..."); // } // // final BioJavaEntry emblEntry = // // new BioJavaEntry (document, new EmblLikeFormat ()); // // return new Entry (emblEntry); // } catch (MalformedURLException mue) { // mue.printStackTrace(); // } catch (BioException be) { // be.printStackTrace(); // } // return null; final String fileName = "/nfs/team81/kmr/pow/java2/AE002734.game"; final FileDocument document = new FileDocument (new File (fileName)); final BioJavaEntry emblEntry = new BioJavaEntry (document, new EmblLikeFormat ()); return new Entry (emblEntry); // final String fileName = "/nfs/team81/kmr/pow/java2/AB000095.embl"; // final FileDocument document = new FileDocument (new File (fileName)); // final BioJavaEntry emblEntry = // new BioJavaEntry (document, new EmblLikeFormat ()); // return new Entry (emblEntry); } /** * Returns true if and only if this EntrySource always returns "full" * entries. ie. entries that contain features and sequence. **/ public boolean isFullEntrySource () { return true; } /** * Return the name of this source (for display to the user in menus). **/ public String getSourceName () { return "BioJava"; } }