2014-09-24 16:55:59 +02:00
|
|
|
void test();
|
|
|
|
|
2014-02-11 11:26:28 +01:00
|
|
|
//
|
|
|
|
void nop()
|
|
|
|
{
|
2015-05-19 17:51:03 +02:00
|
|
|
// nop
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void good_bye()
|
|
|
|
{
|
2015-05-19 17:51:03 +02:00
|
|
|
ERR_CONTEXT(ret_good_bye);
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void help()
|
|
|
|
{
|
2017-04-20 23:06:49 +02:00
|
|
|
// software name
|
2015-05-19 17:51:03 +02:00
|
|
|
cout<<endl;
|
2015-03-02 21:20:56 +01:00
|
|
|
cout<<ATTR_BOLD<<uname<<ATTR_OFF<<endl;
|
2015-05-19 17:51:03 +02:00
|
|
|
cout<<endl;
|
2014-09-24 16:55:59 +02:00
|
|
|
|
2017-04-20 23:06:49 +02:00
|
|
|
// description
|
2017-04-23 15:02:46 +02:00
|
|
|
cout<<description<<endl<<endl;
|
2017-04-20 23:06:49 +02:00
|
|
|
|
2015-05-19 17:51:03 +02:00
|
|
|
// syntax
|
2017-04-20 23:06:49 +02:00
|
|
|
cout<<syntax<<endl;
|
2015-02-23 17:33:05 +01:00
|
|
|
|
|
|
|
// keywords
|
2014-02-12 11:26:26 +01:00
|
|
|
for(unsigned int i=0; i<sizeof(_keywords)/sizeof(_keywords[0]); i++)
|
2015-07-23 13:35:02 +02:00
|
|
|
{
|
2015-05-19 17:51:03 +02:00
|
|
|
if (_keywords[i].comment.size() != 0)
|
2015-07-23 13:35:02 +02:00
|
|
|
{
|
|
|
|
// titles in bold
|
|
|
|
if (_keywords[i].type==cmd_undef)
|
|
|
|
cout<<ATTR_BOLD;
|
|
|
|
// show title or keyword + comment
|
2015-05-19 17:51:03 +02:00
|
|
|
cout<<_keywords[i].name<<"\t"<<_keywords[i].comment<<endl;
|
2015-07-23 13:35:02 +02:00
|
|
|
if (_keywords[i].type==cmd_undef)
|
|
|
|
cout<<ATTR_OFF;
|
|
|
|
}
|
|
|
|
}
|
2015-05-19 17:51:03 +02:00
|
|
|
cout<<endl;
|
|
|
|
|
2017-05-22 17:09:15 +02:00
|
|
|
// show mode
|
2015-05-19 17:51:03 +02:00
|
|
|
cout<<"Current float mode is ";
|
|
|
|
switch(number::s_mode)
|
|
|
|
{
|
|
|
|
case number::std: cout << "'std'"; break;
|
|
|
|
case number::fix: cout << "'fix'"; break;
|
|
|
|
case number::sci: cout << "'sci'"; break;
|
|
|
|
default: cout << "unknown"; break;
|
|
|
|
}
|
2017-05-22 17:09:15 +02:00
|
|
|
cout<<" with "<<number::s_current_precision<<" digits"<<endl;
|
2015-05-19 17:51:03 +02:00
|
|
|
|
2017-05-22 17:09:15 +02:00
|
|
|
// calc precision and rounding mode
|
|
|
|
cout<<"Current floating point precision is "<<(int)s_mpfr_prec<<" bits"<<endl;
|
|
|
|
cout<<"Current rounding mode is '"<<s_mpfr_rnd_str[s_mpfr_rnd]<<"'"<<endl;
|
2015-05-19 17:51:03 +02:00
|
|
|
cout<<endl<<endl;
|
2014-02-11 11:26:28 +01:00
|
|
|
}
|
|
|
|
|
2014-09-05 09:49:39 +02:00
|
|
|
void std()
|
|
|
|
{
|
2017-05-23 14:34:11 +02:00
|
|
|
int precision = -1;
|
|
|
|
|
2015-05-19 17:51:03 +02:00
|
|
|
if (stack_size()>=1)
|
|
|
|
{
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
2017-04-19 23:31:18 +02:00
|
|
|
|
2017-05-23 14:34:11 +02:00
|
|
|
precision = int(((number*)_stack->pop_back())->_value);
|
2015-05-19 17:51:03 +02:00
|
|
|
}
|
2017-04-18 22:53:55 +02:00
|
|
|
|
2017-05-23 14:34:11 +02:00
|
|
|
if (precision != -1)
|
|
|
|
number::s_current_precision = precision;
|
2015-05-19 17:51:03 +02:00
|
|
|
number::s_mode = number::std;
|
|
|
|
|
2017-04-18 22:53:55 +02:00
|
|
|
// format for mpfr_printf
|
|
|
|
stringstream ss;
|
|
|
|
ss << number::s_current_precision;
|
|
|
|
s_mpfr_printf_format = s_mpfr_printf_format_beg + ss.str() + s_mpfr_printf_format_std;
|
2014-09-05 09:49:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void fix()
|
|
|
|
{
|
2015-05-19 17:51:03 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
2014-09-05 09:49:39 +02:00
|
|
|
|
2017-04-21 13:58:44 +02:00
|
|
|
int precision = int(((number*)_stack->pop_back())->_value);
|
2017-04-19 23:31:18 +02:00
|
|
|
number::s_current_precision = int(precision);
|
|
|
|
|
2015-05-19 17:51:03 +02:00
|
|
|
number::s_mode = number::fix;
|
2014-09-06 22:31:01 +02:00
|
|
|
|
2017-04-18 22:53:55 +02:00
|
|
|
// format for mpfr_printf
|
|
|
|
stringstream ss;
|
|
|
|
ss << number::s_current_precision;
|
|
|
|
s_mpfr_printf_format = s_mpfr_printf_format_beg + ss.str() + s_mpfr_printf_format_fix;
|
2014-09-05 09:49:39 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void sci()
|
|
|
|
{
|
2015-05-19 17:51:03 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
2014-09-05 09:49:39 +02:00
|
|
|
|
2017-04-21 13:58:44 +02:00
|
|
|
int precision = int(((number*)_stack->pop_back())->_value);
|
2017-04-19 23:31:18 +02:00
|
|
|
number::s_current_precision = int(precision);
|
|
|
|
|
2015-05-19 17:51:03 +02:00
|
|
|
number::s_mode = number::sci;
|
2014-09-06 22:31:01 +02:00
|
|
|
|
2017-04-18 22:53:55 +02:00
|
|
|
// format for mpfr_printf
|
|
|
|
stringstream ss;
|
|
|
|
ss << number::s_current_precision;
|
|
|
|
s_mpfr_printf_format = s_mpfr_printf_format_beg + ss.str() + s_mpfr_printf_format_sci;
|
2014-09-05 09:49:39 +02:00
|
|
|
}
|
2014-09-24 16:55:59 +02:00
|
|
|
|
|
|
|
void rpn_version()
|
|
|
|
{
|
2017-05-02 10:47:03 +02:00
|
|
|
// allocate and set object
|
|
|
|
unsigned int naked_entry_len = strlen(version);
|
|
|
|
ostring* str = (ostring*)_stack->allocate_back(sizeof(ostring)+naked_entry_len+1, cmd_string);
|
2015-03-02 18:20:21 +01:00
|
|
|
str->set(version, naked_entry_len);
|
2014-09-24 16:55:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void rpn_uname()
|
|
|
|
{
|
2017-05-02 10:47:03 +02:00
|
|
|
// allocate and set object
|
|
|
|
unsigned int naked_entry_len = strlen(uname);
|
|
|
|
ostring* str = (ostring*)_stack->allocate_back(sizeof(ostring)+naked_entry_len+1, cmd_string);
|
2015-03-02 18:20:21 +01:00
|
|
|
str->set(uname, naked_entry_len);
|
2014-09-24 16:55:59 +02:00
|
|
|
}
|
2017-04-22 22:17:51 +02:00
|
|
|
|
|
|
|
void type()
|
|
|
|
{
|
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
|
2017-05-02 17:48:14 +02:00
|
|
|
int type = _stack->back()->_type;
|
2017-04-22 22:17:51 +02:00
|
|
|
if (type < 0 || type >= (int)cmd_max)
|
|
|
|
type = (int)cmd_undef;
|
|
|
|
|
|
|
|
unsigned int string_size = strlen(cmd_type_string[type]);
|
|
|
|
unsigned int size = sizeof(symbol)+string_size+1;
|
2017-05-13 12:20:07 +02:00
|
|
|
symbol* sym = (symbol*)_stack->allocate_back(size, cmd_symbol);
|
2017-05-02 11:39:26 +02:00
|
|
|
sym->set(cmd_type_string[type], string_size, false);
|
2017-04-22 22:17:51 +02:00
|
|
|
}
|
2017-04-23 15:02:46 +02:00
|
|
|
|
|
|
|
void rpn_default()
|
|
|
|
{
|
|
|
|
program::apply_default();
|
|
|
|
}
|
2017-05-22 14:29:55 +02:00
|
|
|
|
|
|
|
void precision()
|
|
|
|
{
|
2017-05-22 17:09:15 +02:00
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_number);
|
|
|
|
|
|
|
|
//set MPFR float precision
|
|
|
|
long prec = mpfr_get_si(((number*)_stack->pop_back())->_value.mpfr, s_mpfr_rnd);
|
|
|
|
if (prec >= 0)
|
2017-05-22 14:29:55 +02:00
|
|
|
{
|
2017-05-22 17:09:15 +02:00
|
|
|
s_mpfr_prec = (mpfr_prec_t)prec;
|
|
|
|
s_mpfr_prec_bytes = mpfr_custom_get_size(prec);
|
2017-05-22 14:29:55 +02:00
|
|
|
}
|
|
|
|
else
|
2017-05-22 17:09:15 +02:00
|
|
|
ERR_CONTEXT(ret_out_of_range);
|
|
|
|
}
|
|
|
|
|
|
|
|
void round()
|
|
|
|
{
|
|
|
|
MIN_ARGUMENTS(1);
|
|
|
|
ARG_MUST_BE_OF_TYPE(0, cmd_string);
|
|
|
|
|
|
|
|
ostring* str = (ostring*)_stack->pop_back();
|
|
|
|
bool done = false;
|
|
|
|
for(int rnd = (int)MPFR_DEF_RND; rnd <= (int)MPFR_RNDA; rnd++)
|
2017-05-22 14:29:55 +02:00
|
|
|
{
|
2017-05-22 17:09:15 +02:00
|
|
|
if (string(s_mpfr_rnd_str[rnd]) == str->_value)
|
|
|
|
{
|
|
|
|
s_mpfr_rnd = (mpfr_rnd_t)rnd;
|
|
|
|
done = true;
|
|
|
|
}
|
2017-05-22 14:29:55 +02:00
|
|
|
}
|
2017-05-22 17:09:15 +02:00
|
|
|
if (!done)
|
|
|
|
ERR_CONTEXT(ret_out_of_range);
|
2017-05-22 14:29:55 +02:00
|
|
|
}
|