seqdbvol.hpp

来自「ncbi源码」· HPP 代码 · 共 148 行

HPP
148
字号
/* * =========================================================================== * PRODUCTION $Log: seqdbvol.hpp,v $ * PRODUCTION Revision 1000.0  2004/04/15 15:06:27  gouriano * PRODUCTION PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.11 * PRODUCTION * =========================================================================== */#ifndef OBJTOOLS_READERS_SEQDB__SEQDBVOL_HPP#define OBJTOOLS_READERS_SEQDB__SEQDBVOL_HPP/*  $Id: seqdbvol.hpp,v 1000.0 2004/04/15 15:06:27 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:  Kevin Bealer * *//// CSeqDBVol class/// /// This object defines access to one database volume.#include <iostream>#include <objtools/readers/seqdb/seqdb.hpp>#include "seqdbfile.hpp"#include <sstream>#include <objects/seq/NCBI2na.hpp>#include <objects/seq/NCBI4na.hpp>#include <objects/seq/NCBIstdaa.hpp>#include <objects/seq/Seq_data.hpp>#include <objects/seq/Seq_descr.hpp>#include <objects/seq/Seqdesc.hpp>#include <objects/seq/Seq_inst.hpp>#include <serial/objistr.hpp>#include <serial/serial.hpp>#include <corelib/ncbimtx.hpp>BEGIN_NCBI_SCOPEusing namespace ncbi::objects;class CSeqDBVol : public CObject {public:    CSeqDBVol(CSeqDBMemPool & mempool,              const string  & name,              char            prot_nucl,              bool            use_mmap)        : m_MemPool(mempool),          m_VolName(name),          m_Idx(mempool, name, prot_nucl, use_mmap),          m_Seq(mempool, name, prot_nucl, use_mmap),          m_Hdr(mempool, name, prot_nucl, use_mmap)    {    }        Int4 GetSeqLength(Uint4 oid, bool approx) const;        Int4 GetSeqLengthApprox(Uint4 oid) const;        CRef<CBlast_def_line_set> GetHdr(Uint4 oid) const;        char GetSeqType(void) const;        CRef<CBioseq> GetBioseq(Int4 oid,                            bool use_objmgr,                            bool insert_ctrlA) const;        Int4 GetSequence(Int4 oid, const char ** buffer) const;        Int4 GetAmbigSeq(Int4            oid,                     char         ** buffer,                     Uint4           nucl_code,                     ESeqDBAllocType alloc_type) const;        list< CRef<CSeq_id> > GetSeqIDs(Uint4 oid) const;        string GetTitle(void) const;        string GetDate(void) const;        Uint4  GetNumSeqs(void) const;        Uint8  GetTotalLength(void) const;        Uint4  GetMaxLength(void) const;        string GetVolName(void) const    {        return m_VolName;    }    private:    CRef<CBlast_def_line_set> x_GetHdr(Uint4 oid) const;    char   x_GetSeqType(void) const;    bool   x_GetAmbChar(Uint4 oid, vector<Int4> ambchars) const;    Int4   x_GetSequence(Int4 oid, const char ** buffer) const;    Int4   x_GetAmbigSeq(Int4            oid,                         char         ** buffer,                         Uint4           nucl_code,                         ESeqDBAllocType alloc_type) const;        char * x_AllocType(Uint4           length,                       ESeqDBAllocType alloc_type) const;        CSeqDBMemPool      & m_MemPool;    string               m_VolName;    mutable CFastMutex   m_Lock;    CSeqDBIdxFile        m_Idx;    CSeqDBSeqFile        m_Seq;    CSeqDBHdrFile        m_Hdr;};END_NCBI_SCOPE#endif // OBJTOOLS_READERS_SEQDB__SEQDBVOL_HPP

⌨️ 快捷键说明

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