aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar gingerBill 2016-05-11 00:47:05 +0100
committerGravatar gingerBill 2016-05-11 00:47:05 +0100
commit6948a291966c8aaf3bdb5404355528bb124353a8 (patch)
treecf91339472c8275c879e5eeb968d244710f8c102
parentStarted making stdio & stdlib optional (diff)
Add string precision and width (experimental)
-rw-r--r--README.md2
-rw-r--r--gb.h29
2 files changed, 23 insertions, 8 deletions
diff --git a/README.md b/README.md
index a083236..2873e4a 100644
--- a/README.md
+++ b/README.md
@@ -4,7 +4,7 @@ gb single-file public domain libraries for C & C++
library | latest version | category | description
----------------|----------------|----------|-------------
-**gb.h** | 0.10c | misc | A helper library for C & C++
+**gb.h** | 0.11a | misc | A helper library for C & C++
**gb_math.h** | 0.06c | math | A C/C++ vector math library geared towards game development
**gb_gl.h** | 0.04b | graphics | A C/C++ OpenGL Helper Library
**gb_string.h** | 0.95 | strings | A better string library for C & C++ (this is built into gb.h too with custom allocator support!)
diff --git a/gb.h b/gb.h
index 1102c62..f0918f8 100644
--- a/gb.h
+++ b/gb.h
@@ -1,4 +1,4 @@
-/* gb.h - v0.11 - Ginger Bill's C Helper Library - public domain
+/* gb.h - v0.11a - Ginger Bill's C Helper Library - public domain
- no warranty implied; use at your own risk
This is a single header file with a bunch of useful stuff
@@ -26,6 +26,7 @@ Conventions used:
Version History:
+ 0.11a - Add string precision and width (experimental)
0.11 - Started making stdio & stdlib optional (Not tested much)
0.10c - Fix gb_endian_swap32()
0.10b - Probable timing bug for gb_time_now()
@@ -2005,9 +2006,14 @@ typedef struct {
gb_internal isize
gb__print_string(char *text, isize max_len, gb__FmtInfo *info, char const *string)
{
+ /* TODO(bill): Get precision and width to work correctly
+ * How does it actually work?!
+ */
isize len = 0;
+ isize str_len = gb_strlen(string);
+ isize precision = str_len;
- if (info && info->width && info->width > gb_strlen(string)) {
+ if (info && info->width && info->width > str_len) {
char fill = info->pad_zeroes ? '0' : ' ';
isize width = info->width - gb_strlen(string);
while (width-- > 0 && max_len > 0) {
@@ -2016,7 +2022,9 @@ gb__print_string(char *text, isize max_len, gb__FmtInfo *info, char const *strin
}
}
- len += gb_strlcpy(text, string, max_len);
+ if (info && info->precision > 0) precision = gb_min(info->precision, precision);
+
+ len += gb_strlcpy(text, string, gb_min(max_len, precision));
if (info) {
if (info->force_case == GB__LETTER_CASE_UPPER)
@@ -2026,7 +2034,6 @@ gb__print_string(char *text, isize max_len, gb__FmtInfo *info, char const *strin
}
return len;
-
}
gb_internal isize
@@ -2143,7 +2150,7 @@ gb__print_f64(char *text, isize max_len, gb__FmtInfo *info, f64 arg)
gb_no_inline isize
gb_snprintf_va(char *text, isize max_len, char const *fmt, va_list va)
{
-#if !defined(GB_NO_STDIO)
+#if 0 && !defined(GB_NO_STDIO)
i32 res;
#if defined(_WIN32)
res = _vsnprintf(text, max_len, fmt, va);
@@ -2186,13 +2193,21 @@ gb_snprintf_va(char *text, isize max_len, char const *fmt, va_list va)
if (*fmt >= '0' && *fmt <= '9')
info.width = gb_str_to_i64(fmt, cast(char **)&fmt, 0);
+ if (*fmt == '*') {
+ info.width = cast(isize)va_arg(va, int);
+ if (fmt[1] == '.') fmt++;
+ }
if (*fmt == '.') {
fmt++;
- if (*fmt >= '0' && *fmt <= '9')
+ if (*fmt >= '0' && *fmt <= '9') {
info.precision = cast(i32)gb_str_to_i64(fmt, cast(char **)&fmt, 0);
- else
+ } else if (*fmt == '*') {
+ info.precision = cast(i32)va_arg(va, int);
+ } else {
info.precision = 0;
+ }
+ fmt++;
}
while (!finish_parse) {