Greg,

Thanks.  The first way does not work. I got the following error message.

*Database.cpp:148:15: **error: **cannot initialize a variable of type
'RDKit::Atom *'*

*      with an rvalue of type 'const RDKit::Atom *'*

        Atom *atom = (*pCurrentROMol)[*atBegin];


The second way, which uses "auto", works. I also updated the code for bond
and got a new error with the following error message.

*Database.cpp:164:49: **error: **no member named 'get' in 'RDKit::Bond'*

        sEdgeLabel += ((queryIsBondInRing(bond->get())) ? "ring|" :
"linear|" );

*                                          ~~~~  ^*

1 error generated.

Could you please confirm that the updated class Bond removes method get()?
If this is the case, which method should I use?

Again, thank you very much for your help!

Yingfeng



On Wed, Dec 12, 2018 at 12:58 AM Greg Landrum <[email protected]>
wrote:

> Hi Yingfeng,
>
> As part of the move over to Modern C++ we also changed the way atoms and
> bonds are stored in molecules: you now get raw pointers back instead of
> smart pointers.
> If you change your code from:
>  boost::shared_ptr<Atom> atom = (*pCurrentROMol)[*atBegin];
> to:
>  Atom *atom = (*pCurrentROMol)[*atBegin];
> or, even simpler:
>  auto atom = (*pCurrentROMol)[*atBegin];
>
> things should work.
> -greg
>
>
> On Wed, Dec 12, 2018 at 12:36 AM Yingfeng Wang <[email protected]> wrote:
>
>> I am using the C++ library of RDKit on Mac. My C++ code works with
>> RDKit_2017_09_3. However, after I switch to RDKit 2018_03_4, I got the
>> following error when compiling my C++ source code.
>>
>> *Database.cpp:148:33: **error: **no viable conversion from 'const
>> RDKit::Atom *' to*
>>
>> *      'boost::shared_ptr<Atom>'*
>>
>>         boost::shared_ptr<Atom> atom = (*pCurrentROMol)[*atBegin];
>>
>> *                                ^      ~~~~~~~~~~~~~~~~~~~~~~~~~~*
>>
>> */usr/local/Cellar/boost/1.68.0/include/boost/smart_ptr/shared_ptr.hpp:358:21:
>> **note: *
>>
>>       candidate constructor not viable: no known conversion from
>>
>>       'const RDKit::Atom *' to 'boost::detail::sp_nullptr_t' (aka
>> 'nullptr_t')
>>
>>       for 1st argument
>>
>>     BOOST_CONSTEXPR shared_ptr( boost::detail::sp_nullptr_t )
>> BOOST_SP_N...
>>
>> *                    ^*
>>
>> */usr/local/Cellar/boost/1.68.0/include/boost/smart_ptr/shared_ptr.hpp:422:5:
>> **note: *
>>
>>       candidate constructor not viable: no known conversion from
>>
>>       'const RDKit::Atom *' to 'const boost::shared_ptr<RDKit::Atom> &'
>> for 1st
>>
>>       argument
>>
>>     shared_ptr( shared_ptr const & r ) BOOST_SP_NOEXCEPT : px( r.px ),
>> p...
>>
>> *    ^*
>>
>> I am using Clang on Mac. The version information is given as follows.
>>
>> g++ -v
>>
>> Configured with: --prefix=/Library/Developer/CommandLineTools/usr
>> --with-gxx-include-dir=/Library/Developer/CommandLineTools/SDKs/MacOSX10.14.sdk/usr/include/c++/4.2.1
>>
>> Apple LLVM version 10.0.0 (clang-1000.10.44.4)
>>
>> Target: x86_64-apple-darwin18.2.0
>>
>> Thread model: posix
>>
>> I notice that "Starting with the 2018_03 release, the RDKit core C++
>> code is written in modern C++; for this release that means C++11. "
>>
>> Actually, I also use -std=c++11 when compiling my C++ source code. I
>> also tested RDKit 2018_09_1 and got the similar error. I am wondering how
>> to fix this problem.
>>
>> Thanks.
>>
>> Yingfeng
>>
>>
>> _______________________________________________
>> Rdkit-discuss mailing list
>> [email protected]
>> https://lists.sourceforge.net/lists/listinfo/rdkit-discuss
>>
>
_______________________________________________
Rdkit-discuss mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/rdkit-discuss

Reply via email to