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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: seqdboidlist.hpp,v $
  4.  * PRODUCTION Revision 1000.0  2004/04/15 15:06:17  gouriano
  5.  * PRODUCTION PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.6
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef OBJTOOLS_READERS_SEQDB__SEQDBOIDLIST_HPP
  10. #define OBJTOOLS_READERS_SEQDB__SEQDBOIDLIST_HPP
  11. /*  $Id: seqdboidlist.hpp,v 1000.0 2004/04/15 15:06:17 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:  Kevin Bealer
  37.  *
  38.  */
  39. /// CSeqDBOIDList class
  40. /// 
  41. /// This object defines access to one database aliasume.
  42. #include <objtools/readers/seqdb/seqdb.hpp>
  43. #include "seqdbfile.hpp"
  44. #include "seqdbvolset.hpp"
  45. BEGIN_NCBI_SCOPE
  46. using namespace ncbi::objects;
  47. class CSeqDBOIDList : public CObject {
  48. public:
  49.     typedef Uint4 TOID;
  50.     
  51.     CSeqDBOIDList(CSeqDBVolSet & volumes, bool use_mmap);
  52.     
  53.     ~CSeqDBOIDList();
  54.     
  55.     bool CheckOrFindOID(TOID & next_oid) const
  56.     {
  57.         if (x_IsSet(next_oid)) {
  58.             return true;
  59.         }
  60.         return x_FindNext(next_oid);
  61.     }
  62.     
  63. private:
  64.     typedef const unsigned char TCUC;
  65.     typedef unsigned char TUC;
  66.     
  67.     bool x_IsSet   (TOID   oid) const;
  68.     void x_SetBit  (TOID   oid);
  69.     bool x_FindNext(TOID & oid) const;
  70.     
  71.     void x_Setup(const string & filename, bool use_mmap);
  72.     void x_Setup(CSeqDBVolSet & volset, bool use_mmap);
  73.     void x_OrFileBits(const string & mask_fname, Uint4 oid_start, Uint4 oid_end, bool use_mmap);
  74.     void x_SetBitRange(Uint4 oid_start, Uint4 oid_end);
  75.     
  76.     // Data
  77.     
  78.     CSeqDBMemPool         m_MemPool;
  79.     CRef<CSeqDBRawFile>   m_RawFile;
  80.     Uint4                 m_NumOIDs;
  81.     
  82.     TUC                 * m_Bits;
  83.     TUC                 * m_BitEnd;
  84. };
  85. END_NCBI_SCOPE
  86. #endif // OBJTOOLS_READERS_SEQDB__SEQDBOIDLIST_HPP