gbseq_formatter.hpp
上传用户:yhdzpy8989
上传日期:2007-06-13
资源大小:13604k
文件大小:5k
源码类别:

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: gbseq_formatter.hpp,v $
  4.  * PRODUCTION Revision 1000.1  2004/06/01 19:38:49  gouriano
  5.  * PRODUCTION PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.2
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef OBJTOOLS_FORMAT___GBSEQ_FORMATTER__HPP
  10. #define OBJTOOLS_FORMAT___GBSEQ_FORMATTER__HPP
  11. /*  $Id: gbseq_formatter.hpp,v 1000.1 2004/06/01 19:38:49 gouriano Exp $
  12. * ===========================================================================
  13. *
  14. *                            PUBLIC DOMAIN NOTICE
  15. *               National Center for Biotechnology Information
  16. *
  17. *  This software/database is a "United States Government Work" under the
  18. *  terms of the United States Copyright Act.  It was written as part of
  19. *  the author's official duties as a United States Government employee and
  20. *  thus cannot be copyrighted.  This software/database is freely available
  21. *  to the public for use. The National Library of Medicine and the U.S.
  22. *  Government have not placed any restriction on its use or reproduction.
  23. *
  24. *  Although all reasonable efforts have been taken to ensure the accuracy
  25. *  and reliability of the software and data, the NLM and the U.S.
  26. *  Government do not and cannot warrant the performance or results that
  27. *  may be obtained by using this software or data. The NLM and the U.S.
  28. *  Government disclaim all warranties, express or implied, including
  29. *  warranties of performance, merchantability or fitness for any particular
  30. *  purpose.
  31. *
  32. *  Please cite the author in any work or product based on this material.
  33. *
  34. * ===========================================================================
  35. *
  36. * Author:  Aaron Ucko, NCBI
  37. *          Mati Shomrat
  38. *
  39. * File Description:
  40. *   GBSeq formatting
  41. */
  42. #include <corelib/ncbistd.hpp>
  43. #include <serial/objectio.hpp>
  44. #include <objects/gbseq/GBSeq.hpp>
  45. #include <objtools/format/item_formatter.hpp>
  46. BEGIN_NCBI_SCOPE
  47. BEGIN_SCOPE(objects)
  48. class CLocusItem;
  49. class CDeflineItem;
  50. class CAccessionItem;
  51. class CVersionItem;
  52. class CKeywordsItem;
  53. class CSourceItem;
  54. class CReferenceItem;
  55. class CCommentItem;
  56. class CFeatureItemBase;
  57. class CSequenceItem;
  58. class CSegmentItem;
  59. class CContigItem;
  60. class CGBSeqFormatter : public CFlatItemFormatter
  61. {
  62. public:
  63.     CGBSeqFormatter(void);
  64.     ~CGBSeqFormatter(void);
  65.     virtual void Start       (IFlatTextOStream&);
  66.     virtual void StartSection(const CStartSectionItem&, IFlatTextOStream&);
  67.     virtual void EndSection  (const CEndSectionItem&, IFlatTextOStream&);
  68.     virtual void End         (IFlatTextOStream&);
  69.     virtual void FormatLocus(const CLocusItem& locus, IFlatTextOStream& text_os);
  70.     virtual void FormatDefline(const CDeflineItem& defline, IFlatTextOStream& text_os);
  71.     virtual void FormatAccession(const CAccessionItem& acc, IFlatTextOStream& text_os);
  72.     virtual void FormatVersion(const CVersionItem& version, IFlatTextOStream& text_os);
  73.     virtual void FormatKeywords(const CKeywordsItem& keys, IFlatTextOStream& text_os);
  74.     virtual void FormatSource(const CSourceItem& source, IFlatTextOStream& text_os);
  75.     virtual void FormatReference(const CReferenceItem& keys, IFlatTextOStream& text_os);
  76.     virtual void FormatComment(const CCommentItem& keys, IFlatTextOStream& text_os);
  77.     virtual void FormatFeature(const CFeatureItemBase& feat, IFlatTextOStream& text_os);
  78.     virtual void FormatSequence(const CSequenceItem& seq, IFlatTextOStream& text_os);
  79.     virtual void FormatSegment(const CSegmentItem& seg, IFlatTextOStream& text_os);
  80.     virtual void FormatContig(const CContigItem& contig, IFlatTextOStream& text_os);
  81. private:
  82.     void x_WriteFileHeader(IFlatTextOStream& text_os);
  83.     void x_StartWriteGBSet(IFlatTextOStream& text_os);
  84.     void x_WriteGBSeq(IFlatTextOStream& text_os);
  85.     void x_EndWriteGBSet(IFlatTextOStream& text_os);
  86.     void x_StrOStreamToTextOStream(IFlatTextOStream& text_os);
  87.     struct SOStreamContainer
  88.     {
  89.         SOStreamContainer(CObjectOStream& out, 
  90.             const CObjectTypeInfo& containerType) :
  91.             m_Cont(out, containerType)
  92.         {}
  93.         void WriteElement(const CConstObjectInfo& element) {
  94.             m_Cont.WriteElement(element);
  95.         }
  96.     private:
  97.         COStreamContainer  m_Cont;
  98.     };
  99.     CRef<CGBSeq> m_GBSeq;
  100.     auto_ptr<CObjectOStream> m_Out;
  101.     CNcbiOstrstream m_StrStream;
  102.     auto_ptr<SOStreamContainer>  m_Cont;
  103. };
  104. END_SCOPE(objects)
  105. END_NCBI_SCOPE
  106. /*
  107. * ===========================================================================
  108. *
  109. * $Log: gbseq_formatter.hpp,v $
  110. * Revision 1000.1  2004/06/01 19:38:49  gouriano
  111. * PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.2
  112. *
  113. * Revision 1.2  2004/04/22 15:45:05  shomrat
  114. * Start/End section changed
  115. *
  116. * Revision 1.1  2004/04/13 16:43:59  shomrat
  117. * Inital Revision
  118. *
  119. *
  120. * ===========================================================================
  121. */
  122. #endif  /* OBJTOOLS_FORMAT___GBSEQ_FORMATTER__HPP */