blob: 77e0ed76143abb5acb5d26863972acc8543c3732 [file] [log] [blame]
Adam Lesinski6f6ceb72014-11-14 14:48:12 -08001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef AAPT_JAVA_CLASS_GENERATOR_H
18#define AAPT_JAVA_CLASS_GENERATOR_H
19
20#include "ResourceTable.h"
21#include "ResourceValues.h"
Adam Lesinski76565542016-03-10 21:55:04 -080022#include "process/IResourceTableConsumer.h"
Adam Lesinski1ab598f2015-08-14 14:26:04 -070023#include "util/StringPiece.h"
24
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080025#include <ostream>
26#include <string>
27
28namespace aapt {
29
Adam Lesinskib274e352015-11-06 15:14:35 -080030class AnnotationProcessor;
Adam Lesinski6cbfb1d2016-03-31 13:33:02 -070031class ClassDefinition;
Adam Lesinskib274e352015-11-06 15:14:35 -080032
Adam Lesinski1ab598f2015-08-14 14:26:04 -070033struct JavaClassGeneratorOptions {
34 /*
35 * Specifies whether to use the 'final' modifier
36 * on resource entries. Default is true.
37 */
38 bool useFinal = true;
Adam Lesinski9e10ac72015-10-16 14:37:48 -070039
40 enum class SymbolTypes {
41 kAll,
42 kPublicPrivate,
43 kPublic,
44 };
45
Adam Lesinski9e10ac72015-10-16 14:37:48 -070046 SymbolTypes types = SymbolTypes::kAll;
Adam Lesinski3524a232016-04-01 19:19:24 -070047
48 /**
49 * A list of JavaDoc annotations to add to the comments of all generated classes.
50 */
51 std::vector<std::string> javadocAnnotations;
Adam Lesinski1ab598f2015-08-14 14:26:04 -070052};
53
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080054/*
55 * Generates the R.java file for a resource table.
56 */
Adam Lesinski1ab598f2015-08-14 14:26:04 -070057class JavaClassGenerator {
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080058public:
Adam Lesinski76565542016-03-10 21:55:04 -080059 JavaClassGenerator(IAaptContext* context, ResourceTable* table,
60 const JavaClassGeneratorOptions& options);
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080061
62 /*
Adam Lesinski769de982015-04-10 19:43:55 -070063 * Writes the R.java file to `out`. Only symbols belonging to `package` are written.
64 * All symbols technically belong to a single package, but linked libraries will
65 * have their names mangled, denoting that they came from a different package.
66 * We need to generate these symbols in a separate file.
67 * Returns true on success.
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080068 */
Adam Lesinski9e10ac72015-10-16 14:37:48 -070069 bool generate(const StringPiece16& packageNameToGenerate, std::ostream* out);
70
71 bool generate(const StringPiece16& packageNameToGenerate,
72 const StringPiece16& outputPackageName,
73 std::ostream* out);
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080074
75 const std::string& getError() const;
76
77private:
Adam Lesinski6cbfb1d2016-03-31 13:33:02 -070078 bool addMembersToTypeClass(const StringPiece16& packageNameToGenerate,
79 const ResourceTablePackage* package,
80 const ResourceTableType* type,
81 ClassDefinition* outTypeClassDef);
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080082
Adam Lesinski6cbfb1d2016-03-31 13:33:02 -070083 void addMembersToStyleableClass(const StringPiece16& packageNameToGenerate,
84 const std::u16string& entryName,
85 const Styleable* styleable,
86 ClassDefinition* outStyleableClassDef);
Adam Lesinski1ab598f2015-08-14 14:26:04 -070087
Adam Lesinski9e10ac72015-10-16 14:37:48 -070088 bool skipSymbol(SymbolState state);
89
Adam Lesinski76565542016-03-10 21:55:04 -080090 IAaptContext* mContext;
Adam Lesinski1ab598f2015-08-14 14:26:04 -070091 ResourceTable* mTable;
92 JavaClassGeneratorOptions mOptions;
Adam Lesinski6f6ceb72014-11-14 14:48:12 -080093 std::string mError;
94};
95
96inline const std::string& JavaClassGenerator::getError() const {
97 return mError;
98}
99
100} // namespace aapt
101
102#endif // AAPT_JAVA_CLASS_GENERATOR_H