#include <string>
#include <list>
#include <stdarg.h>
+
+#include <chrono>
+
#include <private/android_filesystem_config.h>
#include "utils/RWLock.h"
const uid_t INVALID_UID = static_cast<uid_t>(-1);
+class Stopwatch {
+public:
+ Stopwatch() : mStart(std::chrono::steady_clock::now()) {}
+ virtual ~Stopwatch() {};
+
+ float timeTaken() const {
+ using ms = std::chrono::duration<float, std::ratio<1, 1000>>;
+ return (std::chrono::duration_cast<ms>(
+ std::chrono::steady_clock::now() - mStart)).count();
+ }
+
+private:
+ std::chrono::time_point<std::chrono::steady_clock> mStart;
+};
+
namespace android {
namespace net {
typedef std::unique_ptr<addrinfo, AddrinfoDeleter> ScopedAddrinfo;
-class Stopwatch {
-public:
- Stopwatch(): mStart(std::chrono::steady_clock::now()) {}
- float timeTaken() {
- using ms = std::chrono::duration<float, std::ratio<1, 1000>>;
- return (std::chrono::duration_cast<ms>(
- std::chrono::steady_clock::now() - mStart)).count();
- }
-
-private:
- std::chrono::time_point<std::chrono::steady_clock> mStart;
- std::string mName;
-};
-
int checkError(int fd) {
struct {
nlmsghdr h;
};
-class TimedOperation {
+class TimedOperation : public Stopwatch {
public:
- TimedOperation(std::string name): mStart(std::chrono::steady_clock::now()), mName(name) {}
+ TimedOperation(std::string name): mName(name) {}
virtual ~TimedOperation() {
- using ms = std::chrono::duration<float, std::ratio<1, 1000>>;
- fprintf(stderr, " %s: %6.1f ms\n", mName.c_str(),
- std::chrono::duration_cast<ms>(std::chrono::steady_clock::now() - mStart).count());
+ fprintf(stderr, " %s: %6.1f ms\n", mName.c_str(), timeTaken());
}
private:
- std::chrono::time_point<std::chrono::steady_clock> mStart;
std::string mName;
};