Index: webrtc/modules/utility/source/helpers_ios.mm |
diff --git a/webrtc/test/testsupport/iosfileutils.mm b/webrtc/modules/utility/source/helpers_ios.mm |
similarity index 51% |
copy from webrtc/test/testsupport/iosfileutils.mm |
copy to webrtc/modules/utility/source/helpers_ios.mm |
index f3615ed6814b41a696fd04da166a96a59237c2a9..ea95823a2fdb850d868b4f38cbe377c194f59e3d 100644 |
--- a/webrtc/test/testsupport/iosfileutils.mm |
+++ b/webrtc/modules/utility/source/helpers_ios.mm |
@@ -1,5 +1,5 @@ |
/* |
- * Copyright 2015 The WebRTC Project Authors. All rights reserved. |
+ * Copyright (c) 2015 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 |
@@ -10,18 +10,15 @@ |
#if defined(WEBRTC_IOS) |
-#if !defined(__has_feature) || !__has_feature(objc_arc) |
-#error "This file requires ARC support." |
-#endif |
- |
+#import <AVFoundation/AVFoundation.h> |
#import <Foundation/Foundation.h> |
-#include <string.h> |
+#include <pthread.h> |
#include "webrtc/base/checks.h" |
-#include "webrtc/typedefs.h" |
+#include "webrtc/modules/utility/interface/helpers_ios.h" |
namespace webrtc { |
-namespace test { |
+namespace ios { |
// TODO(henrika): move to shared location. |
// See https://code.google.com/p/webrtc/issues/detail?id=4773 for details. |
@@ -39,22 +36,39 @@ std::string StdStringFromNSString(NSString* nsString) { |
[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) { |
- @autoreleasepool { |
- NSString* path = NSStringFromStdString(name); |
- NSString* fileName = path.lastPathComponent; |
- NSString* fileType = NSStringFromStdString(extension); |
- // Get full pathname for the resource identified by the name and extension. |
- NSString* pathString = [[NSBundle mainBundle] pathForResource:fileName |
- ofType:fileType]; |
- return StdStringFromNSString(pathString); |
+bool CheckAndLogError(BOOL success, NSError* error) { |
+ if (!success) { |
+ NSLog(@"Error: %ld, %@", (long)error.code, error.localizedDescription); |
tkchin_webrtc
2015/07/06 03:46:29
I think it is better to stick with webrtc LOG macr
henrika_webrtc
2015/07/07 16:01:39
Done.
henrika_webrtc
2015/07/08 15:20:10
Not sure if my way is what you wanted. Hope it loo
tkchin_webrtc
2015/07/08 19:41:14
Yeah, just wanted LS_ERROR. Format is up to you, l
|
+ return false; |
} |
+ return true; |
+} |
+ |
+std::string GetCurrentThreadDescription() { |
+ NSString* name = [NSString stringWithFormat:@"%@", [NSThread currentThread]]; |
tkchin_webrtc
2015/07/06 03:46:29
I would add these functions to logging.cc so that
henrika_webrtc
2015/07/07 16:01:39
Great idea, let me add support for GetThreadId as
henrika_webrtc
2015/07/08 15:20:10
Found a way. Done. Given new calls in the added un
|
+ return StdStringFromNSString(name); |
+} |
+ |
+std::string GetThreadId() { |
+ char buf[21]; // Big enough to hold a kuint64max plus terminating NULL. |
+ pid_t thread_id = pthread_mach_thread_np(pthread_self()); |
+ CHECK_LT(snprintf(buf, sizeof(buf), "%i", thread_id), |
+ static_cast<int>(sizeof(buf))) |
+ << "Thread id is bigger than uint64??"; |
+ return std::string(buf); |
+} |
+ |
+std::string GetThreadInfo() { |
+ return "@[tid=" + GetThreadId() + "]"; |
+} |
+ |
+AVAudioSession* GetAudioSession() { |
tkchin_webrtc
2015/07/06 03:46:29
Is this necessary since it's a one-liner?
henrika_webrtc
2015/07/07 16:01:39
Removed.
|
+ // Implicit initialization happens when we obtain a reference to the |
+ // AVAudioSession object. |
+ return [AVAudioSession sharedInstance]; |
} |
-} // namespace test |
+} // namespace ios |
} // namespace webrtc |
#endif // defined(WEBRTC_IOS) |