parent
4abcaae0f7
commit
025bedecfb
|
@ -55,11 +55,21 @@ if (${OPENAL_SOUND})
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Platform-dependent implementation of system.h
|
||||||
|
if (${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
||||||
|
set(SYSTEM_CPP_MODULE "system_windows.cpp")
|
||||||
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||||
|
set(SYSTEM_CPP_MODULE "system_linux.cpp")
|
||||||
|
else()
|
||||||
|
set(SYSTEM_CPP_MODULE "system_other.cpp")
|
||||||
|
endif()
|
||||||
|
|
||||||
# Source files
|
# Source files
|
||||||
set(SOURCES
|
set(SOURCES
|
||||||
app/app.cpp
|
app/app.cpp
|
||||||
app/main.cpp
|
app/main.cpp
|
||||||
app/system.cpp
|
app/system.cpp
|
||||||
|
app/${SYSTEM_CPP_MODULE}
|
||||||
common/event.cpp
|
common/event.cpp
|
||||||
common/image.cpp
|
common/image.cpp
|
||||||
common/iman.cpp
|
common/iman.cpp
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
// * This file is part of the COLOBOT source code
|
||||||
|
// * Copyright (C) 2001-2008, Daniel ROUX & EPSITEC SA, www.epsitec.ch
|
||||||
|
// * Copyright (C) 2012, Polish Portal of Colobot (PPC)
|
||||||
|
// *
|
||||||
|
// * This program is free software: you can redistribute it and/or modify
|
||||||
|
// * it under the terms of the GNU General Public License as published by
|
||||||
|
// * the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// * (at your option) any later version.
|
||||||
|
// *
|
||||||
|
// * This program is distributed in the hope that it will be useful,
|
||||||
|
// * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// * GNU General Public License for more details.
|
||||||
|
// *
|
||||||
|
// * You should have received a copy of the GNU General Public License
|
||||||
|
// * along with this program. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
#include "app/system_linux.h"
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
|
||||||
|
SystemDialogResult SystemDialog_Linux(SystemDialogType type, const std::string& title, const std::string& message)
|
||||||
|
{
|
||||||
|
std::string options = "";
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case SDT_INFO:
|
||||||
|
default:
|
||||||
|
options = "--info";
|
||||||
|
break;
|
||||||
|
case SDT_WARNING:
|
||||||
|
options = "--warning";
|
||||||
|
break;
|
||||||
|
case SDT_ERROR:
|
||||||
|
options = "--error";
|
||||||
|
break;
|
||||||
|
case SDT_YES_NO:
|
||||||
|
options = "--question --ok-label=\"Yes\" --cancel-label=\"No\"";
|
||||||
|
break;
|
||||||
|
case SDT_OK_CANCEL:
|
||||||
|
options = "--question --ok-label=\"OK\" --cancel-label=\"Cancel\"";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string command = "zenity " + options + " --text=\"" + message + "\" --title=\"" + title + "\"";
|
||||||
|
int code = system(command.c_str());
|
||||||
|
|
||||||
|
SystemDialogResult result = SDR_OK;
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case SDT_YES_NO:
|
||||||
|
result = code ? SDR_NO : SDR_YES;
|
||||||
|
break;
|
||||||
|
case SDT_OK_CANCEL:
|
||||||
|
result = code ? SDR_CANCEL : SDR_OK;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GetCurrentTimeStamp_Linux(SystemTimeStamp *stamp)
|
||||||
|
{
|
||||||
|
clock_gettime(CLOCK_MONOTONIC, &stamp->clockTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
long long GetTimeStampExactResolution_Linux()
|
||||||
|
{
|
||||||
|
return 1ll;
|
||||||
|
}
|
||||||
|
|
||||||
|
long long TimeStampExactDiff_Linux(SystemTimeStamp *before, SystemTimeStamp *after)
|
||||||
|
{
|
||||||
|
return (after->clockTime.tv_nsec - before->clockTime.tv_nsec) +
|
||||||
|
(after->clockTime.tv_sec - before->clockTime.tv_sec) * 1000000000ll;
|
||||||
|
}
|
|
@ -20,20 +20,11 @@
|
||||||
* \brief Linux-specific implementation of system functions
|
* \brief Linux-specific implementation of system functions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* NOTE: code is contained in this header;
|
#include "app/system.h"
|
||||||
* there is no separate .cpp module for simplicity */
|
|
||||||
|
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <time.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
|
|
||||||
SystemDialogResult SystemDialog_Linux(SystemDialogType type, const std::string& title, const std::string& message);
|
|
||||||
|
|
||||||
void GetCurrentTimeStamp_Linux(SystemTimeStamp *stamp);
|
|
||||||
long long GetTimeStampExactResolution_Linux();
|
|
||||||
long long TimeStampExactDiff_Linux(SystemTimeStamp *before, SystemTimeStamp *after);
|
|
||||||
|
|
||||||
struct SystemTimeStamp
|
struct SystemTimeStamp
|
||||||
{
|
{
|
||||||
timespec clockTime;
|
timespec clockTime;
|
||||||
|
@ -45,60 +36,8 @@ struct SystemTimeStamp
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
SystemDialogResult SystemDialog_Linux(SystemDialogType type, const std::string& title, const std::string& message)
|
SystemDialogResult SystemDialog_Linux(SystemDialogType type, const std::string& title, const std::string& message);
|
||||||
{
|
|
||||||
std::string options = "";
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case SDT_INFO:
|
|
||||||
default:
|
|
||||||
options = "--info";
|
|
||||||
break;
|
|
||||||
case SDT_WARNING:
|
|
||||||
options = "--warning";
|
|
||||||
break;
|
|
||||||
case SDT_ERROR:
|
|
||||||
options = "--error";
|
|
||||||
break;
|
|
||||||
case SDT_YES_NO:
|
|
||||||
options = "--question --ok-label=\"Yes\" --cancel-label=\"No\"";
|
|
||||||
break;
|
|
||||||
case SDT_OK_CANCEL:
|
|
||||||
options = "--question --ok-label=\"OK\" --cancel-label=\"Cancel\"";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string command = "zenity " + options + " --text=\"" + message + "\" --title=\"" + title + "\"";
|
void GetCurrentTimeStamp_Linux(SystemTimeStamp *stamp);
|
||||||
int code = system(command.c_str());
|
long long GetTimeStampExactResolution_Linux();
|
||||||
|
long long TimeStampExactDiff_Linux(SystemTimeStamp *before, SystemTimeStamp *after);
|
||||||
SystemDialogResult result = SDR_OK;
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case SDT_YES_NO:
|
|
||||||
result = code ? SDR_NO : SDR_YES;
|
|
||||||
break;
|
|
||||||
case SDT_OK_CANCEL:
|
|
||||||
result = code ? SDR_CANCEL : SDR_OK;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void GetCurrentTimeStamp_Linux(SystemTimeStamp *stamp)
|
|
||||||
{
|
|
||||||
clock_gettime(CLOCK_MONOTONIC, &stamp->clockTime);
|
|
||||||
}
|
|
||||||
|
|
||||||
long long GetTimeStampExactResolution_Linux()
|
|
||||||
{
|
|
||||||
return 1ll;
|
|
||||||
}
|
|
||||||
|
|
||||||
long long TimeStampExactDiff_Linux(SystemTimeStamp *before, SystemTimeStamp *after)
|
|
||||||
{
|
|
||||||
return (after->clockTime.tv_nsec - before->clockTime.tv_nsec) +
|
|
||||||
(after->clockTime.tv_sec - before->clockTime.tv_sec) * 1000000000ll;
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,122 @@
|
||||||
|
// * This file is part of the COLOBOT source code
|
||||||
|
// * Copyright (C) 2001-2008, Daniel ROUX & EPSITEC SA, www.epsitec.ch
|
||||||
|
// * Copyright (C) 2012, Polish Portal of Colobot (PPC)
|
||||||
|
// *
|
||||||
|
// * This program is free software: you can redistribute it and/or modify
|
||||||
|
// * it under the terms of the GNU General Public License as published by
|
||||||
|
// * the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// * (at your option) any later version.
|
||||||
|
// *
|
||||||
|
// * This program is distributed in the hope that it will be useful,
|
||||||
|
// * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// * GNU General Public License for more details.
|
||||||
|
// *
|
||||||
|
// * You should have received a copy of the GNU General Public License
|
||||||
|
// * along with this program. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
#include "app/system_other.h"
|
||||||
|
|
||||||
|
|
||||||
|
SystemDialogResult SystemDialog_Other(SystemDialogType type, const std::string& title, const std::string& message)
|
||||||
|
{
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case SDT_INFO:
|
||||||
|
std::cout << "INFO: ";
|
||||||
|
break;
|
||||||
|
case SDT_WARNING:
|
||||||
|
std::cout << "WARNING:";
|
||||||
|
break;
|
||||||
|
case SDT_ERROR:
|
||||||
|
std::cout << "ERROR: ";
|
||||||
|
break;
|
||||||
|
case SDT_YES_NO:
|
||||||
|
case SDT_OK_CANCEL:
|
||||||
|
std::cout << "QUESTION: ";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::cout << message << std::endl;
|
||||||
|
|
||||||
|
std::string line;
|
||||||
|
|
||||||
|
SystemDialogResult result = SDR_OK;
|
||||||
|
|
||||||
|
bool done = false;
|
||||||
|
while (!done)
|
||||||
|
{
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case SDT_INFO:
|
||||||
|
case SDT_WARNING:
|
||||||
|
case SDT_ERROR:
|
||||||
|
std::cout << "Press ENTER to continue";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDT_YES_NO:
|
||||||
|
std::cout << "Type 'Y' for Yes or 'N' for No";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDT_OK_CANCEL:
|
||||||
|
std::cout << "Type 'O' for OK or 'C' for Cancel";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::getline(std::cin, line);
|
||||||
|
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case SDT_INFO:
|
||||||
|
case SDT_WARNING:
|
||||||
|
case SDT_ERROR:
|
||||||
|
done = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDT_YES_NO:
|
||||||
|
if (line == "Y" || line == "y")
|
||||||
|
{
|
||||||
|
result = SDR_YES;
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
else if (line == "N" || line == "n")
|
||||||
|
{
|
||||||
|
result = SDR_NO;
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SDT_OK_CANCEL:
|
||||||
|
if (line == "O" || line == "o")
|
||||||
|
{
|
||||||
|
done = true;
|
||||||
|
result = SDR_OK;
|
||||||
|
}
|
||||||
|
else if (line == "C" || line == "c")
|
||||||
|
{
|
||||||
|
done = true;
|
||||||
|
result = SDR_CANCEL;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void GetCurrentTimeStamp_Other(SystemTimeStamp *stamp)
|
||||||
|
{
|
||||||
|
stamp->sdlTicks = SDL_GetTicks();
|
||||||
|
}
|
||||||
|
|
||||||
|
long long GetTimeStampExactResolution_Other()
|
||||||
|
{
|
||||||
|
return 1000000ll;
|
||||||
|
}
|
||||||
|
|
||||||
|
long long TimeStampExactDiff_Other(SystemTimeStamp *before, SystemTimeStamp *after)
|
||||||
|
{
|
||||||
|
return (after->sdlTicks - before->sdlTicks) * 1000000ll;
|
||||||
|
}
|
|
@ -20,20 +20,13 @@
|
||||||
* \brief Fallback code for other systems
|
* \brief Fallback code for other systems
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* NOTE: code is contained in this header;
|
#include "app/system.h"
|
||||||
* there is no separate .cpp module for simplicity */
|
|
||||||
|
|
||||||
#include <SDL/SDL.h>
|
#include <SDL/SDL.h>
|
||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
|
|
||||||
SystemDialogResult SystemDialog_Other(SystemDialogType type, const std::string& title, const std::string& message);
|
|
||||||
|
|
||||||
void GetCurrentTimeStamp_Other(SystemTimeStamp *stamp);
|
|
||||||
long long GetTimeStampExactResolution_Other();
|
|
||||||
long long TimeStampExactDiff_Other(SystemTimeStamp *before, SystemTimeStamp *after);
|
|
||||||
|
|
||||||
struct SystemTimeStamp
|
struct SystemTimeStamp
|
||||||
{
|
{
|
||||||
Uint32 sdlTicks;
|
Uint32 sdlTicks;
|
||||||
|
@ -45,105 +38,8 @@ struct SystemTimeStamp
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
SystemDialogResult SystemDialog_Other(SystemDialogType type, const std::string& title, const std::string& message)
|
SystemDialogResult SystemDialog_Other(SystemDialogType type, const std::string& title, const std::string& message);
|
||||||
{
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case SDT_INFO:
|
|
||||||
std::cout << "INFO: ";
|
|
||||||
break;
|
|
||||||
case SDT_WARNING:
|
|
||||||
std::cout << "WARNING:";
|
|
||||||
break;
|
|
||||||
case SDT_ERROR:
|
|
||||||
std::cout << "ERROR: ";
|
|
||||||
break;
|
|
||||||
case SDT_YES_NO:
|
|
||||||
case SDT_OK_CANCEL:
|
|
||||||
std::cout << "QUESTION: ";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::cout << message << std::endl;
|
void GetCurrentTimeStamp_Other(SystemTimeStamp *stamp);
|
||||||
|
long long GetTimeStampExactResolution_Other();
|
||||||
std::string line;
|
long long TimeStampExactDiff_Other(SystemTimeStamp *before, SystemTimeStamp *after);
|
||||||
|
|
||||||
SystemDialogResult result = SDR_OK;
|
|
||||||
|
|
||||||
bool done = false;
|
|
||||||
while (!done)
|
|
||||||
{
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case SDT_INFO:
|
|
||||||
case SDT_WARNING:
|
|
||||||
case SDT_ERROR:
|
|
||||||
std::cout << "Press ENTER to continue";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SDT_YES_NO:
|
|
||||||
std::cout << "Type 'Y' for Yes or 'N' for No";
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SDT_OK_CANCEL:
|
|
||||||
std::cout << "Type 'O' for OK or 'C' for Cancel";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::getline(std::cin, line);
|
|
||||||
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case SDT_INFO:
|
|
||||||
case SDT_WARNING:
|
|
||||||
case SDT_ERROR:
|
|
||||||
done = true;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SDT_YES_NO:
|
|
||||||
if (line == "Y" || line == "y")
|
|
||||||
{
|
|
||||||
result = SDR_YES;
|
|
||||||
done = true;
|
|
||||||
}
|
|
||||||
else if (line == "N" || line == "n")
|
|
||||||
{
|
|
||||||
result = SDR_NO;
|
|
||||||
done = true;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SDT_OK_CANCEL:
|
|
||||||
if (line == "O" || line == "o")
|
|
||||||
{
|
|
||||||
done = true;
|
|
||||||
result = SDR_OK;
|
|
||||||
}
|
|
||||||
else if (line == "C" || line == "c")
|
|
||||||
{
|
|
||||||
done = true;
|
|
||||||
result = SDR_CANCEL;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void GetCurrentTimeStamp_Other(SystemTimeStamp *stamp)
|
|
||||||
{
|
|
||||||
stamp->sdlTicks = SDL_GetTicks();
|
|
||||||
}
|
|
||||||
|
|
||||||
long long GetTimeStampExactResolution_Other()
|
|
||||||
{
|
|
||||||
return 1000000ll;
|
|
||||||
}
|
|
||||||
|
|
||||||
long long TimeStampExactDiff_Other(SystemTimeStamp *before, SystemTimeStamp *after)
|
|
||||||
{
|
|
||||||
return (after->sdlTicks - before->sdlTicks) * 1000000ll;
|
|
||||||
}
|
|
||||||
|
|
|
@ -0,0 +1,98 @@
|
||||||
|
// * This file is part of the COLOBOT source code
|
||||||
|
// * Copyright (C) 2001-2008, Daniel ROUX & EPSITEC SA, www.epsitec.ch
|
||||||
|
// * Copyright (C) 2012, Polish Portal of Colobot (PPC)
|
||||||
|
// *
|
||||||
|
// * This program is free software: you can redistribute it and/or modify
|
||||||
|
// * it under the terms of the GNU General Public License as published by
|
||||||
|
// * the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// * (at your option) any later version.
|
||||||
|
// *
|
||||||
|
// * This program is distributed in the hope that it will be useful,
|
||||||
|
// * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// * GNU General Public License for more details.
|
||||||
|
// *
|
||||||
|
// * You should have received a copy of the GNU General Public License
|
||||||
|
// * along with this program. If not, see http://www.gnu.org/licenses/.
|
||||||
|
|
||||||
|
#include "app/system_windows.h"
|
||||||
|
|
||||||
|
|
||||||
|
// Convert a wide Unicode string to an UTF8 string
|
||||||
|
std::string UTF8_Encode_Windows(const std::wstring &wstr)
|
||||||
|
{
|
||||||
|
int size_needed = WideCharToMultiByte(CP_UTF8, 0, &wstr[0], static_cast<int>(wstr.size()), NULL, 0, NULL, NULL);
|
||||||
|
std::string strTo(size_needed, 0);
|
||||||
|
WideCharToMultiByte(CP_UTF8, 0, &wstr[0], static_cast<int>(wstr.size()), &strTo[0], size_needed, NULL, NULL);
|
||||||
|
return strTo;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Convert an UTF8 string to a wide Unicode String
|
||||||
|
std::wstring UTF8_Decode_Windows(const std::string &str)
|
||||||
|
{
|
||||||
|
int size_needed = MultiByteToWideChar(CP_UTF8, 0, &str[0], static_cast<int>(str.size()), NULL, 0);
|
||||||
|
std::wstring wstrTo(size_needed, 0);
|
||||||
|
MultiByteToWideChar(CP_UTF8, 0, &str[0], static_cast<int>(str.size()), &wstrTo[0], size_needed);
|
||||||
|
return wstrTo;
|
||||||
|
}
|
||||||
|
|
||||||
|
SystemDialogResult SystemDialog_Windows(SystemDialogType type, const std::string& title, const std::string& message)
|
||||||
|
{
|
||||||
|
unsigned int windowsType = 0;
|
||||||
|
std::wstring windowsMessage = UTF8_Decode_Windows(message);
|
||||||
|
std::wstring windowsTitle = UTF8_Decode_Windows(title);
|
||||||
|
|
||||||
|
switch (type)
|
||||||
|
{
|
||||||
|
case SDT_INFO:
|
||||||
|
default:
|
||||||
|
windowsType = MB_ICONINFORMATION|MB_OK;
|
||||||
|
break;
|
||||||
|
case SDT_WARNING:
|
||||||
|
windowsType = MB_ICONWARNING|MB_OK;
|
||||||
|
break;
|
||||||
|
case SDT_ERROR:
|
||||||
|
windowsType = MB_ICONERROR|MB_OK;
|
||||||
|
break;
|
||||||
|
case SDT_YES_NO:
|
||||||
|
windowsType = MB_ICONQUESTION|MB_YESNO;
|
||||||
|
break;
|
||||||
|
case SDT_OK_CANCEL:
|
||||||
|
windowsType = MB_ICONWARNING|MB_OKCANCEL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (MessageBoxW(NULL, windowsMessage.c_str(), windowsTitle.c_str(), windowsType))
|
||||||
|
{
|
||||||
|
case IDOK:
|
||||||
|
return SDR_OK;
|
||||||
|
case IDCANCEL:
|
||||||
|
return SDR_CANCEL;
|
||||||
|
case IDYES:
|
||||||
|
return SDR_YES;
|
||||||
|
case IDNO:
|
||||||
|
return SDR_NO;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return SDR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GetCurrentTimeStamp_Windows(SystemTimeStamp *stamp)
|
||||||
|
{
|
||||||
|
GetSystemTimeAsFileTime(&stamp->fileTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
long long GetTimeStampExactResolution_Windows()
|
||||||
|
{
|
||||||
|
return 100ll;
|
||||||
|
}
|
||||||
|
|
||||||
|
long long TimeStampExactDiff_Windows(SystemTimeStamp *before, SystemTimeStamp *after)
|
||||||
|
{
|
||||||
|
long long tH = (1ll << 32) * (after->fileTime.dwHighDateTime - before->fileTime.dwHighDateTime);
|
||||||
|
long long tL = after->fileTime.dwLowDateTime - before->fileTime.dwLowDateTime;
|
||||||
|
return (tH + tL) * 100ll;
|
||||||
|
}
|
|
@ -20,20 +20,11 @@
|
||||||
* \brief Windows-specific implementation of system functions
|
* \brief Windows-specific implementation of system functions
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* NOTE: code is contained in this header;
|
#include "app/system.h"
|
||||||
* there is no separate .cpp module for simplicity */
|
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
|
||||||
|
|
||||||
std::string UTF8_Encode_Windows(const std::wstring &wstr);
|
|
||||||
std::wstring UTF8_Decode_Windows(const std::string &str);
|
|
||||||
SystemDialogResult SystemDialog_Windows(SystemDialogType type, const std::string& title, const std::string& message);
|
|
||||||
|
|
||||||
void GetCurrentTimeStamp_Windows(SystemTimeStamp *stamp);
|
|
||||||
long long GetTimeStampExactResolution_Windows();
|
|
||||||
long long TimeStampExactDiff_Windows(SystemTimeStamp *before, SystemTimeStamp *after);
|
|
||||||
|
|
||||||
struct SystemTimeStamp
|
struct SystemTimeStamp
|
||||||
{
|
{
|
||||||
FILETIME fileTime;
|
FILETIME fileTime;
|
||||||
|
@ -44,82 +35,10 @@ struct SystemTimeStamp
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
std::string UTF8_Encode_Windows(const std::wstring &wstr);
|
||||||
|
std::wstring UTF8_Decode_Windows(const std::string &str);
|
||||||
|
SystemDialogResult SystemDialog_Windows(SystemDialogType type, const std::string& title, const std::string& message);
|
||||||
|
|
||||||
// Convert a wide Unicode string to an UTF8 string
|
void GetCurrentTimeStamp_Windows(SystemTimeStamp *stamp);
|
||||||
std::string UTF8_Encode_Windows(const std::wstring &wstr)
|
long long GetTimeStampExactResolution_Windows();
|
||||||
{
|
long long TimeStampExactDiff_Windows(SystemTimeStamp *before, SystemTimeStamp *after);
|
||||||
int size_needed = WideCharToMultiByte(CP_UTF8, 0, &wstr[0], static_cast<int>(wstr.size()), NULL, 0, NULL, NULL);
|
|
||||||
std::string strTo(size_needed, 0);
|
|
||||||
WideCharToMultiByte(CP_UTF8, 0, &wstr[0], static_cast<int>(wstr.size()), &strTo[0], size_needed, NULL, NULL);
|
|
||||||
return strTo;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Convert an UTF8 string to a wide Unicode String
|
|
||||||
std::wstring UTF8_Decode_Windows(const std::string &str)
|
|
||||||
{
|
|
||||||
int size_needed = MultiByteToWideChar(CP_UTF8, 0, &str[0], static_cast<int>(str.size()), NULL, 0);
|
|
||||||
std::wstring wstrTo(size_needed, 0);
|
|
||||||
MultiByteToWideChar(CP_UTF8, 0, &str[0], static_cast<int>(str.size()), &wstrTo[0], size_needed);
|
|
||||||
return wstrTo;
|
|
||||||
}
|
|
||||||
|
|
||||||
SystemDialogResult SystemDialog_Windows(SystemDialogType type, const std::string& title, const std::string& message)
|
|
||||||
{
|
|
||||||
unsigned int windowsType = 0;
|
|
||||||
std::wstring windowsMessage = UTF8_Decode_Windows(message);
|
|
||||||
std::wstring windowsTitle = UTF8_Decode_Windows(title);
|
|
||||||
|
|
||||||
switch (type)
|
|
||||||
{
|
|
||||||
case SDT_INFO:
|
|
||||||
default:
|
|
||||||
windowsType = MB_ICONINFORMATION|MB_OK;
|
|
||||||
break;
|
|
||||||
case SDT_WARNING:
|
|
||||||
windowsType = MB_ICONWARNING|MB_OK;
|
|
||||||
break;
|
|
||||||
case SDT_ERROR:
|
|
||||||
windowsType = MB_ICONERROR|MB_OK;
|
|
||||||
break;
|
|
||||||
case SDT_YES_NO:
|
|
||||||
windowsType = MB_ICONQUESTION|MB_YESNO;
|
|
||||||
break;
|
|
||||||
case SDT_OK_CANCEL:
|
|
||||||
windowsType = MB_ICONWARNING|MB_OKCANCEL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (MessageBoxW(NULL, windowsMessage.c_str(), windowsTitle.c_str(), windowsType))
|
|
||||||
{
|
|
||||||
case IDOK:
|
|
||||||
return SDR_OK;
|
|
||||||
case IDCANCEL:
|
|
||||||
return SDR_CANCEL;
|
|
||||||
case IDYES:
|
|
||||||
return SDR_YES;
|
|
||||||
case IDNO:
|
|
||||||
return SDR_NO;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return SDR_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void GetCurrentTimeStamp_Windows(SystemTimeStamp *stamp)
|
|
||||||
{
|
|
||||||
GetSystemTimeAsFileTime(&stamp->fileTime);
|
|
||||||
}
|
|
||||||
|
|
||||||
long long GetTimeStampExactResolution_Windows()
|
|
||||||
{
|
|
||||||
return 100ll;
|
|
||||||
}
|
|
||||||
|
|
||||||
long long TimeStampExactDiff_Windows(SystemTimeStamp *before, SystemTimeStamp *after)
|
|
||||||
{
|
|
||||||
long long tH = (1ll << 32) * (after->fileTime.dwHighDateTime - before->fileTime.dwHighDateTime);
|
|
||||||
long long tL = after->fileTime.dwLowDateTime - before->fileTime.dwLowDateTime;
|
|
||||||
return (tH + tL) * 100ll;
|
|
||||||
}
|
|
||||||
|
|
|
@ -2,6 +2,14 @@ set(SRC_DIR ${colobot_SOURCE_DIR}/src)
|
||||||
|
|
||||||
configure_file(${SRC_DIR}/common/config.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/common/config.h)
|
configure_file(${SRC_DIR}/common/config.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/common/config.h)
|
||||||
|
|
||||||
|
# Platform-dependent implementation of system.h
|
||||||
|
if (${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
||||||
|
set(SYSTEM_CPP_MODULE "system_windows.cpp")
|
||||||
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||||
|
set(SYSTEM_CPP_MODULE "system_linux.cpp")
|
||||||
|
else()
|
||||||
|
set(SYSTEM_CPP_MODULE "system_other.cpp")
|
||||||
|
endif()
|
||||||
|
|
||||||
set(TEXTURE_SOURCES
|
set(TEXTURE_SOURCES
|
||||||
${SRC_DIR}/graphics/opengl/gldevice.cpp
|
${SRC_DIR}/graphics/opengl/gldevice.cpp
|
||||||
|
@ -17,6 +25,7 @@ ${SRC_DIR}/common/logger.cpp
|
||||||
${SRC_DIR}/common/image.cpp
|
${SRC_DIR}/common/image.cpp
|
||||||
${SRC_DIR}/common/stringutils.cpp
|
${SRC_DIR}/common/stringutils.cpp
|
||||||
${SRC_DIR}/app/system.cpp
|
${SRC_DIR}/app/system.cpp
|
||||||
|
${SRC_DIR}/app/${SYSTEM_CPP_MODULE}
|
||||||
model_test.cpp
|
model_test.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -25,6 +34,7 @@ ${SRC_DIR}/graphics/opengl/gldevice.cpp
|
||||||
${SRC_DIR}/common/logger.cpp
|
${SRC_DIR}/common/logger.cpp
|
||||||
${SRC_DIR}/common/image.cpp
|
${SRC_DIR}/common/image.cpp
|
||||||
${SRC_DIR}/app/system.cpp
|
${SRC_DIR}/app/system.cpp
|
||||||
|
${SRC_DIR}/app/${SYSTEM_CPP_MODULE}
|
||||||
transform_test.cpp
|
transform_test.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -33,6 +43,7 @@ ${SRC_DIR}/graphics/opengl/gldevice.cpp
|
||||||
${SRC_DIR}/common/logger.cpp
|
${SRC_DIR}/common/logger.cpp
|
||||||
${SRC_DIR}/common/image.cpp
|
${SRC_DIR}/common/image.cpp
|
||||||
${SRC_DIR}/app/system.cpp
|
${SRC_DIR}/app/system.cpp
|
||||||
|
${SRC_DIR}/app/${SYSTEM_CPP_MODULE}
|
||||||
light_test.cpp
|
light_test.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -15,10 +15,20 @@ endif()
|
||||||
# Configure file
|
# Configure file
|
||||||
configure_file(${SRC_DIR}/common/config.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/common/config.h)
|
configure_file(${SRC_DIR}/common/config.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/common/config.h)
|
||||||
|
|
||||||
|
# Platform-dependent implementation of system.h
|
||||||
|
if (${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
||||||
|
set(SYSTEM_CPP_MODULE "system_windows.cpp")
|
||||||
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||||
|
set(SYSTEM_CPP_MODULE "system_linux.cpp")
|
||||||
|
else()
|
||||||
|
set(SYSTEM_CPP_MODULE "system_other.cpp")
|
||||||
|
endif()
|
||||||
|
|
||||||
# Code sources
|
# Code sources
|
||||||
set(COLOBOT_SOURCES
|
set(COLOBOT_SOURCES
|
||||||
${SRC_DIR}/app/app.cpp
|
${SRC_DIR}/app/app.cpp
|
||||||
${SRC_DIR}/app/system.cpp
|
${SRC_DIR}/app/system.cpp
|
||||||
|
${SRC_DIR}/app/${SYSTEM_CPP_MODULE}
|
||||||
${SRC_DIR}/common/event.cpp
|
${SRC_DIR}/common/event.cpp
|
||||||
${SRC_DIR}/common/image.cpp
|
${SRC_DIR}/common/image.cpp
|
||||||
${SRC_DIR}/common/iman.cpp
|
${SRC_DIR}/common/iman.cpp
|
||||||
|
@ -159,12 +169,24 @@ if (${OPENAL_SOUND})
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
# Platform-dependent tests
|
||||||
|
if (${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
||||||
|
#TODO: set(PLATFORM_TESTS app/system_windows_test.cpp)
|
||||||
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
||||||
|
set(PLATFORM_TESTS app/system_linux_test.cpp)
|
||||||
|
else()
|
||||||
|
#TODO: set(PLATFORM_TESTS app/system_other_test.cpp)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Tests
|
||||||
set(UT_SOURCES
|
set(UT_SOURCES
|
||||||
main.cpp
|
main.cpp
|
||||||
graphics/engine/lightman_test.cpp
|
graphics/engine/lightman_test.cpp
|
||||||
math/geometry_test.cpp
|
math/geometry_test.cpp
|
||||||
math/matrix_test.cpp
|
math/matrix_test.cpp
|
||||||
math/vector_test.cpp
|
math/vector_test.cpp
|
||||||
|
${PLATFORM_TESTS}
|
||||||
)
|
)
|
||||||
|
|
||||||
include_directories(
|
include_directories(
|
||||||
|
|
|
@ -0,0 +1,51 @@
|
||||||
|
#include "app/system.h"
|
||||||
|
#include "app/system_linux.h"
|
||||||
|
|
||||||
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
|
TEST(SystemLinuxTest, TimeStampDiff)
|
||||||
|
{
|
||||||
|
const long long SEC = 1000000000;
|
||||||
|
|
||||||
|
SystemTimeStamp before, after;
|
||||||
|
|
||||||
|
before.clockTime.tv_sec = 1;
|
||||||
|
before.clockTime.tv_nsec = 100;
|
||||||
|
|
||||||
|
after.clockTime.tv_sec = 1;
|
||||||
|
after.clockTime.tv_nsec = 900;
|
||||||
|
|
||||||
|
long long tDiff = TimeStampExactDiff_Linux(&before, &after);
|
||||||
|
EXPECT_EQ( 800, tDiff);
|
||||||
|
|
||||||
|
tDiff = TimeStampExactDiff_Linux(&after, &before);
|
||||||
|
EXPECT_EQ(-800, tDiff);
|
||||||
|
|
||||||
|
// -------
|
||||||
|
|
||||||
|
before.clockTime.tv_sec = 2;
|
||||||
|
before.clockTime.tv_nsec = 200;
|
||||||
|
|
||||||
|
after.clockTime.tv_sec = 3;
|
||||||
|
after.clockTime.tv_nsec = 500;
|
||||||
|
|
||||||
|
tDiff = TimeStampExactDiff_Linux(&before, &after);
|
||||||
|
EXPECT_EQ( SEC + 300, tDiff);
|
||||||
|
|
||||||
|
tDiff = TimeStampExactDiff_Linux(&after, &before);
|
||||||
|
EXPECT_EQ(-SEC - 300, tDiff);
|
||||||
|
|
||||||
|
// -------
|
||||||
|
|
||||||
|
before.clockTime.tv_sec = 3;
|
||||||
|
before.clockTime.tv_nsec = 200;
|
||||||
|
|
||||||
|
after.clockTime.tv_sec = 4;
|
||||||
|
after.clockTime.tv_nsec = 100;
|
||||||
|
|
||||||
|
tDiff = TimeStampExactDiff_Linux(&before, &after);
|
||||||
|
EXPECT_EQ( SEC - 100, tDiff);
|
||||||
|
|
||||||
|
tDiff = TimeStampExactDiff_Linux(&after, &before);
|
||||||
|
EXPECT_EQ(-SEC + 100, tDiff);
|
||||||
|
}
|
Loading…
Reference in New Issue