locus_link.cpp

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

CPP
219
字号
/* * =========================================================================== * PRODUCTION $Log: locus_link.cpp,v $ * PRODUCTION Revision 1000.5  2004/06/01 20:56:50  gouriano * PRODUCTION PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.10 * PRODUCTION * =========================================================================== *//*  $Id: locus_link.cpp,v 1000.5 2004/06/01 20:56:50 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 "locus_link.hpp"#include "utils.hpp"#include <gui/plugin/PluginInfo.hpp>#include <gui/plugin/PluginRequest.hpp>#include <gui/plugin/PluginCommand.hpp>#include <gui/plugin/PluginCommandSet.hpp>#include <gui/plugin/PluginArgSet.hpp>#include <gui/plugin/PluginArg.hpp>#include <gui/core/version.hpp>#include <gui/core/idocument.hpp>#include <gui/core/plugin_utils.hpp>#include <gui/utils/app_popup.hpp>#include <corelib/ncbiapp.hpp>#include <corelib/ncbireg.hpp>#include <objmgr/util/feature.hpp>#include <objmgr/util/sequence.hpp>#include <objects/seq/Bioseq.hpp>#include <objects/seqfeat/Org_ref.hpp>#include <objects/general/Dbtag.hpp>#include <objects/general/Object_id.hpp>BEGIN_NCBI_SCOPEUSING_SCOPE(objects);// standard info boilerplatevoid CAlgoLinkOut_LocusLink::GetInfo(CPluginInfo& info){    info.Reset();    // version info macro    info.SetInfo(CPluginVersion::eMajor, CPluginVersion::eMinor, 0,                 string(__DATE__) + " " + string(__TIME__),                 "CAlgoLinkOut_LocusLink", "Link Out/LocusLink",                 "Open items in LocusLink", "");    // command info    CPluginCommandSet& cmds = info.SetCommands();    CPluginCommand&    args = cmds.AddAlgoCommand(eAlgoCommand_run);    args.AddArgument("gene", "Gene to search",                     CSeq_feat::GetTypeInfo());    args.SetConstraint("gene",                       (*CPluginValueConstraint::CreateFeatType(),                        CSeqFeatData::e_Gene));    args.AddArgument("orgn", "Limit to originating organism",                     CPluginArg::eBoolean);}// run our pluginvoid CAlgoLinkOut_LocusLink::RunCommand(CPluginMessage& msg){    const CPluginCommand& args = msg.GetRequest().GetCommand();    CPluginReply& reply = msg.SetReply();    plugin_args::TFeatList genes;    GetArgValue(args["gene"], genes);    const CSeq_feat& feat = *genes.front().second;    const IDocument& doc  = *genes.front().first;    bool limit_to_orgn = args["orgn"].AsBoolean();    // retrieve the default link for LocusLink    CNcbiApplication* app = CNcbiApplication::Instance();    _ASSERT(app);    const CNcbiRegistry& reg = app->GetConfig();    string locus_link_url =        reg.GetString("LINKOUT", "LocusLink",                      "http://www.ncbi.nlm.nih.gov/LocusLink/list.cgi?"                      "Q=<gene>");    string gene_name;    feature::GetLabel(feat, &gene_name, feature::eContent, &doc.GetScope());    locus_link_url = NStr::Replace(locus_link_url, "<gene>", gene_name);    //    // check for species    //    if (limit_to_orgn) {        string species_tag;        CBioseq_Handle handle =            doc.GetScope().GetBioseqHandle(feat.GetLocation());        CConstRef<COrg_ref> ref = GetOrganism(handle);        if (ref) {            switch (ref->GetTaxId()) {            default:                break;            case 9606:                // homo sapiens                species_tag = "Hs";                break;            case 7227:                // drosophila melanogaster                species_tag = "Dm";                break;            case 7955:                // danio rerio (zebrafish                species_tag = "Dr";                break;            case 10090:                // mus musculus                species_tag = "Mm";                break;            case 10116:                // rattus norvegicus                species_tag = "Rn";                break;            }            if ( !species_tag.empty() ) {                locus_link_url += "&ORG=" + species_tag;            }        }    }    if ( !CAppPopup::PopupURL(locus_link_url) ) {        reply.SetStatus(eMessageStatus_failed);    } else {        reply.SetStatus(eMessageStatus_success);    }}END_NCBI_SCOPE/* * =========================================================================== * $Log: locus_link.cpp,v $ * Revision 1000.5  2004/06/01 20:56:50  gouriano * PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.10 * * Revision 1.10  2004/05/21 22:27:47  gorelenk * Added PCH ncbi_pch.hpp * * Revision 1.9  2004/01/27 18:45:26  dicuccio * Added missing header files * * Revision 1.8  2003/11/24 15:45:31  dicuccio * Renamed CVersion to CPluginVersion * * Revision 1.7  2003/11/06 20:12:13  dicuccio * Cleaned up handling of USING_SCOPE - removed from all headers * * Revision 1.6  2003/11/04 17:49:24  dicuccio * Changed calling parameters for plugins - pass CPluginMessage instead of paired * CPluginCommand/CPluginReply * * Revision 1.5  2003/10/15 18:30:01  dicuccio * Changed to match one-of-set constraint for feature type * * Revision 1.4  2003/10/07 13:47:04  dicuccio * Renamed CPluginURL* to CPluginValue* * * Revision 1.3  2003/09/25 17:49:17  dicuccio * Cleaned up handling of org-refs - implemented private function to return the * apporpriate COrg_ref.  Added virtual destructors where necessary * * Revision 1.2  2003/09/24 18:24:57  dicuccio * Cleaned up determination of tax-id from org-ref * * Revision 1.1  2003/09/23 19:45:45  dicuccio * Initial revision * * =========================================================================== */

⌨️ 快捷键说明

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