blob: 9b16920589ae846432647d4b981b0174e29ad382 [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>
Jooyung Hanaeb01672021-11-30 17:29:22 +090023#include <variant>
Casey Dahlinbc7a50a2015-09-28 19:20:50 -070024#include <vector>
Casey Dahlindd691812015-09-09 17:59:06 -070025
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +020026#include <android-base/result.h>
Elliott Hughes0a620672015-12-04 13:53:18 -080027#include <android-base/strings.h>
Casey Dahlin73d46b02015-09-11 02:47:54 +000028
Jooyung Han888c5bc2020-12-22 17:28:47 +090029#include "aidl_typenames.h"
30#include "code_writer.h"
Jooyung Han8451a202021-01-16 03:07:06 +090031#include "comments.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090032#include "diagnostics.h"
33#include "io_delegate.h"
Jooyung Han535c5e82020-12-29 15:16:59 +090034#include "location.h"
35#include "logging.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090036#include "options.h"
Thiébaud Weksteen65281c42021-12-15 10:07:10 +110037#include "permission.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090038
Jiyong Parkb034bf02018-07-30 17:44:33 +090039using android::aidl::AidlTypenames;
Jiyong Park02da7422018-07-16 16:00:26 +090040using android::aidl::CodeWriter;
Jooyung Han8451a202021-01-16 03:07:06 +090041using android::aidl::Comments;
Jeongik Cha047c5ee2019-08-07 23:16:49 +090042using android::aidl::Options;
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +020043using android::base::Result;
Steven Moreland3f658cf2018-08-20 13:40:54 -070044using std::shared_ptr;
Jiyong Park1deecc32018-07-17 01:14:41 +090045using std::string;
46using std::unique_ptr;
47using std::vector;
Andrei Onea8714b022019-02-01 18:55:54 +000048class AidlNode;
49
Jooyung Han535c5e82020-12-29 15:16:59 +090050// helper to see if T is the same to one of Args types.
51template <typename T, typename... Args>
52struct is_one_of : std::false_type {};
53
54template <typename T, typename S, typename... Args>
55struct is_one_of<T, S, Args...> {
56 enum { value = std::is_same_v<T, S> || is_one_of<T, Args...>::value };
57};
58
59// helper to see if T is std::vector of something.
60template <typename>
61struct is_vector : std::false_type {};
62
63template <typename T>
64struct is_vector<std::vector<T>> : std::true_type {};
65
66// helper for static_assert(false)
67template <typename T>
68struct unsupported_type : std::false_type {};
69
Andrei Onea8714b022019-02-01 18:55:54 +000070namespace android {
71namespace aidl {
72namespace mappings {
73std::string dump_location(const AidlNode& method);
74} // namespace mappings
Mathew Inwoodadb74672019-11-29 14:01:53 +000075namespace java {
76std::string dump_location(const AidlNode& method);
77} // namespace java
Andrei Onea8714b022019-02-01 18:55:54 +000078} // namespace aidl
79} // namespace android
80
Jooyung Han535c5e82020-12-29 15:16:59 +090081bool ParseFloating(std::string_view sv, double* parsed);
82bool ParseFloating(std::string_view sv, float* parsed);
Steven Moreland46e9da82018-07-27 15:45:29 -070083
Jooyung Han808a2a02020-12-28 16:46:54 +090084class AidlDocument;
85class AidlInterface;
86class AidlParcelable;
87class AidlStructuredParcelable;
88class AidlEnumDeclaration;
89class AidlUnionDecl;
90class AidlVariableDeclaration;
91class AidlConstantDeclaration;
92class AidlEnumerator;
93class AidlMethod;
94class AidlArgument;
Jooyung Hanc5688f72021-01-05 15:41:48 +090095class AidlConstantValue;
96class AidlConstantReference;
97class AidlUnaryConstExpression;
98class AidlBinaryConstExpression;
99class AidlAnnotation;
Jooyung Han808a2a02020-12-28 16:46:54 +0900100
Jiyong Park45854452020-12-31 10:42:28 +0900101// Interface for visitors that can traverse AidlTraversable nodes.
Jooyung Han808a2a02020-12-28 16:46:54 +0900102class AidlVisitor {
103 public:
104 virtual ~AidlVisitor() = default;
Jiyong Park45854452020-12-31 10:42:28 +0900105 virtual void Visit(const AidlDocument&) {}
106 virtual void Visit(const AidlInterface&) {}
107 virtual void Visit(const AidlParcelable&) {}
108 virtual void Visit(const AidlStructuredParcelable&) {}
109 virtual void Visit(const AidlUnionDecl&) {}
110 virtual void Visit(const AidlEnumDeclaration&) {}
111 virtual void Visit(const AidlEnumerator&) {}
112 virtual void Visit(const AidlMethod&) {}
113 virtual void Visit(const AidlVariableDeclaration&) {}
114 virtual void Visit(const AidlConstantDeclaration&) {}
115 virtual void Visit(const AidlArgument&) {}
Jooyung Han865da492021-01-03 11:32:47 +0900116 virtual void Visit(const AidlTypeSpecifier&) {}
Jooyung Hanc5688f72021-01-05 15:41:48 +0900117 virtual void Visit(const AidlConstantValue&) {}
118 virtual void Visit(const AidlConstantReference&) {}
119 virtual void Visit(const AidlUnaryConstExpression&) {}
120 virtual void Visit(const AidlBinaryConstExpression&) {}
121 virtual void Visit(const AidlAnnotation&) {}
Jooyung Han808a2a02020-12-28 16:46:54 +0900122};
123
Jooyung Han13f1fa52021-06-11 18:06:12 +0900124class AidlScope {
125 public:
Jooyung Han35784982021-06-29 06:26:12 +0900126 AidlScope(const AidlNode* self) : self_(self) {}
Jooyung Han13f1fa52021-06-11 18:06:12 +0900127 virtual ~AidlScope() = default;
128 virtual std::string ResolveName(const std::string& name) const = 0;
129 void SetEnclosingScope(const AidlScope* enclosing) {
130 AIDL_FATAL_IF(enclosing_, AIDL_LOCATION_HERE) << "SetEnclosingScope can be set only once.";
131 enclosing_ = enclosing;
132 }
133 const AidlScope* GetEnclosingScope() const { return enclosing_; }
Jooyung Han35784982021-06-29 06:26:12 +0900134 const AidlNode& GetNode() const { return *self_; }
Jooyung Han13f1fa52021-06-11 18:06:12 +0900135
136 private:
Jooyung Han35784982021-06-29 06:26:12 +0900137 const AidlNode* self_;
Jooyung Han13f1fa52021-06-11 18:06:12 +0900138 const AidlScope* enclosing_ = nullptr;
139};
140
Steven Moreland46e9da82018-07-27 15:45:29 -0700141// Anything that is locatable in a .aidl file.
142class AidlNode {
143 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900144 AidlNode(const AidlLocation& location, const Comments& comments = {});
Steven Moreland3f658cf2018-08-20 13:40:54 -0700145
Jooyung Han2b3cd2a2021-10-15 06:54:55 +0900146 virtual ~AidlNode();
Steven Moreland46e9da82018-07-27 15:45:29 -0700147
Steven Morelanda7560e82021-10-08 16:24:39 -0700148 AidlNode(AidlNode&) = delete;
149 AidlNode& operator=(AidlNode&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +0900150 AidlNode(AidlNode&&) = delete;
151 AidlNode& operator=(AidlNode&&) = delete;
152
Devin Mooredf93ebb2020-03-25 14:03:35 -0700153 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700154 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000155 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000156 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700157
Devin Mooredf93ebb2020-03-25 14:03:35 -0700158 const AidlLocation& GetLocation() const { return location_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900159 virtual void TraverseChildren(std::function<void(const AidlNode&)> traverse) const = 0;
160 virtual void DispatchVisit(AidlVisitor&) const = 0;
Devin Mooredf93ebb2020-03-25 14:03:35 -0700161
Jooyung Han8451a202021-01-16 03:07:06 +0900162 const Comments& GetComments() const { return comments_; }
163 void SetComments(const Comments& comments) { comments_ = comments; }
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900164
Jooyung Han2b3cd2a2021-10-15 06:54:55 +0900165 static void ClearUnvisitedNodes();
166 static const std::vector<AidlLocation>& GetLocationsOfUnvisitedNodes();
167 void MarkVisited() const;
168
Steven Moreland46e9da82018-07-27 15:45:29 -0700169 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000170 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000171 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700172 const AidlLocation location_;
Jooyung Han8451a202021-01-16 03:07:06 +0900173 Comments comments_;
Jooyung Han2b3cd2a2021-10-15 06:54:55 +0900174
175 // make sure we are able to abort if types are not visited
176 mutable bool visited_ = false;
177 static std::vector<AidlLocation> unvisited_locations_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700178};
179
Jeongik Chadf76dc72019-11-28 00:08:47 +0900180// unique_ptr<AidlTypeSpecifier> for type arugment,
181// std::string for type parameter(T, U, and so on).
182template <typename T>
183class AidlParameterizable {
184 public:
185 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
186 virtual ~AidlParameterizable() = default;
187 bool IsGeneric() const { return type_params_ != nullptr; }
188 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
189 bool CheckValid() const;
190
Steven Moreland6c07b832020-10-29 23:39:53 +0000191 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
192 if (type_params_) return false;
193 type_params_.reset(type_params);
194 return true;
195 }
196
Jeongik Chadf76dc72019-11-28 00:08:47 +0900197 virtual const AidlNode& AsAidlNode() const = 0;
198
Jeongik Chadf76dc72019-11-28 00:08:47 +0900199 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000200 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900201 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
202 std::is_same<T, std::string>::value);
203};
204template <>
205bool AidlParameterizable<std::string>::CheckValid() const;
206
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900207class AidlCommentable : public AidlNode {
Jooyung Han6736ffb2021-01-16 10:13:40 +0900208 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900209 AidlCommentable(const AidlLocation& location, const Comments& comments)
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900210 : AidlNode(location, comments) {}
Jooyung Han6736ffb2021-01-16 10:13:40 +0900211 virtual ~AidlCommentable() = default;
212
Jooyung Han6736ffb2021-01-16 10:13:40 +0900213 bool IsHidden() const;
214 bool IsDeprecated() const;
Jooyung Han6736ffb2021-01-16 10:13:40 +0900215};
Andrei Onea9445fc62019-06-27 18:11:59 +0100216
217// Transforms a value string into a language specific form. Raw value as produced by
218// AidlConstantValue.
Jooyung Hanaeb01672021-11-30 17:29:22 +0900219using ConstantValueDecorator = std::function<std::string(
220 const AidlTypeSpecifier& type,
221 const std::variant<std::string, std::vector<std::string>>& raw_value)>;
Andrei Onea9445fc62019-06-27 18:11:59 +0100222
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900223class AidlAnnotation : public AidlNode {
Jiyong Park68bc77a2018-07-19 19:00:45 +0900224 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700225 enum class Type {
226 BACKING = 1,
227 HIDE,
228 JAVA_STABLE_PARCELABLE,
229 UNSUPPORTED_APP_USAGE,
230 VINTF_STABILITY,
231 NULLABLE,
232 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000233 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900234 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900235 JAVA_DERIVE,
Hao Ke2a46d062021-11-11 19:40:56 +0000236 JAVA_DEFAULT,
Devin Moore14ca7d92022-02-02 00:00:35 +0000237 JAVA_DELEGATOR,
Jeongik Chad0a10272020-08-06 16:33:36 +0900238 JAVA_ONLY_IMMUTABLE,
Jooyung Hanc2bc7502022-01-18 16:00:51 +0900239 JAVA_SUPPRESS_LINT,
Devin Moorec7e47a32020-08-07 10:55:25 -0700240 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900241 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700242 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900243 SUPPRESS_WARNINGS,
Thiébaud Weksteene79243a2021-11-02 14:36:25 +1100244 PERMISSION_ENFORCE,
245 PERMISSION_NONE,
Makoto Onuki23edf922022-01-27 16:29:55 -0800246 PERMISSION_MANUAL,
247 PROPAGATE_ALLOW_BLOCKING,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700248 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900249
250 using TargetContext = uint16_t;
251 static constexpr TargetContext CONTEXT_TYPE_INTERFACE = 0x1 << 0;
252 static constexpr TargetContext CONTEXT_TYPE_ENUM = 0x1 << 1;
253 static constexpr TargetContext CONTEXT_TYPE_STRUCTURED_PARCELABLE = 0x1 << 2;
254 static constexpr TargetContext CONTEXT_TYPE_UNION = 0x1 << 3;
255 static constexpr TargetContext CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE = 0x1 << 4;
256 static constexpr TargetContext CONTEXT_TYPE =
257 CONTEXT_TYPE_INTERFACE | CONTEXT_TYPE_ENUM | CONTEXT_TYPE_STRUCTURED_PARCELABLE |
258 CONTEXT_TYPE_UNION | CONTEXT_TYPE_UNSTRUCTURED_PARCELABLE;
259 static constexpr TargetContext CONTEXT_CONST = 0x1 << 5;
260 static constexpr TargetContext CONTEXT_FIELD = 0x1 << 6;
261 static constexpr TargetContext CONTEXT_METHOD = 0x1 << 7;
262 static constexpr TargetContext CONTEXT_MEMBER = CONTEXT_CONST | CONTEXT_FIELD | CONTEXT_METHOD;
263 static constexpr TargetContext CONTEXT_TYPE_SPECIFIER = 0x1 << 8;
264 static constexpr TargetContext CONTEXT_ALL =
265 CONTEXT_TYPE | CONTEXT_MEMBER | CONTEXT_TYPE_SPECIFIER;
266
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700267 static std::string TypeToString(Type type);
268
Jooyung Han442cacf2021-09-13 17:44:56 +0900269 static std::unique_ptr<AidlAnnotation> Parse(
Andrei Onea9445fc62019-06-27 18:11:59 +0100270 const AidlLocation& location, const string& name,
Jooyung Han442cacf2021-09-13 17:44:56 +0900271 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameter_list,
Jooyung Han8451a202021-01-16 03:07:06 +0900272 const Comments& comments);
Steven Moreland46e9da82018-07-27 15:45:29 -0700273
Steven Moreland3be75772018-08-20 13:27:43 -0700274 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900275 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100276 bool CheckValid() const;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900277 bool CheckContext(TargetContext context) const;
Jooyung Hand902a972020-10-23 17:32:44 +0900278 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700279 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900280 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900281
282 // ToString is for dumping AIDL.
283 // Returns string representation of this annotation.
284 // e.g) "@RustDerive(Clone=true, Copy=true)"
285 string ToString() const;
286
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900287 template <typename T>
288 std::optional<T> ParamValue(const std::string& param_name) const;
289
Andrei Onea9445fc62019-06-27 18:11:59 +0100290 std::map<std::string, std::string> AnnotationParams(
291 const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900292 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
293 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900294
Thiébaud Weksteen65281c42021-12-15 10:07:10 +1100295 Result<unique_ptr<android::aidl::perm::Expression>> EnforceExpression() const;
Thiébaud Weksteen9ab59122021-09-20 09:37:38 +0200296
Jiyong Park68bc77a2018-07-19 19:00:45 +0900297 private:
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900298 struct ParamType {
299 std::string name;
300 const AidlTypeSpecifier& type;
301 bool required = false;
302 };
303
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700304 struct Schema {
305 AidlAnnotation::Type type;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700306 std::string name;
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900307 TargetContext target_context;
308 std::vector<ParamType> parameters;
309 bool repeatable = false;
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700310
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900311 const ParamType* ParamType(const std::string& name) const {
312 for (const auto& param : parameters) {
313 if (param.name == name) {
314 return &param;
315 }
316 }
317 return nullptr;
318 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700319 };
Jooyung Han2d6b5c42021-01-09 01:01:06 +0900320
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700321 static const std::vector<Schema>& AllSchemas();
322
323 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Jooyung Han442cacf2021-09-13 17:44:56 +0900324 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters,
Jooyung Han8451a202021-01-16 03:07:06 +0900325 const Comments& comments);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700326
327 const Schema& schema_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100328 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900329};
330
Steven Moreland3be75772018-08-20 13:27:43 -0700331static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
332 return lhs.GetName() < rhs.GetName();
333}
334static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
335 return lhs.GetName() == rhs.GetName();
336}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900337
Jooyung Han5c7e77c2021-01-20 16:00:29 +0900338class AidlAnnotatable : public AidlCommentable {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700339 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900340 AidlAnnotatable(const AidlLocation& location, const Comments& comments);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700341
Casey Dahline7922932016-02-29 17:23:01 -0800342 virtual ~AidlAnnotatable() = default;
343
Steven Morelanda7560e82021-10-08 16:24:39 -0700344 void Annotate(vector<std::unique_ptr<AidlAnnotation>>&& annotations) {
Artur Satayev91fe8712019-07-29 13:06:01 +0100345 for (auto& annotation : annotations) {
346 annotations_.emplace_back(std::move(annotation));
347 }
348 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900349 bool IsNullable() const;
Jooyung Han01720ed2021-08-13 07:46:07 +0900350 bool IsHeapNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900351 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000352 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700353 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900354 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700355 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900356 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800357 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900358 bool JavaDerive(const std::string& method) const;
Hao Ke2a46d062021-11-11 19:40:56 +0000359 bool IsJavaDefault() const;
Devin Moore14ca7d92022-02-02 00:00:35 +0000360 bool IsJavaDelegator() const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900361 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100362
363 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700364 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900365 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900366 std::vector<std::string> SuppressWarnings() const;
Thiébaud Weksteen65281c42021-12-15 10:07:10 +1100367 std::unique_ptr<android::aidl::perm::Expression> EnforceExpression() const;
Thiébaud Weksteene79243a2021-11-02 14:36:25 +1100368 bool IsPermissionManual() const;
369 bool IsPermissionNone() const;
Makoto Onuki23edf922022-01-27 16:29:55 -0800370 bool IsPropagateAllowBlocking() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900371
372 // ToString is for dumping AIDL.
373 // Returns string representation of annotations.
374 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900375 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800376
Steven Morelanda7560e82021-10-08 16:24:39 -0700377 const vector<std::unique_ptr<AidlAnnotation>>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900378 bool CheckValid(const AidlTypenames&) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900379 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
380 for (const auto& annot : GetAnnotations()) {
Steven Morelanda7560e82021-10-08 16:24:39 -0700381 traverse(*annot);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900382 }
383 }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900384
Casey Dahline7922932016-02-29 17:23:01 -0800385 private:
Steven Morelanda7560e82021-10-08 16:24:39 -0700386 vector<std::unique_ptr<AidlAnnotation>> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800387};
388
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900389// Represents `[]`
390struct DynamicArray {};
391// Represents `[N][M]..`
392struct FixedSizeArray {
393 FixedSizeArray(std::unique_ptr<AidlConstantValue> dim) { dimensions.push_back(std::move(dim)); }
394 std::vector<std::unique_ptr<AidlConstantValue>> dimensions;
395};
396// Represents `[]` or `[N]` part of type specifier
397using ArrayType = std::variant<DynamicArray, FixedSizeArray>;
398
Jiyong Park1deecc32018-07-17 01:14:41 +0900399// AidlTypeSpecifier represents a reference to either a built-in type,
400// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900401class AidlTypeSpecifier final : public AidlAnnotatable,
402 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800403 public:
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900404 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name,
405 std::optional<ArrayType> array,
Jooyung Han8451a202021-01-16 03:07:06 +0900406 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const Comments& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900407 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700408
Jooyung Han0cc99632021-11-30 17:19:05 +0900409 // View of this type which has one-less dimension(s).
410 // e.g.) T[] => T, T[N][M] => T[M]
Steven Moreland0cac8662021-10-08 16:43:29 -0700411 void ViewAsArrayBase(std::function<void(const AidlTypeSpecifier&)> func) const;
Jooyung Hanca4f3192021-12-15 11:28:06 +0900412 // ViewAsArrayBase passes "mutated" type to its callback.
413 bool IsMutated() const { return mutated_; }
Steven Moreland3f658cf2018-08-20 13:40:54 -0700414
Jiyong Park1deecc32018-07-17 01:14:41 +0900415 // Returns the full-qualified name of the base type.
416 // int -> int
417 // int[] -> int
418 // List<String> -> List
419 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
420 const string& GetName() const {
421 if (IsResolved()) {
422 return fully_qualified_name_;
423 } else {
424 return GetUnresolvedName();
425 }
426 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700427
Jooyung Han965e31d2020-11-27 12:30:16 +0900428 // ToString is for dumping AIDL.
429 // Returns string representation of this type specifier including annotations.
430 // This is "annotations type_name type_params? array_marker?".
431 // e.g) "@utf8InCpp String[]";
432 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900433
Jooyung Han965e31d2020-11-27 12:30:16 +0900434 // Signature is for comparing AIDL types.
435 // Returns string representation of this type specifier.
436 // This is "type_name type_params? array_marker?".
437 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900438 std::string Signature() const;
439
Jiyong Park1deecc32018-07-17 01:14:41 +0900440 const string& GetUnresolvedName() const { return unresolved_name_; }
441
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900442 const std::vector<std::string> GetSplitName() const { return split_name_; }
443
Jiyong Park1deecc32018-07-17 01:14:41 +0900444 bool IsResolved() const { return fully_qualified_name_ != ""; }
445
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900446 bool IsArray() const { return array_.has_value(); }
Jooyung Han729630b2021-12-01 17:32:54 +0900447 bool IsDynamicArray() const {
448 return array_.has_value() && std::get_if<DynamicArray>(&*array_) != nullptr;
449 }
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900450 bool IsFixedSizeArray() const {
451 return array_.has_value() && std::get_if<FixedSizeArray>(&*array_) != nullptr;
Steven Moreland6c07b832020-10-29 23:39:53 +0000452 }
Jooyung Hanca4f3192021-12-15 11:28:06 +0900453 std::vector<int32_t> GetFixedSizeArrayDimensions() const;
Steven Moreland6c07b832020-10-29 23:39:53 +0000454
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900455 const ArrayType& GetArray() const {
456 AIDL_FATAL_IF(!array_.has_value(), this) << "GetArray() for non-array type";
457 return array_.value();
458 }
459
460 // Accept transitions from
461 // T to T[]
462 // or T to T[N]
463 // or T[N] to T[N][M]
464 __attribute__((warn_unused_result)) bool MakeArray(ArrayType array_type);
465
Jiyong Park1deecc32018-07-17 01:14:41 +0900466 // Resolve the base type name to a fully-qualified name. Return false if the
467 // resolution fails.
Jooyung Han13f1fa52021-06-11 18:06:12 +0900468 bool Resolve(const AidlTypenames& typenames, const AidlScope* scope);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700469
Jooyung Han888c5bc2020-12-22 17:28:47 +0900470 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Hanb4997aa2021-10-16 03:26:12 +0900471 bool LanguageSpecificCheckValid(Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900472 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900473
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900474 const AidlDefinedType* GetDefinedType() const;
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900475 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jooyung Han865da492021-01-03 11:32:47 +0900476 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900477
Casey Dahlin0ee37582015-09-30 16:31:55 -0700478 private:
Jiyong Park1deecc32018-07-17 01:14:41 +0900479 const string unresolved_name_;
480 string fully_qualified_name_;
Jooyung Han9fafb8d2021-11-30 13:19:33 +0900481 mutable std::optional<ArrayType> array_;
Jooyung Hanca4f3192021-12-15 11:28:06 +0900482 mutable bool mutated_ = false; // ViewAsArrayBase() sets this as true to distinguish mutated one
483 // from the original type
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900484 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900485 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Casey Dahlin0ee37582015-09-30 16:31:55 -0700486};
487
Steven Moreland860b1942018-08-16 14:59:28 -0700488// Returns the universal value unaltered.
Jooyung Hanaeb01672021-11-30 17:29:22 +0900489std::string AidlConstantValueDecorator(
490 const AidlTypeSpecifier& type,
491 const std::variant<std::string, std::vector<std::string>>& raw_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700492
Jooyung Han2aedb112021-09-29 09:37:59 +0900493class AidlMember : public AidlAnnotatable {
Jooyung Han8aeef8c2021-01-11 12:16:19 +0900494 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900495 AidlMember(const AidlLocation& location, const Comments& comments);
Jooyung Han3f347ca2020-12-01 12:41:50 +0900496 virtual ~AidlMember() = default;
497
498 // non-copyable, non-movable
499 AidlMember(const AidlMember&) = delete;
500 AidlMember(AidlMember&&) = delete;
501 AidlMember& operator=(const AidlMember&) = delete;
502 AidlMember& operator=(AidlMember&&) = delete;
Jooyung Han3f347ca2020-12-01 12:41:50 +0900503};
504
Steven Moreland541788d2020-05-21 22:05:52 +0000505// TODO: This class is used for method arguments and also parcelable fields,
506// and it should be split up since default values don't apply to method
507// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900508class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700509 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700510 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
511 const std::string& name);
512 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
513 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700514 virtual ~AidlVariableDeclaration() = default;
515
Jiyong Parkd800fef2020-07-22 18:09:43 +0900516 // non-copyable, non-movable
517 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
518 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
519 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
520 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
521
Steven Moreland5557f1c2018-07-02 13:50:23 -0700522 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900523 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900524 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000525 // if this was constructed explicitly with a default value
526 bool IsDefaultUserSpecified() const { return default_user_specified_; }
527 // will return the default value this is constructed with or a default value
528 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700529 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900530 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700531
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900532 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700533
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900534 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900535
536 // ToString is for dumping AIDL.
537 // Returns string representation of this variable decl including default value.
538 // This is "annotations type name default_value?".
539 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700540 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900541
542 // Signature is for comparing AIDL types.
543 // Returns string representation of this variable decl.
544 // This is "type name".
545 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900546 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700547
Steven Moreland860b1942018-08-16 14:59:28 -0700548 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700549
Jooyung Hanc5688f72021-01-05 15:41:48 +0900550 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override;
Jiyong Park45854452020-12-31 10:42:28 +0900551 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900552
Steven Moreland5557f1c2018-07-02 13:50:23 -0700553 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900554 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700555 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000556 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700557 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700558};
559
560class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700561 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700562 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
563
Steven Moreland46e9da82018-07-27 15:45:29 -0700564 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
565 AidlTypeSpecifier* type, const std::string& name);
566 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700567 virtual ~AidlArgument() = default;
568
Jiyong Parkd800fef2020-07-22 18:09:43 +0900569 // non-copyable, non-movable
570 AidlArgument(const AidlArgument&) = delete;
571 AidlArgument(AidlArgument&&) = delete;
572 AidlArgument& operator=(const AidlArgument&) = delete;
573 AidlArgument& operator=(AidlArgument&&) = delete;
574
Casey Dahlinc378c992015-09-29 16:50:40 -0700575 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700576 bool IsOut() const { return direction_ & OUT_DIR; }
577 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700578 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900579 string GetDirectionSpecifier() const;
Jooyung Han020d8d12021-02-26 17:23:02 +0900580 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyad339272015-10-05 19:11:58 -0700581
Jooyung Han965e31d2020-11-27 12:30:16 +0900582 // ToString is for dumping AIDL.
583 // Returns string representation of this argument including direction
584 // This is "direction annotations type name".
585 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700586 std::string ToString() const;
Jiyong Park512ed852020-12-30 15:07:23 +0900587
Jiyong Park45854452020-12-31 10:42:28 +0900588 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700589
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700590 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700591 Direction direction_;
592 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700593};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800594
Jooyung Han020d8d12021-02-26 17:23:02 +0900595struct ArgumentAspect {
596 std::string name;
597 std::set<AidlArgument::Direction> possible_directions;
598};
599
Will McVickerd7d18df2019-09-12 13:40:50 -0700600class AidlUnaryConstExpression;
601class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900602class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700603
Steven Moreland693640b2018-07-19 13:46:27 -0700604class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800605 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700606 enum class Type {
607 // WARNING: Don't change this order! The order is used to determine type
608 // promotion during a binary expression.
609 BOOLEAN,
610 INT8,
611 INT32,
612 INT64,
613 ARRAY,
614 CHARACTER,
615 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900616 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700617 FLOATING,
618 UNARY,
619 BINARY,
620 ERROR,
621 };
622
Jooyung Han535c5e82020-12-29 15:16:59 +0900623 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700624 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900625 T EvaluatedValue() const {
626 is_evaluated_ || (CheckValid() && evaluate());
627 AIDL_FATAL_IF(!is_valid_, this);
628
629 if constexpr (is_vector<T>::value) {
630 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
631 T result;
632 for (const auto& v : values_) {
633 result.push_back(v->EvaluatedValue<typename T::value_type>());
634 }
635 return result;
636 } else if constexpr (is_one_of<T, float, double>::value) {
637 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
638 T result;
639 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
640 return result;
641 } else if constexpr (std::is_same<T, std::string>::value) {
642 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
643 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
644 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
645 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
646 return static_cast<T>(final_value_);
647 } else if constexpr (std::is_same<T, char>::value) {
648 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
649 return final_string_value_.at(1); // unquote '
650 } else if constexpr (std::is_same<T, bool>::value) {
651 static_assert(std::is_same<T, bool>::value, "..");
652 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
653 return final_value_ != 0;
654 } else {
655 static_assert(unsupported_type<T>::value);
656 }
657 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800658
Steven Moreland693640b2018-07-19 13:46:27 -0700659 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800660
Jiyong Parkd800fef2020-07-22 18:09:43 +0900661 // non-copyable, non-movable
662 AidlConstantValue(const AidlConstantValue&) = delete;
663 AidlConstantValue(AidlConstantValue&&) = delete;
664 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
665 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
666
Steven Moreland541788d2020-05-21 22:05:52 +0000667 // creates default value, when one isn't specified
668 // nullptr if no default available
669 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
670
Steven Moreland25294322018-08-07 18:13:55 -0700671 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
672 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700673 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700674 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
675 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700676 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700677 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700678 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700679 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700680
Will McVickerd7d18df2019-09-12 13:40:50 -0700681 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900682 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700683
Devin Moore2a45d0a2022-01-21 22:58:52 +0000684 bool Evaluate() const;
Will McVickerd7d18df2019-09-12 13:40:50 -0700685 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700686
687 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800688 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900689
690 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const {
Jooyung Han29813842020-12-08 01:28:03 +0900691 if (type_ == Type::ARRAY) {
692 for (const auto& v : values_) {
Jooyung Hanc5688f72021-01-05 15:41:48 +0900693 traverse(*v);
Jooyung Han29813842020-12-08 01:28:03 +0900694 }
695 }
696 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900697 void DispatchVisit(AidlVisitor& visitor) const override { visitor.Visit(*this); }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800698
699 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700700 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
701 const string& checked_value);
702 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700703 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900704 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
705 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700706 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700707 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
708 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800709
Jooyung Han74675c22020-12-15 08:39:57 +0900710 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800711
Steven Moreland693640b2018-07-19 13:46:27 -0700712 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700713 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
714 const string value_; // otherwise
715
716 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800717 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
718 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700719 mutable Type final_type_;
720 mutable int64_t final_value_;
721 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700722
Will McVickerd7d18df2019-09-12 13:40:50 -0700723 friend AidlUnaryConstExpression;
724 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900725 friend AidlConstantReference;
726};
727
728// Represents "<type>.<field>" which resolves to a constant which is one of
729// - constant declartion
730// - enumerator
731// When a <type> is missing, <field> is of the enclosing type.
732class AidlConstantReference : public AidlConstantValue {
733 public:
Jooyung Hand0c8af02021-01-06 18:08:01 +0900734 AidlConstantReference(const AidlLocation& location, const std::string& value);
Jooyung Han690f5842020-12-04 13:02:04 +0900735
736 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900737 const std::string& GetFieldName() const { return field_name_; }
Jooyung Han690f5842020-12-04 13:02:04 +0900738
739 bool CheckValid() const override;
Jooyung Han289a1bc2021-05-15 15:04:05 +0900740 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
741 if (ref_type_) {
742 traverse(*ref_type_);
743 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900744 }
745 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900746 const AidlConstantValue* Resolve(const AidlDefinedType* scope) const;
Jooyung Han690f5842020-12-04 13:02:04 +0900747
748 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900749 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900750
751 std::unique_ptr<AidlTypeSpecifier> ref_type_;
752 std::string field_name_;
Jooyung Han9d3cbe22020-12-28 03:02:08 +0900753 mutable const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700754};
755
756class AidlUnaryConstExpression : public AidlConstantValue {
757 public:
758 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
759 std::unique_ptr<AidlConstantValue> rval);
760
761 static bool IsCompatibleType(Type type, const string& op);
762 bool CheckValid() const override;
Jooyung Hanc5688f72021-01-05 15:41:48 +0900763 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
764 traverse(*unary_);
Jooyung Han690f5842020-12-04 13:02:04 +0900765 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900766 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han690f5842020-12-04 13:02:04 +0900767
Will McVickerd7d18df2019-09-12 13:40:50 -0700768 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900769 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700770
771 std::unique_ptr<AidlConstantValue> unary_;
772 const string op_;
773};
774
775class AidlBinaryConstExpression : public AidlConstantValue {
776 public:
777 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
778 const string& op, std::unique_ptr<AidlConstantValue> rval);
779
780 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700781
782 static bool AreCompatibleTypes(Type t1, Type t2);
783 // Returns the promoted kind for both operands
784 static Type UsualArithmeticConversion(Type left, Type right);
785 // Returns the promoted integral type where INT32 is the smallest type
786 static Type IntegralPromotion(Type in);
Jooyung Hanc5688f72021-01-05 15:41:48 +0900787 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
788 traverse(*left_val_);
789 traverse(*right_val_);
Jooyung Han690f5842020-12-04 13:02:04 +0900790 }
Jooyung Hanc5688f72021-01-05 15:41:48 +0900791 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700792
793 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900794 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700795
796 std::unique_ptr<AidlConstantValue> left_val_;
797 std::unique_ptr<AidlConstantValue> right_val_;
798 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700799};
800
Andrei Onea9445fc62019-06-27 18:11:59 +0100801struct AidlAnnotationParameter {
802 std::string name;
803 std::unique_ptr<AidlConstantValue> value;
804};
805
Steven Moreland693640b2018-07-19 13:46:27 -0700806class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700807 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700808 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700809 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700810 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700811
Jiyong Parkd800fef2020-07-22 18:09:43 +0900812 // non-copyable, non-movable
813 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
814 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
815 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
816 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
817
Steven Moreland693640b2018-07-19 13:46:27 -0700818 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700819 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700820 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700821 const AidlConstantValue& GetValue() const { return *value_; }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900822 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700823
Jooyung Han965e31d2020-11-27 12:30:16 +0900824 // ToString is for dumping AIDL.
825 // Returns string representation of this const decl including a const value.
826 // This is "`const` annotations type name value".
827 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700828 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900829
830 // Signature is for comparing types.
831 // Returns string representation of this const decl.
832 // This is "direction annotations type name".
833 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700834 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900835
Steven Moreland860b1942018-08-16 14:59:28 -0700836 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700837 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700838 }
Steven Moreland25294322018-08-07 18:13:55 -0700839
Jooyung Hanc5688f72021-01-05 15:41:48 +0900840 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900841 traverse(GetType());
Jooyung Hanc5688f72021-01-05 15:41:48 +0900842 traverse(GetValue());
Jiyong Park512ed852020-12-30 15:07:23 +0900843 }
Jiyong Park45854452020-12-31 10:42:28 +0900844 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +0900845
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700846 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700847 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700848 const string name_;
849 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800850};
851
852class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700853 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700854 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900855 vector<unique_ptr<AidlArgument>>* args, const Comments& comments);
Will McVickerd7d18df2019-09-12 13:40:50 -0700856 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
Jooyung Han8451a202021-01-16 03:07:06 +0900857 vector<unique_ptr<AidlArgument>>* args, const Comments& comments, int id,
Will McVickerd7d18df2019-09-12 13:40:50 -0700858 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700859 virtual ~AidlMethod() = default;
860
Jiyong Parkd800fef2020-07-22 18:09:43 +0900861 // non-copyable, non-movable
862 AidlMethod(const AidlMethod&) = delete;
863 AidlMethod(AidlMethod&&) = delete;
864 AidlMethod& operator=(const AidlMethod&) = delete;
865 AidlMethod& operator=(AidlMethod&&) = delete;
866
Thiébaud Weksteenff6dafa2021-09-21 11:53:40 +0200867 bool CheckValid(const AidlTypenames&) const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900868 const AidlTypeSpecifier& GetType() const { return *type_; }
869 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800870
Steven Moreland8c70ba92018-12-17 10:20:31 -0800871 // set if this method is part of an interface that is marked oneway
872 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700873 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800874
Casey Dahlinf4a93112015-10-05 16:58:09 -0700875 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700876 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900877 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700878 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700879
Jiyong Park309668e2018-07-28 16:55:44 +0900880 bool IsUserDefined() const { return is_user_defined_; }
881
Casey Dahlinf4a93112015-10-05 16:58:09 -0700882 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700883 return arguments_;
884 }
885 // An inout parameter will appear in both GetInArguments()
886 // and GetOutArguments(). AidlMethod retains ownership of the argument
887 // pointers returned in this way.
888 const std::vector<const AidlArgument*>& GetInArguments() const {
889 return in_arguments_;
890 }
891 const std::vector<const AidlArgument*>& GetOutArguments() const {
892 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700893 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700894
Jooyung Han965e31d2020-11-27 12:30:16 +0900895 // ToString is for dumping AIDL.
896 // Returns string representation of this method including everything.
897 // This is "ret_type name ( arg_list ) = id".
898 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900899 std::string ToString() const;
900
Jooyung Han965e31d2020-11-27 12:30:16 +0900901 // Signature is for comparing AIDL types.
902 // Returns string representation of this method's name & type.
903 // e.g) "foo(int, String)"
904 std::string Signature() const;
905
Jooyung Hanc5688f72021-01-05 15:41:48 +0900906 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jooyung Han865da492021-01-03 11:32:47 +0900907 traverse(GetType());
Jiyong Park512ed852020-12-30 15:07:23 +0900908 for (const auto& a : GetArguments()) {
909 traverse(*a);
910 }
911 }
Jiyong Park45854452020-12-31 10:42:28 +0900912 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han808a2a02020-12-28 16:46:54 +0900913
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700914 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700915 bool oneway_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900916 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700917 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700918 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
919 std::vector<const AidlArgument*> in_arguments_;
920 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700921 bool has_id_;
922 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900923 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700924};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800925
Daniel Norman85aed542019-08-21 12:01:14 -0700926// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900927// defined in the source file.
Jooyung Han2aedb112021-09-29 09:37:59 +0900928class AidlDefinedType : public AidlMember, public AidlScope {
Steven Moreland787b0432018-07-03 09:00:58 -0700929 public:
Jooyung Han8451a202021-01-16 03:07:06 +0900930 AidlDefinedType(const AidlLocation& location, const std::string& name, const Comments& comments,
931 const std::string& package, std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700932 virtual ~AidlDefinedType() = default;
933
Jiyong Parkd800fef2020-07-22 18:09:43 +0900934 // non-copyable, non-movable
935 AidlDefinedType(const AidlDefinedType&) = delete;
936 AidlDefinedType(AidlDefinedType&&) = delete;
937 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
938 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
939
Jiyong Park1deecc32018-07-17 01:14:41 +0900940 const std::string& GetName() const { return name_; };
Jiyong Park1deecc32018-07-17 01:14:41 +0900941
Jooyung Han13f1fa52021-06-11 18:06:12 +0900942 std::string ResolveName(const std::string& name) const override;
943
Steven Moreland787b0432018-07-03 09:00:58 -0700944 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900945 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700946 /* dot joined package and name, example: "android.package.foo.IBar" */
947 std::string GetCanonicalName() const;
Jooyung Han93f48f02021-06-05 00:11:16 +0900948 std::vector<std::string> GetSplitPackage() const {
949 if (package_.empty()) return std::vector<std::string>();
950 return android::base::Split(package_, ".");
951 }
Jooyung Han35784982021-06-29 06:26:12 +0900952 const AidlDocument& GetDocument() const;
Steven Moreland787b0432018-07-03 09:00:58 -0700953
Steven Morelanded83a282018-07-17 13:27:29 -0700954 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700955
Steven Moreland5557f1c2018-07-02 13:50:23 -0700956 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700957 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700958 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900959 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700960 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900961 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900962 virtual bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Hanb4997aa2021-10-16 03:26:12 +0900963 bool LanguageSpecificCheckValid(Options::Language lang) const;
Steven Morelandc258abc2018-07-10 14:03:38 -0700964 AidlStructuredParcelable* AsStructuredParcelable() {
965 return const_cast<AidlStructuredParcelable*>(
966 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
967 }
968 AidlParcelable* AsParcelable() {
969 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
970 }
Daniel Norman85aed542019-08-21 12:01:14 -0700971 AidlEnumDeclaration* AsEnumDeclaration() {
972 return const_cast<AidlEnumDeclaration*>(
973 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
974 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900975 AidlUnionDecl* AsUnionDeclaration() {
976 return const_cast<AidlUnionDecl*>(
977 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
978 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700979 AidlInterface* AsInterface() {
980 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
981 }
982
Jeongik Chadf76dc72019-11-28 00:08:47 +0900983 AidlParameterizable<std::string>* AsParameterizable() {
984 return const_cast<AidlParameterizable<std::string>*>(
985 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
986 }
987
Steven Moreland6cee3482018-07-18 14:39:58 -0700988 const AidlParcelable* AsUnstructuredParcelable() const {
989 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900990 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700991 return this->AsParcelable();
992 }
993 AidlParcelable* AsUnstructuredParcelable() {
994 return const_cast<AidlParcelable*>(
995 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
996 }
Jooyung Han2aedb112021-09-29 09:37:59 +0900997 const AidlDefinedType* GetParentType() const;
Jooyung Hanf8c39632021-10-05 09:56:29 +0900998 const AidlDefinedType* GetRootType() const;
Jooyung Han2aedb112021-09-29 09:37:59 +0900999 const std::vector<std::unique_ptr<AidlDefinedType>>& GetNestedTypes() const { return types_; }
Jooyung Han829ec7c2020-12-02 12:07:36 +09001000 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
1001 return variables_;
1002 }
1003 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
1004 return constants_;
1005 }
1006 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
Jooyung Han1bd54482021-10-14 11:40:39 +09001007 void AddMethod(std::unique_ptr<AidlMethod> method) {
1008 members_.push_back(method.get());
1009 methods_.push_back(std::move(method));
1010 }
Jooyung Han829ec7c2020-12-02 12:07:36 +09001011 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
Jooyung Hanc5688f72021-01-05 15:41:48 +09001012 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1013 AidlAnnotatable::TraverseChildren(traverse);
1014 for (const auto c : GetMembers()) {
1015 traverse(*c);
1016 }
1017 }
Jiyong Park512ed852020-12-30 15:07:23 +09001018
Jooyung Han829ec7c2020-12-02 12:07:36 +09001019 protected:
1020 // utility for subclasses with getter names
1021 bool CheckValidForGetterNames() const;
1022
Steven Moreland787b0432018-07-03 09:00:58 -07001023 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +09001024 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
1025
Jiyong Park1deecc32018-07-17 01:14:41 +09001026 std::string name_;
Jooyung Han93f48f02021-06-05 00:11:16 +09001027 std::string package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +09001028 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
1029 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
1030 std::vector<std::unique_ptr<AidlMethod>> methods_;
Jooyung Han2aedb112021-09-29 09:37:59 +09001031 std::vector<std::unique_ptr<AidlDefinedType>> types_;
Jooyung Han829ec7c2020-12-02 12:07:36 +09001032 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -07001033};
1034
Jeongik Chadf76dc72019-11-28 00:08:47 +09001035class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001036 public:
Jiyong Park18132182020-06-08 20:24:40 +09001037 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001038 const Comments& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +09001039 std::vector<std::string>* type_params = nullptr,
1040 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001041 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -08001042
Jiyong Parkd800fef2020-07-22 18:09:43 +09001043 // non-copyable, non-movable
1044 AidlParcelable(const AidlParcelable&) = delete;
1045 AidlParcelable(AidlParcelable&&) = delete;
1046 AidlParcelable& operator=(const AidlParcelable&) = delete;
1047 AidlParcelable& operator=(AidlParcelable&&) = delete;
1048
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001049 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001050
Jooyung Han808a2a02020-12-28 16:46:54 +09001051 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -07001052 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +09001053 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
1054 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001055 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -07001056
Jiyong Park45854452020-12-31 10:42:28 +09001057 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001058
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001059 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -08001060 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001061};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001062
Jooyung Han829ec7c2020-12-02 12:07:36 +09001063class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -07001064 public:
Jiyong Park18132182020-06-08 20:24:40 +09001065 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
Jooyung Han8451a202021-01-16 03:07:06 +09001066 const std::string& package, const Comments& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001067 std::vector<std::string>* type_params,
1068 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001069 virtual ~AidlStructuredParcelable() = default;
1070
1071 // non-copyable, non-movable
1072 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
1073 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
1074 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
1075 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001076
Steven Morelandc258abc2018-07-10 14:03:38 -07001077 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001078 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001079
Jooyung Han808a2a02020-12-28 16:46:54 +09001080 bool CheckValid(const AidlTypenames& typenames) const override;
Jiyong Park45854452020-12-31 10:42:28 +09001081 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001082};
1083
Jooyung Han5c7e77c2021-01-20 16:00:29 +09001084class AidlEnumerator : public AidlCommentable {
Daniel Norman85aed542019-08-21 12:01:14 -07001085 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001086 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
Jooyung Han8451a202021-01-16 03:07:06 +09001087 const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001088 virtual ~AidlEnumerator() = default;
1089
Jiyong Parkd800fef2020-07-22 18:09:43 +09001090 // non-copyable, non-movable
1091 AidlEnumerator(const AidlEnumerator&) = delete;
1092 AidlEnumerator(AidlEnumerator&&) = delete;
1093 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1094 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1095
Daniel Norman85aed542019-08-21 12:01:14 -07001096 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001097 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman85aed542019-08-21 12:01:14 -07001098 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1099
1100 string ValueString(const AidlTypeSpecifier& backing_type,
1101 const ConstantValueDecorator& decorator) const;
1102
Daniel Normanb28684e2019-10-17 15:31:39 -07001103 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001104 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001105
Jooyung Hanc5688f72021-01-05 15:41:48 +09001106 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1107 traverse(*value_);
Jiyong Park512ed852020-12-30 15:07:23 +09001108 }
Jiyong Park45854452020-12-31 10:42:28 +09001109 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001110
Daniel Norman85aed542019-08-21 12:01:14 -07001111 private:
1112 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001113 unique_ptr<AidlConstantValue> value_;
Jooyung Han29813842020-12-08 01:28:03 +09001114 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001115};
1116
1117class AidlEnumDeclaration : public AidlDefinedType {
1118 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001119 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001120 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jooyung Han8451a202021-01-16 03:07:06 +09001121 const std::string& package, const Comments& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001122 virtual ~AidlEnumDeclaration() = default;
1123
Jiyong Parkd800fef2020-07-22 18:09:43 +09001124 // non-copyable, non-movable
1125 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1126 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1127 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1128 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1129
Jooyung Han672557b2020-12-24 05:18:00 +09001130 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001131 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1132 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1133 return enumerators_;
1134 }
Jooyung Han808a2a02020-12-28 16:46:54 +09001135 bool CheckValid(const AidlTypenames& typenames) const override;
Daniel Norman85aed542019-08-21 12:01:14 -07001136 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Daniel Norman85aed542019-08-21 12:01:14 -07001137
1138 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1139
Jooyung Hanc5688f72021-01-05 15:41:48 +09001140 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
1141 AidlDefinedType::TraverseChildren(traverse);
Jooyung Hanca84b032021-09-30 02:15:59 +09001142 if (backing_type_) {
1143 traverse(*backing_type_);
1144 }
Jiyong Park512ed852020-12-30 15:07:23 +09001145 for (const auto& c : GetEnumerators()) {
1146 traverse(*c);
1147 }
1148 }
Jiyong Park45854452020-12-31 10:42:28 +09001149 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001150
Daniel Norman85aed542019-08-21 12:01:14 -07001151 private:
Jooyung Han29813842020-12-08 01:28:03 +09001152
Daniel Norman85aed542019-08-21 12:01:14 -07001153 const std::string name_;
1154 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001155 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001156};
1157
Jooyung Han829ec7c2020-12-02 12:07:36 +09001158class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001159 public:
1160 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han8451a202021-01-16 03:07:06 +09001161 const Comments& comments, std::vector<std::string>* type_params,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001162 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001163 virtual ~AidlUnionDecl() = default;
1164
1165 // non-copyable, non-movable
1166 AidlUnionDecl(const AidlUnionDecl&) = delete;
1167 AidlUnionDecl(AidlUnionDecl&&) = delete;
1168 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1169 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1170
Jooyung Han2946afc2020-10-05 20:29:16 +09001171
1172 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001173 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001174 std::string GetPreprocessDeclarationName() const override { return "union"; }
1175
Jooyung Han2946afc2020-10-05 20:29:16 +09001176 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jiyong Park45854452020-12-31 10:42:28 +09001177 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jooyung Han2946afc2020-10-05 20:29:16 +09001178};
1179
Jiyong Park1deecc32018-07-17 01:14:41 +09001180class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001181 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001182 AidlInterface(const AidlLocation& location, const std::string& name, const Comments& comments,
Jooyung Handb4d8a62021-06-22 10:09:42 +09001183 bool oneway, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001184 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001185 virtual ~AidlInterface() = default;
1186
Jiyong Parkd800fef2020-07-22 18:09:43 +09001187 // non-copyable, non-movable
1188 AidlInterface(const AidlInterface&) = delete;
1189 AidlInterface(AidlInterface&&) = delete;
1190 AidlInterface& operator=(const AidlInterface&) = delete;
1191 AidlInterface& operator=(AidlInterface&&) = delete;
1192
Steven Morelandc258abc2018-07-10 14:03:38 -07001193 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001194 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001195
Jooyung Han808a2a02020-12-28 16:46:54 +09001196 bool CheckValid(const AidlTypenames& typenames) const override;
Thiébaud Weksteene79243a2021-11-02 14:36:25 +11001197 bool CheckValidPermissionAnnotations(const AidlMethod& m) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001198 std::string GetDescriptor() const;
Jiyong Park45854452020-12-31 10:42:28 +09001199 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001200};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001201
Jooyung Hancdf89ec2021-10-29 14:08:30 +09001202inline std::string SimpleName(const std::string& qualified_name) {
1203 return qualified_name.substr(qualified_name.rfind('.') + 1);
1204}
Casey Dahline2507492015-09-14 17:11:20 -07001205
Jiyong Park62515512020-06-08 15:57:11 +09001206// AidlDocument models an AIDL file
Jooyung Han13f1fa52021-06-11 18:06:12 +09001207class AidlDocument : public AidlCommentable, public AidlScope {
Jiyong Park62515512020-06-08 15:57:11 +09001208 public:
Jooyung Han8451a202021-01-16 03:07:06 +09001209 AidlDocument(const AidlLocation& location, const Comments& comments,
Jooyung Hanf08c15f2022-01-28 14:57:13 +09001210 std::vector<std::string> imports,
Jooyung Han35784982021-06-29 06:26:12 +09001211 std::vector<std::unique_ptr<AidlDefinedType>> defined_types, bool is_preprocessed);
Jiyong Parkd800fef2020-07-22 18:09:43 +09001212 ~AidlDocument() = default;
1213
1214 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001215 AidlDocument(const AidlDocument&) = delete;
1216 AidlDocument(AidlDocument&&) = delete;
1217 AidlDocument& operator=(const AidlDocument&) = delete;
1218 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001219
Jooyung Han13f1fa52021-06-11 18:06:12 +09001220 std::string ResolveName(const std::string& name) const override;
Jooyung Hanf08c15f2022-01-28 14:57:13 +09001221 const std::vector<std::string>& Imports() const { return imports_; }
Jiyong Parkd800fef2020-07-22 18:09:43 +09001222 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1223 return defined_types_;
1224 }
Jooyung Han35784982021-06-29 06:26:12 +09001225 bool IsPreprocessed() const { return is_preprocessed_; }
Jiyong Park62515512020-06-08 15:57:11 +09001226
Jooyung Hanc5688f72021-01-05 15:41:48 +09001227 void TraverseChildren(std::function<void(const AidlNode&)> traverse) const override {
Jiyong Park512ed852020-12-30 15:07:23 +09001228 for (const auto& t : DefinedTypes()) {
1229 traverse(*t);
1230 }
1231 }
Jiyong Park45854452020-12-31 10:42:28 +09001232 void DispatchVisit(AidlVisitor& v) const override { v.Visit(*this); }
Jiyong Park512ed852020-12-30 15:07:23 +09001233
Jiyong Park62515512020-06-08 15:57:11 +09001234 private:
Jooyung Hanf08c15f2022-01-28 14:57:13 +09001235 const std::vector<std::string> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001236 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jooyung Han35784982021-06-29 06:26:12 +09001237 bool is_preprocessed_;
Jiyong Park62515512020-06-08 15:57:11 +09001238};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001239
1240template <typename T>
1241std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1242 auto it = parameters_.find(param_name);
1243 if (it == parameters_.end()) {
1244 return std::nullopt;
1245 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001246 return it->second->EvaluatedValue<T>();
Jiyong Park512ed852020-12-30 15:07:23 +09001247}
Jooyung Hanc5688f72021-01-05 15:41:48 +09001248
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001249// Utilities to make a visitor to visit AST tree in top-down order
Jooyung Hanc5688f72021-01-05 15:41:48 +09001250// Given: foo
1251// / \
1252// bar baz
1253// VisitTopDown(v, foo) makes v visit foo -> bar -> baz.
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001254inline void VisitTopDown(std::function<void(const AidlNode&)> v, const AidlNode& node) {
Jooyung Hanc5688f72021-01-05 15:41:48 +09001255 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001256 v(n);
Jooyung Hanc5688f72021-01-05 15:41:48 +09001257 n.TraverseChildren(top_down);
1258 };
1259 top_down(node);
Jooyung Han289a1bc2021-05-15 15:04:05 +09001260}
Jooyung Han2b3cd2a2021-10-15 06:54:55 +09001261inline void VisitTopDown(AidlVisitor& v, const AidlNode& node) {
1262 VisitTopDown([&](const AidlNode& n) { n.DispatchVisit(v); }, node);
1263}
Jooyung Han289a1bc2021-05-15 15:04:05 +09001264
1265// Utility to make a visitor to visit AST tree in bottom-up order
1266// Given: foo
1267// / \
1268// bar baz
1269// VisitBottomUp(v, foo) makes v visit bar -> baz -> foo.
1270inline void VisitBottomUp(AidlVisitor& v, const AidlNode& node) {
1271 std::function<void(const AidlNode&)> bottom_up = [&](const AidlNode& n) {
1272 n.TraverseChildren(bottom_up);
1273 n.DispatchVisit(v);
1274 };
1275 bottom_up(node);
Thiébaud Weksteen5a4db212021-09-02 17:09:34 +02001276}
Jooyung Hanbaa71062021-09-29 09:06:03 +09001277
1278template <typename T>
1279const T* AidlCast(const AidlNode& node) {
1280 struct CastVisitor : AidlVisitor {
1281 const T* cast = nullptr;
1282 void Visit(const T& t) override { cast = &t; }
1283 } visitor;
1284 node.DispatchVisit(visitor);
1285 return visitor.cast;
1286}
1287
1288template <>
1289const AidlDefinedType* AidlCast<AidlDefinedType>(const AidlNode& node);
1290
1291template <typename T>
1292T* AidlCast(AidlNode& node) {
1293 return const_cast<T*>(AidlCast<T>(const_cast<const AidlNode&>(node)));
1294}
Jooyung Han8e9ae872021-10-13 02:52:25 +09001295
1296template <typename AidlNodeType>
1297vector<const AidlNodeType*> Collect(const AidlNode& root) {
1298 vector<const AidlNodeType*> result;
1299 std::function<void(const AidlNode&)> top_down = [&](const AidlNode& n) {
1300 if (auto cast = AidlCast<AidlNodeType>(n); cast) {
1301 result.push_back(cast);
1302 }
1303 n.TraverseChildren(top_down);
1304 };
1305 top_down(root);
1306 return result;
1307}
1308
1309template <typename VisitFn>
1310bool TopologicalVisit(const vector<unique_ptr<AidlDefinedType>>& nested_types, VisitFn visit) {
1311 // 1. Maps deeply nested types to one of nested_types
1312 map<const AidlDefinedType*, const AidlDefinedType*> roots;
1313 for (const auto& nested : nested_types) {
1314 for (const auto& t : Collect<AidlDefinedType>(*nested)) {
1315 roots[t] = nested.get();
1316 }
1317 }
1318 // 2. Collect sibling types referenced within each nested type.
1319 map<const AidlDefinedType*, vector<const AidlDefinedType*>> required_types;
1320 for (const auto& nested : nested_types) {
1321 for (const auto& t : Collect<AidlTypeSpecifier>(*nested)) {
1322 if (auto defined_type = t->GetDefinedType(); defined_type) {
1323 auto sibling = roots[defined_type];
1324 if (sibling && sibling != nested.get()) {
1325 required_types[nested.get()].push_back(sibling);
1326 }
1327 }
1328 }
1329 };
1330 // 3. Run DFS
1331 enum { NOT_STARTED = 0, STARTED = 1, FINISHED = 2 };
1332 map<const AidlDefinedType*, int> visited;
1333 std::function<bool(const AidlDefinedType&)> dfs = [&](const AidlDefinedType& type) {
1334 if (visited[&type] == FINISHED) {
1335 return true;
1336 } else if (visited[&type] == STARTED) {
1337 return false;
1338 } else {
1339 visited[&type] = STARTED;
1340 // Visit every required dep first
1341 for (const auto& dep_type : required_types[&type]) {
1342 if (!dfs(*dep_type)) {
1343 return false;
1344 }
1345 }
1346 visited[&type] = FINISHED;
1347 visit(type);
1348 return true;
1349 }
1350 };
1351
1352 for (const auto& type : nested_types) {
1353 if (!dfs(*type)) {
1354 return false;
1355 }
1356 }
1357
1358 return true;
1359}