[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Tinycc-devel] [PATCH 2/2] tcc -E: preserve spaces (partial solution)
From: |
Kirill Smelkov |
Subject: |
[Tinycc-devel] [PATCH 2/2] tcc -E: preserve spaces (partial solution) |
Date: |
Sun, 18 Jan 2009 17:39:17 +0300 |
Recently I needed to trim storage space on an embedded distro which has
X.
X depend on cpp which is ~8MB in size as shipped in Debian, so the idea
was to remove cpp and use `tcc -E` instead where appropriate.
I've done this with the following 'hack' put inplace of /usr/bin/cpp :
#!/bin/sh -e
TCC=/home/kirr/local/tcc/bin/tcc
last="${!#}"
# hack to distinguish between '... -D...' and '... file'
if test -r "$last"; then
exec $TCC -E "$@"
else
exec $TCC -E "$@" -
fi
But the problem turned out to be in `tcc -E` inability to preserve
spaces between tokens. So e.g. the following ~/.Xresources
XTerm*VT100*foreground: black
...
got translated to
XTerm * VT100 * foreground : black
which is bad, bacause now X don't understand it.
Below is a newbie "fix" for the problem.
It still does not preserve spaces on macro expansion, but since the fix
cures original problem, I think it is at least one step forward.
Signed-off-by: Kirill Smelkov <address@hidden>
---
tcc.c | 10 ++++++++--
1 files changed, 8 insertions(+), 2 deletions(-)
diff --git a/tcc.c b/tcc.c
index 772b171..ef1b6a2 100644
--- a/tcc.c
+++ b/tcc.c
@@ -331,6 +331,7 @@ typedef struct CachedInclude {
/* parser */
static struct BufferedFile *file;
static int ch, tok;
+static CString tok_spaces; /* spaces before current token */
static CValue tokc;
static CString tokcstr; /* current parsed string, if any */
/* additional informations about token */
@@ -3675,6 +3676,7 @@ static inline void next_nomacro1(void)
uint8_t *p, *p1;
unsigned int h;
+ cstr_reset(&tok_spaces);
p = file->buf_ptr;
redo_no_start:
c = *p;
@@ -3684,6 +3686,7 @@ static inline void next_nomacro1(void)
case '\f':
case '\v':
case '\r':
+ cstr_ccat(&tok_spaces, c);
p++;
goto redo_no_start;
@@ -9758,7 +9761,10 @@ static int tcc_compile(TCCState *s1)
}
/* Preprocess the current file */
-/* XXX: add line and file infos, add options to preserve spaces */
+/* XXX: add line and file infos,
+ * XXX: add options to preserve spaces (partly done, only spaces in macro are
+ * not preserved)
+ */
static int tcc_preprocess(TCCState *s1)
{
Sym *define_start;
@@ -9787,7 +9793,7 @@ static int tcc_preprocess(TCCState *s1)
++line_ref;
token_seen = 0;
} else if (token_seen) {
- fputc(' ', s1->outfile);
+ fwrite(tok_spaces.data, tok_spaces.size, 1, s1->outfile);
} else {
int d = file->line_num - line_ref;
if (file != file_ref || d < 0 || d >= 8)
--
1.6.1.79.g92b9.dirty