Index: base/test/test_util.h |
diff --git a/base/test/test_util.h b/base/test/test_util.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..63f0b16c5b15ff965edf75cf11ec9a56e46dad23 |
--- /dev/null |
+++ b/base/test/test_util.h |
@@ -0,0 +1,41 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef BASE_TEST_TEST_UTIL_H_ |
+#define BASE_TEST_TEST_UTIL_H_ |
+#pragma once |
+ |
+// Generic utilities used only by tests. |
Paweł Hajdan Jr.
2011/06/09 08:43:22
Please don't add yet another _util file. How about
|
+ |
+#include <locale.h> |
+ |
+#include <string> |
+ |
+namespace base { |
+ |
+#if defined(OS_POSIX) |
+ |
+// Sets the given |locale| on construction, and restores the previous locale |
+// on destruction. |
+class ScopedSetLocale { |
+ public: |
+ explicit ScopedSetLocale(const char* locale) { |
Paweł Hajdan Jr.
2011/06/09 08:43:22
nit: Could you change the type of the parameter to
|
+ old_locale_ = setlocale(LC_ALL, NULL); |
+ setlocale(LC_ALL, locale); |
Paweł Hajdan Jr.
2011/06/09 08:43:22
Please check the return value. NULL would indicate
|
+ } |
Paweł Hajdan Jr.
2011/06/09 08:43:22
nit: Add empty line below.
|
+ ~ScopedSetLocale() { |
+ setlocale(LC_ALL, old_locale_.c_str()); |
+ } |
+ |
+ private: |
+ std::string old_locale_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(ScopedSetLocale); |
+}; |
+ |
+#endif |
+ |
+} // namespace base |
+ |
+#endif // BASE_TEST_TEST_UTIL_H_ |