8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-24 14:03:02 +01:00

Fixed some possible buffer overruns and marked others.

This commit is contained in:
robocop 2004-10-09 01:47:22 +00:00
parent 6ccf3e6aec
commit 8fd795893f

View File

@ -1065,7 +1065,7 @@ void API_ROUTINE gds__trace_raw(const char* text, unsigned int length)
while (true) { while (true) {
if (trace_file_handle == INVALID_HANDLE_VALUE) { if (trace_file_handle == INVALID_HANDLE_VALUE) {
TEXT name[MAXPATHLEN]; TEXT name[MAXPATHLEN];
gds__prefix(name, LOGFILE); gds__prefix(name, LOGFILE); // B.O.
// We do not care to close this file. // We do not care to close this file.
// It will be closed automatically when our process terminates. // It will be closed automatically when our process terminates.
trace_file_handle = CreateFile(name, GENERIC_WRITE, trace_file_handle = CreateFile(name, GENERIC_WRITE,
@ -1093,7 +1093,7 @@ void API_ROUTINE gds__trace_raw(const char* text, unsigned int length)
// This function is not truly signal safe now. // This function is not truly signal safe now.
// It calls string::c_str() and may call getenv(), not good. // It calls string::c_str() and may call getenv(), not good.
// We can only hope that failure is unlikely in it... // We can only hope that failure is unlikely in it...
gds__prefix(name, LOGFILE); gds__prefix(name, LOGFILE); // B.O.
// Note: signal-safe code // Note: signal-safe code
int file = open(name, O_CREAT | O_APPEND | O_WRONLY, 0660); int file = open(name, O_CREAT | O_APPEND | O_WRONLY, 0660);
@ -1189,7 +1189,7 @@ void API_ROUTINE gds__log(const TEXT* text, ...)
now = time((time_t *)0); now = time((time_t *)0);
#endif #endif
gds__prefix(name, LOGFILE); gds__prefix(name, LOGFILE); // B.O.
const int oldmask = umask(0111); const int oldmask = umask(0111);
#ifdef WIN_NT #ifdef WIN_NT
@ -1239,7 +1239,7 @@ void API_ROUTINE gds__print_pool(JrdMemoryPool* pool, const TEXT* text, ...)
now = time((time_t *)0); now = time((time_t *)0);
#endif #endif
gds__prefix(name, LOGFILE); gds__prefix(name, LOGFILE); // B.O.
const int oldmask = umask(0111); const int oldmask = umask(0111);
#ifdef WIN_NT #ifdef WIN_NT
@ -1388,27 +1388,25 @@ SSHORT API_ROUTINE gds__msg_format(void* handle,
if (n > 0 && n < length) if (n > 0 && n < length)
{ {
sprintf(formatted, buffer, arg1, arg2, arg3, arg4, arg5); fb_utils::snprintf(formatted, size, buffer, arg1, arg2, arg3, arg4, arg5);
} }
else else
{ {
sprintf(formatted, "can't format message %d:%d -- ", facility, Firebird::string s;
number); s.printf("can't format message %d:%d -- ", facility, number);
TEXT* p;
if (n == -1) if (n == -1)
strcat(formatted, "message text not found"); s += "message text not found";
else if (n == -2) { else if (n == -2) {
strcat(formatted, "message file "); s += "message file ";
for (p = formatted; *p;) gds__prefix_msg(formatted, MSG_FILE); // B.O.
p++; s += formatted;
gds__prefix_msg(p, MSG_FILE); s += " not found";
strcat(p, " not found");
} }
else { else {
for (p = formatted; *p;) fb_utils::snprintf(formatted, size, "message system code %d", n);
p++; s += formatted;
sprintf(p, "message system code %d", n);
} }
s.copy_to(formatted, size);
} }
const USHORT l = strlen(formatted); const USHORT l = strlen(formatted);
@ -1467,8 +1465,9 @@ SSHORT API_ROUTINE gds__msg_lookup(void* handle,
p = getenv("LC_MESSAGES"); p = getenv("LC_MESSAGES");
if (p != NULL) { if (p != NULL) {
sanitize(p); // CVC: Sanitizing environment variable??? sanitize(p); // CVC: Sanitizing environment variable???
sprintf(translated_msg_file, MSG_FILE_LANG, p); fb_utils::snprintf(translated_msg_file,
gds__prefix_msg(msg_file, translated_msg_file); sizeof(translated_msg_file), MSG_FILE_LANG, p);
gds__prefix_msg(msg_file, translated_msg_file); // B.O.
status = status =
gds__msg_open(reinterpret_cast<void**>(&messageL), gds__msg_open(reinterpret_cast<void**>(&messageL),
msg_file); msg_file);
@ -1478,7 +1477,7 @@ SSHORT API_ROUTINE gds__msg_lookup(void* handle,
if (status) { if (status) {
/* Default to standard message file */ /* Default to standard message file */
gds__prefix_msg(msg_file, MSG_FILE); gds__prefix_msg(msg_file, MSG_FILE); // B.O.
status = status =
gds__msg_open(reinterpret_cast<void**>(&messageL), gds__msg_open(reinterpret_cast<void**>(&messageL),
msg_file); msg_file);
@ -1627,9 +1626,9 @@ void API_ROUTINE gds__msg_put(
* as fits in callers buffer. * as fits in callers buffer.
* *
**************************************/ **************************************/
TEXT formatted[512]; TEXT formatted[BUFFER_MEDIUM];
gds__msg_format(handle, facility, number, sizeof(TEXT) * BUFFER_MEDIUM, gds__msg_format(handle, facility, number, sizeof(formatted),
formatted, arg1, arg2, arg3, arg4, arg5); formatted, arg1, arg2, arg3, arg4, arg5);
gds__put_error(formatted); gds__put_error(formatted);
} }
@ -1800,7 +1799,7 @@ void API_ROUTINE gds__prefix_lock(TEXT* string, const TEXT* root)
if (!(ib_prefix_lock = getenv(FB_LOCK_ENV))) { if (!(ib_prefix_lock = getenv(FB_LOCK_ENV))) {
#ifdef EMBEDDED #ifdef EMBEDDED
ib_prefix_lock = ib_prefix_lock_val; ib_prefix_lock = ib_prefix_lock_val;
gds__temp_dir(ib_prefix_lock); gds__temp_dir(ib_prefix_lock); // B.O.
// Generate filename based on the current PID // Generate filename based on the current PID
TEXT tmp_buf[MAXPATHLEN]; TEXT tmp_buf[MAXPATHLEN];
sprintf(tmp_buf, FB_PID_FILE, getpid()); sprintf(tmp_buf, FB_PID_FILE, getpid());
@ -1808,7 +1807,7 @@ void API_ROUTINE gds__prefix_lock(TEXT* string, const TEXT* root)
root = tmp_buf; root = tmp_buf;
#else #else
ib_prefix_lock = ib_prefix_lock_val; ib_prefix_lock = ib_prefix_lock_val;
gds__prefix(ib_prefix_lock, ""); gds__prefix(ib_prefix_lock, ""); // B.O.
#endif #endif
} }
else { else {
@ -1891,7 +1890,7 @@ void API_ROUTINE gds__prefix_msg(TEXT* string, const TEXT* root)
if (ib_prefix_msg == NULL) { if (ib_prefix_msg == NULL) {
if (!(ib_prefix_msg = getenv(FB_MSG_ENV))) { if (!(ib_prefix_msg = getenv(FB_MSG_ENV))) {
ib_prefix_msg = ib_prefix_msg_val; ib_prefix_msg = ib_prefix_msg_val;
gds__prefix(ib_prefix_msg, ""); gds__prefix(ib_prefix_msg, ""); // B.O.
} }
else { else {
strcat(ib_prefix_msg_val, ib_prefix_msg); strcat(ib_prefix_msg_val, ib_prefix_msg);
@ -2419,7 +2418,7 @@ void* API_ROUTINE gds__temp_file(
const TEXT* directory = dir; const TEXT* directory = dir;
if (!directory) { if (!directory) {
gds__temp_dir(temp_dir); gds__temp_dir(temp_dir); // B.O.
directory = temp_dir; directory = temp_dir;
} }
if (strlen(directory) >= MAXPATHLEN - strlen(string) - strlen(TEMP_PATTERN) - 2) if (strlen(directory) >= MAXPATHLEN - strlen(string) - strlen(TEMP_PATTERN) - 2)
@ -3722,11 +3721,13 @@ static void safe_concat_path(TEXT *resultString, const TEXT *appendString)
resultString[len + alen] = 0; resultString[len + alen] = 0;
} }
void gds__default_printer(void* arg, SSHORT offset, const TEXT* line) void gds__default_printer(void* arg, SSHORT offset, const TEXT* line)
{ {
printf("%4d %s\n", offset, line); printf("%4d %s\n", offset, line);
} }
void gds__trace_printer(void* arg, SSHORT offset, const TEXT* line) void gds__trace_printer(void* arg, SSHORT offset, const TEXT* line)
{ {
// Assume that line is not too long // Assume that line is not too long