8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-31 09:23:03 +01:00
firebird-mirror/src/jrd/RecordBuffer.cpp
dimitr 11495a55fb Refactored the whole RSB stuff into classes. They're inside the /recsrc sub-directory now.
Fixed the layering for WITH LOCK and (partially) ANY/ALL predicates.
Cleaned up the outdated code that never worked (mapping DISTINCT to an index, some VMS remainings).
Wiped out a lot of the pre-ODS11 optimizer logic. Some minor adjustments there.
Re-implemented the full outer join from scratch. This resolves CORE-2678 (full outer join cannot use available indices).
Resolved CORE-2796: DB_KEY is always zero for external tables.
Implemented the core part of the scrollable PSQL cursors. Implementation is still incomplete, but ready for testing.
Some other changes I don't recall at the moment ;-)

WARNING! The engine may be unstable. Please email me about any issues found.
2009-12-09 18:45:44 +00:00

76 lines
1.8 KiB
C++

/*
* The contents of this file are subject to the Initial
* Developer's 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.ibphoenix.com/main.nfs?a=ibphoenix&page=ibp_idpl.
*
* Software distributed under the License is distributed AS IS,
* 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 Dmitry Yemanov
* for the Firebird Open Source RDBMS project.
*
* Copyright (c) 2006 Dmitry Yemanov <dimitr@users.sf.net>
* and all contributors signed below.
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*/
#include "firebird.h"
#include "../jrd/gdsassert.h"
#include "../jrd/jrd.h"
#include "../jrd/req.h"
#include "../jrd/RecordBuffer.h"
const char* const SCRATCH = "fb_recbuf_";
using namespace Jrd;
RecordBuffer::RecordBuffer(MemoryPool& pool, const Format* format)
: length(format->fmt_length), count(0), filled(false)
{
space = FB_NEW(pool) TempSpace(pool, SCRATCH);
record = FB_NEW_RPT(pool, length) Record(pool);
record->rec_format = format;
record->rec_length = (USHORT) length;
}
RecordBuffer::~RecordBuffer()
{
delete record;
delete space;
}
offset_t RecordBuffer::store(const Record* new_record)
{
fb_assert(new_record->rec_length == length);
fb_assert(!filled);
space->write(count * length, new_record->rec_data, length);
return count++;
}
bool RecordBuffer::fetch(offset_t position, Record* to_record)
{
fb_assert(to_record->rec_length == length);
filled = true;
if (position >= count)
{
return false;
}
space->read(position * length, to_record->rec_data, length);
return true;
}