2024-04-20 15:57:49 +00:00
|
|
|
/*
|
2024-04-29 18:10:09 +00:00
|
|
|
* Descent 3
|
2024-04-20 15:57:49 +00:00
|
|
|
* 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/>.
|
|
|
|
|
2024-05-06 15:12:44 +00:00
|
|
|
--- 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
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2024-05-21 13:30:52 +00:00
|
|
|
#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"
|
2024-08-19 22:27:03 +00:00
|
|
|
#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) {
|
2024-08-19 22:27:03 +00:00
|
|
|
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() {
|
2024-08-19 22:27:03 +00:00
|
|
|
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
|
|
|
|
2024-08-19 22:27:03 +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);
|
2024-05-21 13:30:52 +00:00
|
|
|
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
|
|
|
|
2024-08-19 22:27:03 +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) {
|
2024-08-19 22:27:03 +00:00
|
|
|
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) {
|
2024-08-19 22:27:03 +00:00
|
|
|
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) {
|
2024-08-19 22:27:03 +00:00
|
|
|
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
|
2024-08-19 22:27:03 +00:00
|
|
|
exec_path[len - 1] = '\0';
|
|
|
|
return true;
|
2024-05-21 13:30:52 +00:00
|
|
|
}
|