📄 split_parser.hpp
字号:
/* * =========================================================================== * PRODUCTION $Log: split_parser.hpp,v $ * PRODUCTION Revision 1000.0 2004/04/12 17:38:02 gouriano * PRODUCTION PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.3 * PRODUCTION * =========================================================================== */#ifndef ID2_PARSER__HPP_INCLUDED#define ID2_PARSER__HPP_INCLUDED/* $Id: split_parser.hpp,v 1000.0 2004/04/12 17:38:02 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: Eugene Vasilchenko * * File Description: Methods to create object manager structures from ID2 spec * */#include <corelib/ncbiobj.hpp>#include <util/range.hpp>#include <vector>#include <utility>BEGIN_NCBI_SCOPEBEGIN_SCOPE(objects)class CID2S_Split_Info;class CID2S_Chunk_Info;class CID2S_Chunk;class CID2S_Seq_annot_Info;class CID2S_Seq_annot_place_Info;class CID2_Seq_loc;class CTSE_Info;class CTSE_Chunk_Info;class NCBI_XREADER_EXPORT CSplitParser{public: static void Attach(CTSE_Info& tse, const CID2S_Split_Info& split); static CRef<CTSE_Chunk_Info> Parse(const CID2S_Chunk_Info& info); static void Load(CTSE_Chunk_Info& chunk, const CID2S_Chunk& data); static void x_Attach(CTSE_Chunk_Info& chunk, const CID2S_Seq_annot_Info& annot); static void x_Attach(CTSE_Chunk_Info& chunk, const CID2S_Seq_annot_place_Info& place); typedef int TLocationId; typedef CRange<TSeqPos> TLocationRange; typedef pair<TLocationId, TLocationRange> TLocation; typedef vector<TLocation> TLocationSet; static void x_ParseLocation(TLocationSet& vec, const CID2_Seq_loc& loc);protected: static void x_AddWhole(TLocationSet& vec, const TLocationId& id); static void x_AddInterval(TLocationSet& vec, const TLocationId& id, TSeqPos start, TSeqPos length);};END_SCOPE(objects)END_NCBI_SCOPE/** $Log: split_parser.hpp,v $* Revision 1000.0 2004/04/12 17:38:02 gouriano* PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.3** Revision 1.3 2004/01/28 20:53:42 vasilche* Added CSplitParser::Attach().** Revision 1.2 2004/01/22 22:28:31 vasilche* Added export specifier.** Revision 1.1 2004/01/22 20:10:33 vasilche* 1. Splitted ID2 specs to two parts.* ID2 now specifies only protocol.* Specification of ID2 split data is moved to seqsplit ASN module.* For now they are still reside in one resulting library as before - libid2.* As the result split specific headers are now in objects/seqsplit.* 2. Moved ID2 and ID1 specific code out of object manager.* Protocol is processed by corresponding readers.* ID2 split parsing is processed by ncbi_xreader library - used by all readers.* 3. Updated OBJMGR_LIBS correspondingly.***/#endif//ID2_PARSER__HPP_INCLUDED
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -