Index: webrtc/test/testsupport/iosfileutils.mm |
diff --git a/webrtc/test/testsupport/iosfileutils.mm b/webrtc/test/testsupport/iosfileutils.mm |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f5c4e57edccb98a175158966ee1040e34d67e091 |
--- /dev/null |
+++ b/webrtc/test/testsupport/iosfileutils.mm |
@@ -0,0 +1,58 @@ |
+/* |
+ * Copyright 2014 The WebRTC Project Authors. All rights reserved. |
+ * |
+ * Use of this source code is governed by a BSD-style license |
+ * that can be found in the LICENSE file in the root of the source |
+ * tree. An additional intellectual property rights grant can be found |
+ * in the file PATENTS. All contributing project authors may |
+ * be found in the AUTHORS file in the root of the source tree. |
+ */ |
+ |
+#if defined(WEBRTC_IOS) |
+ |
+#if !defined(__has_feature) || !__has_feature(objc_arc) |
+#error "This file requires ARC support." |
+#endif |
+ |
+#import <Foundation/Foundation.h> |
+#include <string.h> |
+ |
+#include "webrtc/base/checks.h" |
+#include "webrtc/typedefs.h" |
+ |
+NSString* NSStringFromStdString(const std::string& stdString) { |
tkchin_webrtc
2015/06/12 17:43:35
We haven't been consistent with placement of * in
henrika_webrtc
2015/06/15 08:46:29
Filed https://code.google.com/p/webrtc/issues/deta
tkchin_webrtc
2015/06/15 20:23:13
Here we're defining static functions, but making u
|
+ // std::string may contain null termination character so we construct |
+ // using length. |
+ return [[NSString alloc] initWithBytes:stdString.data() |
+ length:stdString.length() |
+ encoding:NSUTF8StringEncoding]; |
+} |
+ |
+std::string StdStringFromNSString(NSString* nsString) { |
+ NSData* charData = [nsString dataUsingEncoding:NSUTF8StringEncoding]; |
+ return std::string(reinterpret_cast<const char*>([charData bytes]), |
+ [charData length]); |
+} |
+ |
+// For iOS, resource files are added to the application bundle in the root |
+// and not in separate folders as is the case for other platforms. This method |
+// therefore removes any prepended folders and uses only the actual file name. |
+std::string IOSResourcePath(std::string name, std::string extension) { |
+ std::string file_name = name; |
tkchin_webrtc
2015/06/12 17:43:35
I think it is better to avoid mixing if all all po
henrika_webrtc
2015/06/15 08:46:29
Great stuff. I am no Objective-C guru...yet ;-)
|
+ std::size_t pos = name.find_last_of("/"); |
+ if (pos != std::string::npos) { |
+ // Extract name of file and exclude the added path. |
+ // Example: name: "audio_coding/testfile32kHz" => file_name: "testfile32kHz" |
+ file_name = name.substr(pos + 1); |
+ } |
+ @autoreleasepool { |
+ NSString* nameString = NSStringFromStdString(file_name); |
+ NSString* typeString = NSStringFromStdString(extension); |
+ // Get full pathname for the resource identified by the name and extension. |
+ NSString* pathString = [[NSBundle mainBundle] pathForResource: nameString |
tkchin_webrtc
2015/06/12 17:43:35
remove spaces after :
henrika_webrtc
2015/06/15 08:46:29
Done.
|
+ ofType: typeString]; |
+ return StdStringFromNSString(pathString); |
+ } |
+} |
+ |
+#endif // defined(WEBRTC_IOS) |