diff options
| author | hwspeedy <ns@bigbear.dk> | 2024-02-16 01:15:43 +0100 | 
|---|---|---|
| committer | hwspeedy <ns@bigbear.dk> | 2024-02-16 01:15:43 +0100 | 
| commit | c362d03622401c6ea39bae828b7e24cb1f75a6bf (patch) | |
| tree | 87d76f889011d2a1f090a2606fc01fd795863b54 /deps/sysobj_early/src/util_edid.c | |
| parent | 0ce19608f1b7ba6e280d5969cbb1a4990af86365 (diff) | |
FIX better implementation for low GLIB
Diffstat (limited to 'deps/sysobj_early/src/util_edid.c')
| -rw-r--r-- | deps/sysobj_early/src/util_edid.c | 62 | 
1 files changed, 54 insertions, 8 deletions
| diff --git a/deps/sysobj_early/src/util_edid.c b/deps/sysobj_early/src/util_edid.c index 06c5534e..906aeff0 100644 --- a/deps/sysobj_early/src/util_edid.c +++ b/deps/sysobj_early/src/util_edid.c @@ -31,17 +31,55 @@  #include "util_edid_svd_table.c" -// TODO: find a better fix, I've seen a few EDID strings with bogus chars -#if !GLIB_CHECK_VERSION(2,52,0) -__attribute__ ((weak)) -gchar *g_utf8_make_valid(const gchar *s, const gssize l) { -    if (l < 0) -        return g_strdup(s); -    else -        return g_strndup(s, (gsize)l); +#if GLIB_CHECK_VERSION(2,52,0) +#else +gchar * +g2_utf8_make_valid (const gchar *str, +                   gssize       len) +{ +  GString *string; +  const gchar *remainder, *invalid; +  gsize remaining_bytes, valid_bytes; + +  g_return_val_if_fail (str != NULL, NULL); + +  if (len < 0) +    len = strlen (str); + +  string = NULL; +  remainder = str; +  remaining_bytes = len; + +  while (remaining_bytes != 0) +    { +      if (g_utf8_validate (remainder, remaining_bytes, &invalid)) +	break; +      valid_bytes = invalid - remainder; + +      if (string == NULL) +	string = g_string_sized_new (remaining_bytes); + +      g_string_append_len (string, remainder, valid_bytes); +      /* append U+FFFD REPLACEMENT CHARACTER */ +      g_string_append (string, "\357\277\275"); + +      remaining_bytes -= valid_bytes + 1; +      remainder = invalid + 1; +    } + +  if (string == NULL) +    return g_strndup (str, len); + +  g_string_append_len (string, remainder, remaining_bytes); +  g_string_append_c (string, '\0'); + +  g_assert (g_utf8_validate (string->str, -1, NULL)); + +  return g_string_free (string, FALSE);  }  #endif +  #define NOMASK (~0U)  #define BFMASK(LSB, MASK) (MASK << LSB) @@ -89,7 +127,11 @@ char *rstr(edid *e, uint32_t offset, uint32_t len) {      char *raw = malloc(len+1), *ret = NULL;      strncpy(raw, (char*)&e->u8[offset], len);      raw[len] = 0; +#if GLIB_CHECK_VERSION(2,52,0)      ret = g_utf8_make_valid(raw, len); +#else +    ret = g2_utf8_make_valid(raw, len); +#endif      g_free(raw);      return ret;  } @@ -100,7 +142,11 @@ char *rstr_strip(edid *e, uint32_t offset, uint32_t len) {      char *raw = malloc(len+1), *ret = NULL;      strncpy(raw, (char*)&e->u8[offset], len);      raw[len] = 0; +#if GLIB_CHECK_VERSION(2,52,0)      ret = g_strstrip(g_utf8_make_valid(raw, len)); +#else +    ret = g_strstrip(g2_utf8_make_valid(raw, len)); +#endif      g_free(raw);      return ret;  } | 
