• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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/memory/singleton.h"
14 
15 namespace base {
16 namespace android {
17 
18 // BuildInfo is a singleton class that stores android build and device
19 // information. It will be called from Android specific code and gets used
20 // primarily in crash reporting.
21 
22 // It is also used to store the last java exception seen during JNI.
23 // TODO(nileshagrawal): Find a better place to store this info.
24 class BASE_EXPORT BuildInfo {
25  public:
26 
~BuildInfo()27   ~BuildInfo() {}
28 
29   // Static factory method for getting the singleton BuildInfo instance.
30   // Note that ownership is not conferred on the caller and the BuildInfo in
31   // question isn't actually freed until shutdown. This is ok because there
32   // should only be one instance of BuildInfo ever created.
33   static BuildInfo* GetInstance();
34 
35   // Const char* is used instead of std::strings because these values must be
36   // available even if the process is in a crash state. Sadly
37   // std::string.c_str() doesn't guarantee that memory won't be allocated when
38   // it is called.
device()39   const char* device() const {
40     return device_;
41   }
42 
manufacturer()43   const char* manufacturer() const {
44     return manufacturer_;
45   }
46 
model()47   const char* model() const {
48     return model_;
49   }
50 
brand()51   const char* brand() const {
52     return brand_;
53   }
54 
android_build_id()55   const char* android_build_id() const {
56     return android_build_id_;
57   }
58 
android_build_fp()59   const char* android_build_fp() const {
60     return android_build_fp_;
61   }
62 
package_version_code()63   const char* package_version_code() const {
64     return package_version_code_;
65   }
66 
package_version_name()67   const char* package_version_name() const {
68     return package_version_name_;
69   }
70 
package_label()71   const char* package_label() const {
72     return package_label_;
73   }
74 
package_name()75   const char* package_name() const {
76     return package_name_;
77   }
78 
build_type()79   const char* build_type() const {
80     return build_type_;
81   }
82 
sdk_int()83   int sdk_int() const {
84     return sdk_int_;
85   }
86 
java_exception_info()87   const char* java_exception_info() const {
88     return java_exception_info_;
89   }
90 
91   void set_java_exception_info(const std::string& info);
92 
93   static bool RegisterBindings(JNIEnv* env);
94 
95  private:
96   friend struct BuildInfoSingletonTraits;
97 
98   explicit BuildInfo(JNIEnv* env);
99 
100   // Const char* is used instead of std::strings because these values must be
101   // available even if the process is in a crash state. Sadly
102   // std::string.c_str() doesn't guarantee that memory won't be allocated when
103   // it is called.
104   const char* const device_;
105   const char* const manufacturer_;
106   const char* const model_;
107   const char* const brand_;
108   const char* const android_build_id_;
109   const char* const android_build_fp_;
110   const char* const package_version_code_;
111   const char* const package_version_name_;
112   const char* const package_label_;
113   const char* const package_name_;
114   const char* const build_type_;
115   const int sdk_int_;
116   // This is set via set_java_exception_info, not at constructor time.
117   const char* java_exception_info_;
118 
119   DISALLOW_COPY_AND_ASSIGN(BuildInfo);
120 };
121 
122 }  // namespace android
123 }  // namespace base
124 
125 #endif  // BASE_ANDROID_BUILD_INFO_H_
126