店播爬取Python脚本

message_factory.h 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. // Protocol Buffers - Google's data interchange format
  2. // Copyright 2008 Google Inc. All rights reserved.
  3. // https://developers.google.com/protocol-buffers/
  4. //
  5. // Redistribution and use in source and binary forms, with or without
  6. // modification, are permitted provided that the following conditions are
  7. // met:
  8. //
  9. // * Redistributions of source code must retain the above copyright
  10. // notice, this list of conditions and the following disclaimer.
  11. // * Redistributions in binary form must reproduce the above
  12. // copyright notice, this list of conditions and the following disclaimer
  13. // in the documentation and/or other materials provided with the
  14. // distribution.
  15. // * Neither the name of Google Inc. nor the names of its
  16. // contributors may be used to endorse or promote products derived from
  17. // this software without specific prior written permission.
  18. //
  19. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  20. // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  21. // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  22. // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  23. // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  24. // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  25. // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  26. // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  27. // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  28. // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  29. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  30. #ifndef GOOGLE_PROTOBUF_PYTHON_CPP_MESSAGE_FACTORY_H__
  31. #define GOOGLE_PROTOBUF_PYTHON_CPP_MESSAGE_FACTORY_H__
  32. #include <Python.h>
  33. #include <unordered_map>
  34. #include <google/protobuf/descriptor.h>
  35. #include <google/protobuf/pyext/descriptor_pool.h>
  36. namespace google {
  37. namespace protobuf {
  38. class MessageFactory;
  39. namespace python {
  40. // The (meta) type of all Messages classes.
  41. struct CMessageClass;
  42. struct PyMessageFactory {
  43. PyObject_HEAD
  44. // DynamicMessageFactory used to create C++ instances of messages.
  45. // This object cache the descriptors that were used, so the DescriptorPool
  46. // needs to get rid of it before it can delete itself.
  47. //
  48. // Note: A C++ MessageFactory is different from the PyMessageFactory.
  49. // The C++ one creates messages, when the Python one creates classes.
  50. MessageFactory* message_factory;
  51. // Owned reference to a Python DescriptorPool.
  52. // This reference must stay until the message_factory is destructed.
  53. PyDescriptorPool* pool;
  54. // Make our own mapping to retrieve Python classes from C++ descriptors.
  55. //
  56. // Descriptor pointers stored here are owned by the DescriptorPool above.
  57. // Python references to classes are owned by this PyDescriptorPool.
  58. typedef std::unordered_map<const Descriptor*, CMessageClass*>
  59. ClassesByMessageMap;
  60. ClassesByMessageMap* classes_by_descriptor;
  61. };
  62. extern PyTypeObject PyMessageFactory_Type;
  63. namespace message_factory {
  64. // Creates a new MessageFactory instance.
  65. PyMessageFactory* NewMessageFactory(PyTypeObject* type, PyDescriptorPool* pool);
  66. // Registers a new Python class for the given message descriptor.
  67. // On error, returns -1 with a Python exception set.
  68. int RegisterMessageClass(PyMessageFactory* self,
  69. const Descriptor* message_descriptor,
  70. CMessageClass* message_class);
  71. // Retrieves the Python class registered with the given message descriptor, or
  72. // fail with a TypeError. Returns a *borrowed* reference.
  73. CMessageClass* GetMessageClass(PyMessageFactory* self,
  74. const Descriptor* message_descriptor);
  75. // Retrieves the Python class registered with the given message descriptor.
  76. // The class is created if not done yet. Returns a *new* reference.
  77. CMessageClass* GetOrCreateMessageClass(PyMessageFactory* self,
  78. const Descriptor* message_descriptor);
  79. } // namespace message_factory
  80. // Initialize objects used by this module.
  81. // On error, returns false with a Python exception set.
  82. bool InitMessageFactory();
  83. } // namespace python
  84. } // namespace protobuf
  85. } // namespace google
  86. #endif // GOOGLE_PROTOBUF_PYTHON_CPP_MESSAGE_FACTORY_H__