Improve definitions of parse_ulong and parse_ullong:
- Use macro to eliminate duplicate body definitions.
- Rename okay as is_okay; add parenthesis to help "clarify" logic.
---
 command.c |   25 +++++++++++--------------
 1 file changed, 11 insertions(+), 14 deletions(-)
======
only in patch2:
unchanged:
--- src/helper/command.c	(revision 2242)
+++ src/helper/command.c	(working copy)
@@ -863,17 +863,14 @@
 	return 0;
 }
 
-int parse_ullong(const char *str, unsigned long long *ul)
-{
-	char *end;
-	*ul = strtoull(str, &end, 0);
-	bool okay = *str && !*end && ULLONG_MAX != *ul;
-	return okay ? ERROR_OK : ERROR_COMMAND_SYNTAX_ERROR;
-}
-int parse_ulong(const char *str, unsigned long *ul)
-{
-	char *end;
-	*ul = strtoul(str, &end, 0);
-	bool okay = *str && !*end && ULONG_MAX != *ul;
-	return okay ? ERROR_OK : ERROR_COMMAND_SYNTAX_ERROR;
-}
+#define DEFINE_PARSE_NUM_TYPE(name, type, func, max) \
+	int parse##name(const char *str, type *ul) \
+	{ \
+		char *end; \
+		*ul = func(str, &end, 0); \
+		bool is_okay = *str && !*end && (max != *ul); \
+		return is_okay ? ERROR_OK : ERROR_COMMAND_SYNTAX_ERROR; \
+	}
+DEFINE_PARSE_NUM_TYPE(_ulong, unsigned long , strtoul, ULONG_MAX)
+DEFINE_PARSE_NUM_TYPE(_ullong, unsigned long long, strtoull, ULLONG_MAX)
+
_______________________________________________
Openocd-development mailing list
[email protected]
https://lists.berlios.de/mailman/listinfo/openocd-development

Reply via email to