8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 01:23:03 +01:00
firebird-mirror/src/common/pretty.cpp

896 lines
19 KiB
C++
Raw Normal View History

2001-05-23 15:26:42 +02:00
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// PROGRAM: BLR Pretty Printer
// MODULE: pretty.cpp
// DESCRIPTION: BLR Pretty Printer
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// The contents of this file are subject to the Interbase Public
// License Version 1.0 (the "License"); you may not use this file
// except in compliance with the License. You may obtain a copy
// of the License at http://www.Inprise.com/IPL.html
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Software distributed under the License is distributed on an
// "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express
// or implied. See the License for the specific language governing
// rights and limitations under the License.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// The Original Code was created by Inprise Corporation
// and its predecessors. Portions created by Inprise Corporation are
// Copyright (C) Inprise Corporation.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// All Rights Reserved.
// Contributor(s): ______________________________________.
// TMN (Mike Nordell) 11.APR.2001 - Reduce compiler warnings
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
//
//____________________________________________________________
//
//
#include "firebird.h"
2010-01-10 18:56:57 +01:00
#include "dyn_consts.h"
2004-04-29 00:36:29 +02:00
#include <stdio.h>
2001-05-23 15:26:42 +02:00
#include <stdarg.h>
2003-11-08 17:40:17 +01:00
#include "../jrd/ibase.h"
#include "../jrd/constants.h"
2010-10-12 10:02:57 +02:00
#include "../common/prett_proto.h"
#include "../yvalve/gds_proto.h"
2001-05-23 15:26:42 +02:00
2009-04-26 12:24:44 +02:00
static inline void ADVANCE_PTR(TEXT*& ptr)
{
while (*ptr)
ptr++;
}
2001-05-23 15:26:42 +02:00
2004-05-18 23:54:56 +02:00
//#define PRINT_VERB if (print_verb (control, level)) return -1
2001-05-23 15:26:42 +02:00
#define PRINT_DYN_VERB if (print_dyn_verb (control, level)) return -1
#define PRINT_SDL_VERB if (print_sdl_verb (control, level)) return -1
#define BLR_BYTE *(control->ctl_blr)++
#define PUT_BYTE(byte) *(control->ctl_ptr)++ = byte
#define NEXT_BYTE *(control->ctl_blr)
struct ctl
{
2009-12-21 00:41:48 +01:00
const UCHAR* ctl_blr; // Running blr string
const UCHAR* ctl_blr_start; // Original start of blr string
2008-12-05 02:20:14 +01:00
FPTR_PRINT_CALLBACK ctl_routine; // Call back
2009-12-21 00:41:48 +01:00
void* ctl_user_arg; // User argument
TEXT* ctl_ptr;
2001-05-23 15:26:42 +02:00
SSHORT ctl_language;
SSHORT ctl_level;
TEXT ctl_buffer[PRETTY_BUFFER_SIZE];
};
2001-05-23 15:26:42 +02:00
2009-04-26 12:24:44 +02:00
static int blr_format(ctl*, const char *, ...);
static int error(ctl*, SSHORT, const TEXT *, int);
static int indent(ctl*, SSHORT);
static int print_blr_dtype(ctl*, bool);
static void print_blr_line(void*, SSHORT, const char*);
2009-04-26 12:24:44 +02:00
static int print_byte(ctl*);
static int print_char(ctl*, SSHORT);
static int print_dyn_verb(ctl*, SSHORT);
static int print_line(ctl*, SSHORT);
2009-04-26 12:24:44 +02:00
static SLONG print_long(ctl*);
static int print_sdl_verb(ctl*, SSHORT);
static int print_string(ctl*, SSHORT);
2009-04-26 12:24:44 +02:00
static int print_word(ctl*);
static inline void CHECK_BUFFER(ctl* control, SSHORT offset)
{
if (control->ctl_ptr > control->ctl_buffer + sizeof(control->ctl_buffer) - 20)
print_line(control, offset);
}
const char *dyn_table[] =
{
2010-10-12 10:02:57 +02:00
#include "../common/dyntable.h"
2001-05-23 15:26:42 +02:00
NULL
};
const char *cdb_table[] =
{
2010-10-12 10:02:57 +02:00
#include "../common/cdbtable.h"
2001-05-23 15:26:42 +02:00
NULL
};
const char *sdl_table[] =
{
2010-10-12 10:02:57 +02:00
#include "../common/sdltable.h"
2001-05-23 15:26:42 +02:00
NULL
};
const char *map_strings[] =
{
2001-05-23 15:26:42 +02:00
"FIELD2",
"FIELD1",
"MESSAGE",
"TERMINATOR",
"TERMINATING_FIELD",
"OPAQUE",
"TRANSPARENT",
"TAG",
"SUB_FORM",
"ITEM_INDEX",
"SUB_FIELD"
};
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Pretty print create database parameter buffer thru callback routine.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
2009-12-21 00:41:48 +01:00
int PRETTY_print_cdb(const UCHAR* blr, FPTR_PRINT_CALLBACK routine, void* user_arg, SSHORT language)
2001-05-23 15:26:42 +02:00
{
2003-09-05 12:14:08 +02:00
ctl ctl_buffer;
ctl* control = &ctl_buffer;
2001-05-23 15:26:42 +02:00
2009-06-25 12:44:37 +02:00
if (!routine)
{
routine = gds__default_printer;
user_arg = NULL;
2001-05-23 15:26:42 +02:00
}
control->ctl_routine = routine;
2001-05-23 15:26:42 +02:00
control->ctl_user_arg = user_arg;
control->ctl_blr = control->ctl_blr_start = blr;
control->ctl_ptr = control->ctl_buffer;
control->ctl_language = language;
SSHORT level = 0;
2001-05-23 15:26:42 +02:00
indent(control, level);
const SSHORT i = BLR_BYTE;
SCHAR temp[32];
2001-05-23 15:26:42 +02:00
if (*control->ctl_blr)
sprintf(temp, "gds__dpb_version%d, ", i);
2001-05-23 15:26:42 +02:00
else
sprintf(temp, "gds__dpb_version%d", i);
2001-05-23 15:26:42 +02:00
blr_format(control, temp);
2008-12-05 02:20:14 +01:00
SSHORT offset = 0;
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
SSHORT parameter;
2009-01-05 09:22:58 +01:00
while (parameter = BLR_BYTE)
{
const char* p;
if (parameter > FB_NELEM(cdb_table) || !(p = cdb_table[parameter]))
{
return error(control, 0, "*** cdb parameter %d is undefined ***\n", parameter);
2001-05-23 15:26:42 +02:00
}
indent(control, level);
blr_format(control, p);
PUT_BYTE(',');
2009-04-26 12:24:44 +02:00
int length = print_byte(control);
2009-06-25 12:44:37 +02:00
if (length)
{
2001-05-23 15:26:42 +02:00
do {
2004-05-18 23:54:56 +02:00
print_char(control, offset);
2001-05-23 15:26:42 +02:00
} while (--length);
}
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
}
return 0;
}
2009-12-21 00:41:48 +01:00
int PRETTY_print_dyn(const UCHAR* blr, FPTR_PRINT_CALLBACK routine, void* user_arg, SSHORT language)
2001-05-23 15:26:42 +02:00
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Pretty print dynamic DDL thru callback routine.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
{
2003-09-05 12:14:08 +02:00
ctl ctl_buffer;
ctl* control = &ctl_buffer;
2001-05-23 15:26:42 +02:00
2009-06-25 12:44:37 +02:00
if (!routine)
{
routine = gds__default_printer;
user_arg = NULL;
2001-05-23 15:26:42 +02:00
}
control->ctl_routine = routine;
2001-05-23 15:26:42 +02:00
control->ctl_user_arg = user_arg;
control->ctl_blr = control->ctl_blr_start = blr;
control->ctl_ptr = control->ctl_buffer;
control->ctl_language = language;
const SSHORT version = BLR_BYTE;
2001-05-23 15:26:42 +02:00
SSHORT offset = 0;
2003-11-08 17:40:17 +01:00
if (version != isc_dyn_version_1)
return error(control, offset, "*** dyn version %d is not supported ***\n", version);
2001-05-23 15:26:42 +02:00
blr_format(control, "gds__dyn_version_1, ");
2004-05-18 23:54:56 +02:00
print_line(control, offset);
SSHORT level = 1;
2001-05-23 15:26:42 +02:00
PRINT_DYN_VERB;
2003-11-08 17:40:17 +01:00
if (BLR_BYTE != isc_dyn_eoc)
return error(control, offset, "*** expected dyn end-of-command ***\n", 0);
2001-05-23 15:26:42 +02:00
blr_format(control, "gds__dyn_eoc");
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
}
2009-12-21 00:41:48 +01:00
int PRETTY_print_sdl(const UCHAR* blr, FPTR_PRINT_CALLBACK routine, void *user_arg, SSHORT language)
2001-05-23 15:26:42 +02:00
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Pretty print slice description language.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
{
2003-09-05 12:14:08 +02:00
ctl ctl_buffer;
ctl* control = &ctl_buffer;
2001-05-23 15:26:42 +02:00
2009-06-25 12:44:37 +02:00
if (!routine)
{
routine = gds__default_printer;
user_arg = NULL;
2001-05-23 15:26:42 +02:00
}
control->ctl_routine = routine;
2001-05-23 15:26:42 +02:00
control->ctl_user_arg = user_arg;
control->ctl_blr = control->ctl_blr_start = blr;
control->ctl_ptr = control->ctl_buffer;
control->ctl_language = language;
const SSHORT version = BLR_BYTE;
2001-05-23 15:26:42 +02:00
SSHORT offset = 0;
2003-11-08 17:40:17 +01:00
if (version != isc_sdl_version1)
return error(control, offset, "*** sdl version %d is not supported ***\n", version);
2001-05-23 15:26:42 +02:00
blr_format(control, "gds__sdl_version1, ");
2004-05-18 23:54:56 +02:00
print_line(control, offset);
SSHORT level = 1;
2001-05-23 15:26:42 +02:00
2003-11-08 17:40:17 +01:00
while (NEXT_BYTE != isc_sdl_eoc)
2001-05-23 15:26:42 +02:00
PRINT_SDL_VERB;
offset = control->ctl_blr - control->ctl_blr_start;
blr_format(control, "gds__sdl_eoc");
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Format an utterance.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int blr_format(ctl* control, const char *string, ...)
2001-05-23 15:26:42 +02:00
{
va_list ptr;
va_start(ptr, string);
2001-05-23 15:26:42 +02:00
vsprintf(control->ctl_ptr, string, ptr);
va_end(ptr);
2001-05-23 15:26:42 +02:00
while (*control->ctl_ptr)
control->ctl_ptr++;
2008-12-05 02:20:14 +01:00
2001-05-23 15:26:42 +02:00
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Put out an error msg and punt.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int error( ctl* control, SSHORT offset, const TEXT* string, int arg)
2001-05-23 15:26:42 +02:00
{
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
sprintf(control->ctl_ptr, string, arg);
2011-01-21 17:43:49 +01:00
fprintf(stderr, "%s", control->ctl_ptr);
2001-05-23 15:26:42 +02:00
ADVANCE_PTR(control->ctl_ptr);
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return -1;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Indent for pretty printing.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int indent( ctl* control, SSHORT level)
2001-05-23 15:26:42 +02:00
{
level *= 3;
while (--level >= 0)
PUT_BYTE(' ');
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a datatype sequence and return the length of the
// data described.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int print_blr_dtype(ctl* control, bool print_object)
2001-05-23 15:26:42 +02:00
{
const char* string = NULL;
SSHORT length = -1;
2001-05-23 15:26:42 +02:00
const USHORT dtype = BLR_BYTE;
2001-05-23 15:26:42 +02:00
// Special case blob (261) to keep down the size of the
// jump table
2001-05-23 15:26:42 +02:00
2009-01-05 09:22:58 +01:00
switch (dtype)
{
2001-05-23 15:26:42 +02:00
case blr_short:
string = "short";
length = 2;
break;
case blr_long:
string = "long";
length = 4;
break;
case blr_quad:
string = "quad";
length = 8;
break;
// Begin date/time/timestamp
2001-05-23 15:26:42 +02:00
case blr_sql_date:
string = "sql_date";
length = sizeof(ISC_DATE);
break;
case blr_sql_time:
string = "sql_time";
length = sizeof(ISC_TIME);
break;
case blr_timestamp:
string = "timestamp";
length = sizeof(ISC_TIMESTAMP);
break;
// End date/time/timestamp
2001-05-23 15:26:42 +02:00
case blr_int64:
string = "int64";
length = sizeof(ISC_INT64);
break;
case blr_float:
string = "float";
length = 4;
break;
case blr_double:
string = "double";
length = 8;
break;
case blr_d_float:
string = "d_float";
length = 8;
break;
case blr_text:
string = "text";
break;
case blr_cstring:
string = "cstring";
break;
case blr_varying:
string = "varying";
break;
case blr_text2:
string = "text2";
break;
case blr_cstring2:
string = "cstring2";
break;
case blr_varying2:
string = "varying2";
break;
case blr_blob_id:
string = "blob_id";
length = 8;
break;
default:
error(control, 0, "*** invalid data type ***", 0);
}
blr_format(control, "blr_%s, ", string);
if (!print_object)
return length;
2008-12-05 02:20:14 +01:00
2009-01-05 09:22:58 +01:00
switch (dtype)
{
2001-05-23 15:26:42 +02:00
case blr_text:
2009-04-26 12:24:44 +02:00
length = print_word(control);
2001-05-23 15:26:42 +02:00
break;
case blr_varying:
2009-04-26 12:24:44 +02:00
length = print_word(control) + 2;
2001-05-23 15:26:42 +02:00
break;
case blr_text2:
2009-04-26 12:24:44 +02:00
print_word(control);
length = print_word(control);
2001-05-23 15:26:42 +02:00
break;
case blr_varying2:
2009-04-26 12:24:44 +02:00
print_word(control);
length = print_word(control) + 2;
2001-05-23 15:26:42 +02:00
break;
case blr_short:
case blr_long:
2002-12-13 15:50:23 +01:00
case blr_int64:
2001-05-23 15:26:42 +02:00
case blr_quad:
2009-04-26 12:24:44 +02:00
print_byte(control);
2001-05-23 15:26:42 +02:00
break;
case blr_blob_id:
2009-04-26 12:24:44 +02:00
print_word(control);
2001-05-23 15:26:42 +02:00
break;
default:
if (dtype == blr_cstring)
2009-04-26 12:24:44 +02:00
length = print_word(control);
2009-06-25 12:44:37 +02:00
else if (dtype == blr_cstring2)
{
2009-04-26 12:24:44 +02:00
print_word(control);
length = print_word(control);
2001-05-23 15:26:42 +02:00
}
break;
}
return length;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a line of pretty-printed BLR.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static void print_blr_line(void* arg, SSHORT offset, const char* line)
2001-05-23 15:26:42 +02:00
{
ctl* control = static_cast<ctl*>(arg);
bool comma = false;
char c;
2001-05-23 15:26:42 +02:00
indent(control, control->ctl_level);
2009-06-25 12:44:37 +02:00
while (c = *line++)
{
2001-05-23 15:26:42 +02:00
PUT_BYTE(c);
if (c == ',')
comma = true;
2001-05-23 15:26:42 +02:00
else if (c != ' ')
comma = false;
2001-05-23 15:26:42 +02:00
}
if (!comma)
PUT_BYTE(',');
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a byte as a numeric value and return same.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
2009-04-26 12:24:44 +02:00
static int print_byte( ctl* control)
2001-05-23 15:26:42 +02:00
{
const UCHAR v = BLR_BYTE;
sprintf(control->ctl_ptr, control->ctl_language ? "chr(%d), " : "%d, ", v);
2001-05-23 15:26:42 +02:00
ADVANCE_PTR(control->ctl_ptr);
return v;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a byte as a numeric value and return same.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int print_char( ctl* control, SSHORT offset)
2001-05-23 15:26:42 +02:00
{
const UCHAR c = BLR_BYTE;
2009-01-05 09:22:58 +01:00
const bool printable = (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z') ||
(c >= '0' && c <= '9') || c == '$' || c == '_';
2001-05-23 15:26:42 +02:00
sprintf(control->ctl_ptr, printable ? "'%c'," : control->ctl_language ? "chr(%d)," : "%d,", c);
2001-05-23 15:26:42 +02:00
ADVANCE_PTR(control->ctl_ptr);
2009-04-26 12:24:44 +02:00
CHECK_BUFFER(control, offset);
2001-05-23 15:26:42 +02:00
return c;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Primary recursive routine to print dynamic DDL.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int print_dyn_verb( ctl* control, SSHORT level)
2001-05-23 15:26:42 +02:00
{
2009-01-05 09:22:58 +01:00
const SSHORT offset = control->ctl_blr - control->ctl_blr_start;
2004-02-02 12:02:12 +01:00
const UCHAR dyn_operator = BLR_BYTE;
2001-05-23 15:26:42 +02:00
2003-12-22 11:00:59 +01:00
const char* p;
const int size = FB_NELEM(dyn_table);
2004-02-02 12:02:12 +01:00
if (dyn_operator > size || dyn_operator <= 0 || !(p = dyn_table[dyn_operator])) {
return error(control, offset, "*** dyn operator %d is undefined ***\n", (int) dyn_operator);
2003-12-22 11:00:59 +01:00
}
2001-05-23 15:26:42 +02:00
indent(control, level);
blr_format(control, p);
PUT_BYTE(',');
PUT_BYTE(' ');
++level;
2003-12-22 11:00:59 +01:00
int length;
2008-12-05 02:20:14 +01:00
switch (dyn_operator)
{
case isc_dyn_drop_difference:
case isc_dyn_begin_backup:
case isc_dyn_end_backup:
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_begin:
case isc_dyn_mod_database:
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2003-11-08 17:40:17 +01:00
while (NEXT_BYTE != isc_dyn_end)
2001-05-23 15:26:42 +02:00
PRINT_DYN_VERB;
PRINT_DYN_VERB;
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_view_blr:
case isc_dyn_fld_validation_blr:
case isc_dyn_fld_computed_blr:
case isc_dyn_trg_blr:
case isc_dyn_fld_missing_value:
case isc_dyn_prc_blr:
case isc_dyn_fld_default_value:
2009-04-26 12:24:44 +02:00
length = print_word(control);
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2009-06-25 12:44:37 +02:00
if (length)
{
2001-05-23 15:26:42 +02:00
control->ctl_level = level;
fb_print_blr(control->ctl_blr, length, print_blr_line, control, control->ctl_language);
2001-05-23 15:26:42 +02:00
control->ctl_blr += length;
}
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_scl_acl:
// case isc_dyn_log_check_point_length:
// case isc_dyn_log_num_of_buffers:
// case isc_dyn_log_buffer_size:
// case isc_dyn_log_group_commit_wait:
2003-11-08 17:40:17 +01:00
case isc_dyn_idx_inactive:
2009-04-26 12:24:44 +02:00
length = print_word(control);
2001-05-23 15:26:42 +02:00
while (length--)
2009-04-26 12:24:44 +02:00
print_byte(control);
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_view_source:
case isc_dyn_fld_validation_source:
case isc_dyn_fld_computed_source:
case isc_dyn_description:
case isc_dyn_prc_source:
case isc_dyn_fld_default_source:
2009-04-26 12:24:44 +02:00
length = print_word(control);
2001-05-23 15:26:42 +02:00
while (length--)
2004-05-18 23:54:56 +02:00
print_char(control, offset);
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_del_exception:
2009-04-26 12:24:44 +02:00
if (length = print_word(control))
2003-12-22 11:00:59 +01:00
do {
2004-05-18 23:54:56 +02:00
print_char(control, offset);
2003-12-22 11:00:59 +01:00
} while (--length);
2001-05-23 15:26:42 +02:00
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_fld_not_null:
case isc_dyn_sql_object:
// case isc_dyn_drop_log:
// case isc_dyn_drop_cache:
// case isc_dyn_def_default_log:
// case isc_dyn_log_file_serial:
// case isc_dyn_log_file_raw:
// case isc_dyn_log_file_overflow:
2003-11-08 17:40:17 +01:00
case isc_dyn_single_validation:
2008-01-16 08:15:01 +01:00
case isc_dyn_del_computed:
2003-11-08 17:40:17 +01:00
case isc_dyn_del_default:
case isc_dyn_del_validation:
case isc_dyn_idx_statistic:
case isc_dyn_foreign_key_delete:
case isc_dyn_foreign_key_update:
case isc_dyn_foreign_key_cascade:
case isc_dyn_foreign_key_default:
case isc_dyn_foreign_key_null:
case isc_dyn_foreign_key_none:
2001-05-23 15:26:42 +02:00
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
2003-11-08 17:40:17 +01:00
case isc_dyn_end:
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
}
2009-04-26 12:24:44 +02:00
if (length = print_word(control))
2003-12-22 11:00:59 +01:00
do {
2004-05-18 23:54:56 +02:00
print_char(control, offset);
2003-12-22 11:00:59 +01:00
} while (--length);
2001-05-23 15:26:42 +02:00
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
switch (dyn_operator)
{
2003-11-08 17:40:17 +01:00
case isc_dyn_def_database:
case isc_dyn_def_dimension:
case isc_dyn_def_exception:
case isc_dyn_def_file:
// case isc_dyn_def_log_file:
// case isc_dyn_def_cache_file:
2003-11-08 17:40:17 +01:00
case isc_dyn_def_filter:
case isc_dyn_def_function:
case isc_dyn_def_function_arg:
case isc_dyn_def_generator:
case isc_dyn_def_global_fld:
case isc_dyn_def_idx:
case isc_dyn_def_local_fld:
case isc_dyn_def_rel:
case isc_dyn_def_procedure:
case isc_dyn_def_parameter:
case isc_dyn_def_security_class:
case isc_dyn_def_shadow:
case isc_dyn_def_sql_fld:
case isc_dyn_def_trigger:
case isc_dyn_def_trigger_msg:
case isc_dyn_def_view:
case isc_dyn_delete_database:
case isc_dyn_delete_dimensions:
case isc_dyn_delete_filter:
case isc_dyn_delete_function:
case isc_dyn_delete_global_fld:
case isc_dyn_delete_idx:
case isc_dyn_delete_local_fld:
case isc_dyn_delete_rel:
case isc_dyn_delete_procedure:
case isc_dyn_delete_parameter:
case isc_dyn_delete_security_class:
case isc_dyn_delete_trigger:
case isc_dyn_delete_trigger_msg:
case isc_dyn_delete_shadow:
case isc_dyn_mod_exception:
case isc_dyn_mod_global_fld:
case isc_dyn_mod_idx:
case isc_dyn_mod_local_fld:
case isc_dyn_mod_procedure:
case isc_dyn_mod_rel:
case isc_dyn_mod_security_class:
case isc_dyn_mod_trigger:
case isc_dyn_mod_trigger_msg:
case isc_dyn_rel_constraint:
case isc_dyn_mod_view:
case isc_dyn_grant:
case isc_dyn_revoke:
case isc_dyn_view_relation:
case isc_dyn_def_sql_role:
2003-11-08 17:40:17 +01:00
while (NEXT_BYTE != isc_dyn_end)
2001-05-23 15:26:42 +02:00
PRINT_DYN_VERB;
PRINT_DYN_VERB;
return 0;
}
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Invoke callback routine to print (or do something with) a line.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int print_line( ctl* control, SSHORT offset)
2001-05-23 15:26:42 +02:00
{
*control->ctl_ptr = 0;
(*control->ctl_routine) (control->ctl_user_arg, offset, control->ctl_buffer);
control->ctl_ptr = control->ctl_buffer;
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a VAX word as a numeric value an return same.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
2009-04-26 12:24:44 +02:00
static SLONG print_long( ctl* control)
2001-05-23 15:26:42 +02:00
{
2003-12-22 11:00:59 +01:00
const UCHAR v1 = BLR_BYTE;
const UCHAR v2 = BLR_BYTE;
const UCHAR v3 = BLR_BYTE;
const UCHAR v4 = BLR_BYTE;
sprintf(control->ctl_ptr, control->ctl_language ?
2004-12-16 04:03:13 +01:00
"chr(%d),chr(%d),chr(%d),chr(%d) " : "%d,%d,%d,%d, ",
v1, v2, v3, v4);
2001-05-23 15:26:42 +02:00
ADVANCE_PTR(control->ctl_ptr);
return v1 | (v2 << 8) | (v3 << 16) | (v4 << 24);
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Primary recursive routine to print slice description language.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int print_sdl_verb( ctl* control, SSHORT level)
2001-05-23 15:26:42 +02:00
{
2004-02-02 12:02:12 +01:00
const char* p;
2001-05-23 15:26:42 +02:00
2004-05-18 23:54:56 +02:00
SSHORT offset = control->ctl_blr - control->ctl_blr_start;
2004-02-02 12:02:12 +01:00
const UCHAR sdl_operator = BLR_BYTE;
2001-05-23 15:26:42 +02:00
if (sdl_operator > FB_NELEM(sdl_table) || sdl_operator <= 0 || !(p = sdl_table[sdl_operator]))
2004-02-02 12:02:12 +01:00
{
return error(control, offset, "*** SDL operator %d is undefined ***\n", (int) sdl_operator);
2004-02-02 12:02:12 +01:00
}
2001-05-23 15:26:42 +02:00
indent(control, level);
blr_format(control, p);
PUT_BYTE(',');
PUT_BYTE(' ');
++level;
2004-02-02 12:02:12 +01:00
int n = 0;
2001-05-23 15:26:42 +02:00
switch (sdl_operator)
{
2003-11-08 17:40:17 +01:00
case isc_sdl_begin:
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2003-11-08 17:40:17 +01:00
while (NEXT_BYTE != isc_sdl_end)
2001-05-23 15:26:42 +02:00
PRINT_SDL_VERB;
PRINT_SDL_VERB;
return 0;
2003-11-08 17:40:17 +01:00
case isc_sdl_struct:
2009-04-26 12:24:44 +02:00
n = print_byte(control);
2009-06-25 12:44:37 +02:00
while (n--)
{
2004-05-18 23:54:56 +02:00
print_line(control, offset);
indent(control, level + 1);
2001-05-23 15:26:42 +02:00
offset = control->ctl_blr - control->ctl_blr_start;
print_blr_dtype(control, true);
2001-05-23 15:26:42 +02:00
}
break;
2003-11-08 17:40:17 +01:00
case isc_sdl_scalar:
2009-04-26 12:24:44 +02:00
print_byte(control);
2001-05-23 15:26:42 +02:00
2003-11-08 17:40:17 +01:00
case isc_sdl_element:
2009-04-26 12:24:44 +02:00
n = print_byte(control);
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
while (n--)
PRINT_SDL_VERB;
return 0;
2003-11-08 17:40:17 +01:00
case isc_sdl_field:
case isc_sdl_relation:
2004-05-18 23:54:56 +02:00
print_string(control, offset);
2001-05-23 15:26:42 +02:00
break;
2003-11-08 17:40:17 +01:00
case isc_sdl_fid:
case isc_sdl_rid:
case isc_sdl_short_integer:
2009-04-26 12:24:44 +02:00
print_word(control);
2001-05-23 15:26:42 +02:00
break;
2003-11-08 17:40:17 +01:00
case isc_sdl_variable:
case isc_sdl_tiny_integer:
2009-04-26 12:24:44 +02:00
print_byte(control);
2001-05-23 15:26:42 +02:00
break;
2003-11-08 17:40:17 +01:00
case isc_sdl_long_integer:
2009-04-26 12:24:44 +02:00
print_long(control);
2001-05-23 15:26:42 +02:00
break;
2003-11-08 17:40:17 +01:00
case isc_sdl_add:
case isc_sdl_subtract:
case isc_sdl_multiply:
case isc_sdl_divide:
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
PRINT_SDL_VERB;
PRINT_SDL_VERB;
return 0;
2003-11-08 17:40:17 +01:00
case isc_sdl_negate:
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
PRINT_SDL_VERB;
return 0;
2003-11-08 17:40:17 +01:00
case isc_sdl_do3:
2001-05-23 15:26:42 +02:00
n++;
2003-11-08 17:40:17 +01:00
case isc_sdl_do2:
2001-05-23 15:26:42 +02:00
n++;
2003-11-08 17:40:17 +01:00
case isc_sdl_do1:
2001-05-23 15:26:42 +02:00
n += 2;
2009-04-26 12:24:44 +02:00
print_byte(control);
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
while (n--)
PRINT_SDL_VERB;
return 0;
}
2004-05-18 23:54:56 +02:00
print_line(control, offset);
2001-05-23 15:26:42 +02:00
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a byte-counted string.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
static int print_string( ctl* control, SSHORT offset)
2001-05-23 15:26:42 +02:00
{
2009-04-26 12:24:44 +02:00
SSHORT n = print_byte(control);
2001-05-23 15:26:42 +02:00
while (--n >= 0)
2004-05-18 23:54:56 +02:00
print_char(control, offset);
2001-05-23 15:26:42 +02:00
PUT_BYTE(' ');
return 0;
}
//____________________________________________________________
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
// Print a VAX word as a numeric value an return same.
2008-12-05 02:20:14 +01:00
//
2001-05-23 15:26:42 +02:00
2009-04-26 12:24:44 +02:00
static int print_word( ctl* control)
2001-05-23 15:26:42 +02:00
{
const UCHAR v1 = BLR_BYTE;
const UCHAR v2 = BLR_BYTE;
sprintf(control->ctl_ptr, control->ctl_language ? "chr(%d),chr(%d), " : "%d,%d, ", v1, v2);
2001-05-23 15:26:42 +02:00
ADVANCE_PTR(control->ctl_ptr);
return (v2 << 8) | v1;
}