⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 flat_head.hpp

📁 ncbi源码
💻 HPP
字号:
/* * =========================================================================== * PRODUCTION $Log: flat_head.hpp,v $ * PRODUCTION Revision 1000.0  2003/10/29 20:59:17  gouriano * PRODUCTION PRODUCTION: IMPORTED [ORIGINAL] Dev-tree R1.4 * PRODUCTION * =========================================================================== */#ifndef OBJECTS_FLAT___FLAT_HEAD__HPP#define OBJECTS_FLAT___FLAT_HEAD__HPP/*  $Id: flat_head.hpp,v 1000.0 2003/10/29 20:59:17 gouriano Exp $* ===========================================================================**                            PUBLIC DOMAIN NOTICE*               National Center for Biotechnology Information**  This software/database is a "United States Government Work" under the*  terms of the United States Copyright Act.  It was written as part of*  the author's official duties as a United States Government employee and*  thus cannot be copyrighted.  This software/database is freely available*  to the public for use. The National Library of Medicine and the U.S.*  Government have not placed any restriction on its use or reproduction.**  Although all reasonable efforts have been taken to ensure the accuracy*  and reliability of the software and data, the NLM and the U.S.*  Government do not and cannot warrant the performance or results that*  may be obtained by using this software or data. The NLM and the U.S.*  Government disclaim all warranties, express or implied, including*  warranties of performance, merchantability or fitness for any particular*  purpose.**  Please cite the author in any work or product based on this material.** ===========================================================================** Author:  Aaron Ucko, NCBI** File Description:*   New (early 2003) flat-file generator -- representation of "header"*   data, which translates into a format-dependent sequence of paragraphs.**/#include <objtools/flat/flat_formatter.hpp>#include <serial/enumvalues.hpp>#include <objects/seq/Bioseq.hpp>#include <objects/seq/Seqdesc.hpp>#include <objects/seqblock/EMBL_block.hpp>BEGIN_NCBI_SCOPEBEGIN_SCOPE(objects)// Ultimately split into several paragraphs in a format-dependent manner// (e.g., LOCUS, DEFINITION, ACCESSION, [PID,] VERSION, DBSOURCE for GenPept)class CFlatHead : public IFlatItem{public:    // also fills in some fields of ctx, which we don't bother duplicating    CFlatHead(CFlatContext& ctx);    void Format(IFlatFormatter& f) const { f.FormatHead(*this); }    typedef CEMBL_block::TDiv    TEMBLDiv;    typedef CSeq_inst::TStrand   TStrand;    typedef CSeq_inst::TTopology TTopology;    const string&       GetLocus       (void) const { return m_Locus;         }    TStrand             GetStrandedness(void) const { return m_Strandedness;  }    const char*         GetMolString   (void) const;    TTopology           GetTopology    (void) const { return m_Topology;      }    string              GetDivision    (void) const;    const CDate&        GetUpdateDate  (void) const { return *m_UpdateDate;   }    const CDate&        GetCreateDate  (void) const { return *m_CreateDate;   }    const string        GetDefinition  (void) const { return m_Definition;    }    const CBioseq::TId& GetOtherIDs    (void) const { return m_OtherIDs;      }    const list<string>& GetSecondaryIDs(void) const { return m_SecondaryIDs;  }    const list<string>& GetDBSource    (void) const { return m_DBSource;      }    const CSeqdesc*     GetProteinBlock(void) const { return m_ProteinBlock;  }private:    void x_AddDate(const CDate& date);    void x_AddDBSource(void);    // helpers for various components    string x_FormatDBSourceID(const CSeq_id& id);    void x_AddPIRBlock(void);    void x_AddSPBlock(void);    void x_AddPRFBlock(void);    void x_AddPDBBlock(void);    string              m_Locus;    TStrand             m_Strandedness;    TTopology           m_Topology;    const string*       m_GBDivision;    TEMBLDiv            m_EMBLDivision;    CConstRef<CDate>    m_UpdateDate;    CConstRef<CDate>    m_CreateDate;    string              m_Definition;    CBioseq::TId        m_OtherIDs; // current    list<string>        m_SecondaryIDs; // predecessors    list<string>        m_DBSource; // for proteins; relatively free-form    CConstRef<CSeqdesc> m_ProteinBlock;    CRef<CFlatContext>  m_Context;};inlinestring CFlatHead::GetDivision(void) const{    if (m_Context->GetFormatter().GetDatabase() == IFlatFormatter::eDB_EMBL) {        return CEMBL_block::GetTypeInfo_enum_EDiv()->FindName            (m_EMBLDivision, true);    } else if (m_GBDivision) {        return *m_GBDivision;    } else {        return "UNK";    }}END_SCOPE(objects)END_NCBI_SCOPE/** ===========================================================================** $Log: flat_head.hpp,v $* Revision 1000.0  2003/10/29 20:59:17  gouriano* PRODUCTION: IMPORTED [ORIGINAL] Dev-tree R1.4** Revision 1.4  2003/06/02 16:01:39  dicuccio* Rearranged include/objects/ subtree.  This includes the following shifts:*     - include/objects/alnmgr --> include/objtools/alnmgr*     - include/objects/cddalignview --> include/objtools/cddalignview*     - include/objects/flat --> include/objtools/flat*     - include/objects/objmgr/ --> include/objmgr/*     - include/objects/util/ --> include/objmgr/util/*     - include/objects/validator --> include/objtools/validator** Revision 1.3  2003/04/24 16:15:57  vasilche* Added missing includes and forward class declarations.** Revision 1.2  2003/03/21 18:47:47  ucko* Turn most structs into (accessor-requiring) classes; replace some* formerly copied fields with pointers to the original data.** Revision 1.1  2003/03/10 16:39:08  ucko* Initial check-in of new flat-file generator*** ===========================================================================*/#endif  /* OBJECTS_FLAT___FLAT_HEAD__HPP */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -