// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
//
// Contact: phylosoft @ gmail . com
-// WWW: www.phylosoft.org/forester
+// WWW: https://sites.google.com/site/cmzmasek/home/software/forester
package org.forester.phylogeny.data;
private DomainArchitecture _da;
private List<Uri> _uris;
private List<SequenceRelation> _seq_relations;
+ private SortedSet<Accession> _xrefs;
public Sequence() {
init();
&& ForesterUtil.isEmpty( getType() ) && ForesterUtil.isEmpty( getLocation() )
&& ForesterUtil.isEmpty( getSourceId() ) && ForesterUtil.isEmpty( getMolecularSequence() )
&& ( getDomainArchitecture() == null ) && ForesterUtil.isEmpty( _annotations )
- && ForesterUtil.isEmpty( _uris ) && ForesterUtil.isEmpty( _seq_relations );
+ && ForesterUtil.isEmpty( _uris ) && ForesterUtil.isEmpty( _seq_relations )
+ && ( getCrossReferences() == null || getCrossReferences().isEmpty() );
}
public void addAnnotation( final Annotation annotation ) {
getAnnotations().add( annotation );
}
+
+ public void addCrossReference( Accession cross_reference ) {
+ if ( getCrossReferences() == null ) {
+ setCrossReferences( new TreeSet<Accession>() );
+ }
+ getCrossReferences().add( cross_reference );
+ }
+
+ public SortedSet<Accession> getCrossReferences() {
+ return _xrefs;
+ }
+
+ private void setCrossReferences( TreeSet<Accession> cross_references ) {
+ _xrefs = cross_references;
+ }
@Override
public void addUri( final Uri uri ) {
else {
seq.setDomainArchitecture( null );
}
+ if ( getCrossReferences() != null ) {
+ seq.setCrossReferences( new TreeSet<Accession>() );
+ for( final Accession x : getCrossReferences() ) {
+ if ( x != null ) {
+ seq.getCrossReferences().add( x);
+ }
+ }
+ }
return seq;
}
setUris( null );
setSequenceRelations( null );
setSourceId( null );
+ setCrossReferences(null);
}
@Override
String.valueOf( isMolecularSequenceAligned() ),
indentation );
}
- if ( getUris() != null ) {
+ if ( getUris() != null && !getUris().isEmpty() ) {
for( final Uri uri : getUris() ) {
if ( uri != null ) {
uri.toPhyloXML( writer, level, indentation );
}
}
}
- if ( _annotations != null ) {
+ if ( getAnnotations() != null && !getAnnotations().isEmpty() ) {
for( final PhylogenyData annotation : getAnnotations() ) {
annotation.toPhyloXML( writer, level, my_ind );
}
if ( getDomainArchitecture() != null ) {
getDomainArchitecture().toPhyloXML( writer, level, my_ind );
}
+ if ( getCrossReferences() != null && !getCrossReferences().isEmpty() ) {
+ writer.write( ForesterUtil.LINE_SEPARATOR );
+ writer.write( my_ind );
+ PhylogenyDataUtil.appendOpen( writer, PhyloXmlMapping.SEQUENCE_X_REFS );
+ for( final PhylogenyData x : getCrossReferences() ) {
+ x.toPhyloXML( writer, level, my_ind );
+ }
+ writer.write( ForesterUtil.LINE_SEPARATOR );
+ writer.write( my_ind );
+ PhylogenyDataUtil.appendClose( writer, PhyloXmlMapping.SEQUENCE_X_REFS );
+ }
writer.write( ForesterUtil.LINE_SEPARATOR );
writer.write( indentation );
PhylogenyDataUtil.appendClose( writer, PhyloXmlMapping.SEQUENCE );