blob: c2cffd6d7f41fd3bd7b4956118bcf469d474a3b7 [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
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +020025#include <android-base/result.h>
Elliott Hughes0a620672015-12-04 13:53:18 -080026#include <android-base/strings.h>
Casey Dahlin73d46b02015-09-11 02:47:54 +000027
Jooyung Han888c5bc2020-12-22 17:28:47 +090028#include "aidl_typenames.h"
29#include "code_writer.h"
Jooyung Han8451a202021-01-16 03:07:06 +090030#include "comments.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090031#include "diagnostics.h"
32#include "io_delegate.h"
Jooyung Han535c5e82020-12-29 15:16:59 +090033#include "location.h"
34#include "logging.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090035#include "options.h"
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +020036#include "permission/parser.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090037
Jiyong Parkb034bf02018-07-30 17:44:33 +090038using android::aidl::AidlTypenames;
Jiyong Park02da7422018-07-16 16:00:26 +090039using android::aidl::CodeWriter;
Jooyung Han8451a202021-01-16 03:07:06 +090040using android::aidl::Comments;
Jeongik Cha047c5ee2019-08-07 23:16:49 +090041using android::aidl::Options;
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +020042using android::base::Result;
Steven Moreland3f658cf2018-08-20 13:40:54 -070043using std::shared_ptr;
Jiyong Park1deecc32018-07-17 01:14:41 +090044using std::string;
45using std::unique_ptr;
46using std::vector;
Andrei Onea8714b022019-02-01 18:55:54 +000047class AidlNode;
48
Jooyung Han535c5e82020-12-29 15:16:59 +090049// helper to see if T is the same to one of Args types.
50template <typename T, typename... Args>
51struct is_one_of : std::false_type {};
52
53template <typename T, typename S, typename... Args>
54struct is_one_of<T, S, Args...> {
55 enum { value = std::is_same_v<T, S> || is_one_of<T, Args...>::value };
56};
57
58// helper to see if T is std::vector of something.
59template <typename>
60struct is_vector : std::false_type {};
61
62template <typename T>
63struct is_vector<std::vector<T>> : std::true_type {};
64
65// helper for static_assert(false)
66template <typename T>
67struct unsupported_type : std::false_type {};
68
Andrei Onea8714b022019-02-01 18:55:54 +000069namespace android {
70namespace aidl {
71namespace mappings {
72std::string dump_location(const AidlNode& method);
73} // namespace mappings
Mathew Inwoodadb74672019-11-29 14:01:53 +000074namespace java {
75std::string dump_location(const AidlNode& method);
76} // namespace java
Andrei Onea8714b022019-02-01 18:55:54 +000077} // namespace aidl
78} // namespace android
79
Jooyung Han535c5e82020-12-29 15:16:59 +090080bool ParseFloating(std::string_view sv, double* parsed);
81bool ParseFloating(std::string_view sv, float* parsed);
Steven Moreland46e9da82018-07-27 15:45:29 -070082
Jooyung Han808a2a02020-12-28 16:46:54 +090083class AidlDocument;
Jooyung Han132cf802021-01-15 02:17:32 +090084class AidlPackage;
Jooyung Hanc5688f72021-01-05 15:41:48 +090085class AidlImport;
Jooyung Han808a2a02020-12-28 16:46:54 +090086class AidlInterface;
87class AidlParcelable;
88class AidlStructuredParcelable;
89class AidlEnumDeclaration;
90class AidlUnionDecl;
91class AidlVariableDeclaration;
92class AidlConstantDeclaration;
93class AidlEnumerator;
94class AidlMethod;
95class AidlArgument;
Jooyung Hanc5688f72021-01-05 15:41:48 +090096class AidlConstantValue;
97class AidlConstantReference;
98class AidlUnaryConstExpression;
99class AidlBinaryConstExpression;
100class AidlAnnotation;
Jooyung Han808a2a02020-12-28 16:46:54 +0900101
Jiyong Park45854452020-12-31 10:42:28 +0900102// Interface for visitors that can traverse AidlTraversable nodes.
Jooyung Han808a2a02020-12-28 16:46:54 +0900103class AidlVisitor {
104 public:
105 virtual ~AidlVisitor() = default;
Jiyong Park45854452020-12-31 10:42:28 +0900106 virtual void Visit(const AidlDocument&) {}
107 virtual void Visit(const AidlInterface&) {}
108 virtual void Visit(const AidlParcelable&) {}
109 virtual void Visit(const AidlStructuredParcelable&) {}
110 virtual void Visit(const AidlUnionDecl&) {}
111 virtual void Visit(const AidlEnumDeclaration&) {}
112 virtual void Visit(const AidlEnumerator&) {}
113 virtual void Visit(const AidlMethod&) {}
114 virtual void Visit(const AidlVariableDeclaration&) {}
115 virtual void Visit(const AidlConstantDeclaration&) {}
116 virtual void Visit(const AidlArgument&) {}
Jooyung Han865da492021-01-03 11:32:47 +0900117 virtual void Visit(const AidlTypeSpecifier&) {}
Jooyung Hanc5688f72021-01-05 15:41:48 +0900118 virtual void Visit(const AidlConstantValue&) {}
119 virtual void Visit(const AidlConstantReference&) {}
120 virtual void Visit(const AidlUnaryConstExpression&) {}
121 virtual void Visit(const AidlBinaryConstExpression&) {}
122 virtual void Visit(const AidlAnnotation&) {}
123 virtual void Visit(const AidlImport&) {}
Jooyung Han132cf802021-01-15 02:17:32 +0900124 virtual void Visit(const AidlPackage&) {}
Jooyung Han808a2a02020-12-28 16:46:54 +0900125};
126
Jooyung Han13f1fa52021-06-11 18:06:12 +0900127class AidlScope {
128 public:
Jooyung Han35784982021-06-29 06:26:12 +0900129 AidlScope(const AidlNode* self) : self_(self) {}
Jooyung Han13f1fa52021-06-11 18:06:12 +0900130 virtual ~AidlScope() = default;
131 virtual std::string ResolveName(const std::string& name) const = 0;
132 void SetEnclosingScope(const AidlScope* enclosing) {
133 AIDL_FATAL_IF(enclosing_, AIDL_LOCATION_HERE) << "SetEnclosingScope can be set only once.";
134 enclosing_ = enclosing;
135 }
136 const AidlScope* GetEnclosingScope() const { return enclosing_; }
Jooyung Han35784982021-06-29 06:26:12 +0900137 const AidlNode& GetNode() const { return *self_; }
Jooyung Han13f1fa52021-06-11 18:06:12 +0900138
139 private:
Jooyung Han35784982021-06-29 06:26:12 +0900140 const AidlNode* self_;
Jooyung Han13f1fa52021-06-11 18:06:12 +0900141 const AidlScope* enclosing_ = nullptr;
142};
143
Steven Moreland46e9da82018-07-27 15:45:29 -0700144// Anything that is locatable in a .aidl file.
145class AidlNode {
146 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900147 AidlNode(const AidlLocation& location, const Comments& comments = {});
Steven Moreland3f658cf2018-08-20 13:40:54 -0700148
149 AidlNode(const AidlNode&) = default;
Steven Moreland46e9da82018-07-27 15:45:29 -0700150 virtual ~AidlNode() = default;
151
Jiyong Parkd800fef2020-07-22 18:09:43 +0900152 AidlNode(AidlNode&&) = delete;
153 AidlNode& operator=(AidlNode&&) = delete;
154
Devin Mooredf93ebb2020-03-25 14:03:35 -0700155 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700156 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000157 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000158 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700159
Devin Mooredf93ebb2020-03-25 14:03:35 -0700160 const AidlLocation& GetLocation() const { return location_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900161 virtual void TraverseChildren(std::function<void(const AidlNode&)> traverse) const = 0;
162 virtual void DispatchVisit(AidlVisitor&) const = 0;
Devin Mooredf93ebb2020-03-25 14:03:35 -0700163
Jooyung Han8451a202021-01-16 03:07:06 +0900164 const Comments& GetComments() const { return comments_; }
165 void SetComments(const Comments& comments) { comments_ = comments; }
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900166
Steven Moreland46e9da82018-07-27 15:45:29 -0700167 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000168 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000169 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700170 const AidlLocation location_;
Jooyung Han8451a202021-01-16 03:07:06 +0900171 Comments comments_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700172};
173
Jeongik Chadf76dc72019-11-28 00:08:47 +0900174// unique_ptr<AidlTypeSpecifier> for type arugment,
175// std::string for type parameter(T, U, and so on).
176template <typename T>
177class AidlParameterizable {
178 public:
179 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
180 virtual ~AidlParameterizable() = default;
181 bool IsGeneric() const { return type_params_ != nullptr; }
182 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
183 bool CheckValid() const;
184
Steven Moreland6c07b832020-10-29 23:39:53 +0000185 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
186 if (type_params_) return false;
187 type_params_.reset(type_params);
188 return true;
189 }
190
Jeongik Chadf76dc72019-11-28 00:08:47 +0900191 virtual const AidlNode& AsAidlNode() const = 0;
192
193 protected:
194 AidlParameterizable(const AidlParameterizable&);
195
196 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000197 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900198 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
199 std::is_same<T, std::string>::value);
200};
201template <>
202bool AidlParameterizable<std::string>::CheckValid() const;
203
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900204class AidlCommentable : public AidlNode {
Jooyung Han6736ffb2021-01-16 10:13:40 +0900205 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900206 AidlCommentable(const AidlLocation& location, const Comments& comments)
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900207 : AidlNode(location, comments) {}
Jooyung Han6736ffb2021-01-16 10:13:40 +0900208 virtual ~AidlCommentable() = default;
209
Jooyung Han6736ffb2021-01-16 10:13:40 +0900210 bool IsHidden() const;
211 bool IsDeprecated() const;
Jooyung Han6736ffb2021-01-16 10:13:40 +0900212};
Andrei Onea9445fc62019-06-27 18:11:59 +0100213
214// Transforms a value string into a language specific form. Raw value as produced by
215// AidlConstantValue.
216using ConstantValueDecorator =
217 std::function<std::string(const AidlTypeSpecifier& type, const std::string& raw_value)>;
218
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900219class AidlAnnotation : public AidlNode {
Jiyong Park68bc77a2018-07-19 19:00:45 +0900220 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700221 enum class Type {
222 BACKING = 1,
223 HIDE,
224 JAVA_STABLE_PARCELABLE,
225 UNSUPPORTED_APP_USAGE,
226 VINTF_STABILITY,
227 NULLABLE,
228 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000229 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900230 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900231 JAVA_DERIVE,
Jeongik Chad0a10272020-08-06 16:33:36 +0900232 JAVA_ONLY_IMMUTABLE,
Devin Moorec7e47a32020-08-07 10:55:25 -0700233 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900234 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700235 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900236 SUPPRESS_WARNINGS,
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +0200237 ENFORCE,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700238 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900239
240 using TargetContext = uint16_t;
241 static constexpr TargetContext CONTEXT_TYPE_INTERFACE = 0x1 << 0;
242 static constexpr TargetContext CONTEXT_TYPE_ENUM = 0x1 << 1;
243 static constexpr TargetContext CONTEXT_TYPE_STRUCTURED_PARCELABLE = 0x1 << 2;
244 static constexpr TargetContext CONTEXT_TYPE_UNION = 0x1 << 3;
245 static constexpr TargetContext CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE = 0x1 << 4;
246 static constexpr TargetContext CONTEXT_TYPE =
247 CONTEXT_TYPE_INTERFACE | CONTEXT_TYPE_ENUM | CONTEXT_TYPE_STRUCTURED_PARCELABLE |
248 CONTEXT_TYPE_UNION | CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE;
249 static constexpr TargetContext CONTEXT_CONST = 0x1 << 5;
250 static constexpr TargetContext CONTEXT_FIELD = 0x1 << 6;
251 static constexpr TargetContext CONTEXT_METHOD = 0x1 << 7;
252 static constexpr TargetContext CONTEXT_MEMBER = CONTEXT_CONST | CONTEXT_FIELD | CONTEXT_METHOD;
253 static constexpr TargetContext CONTEXT_TYPE_SPECIFIER = 0x1 << 8;
254 static constexpr TargetContext CONTEXT_ALL =
255 CONTEXT_TYPE | CONTEXT_MEMBER | CONTEXT_TYPE_SPECIFIER;
256
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700257 static std::string TypeToString(Type type);
258
Jooyung Han442cacf2021-09-13 17:44:56 +0900259 static std::unique_ptr<AidlAnnotation> Parse(
Andrei Onea9445fc62019-06-27 18:11:59 +0100260 const AidlLocation& location, const string& name,
Jooyung Han442cacf2021-09-13 17:44:56 +0900261 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameter_list,
Jooyung Han8451a202021-01-16 03:07:06 +0900262 const Comments& comments);
Steven Moreland46e9da82018-07-27 15:45:29 -0700263
Steven Moreland3f658cf2018-08-20 13:40:54 -0700264 AidlAnnotation(const AidlAnnotation&) = default;
Steven Moreland3be75772018-08-20 13:27:43 -0700265 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900266 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100267 bool CheckValid() const;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900268 bool CheckContext(TargetContext context) const;
Jooyung Hand902a972020-10-23 17:32:44 +0900269 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700270 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900271 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900272
273 // ToString is for dumping AIDL.
274 // Returns string representation of this annotation.
275 // e.g) "@RustDerive(Clone=true, Copy=true)"
276 string ToString() const;
277
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900278 template <typename T>
279 std::optional<T> ParamValue(const std::string& param_name) const;
280
Andrei Onea9445fc62019-06-27 18:11:59 +0100281 std::map<std::string, std::string> AnnotationParams(
282 const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900283 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
284 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900285
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +0200286 Result<unique_ptr<perm::Expression>> EnforceExpression() const;
287
Jiyong Park68bc77a2018-07-19 19:00:45 +0900288 private:
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900289 struct ParamType {
290 std::string name;
291 const AidlTypeSpecifier& type;
292 bool required = false;
293 };
294
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700295 struct Schema {
296 AidlAnnotation::Type type;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700297 std::string name;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900298 TargetContext target_context;
299 std::vector<ParamType> parameters;
300 bool repeatable = false;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700301
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900302 const ParamType* ParamType(const std::string& name) const {
303 for (const auto& param : parameters) {
304 if (param.name == name) {
305 return &param;
306 }
307 }
308 return nullptr;
309 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700310 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900311
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700312 static const std::vector<Schema>& AllSchemas();
313
314 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Jooyung Han442cacf2021-09-13 17:44:56 +0900315 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters,
Jooyung Han8451a202021-01-16 03:07:06 +0900316 const Comments& comments);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700317
318 const Schema& schema_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100319 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900320};
321
Steven Moreland3be75772018-08-20 13:27:43 -0700322static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
323 return lhs.GetName() < rhs.GetName();
324}
325static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
326 return lhs.GetName() == rhs.GetName();
327}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900328
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900329class AidlAnnotatable : public AidlCommentable {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700330 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900331 AidlAnnotatable(const AidlLocation& location, const Comments& comments);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700332
333 AidlAnnotatable(const AidlAnnotatable&) = default;
334 AidlAnnotatable(AidlAnnotatable&&) = default;
Casey Dahline7922932016-02-29 17:23:01 -0800335 virtual ~AidlAnnotatable() = default;
336
Artur Satayev91fe8712019-07-29 13:06:01 +0100337 void Annotate(vector<AidlAnnotation>&& annotations) {
338 for (auto& annotation : annotations) {
339 annotations_.emplace_back(std::move(annotation));
340 }
341 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900342 bool IsNullable() const;
Jooyung Han01720ed2021-08-13 07:46:07 +0900343 bool IsHeapNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900344 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000345 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700346 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900347 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700348 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900349 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800350 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900351 bool JavaDerive(const std::string& method) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900352 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100353
354 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700355 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900356 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900357 std::vector<std::string> SuppressWarnings() const;
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +0200358 std::unique_ptr<perm::Expression> EnforceExpression(const AidlNode&) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900359
360 // ToString is for dumping AIDL.
361 // Returns string representation of annotations.
362 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900363 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800364
Jiyong Parka6605ab2018-11-11 14:30:21 +0900365 const vector<AidlAnnotation>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900366 bool CheckValid(const AidlTypenames&) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900367 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
368 for (const auto& annot : GetAnnotations()) {
369 traverse(annot);
370 }
371 }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900372
Casey Dahline7922932016-02-29 17:23:01 -0800373 private:
Jiyong Parka6605ab2018-11-11 14:30:21 +0900374 vector<AidlAnnotation> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800375};
376
Jiyong Park1deecc32018-07-17 01:14:41 +0900377// AidlTypeSpecifier represents a reference to either a built-in type,
378// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900379class AidlTypeSpecifier final : public AidlAnnotatable,
380 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800381 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700382 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name, bool is_array,
Jooyung Han8451a202021-01-16 03:07:06 +0900383 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const Comments& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900384 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700385
Steven Moreland3f658cf2018-08-20 13:40:54 -0700386 // Copy of this type which is not an array.
Jooyung Hand2fa0232020-10-19 02:51:41 +0900387 const AidlTypeSpecifier& ArrayBase() const;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700388
Jiyong Park1deecc32018-07-17 01:14:41 +0900389 // Returns the full-qualified name of the base type.
390 // int -> int
391 // int[] -> int
392 // List<String> -> List
393 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
394 const string& GetName() const {
395 if (IsResolved()) {
396 return fully_qualified_name_;
397 } else {
398 return GetUnresolvedName();
399 }
400 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700401
Jooyung Han965e31d2020-11-27 12:30:16 +0900402 // ToString is for dumping AIDL.
403 // Returns string representation of this type specifier including annotations.
404 // This is "annotations type_name type_params? array_marker?".
405 // e.g) "@utf8InCpp String[]";
406 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900407
Jooyung Han965e31d2020-11-27 12:30:16 +0900408 // Signature is for comparing AIDL types.
409 // Returns string representation of this type specifier.
410 // This is "type_name type_params? array_marker?".
411 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900412 std::string Signature() const;
413
Jiyong Park1deecc32018-07-17 01:14:41 +0900414 const string& GetUnresolvedName() const { return unresolved_name_; }
415
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900416 const std::vector<std::string> GetSplitName() const { return split_name_; }
417
Jiyong Park1deecc32018-07-17 01:14:41 +0900418 bool IsResolved() const { return fully_qualified_name_ != ""; }
419
420 bool IsArray() const { return is_array_; }
421
Steven Moreland6c07b832020-10-29 23:39:53 +0000422 __attribute__((warn_unused_result)) bool SetArray() {
423 if (is_array_) return false;
424 is_array_ = true;
425 return true;
426 }
427
Jiyong Park1deecc32018-07-17 01:14:41 +0900428 // Resolve the base type name to a fully-qualified name. Return false if the
429 // resolution fails.
Jooyung Han13f1fa52021-06-11 18:06:12 +0900430 bool Resolve(const AidlTypenames& typenames, const AidlScope* scope);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700431
Jooyung Han888c5bc2020-12-22 17:28:47 +0900432 bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700433 bool LanguageSpecificCheckValid(const AidlTypenames& typenames, Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900434 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900435
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900436 const AidlDefinedType* GetDefinedType() const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900437 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
438 AidlAnnotatable::TraverseChildren(traverse);
Jooyung Han865da492021-01-03 11:32:47 +0900439 if (IsGeneric()) {
440 for (const auto& tp : GetTypeParameters()) {
441 traverse(*tp);
442 }
443 }
444 }
445 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900446
Casey Dahlin0ee37582015-09-30 16:31:55 -0700447 private:
Steven Moreland3f658cf2018-08-20 13:40:54 -0700448 AidlTypeSpecifier(const AidlTypeSpecifier&) = default;
449
Jiyong Park1deecc32018-07-17 01:14:41 +0900450 const string unresolved_name_;
451 string fully_qualified_name_;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700452 bool is_array_;
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900453 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900454 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Jooyung Hand2fa0232020-10-19 02:51:41 +0900455 mutable shared_ptr<AidlTypeSpecifier> array_base_;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700456};
457
Steven Moreland860b1942018-08-16 14:59:28 -0700458// Returns the universal value unaltered.
459std::string AidlConstantValueDecorator(const AidlTypeSpecifier& type, const std::string& raw_value);
460
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900461class AidlMember : public AidlCommentable {
Jooyung Han8aeef8c2021-01-11 12:16:19 +0900462 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900463 AidlMember(const AidlLocation& location, const Comments& comments);
Jooyung Han3f347ca2020-12-01 12:41:50 +0900464 virtual ~AidlMember() = default;
465
466 // non-copyable, non-movable
467 AidlMember(const AidlMember&) = delete;
468 AidlMember(AidlMember&&) = delete;
469 AidlMember& operator=(const AidlMember&) = delete;
470 AidlMember& operator=(AidlMember&&) = delete;
471
Jooyung Han829ec7c2020-12-02 12:07:36 +0900472 virtual const AidlMethod* AsMethod() const { return nullptr; }
473 virtual const AidlConstantDeclaration* AsConstantDeclaration() const { return nullptr; }
474 virtual const AidlVariableDeclaration* AsVariableDeclaration() const { return nullptr; }
475
476 AidlMethod* AsMethod() {
477 return const_cast<AidlMethod*>(const_cast<const AidlMember*>(this)->AsMethod());
478 }
479 AidlConstantDeclaration* AsConstantDeclaration() {
480 return const_cast<AidlConstantDeclaration*>(
481 const_cast<const AidlMember*>(this)->AsConstantDeclaration());
482 }
483 AidlVariableDeclaration* AsVariableDeclaration() {
484 return const_cast<AidlVariableDeclaration*>(
485 const_cast<const AidlMember*>(this)->AsVariableDeclaration());
486 }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900487};
488
Steven Moreland541788d2020-05-21 22:05:52 +0000489// TODO: This class is used for method arguments and also parcelable fields,
490// and it should be split up since default values don't apply to method
491// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900492class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700493 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700494 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
495 const std::string& name);
496 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
497 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700498 virtual ~AidlVariableDeclaration() = default;
499
Jiyong Parkd800fef2020-07-22 18:09:43 +0900500 // non-copyable, non-movable
501 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
502 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
503 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
504 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
505
Jooyung Han829ec7c2020-12-02 12:07:36 +0900506 const AidlVariableDeclaration* AsVariableDeclaration() const override { return this; }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900507
Steven Moreland5557f1c2018-07-02 13:50:23 -0700508 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900509 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900510 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000511 // if this was constructed explicitly with a default value
512 bool IsDefaultUserSpecified() const { return default_user_specified_; }
513 // will return the default value this is constructed with or a default value
514 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700515 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900516 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700517
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900518 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700519
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900520 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900521
522 // ToString is for dumping AIDL.
523 // Returns string representation of this variable decl including default value.
524 // This is "annotations type name default_value?".
525 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700526 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900527
528 // Signature is for comparing AIDL types.
529 // Returns string representation of this variable decl.
530 // This is "type name".
531 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900532 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700533
Steven Moreland860b1942018-08-16 14:59:28 -0700534 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700535
Jooyung Hanc5688f72021-01-05 15:41:48 +0900536 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jiyong Park45854452020-12-31 10:42:28 +0900537 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900538
Steven Moreland5557f1c2018-07-02 13:50:23 -0700539 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900540 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700541 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000542 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700543 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700544};
545
546class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700547 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700548 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
549
Steven Moreland46e9da82018-07-27 15:45:29 -0700550 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
551 AidlTypeSpecifier* type, const std::string& name);
552 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700553 virtual ~AidlArgument() = default;
554
Jiyong Parkd800fef2020-07-22 18:09:43 +0900555 // non-copyable, non-movable
556 AidlArgument(const AidlArgument&) = delete;
557 AidlArgument(AidlArgument&&) = delete;
558 AidlArgument& operator=(const AidlArgument&) = delete;
559 AidlArgument& operator=(AidlArgument&&) = delete;
560
Casey Dahlinc378c992015-09-29 16:50:40 -0700561 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700562 bool IsOut() const { return direction_ & OUT_DIR; }
563 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700564 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900565 string GetDirectionSpecifier() const;
Jooyung Han020d8d12021-02-26 17:23:02 +0900566 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyad339272015-10-05 19:11:58 -0700567
Jooyung Han965e31d2020-11-27 12:30:16 +0900568 // ToString is for dumping AIDL.
569 // Returns string representation of this argument including direction
570 // This is "direction annotations type name".
571 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700572 std::string ToString() const;
Jiyong Park512ed852020-12-30 15:07:23 +0900573
Jooyung Hanc5688f72021-01-05 15:41:48 +0900574 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900575 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900576 }
Jiyong Park45854452020-12-31 10:42:28 +0900577 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700578
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700579 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700580 Direction direction_;
581 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700582};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800583
Jooyung Han020d8d12021-02-26 17:23:02 +0900584struct ArgumentAspect {
585 std::string name;
586 std::set<AidlArgument::Direction> possible_directions;
587};
588
Will McVickerd7d18df2019-09-12 13:40:50 -0700589class AidlUnaryConstExpression;
590class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900591class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700592
Steven Moreland693640b2018-07-19 13:46:27 -0700593class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800594 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700595 enum class Type {
596 // WARNING: Don't change this order! The order is used to determine type
597 // promotion during a binary expression.
598 BOOLEAN,
599 INT8,
600 INT32,
601 INT64,
602 ARRAY,
603 CHARACTER,
604 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900605 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700606 FLOATING,
607 UNARY,
608 BINARY,
609 ERROR,
610 };
611
Jooyung Han535c5e82020-12-29 15:16:59 +0900612 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700613 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900614 T EvaluatedValue() const {
615 is_evaluated_ || (CheckValid() && evaluate());
616 AIDL_FATAL_IF(!is_valid_, this);
617
618 if constexpr (is_vector<T>::value) {
619 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
620 T result;
621 for (const auto& v : values_) {
622 result.push_back(v->EvaluatedValue<typename T::value_type>());
623 }
624 return result;
625 } else if constexpr (is_one_of<T, float, double>::value) {
626 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
627 T result;
628 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
629 return result;
630 } else if constexpr (std::is_same<T, std::string>::value) {
631 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
632 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
633 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
634 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
635 return static_cast<T>(final_value_);
636 } else if constexpr (std::is_same<T, char>::value) {
637 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
638 return final_string_value_.at(1); // unquote '
639 } else if constexpr (std::is_same<T, bool>::value) {
640 static_assert(std::is_same<T, bool>::value, "..");
641 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
642 return final_value_ != 0;
643 } else {
644 static_assert(unsupported_type<T>::value);
645 }
646 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800647
Steven Moreland693640b2018-07-19 13:46:27 -0700648 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800649
Jiyong Parkd800fef2020-07-22 18:09:43 +0900650 // non-copyable, non-movable
651 AidlConstantValue(const AidlConstantValue&) = delete;
652 AidlConstantValue(AidlConstantValue&&) = delete;
653 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
654 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
655
Steven Moreland541788d2020-05-21 22:05:52 +0000656 // creates default value, when one isn't specified
657 // nullptr if no default available
658 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
659
Steven Moreland25294322018-08-07 18:13:55 -0700660 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
661 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700662 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700663 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
664 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700665 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700666 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700667 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700668 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700669
Will McVickerd7d18df2019-09-12 13:40:50 -0700670 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900671 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700672
Will McVickerd7d18df2019-09-12 13:40:50 -0700673 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700674
675 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800676 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900677
678 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const {
Jooyung Han29813842020-12-08 01:28:03 +0900679 if (type_ == Type::ARRAY) {
680 for (const auto& v : values_) {
Jooyung Hanc5688f72021-01-05 15:41:48 +0900681 traverse(*v);
Jooyung Han29813842020-12-08 01:28:03 +0900682 }
683 }
684 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900685 void DispatchVisit(AidlVisitor& visitor) const override { visitor.Visit(*this); }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800686
687 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700688 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
689 const string& checked_value);
690 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700691 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900692 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
693 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700694 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700695 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
696 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800697
Jooyung Han74675c22020-12-15 08:39:57 +0900698 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800699
Steven Moreland693640b2018-07-19 13:46:27 -0700700 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700701 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
702 const string value_; // otherwise
703
704 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800705 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
706 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700707 mutable Type final_type_;
708 mutable int64_t final_value_;
709 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700710
Will McVickerd7d18df2019-09-12 13:40:50 -0700711 friend AidlUnaryConstExpression;
712 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900713 friend AidlConstantReference;
714};
715
716// Represents "<type>.<field>" which resolves to a constant which is one of
717// - constant declartion
718// - enumerator
719// When a <type> is missing, <field> is of the enclosing type.
720class AidlConstantReference : public AidlConstantValue {
721 public:
Jooyung Hand0c8af02021-01-06 18:08:01 +0900722 AidlConstantReference(const AidlLocation& location, const std::string& value);
Jooyung Han690f5842020-12-04 13:02:04 +0900723
724 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900725 const std::string& GetFieldName() const { return field_name_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900726
727 bool CheckValid() const override;
Jooyung Han289a1bc2021-05-15 15:04:05 +0900728 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
729 if (ref_type_) {
730 traverse(*ref_type_);
731 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900732 }
733 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900734 const AidlConstantValue* Resolve(const AidlDefinedType* scope) const;
Jooyung Han690f5842020-12-04 13:02:04 +0900735
736 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900737 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900738
739 std::unique_ptr<AidlTypeSpecifier> ref_type_;
740 std::string field_name_;
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900741 mutable const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700742};
743
744class AidlUnaryConstExpression : public AidlConstantValue {
745 public:
746 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
747 std::unique_ptr<AidlConstantValue> rval);
748
749 static bool IsCompatibleType(Type type, const string& op);
750 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900751 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
752 traverse(*unary_);
Jooyung Han690f5842020-12-04 13:02:04 +0900753 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900754 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han690f5842020-12-04 13:02:04 +0900755
Will McVickerd7d18df2019-09-12 13:40:50 -0700756 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900757 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700758
759 std::unique_ptr<AidlConstantValue> unary_;
760 const string op_;
761};
762
763class AidlBinaryConstExpression : public AidlConstantValue {
764 public:
765 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
766 const string& op, std::unique_ptr<AidlConstantValue> rval);
767
768 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700769
770 static bool AreCompatibleTypes(Type t1, Type t2);
771 // Returns the promoted kind for both operands
772 static Type UsualArithmeticConversion(Type left, Type right);
773 // Returns the promoted integral type where INT32 is the smallest type
774 static Type IntegralPromotion(Type in);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900775 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
776 traverse(*left_val_);
777 traverse(*right_val_);
Jooyung Han690f5842020-12-04 13:02:04 +0900778 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900779 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700780
781 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900782 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700783
784 std::unique_ptr<AidlConstantValue> left_val_;
785 std::unique_ptr<AidlConstantValue> right_val_;
786 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700787};
788
Andrei Onea9445fc62019-06-27 18:11:59 +0100789struct AidlAnnotationParameter {
790 std::string name;
791 std::unique_ptr<AidlConstantValue> value;
792};
793
Steven Moreland693640b2018-07-19 13:46:27 -0700794class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700795 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700796 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700797 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700798 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700799
Jiyong Parkd800fef2020-07-22 18:09:43 +0900800 // non-copyable, non-movable
801 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
802 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
803 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
804 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
805
Steven Moreland693640b2018-07-19 13:46:27 -0700806 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700807 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700808 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700809 const AidlConstantValue& GetValue() const { return *value_; }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900810 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700811
Jooyung Han965e31d2020-11-27 12:30:16 +0900812 // ToString is for dumping AIDL.
813 // Returns string representation of this const decl including a const value.
814 // This is "`const` annotations type name value".
815 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700816 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900817
818 // Signature is for comparing types.
819 // Returns string representation of this const decl.
820 // This is "direction annotations type name".
821 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700822 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900823
Steven Moreland860b1942018-08-16 14:59:28 -0700824 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700825 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700826 }
Steven Moreland25294322018-08-07 18:13:55 -0700827
Jooyung Han829ec7c2020-12-02 12:07:36 +0900828 const AidlConstantDeclaration* AsConstantDeclaration() const override { return this; }
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700829
Jooyung Hanc5688f72021-01-05 15:41:48 +0900830 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900831 traverse(GetType());
Jooyung Hanc5688f72021-01-05 15:41:48 +0900832 traverse(GetValue());
Jiyong Park512ed852020-12-30 15:07:23 +0900833 }
Jiyong Park45854452020-12-31 10:42:28 +0900834 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900835
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700836 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700837 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700838 const string name_;
839 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800840};
841
842class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700843 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700844 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900845 vector<unique_ptr<AidlArgument>>* args, const Comments& comments);
Will McVickerd7d18df2019-09-12 13:40:50 -0700846 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900847 vector<unique_ptr<AidlArgument>>* args, const Comments& comments, int id,
Will McVickerd7d18df2019-09-12 13:40:50 -0700848 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700849 virtual ~AidlMethod() = default;
850
Jiyong Parkd800fef2020-07-22 18:09:43 +0900851 // non-copyable, non-movable
852 AidlMethod(const AidlMethod&) = delete;
853 AidlMethod(AidlMethod&&) = delete;
854 AidlMethod& operator=(const AidlMethod&) = delete;
855 AidlMethod& operator=(AidlMethod&&) = delete;
856
Jooyung Han829ec7c2020-12-02 12:07:36 +0900857 const AidlMethod* AsMethod() const override { return this; }
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900858 const AidlTypeSpecifier& GetType() const { return *type_; }
859 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800860
Steven Moreland8c70ba92018-12-17 10:20:31 -0800861 // set if this method is part of an interface that is marked oneway
862 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700863 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800864
Casey Dahlinf4a93112015-10-05 16:58:09 -0700865 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700866 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900867 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700868 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700869
Jiyong Park309668e2018-07-28 16:55:44 +0900870 bool IsUserDefined() const { return is_user_defined_; }
871
Casey Dahlinf4a93112015-10-05 16:58:09 -0700872 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700873 return arguments_;
874 }
875 // An inout parameter will appear in both GetInArguments()
876 // and GetOutArguments(). AidlMethod retains ownership of the argument
877 // pointers returned in this way.
878 const std::vector<const AidlArgument*>& GetInArguments() const {
879 return in_arguments_;
880 }
881 const std::vector<const AidlArgument*>& GetOutArguments() const {
882 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700883 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700884
Jooyung Han965e31d2020-11-27 12:30:16 +0900885 // ToString is for dumping AIDL.
886 // Returns string representation of this method including everything.
887 // This is "ret_type name ( arg_list ) = id".
888 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900889 std::string ToString() const;
890
Jooyung Han965e31d2020-11-27 12:30:16 +0900891 // Signature is for comparing AIDL types.
892 // Returns string representation of this method's name & type.
893 // e.g) "foo(int, String)"
894 std::string Signature() const;
895
Jooyung Hanc5688f72021-01-05 15:41:48 +0900896 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900897 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900898 for (const auto& a : GetArguments()) {
899 traverse(*a);
900 }
901 }
Jiyong Park45854452020-12-31 10:42:28 +0900902 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han808a2a02020-12-28 16:46:54 +0900903
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700904 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700905 bool oneway_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900906 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700907 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700908 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
909 std::vector<const AidlArgument*> in_arguments_;
910 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700911 bool has_id_;
912 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900913 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700914};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800915
Daniel Norman85aed542019-08-21 12:01:14 -0700916// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900917// defined in the source file.
Jooyung Han13f1fa52021-06-11 18:06:12 +0900918class AidlDefinedType : public AidlAnnotatable, public AidlScope {
Steven Moreland787b0432018-07-03 09:00:58 -0700919 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900920 AidlDefinedType(const AidlLocation& location, const std::string& name, const Comments& comments,
921 const std::string& package, std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700922 virtual ~AidlDefinedType() = default;
923
Jiyong Parkd800fef2020-07-22 18:09:43 +0900924 // non-copyable, non-movable
925 AidlDefinedType(const AidlDefinedType&) = delete;
926 AidlDefinedType(AidlDefinedType&&) = delete;
927 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
928 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
929
Jiyong Park1deecc32018-07-17 01:14:41 +0900930 const std::string& GetName() const { return name_; };
Jiyong Park1deecc32018-07-17 01:14:41 +0900931
Jooyung Han13f1fa52021-06-11 18:06:12 +0900932 std::string ResolveName(const std::string& name) const override;
933
Steven Moreland787b0432018-07-03 09:00:58 -0700934 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900935 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700936 /* dot joined package and name, example: "android.package.foo.IBar" */
937 std::string GetCanonicalName() const;
Jooyung Han93f48f02021-06-05 00:11:16 +0900938 std::vector<std::string> GetSplitPackage() const {
939 if (package_.empty()) return std::vector<std::string>();
940 return android::base::Split(package_, ".");
941 }
Jooyung Han35784982021-06-29 06:26:12 +0900942 const AidlDocument& GetDocument() const;
Steven Moreland787b0432018-07-03 09:00:58 -0700943
Steven Morelanded83a282018-07-17 13:27:29 -0700944 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700945
Steven Moreland5557f1c2018-07-02 13:50:23 -0700946 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700947 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700948 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900949 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700950 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900951 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900952 virtual bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700953 virtual bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
954 Options::Language lang) const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700955 AidlStructuredParcelable* AsStructuredParcelable() {
956 return const_cast<AidlStructuredParcelable*>(
957 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
958 }
959 AidlParcelable* AsParcelable() {
960 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
961 }
Daniel Norman85aed542019-08-21 12:01:14 -0700962 AidlEnumDeclaration* AsEnumDeclaration() {
963 return const_cast<AidlEnumDeclaration*>(
964 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
965 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900966 AidlUnionDecl* AsUnionDeclaration() {
967 return const_cast<AidlUnionDecl*>(
968 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
969 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700970 AidlInterface* AsInterface() {
971 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
972 }
973
Jeongik Chadf76dc72019-11-28 00:08:47 +0900974 AidlParameterizable<std::string>* AsParameterizable() {
975 return const_cast<AidlParameterizable<std::string>*>(
976 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
977 }
978
Steven Moreland6cee3482018-07-18 14:39:58 -0700979 const AidlParcelable* AsUnstructuredParcelable() const {
980 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900981 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700982 return this->AsParcelable();
983 }
984 AidlParcelable* AsUnstructuredParcelable() {
985 return const_cast<AidlParcelable*>(
986 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
987 }
988
Jooyung Han829ec7c2020-12-02 12:07:36 +0900989 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
990 return variables_;
991 }
992 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
993 return constants_;
994 }
995 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
996 void AddMethod(std::unique_ptr<AidlMethod> method) { methods_.push_back(std::move(method)); }
997 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900998 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
999 AidlAnnotatable::TraverseChildren(traverse);
1000 for (const auto c : GetMembers()) {
1001 traverse(*c);
1002 }
1003 }
Jiyong Park512ed852020-12-30 15:07:23 +09001004
Jooyung Han829ec7c2020-12-02 12:07:36 +09001005 protected:
1006 // utility for subclasses with getter names
1007 bool CheckValidForGetterNames() const;
1008
Steven Moreland787b0432018-07-03 09:00:58 -07001009 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +09001010 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
1011
Jiyong Park1deecc32018-07-17 01:14:41 +09001012 std::string name_;
Jooyung Han93f48f02021-06-05 00:11:16 +09001013 std::string package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +09001014 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
1015 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
1016 std::vector<std::unique_ptr<AidlMethod>> methods_;
1017 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -07001018};
1019
Jeongik Chadf76dc72019-11-28 00:08:47 +09001020class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001021 public:
Jiyong Park18132182020-06-08 20:24:40 +09001022 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001023 const Comments& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +09001024 std::vector<std::string>* type_params = nullptr,
1025 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001026 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -08001027
Jiyong Parkd800fef2020-07-22 18:09:43 +09001028 // non-copyable, non-movable
1029 AidlParcelable(const AidlParcelable&) = delete;
1030 AidlParcelable(AidlParcelable&&) = delete;
1031 AidlParcelable& operator=(const AidlParcelable&) = delete;
1032 AidlParcelable& operator=(AidlParcelable&&) = delete;
1033
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001034 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001035
Jooyung Han808a2a02020-12-28 16:46:54 +09001036 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001037 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1038 Options::Language lang) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -07001039 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +09001040 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
1041 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001042 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -07001043
Jiyong Park45854452020-12-31 10:42:28 +09001044 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001045
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001046 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001047 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001048};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001049
Jooyung Han829ec7c2020-12-02 12:07:36 +09001050class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -07001051 public:
Jiyong Park18132182020-06-08 20:24:40 +09001052 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
Jooyung Han8451a202021-01-16 03:07:06 +09001053 const std::string& package, const Comments& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001054 std::vector<std::string>* type_params,
1055 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001056 virtual ~AidlStructuredParcelable() = default;
1057
1058 // non-copyable, non-movable
1059 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
1060 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
1061 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
1062 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001063
Steven Morelandc258abc2018-07-10 14:03:38 -07001064 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001065 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001066
Jooyung Han808a2a02020-12-28 16:46:54 +09001067 bool CheckValid(const AidlTypenames& typenames) const override;
Jiyong Park45854452020-12-31 10:42:28 +09001068 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001069};
1070
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001071class AidlEnumerator : public AidlCommentable {
Daniel Norman85aed542019-08-21 12:01:14 -07001072 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001073 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
Jooyung Han8451a202021-01-16 03:07:06 +09001074 const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001075 virtual ~AidlEnumerator() = default;
1076
Jiyong Parkd800fef2020-07-22 18:09:43 +09001077 // non-copyable, non-movable
1078 AidlEnumerator(const AidlEnumerator&) = delete;
1079 AidlEnumerator(AidlEnumerator&&) = delete;
1080 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1081 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1082
Daniel Norman85aed542019-08-21 12:01:14 -07001083 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001084 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman85aed542019-08-21 12:01:14 -07001085 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1086
1087 string ValueString(const AidlTypeSpecifier& backing_type,
1088 const ConstantValueDecorator& decorator) const;
1089
Daniel Normanb28684e2019-10-17 15:31:39 -07001090 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001091 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001092
Jooyung Hanc5688f72021-01-05 15:41:48 +09001093 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1094 traverse(*value_);
Jiyong Park512ed852020-12-30 15:07:23 +09001095 }
Jiyong Park45854452020-12-31 10:42:28 +09001096 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001097
Daniel Norman85aed542019-08-21 12:01:14 -07001098 private:
1099 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001100 unique_ptr<AidlConstantValue> value_;
Jooyung Han29813842020-12-08 01:28:03 +09001101 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001102};
1103
1104class AidlEnumDeclaration : public AidlDefinedType {
1105 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001106 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001107 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jooyung Han8451a202021-01-16 03:07:06 +09001108 const std::string& package, const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001109 virtual ~AidlEnumDeclaration() = default;
1110
Jiyong Parkd800fef2020-07-22 18:09:43 +09001111 // non-copyable, non-movable
1112 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1113 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1114 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1115 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1116
Jooyung Han672557b2020-12-24 05:18:00 +09001117 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001118 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1119 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1120 return enumerators_;
1121 }
Jooyung Han808a2a02020-12-28 16:46:54 +09001122 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001123 bool LanguageSpecificCheckValid(const AidlTypenames& /*typenames*/,
1124 Options::Language) const override {
1125 return true;
1126 }
Daniel Norman85aed542019-08-21 12:01:14 -07001127 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Daniel Norman85aed542019-08-21 12:01:14 -07001128
1129 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1130
Jooyung Hanc5688f72021-01-05 15:41:48 +09001131 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1132 AidlDefinedType::TraverseChildren(traverse);
Jiyong Park512ed852020-12-30 15:07:23 +09001133 for (const auto& c : GetEnumerators()) {
1134 traverse(*c);
1135 }
1136 }
Jiyong Park45854452020-12-31 10:42:28 +09001137 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001138
Daniel Norman85aed542019-08-21 12:01:14 -07001139 private:
Jooyung Han29813842020-12-08 01:28:03 +09001140
Daniel Norman85aed542019-08-21 12:01:14 -07001141 const std::string name_;
1142 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001143 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001144};
1145
Jooyung Han829ec7c2020-12-02 12:07:36 +09001146class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001147 public:
1148 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001149 const Comments& comments, std::vector<std::string>* type_params,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001150 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001151 virtual ~AidlUnionDecl() = default;
1152
1153 // non-copyable, non-movable
1154 AidlUnionDecl(const AidlUnionDecl&) = delete;
1155 AidlUnionDecl(AidlUnionDecl&&) = delete;
1156 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1157 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1158
Jooyung Han2946afc2020-10-05 20:29:16 +09001159
1160 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001161 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001162 std::string GetPreprocessDeclarationName() const override { return "union"; }
1163
Jooyung Han2946afc2020-10-05 20:29:16 +09001164 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jiyong Park45854452020-12-31 10:42:28 +09001165 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han2946afc2020-10-05 20:29:16 +09001166};
1167
Jiyong Park1deecc32018-07-17 01:14:41 +09001168class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001169 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001170 AidlInterface(const AidlLocation& location, const std::string& name, const Comments& comments,
Jooyung Handb4d8a62021-06-22 10:09:42 +09001171 bool oneway, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001172 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001173 virtual ~AidlInterface() = default;
1174
Jiyong Parkd800fef2020-07-22 18:09:43 +09001175 // non-copyable, non-movable
1176 AidlInterface(const AidlInterface&) = delete;
1177 AidlInterface(AidlInterface&&) = delete;
1178 AidlInterface& operator=(const AidlInterface&) = delete;
1179 AidlInterface& operator=(AidlInterface&&) = delete;
1180
Steven Morelandc258abc2018-07-10 14:03:38 -07001181 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001182 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001183
Jooyung Han808a2a02020-12-28 16:46:54 +09001184 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001185 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1186 Options::Language lang) const override;
Jeongik Chadb0f59e2018-11-01 18:11:21 +09001187
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001188 std::string GetDescriptor() const;
Jiyong Park45854452020-12-31 10:42:28 +09001189 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001190};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001191
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001192class AidlPackage : public AidlNode {
Casey Dahlin0edf3422015-10-07 12:34:59 -07001193 public:
Jooyung Han93f48f02021-06-05 00:11:16 +09001194 AidlPackage(const AidlLocation& location, const std::string& name, const Comments& comments)
1195 : AidlNode(location, comments), name_(name) {}
Jooyung Han132cf802021-01-15 02:17:32 +09001196 virtual ~AidlPackage() = default;
1197 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1198 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
Jooyung Han93f48f02021-06-05 00:11:16 +09001199
1200 const std::string& GetName() const { return name_; }
1201
1202 private:
1203 std::string name_;
Jooyung Han132cf802021-01-15 02:17:32 +09001204};
1205
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001206class AidlImport : public AidlNode {
Jooyung Han132cf802021-01-15 02:17:32 +09001207 public:
1208 AidlImport(const AidlLocation& location, const std::string& needed_class,
Jooyung Han8451a202021-01-16 03:07:06 +09001209 const Comments& comments);
Casey Dahlin0edf3422015-10-07 12:34:59 -07001210 virtual ~AidlImport() = default;
1211
Jiyong Parkd800fef2020-07-22 18:09:43 +09001212 // non-copyable, non-movable
1213 AidlImport(const AidlImport&) = delete;
1214 AidlImport(AidlImport&&) = delete;
1215 AidlImport& operator=(const AidlImport&) = delete;
1216 AidlImport& operator=(AidlImport&&) = delete;
1217
Casey Dahlin0edf3422015-10-07 12:34:59 -07001218 const std::string& GetNeededClass() const { return needed_class_; }
Jooyung Hanf886f982021-06-11 09:56:04 +09001219 std::string SimpleName() const { return needed_class_.substr(needed_class_.rfind('.') + 1); }
Jooyung Hanc5688f72021-01-05 15:41:48 +09001220 void TraverseChildren(std::function<void(const AidlNode&)>) const {}
1221 void DispatchVisit(AidlVisitor& v) const { v.Visit(*this); }
Casey Dahlin0edf3422015-10-07 12:34:59 -07001222
1223 private:
Casey Dahlin0edf3422015-10-07 12:34:59 -07001224 std::string needed_class_;
Casey Dahline2507492015-09-14 17:11:20 -07001225};
1226
Jiyong Park62515512020-06-08 15:57:11 +09001227// AidlDocument models an AIDL file
Jooyung Han13f1fa52021-06-11 18:06:12 +09001228class AidlDocument : public AidlCommentable, public AidlScope {
Jiyong Park62515512020-06-08 15:57:11 +09001229 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001230 AidlDocument(const AidlLocation& location, const Comments& comments,
Jooyung Han132cf802021-01-15 02:17:32 +09001231 std::vector<std::unique_ptr<AidlImport>> imports,
Jooyung Han35784982021-06-29 06:26:12 +09001232 std::vector<std::unique_ptr<AidlDefinedType>> defined_types, bool is_preprocessed);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001233 ~AidlDocument() = default;
1234
1235 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001236 AidlDocument(const AidlDocument&) = delete;
1237 AidlDocument(AidlDocument&&) = delete;
1238 AidlDocument& operator=(const AidlDocument&) = delete;
1239 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001240
Jooyung Han13f1fa52021-06-11 18:06:12 +09001241 std::string ResolveName(const std::string& name) const override;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001242 const std::vector<std::unique_ptr<AidlImport>>& Imports() const { return imports_; }
1243 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1244 return defined_types_;
1245 }
Jooyung Han35784982021-06-29 06:26:12 +09001246 bool IsPreprocessed() const { return is_preprocessed_; }
Jiyong Park62515512020-06-08 15:57:11 +09001247
Jooyung Hanc5688f72021-01-05 15:41:48 +09001248 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1249 for (const auto& i : Imports()) {
1250 traverse(*i);
1251 }
Jiyong Park512ed852020-12-30 15:07:23 +09001252 for (const auto& t : DefinedTypes()) {
1253 traverse(*t);
1254 }
1255 }
Jiyong Park45854452020-12-31 10:42:28 +09001256 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001257
Jiyong Park62515512020-06-08 15:57:11 +09001258 private:
1259 const std::vector<std::unique_ptr<AidlImport>> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001260 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jooyung Han35784982021-06-29 06:26:12 +09001261 bool is_preprocessed_;
Jiyong Park62515512020-06-08 15:57:11 +09001262};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001263
1264template <typename T>
1265std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1266 auto it = parameters_.find(param_name);
1267 if (it == parameters_.end()) {
1268 return std::nullopt;
1269 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001270 return it->second->EvaluatedValue<T>();
Jiyong Park512ed852020-12-30 15:07:23 +09001271}
Jooyung Hanc5688f72021-01-05 15:41:48 +09001272
1273// Utility to make a visitor to visit AST tree in top-down order
1274// Given: foo
1275// / \
1276// bar baz
1277// VisitTopDown(v, foo) makes v visit foo -> bar -> baz.
1278inline void VisitTopDown(AidlVisitor& v, const AidlNode& node) {
1279 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
1280 n.DispatchVisit(v);
1281 n.TraverseChildren(top_down);
1282 };
1283 top_down(node);
Jooyung Han289a1bc2021-05-15 15:04:05 +09001284}
1285
1286// Utility to make a visitor to visit AST tree in bottom-up order
1287// Given: foo
1288// / \
1289// bar baz
1290// VisitBottomUp(v, foo) makes v visit bar -> baz -> foo.
1291inline void VisitBottomUp(AidlVisitor& v, const AidlNode& node) {
1292 std::function<void(const AidlNode&)> bottom_up = [&](const AidlNode& n) {
1293 n.TraverseChildren(bottom_up);
1294 n.DispatchVisit(v);
1295 };
1296 bottom_up(node);
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +02001297}