013-lnum-strtoul-parsing-fixes.patch 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. --- a/src/lnum.c
  2. +++ b/src/lnum.c
  3. @@ -127,6 +127,8 @@ static int luaO_str2i (const char *s, lu
  4. #else
  5. return 0; /* Reject the number */
  6. #endif
  7. + } else if (v > LUA_INTEGER_MAX) {
  8. + return TK_NUMBER;
  9. }
  10. } else if ((v > LUA_INTEGER_MAX) || (*endptr && (!isspace(*endptr)))) {
  11. return TK_NUMBER; /* not in signed range, or has '.', 'e' etc. trailing */
  12. @@ -310,3 +312,13 @@ int try_unmint( lua_Integer *r, lua_Inte
  13. return 0;
  14. }
  15. +#ifdef LONG_OVERFLOW_LUA_INTEGER
  16. +unsigned LUA_INTEGER lua_str2ul( const char *str, char **endptr, int base ) {
  17. + unsigned long v= strtoul(str, endptr, base);
  18. + if ( v > LUA_INTEGER_MAX ) {
  19. + errno= ERANGE;
  20. + v= ULONG_MAX;
  21. + }
  22. + return (unsigned LUA_INTEGER)v;
  23. +}
  24. +#endif
  25. --- a/src/lnum_config.h
  26. +++ b/src/lnum_config.h
  27. @@ -141,7 +141,12 @@
  28. #endif
  29. #ifndef lua_str2ul
  30. -# define lua_str2ul (unsigned LUA_INTEGER)strtoul
  31. +# if LONG_MAX > LUA_INTEGER_MAX
  32. +# define LONG_OVERFLOW_LUA_INTEGER
  33. + unsigned LUA_INTEGER lua_str2ul( const char *str, char **endptr, int base );
  34. +# else
  35. +# define lua_str2ul (unsigned LUA_INTEGER)strtoul
  36. +# endif
  37. #endif
  38. #ifndef LUA_INTEGER_MIN
  39. # define LUA_INTEGER_MIN (-LUA_INTEGER_MAX -1) /* -2^16|32 */