mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-23 06:03:02 +01:00
- Decrease SUPERSERVER ifdefs (join & use common error)
- Remove obsolete code - Fix warning in mvol.cpp
This commit is contained in:
parent
76b4619ca7
commit
4832ad1b2c
@ -37,7 +37,7 @@
|
||||
*/
|
||||
|
||||
/*
|
||||
$Id: backup.epp,v 1.42 2003-10-29 10:53:03 robocop Exp $
|
||||
$Id: backup.epp,v 1.43 2003-11-03 01:12:14 brodsom Exp $
|
||||
*/
|
||||
|
||||
#include "firebird.h"
|
||||
@ -109,9 +109,6 @@ void put_numeric(SCHAR, SLONG);
|
||||
void put_relation(BURP_REL);
|
||||
bool put_source_blob(SCHAR, SCHAR, ISC_QUAD *);
|
||||
int put_text(SCHAR, const TEXT *, SSHORT);
|
||||
#ifdef NOT_USED_OR_REPLACED
|
||||
void put_trigger(enum trig_t, GDS__QUAD *, GDS__QUAD *, GDS_NAME);
|
||||
#endif
|
||||
void set_capabilities(void);
|
||||
int symbol_length(const TEXT *, ULONG);
|
||||
void write_character_sets(void);
|
||||
@ -310,8 +307,7 @@ int BACKUP_backup(const TEXT* dbb_file, const TEXT* file_name)
|
||||
tdgbl->action->act_file = fil;
|
||||
if (MVOL_split_hdr_write() == FALSE)
|
||||
{
|
||||
BURP_error(269, tdgbl->action->act_file->fil_name, 0, 0, 0,
|
||||
0);
|
||||
BURP_error(269, true, tdgbl->action->act_file->fil_name, 0, 0, 0, 0);
|
||||
// msg 269 can't write a header record to file %s
|
||||
}
|
||||
}
|
||||
@ -2489,37 +2485,6 @@ int put_text( SCHAR attribute, const TEXT * text, SSHORT size_len)
|
||||
}
|
||||
|
||||
|
||||
#ifdef NOT_USED_OR_REPLACED
|
||||
void put_trigger(enum trig_t type,
|
||||
GDS__QUAD * blob_ident,
|
||||
GDS__QUAD * source_blob, GDS_NAME rel_name)
|
||||
{
|
||||
/**************************************
|
||||
*
|
||||
* p u t _ t r i g g e r
|
||||
*
|
||||
**************************************
|
||||
*
|
||||
* Functional description
|
||||
* Write a trigger to the output file.
|
||||
* NOTE: This is used backup pre-V3 triggers only
|
||||
*
|
||||
**************************************/
|
||||
TGBL tdgbl = GET_THREAD_DATA;
|
||||
|
||||
if (!blob_ident->gds_quad_low)
|
||||
return;
|
||||
|
||||
put(tdgbl, (UCHAR) (rec_trigger));
|
||||
put_numeric(att_trig_type, type);
|
||||
put_blr_blob(att_trig_blr, (ISC_QUAD *) blob_ident);
|
||||
put_source_blob(att_trig_source2, att_trig_source,
|
||||
(ISC_QUAD *) source_blob);
|
||||
put(tdgbl, (UCHAR) (att_end));
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
void set_capabilities(void)
|
||||
{
|
||||
/**************************************
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -29,9 +29,9 @@ int BURP_main(SVC service);
|
||||
#endif
|
||||
|
||||
void BURP_abort(void);
|
||||
void BURP_svc_error(USHORT, USHORT, const void*, USHORT, const void*,
|
||||
void BURP_error(USHORT, bool, USHORT, const void*, USHORT, const void*,
|
||||
USHORT, const void*, USHORT, const void*, USHORT, const void*);
|
||||
void BURP_error(USHORT, const void*, const void*, const void*, const void*, const void*);
|
||||
void BURP_error(USHORT, bool, const void*, const void*, const void*, const void*, const void*);
|
||||
void BURP_print_status(const ISC_STATUS*);
|
||||
void BURP_error_redirect(const ISC_STATUS*, USHORT, const void*, const void*);
|
||||
void BURP_msg_partial(USHORT, const void*, const void*, const void*,
|
||||
|
@ -60,7 +60,8 @@ UCHAR *MISC_alloc_burp(ULONG size)
|
||||
if (!block)
|
||||
/* NOMEM: message & abort FREE: all items freed at gbak exit */
|
||||
{
|
||||
BURP_error(238, NULL, NULL, NULL, NULL, NULL); // msg 238: System memory exhaused
|
||||
BURP_error(238, true, NULL, NULL, NULL, NULL, NULL);
|
||||
// msg 238: System memory exhaused
|
||||
return NULL;
|
||||
}
|
||||
|
||||
@ -110,7 +111,8 @@ void MISC_free_burp( void *free)
|
||||
}
|
||||
|
||||
// We should always find the block in the list
|
||||
BURP_error(238, NULL, NULL, NULL, NULL, NULL); // msg 238: System memory exhausted
|
||||
BURP_error(238, true, NULL, NULL, NULL, NULL, NULL);
|
||||
// msg 238: System memory exhausted
|
||||
// (too lazy to add a better message)
|
||||
}
|
||||
}
|
||||
|
@ -262,7 +262,7 @@ void MVOL_init_write(const UCHAR* database_name, // unused?
|
||||
{
|
||||
if (tdgbl->action->act_action == ACT_backup_split)
|
||||
{
|
||||
BURP_error(269, tdgbl->action->act_file->fil_name, 0, 0, 0, 0);
|
||||
BURP_error(269, true, tdgbl->action->act_file->fil_name, 0, 0, 0, 0);
|
||||
// msg 269 can't write a header record to file %s
|
||||
}
|
||||
tdgbl->file_desc = next_volume(tdgbl->file_desc, MODE_WRITE, false);
|
||||
@ -634,7 +634,8 @@ UCHAR MVOL_write(UCHAR c, int *io_cnt, UCHAR ** io_ptr)
|
||||
}
|
||||
else
|
||||
{
|
||||
BURP_error(270, 0, 0, 0, 0, 0); // msg 270 free disk space exhausted
|
||||
BURP_error(270, true, 0, 0, 0, 0, 0);
|
||||
// msg 270 free disk space exhausted
|
||||
}
|
||||
cnt = 0;
|
||||
continue;
|
||||
@ -1377,7 +1378,7 @@ bool MVOL_split_hdr_read(void)
|
||||
#else
|
||||
cnt = read(tdgbl->action->act_file->fil_fd, buffer, HDR_SPLIT_SIZE);
|
||||
#endif
|
||||
if ((cnt == HDR_SPLIT_SIZE) &&
|
||||
if ((cnt >= 0) && ((ULONG) cnt == HDR_SPLIT_SIZE) &&
|
||||
((strncmp(buffer, HDR_SPLIT_TAG, (sizeof(HDR_SPLIT_TAG) - 1)) == 0) ||
|
||||
(strncmp(buffer, HDR_SPLIT_TAG5, (sizeof(HDR_SPLIT_TAG) - 1)) == 0)))
|
||||
{
|
||||
|
@ -24,7 +24,7 @@
|
||||
* 2003.08.17 Claudio Valderrama: Fix SF Bug #750659.
|
||||
*/
|
||||
/*
|
||||
$Id: restore.epp,v 1.49 2003-10-29 10:53:03 robocop Exp $
|
||||
$Id: restore.epp,v 1.50 2003-11-03 01:12:14 brodsom Exp $
|
||||
*/
|
||||
|
||||
#include "firebird.h"
|
||||
@ -187,9 +187,6 @@ void store_blr_gen_id (const TEXT*, SINT64);
|
||||
void stuff_string(UCHAR **, const TEXT *);
|
||||
void update_global_field (void);
|
||||
void general_on_error (void);
|
||||
#ifdef NOT_USED_OR_REPLACED
|
||||
bool bug_8183 (TGBL);
|
||||
#endif
|
||||
#ifdef DEBUG
|
||||
UCHAR debug_on = 0; // able to turn this on in the debugger
|
||||
#endif
|
||||
@ -2438,13 +2435,9 @@ rec_type get_data (BURP_REL relation)
|
||||
break;
|
||||
|
||||
default:
|
||||
#ifdef SUPERSERVER
|
||||
BURP_svc_error (26, isc_arg_number, (void*) (SLONG) field->fld_type,
|
||||
BURP_error (26, true, isc_arg_number, (void*) (SLONG) field->fld_type,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
#else
|
||||
BURP_error (26, (void*) (SLONG) field->fld_type, 0, 0, 0, 0);
|
||||
// msg 26 datatype %ld not understood
|
||||
#endif
|
||||
break;
|
||||
}
|
||||
if (alignment)
|
||||
@ -2557,14 +2550,10 @@ rec_type get_data (BURP_REL relation)
|
||||
old_length = recompute_length (relation);
|
||||
if (l != old_length)
|
||||
{
|
||||
#ifdef SUPERSERVER
|
||||
BURP_svc_error(40, isc_arg_number, (void*)length,
|
||||
BURP_error(40, true, isc_arg_number, (void*)length,
|
||||
isc_arg_number, (void*) (ULONG) l,
|
||||
0, NULL, 0, NULL, 0, NULL);
|
||||
#else
|
||||
BURP_error (40, (void*) length, (void*)(ULONG) l, 0, 0, 0);
|
||||
// msg 40 wrong length record, expected %ld encountered %ld
|
||||
#endif
|
||||
}
|
||||
}
|
||||
if (!buffer)
|
||||
@ -5028,14 +5017,10 @@ bool get_relation (void)
|
||||
break;
|
||||
|
||||
default:
|
||||
#ifdef SUPERSERVER
|
||||
BURP_svc_error (43, isc_arg_number, (void*) record,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
#else
|
||||
BURP_error (43, (void*) record, 0, 0, 0, 0);
|
||||
BURP_error(43, true, isc_arg_number, (void*) record,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
// msg 43 don't recognize record type %ld
|
||||
#endif
|
||||
break;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -6563,13 +6548,9 @@ bool restore (const TEXT* file_name,
|
||||
|
||||
if (tdgbl->RESTORE_format < 1 || tdgbl->RESTORE_format > ATT_BACKUP_FORMAT)
|
||||
{
|
||||
#ifdef SUPERSERVER
|
||||
BURP_svc_error (44, isc_arg_number, (void*)(ULONG)tdgbl->RESTORE_format,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
#else
|
||||
BURP_error (44, (void*)(ULONG) tdgbl->RESTORE_format, 0, 0, 0, 0);
|
||||
BURP_error(44, true, isc_arg_number, (void*)(ULONG)tdgbl->RESTORE_format,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
// msg 44 Expected backup version 1, 2, or 3. Found %ld
|
||||
#endif
|
||||
}
|
||||
|
||||
create_database (database_name);
|
||||
@ -6588,13 +6569,9 @@ bool restore (const TEXT* file_name,
|
||||
USHORT db_version = check_db_version();
|
||||
if (db_version < DB_VERSION_CURRENT)
|
||||
{
|
||||
#ifdef SUPERSERVER
|
||||
BURP_svc_error (51, isc_arg_number, (void*) (ULONG) db_version,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
#else
|
||||
BURP_error (51, (void*) (ULONG) db_version, 0, 0, 0, 0);
|
||||
BURP_error(51, true, isc_arg_number, (void*) (ULONG) db_version,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
// msg 51 database format %ld is too old to restore to
|
||||
#endif
|
||||
}
|
||||
|
||||
BURP_verbose (129, NULL, NULL, NULL, NULL, NULL);
|
||||
@ -6814,13 +6791,9 @@ bool restore (const TEXT* file_name,
|
||||
break;
|
||||
|
||||
default:
|
||||
#ifdef SUPERSERVER
|
||||
BURP_svc_error (43, isc_arg_number, (void*) record,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
#else
|
||||
BURP_error (43, (void*) record, 0, 0, 0, 0);
|
||||
BURP_error(43, true, isc_arg_number, (void*) record,
|
||||
0, NULL, 0, NULL, 0, NULL, 0, NULL);
|
||||
// msg 43 don't recognize record type %ld
|
||||
#endif
|
||||
break;
|
||||
}
|
||||
}
|
||||
@ -7133,98 +7106,6 @@ void update_global_field (void)
|
||||
tdgbl->gbl_global_fields = NULL;
|
||||
}
|
||||
|
||||
#ifdef NOT_USED_OR_REPLACED
|
||||
bool bug_8183 (TGBL tdgbl)
|
||||
{
|
||||
/**************************************
|
||||
*
|
||||
* b u g _ 8 1 8 3
|
||||
*
|
||||
**************************************
|
||||
*
|
||||
* Name: bug_8183
|
||||
*
|
||||
* Function: Bug fix for bug_no 8183: It is a migration bug between IB3.3
|
||||
* and IB4.0. Gbak v4.0 can't restore database v3.3 if
|
||||
* database has an index definition with comment field.
|
||||
* It happens because of att_index_description2 attribute
|
||||
* (which indicates that index contains a comment field
|
||||
* and is equal 8 under IB3.3) accidently got new value 9
|
||||
* under IB4.0.
|
||||
* At the same time, new attribute att_index_foreign_key
|
||||
* has been added with value 8. Thus, when gbak v4.0 faces
|
||||
* index attribute with value 8 during restore procedure of
|
||||
* database v3.3, it will recognize this attribute as
|
||||
* att_index_foreign_key instead of att_index_description2.
|
||||
*
|
||||
* This function is trying to recognize the next
|
||||
* data in tdgbl->io_ptr buffer as either name of foreign
|
||||
* key or comment field. Function returns true in case of
|
||||
* comment field, otherwise false.
|
||||
*
|
||||
* Usage: result = bug_8183(tdgbl);
|
||||
*
|
||||
* Parameters: tdgbl - pointer to the structure of global switches
|
||||
* and data
|
||||
*
|
||||
* Returns: result [true/false]
|
||||
*
|
||||
* Pre: gbak got an index attribute with value "8" from
|
||||
* backup database.
|
||||
*
|
||||
* Post: none
|
||||
*
|
||||
* Remarks: For more information see bug_no 8183
|
||||
*
|
||||
**************************************/
|
||||
|
||||
UCHAR tmp[sizeof(ULONG) + 1], *p;
|
||||
USHORT i;
|
||||
ULONG len1, len2;
|
||||
bool result = false;
|
||||
|
||||
|
||||
USHORT io_cnt = tdgbl->io_cnt;
|
||||
UCHAR* io_ptr = tdgbl->io_ptr;
|
||||
|
||||
if ( io_cnt > 0 )
|
||||
{
|
||||
len1 = len2 = *io_ptr++;
|
||||
--io_cnt;
|
||||
/* len1 can be either length of att_index_foreign_key OR quantity of byte
|
||||
where seats length of att_index_description2. In case of
|
||||
att_index_description2, len1 should be as even and no bigger
|
||||
than sizeof(ULONG). Let's check it out */
|
||||
if ( (len1 % 2) == 0 && (len1 <= sizeof(ULONG)) )
|
||||
{
|
||||
/* it still can be a foreign key; so
|
||||
try to read it. Note: if internal buffer is over, then
|
||||
we wan't read next block */
|
||||
|
||||
memset(tmp, '\0', sizeof(tmp));
|
||||
|
||||
p = tmp;
|
||||
while (len1-- && io_cnt-- )
|
||||
*p++ = *io_ptr++;
|
||||
|
||||
/* if read array is a foreign key then it should contain following chars
|
||||
only : ['A'..'Z', '0'..'9', '_', '$'] */
|
||||
for ( p = tmp, i = 0;
|
||||
*p && *p != ' ' && ((*p >= 'A' && *p <= 'Z') || (*p == '_') ||
|
||||
(*p >= '0' && *p <= '9') || (*p == '$')) ;
|
||||
p++ )
|
||||
{
|
||||
i++;
|
||||
}
|
||||
if ( (len2 - len1) != i )
|
||||
result = true;
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
#endif
|
||||
|
||||
} // namespace
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user