blob: 455c239a936bd9cec724ab65e85092b743fa1070 [file] [log] [blame]
temporal40ee5512008-07-10 02:12:20 +00001// Protocol Buffers - Google's data interchange format
kenton@google.com24bf56f2008-09-24 20:31:01 +00002// Copyright 2008 Google Inc. All rights reserved.
temporal40ee5512008-07-10 02:12:20 +00003// http://code.google.com/p/protobuf/
4//
kenton@google.com24bf56f2008-09-24 20:31:01 +00005// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are
7// met:
temporal40ee5512008-07-10 02:12:20 +00008//
kenton@google.com24bf56f2008-09-24 20:31:01 +00009// * 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.
temporal40ee5512008-07-10 02:12:20 +000018//
kenton@google.com24bf56f2008-09-24 20:31:01 +000019// 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.
temporal40ee5512008-07-10 02:12:20 +000030
31// Author: kenton@google.com (Kenton Varda)
32// Based on original Protocol Buffers design by
33// Sanjay Ghemawat, Jeff Dean, and others.
34
35#include <google/protobuf/compiler/code_generator.h>
36
kenton@google.comfccb1462009-12-18 02:11:36 +000037#include <google/protobuf/stubs/common.h>
kenton@google.com80b1d622009-07-29 01:13:20 +000038#include <google/protobuf/stubs/strutil.h>
39
temporal40ee5512008-07-10 02:12:20 +000040namespace google {
41namespace protobuf {
42namespace compiler {
43
44CodeGenerator::~CodeGenerator() {}
liujisi@google.com33165fe2010-11-02 13:14:58 +000045GeneratorContext::~GeneratorContext() {}
temporal40ee5512008-07-10 02:12:20 +000046
liujisi@google.com33165fe2010-11-02 13:14:58 +000047io::ZeroCopyOutputStream* GeneratorContext::OpenForInsert(
kenton@google.comfccb1462009-12-18 02:11:36 +000048 const string& filename, const string& insertion_point) {
liujisi@google.com33165fe2010-11-02 13:14:58 +000049 GOOGLE_LOG(FATAL) << "This GeneratorContext does not support insertion.";
kenton@google.comfccb1462009-12-18 02:11:36 +000050 return NULL; // make compiler happy
51}
52
liujisi@google.com33165fe2010-11-02 13:14:58 +000053void GeneratorContext::ListParsedFiles(
54 vector<const FileDescriptor*>* output) {
55 GOOGLE_LOG(FATAL) << "This GeneratorContext does not support ListParsedFiles";
56}
57
kenton@google.com80b1d622009-07-29 01:13:20 +000058// Parses a set of comma-delimited name/value pairs.
59void ParseGeneratorParameter(const string& text,
kenton@google.comfccb1462009-12-18 02:11:36 +000060 vector<pair<string, string> >* output) {
kenton@google.com80b1d622009-07-29 01:13:20 +000061 vector<string> parts;
62 SplitStringUsing(text, ",", &parts);
63
64 for (int i = 0; i < parts.size(); i++) {
65 string::size_type equals_pos = parts[i].find_first_of('=');
66 pair<string, string> value;
67 if (equals_pos == string::npos) {
68 value.first = parts[i];
69 value.second = "";
70 } else {
71 value.first = parts[i].substr(0, equals_pos);
72 value.second = parts[i].substr(equals_pos + 1);
73 }
74 output->push_back(value);
75 }
76}
77
temporal40ee5512008-07-10 02:12:20 +000078} // namespace compiler
79} // namespace protobuf
80} // namespace google