tax_tree_ds.cpp

来自「ncbi源码」· C++ 代码 · 共 216 行

CPP
216
字号
/* * =========================================================================== * PRODUCTION $Log: tax_tree_ds.cpp,v $ * PRODUCTION Revision 1000.0  2004/06/01 21:31:39  gouriano * PRODUCTION PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.2 * PRODUCTION * =========================================================================== *//*  $Id: tax_tree_ds.cpp,v 1000.0 2004/06/01 21:31:39 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. * * =========================================================================== * * Authors:  Mike DiCuccio * * File Description: * */#include <ncbi_pch.hpp>#include <gui/widgets/tax_tree/tax_tree_ds.hpp>#include <objects/seq/Bioseq.hpp>#include <objmgr/util/sequence.hpp>#include <objmgr/seqdesc_ci.hpp>#include <gui/objutils/label.hpp>#include <algorithm>BEGIN_NCBI_SCOPEUSING_SCOPE(objects);CTaxTreeDS_ObjMgr::CTaxTreeDS_ObjMgr(CScope& scope, const TUidVec& uids)    : m_Scope(&scope)    , m_Mode(eDisplay_Default)    , m_Ids(uids){    m_TaxCache.Init();    TTaxMap tax_map;    GetTaxMap(tax_map);    vector<TTaxId> tax_ids_in;    vector<TTaxId> tax_ids_out;    tax_ids_in.reserve(tax_map.size());    ITERATE(TTaxMap, iter, tax_map) {        _TRACE("tax-id: " << iter->first << " seqs: " << iter->second.size());        tax_ids_in.push_back(iter->first);    }    if (tax_ids_in.size() == 0) {        NCBI_THROW(CException, eUnknown,                   "Can't generate common tree for sequences:\n"                   "No taxonomy IDs found.");    }    if ( !m_TaxCache.GetPopsetJoin(tax_ids_in, tax_ids_out) ) {        NCBI_THROW(CException, eUnknown,                   "Can't generate common tree for sequences");    }}ITreeIterator& CTaxTreeDS_ObjMgr::GetIterator(EDisplayMode mode){    if ( !m_Iter  ||  mode != m_Mode) {        // first, fill our internal tree structure        CTaxon1::EIteratorMode iter_mode = CTaxon1::eIteratorMode_Default;        switch (mode) {        default:        case eDisplay_All:            break;        case eDisplay_Best:            iter_mode = CTaxon1::eIteratorMode_Best;            break;        case eDisplay_Blast:            iter_mode = CTaxon1::eIteratorMode_Blast;            break;        }        m_Iter.Reset(m_TaxCache.GetTreeIterator(iter_mode));        m_Mode = mode;    }    return *m_Iter;}void CTaxTreeDS_ObjMgr::GetTaxMap(TTaxMap& tax_map){    TUidVec uids;    GetUids(uids);    ITERATE (TUidVec, iter, uids) {        TTaxId tax_id = 0;        // first, see if we can get it from the sequence        CBioseq_Handle handle = m_Scope->GetBioseqHandle(**iter);        tax_id = sequence::GetTaxId(handle);        // if not, try the tax server        if ( !tax_id ) {            m_TaxCache.GetTaxId4GI(*iter, tax_id);        }        // if we've got something, add it to our cache        if (tax_id) {            tax_map[tax_id].push_back(*iter);        } else {            string str;            CLabel::GetLabel(**iter, &str, CLabel::eDefault, m_Scope);            LOG_POST(Info << "No tax-id for sequence: " << str);        }    }}void CTaxTreeDS_ObjMgr::GetUids(TUidVec& uids){    uids = m_Ids;}void CTaxTreeDS_ObjMgr::GetTitle(const CSeq_id& id, string* title) const{    if (title) {        title->erase();        CBioseq_Handle handle = m_Scope->GetBioseqHandle(id);        const CSeq_id& best_id = sequence::GetId(handle, sequence::eGetId_Best);        best_id.GetLabel(title, CSeq_id::eContent);    }}void CTaxTreeDS_ObjMgr::GetTitle(const ITaxon1Node& node, string* title) const{    if (title) {        *title = node.GetName();    }}const CRef<objects::CScope> &  CTaxTreeDS_ObjMgr::GetScope(void){    return m_Scope;}END_NCBI_SCOPE/* * =========================================================================== * $Log: tax_tree_ds.cpp,v $ * Revision 1000.0  2004/06/01 21:31:39  gouriano * PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.2 * * Revision 1.2  2004/05/21 22:27:55  gorelenk * Added PCH ncbi_pch.hpp * * Revision 1.1  2004/05/13 17:31:46  dicuccio * Renamed data source file * * Revision 1.8  2004/04/09 16:53:32  tereshko * Added functionality to send/accept selections * * Revision 1.7  2004/04/07 13:12:44  dicuccio * Changed internal storage of sequence information to use CConstRef<CSeq_id> * * Revision 1.6  2004/04/01 19:03:13  dicuccio * Added support for limiting the list of displayed nodes.  Changed retrieval of * tax-id to favor sequence first * * Revision 1.5  2004/03/05 17:43:00  dicuccio * Use sequence::GetId() instead of CSeq-id::GetStringDescr() * * Revision 1.4  2004/01/27 18:49:25  dicuccio * Restored functionality * * Revision 1.3  2004/01/07 18:55:36  dicuccio * Code clean-up.  Don't forget to initialize or CTaxon1 class * * Revision 1.2  2003/12/23 15:39:18  dicuccio * Altered the data source - expose an ITreeIterator; the widget no longer * directly creates a CTaxon1 class.  Chaned storage notion from 'gi' to 'uid' * * Revision 1.1  2003/12/22 19:42:59  dicuccio * Initial revision * * =========================================================================== */

⌨️ 快捷键说明

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