fix bracket evaluation
[calc.git] / format.c
CommitLineData
a24bd519
LM
1#include <malloc.h>
2#include <stdio.h>
3#include <string.h>
4
5#include "format.h"
6
7/* global variables */
8
743e93f0
LM
9int _ibase = 10;
10int _obase = 10;
20a64561 11
a24bd519 12#define DEFAULT_FORMAT "=> %.6g\n"
e2a309f9
LM
13char *_format = NULL;
14#define DEFAULT_MINFORM "%.6g"
15char *_minform = NULL;
16
17int _precision = 6;
18
19#define DEFAULT_PROMPT "=> "
20char *_prompt = NULL;
a24bd519
LM
21
22/* print function */
23
e2a309f9
LM
24void set_precision (int precision)
25{
26 _precision = precision;
27}
28
29int get_precision ()
30{
31 return _precision;
32}
33
34void set_prompt (char *prompt)
35{
36 if (_prompt) {
37 free (_prompt);
38 }
39 _prompt = strdup (prompt);
40}
41
42void set_format ()
a24bd519
LM
43{
44 char buffer[128] = {0};
e2a309f9
LM
45 sprintf (buffer, "%s%%.%dg\n", _prompt ? _prompt : DEFAULT_PROMPT, _precision);
46 if (_format) {
47 free (_format);
48 }
49 _format = strdup (buffer);
50 sprintf (buffer, "%%.%dg", _precision);
51 if (_minform) {
52 free (_minform);
53 }
54 _minform = strdup (buffer);
a24bd519
LM
55}
56
57void free_format ()
58{
e2a309f9
LM
59 if (_format) {
60 free (_format);
61 _format = NULL;
62 }
63 if (_minform) {
64 free (_minform);
65 _minform = NULL;
a24bd519 66 }
e2a309f9
LM
67 if (_prompt) {
68 free (_prompt);
69 _prompt = NULL;
a24bd519
LM
70 }
71}
72
743e93f0
LM
73void set_base (int in, int out)
74{
75 _ibase = in;
76 _obase = out;
77}
78
743e93f0
LM
79char *show_base ()
80{
81 static char str[16] = {0};
82 sprintf (str, "%d/%d", _ibase, _obase);
83 return str;
84}
85
86int get_ibase ()
87{
88 return _ibase;
89}
20a64561 90
0aa5a6e5
LM
91/* multi base integer to ascii function */
92
93char *mbitoa (unsigned long value)
20a64561
LM
94{
95 static char str[8 * sizeof (long) + 1];
96
97 /* decompose */
98 char buffer[8 * sizeof (long) + 1] = {0};
99 int size = 0;
100 do {
743e93f0 101 char x = value % _obase;
20a64561 102 buffer[size++] = (x > 9) ? 'a' + x - 10 : '0' + x;
743e93f0 103 value /= _obase;
20a64561
LM
104 } while (value != 0);
105
106 /* revert */
107 int i;
108 for (i = 0; i < size; i++) {
109 str[i] = buffer [size - i - 1];
110 }
111 str[size] = '\0';
112
113 return str;
114}
115
a24bd519
LM
116double print (double value)
117{
743e93f0 118 if (_obase == 10) {
b6311fa2 119 printf (_format ? _format : DEFAULT_FORMAT, value);
20a64561 120 } else {
0aa5a6e5 121 printf ("%s%s\n", (_prompt) ? _prompt : DEFAULT_PROMPT, mbitoa ((unsigned int)value));
20a64561 122 }
e2a309f9
LM
123 return value;
124}
125
126double printl (double value)
127{
743e93f0 128 if (_obase == 10) {
b6311fa2 129 printf (_minform ? _minform : DEFAULT_MINFORM, value);
20a64561 130 } else {
be390043 131 printf ("%s", mbitoa ((unsigned int)value));
20a64561 132 }
a24bd519
LM
133 return value;
134}
e4c7b513
LM
135
136/* vim: set ts=4 sw=4 et: */