mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-31 13:23:02 +01:00
e6909de7f7
Also, surfaced scrollability for PSQL cursors (without internal support yet).
130 lines
3.2 KiB
C++
130 lines
3.2 KiB
C++
/*
|
|
* PROGRAM: JRD Access Method
|
|
* MODULE: exe_proto.h
|
|
* DESCRIPTION: Prototype header file for exe.cpp
|
|
*
|
|
* 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 JRD_EXE_PROTO_H
|
|
#define JRD_EXE_PROTO_H
|
|
|
|
#include "../jrd/cmp_proto.h"
|
|
|
|
namespace Jrd {
|
|
class jrd_req;
|
|
class jrd_nod;
|
|
class jrd_tra;
|
|
}
|
|
|
|
void EXE_assignment(Jrd::thread_db*, Jrd::jrd_nod*);
|
|
void EXE_assignment(Jrd::thread_db* tdbb, Jrd::jrd_nod* to, dsc* from_desc, bool from_null,
|
|
Jrd::jrd_nod* missing_node, Jrd::jrd_nod* missing2_node);
|
|
void EXE_execute_db_triggers(Jrd::thread_db*, Jrd::jrd_tra*, enum Jrd::jrd_req::req_ta);
|
|
void EXE_execute_ddl_triggers(Jrd::thread_db* tdbb, Jrd::jrd_tra* transaction,
|
|
bool preTriggers, int action);
|
|
Jrd::jrd_nod* EXE_looper(Jrd::thread_db* tdbb, Jrd::jrd_req* request, Jrd::jrd_nod* in_node);
|
|
Jrd::jrd_req* EXE_find_request(Jrd::thread_db*, Jrd::jrd_req*, bool);
|
|
void EXE_receive(Jrd::thread_db*, Jrd::jrd_req*, USHORT, USHORT, UCHAR*, bool = false);
|
|
void EXE_send(Jrd::thread_db*, Jrd::jrd_req*, USHORT, USHORT, const UCHAR*);
|
|
void EXE_start(Jrd::thread_db*, Jrd::jrd_req*, Jrd::jrd_tra*);
|
|
void EXE_unwind(Jrd::thread_db*, Jrd::jrd_req*);
|
|
void EXE_verb_cleanup(Jrd::thread_db* tdbb, Jrd::jrd_tra* transaction);
|
|
|
|
namespace Jrd
|
|
{
|
|
// ASF: To make this class MT-safe in SS for v3, it should be AutoCacheRequest::release job to
|
|
// inform CMP that the request is available for subsequent usage.
|
|
class AutoCacheRequest
|
|
{
|
|
public:
|
|
AutoCacheRequest(thread_db* tdbb, USHORT aId, USHORT aWhich)
|
|
: id(aId),
|
|
which(aWhich),
|
|
request(CMP_find_request(tdbb, id, which))
|
|
{
|
|
}
|
|
|
|
~AutoCacheRequest()
|
|
{
|
|
release();
|
|
}
|
|
|
|
public:
|
|
void reset(thread_db* tdbb, USHORT aId, USHORT aWhich)
|
|
{
|
|
release();
|
|
|
|
id = aId;
|
|
which = aWhich;
|
|
request = CMP_find_request(tdbb, id, which);
|
|
}
|
|
|
|
public:
|
|
AutoCacheRequest& operator =(jrd_req* newRequest)
|
|
{
|
|
fb_assert(!request);
|
|
request = newRequest;
|
|
cacheRequest();
|
|
return *this;
|
|
}
|
|
|
|
operator jrd_req*()
|
|
{
|
|
return request;
|
|
}
|
|
|
|
bool operator !() const
|
|
{
|
|
return !request;
|
|
}
|
|
|
|
private:
|
|
inline void release()
|
|
{
|
|
if (request)
|
|
{
|
|
EXE_unwind(JRD_get_thread_data(), request);
|
|
request = NULL;
|
|
}
|
|
}
|
|
|
|
inline void cacheRequest()
|
|
{
|
|
Database* dbb = JRD_get_thread_data()->getDatabase();
|
|
|
|
if (which == IRQ_REQUESTS)
|
|
REQUEST(id) = request;
|
|
else if (which == DYN_REQUESTS)
|
|
DYN_REQUEST(id) = request;
|
|
else
|
|
{
|
|
fb_assert(false);
|
|
}
|
|
}
|
|
|
|
private:
|
|
USHORT id;
|
|
USHORT which;
|
|
jrd_req* request;
|
|
};
|
|
}
|
|
|
|
#endif // JRD_EXE_PROTO_H
|
|
|