Descent3/ddio/lnxio.cpp

139 lines
3.6 KiB
C++
Raw Normal View History

/*
* Descent 3
* Copyright (C) 2024 Parallax Software
*
* 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/>.
--- HISTORICAL COMMENTS FOLLOW ---
2024-04-16 18:56:40 +00:00
* $Logfile: /DescentIII/Main/ddio_lnx/lnxio.cpp $
* $Revision: 1.6 $
* $Date: 2004/02/25 00:04:06 $
* $Author: ryan $
*
* Linux IO routines
*
* $Log: lnxio.cpp,v $
* Revision 1.6 2004/02/25 00:04:06 ryan
* Removed loki_utils dependency and ported to MacOS X (runs, but incomplete).
*
* Revision 1.5 2000/05/29 05:20:13 icculus
* Removed a real repetitive mprintf().
*
* Revision 1.4 2000/05/29 05:19:17 icculus
* Serial behaviour is now correct (and the Rock'n'Ride works!). A
* little more debugging code was added.
*
* Revision 1.3 2000/04/25 06:10:27 icculus
* Added buttloads of debug information, and fixed some more glitches.
*
* Revision 1.2 2000/04/24 03:18:53 icculus
* Serial port i/o code written, so I can ROCK'n'RIDE it!
*
* Revision 1.1.1.1 2000/04/18 00:00:33 icculus
* initial checkin
*
*
2024-04-16 03:43:29 +00:00
* 5 7/14/99 9:06p Jeff
* added comment header
2024-04-16 18:56:40 +00:00
*
* $NoKeywords: $
*/
2024-04-16 03:43:29 +00:00
// ----------------------------------------------------------------------------
// Linux IO System Main Library Interface
// ----------------------------------------------------------------------------
#include <cstdarg>
2024-05-22 09:47:28 +00:00
#include <cstdio>
2024-04-16 03:43:29 +00:00
2024-05-19 21:55:31 +00:00
#ifdef MACOSX
#include <mach-o/dyld.h>
#endif
2024-06-21 16:46:53 +00:00
#ifdef WIN32
#include <windows.h>
#endif
2024-04-16 03:43:29 +00:00
#include "application.h"
#include "ddio.h"
#include "log.h"
2024-04-16 03:43:29 +00:00
bool DDIO_init = false;
oeLnxApplication *Lnx_app_obj = NULL;
// ----------------------------------------------------------------------------
// Initialization and destruction functions
// ----------------------------------------------------------------------------
2024-04-16 18:56:40 +00:00
bool ddio_InternalInit(ddio_init_info *init_info) {
LOG_DEBUG << "DDIO: ddio_InternalInit() called.";
2024-04-16 18:56:40 +00:00
Lnx_app_obj = (oeLnxApplication *)init_info->obj;
DDIO_init = true;
return true;
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
void ddio_InternalClose() {
LOG_DEBUG << "DDIO: ddio_InternalClose() called.";
2024-04-16 03:43:29 +00:00
2024-04-16 18:56:40 +00:00
if (DDIO_init) {
DDIO_init = false;
Lnx_app_obj = NULL;
} // if
2024-04-16 03:43:29 +00:00
LOG_DEBUG << "DDIO: ddio_InternalClose() returning.";
2024-04-16 03:43:29 +00:00
}
2024-04-16 18:56:40 +00:00
void ddio_DebugMessage(unsigned err, char *fmt, ...) {
2024-04-16 03:43:29 +00:00
char buf[128];
va_list arglist;
2024-04-16 18:56:40 +00:00
va_start(arglist, fmt);
std::vsnprintf(buf, sizeof(buf), fmt, arglist);
2024-04-16 03:43:29 +00:00
va_end(arglist);
2024-04-16 18:56:40 +00:00
LOG_DEBUG << buf;
2024-04-16 03:43:29 +00:00
}
2024-05-19 21:55:31 +00:00
bool ddio_GetBinaryPath(char *exec_path, size_t len) {
2024-06-21 16:46:53 +00:00
#ifdef MACOSX
2024-05-19 21:55:31 +00:00
if (exec_path == NULL || len == 0) {
LOG_ERROR << "Invalid arguments";
return false;
2024-05-19 21:55:31 +00:00
}
uint32_t size = (uint32_t)len;
if (_NSGetExecutablePath(exec_path, &size) != 0) {
LOG_ERROR.printf("Buffer too small; need size %u", size);
return false;
2024-05-19 21:55:31 +00:00
}
2024-06-21 16:46:53 +00:00
#elif defined(__LINUX__)
if (realpath("/proc/self/exe", exec_path) == NULL) {
perror("realpath");
return false;
}
#else
if (GetModuleFileName(NULL, exec_path, len) == 0) {
DWORD error = GetLastError();
LOG_ERROR << "GetModuleFileName failed!";
return false;
2024-06-21 16:46:53 +00:00
}
exec_path[len - 1] = '\0';
return true;
2024-05-19 21:55:31 +00:00
#endif
exec_path[len - 1] = '\0';
return true;
}