mirror of
https://github.com/louisrubet/rpn
synced 2025-01-04 11:01:35 +01:00
ostring and symbol work
This commit is contained in:
parent
e810a0fbe4
commit
d32a1cf701
2 changed files with 62 additions and 29 deletions
52
src/parse.h
52
src/parse.h
|
@ -199,24 +199,38 @@ static bool get_symbol(const string& entry, object*& obj, unsigned int& obj_len)
|
|||
{
|
||||
bool ret = false;
|
||||
int entry_len = entry.size();
|
||||
if (entry_len>1 && entry[0]=='\'')
|
||||
if (entry_len>=1 && entry[0]=='\'')
|
||||
{
|
||||
if (entry_len == 1)
|
||||
{
|
||||
// total object length
|
||||
obj_len = sizeof(symbol) + 1;
|
||||
|
||||
// allocate object
|
||||
obj = (symbol*)malloc(obj_len);
|
||||
|
||||
//set it
|
||||
((symbol*)obj)->set("", 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
int naked_entry_len;
|
||||
|
||||
// entry length without prefix / postfix
|
||||
naked_entry_len = entry[entry_len-1]=='\''?(entry_len-3):(entry_len-2);
|
||||
naked_entry_len = entry[entry_len-1]=='\''?(entry_len-2):(entry_len-1);
|
||||
|
||||
// total object length
|
||||
obj_len = sizeof(symbol) + naked_entry_len;
|
||||
obj_len = sizeof(symbol) + naked_entry_len + 1;
|
||||
|
||||
// allocate object
|
||||
obj = (object*)malloc(obj_len);
|
||||
obj = (symbol*)malloc(obj_len);
|
||||
|
||||
// set it
|
||||
((symbol*)obj)->set(&entry[1], naked_entry_len);
|
||||
|
||||
((symbol*)obj)->set(entry.substr(1, naked_entry_len).c_str(), naked_entry_len);
|
||||
}
|
||||
ret = true;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -224,24 +238,38 @@ static bool get_string(const string& entry, object*& obj, unsigned int& obj_len)
|
|||
{
|
||||
bool ret = false;
|
||||
int entry_len = entry.size();
|
||||
if (entry_len>1 && entry[0]=='"')
|
||||
if (entry_len>=1 && entry[0]=='"')
|
||||
{
|
||||
if (entry_len == 1)
|
||||
{
|
||||
// total object length
|
||||
obj_len = sizeof(ostring) + 1;
|
||||
|
||||
// allocate object
|
||||
obj = (ostring*)malloc(obj_len);
|
||||
|
||||
//set it
|
||||
((ostring*)obj)->set("", 0);
|
||||
}
|
||||
else
|
||||
{
|
||||
int naked_entry_len;
|
||||
|
||||
// entry length without prefix / postfix
|
||||
naked_entry_len = entry[entry_len-1]=='"'?(entry_len-3):(entry_len-2);
|
||||
naked_entry_len = entry[entry_len-1]=='"'?(entry_len-2):(entry_len-1);
|
||||
|
||||
// total object length
|
||||
obj_len = sizeof(ostring) + naked_entry_len;
|
||||
obj_len = sizeof(ostring) + naked_entry_len + 1;
|
||||
|
||||
// allocate object
|
||||
obj = (object*)malloc(obj_len);
|
||||
obj = (ostring*)malloc(obj_len);
|
||||
|
||||
// set it
|
||||
((ostring*)obj)->set(&entry[1], naked_entry_len);
|
||||
|
||||
((ostring*)obj)->set(entry.substr(1, naked_entry_len).c_str(), naked_entry_len);
|
||||
}
|
||||
ret = true;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
13
src/rpn.cpp
13
src/rpn.cpp
|
@ -176,6 +176,7 @@ struct ostring : public object
|
|||
_type = cmd_string;
|
||||
if (value != NULL)
|
||||
{
|
||||
if (len>0)
|
||||
(void)memcpy(_value, value, len);
|
||||
_value[len] = 0;
|
||||
_len = len;
|
||||
|
@ -197,6 +198,7 @@ struct oprogram : public object
|
|||
_type = cmd_program;
|
||||
if (value != NULL)
|
||||
{
|
||||
if (len>0)
|
||||
(void)memcpy(_value, value, len);
|
||||
_value[len] = 0;
|
||||
_len = len;
|
||||
|
@ -219,6 +221,7 @@ struct symbol : public object
|
|||
_auto_eval = false;
|
||||
if (value != NULL)
|
||||
{
|
||||
if (len>0)
|
||||
(void)memcpy(_value, value, len);
|
||||
_value[len] = 0;
|
||||
_len = len;
|
||||
|
@ -242,6 +245,7 @@ struct keyword : public object
|
|||
_fn = fn;
|
||||
if (value != NULL)
|
||||
{
|
||||
if (len>0)
|
||||
(void)memcpy(_value, value, len);
|
||||
_value[len] = 0;
|
||||
_len = len;
|
||||
|
@ -271,6 +275,7 @@ struct branch : public object
|
|||
arg_bool = 0;
|
||||
if (value != NULL)
|
||||
{
|
||||
if (len>0)
|
||||
(void)memcpy(_value, value, len);
|
||||
_value[len] = 0;
|
||||
_len = len;
|
||||
|
@ -321,17 +326,17 @@ void object::show(ostream& stream)
|
|||
}
|
||||
break;
|
||||
case cmd_string:
|
||||
stream << "\"" << *((ostring*)this)->_value << "\"";
|
||||
stream << "\"" << ((ostring*)this)->_value << "\"";
|
||||
break;
|
||||
case cmd_program:
|
||||
stream << "<< " << *((oprogram*)this)->_value << " >>";
|
||||
stream << "<< " << ((oprogram*)this)->_value << " >>";
|
||||
break;
|
||||
case cmd_symbol:
|
||||
stream << "'" << *((symbol*)this)->_value << "'";
|
||||
stream << "'" << ((symbol*)this)->_value << "'";
|
||||
break;
|
||||
case cmd_keyword:
|
||||
case cmd_branch:
|
||||
stream << *((keyword*)this)->_value;
|
||||
stream << ((keyword*)this)->_value;
|
||||
break;
|
||||
default:
|
||||
stream << "< unknown object representation >";
|
||||
|
|
Loading…
Reference in a new issue