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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: source_item.hpp,v $
  4.  * PRODUCTION Revision 1000.1  2004/06/01 19:40:26  gouriano
  5.  * PRODUCTION PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.2
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef OBJTOOLS_FORMAT_ITEMS___SOURCE_ITEM__HPP
  10. #define OBJTOOLS_FORMAT_ITEMS___SOURCE_ITEM__HPP
  11. /*  $Id: source_item.hpp,v 1000.1 2004/06/01 19:40:26 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. *   Source item for flat-file generator
  41. *
  42. */
  43. #include <corelib/ncbistd.hpp>
  44. #include <list>
  45. #include <objtools/format/items/item_base.hpp>
  46. BEGIN_NCBI_SCOPE
  47. BEGIN_SCOPE(objects)
  48. class CGB_block;
  49. class CSeqdesc;
  50. class CBioSource;
  51. class CBioseqContext;
  52. class IFormatter;
  53. ///////////////////////////////////////////////////////////////////////////
  54. //
  55. // SOURCE
  56. //   ORGANISM
  57. class CSourceItem : public CFlatItem
  58. {
  59. public:
  60.     CSourceItem(CBioseqContext& ctx);
  61.     void Format(IFormatter& formatter, IFlatTextOStream& text_os) const;
  62.     const string&       GetTaxname      (void) const;
  63.     const string&       GetCommon       (void) const;
  64.     const string&       GetLineage      (void) const;
  65.     const string&       GetOrganelle    (void) const;
  66.     const string&       GetSourceLine   (void) const;
  67.     const list<string>& GetMod          (void) const;
  68.     bool                IsUsingAnamorph (void) const;
  69.     // TaxId ???
  70. private:
  71.     void x_GatherInfo(CBioseqContext& ctx);
  72.     // Populate the object based on the source of the data
  73.     void x_SetSource(const CGB_block&  gb, const CSeqdesc& desc);
  74.     void x_SetSource(const CBioSource& bsrc, const CSerialObject& obj);
  75.     // static members
  76.     static const string       scm_Unknown;
  77.     static const string       scm_Unclassified;
  78.     static const list<string> scm_EmptyList;
  79.     // data
  80.     const string*       m_Taxname;
  81.     const string*       m_Common;
  82.     const string*       m_Organelle;
  83.     const string*       m_Lineage;       // semicolon-delimited
  84.     const string*       m_SourceLine;    // for "old" format style
  85.     const list<string>* m_Mod;
  86.     bool                m_UsingAnamorph;
  87. };
  88. /////////////////////////////////////////////////////////////////////////////
  89. //
  90. // inline methods
  91. inline
  92. const string& CSourceItem::GetTaxname(void) const
  93.     return *m_Taxname;
  94. }
  95. inline
  96. const string& CSourceItem::GetCommon(void) const
  97.     return *m_Common;
  98. }
  99. inline
  100. const string& CSourceItem::GetLineage(void) const
  101.     return *m_Lineage;
  102. }
  103. inline
  104. const string& CSourceItem::GetOrganelle(void) const
  105.     return *m_Organelle;
  106. }
  107. inline
  108. const string& CSourceItem::GetSourceLine(void) const
  109.     return *m_SourceLine;
  110. }
  111. inline
  112. const list<string>& CSourceItem::GetMod(void) const
  113.     return *m_Mod;
  114. }
  115. inline
  116. bool CSourceItem::IsUsingAnamorph(void) const
  117.     return m_UsingAnamorph;
  118. }
  119. END_SCOPE(objects)
  120. END_NCBI_SCOPE
  121. /*
  122. * ===========================================================================
  123. *
  124. * $Log: source_item.hpp,v $
  125. * Revision 1000.1  2004/06/01 19:40:26  gouriano
  126. * PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.2
  127. *
  128. * Revision 1.2  2004/04/22 15:40:05  shomrat
  129. * Changes in context
  130. *
  131. * Revision 1.1  2003/12/17 19:50:09  shomrat
  132. * Initial revision (adapted from flat lib)
  133. *
  134. *
  135. * ===========================================================================
  136. */
  137. #endif  /* OBJTOOLS_FORMAT_ITEMS___SOURCE_ITEM__HPP */