1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef BASE_ANDROID_BUILD_INFO_H_ 6 #define BASE_ANDROID_BUILD_INFO_H_ 7 8 #include <jni.h> 9 10 #include <string> 11 12 #include "base/base_export.h" 13 #include "base/macros.h" 14 #include "base/memory/singleton.h" 15 16 namespace base { 17 namespace android { 18 19 // This enumeration maps to the values returned by BuildInfo::sdk_int(), 20 // indicating the Android release associated with a given SDK version. 21 enum SdkVersion { 22 SDK_VERSION_JELLY_BEAN = 16, 23 SDK_VERSION_JELLY_BEAN_MR1 = 17, 24 SDK_VERSION_JELLY_BEAN_MR2 = 18, 25 SDK_VERSION_KITKAT = 19, 26 SDK_VERSION_KITKAT_WEAR = 20, 27 SDK_VERSION_LOLLIPOP = 21, 28 SDK_VERSION_LOLLIPOP_MR1 = 22, 29 SDK_VERSION_MARSHMALLOW = 23, 30 SDK_VERSION_NOUGAT = 24 31 }; 32 33 // BuildInfo is a singleton class that stores android build and device 34 // information. It will be called from Android specific code and gets used 35 // primarily in crash reporting. 36 37 // It is also used to store the last java exception seen during JNI. 38 // TODO(nileshagrawal): Find a better place to store this info. 39 class BASE_EXPORT BuildInfo { 40 public: 41 42 ~BuildInfo() {} 43 44 // Static factory method for getting the singleton BuildInfo instance. 45 // Note that ownership is not conferred on the caller and the BuildInfo in 46 // question isn't actually freed until shutdown. This is ok because there 47 // should only be one instance of BuildInfo ever created. 48 static BuildInfo* GetInstance(); 49 50 // Const char* is used instead of std::strings because these values must be 51 // available even if the process is in a crash state. Sadly 52 // std::string.c_str() doesn't guarantee that memory won't be allocated when 53 // it is called. 54 const char* device() const { 55 return device_; 56 } 57 58 const char* manufacturer() const { 59 return manufacturer_; 60 } 61 62 const char* model() const { 63 return model_; 64 } 65 66 const char* brand() const { 67 return brand_; 68 } 69 70 const char* android_build_id() const { 71 return android_build_id_; 72 } 73 74 const char* android_build_fp() const { 75 return android_build_fp_; 76 } 77 78 const char* gms_version_code() const { 79 return gms_version_code_; 80 } 81 82 const char* package_version_code() const { 83 return package_version_code_; 84 } 85 86 const char* package_version_name() const { 87 return package_version_name_; 88 } 89 90 const char* package_label() const { 91 return package_label_; 92 } 93 94 const char* package_name() const { 95 return package_name_; 96 } 97 98 const char* build_type() const { 99 return build_type_; 100 } 101 102 int sdk_int() const { 103 return sdk_int_; 104 } 105 106 const char* java_exception_info() const { 107 return java_exception_info_; 108 } 109 110 void SetJavaExceptionInfo(const std::string& info); 111 112 void ClearJavaExceptionInfo(); 113 114 private: 115 friend struct BuildInfoSingletonTraits; 116 117 explicit BuildInfo(JNIEnv* env); 118 119 // Const char* is used instead of std::strings because these values must be 120 // available even if the process is in a crash state. Sadly 121 // std::string.c_str() doesn't guarantee that memory won't be allocated when 122 // it is called. 123 const char* const device_; 124 const char* const manufacturer_; 125 const char* const model_; 126 const char* const brand_; 127 const char* const android_build_id_; 128 const char* const android_build_fp_; 129 const char* const gms_version_code_; 130 const char* const package_version_code_; 131 const char* const package_version_name_; 132 const char* const package_label_; 133 const char* const package_name_; 134 const char* const build_type_; 135 const int sdk_int_; 136 // This is set via set_java_exception_info, not at constructor time. 137 const char* java_exception_info_; 138 139 DISALLOW_COPY_AND_ASSIGN(BuildInfo); 140 }; 141 142 } // namespace android 143 } // namespace base 144 145 #endif // BASE_ANDROID_BUILD_INFO_H_ 146