2015-06-11 12:09:10 +00:00
|
|
|
/*
|
|
|
|
* $Id$
|
|
|
|
*
|
2018-02-21 10:11:39 +00:00
|
|
|
Copyright (c) 2014-2018 Chung, Hyung-Hwan. All rights reserved.
|
2015-06-11 12:09:10 +00:00
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
1. Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR
|
|
|
|
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WAfRRANTIES
|
|
|
|
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
#include "moo-prv.h"
|
2015-06-11 12:09:10 +00:00
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
void moo_dumpsymtab (moo_t* moo)
|
2015-06-11 12:09:10 +00:00
|
|
|
{
|
2017-01-09 09:54:49 +00:00
|
|
|
moo_oow_t i;
|
|
|
|
moo_oop_char_t symbol;
|
2015-06-11 12:09:10 +00:00
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG0 (moo, "--------------------------------------------\n");
|
2018-12-19 16:57:16 +00:00
|
|
|
MOO_DEBUG1 (moo, "MOO Symbol Table %zu\n", MOO_OBJ_GET_SIZE(moo->symtab->bucket));
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG0 (moo, "--------------------------------------------\n");
|
2015-06-11 12:09:10 +00:00
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
for (i = 0; i < MOO_OBJ_GET_SIZE(moo->symtab->bucket); i++)
|
2015-06-11 12:09:10 +00:00
|
|
|
{
|
2018-12-19 15:47:52 +00:00
|
|
|
symbol = (moo_oop_char_t)MOO_OBJ_GET_OOP_VAL(moo->symtab->bucket, i);
|
2018-03-27 09:32:49 +00:00
|
|
|
if ((moo_oop_t)symbol != moo->_nil)
|
2015-06-11 12:09:10 +00:00
|
|
|
{
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG2 (moo, " %07zu %O\n", i, symbol);
|
2015-06-11 12:09:10 +00:00
|
|
|
}
|
|
|
|
}
|
2016-06-05 18:37:28 +00:00
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG0 (moo, "--------------------------------------------\n");
|
2015-06-11 12:09:10 +00:00
|
|
|
}
|
|
|
|
|
2017-05-20 02:27:48 +00:00
|
|
|
void moo_dumpdic (moo_t* moo, moo_oop_dic_t dic, const moo_bch_t* title)
|
2015-06-11 12:09:10 +00:00
|
|
|
{
|
2017-05-16 15:01:31 +00:00
|
|
|
moo_oow_t i;
|
2017-01-09 09:54:49 +00:00
|
|
|
moo_oop_association_t ass;
|
2015-06-11 12:09:10 +00:00
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG0 (moo, "--------------------------------------------\n");
|
|
|
|
MOO_DEBUG2 (moo, "%s %zu\n", title, MOO_OBJ_GET_SIZE(dic->bucket));
|
|
|
|
MOO_DEBUG0 (moo, "--------------------------------------------\n");
|
2015-06-11 12:09:10 +00:00
|
|
|
|
2017-01-09 09:54:49 +00:00
|
|
|
for (i = 0; i < MOO_OBJ_GET_SIZE(dic->bucket); i++)
|
2015-06-11 12:09:10 +00:00
|
|
|
{
|
2018-12-19 15:47:52 +00:00
|
|
|
ass = (moo_oop_association_t)MOO_OBJ_GET_OOP_VAL(dic->bucket, i);
|
2017-01-09 09:54:49 +00:00
|
|
|
if ((moo_oop_t)ass != moo->_nil)
|
2015-06-11 12:09:10 +00:00
|
|
|
{
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG2 (moo, " %07zu %O\n", i, ass->key);
|
2015-06-11 12:09:10 +00:00
|
|
|
}
|
|
|
|
}
|
2017-01-09 09:54:49 +00:00
|
|
|
MOO_DEBUG0 (moo, "--------------------------------------------\n");
|
2015-06-11 12:09:10 +00:00
|
|
|
}
|
2019-07-07 15:24:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* TODO: moo_loaddbginfofromimage() -> load debug information from compiled image?
|
|
|
|
moo_storedbginfotoimage()? -> store debug information to compiled image?
|
|
|
|
moo_compactdbginfo()? -> compact debug information by scaning dbginfo data. find class and method. if not found, drop the portion.
|
|
|
|
*/
|
|
|
|
|
|
|
|
int moo_initdbginfo (moo_t* moo, moo_oow_t capa)
|
|
|
|
{
|
2019-07-08 07:51:53 +00:00
|
|
|
moo_dbginfo_t* tmp;
|
2019-07-07 15:24:27 +00:00
|
|
|
|
2019-07-08 07:51:53 +00:00
|
|
|
if (capa < MOO_SIZEOF(*tmp)) capa = MOO_SIZEOF(*tmp);
|
2019-07-07 15:24:27 +00:00
|
|
|
|
2019-07-08 07:51:53 +00:00
|
|
|
tmp = (moo_dbginfo_t*)moo_callocmem(moo, capa);
|
|
|
|
if (!tmp) return -1;
|
2019-07-07 15:24:27 +00:00
|
|
|
|
2019-07-08 07:51:53 +00:00
|
|
|
tmp->_capa = capa;
|
|
|
|
tmp->_len = MOO_SIZEOF(*tmp);
|
|
|
|
tmp->_last_class = 0;
|
|
|
|
tmp->_last_file = 0;
|
|
|
|
|
|
|
|
moo->dbginfo = tmp;
|
2019-07-07 15:24:27 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void moo_finidbginfo (moo_t* moo)
|
|
|
|
{
|
|
|
|
if (moo->dbginfo)
|
|
|
|
{
|
|
|
|
moo_freemem (moo, moo->dbginfo);
|
|
|
|
moo->dbginfo = MOO_NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
static MOO_INLINE moo_uint8_t* secure_dbginfo_space (moo_t* moo, moo_oow_t req_bytes)
|
2019-07-08 07:51:53 +00:00
|
|
|
{
|
|
|
|
if (moo->dbginfo->_capa - moo->dbginfo->_len < req_bytes)
|
|
|
|
{
|
|
|
|
moo_dbginfo_t* tmp;
|
|
|
|
moo_oow_t newcapa;
|
|
|
|
|
|
|
|
newcapa = moo->dbginfo->_len + req_bytes;
|
|
|
|
newcapa = MOO_ALIGN_POW2(newcapa, 65536); /* TODO: make the align value configurable */
|
|
|
|
tmp = moo_reallocmem(moo, moo->dbginfo, newcapa);
|
2019-07-08 15:41:57 +00:00
|
|
|
if (!tmp) return MOO_NULL;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
|
|
|
moo->dbginfo = tmp;
|
|
|
|
moo->dbginfo->_capa = newcapa;
|
|
|
|
}
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
return &((moo_uint8_t*)moo->dbginfo)[moo->dbginfo->_len];
|
2019-07-08 07:51:53 +00:00
|
|
|
}
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
int moo_addfiletodbginfo (moo_t* moo, const moo_ooch_t* file_name, moo_oow_t* start_offset)
|
2019-07-08 07:51:53 +00:00
|
|
|
{
|
|
|
|
moo_oow_t name_len, name_bytes, name_bytes_aligned, req_bytes;
|
2019-07-08 15:41:57 +00:00
|
|
|
moo_dbginfo_file_t* di;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-09 09:59:38 +00:00
|
|
|
if (!moo->dbginfo)
|
|
|
|
{
|
|
|
|
if (start_offset) *start_offset = MOO_NULL;
|
|
|
|
return 0; /* debug information is disabled*/
|
|
|
|
}
|
|
|
|
|
|
|
|
if (moo->dbginfo->_last_file > 0)
|
|
|
|
{
|
|
|
|
moo_oow_t offset = moo->dbginfo->_last_fiel;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
di = &((moo_uint8_t*)moo->dbginfo)[offset];
|
|
|
|
if (moo_comp_oocstr(di + 1, file_name) == 0)
|
|
|
|
{
|
|
|
|
if (start_offset) *start_offset = offset;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
offset = di->_next;
|
|
|
|
}
|
|
|
|
while (offset > 0);
|
|
|
|
}
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
name_len = moo_count_oocstr(file_name);
|
2019-07-09 09:59:38 +00:00
|
|
|
name_bytes = (name_len + 1) * MOO_SIZEOF(*file_name);
|
2019-07-08 07:51:53 +00:00
|
|
|
name_bytes_aligned = MOO_ALIGN_POW2(name_bytes, MOO_SIZEOF_OOW_T);
|
2019-07-08 15:41:57 +00:00
|
|
|
req_bytes = MOO_SIZEOF(moo_dbginfo_file_t) + name_bytes_aligned;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
di = (moo_dbginfo_file_t*)secure_dbginfo_space(moo, req_bytes);
|
|
|
|
if (!di) return -1;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
di->_type = MOO_DBGINFO_MAKE_TYPE(MOO_DBGINFO_TYPE_CODE_FILE, 0);
|
2019-07-09 09:59:38 +00:00
|
|
|
di->_len = req_bytes;
|
2019-07-08 15:41:57 +00:00
|
|
|
di->_next = moo->dbginfo->_last_file;
|
2019-07-09 09:59:38 +00:00
|
|
|
moo_copy_oocstr (di + 1, name_len + 1, file_name);
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
moo->dbginfo->_last_file = moo->dbginfo->_len;
|
2019-07-08 07:51:53 +00:00
|
|
|
moo->dbginfo->_len += req_bytes;
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
if (start_offset) *start_offset = moo->dbginfo->_last_file;
|
2019-07-08 07:51:53 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
int moo_addclasstodbginfo (moo_t* moo, const moo_ooch_t* class_name, moo_oow_t file_offset, moo_oow_t file_line, moo_oow_t* start_offset)
|
2019-07-08 07:51:53 +00:00
|
|
|
{
|
|
|
|
moo_oow_t name_len, name_bytes, name_bytes_aligned, req_bytes;
|
2019-07-08 15:41:57 +00:00
|
|
|
moo_dbginfo_class_t* di;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
|
|
|
if (!moo->dbginfo) return 0; /* debug information is disabled*/
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
name_len = moo_count_oocstr(class_name);
|
2019-07-09 09:59:38 +00:00
|
|
|
name_bytes = (name_len + 1) * MOO_SIZEOF(*class_name);
|
2019-07-08 07:51:53 +00:00
|
|
|
name_bytes_aligned = MOO_ALIGN_POW2(name_bytes, MOO_SIZEOF_OOW_T);
|
2019-07-08 15:41:57 +00:00
|
|
|
req_bytes = MOO_SIZEOF(moo_dbginfo_class_t) + name_bytes_aligned;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
di = (moo_dbginfo_class_t*)secure_dbginfo_space(moo, req_bytes);
|
|
|
|
if (!di) return -1;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
di->_type = MOO_DBGINFO_MAKE_TYPE(MOO_DBGINFO_TYPE_CODE_CLASS, 0);
|
2019-07-09 09:59:38 +00:00
|
|
|
di->_len = req_bytes;
|
2019-07-08 15:41:57 +00:00
|
|
|
di->_next = moo->dbginfo->_last_class;
|
|
|
|
di->_file = file_offset;
|
|
|
|
di->_line = file_line;
|
2019-07-09 09:59:38 +00:00
|
|
|
moo_copy_oocstr (di + 1, name_len + 1, class_name);
|
2019-07-08 07:51:53 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
moo->dbginfo->_last_class = moo->dbginfo->_len;
|
2019-07-08 07:51:53 +00:00
|
|
|
moo->dbginfo->_len += req_bytes;
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
if (start_offset) *start_offset = moo->dbginfo->_last_class;
|
2019-07-08 07:51:53 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
int moo_addmethodtodbginfo (moo_t* moo, moo_oow_t file_offset, moo_oow_t class_offset, const moo_ooch_t* method_name, const moo_oow_t* code_loc_ptr, moo_oow_t code_loc_len)
|
2019-07-07 15:24:27 +00:00
|
|
|
{
|
2019-07-08 15:41:57 +00:00
|
|
|
moo_oow_t name_len, name_bytes, name_bytes_aligned, code_loc_bytes, code_loc_bytes_aligned, req_bytes;
|
|
|
|
moo_dbginfo_method_t* di;
|
2019-07-08 07:51:53 +00:00
|
|
|
|
|
|
|
if (!moo->dbginfo) return 0; /* debug information is disabled*/
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
name_len = moo_count_oocstr(method_name);
|
2019-07-09 09:59:38 +00:00
|
|
|
name_bytes = (name_len + 1) * MOO_SIZEOF(*method_name);
|
2019-07-08 07:51:53 +00:00
|
|
|
name_bytes_aligned = MOO_ALIGN_POW2(name_bytes, MOO_SIZEOF_OOW_T);
|
2019-07-08 15:41:57 +00:00
|
|
|
code_loc_bytes = code_loc_len * MOO_SIZEOF(*code_loc_ptr);
|
|
|
|
code_loc_bytes_aligned = MOO_ALIGN_POW2(code_loc_bytes, MOO_SIZEOF_OOW_T);
|
|
|
|
req_bytes = MOO_SIZEOF(moo_dbginfo_method_t) + name_bytes_aligned + code_loc_bytes_aligned;
|
|
|
|
|
|
|
|
di = (moo_dbginfo_method_t*)secure_dbginfo_space(moo, req_bytes);
|
|
|
|
if (!di) return -1;
|
|
|
|
|
|
|
|
di->_type = MOO_DBGINFO_MAKE_TYPE(MOO_DBGINFO_TYPE_CODE_METHOD, 0);
|
2019-07-09 09:59:38 +00:00
|
|
|
di->_len = req_bytes;
|
|
|
|
di->_next = moo->dbginfo->_last_method;
|
2019-07-08 15:41:57 +00:00
|
|
|
di->_file = file_offset;
|
|
|
|
di->_class = class_offset;
|
|
|
|
di->code_loc_len = code_loc_len;
|
|
|
|
|
2019-07-09 09:59:38 +00:00
|
|
|
moo_copy_oocstr (di + 1, name_len + 1, method_name);
|
2019-07-08 15:41:57 +00:00
|
|
|
MOO_MEMCPY ((moo_uint8_t*)(di + 1) + name_bytes_aligned, code_loc_ptr, code_loc_bytes);
|
2019-07-09 09:59:38 +00:00
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
moo->dbginfo->_last_method = moo->dbginfo->_len;
|
2019-07-08 07:51:53 +00:00
|
|
|
moo->dbginfo->_len += req_bytes;
|
|
|
|
|
2019-07-08 15:41:57 +00:00
|
|
|
/*if (start_offset) *start_offset = moo->dbginfo->_last_method;*/
|
2019-07-07 15:24:27 +00:00
|
|
|
return 0;
|
2019-07-08 07:51:53 +00:00
|
|
|
}
|