// Copyright (C) 2002-2007 Nikolaus Gebhardt // This file is part of the "Irrlicht Engine". // For conditions of distribution and use, see copyright notice in irrlicht.h #include "COSOperator.h" #include "IrrCompileConfig.h" #ifdef _IRR_WINDOWS_API_ #include #else #include #include #ifdef MACOSX #include "OSXClipboard.h" #include #include #endif #endif namespace irr { // constructor COSOperator::COSOperator(const c8* osVersion) : OperatingSystem(osVersion) { } //! returns the current operating system version as string. const wchar_t* COSOperator::getOperationSystemVersion() const { return OperatingSystem.c_str(); } //! copies text to the clipboard void COSOperator::copyToClipboard(const c8* text) const { if (strlen(text)==0) return; // Windows version #if defined(_IRR_WINDOWS_API_) if (!OpenClipboard(NULL) || text == 0) return; EmptyClipboard(); HGLOBAL clipbuffer; char * buffer; clipbuffer = GlobalAlloc(GMEM_DDESHARE, strlen(text)+1); buffer = (char*)GlobalLock(clipbuffer); strcpy(buffer, text); GlobalUnlock(clipbuffer); SetClipboardData(CF_TEXT, clipbuffer); CloseClipboard(); // MacOSX version #elif defined(MACOSX) OSXCopyToClipboard(text); // todo: Linux version #endif } //! gets text from the clipboard //! \return Returns 0 if no string is in there. c8* COSOperator::getTextFromClipboard() const { #if defined(_IRR_WINDOWS_API_) if (!OpenClipboard(NULL)) return 0; char * buffer = 0; HANDLE hData = GetClipboardData( CF_TEXT ); buffer = (char*)GlobalLock( hData ); GlobalUnlock( hData ); CloseClipboard(); return buffer; #elif defined(MACOSX) return (OSXCopyFromClipboard()); #else // todo: Linux version return 0; #endif } bool COSOperator::getProcessorSpeedMHz(u32* MHz) const { #if defined(_IRR_WINDOWS_API_) LONG Error; HKEY Key; Error = RegOpenKeyEx(HKEY_LOCAL_MACHINE, "HARDWARE\\DESCRIPTION\\System\\CentralProcessor\\0", 0, KEY_READ, &Key); if(Error != ERROR_SUCCESS) return false; DWORD Speed = 0; DWORD Size = sizeof(Speed); Error = RegQueryValueEx(Key, "~MHz", NULL, NULL, (LPBYTE)&Speed, &Size); RegCloseKey(Key); if (Error != ERROR_SUCCESS) return false; else if (MHz) *MHz = Speed; _IRR_IMPLEMENT_MANAGED_MARSHALLING_BUGFIX; return true; #elif defined(MACOSX) struct clockinfo CpuClock; size_t Size = sizeof(clockinfo); if (!sysctlbyname("kern.clockrate", &CpuClock, &Size, NULL, 0)) return false; else if (MHz) *MHz = CpuClock.hz; return true; #else // could probably be read from "/proc/cpuinfo" or "/proc/cpufreq" return false; #endif } bool COSOperator::getSystemMemory(u32* Total, u32* Avail) const { #if defined(_IRR_WINDOWS_API_) MEMORYSTATUS MemoryStatus; MemoryStatus.dwLength = sizeof(MEMORYSTATUS); // cannot fail GlobalMemoryStatus(&MemoryStatus); if (Total) *Total = (u32)(MemoryStatus.dwTotalPhys>>10); if (Avail) *Avail = (u32)(MemoryStatus.dwAvailPhys>>10); _IRR_IMPLEMENT_MANAGED_MARSHALLING_BUGFIX; return true; #elif defined(_IRR_POSIX_API_) #if defined(_SC_PHYS_PAGES) && defined(_SC_AVPHYS_PAGES) long ps = sysconf(_SC_PAGESIZE); long pp = sysconf(_SC_PHYS_PAGES); long ap = sysconf(_SC_AVPHYS_PAGES); if ((ps==-1)||(pp==-1)||(ap==-1)) return false; if (Total) *Total = ((ps*(long long)pp)>>10); if (Avail) *Avail = ((ps*(long long)ap)>>10); return true; #else // TODO: implement for non-availablity of symbols/features return false; #endif #else // TODO: implement for OSX return false; #endif } } // end namespace