Skip to content
Snippets Groups Projects
BioJavaEntrySource.java 7.94 KiB
Newer Older
  • Learn to ignore specific revisions
  • tjc's avatar
    tjc committed
    /* 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";
      }
    }