#ifndef GUI_UTILS___PRIMARY_EDIT__HPP #define GUI_UTILS___PRIMARY_EDIT__HPP /* $Id: primary_edit.hpp 47106 2022-08-09 13:30:47Z asztalos $ * =========================================================================== * * 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: Igor Filippov * * File Description: * */ #include <corelib/ncbiobj.hpp> #include <objects/general/Object_id.hpp> #include <objmgr/bioseq_handle.hpp> #include <objmgr/seqdesc_ci.hpp> BEGIN_NCBI_SCOPE BEGIN_SCOPE(objects) // This object is intended to be created on the fly // Not related to any other bio object // But it can be used by Seqdesc editor for initialization and // after modification applied to CBioseq_Handle. class CPrimaryEdit : public CSeqdesc { public: CPrimaryEdit(CBioseq_Handle& bh) : m_BH(bh) { for ( CSeqdesc_CI desc(m_BH, CSeqdesc::e_User); desc; ++desc ) { const CUser_object& o = desc->GetUser(); if ( o.IsSetType() && o.GetType().IsStr() && o.GetType().GetStr() == "TpaAssembly") { SetUser(const_cast<CUser_object&>(desc->GetUser())); break; } } } CBioseq_Handle GetBioseq_Handle() const { return m_BH; } protected: CBioseq_Handle m_BH; }; END_SCOPE(objects) END_NCBI_SCOPE #endif // GUI_UTILS___PRIMARY_EDIT__HPP
0001 0002 0003 0004 0005 0006 0007 0008 0009 0010 0011 0012 0013 0014 0015 0016 0017 0018 0019 0020 0021 0022 0023 0024 0025 0026 0027 0028 0029 0030 0031 0032 0033 0034 0035 0036 0037 0038 0039 0040 0041 0042 0043 0044 0045 0046 0047 0048 0049 0050 0051 0052 0053 0054 0055 0056 0057 0058 0059 0060 0061 0062 0063 0064 0065 0066 0067 0068 0069 0070 0071 0072 0073 0074 0075