8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-27 05:23:02 +01:00
firebird-mirror/src/jrd/req.h

310 lines
11 KiB
C
Raw Normal View History

2001-05-23 15:26:42 +02:00
/*
* PROGRAM: JRD Access Method
* MODULE: req.h
* DESCRIPTION: Request block definitions
*
* 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
*
* 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.
*
* The Original Code was created by Inprise Corporation
* and its predecessors. Portions created by Inprise Corporation are
* Copyright (C) Inprise Corporation.
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*
* 2002.09.28 Dmitry Yemanov: Reworked internal_info stuff, enhanced
* exception handling in SPs/triggers,
* implemented ROWS_AFFECTED system variable
2001-05-23 15:26:42 +02:00
*/
#ifndef JRD_REQ_H
#define JRD_REQ_H
2001-05-23 15:26:42 +02:00
2001-12-24 03:51:06 +01:00
#include "../jrd/jrd_blks.h"
#include "../include/fb_blk.h"
#include "../jrd/exe.h"
2001-12-24 03:51:06 +01:00
#include <vector>
class lck;
class fmt;
class jrd_rel;
class jrd_prc;
class rec;
class jrd_nod;
2001-05-23 15:26:42 +02:00
/* record parameter block */
typedef struct rpb {
rpb() : rpb_window(-1) {}
2001-05-23 15:26:42 +02:00
SLONG rpb_number; /* record number in relation */
SLONG rpb_transaction; /* transaction number */
jrd_rel* rpb_relation; /* relation of record */
rec* rpb_record; /* final record block */
rec* rpb_prior; /* prior record block if this is a delta record */
2001-05-23 15:26:42 +02:00
struct srpb *rpb_copy; /* rpb copy for singleton verification */
rec* rpb_undo; /* our first version of data if this is a second modification */
2001-05-23 15:26:42 +02:00
USHORT rpb_format_number; /* format number in relation */
SLONG rpb_page; /* page number */
USHORT rpb_line; /* line number on page */
SLONG rpb_f_page; /* fragment page number */
USHORT rpb_f_line; /* fragment line number on page */
SLONG rpb_b_page; /* back page */
USHORT rpb_b_line; /* back line */
UCHAR *rpb_address; /* address of record sans header */
USHORT rpb_length; /* length of record */
USHORT rpb_flags; /* record ODS flags replica */
USHORT rpb_stream_flags; /* stream flags */
SSHORT rpb_org_scans; /* relation scan count at stream open */
struct win rpb_window;
} RPB;
/* Record flags must be an exact replica of ODS record header flags */
#define rpb_deleted 1
#define rpb_chained 2
#define rpb_fragment 4
#define rpb_incomplete 8
#define rpb_blob 16
#define rpb_delta 32 /* prior version is a differences record */
#define rpb_damaged 128 /* record is busted */
#define rpb_gc_active 256 /* garbage collecting dead record version */
/* Stream flags */
#define RPB_s_refetch 0x1 /* re-fetch required due to sort */
#define RPB_s_update 0x2 /* input stream fetched for update */
#define SET_NULL(record, id) record->rec_data [id >> 3] |= (1 << (id & 7))
#define CLEAR_NULL(record, id) record->rec_data [id >> 3] &= ~(1 << (id & 7))
#define TEST_NULL(record, id) record->rec_data [id >> 3] & (1 << (id & 7))
2001-05-23 15:26:42 +02:00
#define MAX_DIFFERENCES 1024 /* Max length of generated Differences string
between two records */
/* Store allocation policy types. Parameter to DPM_store() */
#define DPM_primary 1 /* New primary record */
#define DPM_secondary 2 /* Chained version of primary record */
#define DPM_other 3 /* Independent (or don't care) record */
/* Record block (holds data, remember data?) */
2001-12-24 03:51:06 +01:00
class rec : public pool_alloc_rpt<SCHAR, type_rec>
{
public:
const fmt* rec_format; /* what the data looks like */
class lls *rec_precedence; /* stack of higher precedence pages */
2001-05-23 15:26:42 +02:00
USHORT rec_length; /* how much there is */
const fmt* rec_fmt_bk; // backup format to cope with Borland's ill null signaling
2001-05-23 15:26:42 +02:00
UCHAR rec_flags; /* misc record flags */
SLONG rec_number; /* original rpb number - used for undoing multiple updates */
double rec_dummy; /* this is to force next field to a double boundary */
UCHAR rec_data[1]; /* THIS VARIABLE MUST BE ALIGNED ON A DOUBLE BOUNDARY */
2001-12-24 03:51:06 +01:00
};
typedef rec *REC;
2001-05-23 15:26:42 +02:00
#define REC_same_tx 1 /* record inserted/updated and deleted by same tx */
#define REC_gc_active 2 /* relation garbage collect record block in use */
#define REC_new_version 4 /* savepoint created new record version and deleted it */
/* save rpb block */
2001-12-24 03:51:06 +01:00
class srpb : public pool_alloc<type_srpb>
{
public:
rpb srpb_rpb[1]; /* record parameter blocks */
2001-12-24 03:51:06 +01:00
};
typedef srpb *SRPB;
2001-05-23 15:26:42 +02:00
/* request block */
class jrd_req : public pool_alloc_rpt<rpb, type_req>
2001-12-24 03:51:06 +01:00
{
public:
jrd_req(JrdMemoryPool* pool) : req_fors(pool), req_invariants(pool) { };
2001-12-24 03:51:06 +01:00
ATT req_attachment; // database attachment
USHORT req_count; // number of streams
USHORT req_incarnation; // incarnation number
ULONG req_impure_size; // size of impure area
JrdMemoryPool* req_pool;
struct vec* req_sub_requests; // vector of sub-requests
class jrd_tra* req_transaction;
2004-03-07 08:58:55 +01:00
jrd_req* req_request; /* next request in Database */
2001-12-24 03:51:06 +01:00
struct acc* req_access; /* Access items to be checked */
struct vec* req_variables; /* Vector of variables, if any */
class Resource* req_resources; /* Resources (relations and indices) */
jrd_nod* req_message; /* Current message for send/receive */
2001-05-23 15:26:42 +02:00
#ifdef SCROLLABLE_CURSORS
jrd_nod* req_async_message; /* Asynchronous message (used in scrolling) */
2001-05-23 15:26:42 +02:00
#endif
2001-12-24 03:51:06 +01:00
struct vec* req_refresh_ranges; /* Vector of refresh_ranges */
struct rng* req_begin_ranges; /* Vector of refresh_ranges */
jrd_prc* req_procedure; /* procedure, if any */
2003-12-03 09:19:24 +01:00
const TEXT* req_trg_name; /* name of request (trigger), if any */
2001-05-23 15:26:42 +02:00
USHORT req_length; /* message length for send/receive */
USHORT req_nmsgs; /* number of message types */
USHORT req_mmsg; /* highest message type */
USHORT req_msend; /* longest send message */
USHORT req_mreceive; /* longest receive message */
ULONG req_records_selected; /* count of records selected by request (meeting selection criteria) */
ULONG req_records_inserted; /* count of records inserted by request */
ULONG req_records_updated; /* count of records updated by request */
ULONG req_records_deleted; /* count of records deleted by request */
ULONG req_records_affected; /* count of records affected by the last statement */
2002-06-30 12:22:51 +02:00
USHORT req_view_flags; /* special flags for virtual ops on views */
jrd_rel* req_top_view_store; /* the top view in store(), if any */
jrd_rel* req_top_view_modify; /* the top view in modify(), if any */
jrd_rel* req_top_view_erase; /* the top view in erase(), if any */
2002-06-30 12:22:51 +02:00
jrd_nod* req_top_node; /* top of execution tree */
jrd_nod* req_next; /* next node for execution */
Firebird::Array<class Rsb*> req_fors; /* Vector of for loops, if any */
struct vec* req_cursors; /* Vector of named cursors, if any */
Firebird::Array<jrd_nod*> req_invariants; /* Vector of invariant nodes, if any */
2001-05-23 15:26:42 +02:00
USHORT req_label; /* label for leave */
ULONG req_flags; /* misc request flags */
struct sav *req_proc_sav_point; /* procedure savepoint list */
ULONG req_timestamp; /* Start time of request */
2003-08-22 12:56:55 +02:00
enum req_ta {
req_trigger_insert = 1,
req_trigger_update = 2,
req_trigger_delete = 3
} req_trigger_action; /* action that caused trigger to fire */
2003-08-22 12:56:55 +02:00
enum req_s {
2001-05-23 15:26:42 +02:00
req_evaluate,
2001-12-24 03:51:06 +01:00
req_return,
req_receive,
req_send,
req_proceed,
req_sync,
req_unwind
} req_operation; /* operation for next node */
status_xcp req_last_xcp; /* last known exception */
2001-12-24 03:51:06 +01:00
rpb req_rpb[1]; /* record parameter blocks */
};
typedef jrd_req* JRD_REQ; // CVC: Scheduled for termination, don't use the uppercase type!!!
2001-05-23 15:26:42 +02:00
// Size of request without rpb items at the tail. Used to calculate impure area size
#define REQ_SIZE (sizeof (jrd_req) - sizeof (rpb))
2001-05-23 15:26:42 +02:00
/* Flags for req_flags */
#define req_active 0x1L
#define req_stall 0x2L
#define req_leave 0x4L
#ifdef SCROLLABLE_CURSORS
#define req_async_processing 0x8L
#endif
#define req_null 0x10L
#define req_broken 0x20L
#define req_abort 0x40L
#define req_internal 0x80L
#define req_warning 0x100L
#define req_in_use 0x200L
#define req_sys_trigger 0x400L /* request is a system trigger */
#define req_count_records 0x800L /* count records accessed */
#define req_proc_fetch 0x1000L /* Fetch from procedure in progress */
#define req_ansi_any 0x2000L /* Request is processing ANSI ANY */
#define req_same_tx_upd 0x4000L /* record was updated by same transaction */
#define req_ansi_all 0x8000L /* Request is processing ANSI ANY */
#define req_ansi_not 0x10000L /* Request is processing ANSI ANY */
#define req_reserved 0x20000L /* Request reserved for client */
#define req_ignore_perm 0x40000L /* ignore permissions checks */
#define req_fetch_required 0x80000L /* need to fetch next record */
#define req_error_handler 0x100000L /* looper is called to handle error */
#define req_clone_data_from_default_clause \
0x200000L /* This flag is marked in the
** req_flags if and only if the
** the column that was created or
** added as "DEFAULT xx NOT NULL"
** and no data has been
** inserted/updated to the column.
** The data of this column was
** cloned from the default clause.
*/
#define req_blr_version4 0x400000L /* Request is of blr_version4 */
/* Mask for flags preserved in a clone of a request */
#define REQ_FLAGS_CLONE_MASK (req_sys_trigger | req_internal | req_ignore_perm | req_blr_version4)
/* Mask for flags preserved on initialization of a request */
#define REQ_FLAGS_INIT_MASK (req_in_use | req_internal | req_sys_trigger | req_ignore_perm | req_blr_version4)
2002-06-30 12:22:51 +02:00
/* Flags for req_view_flags */
enum {
req_first_store_return = 0x1,
req_first_modify_return = 0x2,
req_first_erase_return = 0x4
};
2001-05-23 15:26:42 +02:00
// Resources
2001-05-23 15:26:42 +02:00
class Resource : public pool_alloc<type_rsc>
2001-12-24 03:51:06 +01:00
{
public:
enum rsc_s
{
rsc_relation,
rsc_procedure,
rsc_index
};
Resource* rsc_next; /* Next resource in request */
jrd_rel* rsc_rel; /* Relation block */
jrd_prc* rsc_prc; /* Relation block */
USHORT rsc_id; /* Id of parent */
2001-05-23 15:26:42 +02:00
enum rsc_s rsc_type;
2001-12-24 03:51:06 +01:00
};
2001-05-23 15:26:42 +02:00
/* Index lock block */
2001-12-24 03:51:06 +01:00
class idl : public pool_alloc<type_idl>
2001-05-23 15:26:42 +02:00
{
2001-12-24 03:51:06 +01:00
public:
idl* idl_next; /* Next index lock block for relation */
lck* idl_lock; /* Lock block */
jrd_rel* idl_relation; /* Parent relation */
2001-05-23 15:26:42 +02:00
USHORT idl_id; /* Index id */
USHORT idl_count; /* Use count */
2001-12-24 03:51:06 +01:00
};
typedef idl *IDL;
2001-05-23 15:26:42 +02:00
/* Access items */
2001-12-24 03:51:06 +01:00
class acc : public pool_alloc<type_acc>
2001-05-23 15:26:42 +02:00
{
2001-12-24 03:51:06 +01:00
public:
acc* acc_next;
2001-05-23 15:26:42 +02:00
TEXT* acc_security_name; /* WRITTEN into by SCL_get_class() */
SLONG acc_view_id;
2003-02-13 11:11:35 +01:00
const TEXT* acc_trg_name;
const TEXT* acc_prc_name;
const TEXT* acc_name;
const TEXT* acc_type;
2001-05-23 15:26:42 +02:00
USHORT acc_mask;
2001-12-24 03:51:06 +01:00
};
typedef acc *ACC;
2001-05-23 15:26:42 +02:00
#endif // JRD_REQ_H