blob: dfc9d1ff60905775787c3d94aa971537156a2726 [file] [log] [blame]
Will McVickerd7d18df2019-09-12 13:40:50 -07001/*
2 * Copyright (C) 2019, The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Steven Moreland9fccf582018-08-27 20:36:27 -070017#pragma once
Christopher Wileyec31a052016-01-25 07:28:51 -080018
Casey Dahlinbc7a50a2015-09-28 19:20:50 -070019#include <memory>
Jeongik Cha997281d2020-01-16 15:23:59 +090020#include <regex>
Casey Dahlindd691812015-09-09 17:59:06 -070021#include <string>
Jeongik Chadf76dc72019-11-28 00:08:47 +090022#include <unordered_set>
Casey Dahlinbc7a50a2015-09-28 19:20:50 -070023#include <vector>
Casey Dahlindd691812015-09-09 17:59:06 -070024
Elliott Hughes0a620672015-12-04 13:53:18 -080025#include <android-base/strings.h>
Casey Dahlin73d46b02015-09-11 02:47:54 +000026
Jooyung Han888c5bc2020-12-22 17:28:47 +090027#include "aidl_typenames.h"
28#include "code_writer.h"
29#include "diagnostics.h"
30#include "io_delegate.h"
Jooyung Han535c5e82020-12-29 15:16:59 +090031#include "location.h"
32#include "logging.h"
Jooyung Han888c5bc2020-12-22 17:28:47 +090033#include "options.h"
34
Jiyong Parkb034bf02018-07-30 17:44:33 +090035using android::aidl::AidlTypenames;
Jiyong Park02da7422018-07-16 16:00:26 +090036using android::aidl::CodeWriter;
Jooyung Han888c5bc2020-12-22 17:28:47 +090037using android::aidl::DiagnosticsContext;
Jeongik Cha047c5ee2019-08-07 23:16:49 +090038using android::aidl::Options;
Steven Moreland3f658cf2018-08-20 13:40:54 -070039using std::shared_ptr;
Jiyong Park1deecc32018-07-17 01:14:41 +090040using std::string;
41using std::unique_ptr;
42using std::vector;
Andrei Onea8714b022019-02-01 18:55:54 +000043class AidlNode;
44
Jooyung Han535c5e82020-12-29 15:16:59 +090045// helper to see if T is the same to one of Args types.
46template <typename T, typename... Args>
47struct is_one_of : std::false_type {};
48
49template <typename T, typename S, typename... Args>
50struct is_one_of<T, S, Args...> {
51 enum { value = std::is_same_v<T, S> || is_one_of<T, Args...>::value };
52};
53
54// helper to see if T is std::vector of something.
55template <typename>
56struct is_vector : std::false_type {};
57
58template <typename T>
59struct is_vector<std::vector<T>> : std::true_type {};
60
61// helper for static_assert(false)
62template <typename T>
63struct unsupported_type : std::false_type {};
64
Andrei Onea8714b022019-02-01 18:55:54 +000065namespace android {
66namespace aidl {
67namespace mappings {
68std::string dump_location(const AidlNode& method);
69} // namespace mappings
Mathew Inwoodadb74672019-11-29 14:01:53 +000070namespace java {
71std::string dump_location(const AidlNode& method);
72} // namespace java
Andrei Onea8714b022019-02-01 18:55:54 +000073} // namespace aidl
74} // namespace android
75
Jooyung Han535c5e82020-12-29 15:16:59 +090076bool ParseFloating(std::string_view sv, double* parsed);
77bool ParseFloating(std::string_view sv, float* parsed);
Steven Moreland46e9da82018-07-27 15:45:29 -070078
Jooyung Han808a2a02020-12-28 16:46:54 +090079class AidlDocument;
80class AidlInterface;
81class AidlParcelable;
82class AidlStructuredParcelable;
83class AidlEnumDeclaration;
84class AidlUnionDecl;
85class AidlVariableDeclaration;
86class AidlConstantDeclaration;
87class AidlEnumerator;
88class AidlMethod;
89class AidlArgument;
90
91class AidlVisitor {
92 public:
93 virtual ~AidlVisitor() = default;
94 virtual void VisitDocument(const AidlDocument& d) = 0;
95 virtual void VisitInterface(const AidlInterface& i) = 0;
96 virtual void VisitUnstructuredParcelable(const AidlParcelable& p) = 0;
97 virtual void VisitStructuredParcelable(const AidlStructuredParcelable& p) = 0;
98 virtual void VisitUnion(const AidlUnionDecl& u) = 0;
99 virtual void VisitEnum(const AidlEnumDeclaration& e) = 0;
100 virtual void VisitEnumerator(const AidlEnumerator& e) = 0;
101 virtual void VisitMethod(const AidlMethod& m) = 0;
102 virtual void VisitVariable(const AidlVariableDeclaration& v) = 0;
103 virtual void VisitConstant(const AidlConstantDeclaration& c) = 0;
104 virtual void VisitArgument(const AidlArgument& a) = 0;
105};
106
107// Provides default implementation which visits child nodes.
108// In a derived class, call super method to visit chid nodes.
109// Calling super method first visits nodes in bottom-up way.
110class AidlVisitAll : public AidlVisitor {
111 public:
112 void VisitDocument(const AidlDocument& d) override;
113 void VisitInterface(const AidlInterface& i) override;
114 void VisitUnstructuredParcelable(const AidlParcelable& p) override;
115 void VisitStructuredParcelable(const AidlStructuredParcelable& p) override;
116 void VisitUnion(const AidlUnionDecl& u) override;
117 void VisitEnum(const AidlEnumDeclaration& e) override;
118 void VisitEnumerator(const AidlEnumerator& e) override;
119 void VisitMethod(const AidlMethod& m) override;
120 void VisitVariable(const AidlVariableDeclaration& v) override;
121 void VisitConstant(const AidlConstantDeclaration& c) override;
122 void VisitArgument(const AidlArgument& a) override;
123};
124
Steven Moreland46e9da82018-07-27 15:45:29 -0700125// Anything that is locatable in a .aidl file.
126class AidlNode {
127 public:
128 AidlNode(const AidlLocation& location);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700129
130 AidlNode(const AidlNode&) = default;
Steven Moreland46e9da82018-07-27 15:45:29 -0700131 virtual ~AidlNode() = default;
132
Jiyong Parkd800fef2020-07-22 18:09:43 +0900133 AidlNode(AidlNode&&) = delete;
134 AidlNode& operator=(AidlNode&&) = delete;
135
Devin Mooredf93ebb2020-03-25 14:03:35 -0700136 // To be able to print AidlLocation
Steven Morelandb0d15a52020-03-31 14:03:47 -0700137 friend class AidlErrorLog;
Andrei Onea8714b022019-02-01 18:55:54 +0000138 friend std::string android::aidl::mappings::dump_location(const AidlNode&);
Mathew Inwoodadb74672019-11-29 14:01:53 +0000139 friend std::string android::aidl::java::dump_location(const AidlNode&);
Steven Moreland46e9da82018-07-27 15:45:29 -0700140
Devin Mooredf93ebb2020-03-25 14:03:35 -0700141 const AidlLocation& GetLocation() const { return location_; }
142
Steven Moreland46e9da82018-07-27 15:45:29 -0700143 private:
Mathew Inwoodadb74672019-11-29 14:01:53 +0000144 std::string PrintLine() const;
Andrei Onea8714b022019-02-01 18:55:54 +0000145 std::string PrintLocation() const;
Steven Moreland46e9da82018-07-27 15:45:29 -0700146 const AidlLocation location_;
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700147};
148
Jeongik Chadf76dc72019-11-28 00:08:47 +0900149// unique_ptr<AidlTypeSpecifier> for type arugment,
150// std::string for type parameter(T, U, and so on).
151template <typename T>
152class AidlParameterizable {
153 public:
154 AidlParameterizable(std::vector<T>* type_params) : type_params_(type_params) {}
155 virtual ~AidlParameterizable() = default;
156 bool IsGeneric() const { return type_params_ != nullptr; }
157 const std::vector<T>& GetTypeParameters() const { return *type_params_; }
158 bool CheckValid() const;
159
Steven Moreland6c07b832020-10-29 23:39:53 +0000160 __attribute__((warn_unused_result)) bool SetTypeParameters(std::vector<T>* type_params) {
161 if (type_params_) return false;
162 type_params_.reset(type_params);
163 return true;
164 }
165
Jeongik Chadf76dc72019-11-28 00:08:47 +0900166 virtual const AidlNode& AsAidlNode() const = 0;
167
168 protected:
169 AidlParameterizable(const AidlParameterizable&);
170
171 private:
Steven Moreland6c07b832020-10-29 23:39:53 +0000172 unique_ptr<std::vector<T>> type_params_;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900173 static_assert(std::is_same<T, unique_ptr<AidlTypeSpecifier>>::value ||
174 std::is_same<T, std::string>::value);
175};
176template <>
177bool AidlParameterizable<std::string>::CheckValid() const;
178
Andrei Onea9445fc62019-06-27 18:11:59 +0100179class AidlConstantValue;
180class AidlConstantDeclaration;
181
182// Transforms a value string into a language specific form. Raw value as produced by
183// AidlConstantValue.
184using ConstantValueDecorator =
185 std::function<std::string(const AidlTypeSpecifier& type, const std::string& raw_value)>;
186
Jiyong Park68bc77a2018-07-19 19:00:45 +0900187class AidlAnnotation : public AidlNode {
188 public:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700189 enum class Type {
190 BACKING = 1,
191 HIDE,
192 JAVA_STABLE_PARCELABLE,
193 UNSUPPORTED_APP_USAGE,
194 VINTF_STABILITY,
195 NULLABLE,
196 UTF8_IN_CPP,
Steven Morelanda7764e52020-10-27 17:29:29 +0000197 SENSITIVE_DATA,
Jiyong Parkbf5fd5c2020-06-05 19:48:05 +0900198 JAVA_PASSTHROUGH,
Jooyung Han90345002020-10-23 15:28:53 +0900199 JAVA_DERIVE,
Jeongik Chad0a10272020-08-06 16:33:36 +0900200 JAVA_ONLY_IMMUTABLE,
Devin Moorec7e47a32020-08-07 10:55:25 -0700201 FIXED_SIZE,
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900202 DESCRIPTOR,
Andrei Homescue61feb52020-08-18 15:44:24 -0700203 RUST_DERIVE,
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900204 SUPPRESS_WARNINGS,
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700205 };
206 static std::string TypeToString(Type type);
207
Andrei Onea9445fc62019-06-27 18:11:59 +0100208 static AidlAnnotation* Parse(
209 const AidlLocation& location, const string& name,
210 std::map<std::string, std::shared_ptr<AidlConstantValue>>* parameter_list);
Steven Moreland46e9da82018-07-27 15:45:29 -0700211
Steven Moreland3f658cf2018-08-20 13:40:54 -0700212 AidlAnnotation(const AidlAnnotation&) = default;
Steven Moreland3be75772018-08-20 13:27:43 -0700213 AidlAnnotation(AidlAnnotation&&) = default;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900214 virtual ~AidlAnnotation() = default;
Andrei Onea9445fc62019-06-27 18:11:59 +0100215 bool CheckValid() const;
Steven Moreland3be75772018-08-20 13:27:43 -0700216
Jooyung Hand902a972020-10-23 17:32:44 +0900217 const string& GetName() const { return schema_.name; }
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700218 const Type& GetType() const { return schema_.type; }
Jooyung Hand902a972020-10-23 17:32:44 +0900219 bool Repeatable() const { return schema_.repeatable; }
Jooyung Han965e31d2020-11-27 12:30:16 +0900220
221 // ToString is for dumping AIDL.
222 // Returns string representation of this annotation.
223 // e.g) "@RustDerive(Clone=true, Copy=true)"
224 string ToString() const;
225
Jooyung Hanb3c77ed2020-12-26 02:02:45 +0900226 template <typename T>
227 std::optional<T> ParamValue(const std::string& param_name) const;
228
Andrei Onea9445fc62019-06-27 18:11:59 +0100229 std::map<std::string, std::string> AnnotationParams(
230 const ConstantValueDecorator& decorator) const;
Jiyong Parka6605ab2018-11-11 14:30:21 +0900231 const string& GetComments() const { return comments_; }
232 void SetComments(const string& comments) { comments_ = comments; }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900233
234 private:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700235 struct Schema {
236 AidlAnnotation::Type type;
237
238 // text name in .aidl file, e.g. "nullable"
239 std::string name;
240
241 // map from param name -> value type
Jooyung Han5c2fcae2020-12-26 00:04:39 +0900242 std::map<std::string, const AidlTypeSpecifier&> supported_parameters;
Jooyung Hand902a972020-10-23 17:32:44 +0900243
244 bool repeatable;
Jooyung Han5721a232020-12-24 04:34:55 +0900245
246 std::vector<std::string> required_parameters = {};
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700247 };
248 static const std::vector<Schema>& AllSchemas();
249
250 AidlAnnotation(const AidlLocation& location, const Schema& schema,
Andrei Onea9445fc62019-06-27 18:11:59 +0100251 std::map<std::string, std::shared_ptr<AidlConstantValue>>&& parameters);
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700252
253 const Schema& schema_;
Jiyong Parka6605ab2018-11-11 14:30:21 +0900254 string comments_;
Andrei Onea9445fc62019-06-27 18:11:59 +0100255 std::map<std::string, std::shared_ptr<AidlConstantValue>> parameters_;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900256};
257
Steven Moreland3be75772018-08-20 13:27:43 -0700258static inline bool operator<(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
259 return lhs.GetName() < rhs.GetName();
260}
261static inline bool operator==(const AidlAnnotation& lhs, const AidlAnnotation& rhs) {
262 return lhs.GetName() == rhs.GetName();
263}
Jiyong Park3656c3c2018-08-01 20:02:01 +0900264
Casey Dahline7922932016-02-29 17:23:01 -0800265class AidlAnnotatable : public AidlNode {
Casey Dahlin0ee37582015-09-30 16:31:55 -0700266 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700267 AidlAnnotatable(const AidlLocation& location);
Steven Moreland3f658cf2018-08-20 13:40:54 -0700268
269 AidlAnnotatable(const AidlAnnotatable&) = default;
270 AidlAnnotatable(AidlAnnotatable&&) = default;
Casey Dahline7922932016-02-29 17:23:01 -0800271 virtual ~AidlAnnotatable() = default;
272
Artur Satayev91fe8712019-07-29 13:06:01 +0100273 void Annotate(vector<AidlAnnotation>&& annotations) {
274 for (auto& annotation : annotations) {
275 annotations_.emplace_back(std::move(annotation));
276 }
277 }
Jiyong Park68bc77a2018-07-19 19:00:45 +0900278 bool IsNullable() const;
Jiyong Park68bc77a2018-07-19 19:00:45 +0900279 bool IsUtf8InCpp() const;
Steven Morelanda7764e52020-10-27 17:29:29 +0000280 bool IsSensitiveData() const;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700281 bool IsVintfStability() const;
Jeongik Chad0a10272020-08-06 16:33:36 +0900282 bool IsJavaOnlyImmutable() const;
Devin Moorec7e47a32020-08-07 10:55:25 -0700283 bool IsFixedSize() const;
Jeongik Cha88f95a82020-01-15 13:02:16 +0900284 bool IsStableApiParcelable(Options::Language lang) const;
Makoto Onuki78a1c1c2020-03-04 16:57:23 -0800285 bool IsHide() const;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900286 bool JavaDerive(const std::string& method) const;
Jiyong Park27fd7fd2020-08-27 16:25:09 +0900287 std::string GetDescriptor() const;
Andrei Onea9445fc62019-06-27 18:11:59 +0100288
Steven Moreland7e4b9502020-02-20 18:10:42 -0800289 void DumpAnnotations(CodeWriter* writer) const;
290
Andrei Onea9445fc62019-06-27 18:11:59 +0100291 const AidlAnnotation* UnsupportedAppUsage() const;
Andrei Homescue61feb52020-08-18 15:44:24 -0700292 const AidlAnnotation* RustDerive() const;
Jooyung Han672557b2020-12-24 05:18:00 +0900293 const AidlAnnotation* BackingType() const;
Jooyung Hanf8dbbcc2020-12-26 03:05:55 +0900294 std::vector<std::string> SuppressWarnings() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900295
296 // ToString is for dumping AIDL.
297 // Returns string representation of annotations.
298 // e.g) "@JavaDerive(toString=true) @RustDerive(Clone=true, Copy=true)"
Jiyong Park68bc77a2018-07-19 19:00:45 +0900299 std::string ToString() const;
Casey Dahline7922932016-02-29 17:23:01 -0800300
Jiyong Parka6605ab2018-11-11 14:30:21 +0900301 const vector<AidlAnnotation>& GetAnnotations() const { return annotations_; }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900302 bool CheckValid(const AidlTypenames&) const;
Jiyong Park3656c3c2018-08-01 20:02:01 +0900303
Steven Moreland181144c2020-04-20 19:57:56 -0700304 protected:
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700305 virtual std::set<AidlAnnotation::Type> GetSupportedAnnotations() const = 0;
Steven Moreland181144c2020-04-20 19:57:56 -0700306
Casey Dahline7922932016-02-29 17:23:01 -0800307 private:
Jiyong Parka6605ab2018-11-11 14:30:21 +0900308 vector<AidlAnnotation> annotations_;
Casey Dahline7922932016-02-29 17:23:01 -0800309};
310
Jiyong Park1deecc32018-07-17 01:14:41 +0900311// AidlTypeSpecifier represents a reference to either a built-in type,
312// a defined type, or a variant (e.g., array of generic) of a type.
Jeongik Chadf76dc72019-11-28 00:08:47 +0900313class AidlTypeSpecifier final : public AidlAnnotatable,
314 public AidlParameterizable<unique_ptr<AidlTypeSpecifier>> {
Casey Dahline7922932016-02-29 17:23:01 -0800315 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700316 AidlTypeSpecifier(const AidlLocation& location, const string& unresolved_name, bool is_array,
317 vector<unique_ptr<AidlTypeSpecifier>>* type_params, const string& comments);
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900318 virtual ~AidlTypeSpecifier() = default;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700319
Steven Moreland3f658cf2018-08-20 13:40:54 -0700320 // Copy of this type which is not an array.
Jooyung Hand2fa0232020-10-19 02:51:41 +0900321 const AidlTypeSpecifier& ArrayBase() const;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700322
Jiyong Park1deecc32018-07-17 01:14:41 +0900323 // Returns the full-qualified name of the base type.
324 // int -> int
325 // int[] -> int
326 // List<String> -> List
327 // IFoo -> foo.bar.IFoo (if IFoo is in package foo.bar)
328 const string& GetName() const {
329 if (IsResolved()) {
330 return fully_qualified_name_;
331 } else {
332 return GetUnresolvedName();
333 }
334 }
Casey Dahlin0ee37582015-09-30 16:31:55 -0700335
Jooyung Han965e31d2020-11-27 12:30:16 +0900336 // ToString is for dumping AIDL.
337 // Returns string representation of this type specifier including annotations.
338 // This is "annotations type_name type_params? array_marker?".
339 // e.g) "@utf8InCpp String[]";
340 std::string ToString() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900341
Jooyung Han965e31d2020-11-27 12:30:16 +0900342 // Signature is for comparing AIDL types.
343 // Returns string representation of this type specifier.
344 // This is "type_name type_params? array_marker?".
345 // e.g.) "String[]" (even if it is annotated with @utf8InCpp)
Jiyong Park02da7422018-07-16 16:00:26 +0900346 std::string Signature() const;
347
Jiyong Park1deecc32018-07-17 01:14:41 +0900348 const string& GetUnresolvedName() const { return unresolved_name_; }
349
Jeongik Cha997281d2020-01-16 15:23:59 +0900350 bool IsHidden() const;
351
Jiyong Park1deecc32018-07-17 01:14:41 +0900352 const string& GetComments() const { return comments_; }
353
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900354 const std::vector<std::string> GetSplitName() const { return split_name_; }
355
Jiyong Parka6605ab2018-11-11 14:30:21 +0900356 void SetComments(const string& comment) { comments_ = comment; }
357
Jiyong Park1deecc32018-07-17 01:14:41 +0900358 bool IsResolved() const { return fully_qualified_name_ != ""; }
359
360 bool IsArray() const { return is_array_; }
361
Steven Moreland6c07b832020-10-29 23:39:53 +0000362 __attribute__((warn_unused_result)) bool SetArray() {
363 if (is_array_) return false;
364 is_array_ = true;
365 return true;
366 }
367
Jiyong Park1deecc32018-07-17 01:14:41 +0900368 // Resolve the base type name to a fully-qualified name. Return false if the
369 // resolution fails.
Daniel Norman716d3112019-09-10 13:11:56 -0700370 bool Resolve(const AidlTypenames& typenames);
Casey Dahlin0ee37582015-09-30 16:31:55 -0700371
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700372 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han888c5bc2020-12-22 17:28:47 +0900373 bool CheckValid(const AidlTypenames& typenames) const;
Steven Morelandd59e3172020-05-11 16:42:09 -0700374 bool LanguageSpecificCheckValid(const AidlTypenames& typenames, Options::Language lang) const;
Jeongik Chadf76dc72019-11-28 00:08:47 +0900375 const AidlNode& AsAidlNode() const override { return *this; }
Jiyong Park1d2df7d2018-07-23 15:22:50 +0900376
Jooyung Hane9bb9de2020-11-01 22:16:57 +0900377 const AidlDefinedType* GetDefinedType() const;
378
Casey Dahlin0ee37582015-09-30 16:31:55 -0700379 private:
Steven Moreland3f658cf2018-08-20 13:40:54 -0700380 AidlTypeSpecifier(const AidlTypeSpecifier&) = default;
381
Jiyong Park1deecc32018-07-17 01:14:41 +0900382 const string unresolved_name_;
383 string fully_qualified_name_;
Steven Moreland3f658cf2018-08-20 13:40:54 -0700384 bool is_array_;
Jiyong Parka6605ab2018-11-11 14:30:21 +0900385 string comments_;
Jeongik Cha1a7ab642019-07-29 17:31:02 +0900386 vector<string> split_name_;
Jooyung Han690f5842020-12-04 13:02:04 +0900387 const AidlDefinedType* defined_type_ = nullptr; // set when Resolve() for defined types
Jooyung Hand2fa0232020-10-19 02:51:41 +0900388 mutable shared_ptr<AidlTypeSpecifier> array_base_;
Casey Dahlin0ee37582015-09-30 16:31:55 -0700389};
390
Steven Moreland860b1942018-08-16 14:59:28 -0700391// Returns the universal value unaltered.
392std::string AidlConstantValueDecorator(const AidlTypeSpecifier& type, const std::string& raw_value);
393
Steven Moreland9ea10e32018-07-19 15:26:09 -0700394class AidlConstantValue;
Jooyung Han3f347ca2020-12-01 12:41:50 +0900395class AidlMethod;
396class AidlConstantDeclaration;
397class AidlVariableDeclaration;
398
399class AidlMember : public AidlNode {
400 public:
401 AidlMember(const AidlLocation& location);
402 virtual ~AidlMember() = default;
403
404 // non-copyable, non-movable
405 AidlMember(const AidlMember&) = delete;
406 AidlMember(AidlMember&&) = delete;
407 AidlMember& operator=(const AidlMember&) = delete;
408 AidlMember& operator=(AidlMember&&) = delete;
409
Jooyung Han829ec7c2020-12-02 12:07:36 +0900410 virtual const AidlMethod* AsMethod() const { return nullptr; }
411 virtual const AidlConstantDeclaration* AsConstantDeclaration() const { return nullptr; }
412 virtual const AidlVariableDeclaration* AsVariableDeclaration() const { return nullptr; }
413
414 AidlMethod* AsMethod() {
415 return const_cast<AidlMethod*>(const_cast<const AidlMember*>(this)->AsMethod());
416 }
417 AidlConstantDeclaration* AsConstantDeclaration() {
418 return const_cast<AidlConstantDeclaration*>(
419 const_cast<const AidlMember*>(this)->AsConstantDeclaration());
420 }
421 AidlVariableDeclaration* AsVariableDeclaration() {
422 return const_cast<AidlVariableDeclaration*>(
423 const_cast<const AidlMember*>(this)->AsVariableDeclaration());
424 }
Jooyung Han808a2a02020-12-28 16:46:54 +0900425
426 virtual void Accept(AidlVisitor& vis) const = 0;
Jooyung Han3f347ca2020-12-01 12:41:50 +0900427};
428
Steven Moreland541788d2020-05-21 22:05:52 +0000429// TODO: This class is used for method arguments and also parcelable fields,
430// and it should be split up since default values don't apply to method
431// arguments
Jooyung Han3f347ca2020-12-01 12:41:50 +0900432class AidlVariableDeclaration : public AidlMember {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700433 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700434 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
435 const std::string& name);
436 AidlVariableDeclaration(const AidlLocation& location, AidlTypeSpecifier* type,
437 const std::string& name, AidlConstantValue* default_value);
Steven Moreland5557f1c2018-07-02 13:50:23 -0700438 virtual ~AidlVariableDeclaration() = default;
439
Jiyong Parkd800fef2020-07-22 18:09:43 +0900440 // non-copyable, non-movable
441 AidlVariableDeclaration(const AidlVariableDeclaration&) = delete;
442 AidlVariableDeclaration(AidlVariableDeclaration&&) = delete;
443 AidlVariableDeclaration& operator=(const AidlVariableDeclaration&) = delete;
444 AidlVariableDeclaration& operator=(AidlVariableDeclaration&&) = delete;
445
Jooyung Han829ec7c2020-12-02 12:07:36 +0900446 const AidlVariableDeclaration* AsVariableDeclaration() const override { return this; }
Jooyung Han3f347ca2020-12-01 12:41:50 +0900447
Steven Moreland5557f1c2018-07-02 13:50:23 -0700448 std::string GetName() const { return name_; }
Jooyung Hanacae85d2020-10-28 16:39:09 +0900449 std::string GetCapitalizedName() const;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900450 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland541788d2020-05-21 22:05:52 +0000451 // if this was constructed explicitly with a default value
452 bool IsDefaultUserSpecified() const { return default_user_specified_; }
453 // will return the default value this is constructed with or a default value
454 // if one is available
Steven Moreland9ea10e32018-07-19 15:26:09 -0700455 const AidlConstantValue* GetDefaultValue() const { return default_value_.get(); }
Jooyung Han53fb4242020-12-17 16:03:49 +0900456 bool HasUsefulDefaultValue() const;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700457
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900458 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700459
Jooyung Han808a2a02020-12-28 16:46:54 +0900460 void Accept(AidlVisitor& vis) const override { vis.VisitVariable(*this); }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900461 bool CheckValid(const AidlTypenames& typenames) const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900462
463 // ToString is for dumping AIDL.
464 // Returns string representation of this variable decl including default value.
465 // This is "annotations type name default_value?".
466 // e.g) "@utf8InCpp String[] names = {"hello"}"
Steven Moreland5557f1c2018-07-02 13:50:23 -0700467 std::string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900468
469 // Signature is for comparing AIDL types.
470 // Returns string representation of this variable decl.
471 // This is "type name".
472 // e.g) "String[] name" (even if it is annotated with @utf8InCpp and has a default value.)
Jiyong Park02da7422018-07-16 16:00:26 +0900473 std::string Signature() const;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700474
Steven Moreland860b1942018-08-16 14:59:28 -0700475 std::string ValueString(const ConstantValueDecorator& decorator) const;
Steven Moreland25294322018-08-07 18:13:55 -0700476
Steven Moreland5557f1c2018-07-02 13:50:23 -0700477 private:
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900478 std::unique_ptr<AidlTypeSpecifier> type_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700479 std::string name_;
Steven Moreland541788d2020-05-21 22:05:52 +0000480 bool default_user_specified_;
Steven Moreland9ea10e32018-07-19 15:26:09 -0700481 std::unique_ptr<AidlConstantValue> default_value_;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700482};
483
484class AidlArgument : public AidlVariableDeclaration {
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700485 public:
Casey Dahlinc378c992015-09-29 16:50:40 -0700486 enum Direction { IN_DIR = 1, OUT_DIR = 2, INOUT_DIR = 3 };
487
Steven Moreland46e9da82018-07-27 15:45:29 -0700488 AidlArgument(const AidlLocation& location, AidlArgument::Direction direction,
489 AidlTypeSpecifier* type, const std::string& name);
490 AidlArgument(const AidlLocation& location, AidlTypeSpecifier* type, const std::string& name);
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700491 virtual ~AidlArgument() = default;
492
Jiyong Parkd800fef2020-07-22 18:09:43 +0900493 // non-copyable, non-movable
494 AidlArgument(const AidlArgument&) = delete;
495 AidlArgument(AidlArgument&&) = delete;
496 AidlArgument& operator=(const AidlArgument&) = delete;
497 AidlArgument& operator=(AidlArgument&&) = delete;
498
Casey Dahlinc378c992015-09-29 16:50:40 -0700499 Direction GetDirection() const { return direction_; }
Christopher Wileyad339272015-10-05 19:11:58 -0700500 bool IsOut() const { return direction_ & OUT_DIR; }
501 bool IsIn() const { return direction_ & IN_DIR; }
Casey Dahlinc378c992015-09-29 16:50:40 -0700502 bool DirectionWasSpecified() const { return direction_specified_; }
Jiyong Park3656c3c2018-08-01 20:02:01 +0900503 string GetDirectionSpecifier() const;
Christopher Wileyad339272015-10-05 19:11:58 -0700504
Jooyung Han965e31d2020-11-27 12:30:16 +0900505 // ToString is for dumping AIDL.
506 // Returns string representation of this argument including direction
507 // This is "direction annotations type name".
508 // e.g) "in @utf8InCpp String[] names"
Casey Dahlinc378c992015-09-29 16:50:40 -0700509 std::string ToString() const;
Jooyung Han808a2a02020-12-28 16:46:54 +0900510 void Accept(AidlVisitor& vis) const override { vis.VisitArgument(*this); }
Casey Dahlinc378c992015-09-29 16:50:40 -0700511
Casey Dahlinbc7a50a2015-09-28 19:20:50 -0700512 private:
Casey Dahlinc378c992015-09-29 16:50:40 -0700513 Direction direction_;
514 bool direction_specified_;
Casey Dahlina834dd42015-09-23 11:52:15 -0700515};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800516
Will McVickerd7d18df2019-09-12 13:40:50 -0700517class AidlUnaryConstExpression;
518class AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900519class AidlConstantReference;
Will McVickerd7d18df2019-09-12 13:40:50 -0700520
Steven Moreland693640b2018-07-19 13:46:27 -0700521class AidlConstantValue : public AidlNode {
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800522 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700523 enum class Type {
524 // WARNING: Don't change this order! The order is used to determine type
525 // promotion during a binary expression.
526 BOOLEAN,
527 INT8,
528 INT32,
529 INT64,
530 ARRAY,
531 CHARACTER,
532 STRING,
Jooyung Han690f5842020-12-04 13:02:04 +0900533 REF,
Will McVickerd7d18df2019-09-12 13:40:50 -0700534 FLOATING,
535 UNARY,
536 BINARY,
537 ERROR,
538 };
539
Jooyung Han690f5842020-12-04 13:02:04 +0900540 struct Visitor {
541 virtual ~Visitor() {}
542 virtual void Visit(AidlConstantValue&) = 0;
543 virtual void Visit(AidlConstantReference&) = 0;
544 virtual void Visit(AidlUnaryConstExpression&) = 0;
545 virtual void Visit(AidlBinaryConstExpression&) = 0;
546 };
547
Jooyung Han535c5e82020-12-29 15:16:59 +0900548 // Returns the evaluated value. T> should match to the actual type.
Will McVickerd7d18df2019-09-12 13:40:50 -0700549 template <typename T>
Jooyung Han535c5e82020-12-29 15:16:59 +0900550 T EvaluatedValue() const {
551 is_evaluated_ || (CheckValid() && evaluate());
552 AIDL_FATAL_IF(!is_valid_, this);
553
554 if constexpr (is_vector<T>::value) {
555 AIDL_FATAL_IF(final_type_ != Type::ARRAY, this);
556 T result;
557 for (const auto& v : values_) {
558 result.push_back(v->EvaluatedValue<typename T::value_type>());
559 }
560 return result;
561 } else if constexpr (is_one_of<T, float, double>::value) {
562 AIDL_FATAL_IF(final_type_ != Type::FLOATING, this);
563 T result;
564 AIDL_FATAL_IF(!ParseFloating(value_, &result), this);
565 return result;
566 } else if constexpr (std::is_same<T, std::string>::value) {
567 AIDL_FATAL_IF(final_type_ != Type::STRING, this);
568 return final_string_value_.substr(1, final_string_value_.size() - 2); // unquote "
569 } else if constexpr (is_one_of<T, int8_t, int32_t, int64_t>::value) {
570 AIDL_FATAL_IF(final_type_ < Type::INT8 && final_type_ > Type::INT64, this);
571 return static_cast<T>(final_value_);
572 } else if constexpr (std::is_same<T, char>::value) {
573 AIDL_FATAL_IF(final_type_ != Type::CHARACTER, this);
574 return final_string_value_.at(1); // unquote '
575 } else if constexpr (std::is_same<T, bool>::value) {
576 static_assert(std::is_same<T, bool>::value, "..");
577 AIDL_FATAL_IF(final_type_ != Type::BOOLEAN, this);
578 return final_value_ != 0;
579 } else {
580 static_assert(unsupported_type<T>::value);
581 }
582 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800583
Steven Moreland693640b2018-07-19 13:46:27 -0700584 virtual ~AidlConstantValue() = default;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800585
Jiyong Parkd800fef2020-07-22 18:09:43 +0900586 // non-copyable, non-movable
587 AidlConstantValue(const AidlConstantValue&) = delete;
588 AidlConstantValue(AidlConstantValue&&) = delete;
589 AidlConstantValue& operator=(const AidlConstantValue&) = delete;
590 AidlConstantValue& operator=(AidlConstantValue&&) = delete;
591
Steven Moreland541788d2020-05-21 22:05:52 +0000592 // creates default value, when one isn't specified
593 // nullptr if no default available
594 static AidlConstantValue* Default(const AidlTypeSpecifier& specifier);
595
Steven Moreland25294322018-08-07 18:13:55 -0700596 static AidlConstantValue* Boolean(const AidlLocation& location, bool value);
597 static AidlConstantValue* Character(const AidlLocation& location, char value);
Steven Moreland25294322018-08-07 18:13:55 -0700598 // example: 123, -5498, maybe any size
Will McVickerd7d18df2019-09-12 13:40:50 -0700599 static AidlConstantValue* Integral(const AidlLocation& location, const string& value);
600 static AidlConstantValue* Floating(const AidlLocation& location, const std::string& value);
Steven Moreland860b1942018-08-16 14:59:28 -0700601 static AidlConstantValue* Array(const AidlLocation& location,
Will McVickerd7d18df2019-09-12 13:40:50 -0700602 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values);
Steven Moreland693640b2018-07-19 13:46:27 -0700603 // example: "\"asdf\""
Will McVickerd7d18df2019-09-12 13:40:50 -0700604 static AidlConstantValue* String(const AidlLocation& location, const string& value);
Steven Moreland693640b2018-07-19 13:46:27 -0700605
Will McVickerd7d18df2019-09-12 13:40:50 -0700606 Type GetType() const { return final_type_; }
Jooyung Han29813842020-12-08 01:28:03 +0900607 const std::string& Literal() const { return value_; }
Steven Moreland25294322018-08-07 18:13:55 -0700608
Will McVickerd7d18df2019-09-12 13:40:50 -0700609 virtual bool CheckValid() const;
Steven Moreland860b1942018-08-16 14:59:28 -0700610
611 // Raw value of type (currently valid in C++ and Java). Empty string on error.
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800612 string ValueString(const AidlTypeSpecifier& type, const ConstantValueDecorator& decorator) const;
Jooyung Han29813842020-12-08 01:28:03 +0900613 virtual void Accept(Visitor& visitor) {
614 visitor.Visit(*this);
615 if (type_ == Type::ARRAY) {
616 for (const auto& v : values_) {
617 v.get()->Accept(visitor);
618 }
619 }
620 }
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800621
622 private:
Will McVickerd7d18df2019-09-12 13:40:50 -0700623 AidlConstantValue(const AidlLocation& location, Type parsed_type, int64_t parsed_value,
624 const string& checked_value);
625 AidlConstantValue(const AidlLocation& location, Type type, const string& checked_value);
Steven Moreland860b1942018-08-16 14:59:28 -0700626 AidlConstantValue(const AidlLocation& location, Type type,
Jooyung Han29813842020-12-08 01:28:03 +0900627 std::unique_ptr<vector<unique_ptr<AidlConstantValue>>> values,
628 const std::string& value);
Steven Moreland25294322018-08-07 18:13:55 -0700629 static string ToString(Type type);
Will McVickerd7d18df2019-09-12 13:40:50 -0700630 static bool ParseIntegral(const string& value, int64_t* parsed_value, Type* parsed_type);
631 static bool IsHex(const string& value);
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800632
Jooyung Han74675c22020-12-15 08:39:57 +0900633 virtual bool evaluate() const;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800634
Steven Moreland693640b2018-07-19 13:46:27 -0700635 const Type type_ = Type::ERROR;
Will McVickerd7d18df2019-09-12 13:40:50 -0700636 const vector<unique_ptr<AidlConstantValue>> values_; // if type_ == ARRAY
637 const string value_; // otherwise
638
639 // State for tracking evaluation of expressions
Steven Moreland4bcb05c2019-11-27 18:57:47 -0800640 mutable bool is_valid_ = false; // cache of CheckValid, but may be marked false in evaluate
641 mutable bool is_evaluated_ = false; // whether evaluate has been called
Will McVickerd7d18df2019-09-12 13:40:50 -0700642 mutable Type final_type_;
643 mutable int64_t final_value_;
644 mutable string final_string_value_ = "";
Steven Moreland693640b2018-07-19 13:46:27 -0700645
Will McVickerd7d18df2019-09-12 13:40:50 -0700646 friend AidlUnaryConstExpression;
647 friend AidlBinaryConstExpression;
Jooyung Han690f5842020-12-04 13:02:04 +0900648 friend AidlConstantReference;
649};
650
651// Represents "<type>.<field>" which resolves to a constant which is one of
652// - constant declartion
653// - enumerator
654// When a <type> is missing, <field> is of the enclosing type.
655class AidlConstantReference : public AidlConstantValue {
656 public:
657 AidlConstantReference(const AidlLocation& location, const std::string& value,
658 const std::string& comments);
659
660 const std::unique_ptr<AidlTypeSpecifier>& GetRefType() const { return ref_type_; }
661 void SetRefType(std::unique_ptr<AidlTypeSpecifier> type) { ref_type_ = std::move(type); }
662 const std::string& GetFieldName() const { return field_name_; }
663 const std::string& GetComments() const { return comments_; }
664
665 bool CheckValid() const override;
666 void Accept(Visitor& visitor) override { visitor.Visit(*this); }
Jooyung Han29813842020-12-08 01:28:03 +0900667 const AidlConstantValue* Resolve();
Jooyung Han690f5842020-12-04 13:02:04 +0900668
669 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900670 bool evaluate() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900671
672 std::unique_ptr<AidlTypeSpecifier> ref_type_;
673 std::string field_name_;
674 const std::string comments_;
Jooyung Han29813842020-12-08 01:28:03 +0900675 const AidlConstantValue* resolved_ = nullptr;
Will McVickerd7d18df2019-09-12 13:40:50 -0700676};
677
678class AidlUnaryConstExpression : public AidlConstantValue {
679 public:
680 AidlUnaryConstExpression(const AidlLocation& location, const string& op,
681 std::unique_ptr<AidlConstantValue> rval);
682
683 static bool IsCompatibleType(Type type, const string& op);
684 bool CheckValid() const override;
Jooyung Han690f5842020-12-04 13:02:04 +0900685 void Accept(Visitor& visitor) override {
686 visitor.Visit(*this);
687 unary_->Accept(visitor);
688 }
689
Will McVickerd7d18df2019-09-12 13:40:50 -0700690 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900691 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700692
693 std::unique_ptr<AidlConstantValue> unary_;
694 const string op_;
695};
696
697class AidlBinaryConstExpression : public AidlConstantValue {
698 public:
699 AidlBinaryConstExpression(const AidlLocation& location, std::unique_ptr<AidlConstantValue> lval,
700 const string& op, std::unique_ptr<AidlConstantValue> rval);
701
702 bool CheckValid() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700703
704 static bool AreCompatibleTypes(Type t1, Type t2);
705 // Returns the promoted kind for both operands
706 static Type UsualArithmeticConversion(Type left, Type right);
707 // Returns the promoted integral type where INT32 is the smallest type
708 static Type IntegralPromotion(Type in);
Jooyung Han690f5842020-12-04 13:02:04 +0900709 void Accept(Visitor& visitor) override {
710 visitor.Visit(*this);
711 left_val_->Accept(visitor);
712 right_val_->Accept(visitor);
713 }
Will McVickerd7d18df2019-09-12 13:40:50 -0700714
715 private:
Jooyung Han74675c22020-12-15 08:39:57 +0900716 bool evaluate() const override;
Will McVickerd7d18df2019-09-12 13:40:50 -0700717
718 std::unique_ptr<AidlConstantValue> left_val_;
719 std::unique_ptr<AidlConstantValue> right_val_;
720 const string op_;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700721};
722
Andrei Onea9445fc62019-06-27 18:11:59 +0100723struct AidlAnnotationParameter {
724 std::string name;
725 std::unique_ptr<AidlConstantValue> value;
726};
727
Steven Moreland693640b2018-07-19 13:46:27 -0700728class AidlConstantDeclaration : public AidlMember {
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700729 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700730 AidlConstantDeclaration(const AidlLocation& location, AidlTypeSpecifier* specifier,
Will McVickerd7d18df2019-09-12 13:40:50 -0700731 const string& name, AidlConstantValue* value);
Steven Moreland693640b2018-07-19 13:46:27 -0700732 virtual ~AidlConstantDeclaration() = default;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700733
Jiyong Parkd800fef2020-07-22 18:09:43 +0900734 // non-copyable, non-movable
735 AidlConstantDeclaration(const AidlConstantDeclaration&) = delete;
736 AidlConstantDeclaration(AidlConstantDeclaration&&) = delete;
737 AidlConstantDeclaration& operator=(const AidlConstantDeclaration&) = delete;
738 AidlConstantDeclaration& operator=(AidlConstantDeclaration&&) = delete;
739
Steven Moreland693640b2018-07-19 13:46:27 -0700740 const AidlTypeSpecifier& GetType() const { return *type_; }
Steven Moreland4d12f9a2018-10-31 14:30:55 -0700741 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Will McVickerd7d18df2019-09-12 13:40:50 -0700742 const string& GetName() const { return name_; }
Steven Moreland693640b2018-07-19 13:46:27 -0700743 const AidlConstantValue& GetValue() const { return *value_; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900744 void Accept(AidlVisitor& vis) const override { vis.VisitConstant(*this); }
Jeongik Chadb0f59e2018-11-01 18:11:21 +0900745 bool CheckValid(const AidlTypenames& typenames) const;
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700746
Jooyung Han965e31d2020-11-27 12:30:16 +0900747 // ToString is for dumping AIDL.
748 // Returns string representation of this const decl including a const value.
749 // This is "`const` annotations type name value".
750 // e.g) "const @utf8InCpp String[] names = { "hello" }"
Will McVickerd7d18df2019-09-12 13:40:50 -0700751 string ToString() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900752
753 // Signature is for comparing types.
754 // Returns string representation of this const decl.
755 // This is "direction annotations type name".
756 // e.g) "String[] names"
Will McVickerd7d18df2019-09-12 13:40:50 -0700757 string Signature() const;
Jooyung Han965e31d2020-11-27 12:30:16 +0900758
Steven Moreland860b1942018-08-16 14:59:28 -0700759 string ValueString(const ConstantValueDecorator& decorator) const {
Will McVickerd7d18df2019-09-12 13:40:50 -0700760 return value_->ValueString(GetType(), decorator);
Steven Moreland860b1942018-08-16 14:59:28 -0700761 }
Steven Moreland25294322018-08-07 18:13:55 -0700762
Jooyung Han829ec7c2020-12-02 12:07:36 +0900763 const AidlConstantDeclaration* AsConstantDeclaration() const override { return this; }
Christopher Wileyd6bdd8d2016-05-03 11:23:13 -0700764
765 private:
Steven Moreland693640b2018-07-19 13:46:27 -0700766 const unique_ptr<AidlTypeSpecifier> type_;
Will McVickerd7d18df2019-09-12 13:40:50 -0700767 const string name_;
768 unique_ptr<AidlConstantValue> value_;
Casey Dahlind40e2fe2015-11-24 14:06:52 -0800769};
770
771class AidlMethod : public AidlMember {
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700772 public:
Will McVickerd7d18df2019-09-12 13:40:50 -0700773 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
774 vector<unique_ptr<AidlArgument>>* args, const string& comments);
775 AidlMethod(const AidlLocation& location, bool oneway, AidlTypeSpecifier* type, const string& name,
776 vector<unique_ptr<AidlArgument>>* args, const string& comments, int id,
777 bool is_user_defined = true);
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700778 virtual ~AidlMethod() = default;
779
Jiyong Parkd800fef2020-07-22 18:09:43 +0900780 // non-copyable, non-movable
781 AidlMethod(const AidlMethod&) = delete;
782 AidlMethod(AidlMethod&&) = delete;
783 AidlMethod& operator=(const AidlMethod&) = delete;
784 AidlMethod& operator=(AidlMethod&&) = delete;
785
Jooyung Han829ec7c2020-12-02 12:07:36 +0900786 const AidlMethod* AsMethod() const override { return this; }
Jeongik Cha997281d2020-01-16 15:23:59 +0900787 bool IsHidden() const;
Will McVickerd7d18df2019-09-12 13:40:50 -0700788 const string& GetComments() const { return comments_; }
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900789 const AidlTypeSpecifier& GetType() const { return *type_; }
790 AidlTypeSpecifier* GetMutableType() { return type_.get(); }
Steven Morelandacd53472018-12-14 10:17:26 -0800791
Steven Moreland8c70ba92018-12-17 10:20:31 -0800792 // set if this method is part of an interface that is marked oneway
793 void ApplyInterfaceOneway(bool oneway) { oneway_ = oneway_ || oneway; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700794 bool IsOneway() const { return oneway_; }
Steven Morelandacd53472018-12-14 10:17:26 -0800795
Casey Dahlinf4a93112015-10-05 16:58:09 -0700796 const std::string& GetName() const { return name_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700797 bool HasId() const { return has_id_; }
Jiyong Parked65bf42018-08-28 15:43:27 +0900798 int GetId() const { return id_; }
Casey Dahlinf4a93112015-10-05 16:58:09 -0700799 void SetId(unsigned id) { id_ = id; }
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700800
Jiyong Park309668e2018-07-28 16:55:44 +0900801 bool IsUserDefined() const { return is_user_defined_; }
802
Casey Dahlinf4a93112015-10-05 16:58:09 -0700803 const std::vector<std::unique_ptr<AidlArgument>>& GetArguments() const {
Christopher Wileyad339272015-10-05 19:11:58 -0700804 return arguments_;
805 }
806 // An inout parameter will appear in both GetInArguments()
807 // and GetOutArguments(). AidlMethod retains ownership of the argument
808 // pointers returned in this way.
809 const std::vector<const AidlArgument*>& GetInArguments() const {
810 return in_arguments_;
811 }
812 const std::vector<const AidlArgument*>& GetOutArguments() const {
813 return out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700814 }
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700815
Jooyung Han965e31d2020-11-27 12:30:16 +0900816 // ToString is for dumping AIDL.
817 // Returns string representation of this method including everything.
818 // This is "ret_type name ( arg_list ) = id".
819 // e.g) "boolean foo(int, @Nullable String) = 1"
Jiyong Park309668e2018-07-28 16:55:44 +0900820 std::string ToString() const;
821
Jooyung Han965e31d2020-11-27 12:30:16 +0900822 // Signature is for comparing AIDL types.
823 // Returns string representation of this method's name & type.
824 // e.g) "foo(int, String)"
825 std::string Signature() const;
826
Jooyung Han808a2a02020-12-28 16:46:54 +0900827 void Accept(AidlVisitor& vis) const override { vis.VisitMethod(*this); }
828
Casey Dahlin5c69deb2015-10-01 14:44:12 -0700829 private:
Casey Dahlinf4a93112015-10-05 16:58:09 -0700830 bool oneway_;
Casey Dahlinf2d23f72015-10-02 16:19:19 -0700831 std::string comments_;
Jiyong Parkd59a10d2018-07-18 11:12:55 +0900832 std::unique_ptr<AidlTypeSpecifier> type_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700833 std::string name_;
Christopher Wileyad339272015-10-05 19:11:58 -0700834 const std::vector<std::unique_ptr<AidlArgument>> arguments_;
835 std::vector<const AidlArgument*> in_arguments_;
836 std::vector<const AidlArgument*> out_arguments_;
Casey Dahlinf4a93112015-10-05 16:58:09 -0700837 bool has_id_;
838 int id_;
Jiyong Park309668e2018-07-28 16:55:44 +0900839 bool is_user_defined_ = true;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700840};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800841
Steven Morelandc258abc2018-07-10 14:03:38 -0700842class AidlDefinedType;
Jiyong Parkb034bf02018-07-30 17:44:33 +0900843class AidlInterface;
844class AidlParcelable;
845class AidlStructuredParcelable;
Jooyung Han2946afc2020-10-05 20:29:16 +0900846class AidlUnionDecl;
Jooyung Han3f347ca2020-12-01 12:41:50 +0900847
Daniel Norman85aed542019-08-21 12:01:14 -0700848// AidlDefinedType represents either an interface, parcelable, or enum that is
Jiyong Park1deecc32018-07-17 01:14:41 +0900849// defined in the source file.
850class AidlDefinedType : public AidlAnnotatable {
Steven Moreland787b0432018-07-03 09:00:58 -0700851 public:
Steven Moreland46e9da82018-07-27 15:45:29 -0700852 AidlDefinedType(const AidlLocation& location, const std::string& name,
Jooyung Han829ec7c2020-12-02 12:07:36 +0900853 const std::string& comments, const std::string& package,
854 std::vector<std::unique_ptr<AidlMember>>* members);
Steven Moreland787b0432018-07-03 09:00:58 -0700855 virtual ~AidlDefinedType() = default;
856
Jiyong Parkd800fef2020-07-22 18:09:43 +0900857 // non-copyable, non-movable
858 AidlDefinedType(const AidlDefinedType&) = delete;
859 AidlDefinedType(AidlDefinedType&&) = delete;
860 AidlDefinedType& operator=(const AidlDefinedType&) = delete;
861 AidlDefinedType& operator=(AidlDefinedType&&) = delete;
862
Jiyong Park1deecc32018-07-17 01:14:41 +0900863 const std::string& GetName() const { return name_; };
Jeongik Cha997281d2020-01-16 15:23:59 +0900864 bool IsHidden() const;
Jiyong Park1deecc32018-07-17 01:14:41 +0900865 const std::string& GetComments() const { return comments_; }
Jiyong Parka6605ab2018-11-11 14:30:21 +0900866 void SetComments(const std::string comments) { comments_ = comments; }
Jiyong Park1deecc32018-07-17 01:14:41 +0900867
Steven Moreland787b0432018-07-03 09:00:58 -0700868 /* dot joined package, example: "android.package.foo" */
Jiyong Park18132182020-06-08 20:24:40 +0900869 std::string GetPackage() const { return package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700870 /* dot joined package and name, example: "android.package.foo.IBar" */
871 std::string GetCanonicalName() const;
Jiyong Park18132182020-06-08 20:24:40 +0900872 const std::vector<std::string>& GetSplitPackage() const { return split_package_; }
Steven Moreland787b0432018-07-03 09:00:58 -0700873
Steven Morelanded83a282018-07-17 13:27:29 -0700874 virtual std::string GetPreprocessDeclarationName() const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700875
Steven Moreland5557f1c2018-07-02 13:50:23 -0700876 virtual const AidlStructuredParcelable* AsStructuredParcelable() const { return nullptr; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700877 virtual const AidlParcelable* AsParcelable() const { return nullptr; }
Daniel Norman85aed542019-08-21 12:01:14 -0700878 virtual const AidlEnumDeclaration* AsEnumDeclaration() const { return nullptr; }
Jooyung Han2946afc2020-10-05 20:29:16 +0900879 virtual const AidlUnionDecl* AsUnionDeclaration() const { return nullptr; }
Steven Moreland5557f1c2018-07-02 13:50:23 -0700880 virtual const AidlInterface* AsInterface() const { return nullptr; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900881 virtual const AidlParameterizable<std::string>* AsParameterizable() const { return nullptr; }
Jooyung Han808a2a02020-12-28 16:46:54 +0900882 virtual bool CheckValid(const AidlTypenames& typenames) const;
883 virtual void Accept(AidlVisitor& vis) const = 0;
Steven Morelandd59e3172020-05-11 16:42:09 -0700884 virtual bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
885 Options::Language lang) const = 0;
Steven Morelandc258abc2018-07-10 14:03:38 -0700886 AidlStructuredParcelable* AsStructuredParcelable() {
887 return const_cast<AidlStructuredParcelable*>(
888 const_cast<const AidlDefinedType*>(this)->AsStructuredParcelable());
889 }
890 AidlParcelable* AsParcelable() {
891 return const_cast<AidlParcelable*>(const_cast<const AidlDefinedType*>(this)->AsParcelable());
892 }
Daniel Norman85aed542019-08-21 12:01:14 -0700893 AidlEnumDeclaration* AsEnumDeclaration() {
894 return const_cast<AidlEnumDeclaration*>(
895 const_cast<const AidlDefinedType*>(this)->AsEnumDeclaration());
896 }
Jooyung Han2946afc2020-10-05 20:29:16 +0900897 AidlUnionDecl* AsUnionDeclaration() {
898 return const_cast<AidlUnionDecl*>(
899 const_cast<const AidlDefinedType*>(this)->AsUnionDeclaration());
900 }
Steven Morelandc258abc2018-07-10 14:03:38 -0700901 AidlInterface* AsInterface() {
902 return const_cast<AidlInterface*>(const_cast<const AidlDefinedType*>(this)->AsInterface());
903 }
904
Jeongik Chadf76dc72019-11-28 00:08:47 +0900905 AidlParameterizable<std::string>* AsParameterizable() {
906 return const_cast<AidlParameterizable<std::string>*>(
907 const_cast<const AidlDefinedType*>(this)->AsParameterizable());
908 }
909
Steven Moreland6cee3482018-07-18 14:39:58 -0700910 const AidlParcelable* AsUnstructuredParcelable() const {
911 if (this->AsStructuredParcelable() != nullptr) return nullptr;
Jooyung Han2946afc2020-10-05 20:29:16 +0900912 if (this->AsUnionDeclaration() != nullptr) return nullptr;
Steven Moreland6cee3482018-07-18 14:39:58 -0700913 return this->AsParcelable();
914 }
915 AidlParcelable* AsUnstructuredParcelable() {
916 return const_cast<AidlParcelable*>(
917 const_cast<const AidlDefinedType*>(this)->AsUnstructuredParcelable());
918 }
919
Jeongik Cha997281d2020-01-16 15:23:59 +0900920 virtual void Dump(CodeWriter* writer) const = 0;
Steven Morelanda5d9c5c2020-02-21 16:01:09 -0800921 void DumpHeader(CodeWriter* writer) const;
Jiyong Park02da7422018-07-16 16:00:26 +0900922
Jooyung Han829ec7c2020-12-02 12:07:36 +0900923 const std::vector<std::unique_ptr<AidlVariableDeclaration>>& GetFields() const {
924 return variables_;
925 }
926 const std::vector<std::unique_ptr<AidlConstantDeclaration>>& GetConstantDeclarations() const {
927 return constants_;
928 }
929 const std::vector<std::unique_ptr<AidlMethod>>& GetMethods() const { return methods_; }
930 void AddMethod(std::unique_ptr<AidlMethod> method) { methods_.push_back(std::move(method)); }
931 const std::vector<const AidlMember*>& GetMembers() const { return members_; }
932
933 protected:
934 // utility for subclasses with getter names
935 bool CheckValidForGetterNames() const;
936
Steven Moreland787b0432018-07-03 09:00:58 -0700937 private:
Jooyung Han829ec7c2020-12-02 12:07:36 +0900938 bool CheckValidWithMembers(const AidlTypenames& typenames) const;
939
Jiyong Park1deecc32018-07-17 01:14:41 +0900940 std::string name_;
Jiyong Park1deecc32018-07-17 01:14:41 +0900941 std::string comments_;
Jiyong Park18132182020-06-08 20:24:40 +0900942 const std::string package_;
943 const std::vector<std::string> split_package_;
Jooyung Han829ec7c2020-12-02 12:07:36 +0900944 std::vector<std::unique_ptr<AidlVariableDeclaration>> variables_;
945 std::vector<std::unique_ptr<AidlConstantDeclaration>> constants_;
946 std::vector<std::unique_ptr<AidlMethod>> methods_;
947 std::vector<const AidlMember*> members_; // keep members in order of appearance.
Steven Moreland787b0432018-07-03 09:00:58 -0700948};
949
Jeongik Chadf76dc72019-11-28 00:08:47 +0900950class AidlParcelable : public AidlDefinedType, public AidlParameterizable<std::string> {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700951 public:
Jiyong Park18132182020-06-08 20:24:40 +0900952 AidlParcelable(const AidlLocation& location, const std::string& name, const std::string& package,
953 const std::string& comments, const std::string& cpp_header = "",
Jooyung Han829ec7c2020-12-02 12:07:36 +0900954 std::vector<std::string>* type_params = nullptr,
955 std::vector<std::unique_ptr<AidlMember>>* members = nullptr);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700956 virtual ~AidlParcelable() = default;
Adam Lesinskiffa16862014-01-23 18:17:42 -0800957
Jiyong Parkd800fef2020-07-22 18:09:43 +0900958 // non-copyable, non-movable
959 AidlParcelable(const AidlParcelable&) = delete;
960 AidlParcelable(AidlParcelable&&) = delete;
961 AidlParcelable& operator=(const AidlParcelable&) = delete;
962 AidlParcelable& operator=(AidlParcelable&&) = delete;
963
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -0800964 std::string GetCppHeader() const { return cpp_header_; }
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -0800965
Steven Moreland0cea4aa2020-04-20 21:06:02 -0700966 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +0900967 bool CheckValid(const AidlTypenames& typenames) const override;
968 void Accept(AidlVisitor& vis) const override {
969 if (AsUnstructuredParcelable()) vis.VisitUnstructuredParcelable(*this);
970 }
Steven Morelandd59e3172020-05-11 16:42:09 -0700971 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
972 Options::Language lang) const override;
Steven Morelandc258abc2018-07-10 14:03:38 -0700973 const AidlParcelable* AsParcelable() const override { return this; }
Jeongik Chadf76dc72019-11-28 00:08:47 +0900974 const AidlParameterizable<std::string>* AsParameterizable() const override { return this; }
975 const AidlNode& AsAidlNode() const override { return *this; }
Steven Morelanded83a282018-07-17 13:27:29 -0700976 std::string GetPreprocessDeclarationName() const override { return "parcelable"; }
Steven Morelandc258abc2018-07-10 14:03:38 -0700977
Jeongik Cha997281d2020-01-16 15:23:59 +0900978 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +0900979
Casey Dahlin1ae2bc52015-10-07 18:49:10 -0700980 private:
Christopher Wiley8aa4d9f2015-11-16 19:10:45 -0800981 std::string cpp_header_;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -0700982};
Adam Lesinskiffa16862014-01-23 18:17:42 -0800983
Jooyung Han829ec7c2020-12-02 12:07:36 +0900984class AidlStructuredParcelable : public AidlParcelable {
Steven Moreland5557f1c2018-07-02 13:50:23 -0700985 public:
Jiyong Park18132182020-06-08 20:24:40 +0900986 AidlStructuredParcelable(const AidlLocation& location, const std::string& name,
987 const std::string& package, const std::string& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +0900988 std::vector<std::string>* type_params,
989 std::vector<std::unique_ptr<AidlMember>>* members);
Jiyong Parkd800fef2020-07-22 18:09:43 +0900990 virtual ~AidlStructuredParcelable() = default;
991
992 // non-copyable, non-movable
993 AidlStructuredParcelable(const AidlStructuredParcelable&) = delete;
994 AidlStructuredParcelable(AidlStructuredParcelable&&) = delete;
995 AidlStructuredParcelable& operator=(const AidlStructuredParcelable&) = delete;
996 AidlStructuredParcelable& operator=(AidlStructuredParcelable&&) = delete;
Steven Moreland5557f1c2018-07-02 13:50:23 -0700997
Steven Morelandc258abc2018-07-10 14:03:38 -0700998 const AidlStructuredParcelable* AsStructuredParcelable() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -0700999 std::string GetPreprocessDeclarationName() const override { return "structured_parcelable"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001000
Jeongik Cha997281d2020-01-16 15:23:59 +09001001 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001002
Steven Moreland0cea4aa2020-04-20 21:06:02 -07001003 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +09001004 void Accept(AidlVisitor& vis) const override { vis.VisitStructuredParcelable(*this); }
1005 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001006 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1007 Options::Language lang) const override;
Steven Moreland5557f1c2018-07-02 13:50:23 -07001008};
1009
Daniel Norman85aed542019-08-21 12:01:14 -07001010class AidlEnumerator : public AidlNode {
1011 public:
Daniel Norman2e4112d2019-10-03 10:22:35 -07001012 AidlEnumerator(const AidlLocation& location, const std::string& name, AidlConstantValue* value,
1013 const std::string& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001014 virtual ~AidlEnumerator() = default;
1015
Jiyong Parkd800fef2020-07-22 18:09:43 +09001016 // non-copyable, non-movable
1017 AidlEnumerator(const AidlEnumerator&) = delete;
1018 AidlEnumerator(AidlEnumerator&&) = delete;
1019 AidlEnumerator& operator=(const AidlEnumerator&) = delete;
1020 AidlEnumerator& operator=(AidlEnumerator&&) = delete;
1021
Daniel Norman85aed542019-08-21 12:01:14 -07001022 const std::string& GetName() const { return name_; }
Will McVickerd7d18df2019-09-12 13:40:50 -07001023 AidlConstantValue* GetValue() const { return value_.get(); }
Daniel Norman2e4112d2019-10-03 10:22:35 -07001024 const std::string& GetComments() const { return comments_; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001025 void Accept(AidlVisitor& vis) const { vis.VisitEnumerator(*this); }
Daniel Norman85aed542019-08-21 12:01:14 -07001026 bool CheckValid(const AidlTypeSpecifier& enum_backing_type) const;
1027
1028 string ValueString(const AidlTypeSpecifier& backing_type,
1029 const ConstantValueDecorator& decorator) const;
1030
Daniel Normanb28684e2019-10-17 15:31:39 -07001031 void SetValue(std::unique_ptr<AidlConstantValue> value) { value_ = std::move(value); }
Jooyung Han29813842020-12-08 01:28:03 +09001032 bool IsValueUserSpecified() const { return value_user_specified_; }
Daniel Normanb28684e2019-10-17 15:31:39 -07001033
Daniel Norman85aed542019-08-21 12:01:14 -07001034 private:
1035 const std::string name_;
Will McVickerd7d18df2019-09-12 13:40:50 -07001036 unique_ptr<AidlConstantValue> value_;
Daniel Norman2e4112d2019-10-03 10:22:35 -07001037 const std::string comments_;
Jooyung Han29813842020-12-08 01:28:03 +09001038 const bool value_user_specified_;
Daniel Norman85aed542019-08-21 12:01:14 -07001039};
1040
1041class AidlEnumDeclaration : public AidlDefinedType {
1042 public:
Will McVickerd7d18df2019-09-12 13:40:50 -07001043 AidlEnumDeclaration(const AidlLocation& location, const string& name,
Daniel Norman85aed542019-08-21 12:01:14 -07001044 std::vector<std::unique_ptr<AidlEnumerator>>* enumerators,
Jiyong Park18132182020-06-08 20:24:40 +09001045 const std::string& package, const std::string& comments);
Daniel Norman85aed542019-08-21 12:01:14 -07001046 virtual ~AidlEnumDeclaration() = default;
1047
Jiyong Parkd800fef2020-07-22 18:09:43 +09001048 // non-copyable, non-movable
1049 AidlEnumDeclaration(const AidlEnumDeclaration&) = delete;
1050 AidlEnumDeclaration(AidlEnumDeclaration&&) = delete;
1051 AidlEnumDeclaration& operator=(const AidlEnumDeclaration&) = delete;
1052 AidlEnumDeclaration& operator=(AidlEnumDeclaration&&) = delete;
1053
Jooyung Han672557b2020-12-24 05:18:00 +09001054 bool Autofill(const AidlTypenames&);
Daniel Norman85aed542019-08-21 12:01:14 -07001055 const AidlTypeSpecifier& GetBackingType() const { return *backing_type_; }
1056 const std::vector<std::unique_ptr<AidlEnumerator>>& GetEnumerators() const {
1057 return enumerators_;
1058 }
Steven Moreland0cea4aa2020-04-20 21:06:02 -07001059 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +09001060 void Accept(AidlVisitor& vis) const override { vis.VisitEnum(*this); }
1061 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001062 bool LanguageSpecificCheckValid(const AidlTypenames& /*typenames*/,
1063 Options::Language) const override {
1064 return true;
1065 }
Daniel Norman85aed542019-08-21 12:01:14 -07001066 std::string GetPreprocessDeclarationName() const override { return "enum"; }
Jeongik Cha997281d2020-01-16 15:23:59 +09001067 void Dump(CodeWriter* writer) const override;
Daniel Norman85aed542019-08-21 12:01:14 -07001068
1069 const AidlEnumDeclaration* AsEnumDeclaration() const override { return this; }
1070
1071 private:
Jooyung Han29813842020-12-08 01:28:03 +09001072
Daniel Norman85aed542019-08-21 12:01:14 -07001073 const std::string name_;
1074 const std::vector<std::unique_ptr<AidlEnumerator>> enumerators_;
Jooyung Han672557b2020-12-24 05:18:00 +09001075 std::unique_ptr<AidlTypeSpecifier> backing_type_;
Daniel Norman85aed542019-08-21 12:01:14 -07001076};
1077
Jooyung Han829ec7c2020-12-02 12:07:36 +09001078class AidlUnionDecl : public AidlParcelable {
Jooyung Han2946afc2020-10-05 20:29:16 +09001079 public:
1080 AidlUnionDecl(const AidlLocation& location, const std::string& name, const std::string& package,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001081 const std::string& comments, std::vector<std::string>* type_params,
1082 std::vector<std::unique_ptr<AidlMember>>* members);
Jooyung Han2946afc2020-10-05 20:29:16 +09001083 virtual ~AidlUnionDecl() = default;
1084
1085 // non-copyable, non-movable
1086 AidlUnionDecl(const AidlUnionDecl&) = delete;
1087 AidlUnionDecl(AidlUnionDecl&&) = delete;
1088 AidlUnionDecl& operator=(const AidlUnionDecl&) = delete;
1089 AidlUnionDecl& operator=(AidlUnionDecl&&) = delete;
1090
1091 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
1092
1093 const AidlNode& AsAidlNode() const override { return *this; }
Jooyung Han808a2a02020-12-28 16:46:54 +09001094 void Accept(AidlVisitor& vis) const override { vis.VisitUnion(*this); }
1095 bool CheckValid(const AidlTypenames& typenames) const override;
Jooyung Hanfe89f122020-10-14 03:49:18 +09001096 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1097 Options::Language lang) const override;
Jooyung Han2946afc2020-10-05 20:29:16 +09001098 std::string GetPreprocessDeclarationName() const override { return "union"; }
1099
1100 void Dump(CodeWriter* writer) const override;
1101 const AidlUnionDecl* AsUnionDeclaration() const override { return this; }
Jooyung Han2946afc2020-10-05 20:29:16 +09001102};
1103
Jiyong Park1deecc32018-07-17 01:14:41 +09001104class AidlInterface final : public AidlDefinedType {
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001105 public:
Steven Moreland46e9da82018-07-27 15:45:29 -07001106 AidlInterface(const AidlLocation& location, const std::string& name, const std::string& comments,
Jooyung Han829ec7c2020-12-02 12:07:36 +09001107 bool oneway_, const std::string& package,
1108 std::vector<std::unique_ptr<AidlMember>>* members);
Casey Dahlin1ae2bc52015-10-07 18:49:10 -07001109 virtual ~AidlInterface() = default;
1110
Jiyong Parkd800fef2020-07-22 18:09:43 +09001111 // non-copyable, non-movable
1112 AidlInterface(const AidlInterface&) = delete;
1113 AidlInterface(AidlInterface&&) = delete;
1114 AidlInterface& operator=(const AidlInterface&) = delete;
1115 AidlInterface& operator=(AidlInterface&&) = delete;
1116
Steven Morelandc258abc2018-07-10 14:03:38 -07001117 const AidlInterface* AsInterface() const override { return this; }
Steven Morelanded83a282018-07-17 13:27:29 -07001118 std::string GetPreprocessDeclarationName() const override { return "interface"; }
Steven Moreland5557f1c2018-07-02 13:50:23 -07001119
Jeongik Cha997281d2020-01-16 15:23:59 +09001120 void Dump(CodeWriter* writer) const override;
Jiyong Park02da7422018-07-16 16:00:26 +09001121
Steven Moreland0cea4aa2020-04-20 21:06:02 -07001122 std::set<AidlAnnotation::Type> GetSupportedAnnotations() const override;
Jooyung Han808a2a02020-12-28 16:46:54 +09001123 void Accept(AidlVisitor& vis) const override { vis.VisitInterface(*this); }
1124 bool CheckValid(const AidlTypenames& typenames) const override;
Steven Morelandd59e3172020-05-11 16:42:09 -07001125 bool LanguageSpecificCheckValid(const AidlTypenames& typenames,
1126 Options::Language lang) const override;
Jeongik Chadb0f59e2018-11-01 18:11:21 +09001127
Jiyong Park27fd7fd2020-08-27 16:25:09 +09001128 std::string GetDescriptor() const;
Casey Dahlin0a2f8be2015-09-28 16:15:29 -07001129};
Adam Lesinskiffa16862014-01-23 18:17:42 -08001130
Casey Dahlin0edf3422015-10-07 12:34:59 -07001131class AidlImport : public AidlNode {
1132 public:
Steven Moreland46e9da82018-07-27 15:45:29 -07001133 AidlImport(const AidlLocation& location, const std::string& needed_class);
Casey Dahlin0edf3422015-10-07 12:34:59 -07001134 virtual ~AidlImport() = default;
1135
Jiyong Parkd800fef2020-07-22 18:09:43 +09001136 // non-copyable, non-movable
1137 AidlImport(const AidlImport&) = delete;
1138 AidlImport(AidlImport&&) = delete;
1139 AidlImport& operator=(const AidlImport&) = delete;
1140 AidlImport& operator=(AidlImport&&) = delete;
1141
Casey Dahlin0edf3422015-10-07 12:34:59 -07001142 const std::string& GetNeededClass() const { return needed_class_; }
Casey Dahlin0edf3422015-10-07 12:34:59 -07001143
1144 private:
Casey Dahlin0edf3422015-10-07 12:34:59 -07001145 std::string needed_class_;
Casey Dahline2507492015-09-14 17:11:20 -07001146};
1147
Jiyong Park62515512020-06-08 15:57:11 +09001148// AidlDocument models an AIDL file
1149class AidlDocument : public AidlNode {
1150 public:
1151 AidlDocument(const AidlLocation& location, std::vector<std::unique_ptr<AidlImport>>& imports,
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001152 std::vector<std::unique_ptr<AidlDefinedType>>&& defined_types)
1153 : AidlNode(location),
1154 imports_(std::move(imports)),
1155 defined_types_(std::move(defined_types)) {}
Jiyong Parkd800fef2020-07-22 18:09:43 +09001156 ~AidlDocument() = default;
1157
1158 // non-copyable, non-movable
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001159 AidlDocument(const AidlDocument&) = delete;
1160 AidlDocument(AidlDocument&&) = delete;
1161 AidlDocument& operator=(const AidlDocument&) = delete;
1162 AidlDocument& operator=(AidlDocument&&) = delete;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001163
Jooyung Han808a2a02020-12-28 16:46:54 +09001164 void Accept(AidlVisitor& vis) const { vis.VisitDocument(*this); }
Jooyung Han29813842020-12-08 01:28:03 +09001165 std::optional<std::string> ResolveName(const std::string& unresolved_type) const;
Jiyong Parkd800fef2020-07-22 18:09:43 +09001166 const std::vector<std::unique_ptr<AidlImport>>& Imports() const { return imports_; }
1167 const std::vector<std::unique_ptr<AidlDefinedType>>& DefinedTypes() const {
1168 return defined_types_;
1169 }
Jiyong Park62515512020-06-08 15:57:11 +09001170
1171 private:
1172 const std::vector<std::unique_ptr<AidlImport>> imports_;
Jiyong Park8e79b7f2020-07-20 20:52:38 +09001173 const std::vector<std::unique_ptr<AidlDefinedType>> defined_types_;
Jiyong Park62515512020-06-08 15:57:11 +09001174};
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001175
1176template <typename T>
1177std::optional<T> AidlAnnotation::ParamValue(const std::string& param_name) const {
1178 auto it = parameters_.find(param_name);
1179 if (it == parameters_.end()) {
1180 return std::nullopt;
1181 }
Jooyung Han535c5e82020-12-29 15:16:59 +09001182 return it->second->EvaluatedValue<T>();
Jooyung Hanb3c77ed2020-12-26 02:02:45 +09001183}