X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fdynamic-string.c;h=3af7fc9f56634e169b757e93c1abf8f39095597a;hb=828cd4c7cd666b93f72d57e5932b5becf0809619;hp=9684ffad89b3c68b81b2b02745e2c46dfe6aafea;hpb=4871855420190bc83fda294d7e815bd4e9c8531a;p=sliver-openvswitch.git diff --git a/lib/dynamic-string.c b/lib/dynamic-string.c index 9684ffad8..3af7fc9f5 100644 --- a/lib/dynamic-string.c +++ b/lib/dynamic-string.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2009 Nicira Networks. + * Copyright (c) 2008, 2009, 2010 Nicira Networks. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -32,7 +32,7 @@ ds_init(struct ds *ds) } void -ds_clear(struct ds *ds) +ds_clear(struct ds *ds) { ds->length = 0; } @@ -66,11 +66,36 @@ ds_put_uninit(struct ds *ds, size_t n) } void -ds_put_char(struct ds *ds, char c) +ds_put_char__(struct ds *ds, char c) { *ds_put_uninit(ds, 1) = c; } +/* Appends unicode code point 'uc' to 'ds' in UTF-8 encoding. */ +void +ds_put_utf8(struct ds *ds, int uc) +{ + if (uc <= 0x7f) { + ds_put_char(ds, uc); + } else if (uc <= 0x7ff) { + ds_put_char(ds, 0xc0 | (uc >> 6)); + ds_put_char(ds, 0x80 | (uc & 0x3f)); + } else if (uc <= 0xffff) { + ds_put_char(ds, 0xe0 | (uc >> 12)); + ds_put_char(ds, 0x80 | ((uc >> 6) & 0x3f)); + ds_put_char(ds, 0x80 | (uc & 0x3f)); + } else if (uc <= 0x10ffff) { + ds_put_char(ds, 0xf0 | (uc >> 18)); + ds_put_char(ds, 0x80 | ((uc >> 12) & 0x3f)); + ds_put_char(ds, 0x80 | ((uc >> 6) & 0x3f)); + ds_put_char(ds, 0x80 | (uc & 0x3f)); + } else { + /* Invalid code point. Insert the Unicode general substitute + * REPLACEMENT CHARACTER. */ + ds_put_utf8(ds, 0xfffd); + } +} + void ds_put_char_multiple(struct ds *ds, char c, size_t n) { @@ -90,6 +115,13 @@ ds_put_cstr(struct ds *ds, const char *s) memcpy(ds_put_uninit(ds, s_len), s, s_len); } +void +ds_put_and_free_cstr(struct ds *ds, char *s) +{ + ds_put_cstr(ds, s); + free(s); +} + void ds_put_format(struct ds *ds, const char *format, ...) { @@ -115,8 +147,6 @@ ds_put_format_valist(struct ds *ds, const char *format, va_list args_) if (needed < available) { ds->length += needed; } else { - size_t available; - ds_reserve(ds, ds->length + needed); va_copy(args, args_); @@ -130,7 +160,7 @@ ds_put_format_valist(struct ds *ds, const char *format, va_list args_) } void -ds_put_printable(struct ds *ds, const char *s, size_t n) +ds_put_printable(struct ds *ds, const char *s, size_t n) { ds_reserve(ds, ds->length + n); while (n-- > 0) { @@ -147,7 +177,7 @@ void ds_put_strftime(struct ds *ds, const char *template, const struct tm *tm) { if (!tm) { - time_t now = time_now(); + time_t now = time_wall(); tm = localtime(&now); } for (;;) { @@ -157,7 +187,7 @@ ds_put_strftime(struct ds *ds, const char *template, const struct tm *tm) ds->length += used; return; } - ds_reserve(ds, ds->length + (avail < 32 ? 64 : 2 * avail)); + ds_reserve(ds, ds->length + (avail < 32 ? 64 : 2 * avail)); } } @@ -187,6 +217,12 @@ ds_cstr(struct ds *ds) return ds->string; } +const char * +ds_cstr_ro(const struct ds *ds) +{ + return ds_cstr((struct ds *) ds); +} + /* Returns a null-terminated string representing the current contents of 'ds', * which the caller is expected to free with free(), then clears the contents * of 'ds'. */ @@ -204,6 +240,15 @@ ds_destroy(struct ds *ds) free(ds->string); } +/* Swaps the content of 'a' and 'b'. */ +void +ds_swap(struct ds *a, struct ds *b) +{ + struct ds temp = *a; + *a = *b; + *b = temp; +} + /* Writes the 'size' bytes in 'buf' to 'string' as hex bytes arranged 16 per * line. Numeric offsets are also included, starting at 'ofs' for the first * byte in 'buf'. If 'ascii' is true then the corresponding ASCII characters