Blame view

3rdparty/boost_1_81_0/libs/python/test/pickle1.cpp 1.63 KB
73ef4ff3   Hu Chunming   提交三方库
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
  // Copyright Ralf W. Grosse-Kunstleve 2002-2004. Distributed under the Boost
  // Software License, Version 1.0. (See accompanying
  // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  
  /*
      This example shows how to make an Extension Class "pickleable".
  
      The world class below can be fully restored by passing the
      appropriate argument to the constructor. Therefore it is sufficient
      to define the pickle interface method __getinitargs__.
  
      For more information refer to boost/libs/python/doc/pickle.html.
   */
  
  #include <boost/python/module.hpp>
  #include <boost/python/def.hpp>
  #include <boost/python/class.hpp>
  #include <boost/python/tuple.hpp>
  
  #include <string>
  
  namespace boost_python_test {
  
    // A friendly class.
    class world
    {
      private:
        std::string country;
      public:
        world(const std::string& _country) {
          this->country = _country;
        }
        std::string greet() const { return "Hello from " + country + "!"; }
        std::string get_country() const { return country; }
    };
  
    struct world_pickle_suite : boost::python::pickle_suite
    {
      static
      boost::python::tuple
      getinitargs(const world& w)
      {
          return boost::python::make_tuple(w.get_country());
      }
    };
  
    // To support test of "pickling not enabled" error message.
    struct noop {};
  }
  
  BOOST_PYTHON_MODULE(pickle1_ext)
  {
    using namespace boost::python;
    using namespace boost_python_test;
    class_<world>("world", init<const std::string&>())
        .def("greet", &world::greet)
        .def_pickle(world_pickle_suite())
        ;
  
    // To support test of "pickling not enabled" error message.
    class_<noop>("noop");
  }