8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-28 02:43:03 +01:00
firebird-mirror/src/dsql/metd_proto.h
asfernandes 570b6cd4b4 1) CORE-645 and CORE-745: Database triggers
2) CORE-711: Make syntax for "CREATE TRIGGER" compliant with SQL2003
2006-11-05 18:30:36 +00:00

70 lines
2.9 KiB
C++

/*
* PROGRAM: Dynamic SQL runtime support
* MODULE: metd_proto.h
* DESCRIPTION: Prototype Header file for metd.epp
* This is a DSQL private header file. It is not included
* by anything but DSQL itself.
*
* 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): ______________________________________.
*/
#ifndef DSQL_METD_PROTO_H
#define DSQL_METD_PROTO_H
#include "../common/classes/GenericMap.h"
#include "../common/classes/MetaName.h"
#include "../common/classes/fb_pair.h"
typedef Firebird::Pair<Firebird::Full<Firebird::MetaName, Firebird::MetaName> > MetaNamePair;
typedef Firebird::GenericMap<MetaNamePair> MetaNamePairMap;
// forward declarations
class dsql_req;
class dsql_str;
void METD_drop_collation(dsql_req*, const dsql_str*);
void METD_drop_function(dsql_req*, const dsql_str*);
void METD_drop_procedure(dsql_req*, const dsql_str*);
void METD_drop_relation(dsql_req*, const dsql_str*);
dsql_intlsym* METD_get_charset(dsql_req*, USHORT, const char* name); // UTF-8
USHORT METD_get_charset_bpc(dsql_req*, SSHORT);
Firebird::MetaName METD_get_charset_name (dsql_req*, SSHORT);
dsql_intlsym* METD_get_collation(dsql_req*, const dsql_str*, USHORT charset_id);
USHORT METD_get_col_default(dsql_req*, const char*, const char*, bool*, TEXT*, USHORT);
dsql_str* METD_get_default_charset(dsql_req*);
USHORT METD_get_domain(dsql_req*, class dsql_fld*, const char* name); // UTF-8
USHORT METD_get_domain_default(dsql_req*, const TEXT*, bool*, TEXT*, USHORT);
bool METD_get_exception(dsql_req*, const dsql_str*);
dsql_udf* METD_get_function(dsql_req*, const dsql_str*);
dsql_nod* METD_get_primary_key(dsql_req*, const dsql_str*);
dsql_prc* METD_get_procedure(dsql_req*, const dsql_str*);
dsql_rel* METD_get_relation(dsql_req*, const dsql_str*);
bool METD_get_trigger(dsql_req*, const dsql_str*, dsql_str**, USHORT*);
bool METD_get_type(dsql_req*, const dsql_str*, char*, SSHORT*);
dsql_rel* METD_get_view_base(dsql_req* request,
const char* view_name, // UTF-8
MetaNamePairMap& fields);
dsql_rel* METD_get_view_relation(dsql_req* request,
const char* view_name, // UTF-8
const char* relation_or_alias, // UTF-8
USHORT level);
#endif // DSQL_METD_PROTO_H