annotate system/System.cpp @ 170:b23eea68357e

* flesh out StorageAdviser
author Chris Cannam
date Tue, 26 Sep 2006 12:58:12 +0000
parents 603991c63ff6
children ebf55cf0d34d
rev   line source
Chris@150 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@150 2
Chris@150 3 /*
Chris@150 4 Sonic Visualiser
Chris@150 5 An audio file viewer and annotation editor.
Chris@150 6 Centre for Digital Music, Queen Mary, University of London.
Chris@150 7 This file copyright 2006 Chris Cannam.
Chris@150 8
Chris@150 9 This program is free software; you can redistribute it and/or
Chris@150 10 modify it under the terms of the GNU General Public License as
Chris@150 11 published by the Free Software Foundation; either version 2 of the
Chris@150 12 License, or (at your option) any later version. See the file
Chris@150 13 COPYING included with this distribution for more information.
Chris@150 14 */
Chris@150 15
Chris@150 16 #include "System.h"
Chris@150 17
Chris@168 18 #include <QStringList>
Chris@168 19 #include <QString>
Chris@168 20
Chris@170 21 #include <stdint.h>
Chris@170 22
Chris@150 23 #ifndef _WIN32
Chris@150 24 #include <signal.h>
Chris@168 25 #include <sys/statvfs.h>
Chris@150 26 #endif
Chris@150 27
Chris@150 28 #include <iostream>
Chris@150 29
Chris@150 30 #ifdef _WIN32
Chris@150 31
Chris@150 32 extern "C" {
Chris@150 33
Chris@150 34 void usleep(unsigned long usec)
Chris@150 35 {
Chris@150 36 ::Sleep(usec / 1000);
Chris@150 37 }
Chris@150 38
Chris@150 39 void gettimeofday(struct timeval *tv, void *tz)
Chris@150 40 {
Chris@150 41 union {
Chris@150 42 long long ns100;
Chris@150 43 FILETIME ft;
Chris@150 44 } now;
Chris@150 45
Chris@150 46 ::GetSystemTimeAsFileTime(&now.ft);
Chris@150 47 tv->tv_usec = (long)((now.ns100 / 10LL) % 1000000LL);
Chris@150 48 tv->tv_sec = (long)((now.ns100 - 116444736000000000LL) / 10000000LL);
Chris@150 49 }
Chris@150 50
Chris@150 51 }
Chris@150 52
Chris@150 53 #endif
Chris@150 54
Chris@150 55 ProcessStatus
Chris@150 56 GetProcessStatus(int pid)
Chris@150 57 {
Chris@150 58 #ifdef _WIN32
Chris@150 59 HANDLE handle = OpenProcess(PROCESS_QUERY_INFORMATION, FALSE, pid);
Chris@150 60 if (!handle) {
Chris@150 61 return ProcessNotRunning;
Chris@150 62 } else {
Chris@150 63 CloseHandle(handle);
Chris@150 64 return ProcessRunning;
Chris@150 65 }
Chris@150 66 #else
Chris@150 67 if (kill(getpid(), 0) == 0) {
Chris@150 68 if (kill(pid, 0) == 0) {
Chris@150 69 return ProcessRunning;
Chris@150 70 } else {
Chris@150 71 return ProcessNotRunning;
Chris@150 72 }
Chris@150 73 } else {
Chris@150 74 return UnknownProcessStatus;
Chris@150 75 }
Chris@150 76 #endif
Chris@150 77 }
Chris@150 78
Chris@170 79 void
Chris@170 80 GetRealMemoryMBAvailable(int &available, int &total)
Chris@168 81 {
Chris@170 82 available = -1;
Chris@170 83 total = -1;
Chris@170 84
Chris@169 85 FILE *meminfo = fopen("/proc/meminfo", "r");
Chris@170 86 if (!meminfo) return;
Chris@169 87
Chris@169 88 char buf[256];
Chris@169 89 while (!feof(meminfo)) {
Chris@169 90 fgets(buf, 256, meminfo);
Chris@170 91 bool isMemFree = (strncmp(buf, "MemFree:", 8) == 0);
Chris@170 92 bool isMemTotal = (!isMemFree && (strncmp(buf, "MemTotal:", 9) == 0));
Chris@170 93 if (isMemFree || isMemTotal) {
Chris@169 94 QString line = QString(buf).trimmed();
Chris@169 95 QStringList elements = line.split(' ', QString::SkipEmptyParts);
Chris@169 96 QString unit = "kB";
Chris@169 97 if (elements.size() > 2) unit = elements[2];
Chris@169 98 int size = elements[1].toInt();
Chris@169 99 // std::cerr << "have size \"" << size << "\", unit \""
Chris@169 100 // << unit.toStdString() << "\"" << std::endl;
Chris@170 101 if (unit.toLower() == "gb") size = size * 1024;
Chris@170 102 else if (unit.toLower() == "mb") size = size;
Chris@170 103 else if (unit.toLower() == "kb") size = size / 1024;
Chris@170 104 else size = size / 1048576;
Chris@170 105
Chris@170 106 if (isMemFree) available = size;
Chris@170 107 else total = size;
Chris@170 108 }
Chris@170 109 if (available != -1 && total != -1) {
Chris@170 110 fclose(meminfo);
Chris@170 111 return;
Chris@168 112 }
Chris@168 113 }
Chris@169 114 fclose(meminfo);
Chris@168 115 }
Chris@168 116
Chris@168 117 int
Chris@168 118 GetDiscSpaceMBAvailable(const char *path)
Chris@168 119 {
Chris@168 120 #ifdef _WIN32
Chris@168 121 __int64 available, total, totalFree;
Chris@168 122 if (GetDiskFreeSpaceEx(path, &available, &total, &totalFree)) {
Chris@168 123 available /= 1048576;
Chris@170 124 if (available > INT_MAX) available = INT_MAX;
Chris@168 125 return int(available);
Chris@168 126 } else {
Chris@168 127 std::cerr << "WARNING: GetDiskFreeSpaceEx failed: error code "
Chris@168 128 << GetLastError() << std::endl;
Chris@168 129 return -1;
Chris@168 130 }
Chris@168 131 #else
Chris@168 132 struct statvfs buf;
Chris@168 133 if (!statvfs(path, &buf)) {
Chris@168 134 // do the multiplies and divides in this order to reduce the
Chris@168 135 // likelihood of arithmetic overflow
Chris@168 136 std::cerr << "statvfs(" << path << ") says available: " << buf.f_bavail << ", block size: " << buf.f_bsize << std::endl;
Chris@170 137 uint64_t available = ((buf.f_bavail / 1024) * buf.f_bsize) / 1024;
Chris@170 138 if (available > INT_MAX) available = INT_MAX;
Chris@170 139 return int(available);
Chris@168 140 } else {
Chris@168 141 perror("statvfs failed");
Chris@168 142 return -1;
Chris@168 143 }
Chris@168 144 #endif
Chris@168 145 }
Chris@168 146
Chris@168 147
Chris@150 148 double mod(double x, double y) { return x - (y * floor(x / y)); }
Chris@150 149 float modf(float x, float y) { return x - (y * floorf(x / y)); }
Chris@150 150
Chris@150 151 double princarg(double a) { return mod(a + M_PI, -2 * M_PI) + M_PI; }
Chris@150 152 float princargf(float a) { return modf(a + M_PI, -2 * M_PI) + M_PI; }
Chris@150 153