blob: 98d818e9234dc947ec3127a4a8206898b67f52b4 [file] [log] [blame]
Christopher Wiley4427d862015-09-14 11:07:39 -07001/*
Christopher Wileyb1bbdf82016-04-21 11:43:45 -07002 * Copyright (C) 2015, The Android Open Source Project *
Christopher Wiley4427d862015-09-14 11:07:39 -07003 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
Steven Moreland9fccf582018-08-27 20:36:27 -070016#pragma once
Adam Lesinskiffa16862014-01-23 18:17:42 -080017
Jiyong Park8c380532018-08-30 14:55:26 +090018#include <set>
Adam Lesinskiffa16862014-01-23 18:17:42 -080019#include <string>
20#include <vector>
21
Jooyung Han888c5bc2020-12-22 17:28:47 +090022#include "diagnostics.h"
23
Christopher Wiley4427d862015-09-14 11:07:39 -070024namespace android {
25namespace aidl {
Adam Lesinskiffa16862014-01-23 18:17:42 -080026
Jiyong Park8c380532018-08-30 14:55:26 +090027using std::set;
Jiyong Park1d2df7d2018-07-23 15:22:50 +090028using std::string;
29using std::vector;
30
Jiyong Park223274e2021-09-24 14:14:12 +090031// The oldest SDK version that is supported for each backend. For non-Java backends, these are the
32// platform SDK version where the support for the backend was added. For Java backend, this should
33// ideally be 1, but is actually 23 as the generated code uses some APIs (like
34// `Parcel.writeTypedObject`) added in 23.
35constexpr uint32_t DEFAULT_SDK_VERSION_JAVA = 23;
36constexpr uint32_t DEFAULT_SDK_VERSION_CPP = 23;
37constexpr uint32_t DEFAULT_SDK_VERSION_NDK = 29;
38constexpr uint32_t DEFAULT_SDK_VERSION_RUST = 31;
39
Jiyong Park6f77e0c2018-07-28 16:55:44 +090040// A simple wrapper around ostringstream. This is just to make Options class
41// copiable by the implicit copy constructor. If ostingstream is not wrapped,
42// the implcit copy constructor is not generated because ostringstream isn't
43// copiable. This class makes the field copiable by having a copy constructor
44// that does not copy the underlying stream.
45class ErrorMessage {
46 public:
47 ErrorMessage() = default;
48 ErrorMessage(const ErrorMessage&) {}
49 std::ostringstream stream_;
Jiyong Parke1d02682018-08-01 12:18:02 +090050
51 template <typename T>
52 ErrorMessage& operator<<(T& t) {
53 stream_ << t;
Jiyong Park6f77e0c2018-07-28 16:55:44 +090054 return *this;
55 }
Jiyong Parke1d02682018-08-01 12:18:02 +090056
57 template <typename T>
58 ErrorMessage& operator<<(const T& t) {
59 stream_ << t;
Jiyong Park6f77e0c2018-07-28 16:55:44 +090060 return *this;
61 }
Jiyong Parke1d02682018-08-01 12:18:02 +090062
63 // for "<< endl"
Jiyong Park6f77e0c2018-07-28 16:55:44 +090064 ErrorMessage& operator<<(std::ostream& (*f)(std::ostream&)) {
65 f(stream_);
66 return *this;
67 }
68};
69
Jooyung Han808a2a02020-12-28 16:46:54 +090070// Handles warning-related options (e.g. -W, -w, ...)
Jooyung Han888c5bc2020-12-22 17:28:47 +090071class WarningOptions {
72 public:
73 std::vector<const char*> Parse(int argc, const char* const argv[], ErrorMessage& error_message);
Jooyung Han808a2a02020-12-28 16:46:54 +090074 DiagnosticMapping GetDiagnosticMapping() const;
Jooyung Han888c5bc2020-12-22 17:28:47 +090075
76 private:
77 bool as_errors_ = false; // -Werror
78 bool enable_all_ = false; // -Weverything
79 bool disable_all_ = false; // -w
80 std::set<std::string> enabled_; // -Wfoo
81 std::set<std::string> disabled_; // -Wno-foo
82 std::set<std::string> no_errors_; // -Wno-error=foo
Jooyung Han888c5bc2020-12-22 17:28:47 +090083};
84
Jiyong Park74595c12018-07-23 15:22:50 +090085class Options final {
Steven Morelandda0654f2018-07-17 12:24:38 -070086 public:
Andrei Homescub62afd92020-05-11 19:24:59 -070087 enum class Language { UNSPECIFIED, JAVA, CPP, NDK, RUST };
Steven Morelandda0654f2018-07-17 12:24:38 -070088
Steven Moreland481f5932021-08-09 17:31:05 -070089 enum class Task { HELP, COMPILE, PREPROCESS, DUMP_API, CHECK_API, DUMP_MAPPINGS };
Steven Morelandda0654f2018-07-17 12:24:38 -070090
Jooyung Hanb8a97772021-01-19 01:27:38 +090091 enum class CheckApiLevel { COMPATIBLE, EQUAL };
92
Steven Morelanda57d0a62019-07-30 09:41:14 -070093 enum class Stability { UNSPECIFIED, VINTF };
94 bool StabilityFromString(const std::string& stability, Stability* out_stability);
95
Jiyong Park74595c12018-07-23 15:22:50 +090096 Options(int argc, const char* const argv[], Language default_lang = Language::UNSPECIFIED);
Steven Morelandda0654f2018-07-17 12:24:38 -070097
Jooyung Han8e3b72c2021-05-22 02:54:37 +090098 Options PlusImportDir(const std::string& import_dir) const {
99 Options copy(*this);
100 copy.import_dirs_.insert(import_dir);
101 return copy;
102 }
103
Jiyong Park6f77e0c2018-07-28 16:55:44 +0900104 static Options From(const string& cmdline);
105
106 static Options From(const vector<string>& args);
107
Steven Moreland6cee3482018-07-18 14:39:58 -0700108 // Contain no references to unstructured data types (such as a parcelable that is
109 // implemented in Java). These interfaces aren't inherently stable but they have the
110 // capacity to be stabilized.
111 bool IsStructured() const { return structured_; }
112
Steven Morelanda57d0a62019-07-30 09:41:14 -0700113 Stability GetStability() const { return stability_; }
114
Jiyong Park223274e2021-09-24 14:14:12 +0900115 uint32_t GetMinSdkVersion() const { return min_sdk_version_; }
116
Jiyong Park74595c12018-07-23 15:22:50 +0900117 Language TargetLanguage() const { return language_; }
Steven Morelandc26d8142018-09-17 14:25:33 -0700118 bool IsCppOutput() const { return language_ == Language::CPP || language_ == Language::NDK; }
Steven Morelandda0654f2018-07-17 12:24:38 -0700119
Jiyong Park74595c12018-07-23 15:22:50 +0900120 Task GetTask() const { return task_; }
Steven Morelandda0654f2018-07-17 12:24:38 -0700121
Jooyung Hanb8a97772021-01-19 01:27:38 +0900122 CheckApiLevel GetCheckApiLevel() const { return check_api_level_; }
123
Jiyong Park8c380532018-08-30 14:55:26 +0900124 const set<string>& ImportDirs() const { return import_dirs_; }
Jiyong Park3c35e392018-08-30 13:10:30 +0900125
Jiyong Park74595c12018-07-23 15:22:50 +0900126 const vector<string>& PreprocessedFiles() const { return preprocessed_files_; }
Adam Lesinskiffa16862014-01-23 18:17:42 -0800127
Jiyong Park74595c12018-07-23 15:22:50 +0900128 string DependencyFile() const {
Jiyong Park74595c12018-07-23 15:22:50 +0900129 return dependency_file_;
130 }
Christopher Wiley4427d862015-09-14 11:07:39 -0700131
Jiyong Park74595c12018-07-23 15:22:50 +0900132 bool AutoDepFile() const { return auto_dep_file_; }
Christopher Wileyef4132c2015-11-05 15:47:40 -0800133
Steven Morelanda4b6b292021-09-01 12:35:28 -0700134 bool GenRpc() const { return gen_rpc_; }
135
Jiyong Park74595c12018-07-23 15:22:50 +0900136 bool GenTraces() const { return gen_traces_; }
Steven Morelandda0654f2018-07-17 12:24:38 -0700137
Jiyong Park74595c12018-07-23 15:22:50 +0900138 bool GenTransactionNames() const { return gen_transaction_names_; }
Christopher Wiley4427d862015-09-14 11:07:39 -0700139
Jiyong Park74595c12018-07-23 15:22:50 +0900140 bool DependencyFileNinja() const { return dependency_file_ninja_; }
141
142 const vector<string>& InputFiles() const { return input_files_; }
143
144 // Path to the output file. This is used only when there is only one
145 // output file for the invocation. When there are multiple outputs
146 // (e.g. compile multiple AIDL files), output files are created under
147 // OutputDir().
148 const string& OutputFile() const { return output_file_; }
149
150 // Path to the directory where output file(s) will be generated under.
151 const string& OutputDir() const { return output_dir_; }
152
153 // Path to the directory where header file(s) will be generated under.
154 // Only used when TargetLanguage() == Language::CPP
155 const string& OutputHeaderDir() const { return output_header_dir_; }
156
157 bool FailOnParcelable() const { return fail_on_parcelable_; }
158
Jiyong Park309668e2018-07-28 16:55:44 +0900159 int Version() const { return version_; }
160
Paul Trautrimb77048c2020-01-21 16:39:32 +0900161 string Hash() const { return hash_; }
162
Jiyong Parkce50e262018-10-29 09:54:20 +0900163 bool GenLog() const { return gen_log_; }
164
Jooyung Han252657e2021-02-27 02:51:39 +0900165 bool DumpNoLicense() const { return dump_no_license_; }
166
Jiyong Park6f77e0c2018-07-28 16:55:44 +0900167 bool Ok() const { return error_message_.stream_.str().empty(); }
Jiyong Park74595c12018-07-23 15:22:50 +0900168
Jiyong Park6f77e0c2018-07-28 16:55:44 +0900169 string GetErrorMessage() const { return error_message_.stream_.str(); }
Jiyong Park74595c12018-07-23 15:22:50 +0900170
171 string GetUsage() const;
Andreas Gampee9c816e2018-03-14 09:05:48 -0700172
Andrei Onea8714b022019-02-01 18:55:54 +0000173 bool GenApiMapping() const { return task_ == Task::DUMP_MAPPINGS; }
174
Jooyung Han808a2a02020-12-28 16:46:54 +0900175 DiagnosticMapping GetDiagnosticMapping() const { return warning_options_.GetDiagnosticMapping(); }
Jooyung Han888c5bc2020-12-22 17:28:47 +0900176
Steven Morelandda0654f2018-07-17 12:24:38 -0700177 // The following are for testability, but cannot be influenced on the command line.
Andreas Gampee9c816e2018-03-14 09:05:48 -0700178 // Threshold of interface methods to enable outlining of onTransact cases.
179 size_t onTransact_outline_threshold_{275u};
180 // Number of cases to _not_ outline, if outlining is enabled.
181 size_t onTransact_non_outline_count_{275u};
182
Christopher Wiley4427d862015-09-14 11:07:39 -0700183 private:
Jiyong Park74595c12018-07-23 15:22:50 +0900184 Options() = default;
Christopher Wiley4427d862015-09-14 11:07:39 -0700185
Jiyong Park74595c12018-07-23 15:22:50 +0900186 const string myname_;
187 Language language_ = Language::UNSPECIFIED;
188 Task task_ = Task::COMPILE;
Jooyung Hanb8a97772021-01-19 01:27:38 +0900189 CheckApiLevel check_api_level_ = CheckApiLevel::COMPATIBLE;
Jiyong Park8c380532018-08-30 14:55:26 +0900190 set<string> import_dirs_;
Jiyong Park74595c12018-07-23 15:22:50 +0900191 vector<string> preprocessed_files_;
192 string dependency_file_;
Steven Morelanda4b6b292021-09-01 12:35:28 -0700193 bool gen_rpc_ = false;
Jiyong Park74595c12018-07-23 15:22:50 +0900194 bool gen_traces_ = false;
195 bool gen_transaction_names_ = false;
196 bool dependency_file_ninja_ = false;
Steven Morelanda57d0a62019-07-30 09:41:14 -0700197 bool structured_ = false;
198 Stability stability_ = Stability::UNSPECIFIED;
Jiyong Park223274e2021-09-24 14:14:12 +0900199 uint32_t min_sdk_version_ = 0; // invalid version
Jiyong Park74595c12018-07-23 15:22:50 +0900200 string output_dir_;
201 string output_header_dir_;
202 bool fail_on_parcelable_ = false;
203 bool auto_dep_file_ = false;
204 vector<string> input_files_;
205 string output_file_;
Jiyong Park309668e2018-07-28 16:55:44 +0900206 int version_ = 0;
Paul Trautrimb77048c2020-01-21 16:39:32 +0900207 string hash_ = "";
Jiyong Parkce50e262018-10-29 09:54:20 +0900208 bool gen_log_ = false;
Jooyung Han252657e2021-02-27 02:51:39 +0900209 bool dump_no_license_ = false;
Jiyong Park6f77e0c2018-07-28 16:55:44 +0900210 ErrorMessage error_message_;
Jooyung Han888c5bc2020-12-22 17:28:47 +0900211 WarningOptions warning_options_;
Adam Lesinskiffa16862014-01-23 18:17:42 -0800212};
213
Jooyung Han9435e9a2021-01-06 10:16:31 +0900214std::string to_string(Options::Language language);
215
Christopher Wiley4427d862015-09-14 11:07:39 -0700216} // namespace aidl
Steven Morelandf4c64df2019-07-29 19:54:04 -0700217} // namespace android