/* * Copyright (C) 2011 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ART_RUNTIME_PARSED_OPTIONS_H_ #define ART_RUNTIME_PARSED_OPTIONS_H_ #include #include "runtime.h" #include "trace.h" namespace art { class ParsedOptions { public: // returns null if problem parsing and ignore_unrecognized is false static ParsedOptions* Create(const Runtime::Options& options, bool ignore_unrecognized); const std::vector* boot_class_path_; std::string boot_class_path_string_; std::string class_path_string_; std::string image_; bool check_jni_; std::string jni_trace_; CompilerCallbacks* compiler_callbacks_; bool is_zygote_; bool interpreter_only_; bool is_explicit_gc_disabled_; bool use_tlab_; bool verify_pre_gc_heap_; bool verify_post_gc_heap_; bool verify_pre_gc_rosalloc_; bool verify_post_gc_rosalloc_; unsigned int long_pause_log_threshold_; unsigned int long_gc_log_threshold_; bool dump_gc_performance_on_shutdown_; bool ignore_max_footprint_; size_t heap_initial_size_; size_t heap_maximum_size_; size_t heap_growth_limit_; size_t heap_min_free_; size_t heap_max_free_; double heap_target_utilization_; unsigned int parallel_gc_threads_; unsigned int conc_gc_threads_; gc::CollectorType collector_type_; gc::CollectorType background_collector_type_; size_t stack_size_; unsigned int max_spins_before_thin_lock_inflation_; bool low_memory_mode_; unsigned int lock_profiling_threshold_; std::string stack_trace_file_; bool method_trace_; std::string method_trace_file_; unsigned int method_trace_file_size_; bool (*hook_is_sensitive_thread_)(); jint (*hook_vfprintf_)(FILE* stream, const char* format, va_list ap); void (*hook_exit_)(jint status); void (*hook_abort_)(); std::vector properties_; std::vector compiler_options_; std::vector image_compiler_options_; bool profile_; std::string profile_output_filename_; uint32_t profile_period_s_; uint32_t profile_duration_s_; uint32_t profile_interval_us_; double profile_backoff_coefficient_; ProfilerClockSource profile_clock_source_; bool verify_; static constexpr uint32_t kExplicitNullCheck = 1; static constexpr uint32_t kExplicitSuspendCheck = 2; static constexpr uint32_t kExplicitStackOverflowCheck = 4; uint32_t explicit_checks_; private: ParsedOptions() {} void Usage(const char* fmt, ...); void UsageMessage(FILE* stream, const char* fmt, ...); void UsageMessageV(FILE* stream, const char* fmt, va_list ap); void Exit(int status); void Abort(); bool Parse(const Runtime::Options& options, bool ignore_unrecognized); bool ParseStringAfterChar(const std::string& option, char after_char, std::string* parsed_value); bool ParseInteger(const std::string& option, char after_char, int* parsed_value); bool ParseUnsignedInteger(const std::string& option, char after_char, unsigned int* parsed_value); bool ParseDouble(const std::string& option, char after_char, double min, double max, double* parsed_value); }; } // namespace art #endif // ART_RUNTIME_PARSED_OPTIONS_H_