summaryrefslogtreecommitdiffstats
path: root/libs/utils
diff options
context:
space:
mode:
authorMathias Agopian <mathias@google.com>2013-05-08 16:04:13 -0700
committerAlex Ray <aray@google.com>2013-07-30 13:57:01 -0700
commit4485d0d966d062d1b45b635e2447a2d2f96c3f38 (patch)
tree89a0c95a7a27261e626dbedfd3fcacff01e41b20 /libs/utils
parent9eb2a3b1c0cc1ff3082a9283e24c8babc112f56b (diff)
downloadcore-4485d0d966d062d1b45b635e2447a2d2f96c3f38.tar.gz
core-4485d0d966d062d1b45b635e2447a2d2f96c3f38.tar.bz2
core-4485d0d966d062d1b45b635e2447a2d2f96c3f38.zip
new String8, String16 ctors to initialize empty static strings with static linkage
when libutils is statically linked, the ordering of the static initializer is not guaranteed and therefore it's unsafe to use empty static strings: e.g.: static String8 sThisStaticStringIsNotSafe; instead, this new constructor can be used: static String8 sThisStaticStringIsSafe(kEmptyString); Change-Id: Ia3daf1cab1c97d021c0ee9c2b394b5e27e8d6c0d
Diffstat (limited to 'libs/utils')
-rw-r--r--libs/utils/String16.cpp13
-rw-r--r--libs/utils/String8.cpp17
2 files changed, 26 insertions, 4 deletions
diff --git a/libs/utils/String16.cpp b/libs/utils/String16.cpp
index c856ceb9b..b09b728ad 100644
--- a/libs/utils/String16.cpp
+++ b/libs/utils/String16.cpp
@@ -93,6 +93,19 @@ String16::String16()
{
}
+String16::String16(StaticLinkage)
+ : mString(0)
+{
+ // this constructor is used when we can't rely on the static-initializers
+ // having run. In this case we always allocate an empty string. It's less
+ // efficient than using getEmptyString(), but we assume it's uncommon.
+
+ char16_t* data = static_cast<char16_t*>(
+ SharedBuffer::alloc(sizeof(char16_t))->data());
+ data[0] = 0;
+ mString = data;
+}
+
String16::String16(const String16& o)
: mString(o.mString)
{
diff --git a/libs/utils/String8.cpp b/libs/utils/String8.cpp
index 413928abb..e852d77b7 100644
--- a/libs/utils/String8.cpp
+++ b/libs/utils/String8.cpp
@@ -47,16 +47,12 @@ void initialize_string8();
static inline char* getEmptyString()
{
- if (!gEmptyStringBuf) initialize_string8();
-
gEmptyStringBuf->acquire();
return gEmptyString;
}
void initialize_string8()
{
- if (gEmptyStringBuf) return;
-
// HACK: This dummy dependency forces linking libutils Static.cpp,
// which is needed to initialize String8/String16 classes.
// These variables are named for Darwin, but are needed elsewhere too,
@@ -146,6 +142,19 @@ String8::String8()
{
}
+String8::String8(StaticLinkage)
+ : mString(0)
+{
+ // this constructor is used when we can't rely on the static-initializers
+ // having run. In this case we always allocate an empty string. It's less
+ // efficient than using getEmptyString(), but we assume it's uncommon.
+
+ char* data = static_cast<char*>(
+ SharedBuffer::alloc(sizeof(char))->data());
+ data[0] = 0;
+ mString = data;
+}
+
String8::String8(const String8& o)
: mString(o.mString)
{