X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=ir%2Flibcore%2Flc_appendable.c;h=f62aa6bc6b1a29f0c5eb049c189af9395e4c5bf0;hb=a147197e0d20514db14cd60a2e876bcdd6c05f66;hp=7656375b7aad0668a41311a9477f7acffd7f3ab1;hpb=de1b0c8d4f653f534a38740ad7f6803d82f2762e;p=libfirm diff --git a/ir/libcore/lc_appendable.c b/ir/libcore/lc_appendable.c index 7656375b7..f62aa6bc6 100644 --- a/ir/libcore/lc_appendable.c +++ b/ir/libcore/lc_appendable.c @@ -16,13 +16,13 @@ License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ +#include "config.h" #include #include #include -#include "lc_common_t.h" -#include "lc_defines.h" +#include "util.h" #include "lc_printf.h" /* Default appendable implementations */ @@ -31,18 +31,18 @@ int lc_appendable_snwadd(lc_appendable_t *app, const char *str, size_t len, unsigned int width, int left_just, char pad) { int res = 0; - int i; - int to_pad = width - len; + size_t i; + size_t to_pad = width > len ? width - len : 0; /* If not left justified, pad left */ - for(i = 0; !left_just && i < to_pad; ++i) + for (i = 0; !left_just && i < to_pad; ++i) res += lc_appendable_chadd(app, pad); /* Send the visible portion of the string to the output. */ res += lc_appendable_snadd(app, str, len); /* If left justified, pad right. */ - for(i = 0; left_just && i < to_pad; ++i) + for (i = 0; left_just && i < to_pad; ++i) res += lc_appendable_chadd(app, pad); return res; @@ -60,12 +60,14 @@ void lc_appendable_init(lc_appendable_t *env, const lc_appendable_funcs_t *app, app->init(env); } -static void default_init(UNUSED(lc_appendable_t *env)) +static void default_init(lc_appendable_t *env) { + (void) env; } -static void default_finish(UNUSED(lc_appendable_t *env)) +static void default_finish(lc_appendable_t *env) { + (void) env; } /* @@ -75,13 +77,13 @@ static void default_finish(UNUSED(lc_appendable_t *env)) static int file_snadd(lc_appendable_t *obj, const char *str, size_t n) { obj->written += n; - fwrite(str, sizeof(char), n, obj->obj); + fwrite(str, sizeof(char), n, (FILE*)obj->obj); return n; } static int file_chadd(lc_appendable_t *obj, int ch) { - fputc(ch, obj->obj); + fputc(ch, (FILE*)obj->obj); obj->written++; return 1; } @@ -102,13 +104,13 @@ const lc_appendable_funcs_t *lc_appendable_file = &app_file; static void str_init(lc_appendable_t *obj) { - strncpy(obj->obj, "", obj->limit); + strncpy((char*)obj->obj, "", obj->limit); } static int str_snadd(lc_appendable_t *obj, const char *str, size_t n) { - size_t to_write = LC_MIN(obj->limit - obj->written - 1, n); - char *tgt = obj->obj; + size_t to_write = MIN(obj->limit - obj->written - 1, n); + char *tgt = (char*)obj->obj; strncpy(tgt + obj->written, str, to_write); obj->written += to_write; return to_write; @@ -116,8 +118,8 @@ static int str_snadd(lc_appendable_t *obj, const char *str, size_t n) static int str_chadd(lc_appendable_t *obj, int ch) { - if(obj->limit - obj->written > 1) { - char *tgt = obj->obj; + if (obj->limit - obj->written > 1) { + char *tgt = (char*)obj->obj; tgt[obj->written++] = (char) ch; return 1; } @@ -127,7 +129,7 @@ static int str_chadd(lc_appendable_t *obj, int ch) static void str_finish(lc_appendable_t *obj) { - char *str = obj->obj; + char *str = (char*)obj->obj; str[obj->written] = '\0'; } @@ -146,7 +148,7 @@ const lc_appendable_funcs_t *lc_appendable_string = &app_string; static int obst_snadd(lc_appendable_t *obj, const char *str, size_t n) { - struct obstack *obst = obj->obj; + struct obstack *obst = (struct obstack*)obj->obj; obj->written += n; obstack_grow(obst, str, n); return n; @@ -154,7 +156,7 @@ static int obst_snadd(lc_appendable_t *obj, const char *str, size_t n) static int obst_chadd(lc_appendable_t *obj, int ch) { - struct obstack *obst = obj->obj; + struct obstack *obst = (struct obstack*)obj->obj; obstack_1grow(obst, (char) ch); obj->written++; return 1;