blob: 6855aafd3baecf287b6bc76303105a3317ad0a0e [file] [log] [blame]
Will McVickerd7d18df2019-09-12 13:40:50 -07001/*
2 * Copyright (C) 2019, 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
Steven Moreland9fccf582018-08-27 20:36:27 -070017#pragma once
Christopher Wileyec31a052016-01-25 07:28:51 -080018
Casey Dahlinbc7a50a2015-09-28 19:20:50 -070019#include <memory>
Jeongik Cha997281d2020-01-16 15:23:59 +090020#include <regex>
Casey Dahlindd691812015-09-09 17:59:06 -070021#include <string>
Jeongik Chadf76dc72019-11-28 00:08:47 +090022#include <unordered_set>
Casey Dahlinbc7a50a2015-09-28 19:20:50 -070023#include <vector>
Casey Dahlindd691812015-09-09 17:59:06 -070024
Elliott Hughes0a620672015-12-04 13:53:18 -080025#include <android-base/strings.h>
Casey Dahlin73d46b02015-09-11 02:47:54 +000026
Jooyung Han888c5bc2020-12-22 17:28:47 +090027#include "aidl_typenames.h"
28#include "code_writer.h"
29#include "diagnostics.h"
30#include "io_delegate.h"
Jooyung Han535c5e82020-12-29 15:16:59 +090031#include "location.h"
32#include "logging.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090033#include "options.h"
34
Jiyong Parkb034bf02018-07-30 17:44:33 +090035using android::aidl::AidlTypenames;
Jiyong Park02da7422018-07-16 16:00:26 +090036using android::aidl::CodeWriter;
Jeongik Cha047c5ee2019-08-07 23:16:49 +090037using android::aidl::Options;
Steven Moreland3f658cf2018-08-20 13:40:54 -070038using std::shared_ptr;
Jiyong Park1deecc32018-07-17 01:14:41 +090039using std::string;
40using std::unique_ptr;
41using std::vector;
Andrei Onea8714b022019-02-01 18:55:54 +000042class AidlNode;
43
Jooyung Han535c5e82020-12-29 15:16:59 +090044// helper to see if T is the same to one of Args types.
45template <typename T, typename... Args>
46struct is_one_of : std::false_type {};
47
48template <typename T, typename S, typename... Args>
49struct is_one_of<T, S, Args...> {
50 enum { value = std::is_same_v<T, S> || is_one_of<T, Args...>::value };
51};
52
53// helper to see if T is std::vector of something.
54template <typename>
55struct is_vector : std::false_type {};
56
57template <typename T>
58struct is_vector<std::vector<T>> : std::true_type {};
59
60// helper for static_assert(false)
61template <typename T>
62struct unsupported_type : std::false_type {};
63
Andrei Onea8714b022019-02-01 18:55:54 +000064namespace android {
65namespace aidl {
66namespace mappings {
67std::string dump_location(const AidlNode& method);
68} // namespace mappings
Mathew Inwoodadb74672019-11-29 14:01:53 +000069namespace java {
70std::string dump_location(const AidlNode& method);
71} // namespace java
Andrei Onea8714b022019-02-01 18:55:54 +000072} // namespace aidl
73} // namespace android
74
Jooyung Han535c5e82020-12-29 15:16:59 +090075bool ParseFloating(std::string_view sv, double* parsed);
76bool ParseFloating(std::string_view sv, float* parsed);
Steven Moreland46e9da82018-07-27 15:45:29 -070077
Jooyung Han808a2a02020-12-28 16:46:54 +090078class AidlDocument;
Jooyung Han132cf802021-01-15 02:17:32 +090079class AidlPackage;
Jooyung Hanc5688f72021-01-05 15:41:48 +090080class AidlImport;
Jooyung Han808a2a02020-12-28 16:46:54 +090081class AidlInterface;
82class AidlParcelable;
83class AidlStructuredParcelable;
84class AidlEnumDeclaration;
85class AidlUnionDecl;
86class AidlVariableDeclaration;
87class AidlConstantDeclaration;
88class AidlEnumerator;
89class AidlMethod;
90class AidlArgument;
Jooyung Hanc5688f72021-01-05 15:41:48 +090091class AidlConstantValue;
92class AidlConstantReference;
93class AidlUnaryConstExpression;
94class AidlBinaryConstExpression;
95class AidlAnnotation;
Jooyung Han808a2a02020-12-28 16:46:54 +090096
Jiyong Park45854452020-12-31 10:42:28 +090097// Interface for visitors that can traverse AidlTraversable nodes.
Jooyung Han808a2a02020-12-28 16:46:54 +090098class AidlVisitor {
99 public:
100 virtual ~AidlVisitor() = default;
Jiyong Park45854452020-12-31 10:42:28 +0900101 virtual void Visit(const AidlDocument&) {}
102 virtual void Visit(const AidlInterface&) {}
103 virtual void Visit(const AidlParcelable&) {}
104 virtual void Visit(const AidlStructuredParcelable&) {}
105 virtual void Visit(const AidlUnionDecl&) {}
106 virtual void Visit(const AidlEnumDeclaration&) {}
107 virtual void Visit(const AidlEnumerator&) {}
108 virtual void Visit(const AidlMethod&) {}
109 virtual void Visit(const AidlVariableDeclaration&) {}
110 virtual void Visit(const AidlConstantDeclaration&) {}
111 virtual void Visit(const AidlArgument&) {}
Jooyung Han865da492021-01-03 11:32:47 +0900112 virtual void Visit(const AidlTypeSpecifier&) {}
Jooyung Hanc5688f72021-01-05 15:41:48 +0900113 virtual void Visit(const AidlConstantValue&) {}
114 virtual void Visit(const AidlConstantReference&) {}
115 virtual void Visit(const AidlUnaryConstExpression&) {}
116 virtual void Visit(const AidlBinaryConstExpression&) {}
117 virtual void Visit(const AidlAnnotation&) {}
118 virtual void Visit(const AidlImport&) {}
Jooyung Han132cf802021-01-15 02:17:32 +0900119 virtual void Visit(const AidlPackage&) {}
Jooyung Han808a2a02020-12-28 16:46:54 +0900120};
121
Steven Moreland46e9da82018-07-27 15:45:29 -0700122// Anything that is locatable in a .aidl file.
123class AidlNode {
124 public:
125 AidlNode(const AidlLocation& location);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700126
127 AidlNode(const AidlNode&) = default;
Steven Moreland46e9da82018-07-27 15:45:29 -0700128 virtual ~AidlNode() = default;
129
Jiyong Parkd800fef2020-07-22 18:09:43 +0900130 AidlNode(AidlNode&&) = delete;
131 AidlNode& operator=(AidlNode&&) = delete;
132
Devin Mooredf93ebb2020-03-25 14:03:35 -0700133 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700134 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000135 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000136 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700137
Devin Mooredf93ebb2020-03-25 14:03:35 -0700138 const AidlLocation& GetLocation() const { return location_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900139 virtual void TraverseChildren(std::function<void(const AidlNode&)> traverse) const = 0;
140 virtual void DispatchVisit(AidlVisitor&) const = 0;
Devin Mooredf93ebb2020-03-25 14:03:35 -0700141
Steven Moreland46e9da82018-07-27 15:45:29 -0700142 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000143 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000144 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700145 const AidlLocation location_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700146};
147
Jeongik Chadf76dc72019-11-28 00:08:47 +0900148// unique_ptr<AidlTypeSpecifier> for type arugment,
149// std::string for type parameter(T, U, and so on).
150template <typename T>
151class AidlParameterizable {
152 public:
153 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
154 virtual ~AidlParameterizable() = default;
155 bool IsGeneric() const { return type_params_ != nullptr; }
156 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
157 bool CheckValid() const;
158
Steven Moreland6c07b832020-10-29 23:39:53 +0000159 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
160 if (type_params_) return false;
161 type_params_.reset(type_params);
162 return true;
163 }
164
Jeongik Chadf76dc72019-11-28 00:08:47 +0900165 virtual const AidlNode& AsAidlNode() const = 0;
166
167 protected:
168 AidlParameterizable(const AidlParameterizable&);
169
170 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000171 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900172 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
173 std::is_same<T, std::string>::value);
174};
175template <>
176bool AidlParameterizable<std::string>::CheckValid() const;
177
Jooyung Han6736ffb2021-01-16 10:13:40 +0900178class AidlCommentable {
179 public:
180 AidlCommentable(const std::string& comments) : comments_(comments) {}
181 virtual ~AidlCommentable() = default;
182
183 const std::string& GetComments() const { return comments_; }
184 void SetComments(const std::string comments) { comments_ = comments; }
185 bool IsHidden() const;
186 bool IsDeprecated() const;
187 void Dump(CodeWriter& out) const;
188
189 private:
190 std::string comments_;
191};
Andrei Onea9445fc62019-06-27 18:11:59 +0100192
193// Transforms a value string into a language specific form. Raw value as produced by
194// AidlConstantValue.
195using ConstantValueDecorator =
196 std::function<std::string(const AidlTypeSpecifier& type, const std::string& raw_value)>;
197
Jooyung Han6736ffb2021-01-16 10:13:40 +0900198class AidlAnnotation : public AidlNode, public AidlCommentable {
Jiyong Park68bc77a2018-07-19 19:00:45 +0900199 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700200 enum class Type {
201 BACKING = 1,
202 HIDE,
203 JAVA_STABLE_PARCELABLE,
204 UNSUPPORTED_APP_USAGE,
205 VINTF_STABILITY,
206 NULLABLE,
207 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000208 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900209 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900210 JAVA_DERIVE,
Jeongik Chad0a10272020-08-06 16:33:36 +0900211 JAVA_ONLY_IMMUTABLE,
Devin Moorec7e47a32020-08-07 10:55:25 -0700212 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900213 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700214 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900215 SUPPRESS_WARNINGS,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700216 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900217
218 using TargetContext = uint16_t;
219 static constexpr TargetContext CONTEXT_TYPE_INTERFACE = 0x1 << 0;
220 static constexpr TargetContext CONTEXT_TYPE_ENUM = 0x1 << 1;
221 static constexpr TargetContext CONTEXT_TYPE_STRUCTURED_PARCELABLE = 0x1 << 2;
222 static constexpr TargetContext CONTEXT_TYPE_UNION = 0x1 << 3;
223 static constexpr TargetContext CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE = 0x1 << 4;
224 static constexpr TargetContext CONTEXT_TYPE =
225 CONTEXT_TYPE_INTERFACE | CONTEXT_TYPE_ENUM | CONTEXT_TYPE_STRUCTURED_PARCELABLE |
226 CONTEXT_TYPE_UNION | CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE;
227 static constexpr TargetContext CONTEXT_CONST = 0x1 << 5;
228 static constexpr TargetContext CONTEXT_FIELD = 0x1 << 6;
229 static constexpr TargetContext CONTEXT_METHOD = 0x1 << 7;
230 static constexpr TargetContext CONTEXT_MEMBER = CONTEXT_CONST | CONTEXT_FIELD | CONTEXT_METHOD;
231 static constexpr TargetContext CONTEXT_TYPE_SPECIFIER = 0x1 << 8;
232 static constexpr TargetContext CONTEXT_ALL =
233 CONTEXT_TYPE | CONTEXT_MEMBER | CONTEXT_TYPE_SPECIFIER;
234
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700235 static std::string TypeToString(Type type);
236
Andrei Onea9445fc62019-06-27 18:11:59 +0100237 static AidlAnnotation* Parse(
238 const AidlLocation& location, const string& name,
Jooyung Han6736ffb2021-01-16 10:13:40 +0900239 std::map<std::string, std::shared_ptr<AidlConstantValue>>* parameter_list,
240 const std::string& comments);
Steven Moreland46e9da82018-07-27 15:45:29 -0700241
Steven Moreland3f658cf2018-08-20 13:40:54 -0700242 AidlAnnotation(const AidlAnnotation&) = default;
Steven Moreland3be75772018-08-20 13:27:43 -0700243 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900244 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100245 bool CheckValid() const;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900246 bool CheckContext(TargetContext context) const;
Jooyung Hand902a972020-10-23 17:32:44 +0900247 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700248 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900249 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900250
251 // ToString is for dumping AIDL.
252 // Returns string representation of this annotation.
253 // e.g) "@RustDerive(Clone=true, Copy=true)"
254 string ToString() const;
255
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900256 template <typename T>
257 std::optional<T> ParamValue(const std::string& param_name) const;
258
Andrei Onea9445fc62019-06-27 18:11:59 +0100259 std::map<std::string, std::string> AnnotationParams(
260 const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900261 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
262 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900263
264 private:
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900265 struct ParamType {
266 std::string name;
267 const AidlTypeSpecifier& type;
268 bool required = false;
269 };
270
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700271 struct Schema {
272 AidlAnnotation::Type type;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700273 std::string name;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900274 TargetContext target_context;
275 std::vector<ParamType> parameters;
276 bool repeatable = false;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700277
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900278 const ParamType* ParamType(const std::string& name) const {
279 for (const auto& param : parameters) {
280 if (param.name == name) {
281 return &param;
282 }
283 }
284 return nullptr;
285 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700286 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900287
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700288 static const std::vector<Schema>& AllSchemas();
289
290 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Jooyung Han6736ffb2021-01-16 10:13:40 +0900291 std::map<std::string, std::shared_ptr<AidlConstantValue>>&& parameters,
292 const std::string& comments);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700293
294 const Schema& schema_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100295 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900296};
297
Steven Moreland3be75772018-08-20 13:27:43 -0700298static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
299 return lhs.GetName() < rhs.GetName();
300}
301static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
302 return lhs.GetName() == rhs.GetName();
303}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900304
Casey Dahline7922932016-02-29 17:23:01 -0800305class AidlAnnotatable : public AidlNode {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700306 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700307 AidlAnnotatable(const AidlLocation& location);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700308
309 AidlAnnotatable(const AidlAnnotatable&) = default;
310 AidlAnnotatable(AidlAnnotatable&&) = default;
Casey Dahline7922932016-02-29 17:23:01 -0800311 virtual ~AidlAnnotatable() = default;
312
Artur Satayev91fe8712019-07-29 13:06:01 +0100313 void Annotate(vector<AidlAnnotation>&& annotations) {
314 for (auto& annotation : annotations) {
315 annotations_.emplace_back(std::move(annotation));
316 }
317 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900318 bool IsNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900319 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000320 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700321 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900322 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700323 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900324 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800325 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900326 bool JavaDerive(const std::string& method) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900327 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100328
Steven Moreland7e4b9502020-02-20 18:10:42 -0800329 void DumpAnnotations(CodeWriter* writer) const;
330
Andrei Onea9445fc62019-06-27 18:11:59 +0100331 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700332 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900333 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900334 std::vector<std::string> SuppressWarnings() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900335
336 // ToString is for dumping AIDL.
337 // Returns string representation of annotations.
338 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900339 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800340
Jiyong Parka6605ab2018-11-11 14:30:21 +0900341 const vector<AidlAnnotation>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900342 bool CheckValid(const AidlTypenames&) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900343 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
344 for (const auto& annot : GetAnnotations()) {
345 traverse(annot);
346 }
347 }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900348
Casey Dahline7922932016-02-29 17:23:01 -0800349 private:
Jiyong Parka6605ab2018-11-11 14:30:21 +0900350 vector<AidlAnnotation> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800351};
352
Jiyong Park1deecc32018-07-17 01:14:41 +0900353// AidlTypeSpecifier represents a reference to either a built-in type,
354// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900355class AidlTypeSpecifier final : public AidlAnnotatable,
Jooyung Han6736ffb2021-01-16 10:13:40 +0900356 public AidlCommentable,
Jeongik Chadf76dc72019-11-28 00:08:47 +0900357 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800358 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700359 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name, bool is_array,
360 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const string& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900361 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700362
Steven Moreland3f658cf2018-08-20 13:40:54 -0700363 // Copy of this type which is not an array.
Jooyung Hand2fa0232020-10-19 02:51:41 +0900364 const AidlTypeSpecifier& ArrayBase() const;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700365
Jiyong Park1deecc32018-07-17 01:14:41 +0900366 // Returns the full-qualified name of the base type.
367 // int -> int
368 // int[] -> int
369 // List<String> -> List
370 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
371 const string& GetName() const {
372 if (IsResolved()) {
373 return fully_qualified_name_;
374 } else {
375 return GetUnresolvedName();
376 }
377 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700378
Jooyung Han965e31d2020-11-27 12:30:16 +0900379 // ToString is for dumping AIDL.
380 // Returns string representation of this type specifier including annotations.
381 // This is "annotations type_name type_params? array_marker?".
382 // e.g) "@utf8InCpp String[]";
383 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900384
Jooyung Han965e31d2020-11-27 12:30:16 +0900385 // Signature is for comparing AIDL types.
386 // Returns string representation of this type specifier.
387 // This is "type_name type_params? array_marker?".
388 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900389 std::string Signature() const;
390
Jiyong Park1deecc32018-07-17 01:14:41 +0900391 const string& GetUnresolvedName() const { return unresolved_name_; }
392
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900393 const std::vector<std::string> GetSplitName() const { return split_name_; }
394
Jiyong Park1deecc32018-07-17 01:14:41 +0900395 bool IsResolved() const { return fully_qualified_name_ != ""; }
396
397 bool IsArray() const { return is_array_; }
398
Steven Moreland6c07b832020-10-29 23:39:53 +0000399 __attribute__((warn_unused_result)) bool SetArray() {
400 if (is_array_) return false;
401 is_array_ = true;
402 return true;
403 }
404
Jiyong Park1deecc32018-07-17 01:14:41 +0900405 // Resolve the base type name to a fully-qualified name. Return false if the
406 // resolution fails.
Daniel Norman716d3112019-09-10 13:11:56 -0700407 bool Resolve(const AidlTypenames& typenames);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700408
Jooyung Han888c5bc2020-12-22 17:28:47 +0900409 bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700410 bool LanguageSpecificCheckValid(const AidlTypenames& typenames, Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900411 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900412
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900413 const AidlDefinedType* GetDefinedType() const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900414 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
415 AidlAnnotatable::TraverseChildren(traverse);
Jooyung Han865da492021-01-03 11:32:47 +0900416 if (IsGeneric()) {
417 for (const auto& tp : GetTypeParameters()) {
418 traverse(*tp);
419 }
420 }
421 }
422 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900423
Casey Dahlin0ee37582015-09-30 16:31:55 -0700424 private:
Steven Moreland3f658cf2018-08-20 13:40:54 -0700425 AidlTypeSpecifier(const AidlTypeSpecifier&) = default;
426
Jiyong Park1deecc32018-07-17 01:14:41 +0900427 const string unresolved_name_;
428 string fully_qualified_name_;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700429 bool is_array_;
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900430 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900431 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Jooyung Hand2fa0232020-10-19 02:51:41 +0900432 mutable shared_ptr<AidlTypeSpecifier> array_base_;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700433};
434
Steven Moreland860b1942018-08-16 14:59:28 -0700435// Returns the universal value unaltered.
436std::string AidlConstantValueDecorator(const AidlTypeSpecifier& type, const std::string& raw_value);
437
Jooyung Han8aeef8c2021-01-11 12:16:19 +0900438class AidlMember : public AidlNode, public AidlCommentable {
439 public:
440 AidlMember(const AidlLocation& location, const std::string& comments);
Jooyung Han3f347ca2020-12-01 12:41:50 +0900441 virtual ~AidlMember() = default;
442
443 // non-copyable, non-movable
444 AidlMember(const AidlMember&) = delete;
445 AidlMember(AidlMember&&) = delete;
446 AidlMember& operator=(const AidlMember&) = delete;
447 AidlMember& operator=(AidlMember&&) = delete;
448
Jooyung Han829ec7c2020-12-02 12:07:36 +0900449 virtual const AidlMethod* AsMethod() const { return nullptr; }
450 virtual const AidlConstantDeclaration* AsConstantDeclaration() const { return nullptr; }
451 virtual const AidlVariableDeclaration* AsVariableDeclaration() const { return nullptr; }
452
453 AidlMethod* AsMethod() {
454 return const_cast<AidlMethod*>(const_cast<const AidlMember*>(this)->AsMethod());
455 }
456 AidlConstantDeclaration* AsConstantDeclaration() {
457 return const_cast<AidlConstantDeclaration*>(
458 const_cast<const AidlMember*>(this)->AsConstantDeclaration());
459 }
460 AidlVariableDeclaration* AsVariableDeclaration() {
461 return const_cast<AidlVariableDeclaration*>(
462 const_cast<const AidlMember*>(this)->AsVariableDeclaration());
463 }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900464};
465
Steven Moreland541788d2020-05-21 22:05:52 +0000466// TODO: This class is used for method arguments and also parcelable fields,
467// and it should be split up since default values don't apply to method
468// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900469class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700470 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700471 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
472 const std::string& name);
473 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
474 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700475 virtual ~AidlVariableDeclaration() = default;
476
Jiyong Parkd800fef2020-07-22 18:09:43 +0900477 // non-copyable, non-movable
478 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
479 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
480 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
481 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
482
Jooyung Han829ec7c2020-12-02 12:07:36 +0900483 const AidlVariableDeclaration* AsVariableDeclaration() const override { return this; }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900484
Steven Moreland5557f1c2018-07-02 13:50:23 -0700485 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900486 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900487 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000488 // if this was constructed explicitly with a default value
489 bool IsDefaultUserSpecified() const { return default_user_specified_; }
490 // will return the default value this is constructed with or a default value
491 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700492 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900493 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700494
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900495 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700496
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900497 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900498
499 // ToString is for dumping AIDL.
500 // Returns string representation of this variable decl including default value.
501 // This is "annotations type name default_value?".
502 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700503 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900504
505 // Signature is for comparing AIDL types.
506 // Returns string representation of this variable decl.
507 // This is "type name".
508 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900509 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700510
Steven Moreland860b1942018-08-16 14:59:28 -0700511 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700512
Jooyung Hanc5688f72021-01-05 15:41:48 +0900513 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jiyong Park45854452020-12-31 10:42:28 +0900514 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900515
Steven Moreland5557f1c2018-07-02 13:50:23 -0700516 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900517 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700518 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000519 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700520 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700521};
522
523class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700524 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700525 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
526
Steven Moreland46e9da82018-07-27 15:45:29 -0700527 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
528 AidlTypeSpecifier* type, const std::string& name);
529 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700530 virtual ~AidlArgument() = default;
531
Jiyong Parkd800fef2020-07-22 18:09:43 +0900532 // non-copyable, non-movable
533 AidlArgument(const AidlArgument&) = delete;
534 AidlArgument(AidlArgument&&) = delete;
535 AidlArgument& operator=(const AidlArgument&) = delete;
536 AidlArgument& operator=(AidlArgument&&) = delete;
537
Casey Dahlinc378c992015-09-29 16:50:40 -0700538 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700539 bool IsOut() const { return direction_ & OUT_DIR; }
540 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700541 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900542 string GetDirectionSpecifier() const;
Christopher Wileyad339272015-10-05 19:11:58 -0700543
Jooyung Han965e31d2020-11-27 12:30:16 +0900544 // ToString is for dumping AIDL.
545 // Returns string representation of this argument including direction
546 // This is "direction annotations type name".
547 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700548 std::string ToString() const;
Jiyong Park512ed852020-12-30 15:07:23 +0900549
Jooyung Hanc5688f72021-01-05 15:41:48 +0900550 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900551 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900552 }
Jiyong Park45854452020-12-31 10:42:28 +0900553 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700554
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700555 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700556 Direction direction_;
557 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700558};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800559
Will McVickerd7d18df2019-09-12 13:40:50 -0700560class AidlUnaryConstExpression;
561class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900562class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700563
Steven Moreland693640b2018-07-19 13:46:27 -0700564class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800565 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700566 enum class Type {
567 // WARNING: Don't change this order! The order is used to determine type
568 // promotion during a binary expression.
569 BOOLEAN,
570 INT8,
571 INT32,
572 INT64,
573 ARRAY,
574 CHARACTER,
575 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900576 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700577 FLOATING,
578 UNARY,
579 BINARY,
580 ERROR,
581 };
582
Jooyung Han535c5e82020-12-29 15:16:59 +0900583 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700584 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900585 T EvaluatedValue() const {
586 is_evaluated_ || (CheckValid() && evaluate());
587 AIDL_FATAL_IF(!is_valid_, this);
588
589 if constexpr (is_vector<T>::value) {
590 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
591 T result;
592 for (const auto& v : values_) {
593 result.push_back(v->EvaluatedValue<typename T::value_type>());
594 }
595 return result;
596 } else if constexpr (is_one_of<T, float, double>::value) {
597 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
598 T result;
599 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
600 return result;
601 } else if constexpr (std::is_same<T, std::string>::value) {
602 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
603 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
604 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
605 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
606 return static_cast<T>(final_value_);
607 } else if constexpr (std::is_same<T, char>::value) {
608 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
609 return final_string_value_.at(1); // unquote '
610 } else if constexpr (std::is_same<T, bool>::value) {
611 static_assert(std::is_same<T, bool>::value, "..");
612 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
613 return final_value_ != 0;
614 } else {
615 static_assert(unsupported_type<T>::value);
616 }
617 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800618
Steven Moreland693640b2018-07-19 13:46:27 -0700619 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800620
Jiyong Parkd800fef2020-07-22 18:09:43 +0900621 // non-copyable, non-movable
622 AidlConstantValue(const AidlConstantValue&) = delete;
623 AidlConstantValue(AidlConstantValue&&) = delete;
624 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
625 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
626
Steven Moreland541788d2020-05-21 22:05:52 +0000627 // creates default value, when one isn't specified
628 // nullptr if no default available
629 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
630
Steven Moreland25294322018-08-07 18:13:55 -0700631 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
632 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700633 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700634 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
635 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700636 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700637 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700638 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700639 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700640
Will McVickerd7d18df2019-09-12 13:40:50 -0700641 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900642 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700643
Will McVickerd7d18df2019-09-12 13:40:50 -0700644 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700645
646 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800647 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900648
649 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const {
Jooyung Han29813842020-12-08 01:28:03 +0900650 if (type_ == Type::ARRAY) {
651 for (const auto& v : values_) {
Jooyung Hanc5688f72021-01-05 15:41:48 +0900652 traverse(*v);
Jooyung Han29813842020-12-08 01:28:03 +0900653 }
654 }
655 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900656 void DispatchVisit(AidlVisitor& visitor) const override { visitor.Visit(*this); }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800657
658 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700659 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
660 const string& checked_value);
661 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700662 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900663 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
664 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700665 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700666 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
667 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800668
Jooyung Han74675c22020-12-15 08:39:57 +0900669 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800670
Steven Moreland693640b2018-07-19 13:46:27 -0700671 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700672 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
673 const string value_; // otherwise
674
675 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800676 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
677 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700678 mutable Type final_type_;
679 mutable int64_t final_value_;
680 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700681
Will McVickerd7d18df2019-09-12 13:40:50 -0700682 friend AidlUnaryConstExpression;
683 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900684 friend AidlConstantReference;
685};
686
687// Represents "<type>.<field>" which resolves to a constant which is one of
688// - constant declartion
689// - enumerator
690// When a <type> is missing, <field> is of the enclosing type.
691class AidlConstantReference : public AidlConstantValue {
692 public:
Jooyung Hand0c8af02021-01-06 18:08:01 +0900693 AidlConstantReference(const AidlLocation& location, const std::string& value);
Jooyung Han690f5842020-12-04 13:02:04 +0900694
695 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900696 const std::string& GetFieldName() const { return field_name_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900697
698 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900699 void TraverseChildren(std::function<void(const AidlNode&)>) const override {
700 // resolved_ is not my child.
701 }
702 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900703 const AidlConstantValue* Resolve(const AidlDefinedType* scope) const;
Jooyung Han690f5842020-12-04 13:02:04 +0900704
705 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900706 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900707
708 std::unique_ptr<AidlTypeSpecifier> ref_type_;
709 std::string field_name_;
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900710 mutable const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700711};
712
713class AidlUnaryConstExpression : public AidlConstantValue {
714 public:
715 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
716 std::unique_ptr<AidlConstantValue> rval);
717
718 static bool IsCompatibleType(Type type, const string& op);
719 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900720 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
721 traverse(*unary_);
Jooyung Han690f5842020-12-04 13:02:04 +0900722 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900723 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han690f5842020-12-04 13:02:04 +0900724
Will McVickerd7d18df2019-09-12 13:40:50 -0700725 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900726 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700727
728 std::unique_ptr<AidlConstantValue> unary_;
729 const string op_;
730};
731
732class AidlBinaryConstExpression : public AidlConstantValue {
733 public:
734 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
735 const string& op, std::unique_ptr<AidlConstantValue> rval);
736
737 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700738
739 static bool AreCompatibleTypes(Type t1, Type t2);
740 // Returns the promoted kind for both operands
741 static Type UsualArithmeticConversion(Type left, Type right);
742 // Returns the promoted integral type where INT32 is the smallest type
743 static Type IntegralPromotion(Type in);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900744 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
745 traverse(*left_val_);
746 traverse(*right_val_);
Jooyung Han690f5842020-12-04 13:02:04 +0900747 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900748 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700749
750 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900751 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700752
753 std::unique_ptr<AidlConstantValue> left_val_;
754 std::unique_ptr<AidlConstantValue> right_val_;
755 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700756};
757
Andrei Onea9445fc62019-06-27 18:11:59 +0100758struct AidlAnnotationParameter {
759 std::string name;
760 std::unique_ptr<AidlConstantValue> value;
761};
762
Steven Moreland693640b2018-07-19 13:46:27 -0700763class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700764 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700765 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700766 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700767 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700768
Jiyong Parkd800fef2020-07-22 18:09:43 +0900769 // non-copyable, non-movable
770 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
771 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
772 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
773 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
774
Steven Moreland693640b2018-07-19 13:46:27 -0700775 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700776 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700777 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700778 const AidlConstantValue& GetValue() const { return *value_; }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900779 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700780
Jooyung Han965e31d2020-11-27 12:30:16 +0900781 // ToString is for dumping AIDL.
782 // Returns string representation of this const decl including a const value.
783 // This is "`const` annotations type name value".
784 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700785 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900786
787 // Signature is for comparing types.
788 // Returns string representation of this const decl.
789 // This is "direction annotations type name".
790 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700791 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900792
Steven Moreland860b1942018-08-16 14:59:28 -0700793 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700794 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700795 }
Steven Moreland25294322018-08-07 18:13:55 -0700796
Jooyung Han829ec7c2020-12-02 12:07:36 +0900797 const AidlConstantDeclaration* AsConstantDeclaration() const override { return this; }
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700798
Jooyung Hanc5688f72021-01-05 15:41:48 +0900799 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900800 traverse(GetType());
Jooyung Hanc5688f72021-01-05 15:41:48 +0900801 traverse(GetValue());
Jiyong Park512ed852020-12-30 15:07:23 +0900802 }
Jiyong Park45854452020-12-31 10:42:28 +0900803 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900804
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700805 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700806 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700807 const string name_;
808 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800809};
810
811class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700812 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700813 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
814 vector<unique_ptr<AidlArgument>>* args, const string& comments);
815 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
816 vector<unique_ptr<AidlArgument>>* args, const string& comments, int id,
817 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700818 virtual ~AidlMethod() = default;
819
Jiyong Parkd800fef2020-07-22 18:09:43 +0900820 // non-copyable, non-movable
821 AidlMethod(const AidlMethod&) = delete;
822 AidlMethod(AidlMethod&&) = delete;
823 AidlMethod& operator=(const AidlMethod&) = delete;
824 AidlMethod& operator=(AidlMethod&&) = delete;
825
Jooyung Han829ec7c2020-12-02 12:07:36 +0900826 const AidlMethod* AsMethod() const override { return this; }
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900827 const AidlTypeSpecifier& GetType() const { return *type_; }
828 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800829
Steven Moreland8c70ba92018-12-17 10:20:31 -0800830 // set if this method is part of an interface that is marked oneway
831 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700832 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800833
Casey Dahlinf4a93112015-10-05 16:58:09 -0700834 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700835 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900836 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700837 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700838
Jiyong Park309668e2018-07-28 16:55:44 +0900839 bool IsUserDefined() const { return is_user_defined_; }
840
Casey Dahlinf4a93112015-10-05 16:58:09 -0700841 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700842 return arguments_;
843 }
844 // An inout parameter will appear in both GetInArguments()
845 // and GetOutArguments(). AidlMethod retains ownership of the argument
846 // pointers returned in this way.
847 const std::vector<const AidlArgument*>& GetInArguments() const {
848 return in_arguments_;
849 }
850 const std::vector<const AidlArgument*>& GetOutArguments() const {
851 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700852 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700853
Jooyung Han965e31d2020-11-27 12:30:16 +0900854 // ToString is for dumping AIDL.
855 // Returns string representation of this method including everything.
856 // This is "ret_type name ( arg_list ) = id".
857 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900858 std::string ToString() const;
859
Jooyung Han965e31d2020-11-27 12:30:16 +0900860 // Signature is for comparing AIDL types.
861 // Returns string representation of this method's name & type.
862 // e.g) "foo(int, String)"
863 std::string Signature() const;
864
Jooyung Hanc5688f72021-01-05 15:41:48 +0900865 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900866 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900867 for (const auto& a : GetArguments()) {
868 traverse(*a);
869 }
870 }
Jiyong Park45854452020-12-31 10:42:28 +0900871 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han808a2a02020-12-28 16:46:54 +0900872
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700873 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700874 bool oneway_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900875 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700876 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700877 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
878 std::vector<const AidlArgument*> in_arguments_;
879 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700880 bool has_id_;
881 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900882 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700883};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800884
Daniel Norman85aed542019-08-21 12:01:14 -0700885// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900886// defined in the source file.
Jooyung Han8aeef8c2021-01-11 12:16:19 +0900887class AidlDefinedType : public AidlAnnotatable, public AidlCommentable {
Steven Moreland787b0432018-07-03 09:00:58 -0700888 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700889 AidlDefinedType(const AidlLocation& location, const std::string& name,
Jooyung Han829ec7c2020-12-02 12:07:36 +0900890 const std::string& comments, const std::string& package,
891 std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700892 virtual ~AidlDefinedType() = default;
893
Jiyong Parkd800fef2020-07-22 18:09:43 +0900894 // non-copyable, non-movable
895 AidlDefinedType(const AidlDefinedType&) = delete;
896 AidlDefinedType(AidlDefinedType&&) = delete;
897 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
898 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
899
Jiyong Park1deecc32018-07-17 01:14:41 +0900900 const std::string& GetName() const { return name_; };
Jiyong Park1deecc32018-07-17 01:14:41 +0900901
Steven Moreland787b0432018-07-03 09:00:58 -0700902 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900903 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700904 /* dot joined package and name, example: "android.package.foo.IBar" */
905 std::string GetCanonicalName() const;
Jiyong Park18132182020-06-08 20:24:40 +0900906 const std::vector<std::string>& GetSplitPackage() const { return split_package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700907
Steven Morelanded83a282018-07-17 13:27:29 -0700908 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700909
Steven Moreland5557f1c2018-07-02 13:50:23 -0700910 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700911 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700912 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900913 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700914 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900915 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900916 virtual bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700917 virtual bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
918 Options::Language lang) const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700919 AidlStructuredParcelable* AsStructuredParcelable() {
920 return const_cast<AidlStructuredParcelable*>(
921 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
922 }
923 AidlParcelable* AsParcelable() {
924 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
925 }
Daniel Norman85aed542019-08-21 12:01:14 -0700926 AidlEnumDeclaration* AsEnumDeclaration() {
927 return const_cast<AidlEnumDeclaration*>(
928 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
929 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900930 AidlUnionDecl* AsUnionDeclaration() {
931 return const_cast<AidlUnionDecl*>(
932 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
933 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700934 AidlInterface* AsInterface() {
935 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
936 }
937
Jeongik Chadf76dc72019-11-28 00:08:47 +0900938 AidlParameterizable<std::string>* AsParameterizable() {
939 return const_cast<AidlParameterizable<std::string>*>(
940 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
941 }
942
Steven Moreland6cee3482018-07-18 14:39:58 -0700943 const AidlParcelable* AsUnstructuredParcelable() const {
944 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900945 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700946 return this->AsParcelable();
947 }
948 AidlParcelable* AsUnstructuredParcelable() {
949 return const_cast<AidlParcelable*>(
950 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
951 }
952
Jeongik Cha997281d2020-01-16 15:23:59 +0900953 virtual void Dump(CodeWriter* writer) const = 0;
Steven Morelanda5d9c5c2020-02-21 16:01:09 -0800954 void DumpHeader(CodeWriter* writer) const;
Jooyung Han9fd67022021-01-13 10:49:48 +0900955 void DumpMembers(CodeWriter& out) const;
Jiyong Park02da7422018-07-16 16:00:26 +0900956
Jooyung Han829ec7c2020-12-02 12:07:36 +0900957 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
958 return variables_;
959 }
960 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
961 return constants_;
962 }
963 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
964 void AddMethod(std::unique_ptr<AidlMethod> method) { methods_.push_back(std::move(method)); }
965 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900966 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
967 AidlAnnotatable::TraverseChildren(traverse);
968 for (const auto c : GetMembers()) {
969 traverse(*c);
970 }
971 }
Jiyong Park512ed852020-12-30 15:07:23 +0900972
Jooyung Han829ec7c2020-12-02 12:07:36 +0900973 protected:
974 // utility for subclasses with getter names
975 bool CheckValidForGetterNames() const;
976
Steven Moreland787b0432018-07-03 09:00:58 -0700977 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +0900978 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
979
Jiyong Park1deecc32018-07-17 01:14:41 +0900980 std::string name_;
Jiyong Park18132182020-06-08 20:24:40 +0900981 const std::string package_;
982 const std::vector<std::string> split_package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900983 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
984 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
985 std::vector<std::unique_ptr<AidlMethod>> methods_;
986 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -0700987};
988
Jeongik Chadf76dc72019-11-28 00:08:47 +0900989class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700990 public:
Jiyong Park18132182020-06-08 20:24:40 +0900991 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
992 const std::string& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +0900993 std::vector<std::string>* type_params = nullptr,
994 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700995 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -0800996
Jiyong Parkd800fef2020-07-22 18:09:43 +0900997 // non-copyable, non-movable
998 AidlParcelable(const AidlParcelable&) = delete;
999 AidlParcelable(AidlParcelable&&) = delete;
1000 AidlParcelable& operator=(const AidlParcelable&) = delete;
1001 AidlParcelable& operator=(AidlParcelable&&) = delete;
1002
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001003 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001004
Jooyung Han808a2a02020-12-28 16:46:54 +09001005 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001006 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1007 Options::Language lang) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -07001008 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +09001009 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
1010 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001011 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -07001012
Jeongik Cha997281d2020-01-16 15:23:59 +09001013 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001014
Jiyong Park45854452020-12-31 10:42:28 +09001015 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001016
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001017 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001018 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001019};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001020
Jooyung Han829ec7c2020-12-02 12:07:36 +09001021class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -07001022 public:
Jiyong Park18132182020-06-08 20:24:40 +09001023 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
1024 const std::string& package, const std::string& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001025 std::vector<std::string>* type_params,
1026 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001027 virtual ~AidlStructuredParcelable() = default;
1028
1029 // non-copyable, non-movable
1030 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
1031 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
1032 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
1033 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001034
Steven Morelandc258abc2018-07-10 14:03:38 -07001035 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001036 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001037
Jeongik Cha997281d2020-01-16 15:23:59 +09001038 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001039
Jooyung Han808a2a02020-12-28 16:46:54 +09001040 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001041 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1042 Options::Language lang) const override;
Jiyong Park512ed852020-12-30 15:07:23 +09001043
Jiyong Park45854452020-12-31 10:42:28 +09001044 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001045};
1046
Jooyung Hanbd9db442021-01-14 01:45:55 +09001047class AidlEnumerator : public AidlNode, public AidlCommentable {
Daniel Norman85aed542019-08-21 12:01:14 -07001048 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001049 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
1050 const std::string& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001051 virtual ~AidlEnumerator() = default;
1052
Jiyong Parkd800fef2020-07-22 18:09:43 +09001053 // non-copyable, non-movable
1054 AidlEnumerator(const AidlEnumerator&) = delete;
1055 AidlEnumerator(AidlEnumerator&&) = delete;
1056 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1057 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1058
Daniel Norman85aed542019-08-21 12:01:14 -07001059 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001060 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman85aed542019-08-21 12:01:14 -07001061 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1062
1063 string ValueString(const AidlTypeSpecifier& backing_type,
1064 const ConstantValueDecorator& decorator) const;
1065
Daniel Normanb28684e2019-10-17 15:31:39 -07001066 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001067 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001068
Jooyung Hanc5688f72021-01-05 15:41:48 +09001069 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1070 traverse(*value_);
Jiyong Park512ed852020-12-30 15:07:23 +09001071 }
Jiyong Park45854452020-12-31 10:42:28 +09001072 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001073
Daniel Norman85aed542019-08-21 12:01:14 -07001074 private:
1075 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001076 unique_ptr<AidlConstantValue> value_;
Jooyung Han29813842020-12-08 01:28:03 +09001077 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001078};
1079
1080class AidlEnumDeclaration : public AidlDefinedType {
1081 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001082 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001083 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jiyong Park18132182020-06-08 20:24:40 +09001084 const std::string& package, const std::string& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001085 virtual ~AidlEnumDeclaration() = default;
1086
Jiyong Parkd800fef2020-07-22 18:09:43 +09001087 // non-copyable, non-movable
1088 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1089 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1090 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1091 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1092
Jooyung Han672557b2020-12-24 05:18:00 +09001093 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001094 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1095 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1096 return enumerators_;
1097 }
Jooyung Han808a2a02020-12-28 16:46:54 +09001098 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001099 bool LanguageSpecificCheckValid(const AidlTypenames& /*typenames*/,
1100 Options::Language) const override {
1101 return true;
1102 }
Daniel Norman85aed542019-08-21 12:01:14 -07001103 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Jeongik Cha997281d2020-01-16 15:23:59 +09001104 void Dump(CodeWriter* writer) const override;
Daniel Norman85aed542019-08-21 12:01:14 -07001105
1106 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1107
Jooyung Hanc5688f72021-01-05 15:41:48 +09001108 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1109 AidlDefinedType::TraverseChildren(traverse);
Jiyong Park512ed852020-12-30 15:07:23 +09001110 for (const auto& c : GetEnumerators()) {
1111 traverse(*c);
1112 }
1113 }
Jiyong Park45854452020-12-31 10:42:28 +09001114 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001115
Daniel Norman85aed542019-08-21 12:01:14 -07001116 private:
Jooyung Han29813842020-12-08 01:28:03 +09001117
Daniel Norman85aed542019-08-21 12:01:14 -07001118 const std::string name_;
1119 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001120 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001121};
1122
Jooyung Han829ec7c2020-12-02 12:07:36 +09001123class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001124 public:
1125 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001126 const std::string& comments, std::vector<std::string>* type_params,
1127 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001128 virtual ~AidlUnionDecl() = default;
1129
1130 // non-copyable, non-movable
1131 AidlUnionDecl(const AidlUnionDecl&) = delete;
1132 AidlUnionDecl(AidlUnionDecl&&) = delete;
1133 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1134 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1135
Jooyung Han2946afc2020-10-05 20:29:16 +09001136
1137 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001138 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Hanfe89f122020-10-14 03:49:18 +09001139 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1140 Options::Language lang) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001141 std::string GetPreprocessDeclarationName() const override { return "union"; }
1142
1143 void Dump(CodeWriter* writer) const override;
1144 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jiyong Park45854452020-12-31 10:42:28 +09001145 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han2946afc2020-10-05 20:29:16 +09001146};
1147
Jiyong Park1deecc32018-07-17 01:14:41 +09001148class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001149 public:
Steven Moreland46e9da82018-07-27 15:45:29 -07001150 AidlInterface(const AidlLocation& location, const std::string& name, const std::string& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001151 bool oneway_, const std::string& package,
1152 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001153 virtual ~AidlInterface() = default;
1154
Jiyong Parkd800fef2020-07-22 18:09:43 +09001155 // non-copyable, non-movable
1156 AidlInterface(const AidlInterface&) = delete;
1157 AidlInterface(AidlInterface&&) = delete;
1158 AidlInterface& operator=(const AidlInterface&) = delete;
1159 AidlInterface& operator=(AidlInterface&&) = delete;
1160
Steven Morelandc258abc2018-07-10 14:03:38 -07001161 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001162 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001163
Jeongik Cha997281d2020-01-16 15:23:59 +09001164 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001165
Jooyung Han808a2a02020-12-28 16:46:54 +09001166 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001167 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1168 Options::Language lang) const override;
Jeongik Chadb0f59e2018-11-01 18:11:21 +09001169
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001170 std::string GetDescriptor() const;
Jiyong Park45854452020-12-31 10:42:28 +09001171 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001172};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001173
Jooyung Han132cf802021-01-15 02:17:32 +09001174class AidlPackage : public AidlNode, public AidlCommentable {
Casey Dahlin0edf3422015-10-07 12:34:59 -07001175 public:
Jooyung Han132cf802021-01-15 02:17:32 +09001176 AidlPackage(const AidlLocation& location, const std::string& comments)
1177 : AidlNode(location), AidlCommentable(comments) {}
1178 virtual ~AidlPackage() = default;
1179 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1180 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
1181};
1182
1183class AidlImport : public AidlNode, public AidlCommentable {
1184 public:
1185 AidlImport(const AidlLocation& location, const std::string& needed_class,
1186 const std::string& comments);
Casey Dahlin0edf3422015-10-07 12:34:59 -07001187 virtual ~AidlImport() = default;
1188
Jiyong Parkd800fef2020-07-22 18:09:43 +09001189 // non-copyable, non-movable
1190 AidlImport(const AidlImport&) = delete;
1191 AidlImport(AidlImport&&) = delete;
1192 AidlImport& operator=(const AidlImport&) = delete;
1193 AidlImport& operator=(AidlImport&&) = delete;
1194
Casey Dahlin0edf3422015-10-07 12:34:59 -07001195 const std::string& GetNeededClass() const { return needed_class_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +09001196 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1197 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
Casey Dahlin0edf3422015-10-07 12:34:59 -07001198
1199 private:
Casey Dahlin0edf3422015-10-07 12:34:59 -07001200 std::string needed_class_;
Casey Dahline2507492015-09-14 17:11:20 -07001201};
1202
Jiyong Park62515512020-06-08 15:57:11 +09001203// AidlDocument models an AIDL file
Jooyung Han132cf802021-01-15 02:17:32 +09001204class AidlDocument : public AidlNode, public AidlCommentable {
Jiyong Park62515512020-06-08 15:57:11 +09001205 public:
Jooyung Han132cf802021-01-15 02:17:32 +09001206 AidlDocument(const AidlLocation& location, const std::string& comments,
1207 std::vector<std::unique_ptr<AidlImport>> imports,
1208 std::vector<std::unique_ptr<AidlDefinedType>> defined_types)
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001209 : AidlNode(location),
Jooyung Han132cf802021-01-15 02:17:32 +09001210 AidlCommentable(comments),
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001211 imports_(std::move(imports)),
1212 defined_types_(std::move(defined_types)) {}
Jiyong Parkd800fef2020-07-22 18:09:43 +09001213 ~AidlDocument() = default;
1214
1215 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001216 AidlDocument(const AidlDocument&) = delete;
1217 AidlDocument(AidlDocument&&) = delete;
1218 AidlDocument& operator=(const AidlDocument&) = delete;
1219 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001220
Jooyung Han29813842020-12-08 01:28:03 +09001221 std::optional<std::string> ResolveName(const std::string& unresolved_type) const;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001222 const std::vector<std::unique_ptr<AidlImport>>& Imports() const { return imports_; }
1223 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1224 return defined_types_;
1225 }
Jiyong Park62515512020-06-08 15:57:11 +09001226
Jooyung Hanc5688f72021-01-05 15:41:48 +09001227 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1228 for (const auto& i : Imports()) {
1229 traverse(*i);
1230 }
Jiyong Park512ed852020-12-30 15:07:23 +09001231 for (const auto& t : DefinedTypes()) {
1232 traverse(*t);
1233 }
1234 }
Jiyong Park45854452020-12-31 10:42:28 +09001235 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001236
Jiyong Park62515512020-06-08 15:57:11 +09001237 private:
1238 const std::vector<std::unique_ptr<AidlImport>> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001239 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jiyong Park62515512020-06-08 15:57:11 +09001240};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001241
1242template <typename T>
1243std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1244 auto it = parameters_.find(param_name);
1245 if (it == parameters_.end()) {
1246 return std::nullopt;
1247 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001248 return it->second->EvaluatedValue<T>();
Jiyong Park512ed852020-12-30 15:07:23 +09001249}
Jooyung Hanc5688f72021-01-05 15:41:48 +09001250
1251// Utility to make a visitor to visit AST tree in top-down order
1252// Given: foo
1253// / \
1254// bar baz
1255// VisitTopDown(v, foo) makes v visit foo -> bar -> baz.
1256inline void VisitTopDown(AidlVisitor& v, const AidlNode& node) {
1257 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
1258 n.DispatchVisit(v);
1259 n.TraverseChildren(top_down);
1260 };
1261 top_down(node);
1262}