From af740ca41a86c18cf170e47a42ef4b88491e7532 Mon Sep 17 00:00:00 2001 From: hvlad Date: Sat, 14 May 2005 13:45:01 +0000 Subject: [PATCH] 1. Fixed bug #908319 2. Fixed inability to restore into nonexisting file with -se switch used --- src/alice/alice.cpp | 8 +++++--- src/burp/burp.cpp | 11 +++++++---- 2 files changed, 12 insertions(+), 7 deletions(-) diff --git a/src/alice/alice.cpp b/src/alice/alice.cpp index bcd162fd0f..1765379def 100644 --- a/src/alice/alice.cpp +++ b/src/alice/alice.cpp @@ -24,7 +24,7 @@ // //____________________________________________________________ // -// $Id: alice.cpp,v 1.75 2004-11-28 01:01:43 robocop Exp $ +// $Id: alice.cpp,v 1.76 2005-05-14 13:44:55 hvlad Exp $ // // 2001.07.06 Sean Leyne - Code Cleanup, removed "#ifdef READONLY_DATABASE" // conditionals, as the engine now fully supports @@ -687,8 +687,10 @@ void ALICE_print_status(const ISC_STATUS* status_vector) AliceGlobals* tdgbl = AliceGlobals::getSpecific(); ISC_STATUS* status = tdgbl->service_blk->svc_status; if (status != status_vector) { - while (*status && (++i < ISC_STATUS_LENGTH)) { - status++; + if (status[1]) { + while (*status && (++i < ISC_STATUS_LENGTH)) { + status++; + } } for (int j = 0; status_vector[j] && (i < ISC_STATUS_LENGTH); j++, i++) { *status++ = status_vector[j]; diff --git a/src/burp/burp.cpp b/src/burp/burp.cpp index 5d3da160e3..cc0d2edc40 100644 --- a/src/burp/burp.cpp +++ b/src/burp/burp.cpp @@ -1473,9 +1473,11 @@ void BURP_print_status(const ISC_STATUS* status_vector) BurpGlobals* tdgbl = BurpGlobals::getSpecific(); ISC_STATUS* status = tdgbl->service_blk->svc_status; if (status != status_vector) { - int i = 0; - while (*status && (++i < ISC_STATUS_LENGTH)) - status++; + int i = 0; + if (status[1]) { + while (*status && (++i < ISC_STATUS_LENGTH)) + status++; + } for (int j = 0; status_vector[j] && (i < ISC_STATUS_LENGTH); j++, i++) *status++ = status_vector[j]; } @@ -1651,7 +1653,8 @@ static gbak_action open_files(const TEXT* file1, * **************************************/ BurpGlobals* tdgbl = BurpGlobals::getSpecific(); - ISC_STATUS* status_vector = tdgbl->status; + ISC_STATUS_ARRAY temp_status; + ISC_STATUS* status_vector = temp_status; // try to attach the database using the first file_name