📄 seq_loc_mix.cpp
字号:
/* * =========================================================================== * PRODUCTION $Log: Seq_loc_mix.cpp,v $ * PRODUCTION Revision 1000.2 2004/06/01 19:34:40 gouriano * PRODUCTION PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R6.12 * PRODUCTION * =========================================================================== *//* $Id: Seq_loc_mix.cpp,v 1000.2 2004/06/01 19:34:40 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: * ....... * * Remark: * This code was originally generated by application DATATOOL * using specifications from the ASN data definition file * 'seqloc.asn'. */#include <ncbi_pch.hpp>#include <objects/seqloc/Seq_loc_mix.hpp>#include <objects/seqloc/Seq_interval.hpp>#include <objects/seqloc/Seq_point.hpp>BEGIN_NCBI_SCOPEBEGIN_objects_SCOPE // namespace ncbi::objects::CSeq_loc_mix::CSeq_loc_mix(void){ return;}CSeq_loc_mix::~CSeq_loc_mix(void){}bool CSeq_loc_mix::IsPartialLeft (void) const{ return Get ().front ()->IsPartialLeft ();}bool CSeq_loc_mix::IsPartialRight (void) const{ return Get ().back ()->IsPartialRight ();}void CSeq_loc_mix::SetPartialLeft (bool val){ if ( !Set().empty() ) { Set().front()->SetPartialLeft(val); } _ASSERT(val == IsPartialLeft());}void CSeq_loc_mix::SetPartialRight(bool val){ if ( !Set().empty() ) { Set().front()->SetPartialRight(val); } _ASSERT(val == IsPartialRight());}void CSeq_loc_mix::AddSeqLoc(const CSeq_loc& other){ if ( !other.IsMix() ) { CRef<CSeq_loc> loc(new CSeq_loc); loc->Assign(other); Set().push_back(loc); } else { // "flatten" the other seq-loc ITERATE(CSeq_loc_mix::Tdata, li, other.GetMix().Get()) { AddSeqLoc(**li); } }}void CSeq_loc_mix::AddSeqLoc(CSeq_loc& other){ if ( !other.IsMix() ) { CRef<CSeq_loc> loc(&other); Set().push_back(loc); } else { // "flatten" the other seq-loc NON_CONST_ITERATE(CSeq_loc_mix::Tdata, li, other.SetMix().Set()) { AddSeqLoc(**li); } }}void CSeq_loc_mix::AddInterval(const CSeq_id& id, TSeqPos from, TSeqPos to, ENa_strand strand){ CRef<CSeq_loc> loc(new CSeq_loc); if (from == to) { CSeq_point& pnt = loc->SetPnt(); pnt.SetPoint(from); pnt.SetId().Assign(id); if (strand != eNa_strand_unknown) { pnt.SetStrand(strand); } } else { CSeq_interval& ival = loc->SetInt(); ival.SetFrom(from); ival.SetTo(to); ival.SetId().Assign(id); if (strand != eNa_strand_unknown) { ival.SetStrand(strand); } } Set().push_back(loc);}END_objects_SCOPE // namespace ncbi::objects::END_NCBI_SCOPE/* * =========================================================================== * * $Log: Seq_loc_mix.cpp,v $ * Revision 1000.2 2004/06/01 19:34:40 gouriano * PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R6.12 * * Revision 6.12 2004/05/19 17:26:25 gorelenk * Added include of PCH - ncbi_pch.hpp * * Revision 6.11 2004/05/06 16:55:00 shomrat * Added methods to set partial left and right * * Revision 6.10 2004/01/28 17:18:19 shomrat * Added methods to ease the construction of objects * * Revision 6.9 2003/05/23 20:24:56 ucko * +AddInterval (also handles points automatically); CVS log -> end; * drop workaround for old WorkShop bug * * Revision 6.8 2002/09/12 21:19:02 kans * added IsPartialLeft and IsPartialRight * * Revision 6.7 2002/06/06 20:51:51 clausen * Moved GetLength to objects/util/sequence.cpp * * Revision 6.6 2002/05/03 21:28:19 ucko * Introduce T(Signed)SeqPos. * * Revision 6.5 2002/04/22 20:09:08 grichenk * -GetTotalRange(), GetRangeMap(), ResetRangeMap() * * Revision 6.4 2002/01/24 23:29:48 vakatov * Note for ourselves that the bug workaround "BW_010" is not needed * anymore, and we should get rid of it in about half a year * * Revision 6.3 2002/01/07 05:20:03 vakatov * Workaround for the SUN Forte 6 Update 1,2 compiler's internal bug. * * Revision 6.2 2001/01/03 16:39:05 vasilche * Added CAbstractObjectManager - stub for object manager. * CRange extracted to separate file. * * Revision 6.1 2000/11/17 21:35:10 vasilche * Added GetLength() method to CSeq_loc class. * * =========================================================================== */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -