8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-26 08:03:03 +01:00
firebird-mirror/src/jrd/DebugInterface.cpp

157 lines
3.4 KiB
C++
Raw Normal View History

/*
* 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 Vlad Horsun
* for the Firebird Open Source RDBMS project.
*
* Copyright (c) 2006 Vlad Horsun <hvlad@users.sourceforge.net>
* and all contributors signed below.
*
* All Rights Reserved.
* Contributor(s): ______________________________________.
*/
#include "firebird.h"
#include "../jrd/Attachment.h"
#include "../jrd/DebugInterface.h"
#include "../jrd/blb_proto.h"
using namespace Jrd;
using namespace Firebird;
2008-03-06 10:36:45 +01:00
const UCHAR CURRENT_DBG_INFO_VERSION = UCHAR(1);
void DBG_parse_debug_info(thread_db* tdbb, bid* blob_id, Firebird::DbgInfo& dbgInfo)
{
Jrd::Attachment* attachment = tdbb->getAttachment();
blb* blob = BLB_open(tdbb, attachment->getSysTransaction(), blob_id);
2009-08-05 14:31:54 +02:00
const ULONG length = blob->blb_length;
fb_assert(length < MAX_USHORT); // CVC: Otherwise, we'll overflow the function below.
Firebird::HalfStaticArray<UCHAR, 128> tmp;
UCHAR* temp = tmp.getBuffer(length);
BLB_get_data(tdbb, blob, temp, length);
DBG_parse_debug_info(length, temp, dbgInfo);
}
void DBG_parse_debug_info(USHORT length, const UCHAR* data, Firebird::DbgInfo& dbgInfo)
{
2008-03-06 10:36:45 +01:00
const UCHAR* const end = data + length;
bool bad_format = false;
2008-12-18 11:47:25 +01:00
if ((*data++ != fb_dbg_version) || (end[-1] != fb_dbg_end) ||
2008-03-06 10:36:45 +01:00
(*data++ != CURRENT_DBG_INFO_VERSION))
{
bad_format = true;
}
2008-12-05 02:20:14 +01:00
while (!bad_format && (data < end))
{
switch (*data++)
{
case fb_dbg_map_src2blr:
2008-01-16 09:31:31 +01:00
{
if (data + 6 > end) {
bad_format = true;
break;
}
2008-01-16 09:31:31 +01:00
MapBlrToSrcItem i;
i.mbs_src_line = *data++;
i.mbs_src_line |= *data++ << 8;
2008-01-16 09:31:31 +01:00
i.mbs_src_col = *data++;
i.mbs_src_col |= *data++ << 8;
2008-01-16 09:31:31 +01:00
i.mbs_offset = *data++;
i.mbs_offset |= *data++ << 8;
2008-01-16 09:31:31 +01:00
dbgInfo.blrToSrc.add(i);
}
break;
case fb_dbg_map_varname:
2008-01-16 09:31:31 +01:00
{
if (data + 3 > end) {
bad_format = true;
break;
}
2008-01-16 09:31:31 +01:00
// variable number
USHORT index = *data++;
index |= *data++;
2008-01-16 09:31:31 +01:00
// variable name string length
USHORT length = *data++;
2008-01-16 09:31:31 +01:00
if (data + length > end) {
bad_format = true;
break;
}
2008-01-16 09:31:31 +01:00
dbgInfo.varIndexToName.put(index, MetaName((const TEXT*) data, length));
2008-01-16 09:31:31 +01:00
// variable name string
data += length;
}
break;
case fb_dbg_map_argument:
2008-01-16 09:31:31 +01:00
{
if (data + 4 > end) {
bad_format = true;
break;
}
2008-01-16 09:31:31 +01:00
ArgumentInfo info;
2008-01-16 09:31:31 +01:00
// argument type
info.type = *data++;
2008-01-16 09:31:31 +01:00
// argument number
info.index = *data++;
info.index |= *data++;
2008-01-16 09:31:31 +01:00
// argument name string length
USHORT length = *data++;
2008-01-16 09:31:31 +01:00
if (data + length > end) {
bad_format = true;
break;
}
2008-01-16 09:31:31 +01:00
dbgInfo.argInfoToName.put(info, MetaName((const TEXT*) data, length));
2008-01-16 09:31:31 +01:00
// variable name string
data += length;
}
break;
case fb_dbg_end:
if (data != end)
bad_format = true;
2008-01-16 09:31:31 +01:00
break;
default:
bad_format = true;
}
}
2008-03-06 10:36:45 +01:00
if (bad_format || data != end)
{
dbgInfo.clear();
ERR_post_warning(Arg::Warning(isc_bad_debug_format));
}
}