blob: d790e05dfd533885790112e1e4ae03945741c343 [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;
84class AidlInterface;
85class AidlParcelable;
86class AidlStructuredParcelable;
87class AidlEnumDeclaration;
88class AidlUnionDecl;
89class AidlVariableDeclaration;
90class AidlConstantDeclaration;
91class AidlEnumerator;
92class AidlMethod;
93class AidlArgument;
Jooyung Hanc5688f72021-01-05 15:41:48 +090094class AidlConstantValue;
95class AidlConstantReference;
96class AidlUnaryConstExpression;
97class AidlBinaryConstExpression;
98class AidlAnnotation;
Jooyung Han808a2a02020-12-28 16:46:54 +090099
Jiyong Park45854452020-12-31 10:42:28 +0900100// Interface for visitors that can traverse AidlTraversable nodes.
Jooyung Han808a2a02020-12-28 16:46:54 +0900101class AidlVisitor {
102 public:
103 virtual ~AidlVisitor() = default;
Jiyong Park45854452020-12-31 10:42:28 +0900104 virtual void Visit(const AidlDocument&) {}
105 virtual void Visit(const AidlInterface&) {}
106 virtual void Visit(const AidlParcelable&) {}
107 virtual void Visit(const AidlStructuredParcelable&) {}
108 virtual void Visit(const AidlUnionDecl&) {}
109 virtual void Visit(const AidlEnumDeclaration&) {}
110 virtual void Visit(const AidlEnumerator&) {}
111 virtual void Visit(const AidlMethod&) {}
112 virtual void Visit(const AidlVariableDeclaration&) {}
113 virtual void Visit(const AidlConstantDeclaration&) {}
114 virtual void Visit(const AidlArgument&) {}
Jooyung Han865da492021-01-03 11:32:47 +0900115 virtual void Visit(const AidlTypeSpecifier&) {}
Jooyung Hanc5688f72021-01-05 15:41:48 +0900116 virtual void Visit(const AidlConstantValue&) {}
117 virtual void Visit(const AidlConstantReference&) {}
118 virtual void Visit(const AidlUnaryConstExpression&) {}
119 virtual void Visit(const AidlBinaryConstExpression&) {}
120 virtual void Visit(const AidlAnnotation&) {}
Jooyung Han808a2a02020-12-28 16:46:54 +0900121};
122
Jooyung Han13f1fa52021-06-11 18:06:12 +0900123class AidlScope {
124 public:
Jooyung Han35784982021-06-29 06:26:12 +0900125 AidlScope(const AidlNode* self) : self_(self) {}
Jooyung Han13f1fa52021-06-11 18:06:12 +0900126 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_; }
Jooyung Han35784982021-06-29 06:26:12 +0900133 const AidlNode& GetNode() const { return *self_; }
Jooyung Han13f1fa52021-06-11 18:06:12 +0900134
135 private:
Jooyung Han35784982021-06-29 06:26:12 +0900136 const AidlNode* self_;
Jooyung Han13f1fa52021-06-11 18:06:12 +0900137 const AidlScope* enclosing_ = nullptr;
138};
139
Steven Moreland46e9da82018-07-27 15:45:29 -0700140// Anything that is locatable in a .aidl file.
141class AidlNode {
142 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900143 AidlNode(const AidlLocation& location, const Comments& comments = {});
Steven Moreland3f658cf2018-08-20 13:40:54 -0700144
Jooyung Han2b3cd2a2021-10-15 06:54:55 +0900145 virtual ~AidlNode();
Steven Moreland46e9da82018-07-27 15:45:29 -0700146
Steven Morelanda7560e82021-10-08 16:24:39 -0700147 AidlNode(AidlNode&) = delete;
148 AidlNode& operator=(AidlNode&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +0900149 AidlNode(AidlNode&&) = delete;
150 AidlNode& operator=(AidlNode&&) = delete;
151
Devin Mooredf93ebb2020-03-25 14:03:35 -0700152 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700153 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000154 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000155 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700156
Devin Mooredf93ebb2020-03-25 14:03:35 -0700157 const AidlLocation& GetLocation() const { return location_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900158 virtual void TraverseChildren(std::function<void(const AidlNode&)> traverse) const = 0;
159 virtual void DispatchVisit(AidlVisitor&) const = 0;
Devin Mooredf93ebb2020-03-25 14:03:35 -0700160
Jooyung Han8451a202021-01-16 03:07:06 +0900161 const Comments& GetComments() const { return comments_; }
162 void SetComments(const Comments& comments) { comments_ = comments; }
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900163
Jooyung Han2b3cd2a2021-10-15 06:54:55 +0900164 static void ClearUnvisitedNodes();
165 static const std::vector<AidlLocation>& GetLocationsOfUnvisitedNodes();
166 void MarkVisited() const;
167
Steven Moreland46e9da82018-07-27 15:45:29 -0700168 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000169 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000170 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700171 const AidlLocation location_;
Jooyung Han8451a202021-01-16 03:07:06 +0900172 Comments comments_;
Jooyung Han2b3cd2a2021-10-15 06:54:55 +0900173
174 // make sure we are able to abort if types are not visited
175 mutable bool visited_ = false;
176 static std::vector<AidlLocation> unvisited_locations_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700177};
178
Jeongik Chadf76dc72019-11-28 00:08:47 +0900179// unique_ptr<AidlTypeSpecifier> for type arugment,
180// std::string for type parameter(T, U, and so on).
181template <typename T>
182class AidlParameterizable {
183 public:
184 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
185 virtual ~AidlParameterizable() = default;
186 bool IsGeneric() const { return type_params_ != nullptr; }
187 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
188 bool CheckValid() const;
189
Steven Moreland6c07b832020-10-29 23:39:53 +0000190 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
191 if (type_params_) return false;
192 type_params_.reset(type_params);
193 return true;
194 }
195
Jeongik Chadf76dc72019-11-28 00:08:47 +0900196 virtual const AidlNode& AsAidlNode() const = 0;
197
Jeongik Chadf76dc72019-11-28 00:08:47 +0900198 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000199 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900200 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
201 std::is_same<T, std::string>::value);
202};
203template <>
204bool AidlParameterizable<std::string>::CheckValid() const;
205
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900206class AidlCommentable : public AidlNode {
Jooyung Han6736ffb2021-01-16 10:13:40 +0900207 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900208 AidlCommentable(const AidlLocation& location, const Comments& comments)
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900209 : AidlNode(location, comments) {}
Jooyung Han6736ffb2021-01-16 10:13:40 +0900210 virtual ~AidlCommentable() = default;
211
Jooyung Han6736ffb2021-01-16 10:13:40 +0900212 bool IsHidden() const;
213 bool IsDeprecated() const;
Jooyung Han6736ffb2021-01-16 10:13:40 +0900214};
Andrei Onea9445fc62019-06-27 18:11:59 +0100215
216// Transforms a value string into a language specific form. Raw value as produced by
217// AidlConstantValue.
218using ConstantValueDecorator =
219 std::function<std::string(const AidlTypeSpecifier& type, const std::string& raw_value)>;
220
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900221class AidlAnnotation : public AidlNode {
Jiyong Park68bc77a2018-07-19 19:00:45 +0900222 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700223 enum class Type {
224 BACKING = 1,
225 HIDE,
226 JAVA_STABLE_PARCELABLE,
227 UNSUPPORTED_APP_USAGE,
228 VINTF_STABILITY,
229 NULLABLE,
230 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000231 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900232 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900233 JAVA_DERIVE,
Jeongik Chad0a10272020-08-06 16:33:36 +0900234 JAVA_ONLY_IMMUTABLE,
Devin Moorec7e47a32020-08-07 10:55:25 -0700235 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900236 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700237 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900238 SUPPRESS_WARNINGS,
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +0200239 ENFORCE,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700240 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900241
242 using TargetContext = uint16_t;
243 static constexpr TargetContext CONTEXT_TYPE_INTERFACE = 0x1 << 0;
244 static constexpr TargetContext CONTEXT_TYPE_ENUM = 0x1 << 1;
245 static constexpr TargetContext CONTEXT_TYPE_STRUCTURED_PARCELABLE = 0x1 << 2;
246 static constexpr TargetContext CONTEXT_TYPE_UNION = 0x1 << 3;
247 static constexpr TargetContext CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE = 0x1 << 4;
248 static constexpr TargetContext CONTEXT_TYPE =
249 CONTEXT_TYPE_INTERFACE | CONTEXT_TYPE_ENUM | CONTEXT_TYPE_STRUCTURED_PARCELABLE |
250 CONTEXT_TYPE_UNION | CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE;
251 static constexpr TargetContext CONTEXT_CONST = 0x1 << 5;
252 static constexpr TargetContext CONTEXT_FIELD = 0x1 << 6;
253 static constexpr TargetContext CONTEXT_METHOD = 0x1 << 7;
254 static constexpr TargetContext CONTEXT_MEMBER = CONTEXT_CONST | CONTEXT_FIELD | CONTEXT_METHOD;
255 static constexpr TargetContext CONTEXT_TYPE_SPECIFIER = 0x1 << 8;
256 static constexpr TargetContext CONTEXT_ALL =
257 CONTEXT_TYPE | CONTEXT_MEMBER | CONTEXT_TYPE_SPECIFIER;
258
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700259 static std::string TypeToString(Type type);
260
Jooyung Han442cacf2021-09-13 17:44:56 +0900261 static std::unique_ptr<AidlAnnotation> Parse(
Andrei Onea9445fc62019-06-27 18:11:59 +0100262 const AidlLocation& location, const string& name,
Jooyung Han442cacf2021-09-13 17:44:56 +0900263 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameter_list,
Jooyung Han8451a202021-01-16 03:07:06 +0900264 const Comments& comments);
Steven Moreland46e9da82018-07-27 15:45:29 -0700265
Steven Moreland3be75772018-08-20 13:27:43 -0700266 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900267 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100268 bool CheckValid() const;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900269 bool CheckContext(TargetContext context) const;
Jooyung Hand902a972020-10-23 17:32:44 +0900270 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700271 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900272 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900273
274 // ToString is for dumping AIDL.
275 // Returns string representation of this annotation.
276 // e.g) "@RustDerive(Clone=true, Copy=true)"
277 string ToString() const;
278
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900279 template <typename T>
280 std::optional<T> ParamValue(const std::string& param_name) const;
281
Andrei Onea9445fc62019-06-27 18:11:59 +0100282 std::map<std::string, std::string> AnnotationParams(
283 const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900284 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
285 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900286
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +0200287 Result<unique_ptr<perm::Expression>> EnforceExpression() const;
288
Jiyong Park68bc77a2018-07-19 19:00:45 +0900289 private:
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900290 struct ParamType {
291 std::string name;
292 const AidlTypeSpecifier& type;
293 bool required = false;
294 };
295
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700296 struct Schema {
297 AidlAnnotation::Type type;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700298 std::string name;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900299 TargetContext target_context;
300 std::vector<ParamType> parameters;
301 bool repeatable = false;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700302
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900303 const ParamType* ParamType(const std::string& name) const {
304 for (const auto& param : parameters) {
305 if (param.name == name) {
306 return &param;
307 }
308 }
309 return nullptr;
310 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700311 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900312
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700313 static const std::vector<Schema>& AllSchemas();
314
315 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Jooyung Han442cacf2021-09-13 17:44:56 +0900316 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters,
Jooyung Han8451a202021-01-16 03:07:06 +0900317 const Comments& comments);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700318
319 const Schema& schema_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100320 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900321};
322
Steven Moreland3be75772018-08-20 13:27:43 -0700323static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
324 return lhs.GetName() < rhs.GetName();
325}
326static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
327 return lhs.GetName() == rhs.GetName();
328}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900329
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900330class AidlAnnotatable : public AidlCommentable {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700331 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900332 AidlAnnotatable(const AidlLocation& location, const Comments& comments);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700333
Casey Dahline7922932016-02-29 17:23:01 -0800334 virtual ~AidlAnnotatable() = default;
335
Steven Morelanda7560e82021-10-08 16:24:39 -0700336 void Annotate(vector<std::unique_ptr<AidlAnnotation>>&& annotations) {
Artur Satayev91fe8712019-07-29 13:06:01 +0100337 for (auto& annotation : annotations) {
338 annotations_.emplace_back(std::move(annotation));
339 }
340 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900341 bool IsNullable() const;
Jooyung Han01720ed2021-08-13 07:46:07 +0900342 bool IsHeapNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900343 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000344 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700345 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900346 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700347 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900348 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800349 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900350 bool JavaDerive(const std::string& method) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900351 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100352
353 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700354 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900355 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900356 std::vector<std::string> SuppressWarnings() const;
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +0200357 std::unique_ptr<perm::Expression> EnforceExpression(const AidlNode&) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900358
359 // ToString is for dumping AIDL.
360 // Returns string representation of annotations.
361 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900362 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800363
Steven Morelanda7560e82021-10-08 16:24:39 -0700364 const vector<std::unique_ptr<AidlAnnotation>>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900365 bool CheckValid(const AidlTypenames&) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900366 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
367 for (const auto& annot : GetAnnotations()) {
Steven Morelanda7560e82021-10-08 16:24:39 -0700368 traverse(*annot);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900369 }
370 }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900371
Casey Dahline7922932016-02-29 17:23:01 -0800372 private:
Steven Morelanda7560e82021-10-08 16:24:39 -0700373 vector<std::unique_ptr<AidlAnnotation>> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800374};
375
Jiyong Park1deecc32018-07-17 01:14:41 +0900376// AidlTypeSpecifier represents a reference to either a built-in type,
377// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900378class AidlTypeSpecifier final : public AidlAnnotatable,
379 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800380 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700381 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name, bool is_array,
Jooyung Han8451a202021-01-16 03:07:06 +0900382 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const Comments& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900383 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700384
Steven Moreland0cac8662021-10-08 16:43:29 -0700385 // View of this type which is not an array.
386 void ViewAsArrayBase(std::function<void(const AidlTypeSpecifier&)> func) const;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700387
Jiyong Park1deecc32018-07-17 01:14:41 +0900388 // Returns the full-qualified name of the base type.
389 // int -> int
390 // int[] -> int
391 // List<String> -> List
392 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
393 const string& GetName() const {
394 if (IsResolved()) {
395 return fully_qualified_name_;
396 } else {
397 return GetUnresolvedName();
398 }
399 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700400
Jooyung Han965e31d2020-11-27 12:30:16 +0900401 // ToString is for dumping AIDL.
402 // Returns string representation of this type specifier including annotations.
403 // This is "annotations type_name type_params? array_marker?".
404 // e.g) "@utf8InCpp String[]";
405 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900406
Jooyung Han965e31d2020-11-27 12:30:16 +0900407 // Signature is for comparing AIDL types.
408 // Returns string representation of this type specifier.
409 // This is "type_name type_params? array_marker?".
410 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900411 std::string Signature() const;
412
Jiyong Park1deecc32018-07-17 01:14:41 +0900413 const string& GetUnresolvedName() const { return unresolved_name_; }
414
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900415 const std::vector<std::string> GetSplitName() const { return split_name_; }
416
Jiyong Park1deecc32018-07-17 01:14:41 +0900417 bool IsResolved() const { return fully_qualified_name_ != ""; }
418
419 bool IsArray() const { return is_array_; }
420
Steven Moreland6c07b832020-10-29 23:39:53 +0000421 __attribute__((warn_unused_result)) bool SetArray() {
422 if (is_array_) return false;
423 is_array_ = true;
424 return true;
425 }
426
Jiyong Park1deecc32018-07-17 01:14:41 +0900427 // Resolve the base type name to a fully-qualified name. Return false if the
428 // resolution fails.
Jooyung Han13f1fa52021-06-11 18:06:12 +0900429 bool Resolve(const AidlTypenames& typenames, const AidlScope* scope);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700430
Jooyung Han888c5bc2020-12-22 17:28:47 +0900431 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Hanb4997aa2021-10-16 03:26:12 +0900432 bool LanguageSpecificCheckValid(Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900433 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900434
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900435 const AidlDefinedType* GetDefinedType() const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900436 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
437 AidlAnnotatable::TraverseChildren(traverse);
Jooyung Han865da492021-01-03 11:32:47 +0900438 if (IsGeneric()) {
439 for (const auto& tp : GetTypeParameters()) {
440 traverse(*tp);
441 }
442 }
443 }
444 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900445
Casey Dahlin0ee37582015-09-30 16:31:55 -0700446 private:
Jiyong Park1deecc32018-07-17 01:14:41 +0900447 const string unresolved_name_;
448 string fully_qualified_name_;
Steven Moreland0cac8662021-10-08 16:43:29 -0700449 mutable bool is_array_;
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900450 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900451 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Casey Dahlin0ee37582015-09-30 16:31:55 -0700452};
453
Steven Moreland860b1942018-08-16 14:59:28 -0700454// Returns the universal value unaltered.
455std::string AidlConstantValueDecorator(const AidlTypeSpecifier& type, const std::string& raw_value);
456
Jooyung Han2aedb112021-09-29 09:37:59 +0900457class AidlMember : public AidlAnnotatable {
Jooyung Han8aeef8c2021-01-11 12:16:19 +0900458 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900459 AidlMember(const AidlLocation& location, const Comments& comments);
Jooyung Han3f347ca2020-12-01 12:41:50 +0900460 virtual ~AidlMember() = default;
461
462 // non-copyable, non-movable
463 AidlMember(const AidlMember&) = delete;
464 AidlMember(AidlMember&&) = delete;
465 AidlMember& operator=(const AidlMember&) = delete;
466 AidlMember& operator=(AidlMember&&) = delete;
Jooyung Han3f347ca2020-12-01 12:41:50 +0900467};
468
Steven Moreland541788d2020-05-21 22:05:52 +0000469// TODO: This class is used for method arguments and also parcelable fields,
470// and it should be split up since default values don't apply to method
471// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900472class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700473 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700474 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
475 const std::string& name);
476 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
477 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700478 virtual ~AidlVariableDeclaration() = default;
479
Jiyong Parkd800fef2020-07-22 18:09:43 +0900480 // non-copyable, non-movable
481 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
482 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
483 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
484 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
485
Steven Moreland5557f1c2018-07-02 13:50:23 -0700486 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900487 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900488 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000489 // if this was constructed explicitly with a default value
490 bool IsDefaultUserSpecified() const { return default_user_specified_; }
491 // will return the default value this is constructed with or a default value
492 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700493 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900494 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700495
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900496 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700497
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900498 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900499
500 // ToString is for dumping AIDL.
501 // Returns string representation of this variable decl including default value.
502 // This is "annotations type name default_value?".
503 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700504 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900505
506 // Signature is for comparing AIDL types.
507 // Returns string representation of this variable decl.
508 // This is "type name".
509 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900510 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700511
Steven Moreland860b1942018-08-16 14:59:28 -0700512 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700513
Jooyung Hanc5688f72021-01-05 15:41:48 +0900514 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jiyong Park45854452020-12-31 10:42:28 +0900515 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900516
Steven Moreland5557f1c2018-07-02 13:50:23 -0700517 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900518 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700519 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000520 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700521 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700522};
523
524class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700525 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700526 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
527
Steven Moreland46e9da82018-07-27 15:45:29 -0700528 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
529 AidlTypeSpecifier* type, const std::string& name);
530 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700531 virtual ~AidlArgument() = default;
532
Jiyong Parkd800fef2020-07-22 18:09:43 +0900533 // non-copyable, non-movable
534 AidlArgument(const AidlArgument&) = delete;
535 AidlArgument(AidlArgument&&) = delete;
536 AidlArgument& operator=(const AidlArgument&) = delete;
537 AidlArgument& operator=(AidlArgument&&) = delete;
538
Casey Dahlinc378c992015-09-29 16:50:40 -0700539 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700540 bool IsOut() const { return direction_ & OUT_DIR; }
541 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700542 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900543 string GetDirectionSpecifier() const;
Jooyung Han020d8d12021-02-26 17:23:02 +0900544 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyad339272015-10-05 19:11:58 -0700545
Jooyung Han965e31d2020-11-27 12:30:16 +0900546 // ToString is for dumping AIDL.
547 // Returns string representation of this argument including direction
548 // This is "direction annotations type name".
549 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700550 std::string ToString() const;
Jiyong Park512ed852020-12-30 15:07:23 +0900551
Jiyong Park45854452020-12-31 10:42:28 +0900552 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700553
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700554 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700555 Direction direction_;
556 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700557};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800558
Jooyung Han020d8d12021-02-26 17:23:02 +0900559struct ArgumentAspect {
560 std::string name;
561 std::set<AidlArgument::Direction> possible_directions;
562};
563
Will McVickerd7d18df2019-09-12 13:40:50 -0700564class AidlUnaryConstExpression;
565class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900566class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700567
Steven Moreland693640b2018-07-19 13:46:27 -0700568class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800569 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700570 enum class Type {
571 // WARNING: Don't change this order! The order is used to determine type
572 // promotion during a binary expression.
573 BOOLEAN,
574 INT8,
575 INT32,
576 INT64,
577 ARRAY,
578 CHARACTER,
579 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900580 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700581 FLOATING,
582 UNARY,
583 BINARY,
584 ERROR,
585 };
586
Jooyung Han535c5e82020-12-29 15:16:59 +0900587 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700588 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900589 T EvaluatedValue() const {
590 is_evaluated_ || (CheckValid() && evaluate());
591 AIDL_FATAL_IF(!is_valid_, this);
592
593 if constexpr (is_vector<T>::value) {
594 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
595 T result;
596 for (const auto& v : values_) {
597 result.push_back(v->EvaluatedValue<typename T::value_type>());
598 }
599 return result;
600 } else if constexpr (is_one_of<T, float, double>::value) {
601 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
602 T result;
603 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
604 return result;
605 } else if constexpr (std::is_same<T, std::string>::value) {
606 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
607 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
608 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
609 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
610 return static_cast<T>(final_value_);
611 } else if constexpr (std::is_same<T, char>::value) {
612 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
613 return final_string_value_.at(1); // unquote '
614 } else if constexpr (std::is_same<T, bool>::value) {
615 static_assert(std::is_same<T, bool>::value, "..");
616 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
617 return final_value_ != 0;
618 } else {
619 static_assert(unsupported_type<T>::value);
620 }
621 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800622
Steven Moreland693640b2018-07-19 13:46:27 -0700623 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800624
Jiyong Parkd800fef2020-07-22 18:09:43 +0900625 // non-copyable, non-movable
626 AidlConstantValue(const AidlConstantValue&) = delete;
627 AidlConstantValue(AidlConstantValue&&) = delete;
628 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
629 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
630
Steven Moreland541788d2020-05-21 22:05:52 +0000631 // creates default value, when one isn't specified
632 // nullptr if no default available
633 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
634
Steven Moreland25294322018-08-07 18:13:55 -0700635 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
636 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700637 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700638 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
639 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700640 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700641 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700642 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700643 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700644
Will McVickerd7d18df2019-09-12 13:40:50 -0700645 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900646 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700647
Will McVickerd7d18df2019-09-12 13:40:50 -0700648 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700649
650 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800651 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900652
653 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const {
Jooyung Han29813842020-12-08 01:28:03 +0900654 if (type_ == Type::ARRAY) {
655 for (const auto& v : values_) {
Jooyung Hanc5688f72021-01-05 15:41:48 +0900656 traverse(*v);
Jooyung Han29813842020-12-08 01:28:03 +0900657 }
658 }
659 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900660 void DispatchVisit(AidlVisitor& visitor) const override { visitor.Visit(*this); }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800661
662 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700663 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
664 const string& checked_value);
665 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700666 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900667 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
668 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700669 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700670 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
671 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800672
Jooyung Han74675c22020-12-15 08:39:57 +0900673 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800674
Steven Moreland693640b2018-07-19 13:46:27 -0700675 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700676 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
677 const string value_; // otherwise
678
679 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800680 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
681 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700682 mutable Type final_type_;
683 mutable int64_t final_value_;
684 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700685
Will McVickerd7d18df2019-09-12 13:40:50 -0700686 friend AidlUnaryConstExpression;
687 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900688 friend AidlConstantReference;
689};
690
691// Represents "<type>.<field>" which resolves to a constant which is one of
692// - constant declartion
693// - enumerator
694// When a <type> is missing, <field> is of the enclosing type.
695class AidlConstantReference : public AidlConstantValue {
696 public:
Jooyung Hand0c8af02021-01-06 18:08:01 +0900697 AidlConstantReference(const AidlLocation& location, const std::string& value);
Jooyung Han690f5842020-12-04 13:02:04 +0900698
699 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900700 const std::string& GetFieldName() const { return field_name_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900701
702 bool CheckValid() const override;
Jooyung Han289a1bc2021-05-15 15:04:05 +0900703 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
704 if (ref_type_) {
705 traverse(*ref_type_);
706 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900707 }
708 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900709 const AidlConstantValue* Resolve(const AidlDefinedType* scope) const;
Jooyung Han690f5842020-12-04 13:02:04 +0900710
711 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900712 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900713
714 std::unique_ptr<AidlTypeSpecifier> ref_type_;
715 std::string field_name_;
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900716 mutable const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700717};
718
719class AidlUnaryConstExpression : public AidlConstantValue {
720 public:
721 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
722 std::unique_ptr<AidlConstantValue> rval);
723
724 static bool IsCompatibleType(Type type, const string& op);
725 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900726 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
727 traverse(*unary_);
Jooyung Han690f5842020-12-04 13:02:04 +0900728 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900729 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han690f5842020-12-04 13:02:04 +0900730
Will McVickerd7d18df2019-09-12 13:40:50 -0700731 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900732 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700733
734 std::unique_ptr<AidlConstantValue> unary_;
735 const string op_;
736};
737
738class AidlBinaryConstExpression : public AidlConstantValue {
739 public:
740 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
741 const string& op, std::unique_ptr<AidlConstantValue> rval);
742
743 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700744
745 static bool AreCompatibleTypes(Type t1, Type t2);
746 // Returns the promoted kind for both operands
747 static Type UsualArithmeticConversion(Type left, Type right);
748 // Returns the promoted integral type where INT32 is the smallest type
749 static Type IntegralPromotion(Type in);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900750 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
751 traverse(*left_val_);
752 traverse(*right_val_);
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); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700755
756 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> left_val_;
760 std::unique_ptr<AidlConstantValue> right_val_;
761 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700762};
763
Andrei Onea9445fc62019-06-27 18:11:59 +0100764struct AidlAnnotationParameter {
765 std::string name;
766 std::unique_ptr<AidlConstantValue> value;
767};
768
Steven Moreland693640b2018-07-19 13:46:27 -0700769class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700770 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700771 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700772 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700773 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700774
Jiyong Parkd800fef2020-07-22 18:09:43 +0900775 // non-copyable, non-movable
776 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
777 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
778 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
779 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
780
Steven Moreland693640b2018-07-19 13:46:27 -0700781 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700782 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700783 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700784 const AidlConstantValue& GetValue() const { return *value_; }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900785 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700786
Jooyung Han965e31d2020-11-27 12:30:16 +0900787 // ToString is for dumping AIDL.
788 // Returns string representation of this const decl including a const value.
789 // This is "`const` annotations type name value".
790 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700791 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900792
793 // Signature is for comparing types.
794 // Returns string representation of this const decl.
795 // This is "direction annotations type name".
796 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700797 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900798
Steven Moreland860b1942018-08-16 14:59:28 -0700799 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700800 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700801 }
Steven Moreland25294322018-08-07 18:13:55 -0700802
Jooyung Hanc5688f72021-01-05 15:41:48 +0900803 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900804 traverse(GetType());
Jooyung Hanc5688f72021-01-05 15:41:48 +0900805 traverse(GetValue());
Jiyong Park512ed852020-12-30 15:07:23 +0900806 }
Jiyong Park45854452020-12-31 10:42:28 +0900807 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900808
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700809 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700810 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700811 const string name_;
812 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800813};
814
815class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700816 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700817 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900818 vector<unique_ptr<AidlArgument>>* args, const Comments& comments);
Will McVickerd7d18df2019-09-12 13:40:50 -0700819 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900820 vector<unique_ptr<AidlArgument>>* args, const Comments& comments, int id,
Will McVickerd7d18df2019-09-12 13:40:50 -0700821 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700822 virtual ~AidlMethod() = default;
823
Jiyong Parkd800fef2020-07-22 18:09:43 +0900824 // non-copyable, non-movable
825 AidlMethod(const AidlMethod&) = delete;
826 AidlMethod(AidlMethod&&) = delete;
827 AidlMethod& operator=(const AidlMethod&) = delete;
828 AidlMethod& operator=(AidlMethod&&) = delete;
829
Thiébaud Weksteenff6dafa2021-09-21 11:53:40 +0200830 bool CheckValid(const AidlTypenames&) const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900831 const AidlTypeSpecifier& GetType() const { return *type_; }
832 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800833
Steven Moreland8c70ba92018-12-17 10:20:31 -0800834 // set if this method is part of an interface that is marked oneway
835 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700836 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800837
Casey Dahlinf4a93112015-10-05 16:58:09 -0700838 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700839 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900840 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700841 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700842
Jiyong Park309668e2018-07-28 16:55:44 +0900843 bool IsUserDefined() const { return is_user_defined_; }
844
Casey Dahlinf4a93112015-10-05 16:58:09 -0700845 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700846 return arguments_;
847 }
848 // An inout parameter will appear in both GetInArguments()
849 // and GetOutArguments(). AidlMethod retains ownership of the argument
850 // pointers returned in this way.
851 const std::vector<const AidlArgument*>& GetInArguments() const {
852 return in_arguments_;
853 }
854 const std::vector<const AidlArgument*>& GetOutArguments() const {
855 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700856 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700857
Jooyung Han965e31d2020-11-27 12:30:16 +0900858 // ToString is for dumping AIDL.
859 // Returns string representation of this method including everything.
860 // This is "ret_type name ( arg_list ) = id".
861 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900862 std::string ToString() const;
863
Jooyung Han965e31d2020-11-27 12:30:16 +0900864 // Signature is for comparing AIDL types.
865 // Returns string representation of this method's name & type.
866 // e.g) "foo(int, String)"
867 std::string Signature() const;
868
Jooyung Hanc5688f72021-01-05 15:41:48 +0900869 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900870 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900871 for (const auto& a : GetArguments()) {
872 traverse(*a);
873 }
874 }
Jiyong Park45854452020-12-31 10:42:28 +0900875 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han808a2a02020-12-28 16:46:54 +0900876
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700877 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700878 bool oneway_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900879 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700880 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700881 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
882 std::vector<const AidlArgument*> in_arguments_;
883 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700884 bool has_id_;
885 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900886 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700887};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800888
Daniel Norman85aed542019-08-21 12:01:14 -0700889// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900890// defined in the source file.
Jooyung Han2aedb112021-09-29 09:37:59 +0900891class AidlDefinedType : public AidlMember, public AidlScope {
Steven Moreland787b0432018-07-03 09:00:58 -0700892 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900893 AidlDefinedType(const AidlLocation& location, const std::string& name, const Comments& comments,
894 const std::string& package, std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700895 virtual ~AidlDefinedType() = default;
896
Jiyong Parkd800fef2020-07-22 18:09:43 +0900897 // non-copyable, non-movable
898 AidlDefinedType(const AidlDefinedType&) = delete;
899 AidlDefinedType(AidlDefinedType&&) = delete;
900 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
901 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
902
Jiyong Park1deecc32018-07-17 01:14:41 +0900903 const std::string& GetName() const { return name_; };
Jiyong Park1deecc32018-07-17 01:14:41 +0900904
Jooyung Han13f1fa52021-06-11 18:06:12 +0900905 std::string ResolveName(const std::string& name) const override;
906
Steven Moreland787b0432018-07-03 09:00:58 -0700907 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900908 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700909 /* dot joined package and name, example: "android.package.foo.IBar" */
910 std::string GetCanonicalName() const;
Jooyung Han93f48f02021-06-05 00:11:16 +0900911 std::vector<std::string> GetSplitPackage() const {
912 if (package_.empty()) return std::vector<std::string>();
913 return android::base::Split(package_, ".");
914 }
Jooyung Han35784982021-06-29 06:26:12 +0900915 const AidlDocument& GetDocument() const;
Steven Moreland787b0432018-07-03 09:00:58 -0700916
Steven Morelanded83a282018-07-17 13:27:29 -0700917 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700918
Steven Moreland5557f1c2018-07-02 13:50:23 -0700919 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700920 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700921 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900922 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700923 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900924 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900925 virtual bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Hanb4997aa2021-10-16 03:26:12 +0900926 bool LanguageSpecificCheckValid(Options::Language lang) const;
Steven Morelandc258abc2018-07-10 14:03:38 -0700927 AidlStructuredParcelable* AsStructuredParcelable() {
928 return const_cast<AidlStructuredParcelable*>(
929 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
930 }
931 AidlParcelable* AsParcelable() {
932 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
933 }
Daniel Norman85aed542019-08-21 12:01:14 -0700934 AidlEnumDeclaration* AsEnumDeclaration() {
935 return const_cast<AidlEnumDeclaration*>(
936 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
937 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900938 AidlUnionDecl* AsUnionDeclaration() {
939 return const_cast<AidlUnionDecl*>(
940 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
941 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700942 AidlInterface* AsInterface() {
943 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
944 }
945
Jeongik Chadf76dc72019-11-28 00:08:47 +0900946 AidlParameterizable<std::string>* AsParameterizable() {
947 return const_cast<AidlParameterizable<std::string>*>(
948 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
949 }
950
Steven Moreland6cee3482018-07-18 14:39:58 -0700951 const AidlParcelable* AsUnstructuredParcelable() const {
952 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900953 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700954 return this->AsParcelable();
955 }
956 AidlParcelable* AsUnstructuredParcelable() {
957 return const_cast<AidlParcelable*>(
958 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
959 }
Jooyung Han2aedb112021-09-29 09:37:59 +0900960 const AidlDefinedType* GetParentType() const;
Jooyung Hanf8c39632021-10-05 09:56:29 +0900961 const AidlDefinedType* GetRootType() const;
Jooyung Han2aedb112021-09-29 09:37:59 +0900962 const std::vector<std::unique_ptr<AidlDefinedType>>& GetNestedTypes() const { return types_; }
Jooyung Han829ec7c2020-12-02 12:07:36 +0900963 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
964 return variables_;
965 }
966 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
967 return constants_;
968 }
969 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
Jooyung Han1bd54482021-10-14 11:40:39 +0900970 void AddMethod(std::unique_ptr<AidlMethod> method) {
971 members_.push_back(method.get());
972 methods_.push_back(std::move(method));
973 }
Jooyung Han829ec7c2020-12-02 12:07:36 +0900974 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900975 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
976 AidlAnnotatable::TraverseChildren(traverse);
977 for (const auto c : GetMembers()) {
978 traverse(*c);
979 }
980 }
Jiyong Park512ed852020-12-30 15:07:23 +0900981
Jooyung Han829ec7c2020-12-02 12:07:36 +0900982 protected:
983 // utility for subclasses with getter names
984 bool CheckValidForGetterNames() const;
985
Steven Moreland787b0432018-07-03 09:00:58 -0700986 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +0900987 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
988
Jiyong Park1deecc32018-07-17 01:14:41 +0900989 std::string name_;
Jooyung Han93f48f02021-06-05 00:11:16 +0900990 std::string package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900991 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
992 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
993 std::vector<std::unique_ptr<AidlMethod>> methods_;
Jooyung Han2aedb112021-09-29 09:37:59 +0900994 std::vector<std::unique_ptr<AidlDefinedType>> types_;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900995 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -0700996};
997
Jeongik Chadf76dc72019-11-28 00:08:47 +0900998class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700999 public:
Jiyong Park18132182020-06-08 20:24:40 +09001000 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001001 const Comments& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +09001002 std::vector<std::string>* type_params = nullptr,
1003 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001004 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -08001005
Jiyong Parkd800fef2020-07-22 18:09:43 +09001006 // non-copyable, non-movable
1007 AidlParcelable(const AidlParcelable&) = delete;
1008 AidlParcelable(AidlParcelable&&) = delete;
1009 AidlParcelable& operator=(const AidlParcelable&) = delete;
1010 AidlParcelable& operator=(AidlParcelable&&) = delete;
1011
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001012 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001013
Jooyung Han808a2a02020-12-28 16:46:54 +09001014 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -07001015 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +09001016 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
1017 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001018 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -07001019
Jiyong Park45854452020-12-31 10:42:28 +09001020 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001021
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001022 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001023 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001024};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001025
Jooyung Han829ec7c2020-12-02 12:07:36 +09001026class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -07001027 public:
Jiyong Park18132182020-06-08 20:24:40 +09001028 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
Jooyung Han8451a202021-01-16 03:07:06 +09001029 const std::string& package, const Comments& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001030 std::vector<std::string>* type_params,
1031 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001032 virtual ~AidlStructuredParcelable() = default;
1033
1034 // non-copyable, non-movable
1035 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
1036 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
1037 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
1038 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001039
Steven Morelandc258abc2018-07-10 14:03:38 -07001040 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001041 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001042
Jooyung Han808a2a02020-12-28 16:46:54 +09001043 bool CheckValid(const AidlTypenames& typenames) const override;
Jiyong Park45854452020-12-31 10:42:28 +09001044 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001045};
1046
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001047class AidlEnumerator : public AidlCommentable {
Daniel Norman85aed542019-08-21 12:01:14 -07001048 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001049 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
Jooyung Han8451a202021-01-16 03:07:06 +09001050 const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001051 virtual ~AidlEnumerator() = default;
1052
Jiyong Parkd800fef2020-07-22 18:09:43 +09001053 // non-copyable, non-movable
1054 AidlEnumerator(const AidlEnumerator&) = delete;
1055 AidlEnumerator(AidlEnumerator&&) = delete;
1056 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1057 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1058
Daniel Norman85aed542019-08-21 12:01:14 -07001059 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001060 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman85aed542019-08-21 12:01:14 -07001061 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1062
1063 string ValueString(const AidlTypeSpecifier& backing_type,
1064 const ConstantValueDecorator& decorator) const;
1065
Daniel Normanb28684e2019-10-17 15:31:39 -07001066 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001067 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001068
Jooyung Hanc5688f72021-01-05 15:41:48 +09001069 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1070 traverse(*value_);
Jiyong Park512ed852020-12-30 15:07:23 +09001071 }
Jiyong Park45854452020-12-31 10:42:28 +09001072 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001073
Daniel Norman85aed542019-08-21 12:01:14 -07001074 private:
1075 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001076 unique_ptr<AidlConstantValue> value_;
Jooyung Han29813842020-12-08 01:28:03 +09001077 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001078};
1079
1080class AidlEnumDeclaration : public AidlDefinedType {
1081 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001082 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001083 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jooyung Han8451a202021-01-16 03:07:06 +09001084 const std::string& package, const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001085 virtual ~AidlEnumDeclaration() = default;
1086
Jiyong Parkd800fef2020-07-22 18:09:43 +09001087 // non-copyable, non-movable
1088 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1089 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1090 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1091 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1092
Jooyung Han672557b2020-12-24 05:18:00 +09001093 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001094 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1095 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1096 return enumerators_;
1097 }
Jooyung Han808a2a02020-12-28 16:46:54 +09001098 bool CheckValid(const AidlTypenames& typenames) const override;
Daniel Norman85aed542019-08-21 12:01:14 -07001099 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Daniel Norman85aed542019-08-21 12:01:14 -07001100
1101 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1102
Jooyung Hanc5688f72021-01-05 15:41:48 +09001103 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1104 AidlDefinedType::TraverseChildren(traverse);
Jooyung Hanca84b032021-09-30 02:15:59 +09001105 if (backing_type_) {
1106 traverse(*backing_type_);
1107 }
Jiyong Park512ed852020-12-30 15:07:23 +09001108 for (const auto& c : GetEnumerators()) {
1109 traverse(*c);
1110 }
1111 }
Jiyong Park45854452020-12-31 10:42:28 +09001112 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001113
Daniel Norman85aed542019-08-21 12:01:14 -07001114 private:
Jooyung Han29813842020-12-08 01:28:03 +09001115
Daniel Norman85aed542019-08-21 12:01:14 -07001116 const std::string name_;
1117 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001118 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001119};
1120
Jooyung Han829ec7c2020-12-02 12:07:36 +09001121class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001122 public:
1123 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001124 const Comments& comments, std::vector<std::string>* type_params,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001125 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001126 virtual ~AidlUnionDecl() = default;
1127
1128 // non-copyable, non-movable
1129 AidlUnionDecl(const AidlUnionDecl&) = delete;
1130 AidlUnionDecl(AidlUnionDecl&&) = delete;
1131 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1132 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1133
Jooyung Han2946afc2020-10-05 20:29:16 +09001134
1135 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001136 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001137 std::string GetPreprocessDeclarationName() const override { return "union"; }
1138
Jooyung Han2946afc2020-10-05 20:29:16 +09001139 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jiyong Park45854452020-12-31 10:42:28 +09001140 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han2946afc2020-10-05 20:29:16 +09001141};
1142
Jiyong Park1deecc32018-07-17 01:14:41 +09001143class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001144 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001145 AidlInterface(const AidlLocation& location, const std::string& name, const Comments& comments,
Jooyung Handb4d8a62021-06-22 10:09:42 +09001146 bool oneway, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001147 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001148 virtual ~AidlInterface() = default;
1149
Jiyong Parkd800fef2020-07-22 18:09:43 +09001150 // non-copyable, non-movable
1151 AidlInterface(const AidlInterface&) = delete;
1152 AidlInterface(AidlInterface&&) = delete;
1153 AidlInterface& operator=(const AidlInterface&) = delete;
1154 AidlInterface& operator=(AidlInterface&&) = delete;
1155
Steven Morelandc258abc2018-07-10 14:03:38 -07001156 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001157 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001158
Jooyung Han808a2a02020-12-28 16:46:54 +09001159 bool CheckValid(const AidlTypenames& typenames) const override;
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001160 std::string GetDescriptor() const;
Jiyong Park45854452020-12-31 10:42:28 +09001161 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001162};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001163
Jooyung Hancdf89ec2021-10-29 14:08:30 +09001164inline std::string SimpleName(const std::string& qualified_name) {
1165 return qualified_name.substr(qualified_name.rfind('.') + 1);
1166}
Casey Dahline2507492015-09-14 17:11:20 -07001167
Jiyong Park62515512020-06-08 15:57:11 +09001168// AidlDocument models an AIDL file
Jooyung Han13f1fa52021-06-11 18:06:12 +09001169class AidlDocument : public AidlCommentable, public AidlScope {
Jiyong Park62515512020-06-08 15:57:11 +09001170 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001171 AidlDocument(const AidlLocation& location, const Comments& comments,
Jooyung Hancdf89ec2021-10-29 14:08:30 +09001172 std::set<std::string> imports,
Jooyung Han35784982021-06-29 06:26:12 +09001173 std::vector<std::unique_ptr<AidlDefinedType>> defined_types, bool is_preprocessed);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001174 ~AidlDocument() = default;
1175
1176 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001177 AidlDocument(const AidlDocument&) = delete;
1178 AidlDocument(AidlDocument&&) = delete;
1179 AidlDocument& operator=(const AidlDocument&) = delete;
1180 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001181
Jooyung Han13f1fa52021-06-11 18:06:12 +09001182 std::string ResolveName(const std::string& name) const override;
Jooyung Hancdf89ec2021-10-29 14:08:30 +09001183 const std::set<std::string>& Imports() const { return imports_; }
Jiyong Parkd800fef2020-07-22 18:09:43 +09001184 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1185 return defined_types_;
1186 }
Jooyung Han35784982021-06-29 06:26:12 +09001187 bool IsPreprocessed() const { return is_preprocessed_; }
Jiyong Park62515512020-06-08 15:57:11 +09001188
Jooyung Hanc5688f72021-01-05 15:41:48 +09001189 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jiyong Park512ed852020-12-30 15:07:23 +09001190 for (const auto& t : DefinedTypes()) {
1191 traverse(*t);
1192 }
1193 }
Jiyong Park45854452020-12-31 10:42:28 +09001194 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001195
Jiyong Park62515512020-06-08 15:57:11 +09001196 private:
Jooyung Hancdf89ec2021-10-29 14:08:30 +09001197 const std::set<std::string> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001198 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jooyung Han35784982021-06-29 06:26:12 +09001199 bool is_preprocessed_;
Jiyong Park62515512020-06-08 15:57:11 +09001200};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001201
1202template <typename T>
1203std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1204 auto it = parameters_.find(param_name);
1205 if (it == parameters_.end()) {
1206 return std::nullopt;
1207 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001208 return it->second->EvaluatedValue<T>();
Jiyong Park512ed852020-12-30 15:07:23 +09001209}
Jooyung Hanc5688f72021-01-05 15:41:48 +09001210
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001211// Utilities to make a visitor to visit AST tree in top-down order
Jooyung Hanc5688f72021-01-05 15:41:48 +09001212// Given: foo
1213// / \
1214// bar baz
1215// VisitTopDown(v, foo) makes v visit foo -> bar -> baz.
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001216inline void VisitTopDown(std::function<void(const AidlNode&)> v, const AidlNode& node) {
Jooyung Hanc5688f72021-01-05 15:41:48 +09001217 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001218 v(n);
Jooyung Hanc5688f72021-01-05 15:41:48 +09001219 n.TraverseChildren(top_down);
1220 };
1221 top_down(node);
Jooyung Han289a1bc2021-05-15 15:04:05 +09001222}
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001223inline void VisitTopDown(AidlVisitor& v, const AidlNode& node) {
1224 VisitTopDown([&](const AidlNode& n) { n.DispatchVisit(v); }, node);
1225}
Jooyung Han289a1bc2021-05-15 15:04:05 +09001226
1227// Utility to make a visitor to visit AST tree in bottom-up order
1228// Given: foo
1229// / \
1230// bar baz
1231// VisitBottomUp(v, foo) makes v visit bar -> baz -> foo.
1232inline void VisitBottomUp(AidlVisitor& v, const AidlNode& node) {
1233 std::function<void(const AidlNode&)> bottom_up = [&](const AidlNode& n) {
1234 n.TraverseChildren(bottom_up);
1235 n.DispatchVisit(v);
1236 };
1237 bottom_up(node);
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +02001238}
Jooyung Hanbaa71062021-09-29 09:06:03 +09001239
1240template <typename T>
1241const T* AidlCast(const AidlNode& node) {
1242 struct CastVisitor : AidlVisitor {
1243 const T* cast = nullptr;
1244 void Visit(const T& t) override { cast = &t; }
1245 } visitor;
1246 node.DispatchVisit(visitor);
1247 return visitor.cast;
1248}
1249
1250template <>
1251const AidlDefinedType* AidlCast<AidlDefinedType>(const AidlNode& node);
1252
1253template <typename T>
1254T* AidlCast(AidlNode& node) {
1255 return const_cast<T*>(AidlCast<T>(const_cast<const AidlNode&>(node)));
1256}
Jooyung Han8e9ae872021-10-13 02:52:25 +09001257
1258template <typename AidlNodeType>
1259vector<const AidlNodeType*> Collect(const AidlNode& root) {
1260 vector<const AidlNodeType*> result;
1261 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
1262 if (auto cast = AidlCast<AidlNodeType>(n); cast) {
1263 result.push_back(cast);
1264 }
1265 n.TraverseChildren(top_down);
1266 };
1267 top_down(root);
1268 return result;
1269}
1270
1271template <typename VisitFn>
1272bool TopologicalVisit(const vector<unique_ptr<AidlDefinedType>>& nested_types, VisitFn visit) {
1273 // 1. Maps deeply nested types to one of nested_types
1274 map<const AidlDefinedType*, const AidlDefinedType*> roots;
1275 for (const auto& nested : nested_types) {
1276 for (const auto& t : Collect<AidlDefinedType>(*nested)) {
1277 roots[t] = nested.get();
1278 }
1279 }
1280 // 2. Collect sibling types referenced within each nested type.
1281 map<const AidlDefinedType*, vector<const AidlDefinedType*>> required_types;
1282 for (const auto& nested : nested_types) {
1283 for (const auto& t : Collect<AidlTypeSpecifier>(*nested)) {
1284 if (auto defined_type = t->GetDefinedType(); defined_type) {
1285 auto sibling = roots[defined_type];
1286 if (sibling && sibling != nested.get()) {
1287 required_types[nested.get()].push_back(sibling);
1288 }
1289 }
1290 }
1291 };
1292 // 3. Run DFS
1293 enum { NOT_STARTED = 0, STARTED = 1, FINISHED = 2 };
1294 map<const AidlDefinedType*, int> visited;
1295 std::function<bool(const AidlDefinedType&)> dfs = [&](const AidlDefinedType& type) {
1296 if (visited[&type] == FINISHED) {
1297 return true;
1298 } else if (visited[&type] == STARTED) {
1299 return false;
1300 } else {
1301 visited[&type] = STARTED;
1302 // Visit every required dep first
1303 for (const auto& dep_type : required_types[&type]) {
1304 if (!dfs(*dep_type)) {
1305 return false;
1306 }
1307 }
1308 visited[&type] = FINISHED;
1309 visit(type);
1310 return true;
1311 }
1312 };
1313
1314 for (const auto& type : nested_types) {
1315 if (!dfs(*type)) {
1316 return false;
1317 }
1318 }
1319
1320 return true;
1321}