blob: 15428c49bd26664e873e08d1b422a0807e8353ed [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 Hanc5688f72021-01-05 15:41:48 +090079class AidlImport;
Jooyung Han808a2a02020-12-28 16:46:54 +090080class AidlInterface;
81class AidlParcelable;
82class AidlStructuredParcelable;
83class AidlEnumDeclaration;
84class AidlUnionDecl;
85class AidlVariableDeclaration;
86class AidlConstantDeclaration;
87class AidlEnumerator;
88class AidlMethod;
89class AidlArgument;
Jooyung Hanc5688f72021-01-05 15:41:48 +090090class AidlConstantValue;
91class AidlConstantReference;
92class AidlUnaryConstExpression;
93class AidlBinaryConstExpression;
94class AidlAnnotation;
Jooyung Han808a2a02020-12-28 16:46:54 +090095
Jiyong Park45854452020-12-31 10:42:28 +090096// Interface for visitors that can traverse AidlTraversable nodes.
Jooyung Han808a2a02020-12-28 16:46:54 +090097class AidlVisitor {
98 public:
99 virtual ~AidlVisitor() = default;
Jiyong Park45854452020-12-31 10:42:28 +0900100 virtual void Visit(const AidlDocument&) {}
101 virtual void Visit(const AidlInterface&) {}
102 virtual void Visit(const AidlParcelable&) {}
103 virtual void Visit(const AidlStructuredParcelable&) {}
104 virtual void Visit(const AidlUnionDecl&) {}
105 virtual void Visit(const AidlEnumDeclaration&) {}
106 virtual void Visit(const AidlEnumerator&) {}
107 virtual void Visit(const AidlMethod&) {}
108 virtual void Visit(const AidlVariableDeclaration&) {}
109 virtual void Visit(const AidlConstantDeclaration&) {}
110 virtual void Visit(const AidlArgument&) {}
Jooyung Han865da492021-01-03 11:32:47 +0900111 virtual void Visit(const AidlTypeSpecifier&) {}
Jooyung Hanc5688f72021-01-05 15:41:48 +0900112 virtual void Visit(const AidlConstantValue&) {}
113 virtual void Visit(const AidlConstantReference&) {}
114 virtual void Visit(const AidlUnaryConstExpression&) {}
115 virtual void Visit(const AidlBinaryConstExpression&) {}
116 virtual void Visit(const AidlAnnotation&) {}
117 virtual void Visit(const AidlImport&) {}
Jooyung Han808a2a02020-12-28 16:46:54 +0900118};
119
Steven Moreland46e9da82018-07-27 15:45:29 -0700120// Anything that is locatable in a .aidl file.
121class AidlNode {
122 public:
123 AidlNode(const AidlLocation& location);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700124
125 AidlNode(const AidlNode&) = default;
Steven Moreland46e9da82018-07-27 15:45:29 -0700126 virtual ~AidlNode() = default;
127
Jiyong Parkd800fef2020-07-22 18:09:43 +0900128 AidlNode(AidlNode&&) = delete;
129 AidlNode& operator=(AidlNode&&) = delete;
130
Devin Mooredf93ebb2020-03-25 14:03:35 -0700131 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700132 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000133 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000134 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700135
Devin Mooredf93ebb2020-03-25 14:03:35 -0700136 const AidlLocation& GetLocation() const { return location_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900137 virtual void TraverseChildren(std::function<void(const AidlNode&)> traverse) const = 0;
138 virtual void DispatchVisit(AidlVisitor&) const = 0;
Devin Mooredf93ebb2020-03-25 14:03:35 -0700139
Steven Moreland46e9da82018-07-27 15:45:29 -0700140 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000141 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000142 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700143 const AidlLocation location_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700144};
145
Jeongik Chadf76dc72019-11-28 00:08:47 +0900146// unique_ptr<AidlTypeSpecifier> for type arugment,
147// std::string for type parameter(T, U, and so on).
148template <typename T>
149class AidlParameterizable {
150 public:
151 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
152 virtual ~AidlParameterizable() = default;
153 bool IsGeneric() const { return type_params_ != nullptr; }
154 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
155 bool CheckValid() const;
156
Steven Moreland6c07b832020-10-29 23:39:53 +0000157 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
158 if (type_params_) return false;
159 type_params_.reset(type_params);
160 return true;
161 }
162
Jeongik Chadf76dc72019-11-28 00:08:47 +0900163 virtual const AidlNode& AsAidlNode() const = 0;
164
165 protected:
166 AidlParameterizable(const AidlParameterizable&);
167
168 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000169 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900170 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
171 std::is_same<T, std::string>::value);
172};
173template <>
174bool AidlParameterizable<std::string>::CheckValid() const;
175
Andrei Onea9445fc62019-06-27 18:11:59 +0100176class AidlConstantValue;
177class AidlConstantDeclaration;
178
179// Transforms a value string into a language specific form. Raw value as produced by
180// AidlConstantValue.
181using ConstantValueDecorator =
182 std::function<std::string(const AidlTypeSpecifier& type, const std::string& raw_value)>;
183
Jiyong Park68bc77a2018-07-19 19:00:45 +0900184class AidlAnnotation : public AidlNode {
185 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700186 enum class Type {
187 BACKING = 1,
188 HIDE,
189 JAVA_STABLE_PARCELABLE,
190 UNSUPPORTED_APP_USAGE,
191 VINTF_STABILITY,
192 NULLABLE,
193 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000194 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900195 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900196 JAVA_DERIVE,
Jeongik Chad0a10272020-08-06 16:33:36 +0900197 JAVA_ONLY_IMMUTABLE,
Devin Moorec7e47a32020-08-07 10:55:25 -0700198 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900199 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700200 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900201 SUPPRESS_WARNINGS,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700202 };
203 static std::string TypeToString(Type type);
204
Andrei Onea9445fc62019-06-27 18:11:59 +0100205 static AidlAnnotation* Parse(
206 const AidlLocation& location, const string& name,
207 std::map<std::string, std::shared_ptr<AidlConstantValue>>* parameter_list);
Steven Moreland46e9da82018-07-27 15:45:29 -0700208
Steven Moreland3f658cf2018-08-20 13:40:54 -0700209 AidlAnnotation(const AidlAnnotation&) = default;
Steven Moreland3be75772018-08-20 13:27:43 -0700210 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900211 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100212 bool CheckValid() const;
Steven Moreland3be75772018-08-20 13:27:43 -0700213
Jooyung Hand902a972020-10-23 17:32:44 +0900214 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700215 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900216 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900217
218 // ToString is for dumping AIDL.
219 // Returns string representation of this annotation.
220 // e.g) "@RustDerive(Clone=true, Copy=true)"
221 string ToString() const;
222
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900223 template <typename T>
224 std::optional<T> ParamValue(const std::string& param_name) const;
225
Andrei Onea9445fc62019-06-27 18:11:59 +0100226 std::map<std::string, std::string> AnnotationParams(
227 const ConstantValueDecorator& decorator) const;
Jiyong Parka6605ab2018-11-11 14:30:21 +0900228 const string& GetComments() const { return comments_; }
229 void SetComments(const string& comments) { comments_ = comments; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900230 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
231 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900232
233 private:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700234 struct Schema {
235 AidlAnnotation::Type type;
236
237 // text name in .aidl file, e.g. "nullable"
238 std::string name;
239
240 // map from param name -> value type
Jooyung Han5c2fcae2020-12-26 00:04:39 +0900241 std::map<std::string, const AidlTypeSpecifier&> supported_parameters;
Jooyung Hand902a972020-10-23 17:32:44 +0900242
243 bool repeatable;
Jooyung Han5721a232020-12-24 04:34:55 +0900244
245 std::vector<std::string> required_parameters = {};
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700246 };
247 static const std::vector<Schema>& AllSchemas();
248
249 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Andrei Onea9445fc62019-06-27 18:11:59 +0100250 std::map<std::string, std::shared_ptr<AidlConstantValue>>&& parameters);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700251
252 const Schema& schema_;
Jiyong Parka6605ab2018-11-11 14:30:21 +0900253 string comments_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100254 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900255};
256
Steven Moreland3be75772018-08-20 13:27:43 -0700257static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
258 return lhs.GetName() < rhs.GetName();
259}
260static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
261 return lhs.GetName() == rhs.GetName();
262}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900263
Casey Dahline7922932016-02-29 17:23:01 -0800264class AidlAnnotatable : public AidlNode {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700265 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700266 AidlAnnotatable(const AidlLocation& location);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700267
268 AidlAnnotatable(const AidlAnnotatable&) = default;
269 AidlAnnotatable(AidlAnnotatable&&) = default;
Casey Dahline7922932016-02-29 17:23:01 -0800270 virtual ~AidlAnnotatable() = default;
271
Artur Satayev91fe8712019-07-29 13:06:01 +0100272 void Annotate(vector<AidlAnnotation>&& annotations) {
273 for (auto& annotation : annotations) {
274 annotations_.emplace_back(std::move(annotation));
275 }
276 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900277 bool IsNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900278 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000279 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700280 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900281 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700282 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900283 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800284 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900285 bool JavaDerive(const std::string& method) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900286 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100287
Steven Moreland7e4b9502020-02-20 18:10:42 -0800288 void DumpAnnotations(CodeWriter* writer) const;
289
Andrei Onea9445fc62019-06-27 18:11:59 +0100290 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700291 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900292 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900293 std::vector<std::string> SuppressWarnings() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900294
295 // ToString is for dumping AIDL.
296 // Returns string representation of annotations.
297 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900298 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800299
Jiyong Parka6605ab2018-11-11 14:30:21 +0900300 const vector<AidlAnnotation>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900301 bool CheckValid(const AidlTypenames&) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900302 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
303 for (const auto& annot : GetAnnotations()) {
304 traverse(annot);
305 }
306 }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900307
Steven Moreland181144c2020-04-20 19:57:56 -0700308 protected:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700309 virtual std::set<AidlAnnotation::Type> GetSupportedAnnotations() const = 0;
Steven Moreland181144c2020-04-20 19:57:56 -0700310
Casey Dahline7922932016-02-29 17:23:01 -0800311 private:
Jiyong Parka6605ab2018-11-11 14:30:21 +0900312 vector<AidlAnnotation> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800313};
314
Jiyong Park1deecc32018-07-17 01:14:41 +0900315// AidlTypeSpecifier represents a reference to either a built-in type,
316// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900317class AidlTypeSpecifier final : public AidlAnnotatable,
318 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800319 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700320 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name, bool is_array,
321 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const string& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900322 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700323
Steven Moreland3f658cf2018-08-20 13:40:54 -0700324 // Copy of this type which is not an array.
Jooyung Hand2fa0232020-10-19 02:51:41 +0900325 const AidlTypeSpecifier& ArrayBase() const;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700326
Jiyong Park1deecc32018-07-17 01:14:41 +0900327 // Returns the full-qualified name of the base type.
328 // int -> int
329 // int[] -> int
330 // List<String> -> List
331 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
332 const string& GetName() const {
333 if (IsResolved()) {
334 return fully_qualified_name_;
335 } else {
336 return GetUnresolvedName();
337 }
338 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700339
Jooyung Han965e31d2020-11-27 12:30:16 +0900340 // ToString is for dumping AIDL.
341 // Returns string representation of this type specifier including annotations.
342 // This is "annotations type_name type_params? array_marker?".
343 // e.g) "@utf8InCpp String[]";
344 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900345
Jooyung Han965e31d2020-11-27 12:30:16 +0900346 // Signature is for comparing AIDL types.
347 // Returns string representation of this type specifier.
348 // This is "type_name type_params? array_marker?".
349 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900350 std::string Signature() const;
351
Jiyong Park1deecc32018-07-17 01:14:41 +0900352 const string& GetUnresolvedName() const { return unresolved_name_; }
353
Jeongik Cha997281d2020-01-16 15:23:59 +0900354 bool IsHidden() const;
355
Jiyong Park1deecc32018-07-17 01:14:41 +0900356 const string& GetComments() const { return comments_; }
357
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900358 const std::vector<std::string> GetSplitName() const { return split_name_; }
359
Jiyong Parka6605ab2018-11-11 14:30:21 +0900360 void SetComments(const string& comment) { comments_ = comment; }
361
Jiyong Park1deecc32018-07-17 01:14:41 +0900362 bool IsResolved() const { return fully_qualified_name_ != ""; }
363
364 bool IsArray() const { return is_array_; }
365
Steven Moreland6c07b832020-10-29 23:39:53 +0000366 __attribute__((warn_unused_result)) bool SetArray() {
367 if (is_array_) return false;
368 is_array_ = true;
369 return true;
370 }
371
Jiyong Park1deecc32018-07-17 01:14:41 +0900372 // Resolve the base type name to a fully-qualified name. Return false if the
373 // resolution fails.
Daniel Norman716d3112019-09-10 13:11:56 -0700374 bool Resolve(const AidlTypenames& typenames);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700375
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700376 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han888c5bc2020-12-22 17:28:47 +0900377 bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700378 bool LanguageSpecificCheckValid(const AidlTypenames& typenames, Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900379 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900380
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900381 const AidlDefinedType* GetDefinedType() const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900382 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
383 AidlAnnotatable::TraverseChildren(traverse);
Jooyung Han865da492021-01-03 11:32:47 +0900384 if (IsGeneric()) {
385 for (const auto& tp : GetTypeParameters()) {
386 traverse(*tp);
387 }
388 }
389 }
390 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900391
Casey Dahlin0ee37582015-09-30 16:31:55 -0700392 private:
Steven Moreland3f658cf2018-08-20 13:40:54 -0700393 AidlTypeSpecifier(const AidlTypeSpecifier&) = default;
394
Jiyong Park1deecc32018-07-17 01:14:41 +0900395 const string unresolved_name_;
396 string fully_qualified_name_;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700397 bool is_array_;
Jiyong Parka6605ab2018-11-11 14:30:21 +0900398 string comments_;
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900399 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900400 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Jooyung Hand2fa0232020-10-19 02:51:41 +0900401 mutable shared_ptr<AidlTypeSpecifier> array_base_;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700402};
403
Steven Moreland860b1942018-08-16 14:59:28 -0700404// Returns the universal value unaltered.
405std::string AidlConstantValueDecorator(const AidlTypeSpecifier& type, const std::string& raw_value);
406
Jooyung Hanc5688f72021-01-05 15:41:48 +0900407class AidlMember : public AidlNode {
Jooyung Han3f347ca2020-12-01 12:41:50 +0900408 public:
409 AidlMember(const AidlLocation& location);
410 virtual ~AidlMember() = default;
411
412 // non-copyable, non-movable
413 AidlMember(const AidlMember&) = delete;
414 AidlMember(AidlMember&&) = delete;
415 AidlMember& operator=(const AidlMember&) = delete;
416 AidlMember& operator=(AidlMember&&) = delete;
417
Jooyung Han829ec7c2020-12-02 12:07:36 +0900418 virtual const AidlMethod* AsMethod() const { return nullptr; }
419 virtual const AidlConstantDeclaration* AsConstantDeclaration() const { return nullptr; }
420 virtual const AidlVariableDeclaration* AsVariableDeclaration() const { return nullptr; }
421
422 AidlMethod* AsMethod() {
423 return const_cast<AidlMethod*>(const_cast<const AidlMember*>(this)->AsMethod());
424 }
425 AidlConstantDeclaration* AsConstantDeclaration() {
426 return const_cast<AidlConstantDeclaration*>(
427 const_cast<const AidlMember*>(this)->AsConstantDeclaration());
428 }
429 AidlVariableDeclaration* AsVariableDeclaration() {
430 return const_cast<AidlVariableDeclaration*>(
431 const_cast<const AidlMember*>(this)->AsVariableDeclaration());
432 }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900433};
434
Steven Moreland541788d2020-05-21 22:05:52 +0000435// TODO: This class is used for method arguments and also parcelable fields,
436// and it should be split up since default values don't apply to method
437// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900438class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700439 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700440 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
441 const std::string& name);
442 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
443 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700444 virtual ~AidlVariableDeclaration() = default;
445
Jiyong Parkd800fef2020-07-22 18:09:43 +0900446 // non-copyable, non-movable
447 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
448 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
449 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
450 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
451
Jooyung Han829ec7c2020-12-02 12:07:36 +0900452 const AidlVariableDeclaration* AsVariableDeclaration() const override { return this; }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900453
Steven Moreland5557f1c2018-07-02 13:50:23 -0700454 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900455 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900456 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000457 // if this was constructed explicitly with a default value
458 bool IsDefaultUserSpecified() const { return default_user_specified_; }
459 // will return the default value this is constructed with or a default value
460 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700461 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900462 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700463
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900464 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700465
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900466 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900467
468 // ToString is for dumping AIDL.
469 // Returns string representation of this variable decl including default value.
470 // This is "annotations type name default_value?".
471 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700472 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900473
474 // Signature is for comparing AIDL types.
475 // Returns string representation of this variable decl.
476 // This is "type name".
477 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900478 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700479
Steven Moreland860b1942018-08-16 14:59:28 -0700480 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700481
Jooyung Hanc5688f72021-01-05 15:41:48 +0900482 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jiyong Park45854452020-12-31 10:42:28 +0900483 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900484
Steven Moreland5557f1c2018-07-02 13:50:23 -0700485 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900486 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700487 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000488 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700489 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700490};
491
492class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700493 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700494 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
495
Steven Moreland46e9da82018-07-27 15:45:29 -0700496 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
497 AidlTypeSpecifier* type, const std::string& name);
498 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700499 virtual ~AidlArgument() = default;
500
Jiyong Parkd800fef2020-07-22 18:09:43 +0900501 // non-copyable, non-movable
502 AidlArgument(const AidlArgument&) = delete;
503 AidlArgument(AidlArgument&&) = delete;
504 AidlArgument& operator=(const AidlArgument&) = delete;
505 AidlArgument& operator=(AidlArgument&&) = delete;
506
Casey Dahlinc378c992015-09-29 16:50:40 -0700507 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700508 bool IsOut() const { return direction_ & OUT_DIR; }
509 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700510 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900511 string GetDirectionSpecifier() const;
Christopher Wileyad339272015-10-05 19:11:58 -0700512
Jooyung Han965e31d2020-11-27 12:30:16 +0900513 // ToString is for dumping AIDL.
514 // Returns string representation of this argument including direction
515 // This is "direction annotations type name".
516 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700517 std::string ToString() const;
Jiyong Park512ed852020-12-30 15:07:23 +0900518
Jooyung Hanc5688f72021-01-05 15:41:48 +0900519 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900520 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900521 }
Jiyong Park45854452020-12-31 10:42:28 +0900522 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700523
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700524 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700525 Direction direction_;
526 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700527};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800528
Will McVickerd7d18df2019-09-12 13:40:50 -0700529class AidlUnaryConstExpression;
530class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900531class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700532
Steven Moreland693640b2018-07-19 13:46:27 -0700533class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800534 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700535 enum class Type {
536 // WARNING: Don't change this order! The order is used to determine type
537 // promotion during a binary expression.
538 BOOLEAN,
539 INT8,
540 INT32,
541 INT64,
542 ARRAY,
543 CHARACTER,
544 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900545 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700546 FLOATING,
547 UNARY,
548 BINARY,
549 ERROR,
550 };
551
Jooyung Han535c5e82020-12-29 15:16:59 +0900552 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700553 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900554 T EvaluatedValue() const {
555 is_evaluated_ || (CheckValid() && evaluate());
556 AIDL_FATAL_IF(!is_valid_, this);
557
558 if constexpr (is_vector<T>::value) {
559 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
560 T result;
561 for (const auto& v : values_) {
562 result.push_back(v->EvaluatedValue<typename T::value_type>());
563 }
564 return result;
565 } else if constexpr (is_one_of<T, float, double>::value) {
566 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
567 T result;
568 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
569 return result;
570 } else if constexpr (std::is_same<T, std::string>::value) {
571 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
572 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
573 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
574 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
575 return static_cast<T>(final_value_);
576 } else if constexpr (std::is_same<T, char>::value) {
577 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
578 return final_string_value_.at(1); // unquote '
579 } else if constexpr (std::is_same<T, bool>::value) {
580 static_assert(std::is_same<T, bool>::value, "..");
581 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
582 return final_value_ != 0;
583 } else {
584 static_assert(unsupported_type<T>::value);
585 }
586 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800587
Steven Moreland693640b2018-07-19 13:46:27 -0700588 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800589
Jiyong Parkd800fef2020-07-22 18:09:43 +0900590 // non-copyable, non-movable
591 AidlConstantValue(const AidlConstantValue&) = delete;
592 AidlConstantValue(AidlConstantValue&&) = delete;
593 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
594 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
595
Steven Moreland541788d2020-05-21 22:05:52 +0000596 // creates default value, when one isn't specified
597 // nullptr if no default available
598 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
599
Steven Moreland25294322018-08-07 18:13:55 -0700600 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
601 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700602 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700603 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
604 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700605 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700606 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700607 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700608 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700609
Will McVickerd7d18df2019-09-12 13:40:50 -0700610 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900611 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700612
Will McVickerd7d18df2019-09-12 13:40:50 -0700613 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700614
615 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800616 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900617
618 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const {
Jooyung Han29813842020-12-08 01:28:03 +0900619 if (type_ == Type::ARRAY) {
620 for (const auto& v : values_) {
Jooyung Hanc5688f72021-01-05 15:41:48 +0900621 traverse(*v);
Jooyung Han29813842020-12-08 01:28:03 +0900622 }
623 }
624 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900625 void DispatchVisit(AidlVisitor& visitor) const override { visitor.Visit(*this); }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800626
627 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700628 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
629 const string& checked_value);
630 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700631 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900632 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
633 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700634 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700635 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
636 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800637
Jooyung Han74675c22020-12-15 08:39:57 +0900638 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800639
Steven Moreland693640b2018-07-19 13:46:27 -0700640 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700641 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
642 const string value_; // otherwise
643
644 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800645 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
646 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700647 mutable Type final_type_;
648 mutable int64_t final_value_;
649 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700650
Will McVickerd7d18df2019-09-12 13:40:50 -0700651 friend AidlUnaryConstExpression;
652 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900653 friend AidlConstantReference;
654};
655
656// Represents "<type>.<field>" which resolves to a constant which is one of
657// - constant declartion
658// - enumerator
659// When a <type> is missing, <field> is of the enclosing type.
660class AidlConstantReference : public AidlConstantValue {
661 public:
662 AidlConstantReference(const AidlLocation& location, const std::string& value,
663 const std::string& comments);
664
665 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900666 const std::string& GetFieldName() const { return field_name_; }
667 const std::string& GetComments() const { return comments_; }
668
669 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900670 void TraverseChildren(std::function<void(const AidlNode&)>) const override {
671 // resolved_ is not my child.
672 }
673 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900674 const AidlConstantValue* Resolve(const AidlDefinedType* scope) const;
Jooyung Han690f5842020-12-04 13:02:04 +0900675
676 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900677 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900678
679 std::unique_ptr<AidlTypeSpecifier> ref_type_;
680 std::string field_name_;
681 const std::string comments_;
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900682 mutable const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700683};
684
685class AidlUnaryConstExpression : public AidlConstantValue {
686 public:
687 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
688 std::unique_ptr<AidlConstantValue> rval);
689
690 static bool IsCompatibleType(Type type, const string& op);
691 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900692 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
693 traverse(*unary_);
Jooyung Han690f5842020-12-04 13:02:04 +0900694 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900695 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han690f5842020-12-04 13:02:04 +0900696
Will McVickerd7d18df2019-09-12 13:40:50 -0700697 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900698 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700699
700 std::unique_ptr<AidlConstantValue> unary_;
701 const string op_;
702};
703
704class AidlBinaryConstExpression : public AidlConstantValue {
705 public:
706 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
707 const string& op, std::unique_ptr<AidlConstantValue> rval);
708
709 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700710
711 static bool AreCompatibleTypes(Type t1, Type t2);
712 // Returns the promoted kind for both operands
713 static Type UsualArithmeticConversion(Type left, Type right);
714 // Returns the promoted integral type where INT32 is the smallest type
715 static Type IntegralPromotion(Type in);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900716 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
717 traverse(*left_val_);
718 traverse(*right_val_);
Jooyung Han690f5842020-12-04 13:02:04 +0900719 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900720 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700721
722 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900723 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700724
725 std::unique_ptr<AidlConstantValue> left_val_;
726 std::unique_ptr<AidlConstantValue> right_val_;
727 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700728};
729
Andrei Onea9445fc62019-06-27 18:11:59 +0100730struct AidlAnnotationParameter {
731 std::string name;
732 std::unique_ptr<AidlConstantValue> value;
733};
734
Steven Moreland693640b2018-07-19 13:46:27 -0700735class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700736 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700737 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700738 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700739 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700740
Jiyong Parkd800fef2020-07-22 18:09:43 +0900741 // non-copyable, non-movable
742 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
743 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
744 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
745 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
746
Steven Moreland693640b2018-07-19 13:46:27 -0700747 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700748 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700749 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700750 const AidlConstantValue& GetValue() const { return *value_; }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900751 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700752
Jooyung Han965e31d2020-11-27 12:30:16 +0900753 // ToString is for dumping AIDL.
754 // Returns string representation of this const decl including a const value.
755 // This is "`const` annotations type name value".
756 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700757 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900758
759 // Signature is for comparing types.
760 // Returns string representation of this const decl.
761 // This is "direction annotations type name".
762 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700763 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900764
Steven Moreland860b1942018-08-16 14:59:28 -0700765 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700766 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700767 }
Steven Moreland25294322018-08-07 18:13:55 -0700768
Jooyung Han829ec7c2020-12-02 12:07:36 +0900769 const AidlConstantDeclaration* AsConstantDeclaration() const override { return this; }
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700770
Jooyung Hanc5688f72021-01-05 15:41:48 +0900771 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900772 traverse(GetType());
Jooyung Hanc5688f72021-01-05 15:41:48 +0900773 traverse(GetValue());
Jiyong Park512ed852020-12-30 15:07:23 +0900774 }
Jiyong Park45854452020-12-31 10:42:28 +0900775 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900776
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700777 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700778 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700779 const string name_;
780 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800781};
782
783class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700784 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700785 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
786 vector<unique_ptr<AidlArgument>>* args, const string& comments);
787 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
788 vector<unique_ptr<AidlArgument>>* args, const string& comments, int id,
789 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700790 virtual ~AidlMethod() = default;
791
Jiyong Parkd800fef2020-07-22 18:09:43 +0900792 // non-copyable, non-movable
793 AidlMethod(const AidlMethod&) = delete;
794 AidlMethod(AidlMethod&&) = delete;
795 AidlMethod& operator=(const AidlMethod&) = delete;
796 AidlMethod& operator=(AidlMethod&&) = delete;
797
Jooyung Han829ec7c2020-12-02 12:07:36 +0900798 const AidlMethod* AsMethod() const override { return this; }
Jeongik Cha997281d2020-01-16 15:23:59 +0900799 bool IsHidden() const;
Will McVickerd7d18df2019-09-12 13:40:50 -0700800 const string& GetComments() const { return comments_; }
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900801 const AidlTypeSpecifier& GetType() const { return *type_; }
802 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800803
Steven Moreland8c70ba92018-12-17 10:20:31 -0800804 // set if this method is part of an interface that is marked oneway
805 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700806 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800807
Casey Dahlinf4a93112015-10-05 16:58:09 -0700808 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700809 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900810 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700811 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700812
Jiyong Park309668e2018-07-28 16:55:44 +0900813 bool IsUserDefined() const { return is_user_defined_; }
814
Casey Dahlinf4a93112015-10-05 16:58:09 -0700815 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700816 return arguments_;
817 }
818 // An inout parameter will appear in both GetInArguments()
819 // and GetOutArguments(). AidlMethod retains ownership of the argument
820 // pointers returned in this way.
821 const std::vector<const AidlArgument*>& GetInArguments() const {
822 return in_arguments_;
823 }
824 const std::vector<const AidlArgument*>& GetOutArguments() const {
825 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700826 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700827
Jooyung Han965e31d2020-11-27 12:30:16 +0900828 // ToString is for dumping AIDL.
829 // Returns string representation of this method including everything.
830 // This is "ret_type name ( arg_list ) = id".
831 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900832 std::string ToString() const;
833
Jooyung Han965e31d2020-11-27 12:30:16 +0900834 // Signature is for comparing AIDL types.
835 // Returns string representation of this method's name & type.
836 // e.g) "foo(int, String)"
837 std::string Signature() const;
838
Jooyung Hanc5688f72021-01-05 15:41:48 +0900839 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900840 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900841 for (const auto& a : GetArguments()) {
842 traverse(*a);
843 }
844 }
Jiyong Park45854452020-12-31 10:42:28 +0900845 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han808a2a02020-12-28 16:46:54 +0900846
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700847 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700848 bool oneway_;
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700849 std::string comments_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900850 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700851 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700852 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
853 std::vector<const AidlArgument*> in_arguments_;
854 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700855 bool has_id_;
856 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900857 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700858};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800859
Daniel Norman85aed542019-08-21 12:01:14 -0700860// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900861// defined in the source file.
Jooyung Hanc5688f72021-01-05 15:41:48 +0900862class AidlDefinedType : public AidlAnnotatable {
Steven Moreland787b0432018-07-03 09:00:58 -0700863 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700864 AidlDefinedType(const AidlLocation& location, const std::string& name,
Jooyung Han829ec7c2020-12-02 12:07:36 +0900865 const std::string& comments, const std::string& package,
866 std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700867 virtual ~AidlDefinedType() = default;
868
Jiyong Parkd800fef2020-07-22 18:09:43 +0900869 // non-copyable, non-movable
870 AidlDefinedType(const AidlDefinedType&) = delete;
871 AidlDefinedType(AidlDefinedType&&) = delete;
872 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
873 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
874
Jiyong Park1deecc32018-07-17 01:14:41 +0900875 const std::string& GetName() const { return name_; };
Jeongik Cha997281d2020-01-16 15:23:59 +0900876 bool IsHidden() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900877 const std::string& GetComments() const { return comments_; }
Jiyong Parka6605ab2018-11-11 14:30:21 +0900878 void SetComments(const std::string comments) { comments_ = comments; }
Jiyong Park1deecc32018-07-17 01:14:41 +0900879
Steven Moreland787b0432018-07-03 09:00:58 -0700880 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900881 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700882 /* dot joined package and name, example: "android.package.foo.IBar" */
883 std::string GetCanonicalName() const;
Jiyong Park18132182020-06-08 20:24:40 +0900884 const std::vector<std::string>& GetSplitPackage() const { return split_package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700885
Steven Morelanded83a282018-07-17 13:27:29 -0700886 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700887
Steven Moreland5557f1c2018-07-02 13:50:23 -0700888 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700889 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700890 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900891 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700892 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900893 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900894 virtual bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700895 virtual bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
896 Options::Language lang) const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700897 AidlStructuredParcelable* AsStructuredParcelable() {
898 return const_cast<AidlStructuredParcelable*>(
899 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
900 }
901 AidlParcelable* AsParcelable() {
902 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
903 }
Daniel Norman85aed542019-08-21 12:01:14 -0700904 AidlEnumDeclaration* AsEnumDeclaration() {
905 return const_cast<AidlEnumDeclaration*>(
906 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
907 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900908 AidlUnionDecl* AsUnionDeclaration() {
909 return const_cast<AidlUnionDecl*>(
910 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
911 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700912 AidlInterface* AsInterface() {
913 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
914 }
915
Jeongik Chadf76dc72019-11-28 00:08:47 +0900916 AidlParameterizable<std::string>* AsParameterizable() {
917 return const_cast<AidlParameterizable<std::string>*>(
918 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
919 }
920
Steven Moreland6cee3482018-07-18 14:39:58 -0700921 const AidlParcelable* AsUnstructuredParcelable() const {
922 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900923 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700924 return this->AsParcelable();
925 }
926 AidlParcelable* AsUnstructuredParcelable() {
927 return const_cast<AidlParcelable*>(
928 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
929 }
930
Jeongik Cha997281d2020-01-16 15:23:59 +0900931 virtual void Dump(CodeWriter* writer) const = 0;
Steven Morelanda5d9c5c2020-02-21 16:01:09 -0800932 void DumpHeader(CodeWriter* writer) const;
Jiyong Park02da7422018-07-16 16:00:26 +0900933
Jooyung Han829ec7c2020-12-02 12:07:36 +0900934 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
935 return variables_;
936 }
937 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
938 return constants_;
939 }
940 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
941 void AddMethod(std::unique_ptr<AidlMethod> method) { methods_.push_back(std::move(method)); }
942 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900943 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
944 AidlAnnotatable::TraverseChildren(traverse);
945 for (const auto c : GetMembers()) {
946 traverse(*c);
947 }
948 }
Jiyong Park512ed852020-12-30 15:07:23 +0900949
Jooyung Han829ec7c2020-12-02 12:07:36 +0900950 protected:
951 // utility for subclasses with getter names
952 bool CheckValidForGetterNames() const;
953
Steven Moreland787b0432018-07-03 09:00:58 -0700954 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +0900955 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
956
Jiyong Park1deecc32018-07-17 01:14:41 +0900957 std::string name_;
Jiyong Park1deecc32018-07-17 01:14:41 +0900958 std::string comments_;
Jiyong Park18132182020-06-08 20:24:40 +0900959 const std::string package_;
960 const std::vector<std::string> split_package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900961 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
962 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
963 std::vector<std::unique_ptr<AidlMethod>> methods_;
964 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -0700965};
966
Jeongik Chadf76dc72019-11-28 00:08:47 +0900967class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700968 public:
Jiyong Park18132182020-06-08 20:24:40 +0900969 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
970 const std::string& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +0900971 std::vector<std::string>* type_params = nullptr,
972 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700973 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -0800974
Jiyong Parkd800fef2020-07-22 18:09:43 +0900975 // non-copyable, non-movable
976 AidlParcelable(const AidlParcelable&) = delete;
977 AidlParcelable(AidlParcelable&&) = delete;
978 AidlParcelable& operator=(const AidlParcelable&) = delete;
979 AidlParcelable& operator=(AidlParcelable&&) = delete;
980
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -0800981 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -0800982
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700983 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +0900984 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -0700985 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
986 Options::Language lang) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -0700987 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900988 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
989 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -0700990 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700991
Jeongik Cha997281d2020-01-16 15:23:59 +0900992 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +0900993
Jiyong Park45854452020-12-31 10:42:28 +0900994 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900995
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700996 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -0800997 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700998};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800999
Jooyung Han829ec7c2020-12-02 12:07:36 +09001000class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -07001001 public:
Jiyong Park18132182020-06-08 20:24:40 +09001002 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
1003 const std::string& package, const std::string& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001004 std::vector<std::string>* type_params,
1005 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001006 virtual ~AidlStructuredParcelable() = default;
1007
1008 // non-copyable, non-movable
1009 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
1010 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
1011 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
1012 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001013
Steven Morelandc258abc2018-07-10 14:03:38 -07001014 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001015 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001016
Jeongik Cha997281d2020-01-16 15:23:59 +09001017 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001018
Steven Moreland0cea4aa2020-04-20 21:06:02 -07001019 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +09001020 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001021 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1022 Options::Language lang) const override;
Jiyong Park512ed852020-12-30 15:07:23 +09001023
Jiyong Park45854452020-12-31 10:42:28 +09001024 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001025};
1026
Jooyung Hanc5688f72021-01-05 15:41:48 +09001027class AidlEnumerator : public AidlNode {
Daniel Norman85aed542019-08-21 12:01:14 -07001028 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001029 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
1030 const std::string& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001031 virtual ~AidlEnumerator() = default;
1032
Jiyong Parkd800fef2020-07-22 18:09:43 +09001033 // non-copyable, non-movable
1034 AidlEnumerator(const AidlEnumerator&) = delete;
1035 AidlEnumerator(AidlEnumerator&&) = delete;
1036 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1037 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1038
Daniel Norman85aed542019-08-21 12:01:14 -07001039 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001040 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman2e4112d2019-10-03 10:22:35 -07001041 const std::string& GetComments() const { return comments_; }
Daniel Norman85aed542019-08-21 12:01:14 -07001042 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1043
1044 string ValueString(const AidlTypeSpecifier& backing_type,
1045 const ConstantValueDecorator& decorator) const;
1046
Daniel Normanb28684e2019-10-17 15:31:39 -07001047 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001048 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001049
Jooyung Hanc5688f72021-01-05 15:41:48 +09001050 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1051 traverse(*value_);
Jiyong Park512ed852020-12-30 15:07:23 +09001052 }
Jiyong Park45854452020-12-31 10:42:28 +09001053 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001054
Daniel Norman85aed542019-08-21 12:01:14 -07001055 private:
1056 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001057 unique_ptr<AidlConstantValue> value_;
Daniel Norman2e4112d2019-10-03 10:22:35 -07001058 const std::string comments_;
Jooyung Han29813842020-12-08 01:28:03 +09001059 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001060};
1061
1062class AidlEnumDeclaration : public AidlDefinedType {
1063 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001064 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001065 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jiyong Park18132182020-06-08 20:24:40 +09001066 const std::string& package, const std::string& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001067 virtual ~AidlEnumDeclaration() = default;
1068
Jiyong Parkd800fef2020-07-22 18:09:43 +09001069 // non-copyable, non-movable
1070 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1071 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1072 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1073 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1074
Jooyung Han672557b2020-12-24 05:18:00 +09001075 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001076 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1077 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1078 return enumerators_;
1079 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -07001080 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +09001081 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001082 bool LanguageSpecificCheckValid(const AidlTypenames& /*typenames*/,
1083 Options::Language) const override {
1084 return true;
1085 }
Daniel Norman85aed542019-08-21 12:01:14 -07001086 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Jeongik Cha997281d2020-01-16 15:23:59 +09001087 void Dump(CodeWriter* writer) const override;
Daniel Norman85aed542019-08-21 12:01:14 -07001088
1089 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1090
Jooyung Hanc5688f72021-01-05 15:41:48 +09001091 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1092 AidlDefinedType::TraverseChildren(traverse);
Jiyong Park512ed852020-12-30 15:07:23 +09001093 for (const auto& c : GetEnumerators()) {
1094 traverse(*c);
1095 }
1096 }
Jiyong Park45854452020-12-31 10:42:28 +09001097 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001098
Daniel Norman85aed542019-08-21 12:01:14 -07001099 private:
Jooyung Han29813842020-12-08 01:28:03 +09001100
Daniel Norman85aed542019-08-21 12:01:14 -07001101 const std::string name_;
1102 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001103 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001104};
1105
Jooyung Han829ec7c2020-12-02 12:07:36 +09001106class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001107 public:
1108 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001109 const std::string& comments, std::vector<std::string>* type_params,
1110 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001111 virtual ~AidlUnionDecl() = default;
1112
1113 // non-copyable, non-movable
1114 AidlUnionDecl(const AidlUnionDecl&) = delete;
1115 AidlUnionDecl(AidlUnionDecl&&) = delete;
1116 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1117 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1118
1119 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
1120
1121 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001122 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Hanfe89f122020-10-14 03:49:18 +09001123 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1124 Options::Language lang) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001125 std::string GetPreprocessDeclarationName() const override { return "union"; }
1126
1127 void Dump(CodeWriter* writer) const override;
1128 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jiyong Park45854452020-12-31 10:42:28 +09001129 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han2946afc2020-10-05 20:29:16 +09001130};
1131
Jiyong Park1deecc32018-07-17 01:14:41 +09001132class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001133 public:
Steven Moreland46e9da82018-07-27 15:45:29 -07001134 AidlInterface(const AidlLocation& location, const std::string& name, const std::string& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001135 bool oneway_, const std::string& package,
1136 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001137 virtual ~AidlInterface() = default;
1138
Jiyong Parkd800fef2020-07-22 18:09:43 +09001139 // non-copyable, non-movable
1140 AidlInterface(const AidlInterface&) = delete;
1141 AidlInterface(AidlInterface&&) = delete;
1142 AidlInterface& operator=(const AidlInterface&) = delete;
1143 AidlInterface& operator=(AidlInterface&&) = delete;
1144
Steven Morelandc258abc2018-07-10 14:03:38 -07001145 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001146 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001147
Jeongik Cha997281d2020-01-16 15:23:59 +09001148 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001149
Steven Moreland0cea4aa2020-04-20 21:06:02 -07001150 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +09001151 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001152 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1153 Options::Language lang) const override;
Jeongik Chadb0f59e2018-11-01 18:11:21 +09001154
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001155 std::string GetDescriptor() const;
Jiyong Park45854452020-12-31 10:42:28 +09001156 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001157};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001158
Casey Dahlin0edf3422015-10-07 12:34:59 -07001159class AidlImport : public AidlNode {
1160 public:
Steven Moreland46e9da82018-07-27 15:45:29 -07001161 AidlImport(const AidlLocation& location, const std::string& needed_class);
Casey Dahlin0edf3422015-10-07 12:34:59 -07001162 virtual ~AidlImport() = default;
1163
Jiyong Parkd800fef2020-07-22 18:09:43 +09001164 // non-copyable, non-movable
1165 AidlImport(const AidlImport&) = delete;
1166 AidlImport(AidlImport&&) = delete;
1167 AidlImport& operator=(const AidlImport&) = delete;
1168 AidlImport& operator=(AidlImport&&) = delete;
1169
Casey Dahlin0edf3422015-10-07 12:34:59 -07001170 const std::string& GetNeededClass() const { return needed_class_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +09001171 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1172 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
Casey Dahlin0edf3422015-10-07 12:34:59 -07001173
1174 private:
Casey Dahlin0edf3422015-10-07 12:34:59 -07001175 std::string needed_class_;
Casey Dahline2507492015-09-14 17:11:20 -07001176};
1177
Jiyong Park62515512020-06-08 15:57:11 +09001178// AidlDocument models an AIDL file
Jooyung Hanc5688f72021-01-05 15:41:48 +09001179class AidlDocument : public AidlNode {
Jiyong Park62515512020-06-08 15:57:11 +09001180 public:
1181 AidlDocument(const AidlLocation& location, std::vector<std::unique_ptr<AidlImport>>& imports,
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001182 std::vector<std::unique_ptr<AidlDefinedType>>&& defined_types)
1183 : AidlNode(location),
1184 imports_(std::move(imports)),
1185 defined_types_(std::move(defined_types)) {}
Jiyong Parkd800fef2020-07-22 18:09:43 +09001186 ~AidlDocument() = default;
1187
1188 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001189 AidlDocument(const AidlDocument&) = delete;
1190 AidlDocument(AidlDocument&&) = delete;
1191 AidlDocument& operator=(const AidlDocument&) = delete;
1192 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001193
Jooyung Han29813842020-12-08 01:28:03 +09001194 std::optional<std::string> ResolveName(const std::string& unresolved_type) const;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001195 const std::vector<std::unique_ptr<AidlImport>>& Imports() const { return imports_; }
1196 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1197 return defined_types_;
1198 }
Jiyong Park62515512020-06-08 15:57:11 +09001199
Jooyung Hanc5688f72021-01-05 15:41:48 +09001200 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1201 for (const auto& i : Imports()) {
1202 traverse(*i);
1203 }
Jiyong Park512ed852020-12-30 15:07:23 +09001204 for (const auto& t : DefinedTypes()) {
1205 traverse(*t);
1206 }
1207 }
Jiyong Park45854452020-12-31 10:42:28 +09001208 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001209
Jiyong Park62515512020-06-08 15:57:11 +09001210 private:
1211 const std::vector<std::unique_ptr<AidlImport>> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001212 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jiyong Park62515512020-06-08 15:57:11 +09001213};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001214
1215template <typename T>
1216std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1217 auto it = parameters_.find(param_name);
1218 if (it == parameters_.end()) {
1219 return std::nullopt;
1220 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001221 return it->second->EvaluatedValue<T>();
Jiyong Park512ed852020-12-30 15:07:23 +09001222}
Jooyung Hanc5688f72021-01-05 15:41:48 +09001223
1224// Utility to make a visitor to visit AST tree in top-down order
1225// Given: foo
1226// / \
1227// bar baz
1228// VisitTopDown(v, foo) makes v visit foo -> bar -> baz.
1229inline void VisitTopDown(AidlVisitor& v, const AidlNode& node) {
1230 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
1231 n.DispatchVisit(v);
1232 n.TraverseChildren(top_down);
1233 };
1234 top_down(node);
1235}