blob: 4f19261aab1844982537fab630f3f281cdbba2f0 [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"
Jooyung Han8451a202021-01-16 03:07:06 +090029#include "comments.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090030#include "diagnostics.h"
31#include "io_delegate.h"
Jooyung Han535c5e82020-12-29 15:16:59 +090032#include "location.h"
33#include "logging.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090034#include "options.h"
35
Jiyong Parkb034bf02018-07-30 17:44:33 +090036using android::aidl::AidlTypenames;
Jiyong Park02da7422018-07-16 16:00:26 +090037using android::aidl::CodeWriter;
Jooyung Han8451a202021-01-16 03:07:06 +090038using android::aidl::Comments;
Jeongik Cha047c5ee2019-08-07 23:16:49 +090039using android::aidl::Options;
Steven Moreland3f658cf2018-08-20 13:40:54 -070040using std::shared_ptr;
Jiyong Park1deecc32018-07-17 01:14:41 +090041using std::string;
42using std::unique_ptr;
43using std::vector;
Andrei Onea8714b022019-02-01 18:55:54 +000044class AidlNode;
45
Jooyung Han535c5e82020-12-29 15:16:59 +090046// helper to see if T is the same to one of Args types.
47template <typename T, typename... Args>
48struct is_one_of : std::false_type {};
49
50template <typename T, typename S, typename... Args>
51struct is_one_of<T, S, Args...> {
52 enum { value = std::is_same_v<T, S> || is_one_of<T, Args...>::value };
53};
54
55// helper to see if T is std::vector of something.
56template <typename>
57struct is_vector : std::false_type {};
58
59template <typename T>
60struct is_vector<std::vector<T>> : std::true_type {};
61
62// helper for static_assert(false)
63template <typename T>
64struct unsupported_type : std::false_type {};
65
Andrei Onea8714b022019-02-01 18:55:54 +000066namespace android {
67namespace aidl {
68namespace mappings {
69std::string dump_location(const AidlNode& method);
70} // namespace mappings
Mathew Inwoodadb74672019-11-29 14:01:53 +000071namespace java {
72std::string dump_location(const AidlNode& method);
73} // namespace java
Andrei Onea8714b022019-02-01 18:55:54 +000074} // namespace aidl
75} // namespace android
76
Jooyung Han535c5e82020-12-29 15:16:59 +090077bool ParseFloating(std::string_view sv, double* parsed);
78bool ParseFloating(std::string_view sv, float* parsed);
Steven Moreland46e9da82018-07-27 15:45:29 -070079
Jooyung Han808a2a02020-12-28 16:46:54 +090080class AidlDocument;
Jooyung Han132cf802021-01-15 02:17:32 +090081class AidlPackage;
Jooyung Hanc5688f72021-01-05 15:41:48 +090082class AidlImport;
Jooyung Han808a2a02020-12-28 16:46:54 +090083class AidlInterface;
84class AidlParcelable;
85class AidlStructuredParcelable;
86class AidlEnumDeclaration;
87class AidlUnionDecl;
88class AidlVariableDeclaration;
89class AidlConstantDeclaration;
90class AidlEnumerator;
91class AidlMethod;
92class AidlArgument;
Jooyung Hanc5688f72021-01-05 15:41:48 +090093class AidlConstantValue;
94class AidlConstantReference;
95class AidlUnaryConstExpression;
96class AidlBinaryConstExpression;
97class AidlAnnotation;
Jooyung Han808a2a02020-12-28 16:46:54 +090098
Jiyong Park45854452020-12-31 10:42:28 +090099// Interface for visitors that can traverse AidlTraversable nodes.
Jooyung Han808a2a02020-12-28 16:46:54 +0900100class AidlVisitor {
101 public:
102 virtual ~AidlVisitor() = default;
Jiyong Park45854452020-12-31 10:42:28 +0900103 virtual void Visit(const AidlDocument&) {}
104 virtual void Visit(const AidlInterface&) {}
105 virtual void Visit(const AidlParcelable&) {}
106 virtual void Visit(const AidlStructuredParcelable&) {}
107 virtual void Visit(const AidlUnionDecl&) {}
108 virtual void Visit(const AidlEnumDeclaration&) {}
109 virtual void Visit(const AidlEnumerator&) {}
110 virtual void Visit(const AidlMethod&) {}
111 virtual void Visit(const AidlVariableDeclaration&) {}
112 virtual void Visit(const AidlConstantDeclaration&) {}
113 virtual void Visit(const AidlArgument&) {}
Jooyung Han865da492021-01-03 11:32:47 +0900114 virtual void Visit(const AidlTypeSpecifier&) {}
Jooyung Hanc5688f72021-01-05 15:41:48 +0900115 virtual void Visit(const AidlConstantValue&) {}
116 virtual void Visit(const AidlConstantReference&) {}
117 virtual void Visit(const AidlUnaryConstExpression&) {}
118 virtual void Visit(const AidlBinaryConstExpression&) {}
119 virtual void Visit(const AidlAnnotation&) {}
120 virtual void Visit(const AidlImport&) {}
Jooyung Han132cf802021-01-15 02:17:32 +0900121 virtual void Visit(const AidlPackage&) {}
Jooyung Han808a2a02020-12-28 16:46:54 +0900122};
123
Jooyung Han13f1fa52021-06-11 18:06:12 +0900124class AidlScope {
125 public:
126 virtual ~AidlScope() = default;
127 virtual std::string ResolveName(const std::string& name) const = 0;
128 void SetEnclosingScope(const AidlScope* enclosing) {
129 AIDL_FATAL_IF(enclosing_, AIDL_LOCATION_HERE) << "SetEnclosingScope can be set only once.";
130 enclosing_ = enclosing;
131 }
132 const AidlScope* GetEnclosingScope() const { return enclosing_; }
133
134 private:
135 const AidlScope* enclosing_ = nullptr;
136};
137
Steven Moreland46e9da82018-07-27 15:45:29 -0700138// Anything that is locatable in a .aidl file.
139class AidlNode {
140 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900141 AidlNode(const AidlLocation& location, const Comments& comments = {});
Steven Moreland3f658cf2018-08-20 13:40:54 -0700142
143 AidlNode(const AidlNode&) = default;
Steven Moreland46e9da82018-07-27 15:45:29 -0700144 virtual ~AidlNode() = default;
145
Jiyong Parkd800fef2020-07-22 18:09:43 +0900146 AidlNode(AidlNode&&) = delete;
147 AidlNode& operator=(AidlNode&&) = delete;
148
Devin Mooredf93ebb2020-03-25 14:03:35 -0700149 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700150 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000151 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000152 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700153
Devin Mooredf93ebb2020-03-25 14:03:35 -0700154 const AidlLocation& GetLocation() const { return location_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900155 virtual void TraverseChildren(std::function<void(const AidlNode&)> traverse) const = 0;
156 virtual void DispatchVisit(AidlVisitor&) const = 0;
Devin Mooredf93ebb2020-03-25 14:03:35 -0700157
Jooyung Han8451a202021-01-16 03:07:06 +0900158 const Comments& GetComments() const { return comments_; }
159 void SetComments(const Comments& comments) { comments_ = comments; }
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900160
Steven Moreland46e9da82018-07-27 15:45:29 -0700161 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000162 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000163 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700164 const AidlLocation location_;
Jooyung Han8451a202021-01-16 03:07:06 +0900165 Comments comments_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700166};
167
Jeongik Chadf76dc72019-11-28 00:08:47 +0900168// unique_ptr<AidlTypeSpecifier> for type arugment,
169// std::string for type parameter(T, U, and so on).
170template <typename T>
171class AidlParameterizable {
172 public:
173 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
174 virtual ~AidlParameterizable() = default;
175 bool IsGeneric() const { return type_params_ != nullptr; }
176 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
177 bool CheckValid() const;
178
Steven Moreland6c07b832020-10-29 23:39:53 +0000179 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
180 if (type_params_) return false;
181 type_params_.reset(type_params);
182 return true;
183 }
184
Jeongik Chadf76dc72019-11-28 00:08:47 +0900185 virtual const AidlNode& AsAidlNode() const = 0;
186
187 protected:
188 AidlParameterizable(const AidlParameterizable&);
189
190 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000191 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900192 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
193 std::is_same<T, std::string>::value);
194};
195template <>
196bool AidlParameterizable<std::string>::CheckValid() const;
197
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900198class AidlCommentable : public AidlNode {
Jooyung Han6736ffb2021-01-16 10:13:40 +0900199 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900200 AidlCommentable(const AidlLocation& location, const Comments& comments)
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900201 : AidlNode(location, comments) {}
Jooyung Han6736ffb2021-01-16 10:13:40 +0900202 virtual ~AidlCommentable() = default;
203
Jooyung Han6736ffb2021-01-16 10:13:40 +0900204 bool IsHidden() const;
205 bool IsDeprecated() const;
Jooyung Han6736ffb2021-01-16 10:13:40 +0900206};
Andrei Onea9445fc62019-06-27 18:11:59 +0100207
208// Transforms a value string into a language specific form. Raw value as produced by
209// AidlConstantValue.
210using ConstantValueDecorator =
211 std::function<std::string(const AidlTypeSpecifier& type, const std::string& raw_value)>;
212
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900213class AidlAnnotation : public AidlNode {
Jiyong Park68bc77a2018-07-19 19:00:45 +0900214 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700215 enum class Type {
216 BACKING = 1,
217 HIDE,
218 JAVA_STABLE_PARCELABLE,
219 UNSUPPORTED_APP_USAGE,
220 VINTF_STABILITY,
221 NULLABLE,
222 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000223 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900224 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900225 JAVA_DERIVE,
Jeongik Chad0a10272020-08-06 16:33:36 +0900226 JAVA_ONLY_IMMUTABLE,
Devin Moorec7e47a32020-08-07 10:55:25 -0700227 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900228 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700229 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900230 SUPPRESS_WARNINGS,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700231 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900232
233 using TargetContext = uint16_t;
234 static constexpr TargetContext CONTEXT_TYPE_INTERFACE = 0x1 << 0;
235 static constexpr TargetContext CONTEXT_TYPE_ENUM = 0x1 << 1;
236 static constexpr TargetContext CONTEXT_TYPE_STRUCTURED_PARCELABLE = 0x1 << 2;
237 static constexpr TargetContext CONTEXT_TYPE_UNION = 0x1 << 3;
238 static constexpr TargetContext CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE = 0x1 << 4;
239 static constexpr TargetContext CONTEXT_TYPE =
240 CONTEXT_TYPE_INTERFACE | CONTEXT_TYPE_ENUM | CONTEXT_TYPE_STRUCTURED_PARCELABLE |
241 CONTEXT_TYPE_UNION | CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE;
242 static constexpr TargetContext CONTEXT_CONST = 0x1 << 5;
243 static constexpr TargetContext CONTEXT_FIELD = 0x1 << 6;
244 static constexpr TargetContext CONTEXT_METHOD = 0x1 << 7;
245 static constexpr TargetContext CONTEXT_MEMBER = CONTEXT_CONST | CONTEXT_FIELD | CONTEXT_METHOD;
246 static constexpr TargetContext CONTEXT_TYPE_SPECIFIER = 0x1 << 8;
247 static constexpr TargetContext CONTEXT_ALL =
248 CONTEXT_TYPE | CONTEXT_MEMBER | CONTEXT_TYPE_SPECIFIER;
249
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700250 static std::string TypeToString(Type type);
251
Andrei Onea9445fc62019-06-27 18:11:59 +0100252 static AidlAnnotation* Parse(
253 const AidlLocation& location, const string& name,
Jooyung Han6736ffb2021-01-16 10:13:40 +0900254 std::map<std::string, std::shared_ptr<AidlConstantValue>>* parameter_list,
Jooyung Han8451a202021-01-16 03:07:06 +0900255 const Comments& comments);
Steven Moreland46e9da82018-07-27 15:45:29 -0700256
Steven Moreland3f658cf2018-08-20 13:40:54 -0700257 AidlAnnotation(const AidlAnnotation&) = default;
Steven Moreland3be75772018-08-20 13:27:43 -0700258 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900259 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100260 bool CheckValid() const;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900261 bool CheckContext(TargetContext context) const;
Jooyung Hand902a972020-10-23 17:32:44 +0900262 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700263 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900264 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900265
266 // ToString is for dumping AIDL.
267 // Returns string representation of this annotation.
268 // e.g) "@RustDerive(Clone=true, Copy=true)"
269 string ToString() const;
270
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900271 template <typename T>
272 std::optional<T> ParamValue(const std::string& param_name) const;
273
Andrei Onea9445fc62019-06-27 18:11:59 +0100274 std::map<std::string, std::string> AnnotationParams(
275 const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900276 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
277 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900278
279 private:
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900280 struct ParamType {
281 std::string name;
282 const AidlTypeSpecifier& type;
283 bool required = false;
284 };
285
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700286 struct Schema {
287 AidlAnnotation::Type type;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700288 std::string name;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900289 TargetContext target_context;
290 std::vector<ParamType> parameters;
291 bool repeatable = false;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700292
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900293 const ParamType* ParamType(const std::string& name) const {
294 for (const auto& param : parameters) {
295 if (param.name == name) {
296 return &param;
297 }
298 }
299 return nullptr;
300 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700301 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900302
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700303 static const std::vector<Schema>& AllSchemas();
304
305 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Jooyung Han6736ffb2021-01-16 10:13:40 +0900306 std::map<std::string, std::shared_ptr<AidlConstantValue>>&& parameters,
Jooyung Han8451a202021-01-16 03:07:06 +0900307 const Comments& comments);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700308
309 const Schema& schema_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100310 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900311};
312
Steven Moreland3be75772018-08-20 13:27:43 -0700313static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
314 return lhs.GetName() < rhs.GetName();
315}
316static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
317 return lhs.GetName() == rhs.GetName();
318}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900319
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900320class AidlAnnotatable : public AidlCommentable {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700321 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900322 AidlAnnotatable(const AidlLocation& location, const Comments& comments);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700323
324 AidlAnnotatable(const AidlAnnotatable&) = default;
325 AidlAnnotatable(AidlAnnotatable&&) = default;
Casey Dahline7922932016-02-29 17:23:01 -0800326 virtual ~AidlAnnotatable() = default;
327
Artur Satayev91fe8712019-07-29 13:06:01 +0100328 void Annotate(vector<AidlAnnotation>&& annotations) {
329 for (auto& annotation : annotations) {
330 annotations_.emplace_back(std::move(annotation));
331 }
332 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900333 bool IsNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900334 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000335 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700336 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900337 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700338 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900339 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800340 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900341 bool JavaDerive(const std::string& method) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900342 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100343
344 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700345 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900346 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900347 std::vector<std::string> SuppressWarnings() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900348
349 // ToString is for dumping AIDL.
350 // Returns string representation of annotations.
351 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900352 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800353
Jiyong Parka6605ab2018-11-11 14:30:21 +0900354 const vector<AidlAnnotation>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900355 bool CheckValid(const AidlTypenames&) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900356 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
357 for (const auto& annot : GetAnnotations()) {
358 traverse(annot);
359 }
360 }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900361
Casey Dahline7922932016-02-29 17:23:01 -0800362 private:
Jiyong Parka6605ab2018-11-11 14:30:21 +0900363 vector<AidlAnnotation> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800364};
365
Jiyong Park1deecc32018-07-17 01:14:41 +0900366// AidlTypeSpecifier represents a reference to either a built-in type,
367// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900368class AidlTypeSpecifier final : public AidlAnnotatable,
369 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800370 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700371 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name, bool is_array,
Jooyung Han8451a202021-01-16 03:07:06 +0900372 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const Comments& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900373 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700374
Steven Moreland3f658cf2018-08-20 13:40:54 -0700375 // Copy of this type which is not an array.
Jooyung Hand2fa0232020-10-19 02:51:41 +0900376 const AidlTypeSpecifier& ArrayBase() const;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700377
Jiyong Park1deecc32018-07-17 01:14:41 +0900378 // Returns the full-qualified name of the base type.
379 // int -> int
380 // int[] -> int
381 // List<String> -> List
382 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
383 const string& GetName() const {
384 if (IsResolved()) {
385 return fully_qualified_name_;
386 } else {
387 return GetUnresolvedName();
388 }
389 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700390
Jooyung Han965e31d2020-11-27 12:30:16 +0900391 // ToString is for dumping AIDL.
392 // Returns string representation of this type specifier including annotations.
393 // This is "annotations type_name type_params? array_marker?".
394 // e.g) "@utf8InCpp String[]";
395 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900396
Jooyung Han965e31d2020-11-27 12:30:16 +0900397 // Signature is for comparing AIDL types.
398 // Returns string representation of this type specifier.
399 // This is "type_name type_params? array_marker?".
400 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900401 std::string Signature() const;
402
Jiyong Park1deecc32018-07-17 01:14:41 +0900403 const string& GetUnresolvedName() const { return unresolved_name_; }
404
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900405 const std::vector<std::string> GetSplitName() const { return split_name_; }
406
Jiyong Park1deecc32018-07-17 01:14:41 +0900407 bool IsResolved() const { return fully_qualified_name_ != ""; }
408
409 bool IsArray() const { return is_array_; }
410
Steven Moreland6c07b832020-10-29 23:39:53 +0000411 __attribute__((warn_unused_result)) bool SetArray() {
412 if (is_array_) return false;
413 is_array_ = true;
414 return true;
415 }
416
Jiyong Park1deecc32018-07-17 01:14:41 +0900417 // Resolve the base type name to a fully-qualified name. Return false if the
418 // resolution fails.
Jooyung Han13f1fa52021-06-11 18:06:12 +0900419 bool Resolve(const AidlTypenames& typenames, const AidlScope* scope);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700420
Jooyung Han888c5bc2020-12-22 17:28:47 +0900421 bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700422 bool LanguageSpecificCheckValid(const AidlTypenames& typenames, Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900423 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900424
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900425 const AidlDefinedType* GetDefinedType() const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900426 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
427 AidlAnnotatable::TraverseChildren(traverse);
Jooyung Han865da492021-01-03 11:32:47 +0900428 if (IsGeneric()) {
429 for (const auto& tp : GetTypeParameters()) {
430 traverse(*tp);
431 }
432 }
433 }
434 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900435
Casey Dahlin0ee37582015-09-30 16:31:55 -0700436 private:
Steven Moreland3f658cf2018-08-20 13:40:54 -0700437 AidlTypeSpecifier(const AidlTypeSpecifier&) = default;
438
Jiyong Park1deecc32018-07-17 01:14:41 +0900439 const string unresolved_name_;
440 string fully_qualified_name_;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700441 bool is_array_;
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900442 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900443 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Jooyung Hand2fa0232020-10-19 02:51:41 +0900444 mutable shared_ptr<AidlTypeSpecifier> array_base_;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700445};
446
Steven Moreland860b1942018-08-16 14:59:28 -0700447// Returns the universal value unaltered.
448std::string AidlConstantValueDecorator(const AidlTypeSpecifier& type, const std::string& raw_value);
449
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900450class AidlMember : public AidlCommentable {
Jooyung Han8aeef8c2021-01-11 12:16:19 +0900451 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900452 AidlMember(const AidlLocation& location, const Comments& comments);
Jooyung Han3f347ca2020-12-01 12:41:50 +0900453 virtual ~AidlMember() = default;
454
455 // non-copyable, non-movable
456 AidlMember(const AidlMember&) = delete;
457 AidlMember(AidlMember&&) = delete;
458 AidlMember& operator=(const AidlMember&) = delete;
459 AidlMember& operator=(AidlMember&&) = delete;
460
Jooyung Han829ec7c2020-12-02 12:07:36 +0900461 virtual const AidlMethod* AsMethod() const { return nullptr; }
462 virtual const AidlConstantDeclaration* AsConstantDeclaration() const { return nullptr; }
463 virtual const AidlVariableDeclaration* AsVariableDeclaration() const { return nullptr; }
464
465 AidlMethod* AsMethod() {
466 return const_cast<AidlMethod*>(const_cast<const AidlMember*>(this)->AsMethod());
467 }
468 AidlConstantDeclaration* AsConstantDeclaration() {
469 return const_cast<AidlConstantDeclaration*>(
470 const_cast<const AidlMember*>(this)->AsConstantDeclaration());
471 }
472 AidlVariableDeclaration* AsVariableDeclaration() {
473 return const_cast<AidlVariableDeclaration*>(
474 const_cast<const AidlMember*>(this)->AsVariableDeclaration());
475 }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900476};
477
Steven Moreland541788d2020-05-21 22:05:52 +0000478// TODO: This class is used for method arguments and also parcelable fields,
479// and it should be split up since default values don't apply to method
480// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900481class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700482 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700483 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
484 const std::string& name);
485 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
486 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700487 virtual ~AidlVariableDeclaration() = default;
488
Jiyong Parkd800fef2020-07-22 18:09:43 +0900489 // non-copyable, non-movable
490 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
491 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
492 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
493 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
494
Jooyung Han829ec7c2020-12-02 12:07:36 +0900495 const AidlVariableDeclaration* AsVariableDeclaration() const override { return this; }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900496
Steven Moreland5557f1c2018-07-02 13:50:23 -0700497 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900498 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900499 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000500 // if this was constructed explicitly with a default value
501 bool IsDefaultUserSpecified() const { return default_user_specified_; }
502 // will return the default value this is constructed with or a default value
503 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700504 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900505 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700506
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900507 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700508
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900509 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900510
511 // ToString is for dumping AIDL.
512 // Returns string representation of this variable decl including default value.
513 // This is "annotations type name default_value?".
514 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700515 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900516
517 // Signature is for comparing AIDL types.
518 // Returns string representation of this variable decl.
519 // This is "type name".
520 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900521 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700522
Steven Moreland860b1942018-08-16 14:59:28 -0700523 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700524
Jooyung Hanc5688f72021-01-05 15:41:48 +0900525 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jiyong Park45854452020-12-31 10:42:28 +0900526 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900527
Steven Moreland5557f1c2018-07-02 13:50:23 -0700528 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900529 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700530 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000531 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700532 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700533};
534
535class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700536 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700537 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
538
Steven Moreland46e9da82018-07-27 15:45:29 -0700539 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
540 AidlTypeSpecifier* type, const std::string& name);
541 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700542 virtual ~AidlArgument() = default;
543
Jiyong Parkd800fef2020-07-22 18:09:43 +0900544 // non-copyable, non-movable
545 AidlArgument(const AidlArgument&) = delete;
546 AidlArgument(AidlArgument&&) = delete;
547 AidlArgument& operator=(const AidlArgument&) = delete;
548 AidlArgument& operator=(AidlArgument&&) = delete;
549
Casey Dahlinc378c992015-09-29 16:50:40 -0700550 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700551 bool IsOut() const { return direction_ & OUT_DIR; }
552 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700553 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900554 string GetDirectionSpecifier() const;
Jooyung Han020d8d12021-02-26 17:23:02 +0900555 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyad339272015-10-05 19:11:58 -0700556
Jooyung Han965e31d2020-11-27 12:30:16 +0900557 // ToString is for dumping AIDL.
558 // Returns string representation of this argument including direction
559 // This is "direction annotations type name".
560 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700561 std::string ToString() const;
Jiyong Park512ed852020-12-30 15:07:23 +0900562
Jooyung Hanc5688f72021-01-05 15:41:48 +0900563 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900564 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900565 }
Jiyong Park45854452020-12-31 10:42:28 +0900566 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700567
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700568 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700569 Direction direction_;
570 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700571};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800572
Jooyung Han020d8d12021-02-26 17:23:02 +0900573struct ArgumentAspect {
574 std::string name;
575 std::set<AidlArgument::Direction> possible_directions;
576};
577
Will McVickerd7d18df2019-09-12 13:40:50 -0700578class AidlUnaryConstExpression;
579class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900580class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700581
Steven Moreland693640b2018-07-19 13:46:27 -0700582class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800583 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700584 enum class Type {
585 // WARNING: Don't change this order! The order is used to determine type
586 // promotion during a binary expression.
587 BOOLEAN,
588 INT8,
589 INT32,
590 INT64,
591 ARRAY,
592 CHARACTER,
593 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900594 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700595 FLOATING,
596 UNARY,
597 BINARY,
598 ERROR,
599 };
600
Jooyung Han535c5e82020-12-29 15:16:59 +0900601 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700602 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900603 T EvaluatedValue() const {
604 is_evaluated_ || (CheckValid() && evaluate());
605 AIDL_FATAL_IF(!is_valid_, this);
606
607 if constexpr (is_vector<T>::value) {
608 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
609 T result;
610 for (const auto& v : values_) {
611 result.push_back(v->EvaluatedValue<typename T::value_type>());
612 }
613 return result;
614 } else if constexpr (is_one_of<T, float, double>::value) {
615 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
616 T result;
617 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
618 return result;
619 } else if constexpr (std::is_same<T, std::string>::value) {
620 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
621 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
622 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
623 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
624 return static_cast<T>(final_value_);
625 } else if constexpr (std::is_same<T, char>::value) {
626 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
627 return final_string_value_.at(1); // unquote '
628 } else if constexpr (std::is_same<T, bool>::value) {
629 static_assert(std::is_same<T, bool>::value, "..");
630 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
631 return final_value_ != 0;
632 } else {
633 static_assert(unsupported_type<T>::value);
634 }
635 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800636
Steven Moreland693640b2018-07-19 13:46:27 -0700637 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800638
Jiyong Parkd800fef2020-07-22 18:09:43 +0900639 // non-copyable, non-movable
640 AidlConstantValue(const AidlConstantValue&) = delete;
641 AidlConstantValue(AidlConstantValue&&) = delete;
642 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
643 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
644
Steven Moreland541788d2020-05-21 22:05:52 +0000645 // creates default value, when one isn't specified
646 // nullptr if no default available
647 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
648
Steven Moreland25294322018-08-07 18:13:55 -0700649 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
650 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700651 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700652 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
653 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700654 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700655 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700656 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700657 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700658
Will McVickerd7d18df2019-09-12 13:40:50 -0700659 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900660 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700661
Will McVickerd7d18df2019-09-12 13:40:50 -0700662 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700663
664 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800665 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900666
667 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const {
Jooyung Han29813842020-12-08 01:28:03 +0900668 if (type_ == Type::ARRAY) {
669 for (const auto& v : values_) {
Jooyung Hanc5688f72021-01-05 15:41:48 +0900670 traverse(*v);
Jooyung Han29813842020-12-08 01:28:03 +0900671 }
672 }
673 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900674 void DispatchVisit(AidlVisitor& visitor) const override { visitor.Visit(*this); }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800675
676 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700677 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
678 const string& checked_value);
679 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700680 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900681 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
682 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700683 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700684 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
685 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800686
Jooyung Han74675c22020-12-15 08:39:57 +0900687 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800688
Steven Moreland693640b2018-07-19 13:46:27 -0700689 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700690 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
691 const string value_; // otherwise
692
693 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800694 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
695 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700696 mutable Type final_type_;
697 mutable int64_t final_value_;
698 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700699
Will McVickerd7d18df2019-09-12 13:40:50 -0700700 friend AidlUnaryConstExpression;
701 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900702 friend AidlConstantReference;
703};
704
705// Represents "<type>.<field>" which resolves to a constant which is one of
706// - constant declartion
707// - enumerator
708// When a <type> is missing, <field> is of the enclosing type.
709class AidlConstantReference : public AidlConstantValue {
710 public:
Jooyung Hand0c8af02021-01-06 18:08:01 +0900711 AidlConstantReference(const AidlLocation& location, const std::string& value);
Jooyung Han690f5842020-12-04 13:02:04 +0900712
713 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900714 const std::string& GetFieldName() const { return field_name_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900715
716 bool CheckValid() const override;
Jooyung Han289a1bc2021-05-15 15:04:05 +0900717 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
718 if (ref_type_) {
719 traverse(*ref_type_);
720 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900721 }
722 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900723 const AidlConstantValue* Resolve(const AidlDefinedType* scope) const;
Jooyung Han690f5842020-12-04 13:02:04 +0900724
725 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900726 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900727
728 std::unique_ptr<AidlTypeSpecifier> ref_type_;
729 std::string field_name_;
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900730 mutable const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700731};
732
733class AidlUnaryConstExpression : public AidlConstantValue {
734 public:
735 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
736 std::unique_ptr<AidlConstantValue> rval);
737
738 static bool IsCompatibleType(Type type, const string& op);
739 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900740 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
741 traverse(*unary_);
Jooyung Han690f5842020-12-04 13:02:04 +0900742 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900743 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han690f5842020-12-04 13:02:04 +0900744
Will McVickerd7d18df2019-09-12 13:40:50 -0700745 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900746 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700747
748 std::unique_ptr<AidlConstantValue> unary_;
749 const string op_;
750};
751
752class AidlBinaryConstExpression : public AidlConstantValue {
753 public:
754 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
755 const string& op, std::unique_ptr<AidlConstantValue> rval);
756
757 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700758
759 static bool AreCompatibleTypes(Type t1, Type t2);
760 // Returns the promoted kind for both operands
761 static Type UsualArithmeticConversion(Type left, Type right);
762 // Returns the promoted integral type where INT32 is the smallest type
763 static Type IntegralPromotion(Type in);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900764 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
765 traverse(*left_val_);
766 traverse(*right_val_);
Jooyung Han690f5842020-12-04 13:02:04 +0900767 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900768 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700769
770 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900771 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700772
773 std::unique_ptr<AidlConstantValue> left_val_;
774 std::unique_ptr<AidlConstantValue> right_val_;
775 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700776};
777
Andrei Onea9445fc62019-06-27 18:11:59 +0100778struct AidlAnnotationParameter {
779 std::string name;
780 std::unique_ptr<AidlConstantValue> value;
781};
782
Steven Moreland693640b2018-07-19 13:46:27 -0700783class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700784 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700785 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700786 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700787 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700788
Jiyong Parkd800fef2020-07-22 18:09:43 +0900789 // non-copyable, non-movable
790 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
791 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
792 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
793 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
794
Steven Moreland693640b2018-07-19 13:46:27 -0700795 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700796 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700797 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700798 const AidlConstantValue& GetValue() const { return *value_; }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900799 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700800
Jooyung Han965e31d2020-11-27 12:30:16 +0900801 // ToString is for dumping AIDL.
802 // Returns string representation of this const decl including a const value.
803 // This is "`const` annotations type name value".
804 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700805 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900806
807 // Signature is for comparing types.
808 // Returns string representation of this const decl.
809 // This is "direction annotations type name".
810 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700811 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900812
Steven Moreland860b1942018-08-16 14:59:28 -0700813 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700814 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700815 }
Steven Moreland25294322018-08-07 18:13:55 -0700816
Jooyung Han829ec7c2020-12-02 12:07:36 +0900817 const AidlConstantDeclaration* AsConstantDeclaration() const override { return this; }
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700818
Jooyung Hanc5688f72021-01-05 15:41:48 +0900819 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900820 traverse(GetType());
Jooyung Hanc5688f72021-01-05 15:41:48 +0900821 traverse(GetValue());
Jiyong Park512ed852020-12-30 15:07:23 +0900822 }
Jiyong Park45854452020-12-31 10:42:28 +0900823 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900824
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700825 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700826 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700827 const string name_;
828 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800829};
830
831class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700832 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700833 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900834 vector<unique_ptr<AidlArgument>>* args, const Comments& comments);
Will McVickerd7d18df2019-09-12 13:40:50 -0700835 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900836 vector<unique_ptr<AidlArgument>>* args, const Comments& comments, int id,
Will McVickerd7d18df2019-09-12 13:40:50 -0700837 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700838 virtual ~AidlMethod() = default;
839
Jiyong Parkd800fef2020-07-22 18:09:43 +0900840 // non-copyable, non-movable
841 AidlMethod(const AidlMethod&) = delete;
842 AidlMethod(AidlMethod&&) = delete;
843 AidlMethod& operator=(const AidlMethod&) = delete;
844 AidlMethod& operator=(AidlMethod&&) = delete;
845
Jooyung Han829ec7c2020-12-02 12:07:36 +0900846 const AidlMethod* AsMethod() const override { return this; }
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900847 const AidlTypeSpecifier& GetType() const { return *type_; }
848 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800849
Steven Moreland8c70ba92018-12-17 10:20:31 -0800850 // set if this method is part of an interface that is marked oneway
851 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700852 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800853
Casey Dahlinf4a93112015-10-05 16:58:09 -0700854 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700855 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900856 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700857 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700858
Jiyong Park309668e2018-07-28 16:55:44 +0900859 bool IsUserDefined() const { return is_user_defined_; }
860
Casey Dahlinf4a93112015-10-05 16:58:09 -0700861 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700862 return arguments_;
863 }
864 // An inout parameter will appear in both GetInArguments()
865 // and GetOutArguments(). AidlMethod retains ownership of the argument
866 // pointers returned in this way.
867 const std::vector<const AidlArgument*>& GetInArguments() const {
868 return in_arguments_;
869 }
870 const std::vector<const AidlArgument*>& GetOutArguments() const {
871 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700872 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700873
Jooyung Han965e31d2020-11-27 12:30:16 +0900874 // ToString is for dumping AIDL.
875 // Returns string representation of this method including everything.
876 // This is "ret_type name ( arg_list ) = id".
877 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900878 std::string ToString() const;
879
Jooyung Han965e31d2020-11-27 12:30:16 +0900880 // Signature is for comparing AIDL types.
881 // Returns string representation of this method's name & type.
882 // e.g) "foo(int, String)"
883 std::string Signature() const;
884
Jooyung Hanc5688f72021-01-05 15:41:48 +0900885 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900886 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900887 for (const auto& a : GetArguments()) {
888 traverse(*a);
889 }
890 }
Jiyong Park45854452020-12-31 10:42:28 +0900891 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han808a2a02020-12-28 16:46:54 +0900892
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700893 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700894 bool oneway_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900895 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700896 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700897 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
898 std::vector<const AidlArgument*> in_arguments_;
899 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700900 bool has_id_;
901 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900902 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700903};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800904
Daniel Norman85aed542019-08-21 12:01:14 -0700905// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900906// defined in the source file.
Jooyung Han13f1fa52021-06-11 18:06:12 +0900907class AidlDefinedType : public AidlAnnotatable, public AidlScope {
Steven Moreland787b0432018-07-03 09:00:58 -0700908 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900909 AidlDefinedType(const AidlLocation& location, const std::string& name, const Comments& comments,
910 const std::string& package, std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700911 virtual ~AidlDefinedType() = default;
912
Jiyong Parkd800fef2020-07-22 18:09:43 +0900913 // non-copyable, non-movable
914 AidlDefinedType(const AidlDefinedType&) = delete;
915 AidlDefinedType(AidlDefinedType&&) = delete;
916 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
917 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
918
Jiyong Park1deecc32018-07-17 01:14:41 +0900919 const std::string& GetName() const { return name_; };
Jiyong Park1deecc32018-07-17 01:14:41 +0900920
Jooyung Han13f1fa52021-06-11 18:06:12 +0900921 std::string ResolveName(const std::string& name) const override;
922
Steven Moreland787b0432018-07-03 09:00:58 -0700923 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900924 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700925 /* dot joined package and name, example: "android.package.foo.IBar" */
926 std::string GetCanonicalName() const;
Jooyung Han93f48f02021-06-05 00:11:16 +0900927 std::vector<std::string> GetSplitPackage() const {
928 if (package_.empty()) return std::vector<std::string>();
929 return android::base::Split(package_, ".");
930 }
Steven Moreland787b0432018-07-03 09:00:58 -0700931
Steven Morelanded83a282018-07-17 13:27:29 -0700932 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700933
Steven Moreland5557f1c2018-07-02 13:50:23 -0700934 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700935 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700936 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900937 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700938 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900939 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900940 virtual bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700941 virtual bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
942 Options::Language lang) const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700943 AidlStructuredParcelable* AsStructuredParcelable() {
944 return const_cast<AidlStructuredParcelable*>(
945 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
946 }
947 AidlParcelable* AsParcelable() {
948 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
949 }
Daniel Norman85aed542019-08-21 12:01:14 -0700950 AidlEnumDeclaration* AsEnumDeclaration() {
951 return const_cast<AidlEnumDeclaration*>(
952 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
953 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900954 AidlUnionDecl* AsUnionDeclaration() {
955 return const_cast<AidlUnionDecl*>(
956 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
957 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700958 AidlInterface* AsInterface() {
959 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
960 }
961
Jeongik Chadf76dc72019-11-28 00:08:47 +0900962 AidlParameterizable<std::string>* AsParameterizable() {
963 return const_cast<AidlParameterizable<std::string>*>(
964 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
965 }
966
Steven Moreland6cee3482018-07-18 14:39:58 -0700967 const AidlParcelable* AsUnstructuredParcelable() const {
968 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900969 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700970 return this->AsParcelable();
971 }
972 AidlParcelable* AsUnstructuredParcelable() {
973 return const_cast<AidlParcelable*>(
974 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
975 }
976
Jooyung Han829ec7c2020-12-02 12:07:36 +0900977 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
978 return variables_;
979 }
980 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
981 return constants_;
982 }
983 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
984 void AddMethod(std::unique_ptr<AidlMethod> method) { methods_.push_back(std::move(method)); }
985 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900986 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
987 AidlAnnotatable::TraverseChildren(traverse);
988 for (const auto c : GetMembers()) {
989 traverse(*c);
990 }
991 }
Jiyong Park512ed852020-12-30 15:07:23 +0900992
Jooyung Han829ec7c2020-12-02 12:07:36 +0900993 protected:
994 // utility for subclasses with getter names
995 bool CheckValidForGetterNames() const;
996
Steven Moreland787b0432018-07-03 09:00:58 -0700997 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +0900998 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
999
Jiyong Park1deecc32018-07-17 01:14:41 +09001000 std::string name_;
Jooyung Han93f48f02021-06-05 00:11:16 +09001001 std::string package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +09001002 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
1003 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
1004 std::vector<std::unique_ptr<AidlMethod>> methods_;
1005 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -07001006};
1007
Jeongik Chadf76dc72019-11-28 00:08:47 +09001008class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001009 public:
Jiyong Park18132182020-06-08 20:24:40 +09001010 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001011 const Comments& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +09001012 std::vector<std::string>* type_params = nullptr,
1013 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001014 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -08001015
Jiyong Parkd800fef2020-07-22 18:09:43 +09001016 // non-copyable, non-movable
1017 AidlParcelable(const AidlParcelable&) = delete;
1018 AidlParcelable(AidlParcelable&&) = delete;
1019 AidlParcelable& operator=(const AidlParcelable&) = delete;
1020 AidlParcelable& operator=(AidlParcelable&&) = delete;
1021
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001022 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001023
Jooyung Han808a2a02020-12-28 16:46:54 +09001024 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001025 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1026 Options::Language lang) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -07001027 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +09001028 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
1029 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001030 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -07001031
Jiyong Park45854452020-12-31 10:42:28 +09001032 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001033
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001034 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001035 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001036};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001037
Jooyung Han829ec7c2020-12-02 12:07:36 +09001038class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -07001039 public:
Jiyong Park18132182020-06-08 20:24:40 +09001040 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
Jooyung Han8451a202021-01-16 03:07:06 +09001041 const std::string& package, const Comments& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001042 std::vector<std::string>* type_params,
1043 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001044 virtual ~AidlStructuredParcelable() = default;
1045
1046 // non-copyable, non-movable
1047 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
1048 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
1049 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
1050 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001051
Steven Morelandc258abc2018-07-10 14:03:38 -07001052 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001053 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001054
Jooyung Han808a2a02020-12-28 16:46:54 +09001055 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001056 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1057 Options::Language lang) const override;
Jiyong Park512ed852020-12-30 15:07:23 +09001058
Jiyong Park45854452020-12-31 10:42:28 +09001059 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001060};
1061
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001062class AidlEnumerator : public AidlCommentable {
Daniel Norman85aed542019-08-21 12:01:14 -07001063 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001064 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
Jooyung Han8451a202021-01-16 03:07:06 +09001065 const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001066 virtual ~AidlEnumerator() = default;
1067
Jiyong Parkd800fef2020-07-22 18:09:43 +09001068 // non-copyable, non-movable
1069 AidlEnumerator(const AidlEnumerator&) = delete;
1070 AidlEnumerator(AidlEnumerator&&) = delete;
1071 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1072 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1073
Daniel Norman85aed542019-08-21 12:01:14 -07001074 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001075 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman85aed542019-08-21 12:01:14 -07001076 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1077
1078 string ValueString(const AidlTypeSpecifier& backing_type,
1079 const ConstantValueDecorator& decorator) const;
1080
Daniel Normanb28684e2019-10-17 15:31:39 -07001081 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001082 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001083
Jooyung Hanc5688f72021-01-05 15:41:48 +09001084 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1085 traverse(*value_);
Jiyong Park512ed852020-12-30 15:07:23 +09001086 }
Jiyong Park45854452020-12-31 10:42:28 +09001087 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001088
Daniel Norman85aed542019-08-21 12:01:14 -07001089 private:
1090 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001091 unique_ptr<AidlConstantValue> value_;
Jooyung Han29813842020-12-08 01:28:03 +09001092 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001093};
1094
1095class AidlEnumDeclaration : public AidlDefinedType {
1096 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001097 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001098 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jooyung Han8451a202021-01-16 03:07:06 +09001099 const std::string& package, const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001100 virtual ~AidlEnumDeclaration() = default;
1101
Jiyong Parkd800fef2020-07-22 18:09:43 +09001102 // non-copyable, non-movable
1103 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1104 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1105 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1106 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1107
Jooyung Han672557b2020-12-24 05:18:00 +09001108 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001109 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1110 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1111 return enumerators_;
1112 }
Jooyung Han808a2a02020-12-28 16:46:54 +09001113 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001114 bool LanguageSpecificCheckValid(const AidlTypenames& /*typenames*/,
1115 Options::Language) const override {
1116 return true;
1117 }
Daniel Norman85aed542019-08-21 12:01:14 -07001118 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Daniel Norman85aed542019-08-21 12:01:14 -07001119
1120 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1121
Jooyung Hanc5688f72021-01-05 15:41:48 +09001122 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1123 AidlDefinedType::TraverseChildren(traverse);
Jiyong Park512ed852020-12-30 15:07:23 +09001124 for (const auto& c : GetEnumerators()) {
1125 traverse(*c);
1126 }
1127 }
Jiyong Park45854452020-12-31 10:42:28 +09001128 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001129
Daniel Norman85aed542019-08-21 12:01:14 -07001130 private:
Jooyung Han29813842020-12-08 01:28:03 +09001131
Daniel Norman85aed542019-08-21 12:01:14 -07001132 const std::string name_;
1133 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001134 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001135};
1136
Jooyung Han829ec7c2020-12-02 12:07:36 +09001137class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001138 public:
1139 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001140 const Comments& comments, std::vector<std::string>* type_params,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001141 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001142 virtual ~AidlUnionDecl() = default;
1143
1144 // non-copyable, non-movable
1145 AidlUnionDecl(const AidlUnionDecl&) = delete;
1146 AidlUnionDecl(AidlUnionDecl&&) = delete;
1147 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1148 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1149
Jooyung Han2946afc2020-10-05 20:29:16 +09001150
1151 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001152 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Hanfe89f122020-10-14 03:49:18 +09001153 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1154 Options::Language lang) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001155 std::string GetPreprocessDeclarationName() const override { return "union"; }
1156
Jooyung Han2946afc2020-10-05 20:29:16 +09001157 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jiyong Park45854452020-12-31 10:42:28 +09001158 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han2946afc2020-10-05 20:29:16 +09001159};
1160
Jiyong Park1deecc32018-07-17 01:14:41 +09001161class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001162 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001163 AidlInterface(const AidlLocation& location, const std::string& name, const Comments& comments,
Jooyung Handb4d8a62021-06-22 10:09:42 +09001164 bool oneway, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001165 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001166 virtual ~AidlInterface() = default;
1167
Jiyong Parkd800fef2020-07-22 18:09:43 +09001168 // non-copyable, non-movable
1169 AidlInterface(const AidlInterface&) = delete;
1170 AidlInterface(AidlInterface&&) = delete;
1171 AidlInterface& operator=(const AidlInterface&) = delete;
1172 AidlInterface& operator=(AidlInterface&&) = delete;
1173
Steven Morelandc258abc2018-07-10 14:03:38 -07001174 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001175 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001176
Jooyung Han808a2a02020-12-28 16:46:54 +09001177 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001178 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1179 Options::Language lang) const override;
Jeongik Chadb0f59e2018-11-01 18:11:21 +09001180
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001181 std::string GetDescriptor() const;
Jiyong Park45854452020-12-31 10:42:28 +09001182 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001183};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001184
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001185class AidlPackage : public AidlNode {
Casey Dahlin0edf3422015-10-07 12:34:59 -07001186 public:
Jooyung Han93f48f02021-06-05 00:11:16 +09001187 AidlPackage(const AidlLocation& location, const std::string& name, const Comments& comments)
1188 : AidlNode(location, comments), name_(name) {}
Jooyung Han132cf802021-01-15 02:17:32 +09001189 virtual ~AidlPackage() = default;
1190 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1191 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
Jooyung Han93f48f02021-06-05 00:11:16 +09001192
1193 const std::string& GetName() const { return name_; }
1194
1195 private:
1196 std::string name_;
Jooyung Han132cf802021-01-15 02:17:32 +09001197};
1198
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001199class AidlImport : public AidlNode {
Jooyung Han132cf802021-01-15 02:17:32 +09001200 public:
1201 AidlImport(const AidlLocation& location, const std::string& needed_class,
Jooyung Han8451a202021-01-16 03:07:06 +09001202 const Comments& comments);
Casey Dahlin0edf3422015-10-07 12:34:59 -07001203 virtual ~AidlImport() = default;
1204
Jiyong Parkd800fef2020-07-22 18:09:43 +09001205 // non-copyable, non-movable
1206 AidlImport(const AidlImport&) = delete;
1207 AidlImport(AidlImport&&) = delete;
1208 AidlImport& operator=(const AidlImport&) = delete;
1209 AidlImport& operator=(AidlImport&&) = delete;
1210
Casey Dahlin0edf3422015-10-07 12:34:59 -07001211 const std::string& GetNeededClass() const { return needed_class_; }
Jooyung Hanf886f982021-06-11 09:56:04 +09001212 std::string SimpleName() const { return needed_class_.substr(needed_class_.rfind('.') + 1); }
Jooyung Hanc5688f72021-01-05 15:41:48 +09001213 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1214 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
Casey Dahlin0edf3422015-10-07 12:34:59 -07001215
1216 private:
Casey Dahlin0edf3422015-10-07 12:34:59 -07001217 std::string needed_class_;
Casey Dahline2507492015-09-14 17:11:20 -07001218};
1219
Jiyong Park62515512020-06-08 15:57:11 +09001220// AidlDocument models an AIDL file
Jooyung Han13f1fa52021-06-11 18:06:12 +09001221class AidlDocument : public AidlCommentable, public AidlScope {
Jiyong Park62515512020-06-08 15:57:11 +09001222 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001223 AidlDocument(const AidlLocation& location, const Comments& comments,
Jooyung Han132cf802021-01-15 02:17:32 +09001224 std::vector<std::unique_ptr<AidlImport>> imports,
Jooyung Han13f1fa52021-06-11 18:06:12 +09001225 std::vector<std::unique_ptr<AidlDefinedType>> defined_types);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001226 ~AidlDocument() = default;
1227
1228 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001229 AidlDocument(const AidlDocument&) = delete;
1230 AidlDocument(AidlDocument&&) = delete;
1231 AidlDocument& operator=(const AidlDocument&) = delete;
1232 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001233
Jooyung Han13f1fa52021-06-11 18:06:12 +09001234 std::string ResolveName(const std::string& name) const override;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001235 const std::vector<std::unique_ptr<AidlImport>>& Imports() const { return imports_; }
1236 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1237 return defined_types_;
1238 }
Jiyong Park62515512020-06-08 15:57:11 +09001239
Jooyung Hanc5688f72021-01-05 15:41:48 +09001240 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1241 for (const auto& i : Imports()) {
1242 traverse(*i);
1243 }
Jiyong Park512ed852020-12-30 15:07:23 +09001244 for (const auto& t : DefinedTypes()) {
1245 traverse(*t);
1246 }
1247 }
Jiyong Park45854452020-12-31 10:42:28 +09001248 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001249
Jiyong Park62515512020-06-08 15:57:11 +09001250 private:
1251 const std::vector<std::unique_ptr<AidlImport>> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001252 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jiyong Park62515512020-06-08 15:57:11 +09001253};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001254
1255template <typename T>
1256std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1257 auto it = parameters_.find(param_name);
1258 if (it == parameters_.end()) {
1259 return std::nullopt;
1260 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001261 return it->second->EvaluatedValue<T>();
Jiyong Park512ed852020-12-30 15:07:23 +09001262}
Jooyung Hanc5688f72021-01-05 15:41:48 +09001263
1264// Utility to make a visitor to visit AST tree in top-down order
1265// Given: foo
1266// / \
1267// bar baz
1268// VisitTopDown(v, foo) makes v visit foo -> bar -> baz.
1269inline void VisitTopDown(AidlVisitor& v, const AidlNode& node) {
1270 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
1271 n.DispatchVisit(v);
1272 n.TraverseChildren(top_down);
1273 };
1274 top_down(node);
Jooyung Han289a1bc2021-05-15 15:04:05 +09001275}
1276
1277// Utility to make a visitor to visit AST tree in bottom-up order
1278// Given: foo
1279// / \
1280// bar baz
1281// VisitBottomUp(v, foo) makes v visit bar -> baz -> foo.
1282inline void VisitBottomUp(AidlVisitor& v, const AidlNode& node) {
1283 std::function<void(const AidlNode&)> bottom_up = [&](const AidlNode& n) {
1284 n.TraverseChildren(bottom_up);
1285 n.DispatchVisit(v);
1286 };
1287 bottom_up(node);
Jooyung Hanc5688f72021-01-05 15:41:48 +09001288}