1fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// Protocol Buffers - Google's data interchange format
2fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// Copyright 2008 Google Inc.  All rights reserved.
3afb4b72037e3f13db208590fc782c4bc8e27f862Jeff Davidson// https://developers.google.com/protocol-buffers/
4fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//
5fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// Redistribution and use in source and binary forms, with or without
6fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// modification, are permitted provided that the following conditions are
7fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// met:
8fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//
9fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//     * Redistributions of source code must retain the above copyright
10fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// notice, this list of conditions and the following disclaimer.
11fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//     * Redistributions in binary form must reproduce the above
12fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// copyright notice, this list of conditions and the following disclaimer
13fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// in the documentation and/or other materials provided with the
14fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// distribution.
15fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//     * Neither the name of Google Inc. nor the names of its
16fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// contributors may be used to endorse or promote products derived from
17fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// this software without specific prior written permission.
18fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//
19fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
31fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville// Author: kenton@google.com (Kenton Varda)
32fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//  Based on original Protocol Buffers design by
33fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville//  Sanjay Ghemawat, Jeff Dean, and others.
34fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
35fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville#ifndef GOOGLE_PROTOBUF_COMPILER_JAVA_MESSAGE_H__
36fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville#define GOOGLE_PROTOBUF_COMPILER_JAVA_MESSAGE_H__
37fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
38fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville#include <string>
39a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson#include <map>
40fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville#include <google/protobuf/compiler/java/java_field.h>
41fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
42fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Savillenamespace google {
43fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Savillenamespace protobuf {
44a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  namespace compiler {
45a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson    namespace java {
46a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson      class Context;           // context.h
47a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson      class ClassNameResolver; // name_resolver.h
48a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson    }
49a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  }
50fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  namespace io {
51fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville    class Printer;             // printer.h
52fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  }
53fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville}
54fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
55fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Savillenamespace protobuf {
56fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Savillenamespace compiler {
57fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Savillenamespace java {
58fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
59b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammerstatic const int kMaxStaticSize = 1 << 15;  // aka 32k
60b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer
61fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Savilleclass MessageGenerator {
62fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville public:
63fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  explicit MessageGenerator(const Descriptor* descriptor);
64a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual ~MessageGenerator();
65fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
66fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // All static variables have to be declared at the top-level of the file
67fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // so that we can control initialization order, which is important for
68fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // DescriptorProto bootstrapping to work.
69b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  virtual void GenerateStaticVariables(
70b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer      io::Printer* printer, int* bytecode_estimate) = 0;
71fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
72fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // Output code which initializes the static variables generated by
73b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  // GenerateStaticVariables(). Returns an estimate of bytecode size.
74b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  virtual int GenerateStaticVariableInitializers(io::Printer* printer) = 0;
75fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
76fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // Generate the class itself.
77a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual void Generate(io::Printer* printer) = 0;
78a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
79a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  // Generates the base interface that both the class and its builder implement
80a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual void GenerateInterface(io::Printer* printer) = 0;
81fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
82fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // Generate code to register all contained extensions with an
83fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  // ExtensionRegistry.
84a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual void GenerateExtensionRegistrationCode(io::Printer* printer) = 0;
85a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
86a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson protected:
87a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  const Descriptor* descriptor_;
88fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
89fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville private:
90a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(MessageGenerator);
91a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson};
92a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
93a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidsonclass ImmutableMessageGenerator : public MessageGenerator {
94a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson public:
95a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  explicit ImmutableMessageGenerator(const Descriptor* descriptor,
96a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson                                     Context* context);
97a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual ~ImmutableMessageGenerator();
98a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
99a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual void Generate(io::Printer* printer);
100a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual void GenerateInterface(io::Printer* printer);
101a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  virtual void GenerateExtensionRegistrationCode(io::Printer* printer);
102b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  virtual void GenerateStaticVariables(
103b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer      io::Printer* printer, int* bytecode_estimate);
104b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer
105b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  // Returns an estimate of the number of bytes the printed code will compile to
106b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  virtual int GenerateStaticVariableInitializers(io::Printer* printer);
107a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
108a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson private:
109a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
110b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  void GenerateFieldAccessorTable(io::Printer* printer, int* bytecode_estimate);
111b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer
112b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  // Returns an estimate of the number of bytes the printed code will compile to
113b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  int GenerateFieldAccessorTableInitializer(io::Printer* printer);
114a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson
115fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  void GenerateMessageSerializationMethods(io::Printer* printer);
116fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  void GenerateParseFromMethods(io::Printer* printer);
117fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  void GenerateSerializeOneField(io::Printer* printer,
118fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville                                 const FieldDescriptor* field);
119fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  void GenerateSerializeOneExtensionRange(
120fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville      io::Printer* printer, const Descriptor::ExtensionRange* range);
121fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
122fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville  void GenerateBuilder(io::Printer* printer);
123b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  void GenerateIsInitialized(io::Printer* printer);
124a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  void GenerateDescriptorMethods(io::Printer* printer);
125b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  void GenerateInitializers(io::Printer* printer);
126a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  void GenerateEqualsAndHashCode(io::Printer* printer);
127a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  void GenerateParser(io::Printer* printer);
128a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  void GenerateParsingConstructor(io::Printer* printer);
129b0575e93e4c39dec69365b850088a1eb7f82c5b3Tamas Berghammer  void GenerateAnyMethods(io::Printer* printer);
130fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
131a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  Context* context_;
132a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  ClassNameResolver* name_resolver_;
133a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  FieldGeneratorMap<ImmutableFieldGenerator> field_generators_;
134fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
135a3b2a6da25a76f17c73d31def3952feb0fd2296eJeff Davidson  GOOGLE_DISALLOW_EVIL_CONSTRUCTORS(ImmutableMessageGenerator);
136fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville};
137fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
138fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville}  // namespace java
139fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville}  // namespace compiler
140fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville}  // namespace protobuf
141fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville
142fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville}  // namespace google
143fbaaef999ba563838ebd00874ed8a1c01fbf286dWink Saville#endif  // GOOGLE_PROTOBUF_COMPILER_JAVA_MESSAGE_H__
144