args.c 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #include "args.h"
  2. #include "hex.h"
  3. size_t args_get_first_word_length(string_t args) {
  4. size_t ws = string_search_char(args, ' ');
  5. if(ws == STRING_FAILURE) {
  6. ws = string_size(args);
  7. }
  8. return ws;
  9. }
  10. size_t args_length(string_t args) {
  11. return string_size(args);
  12. }
  13. bool args_read_int_and_trim(string_t args, int* value) {
  14. size_t cmd_length = args_get_first_word_length(args);
  15. if(cmd_length == 0) {
  16. return false;
  17. }
  18. if (sscanf(string_get_cstr(args), "%d", value) == 1) {
  19. string_right(args, cmd_length);
  20. string_strim(args);
  21. return true;
  22. }
  23. return false;
  24. }
  25. bool args_read_string_and_trim(string_t args, string_t word) {
  26. size_t cmd_length = args_get_first_word_length(args);
  27. if(cmd_length == 0) {
  28. return false;
  29. }
  30. string_set_n(word, args, 0, cmd_length);
  31. string_right(args, cmd_length);
  32. string_strim(args);
  33. return true;
  34. }
  35. bool args_read_probably_quoted_string_and_trim(string_t args, string_t word) {
  36. if(string_size(args) > 1 && string_get_char(args, 0) == '\"') {
  37. size_t second_quote_pos = string_search_char(args, '\"', 1);
  38. if(second_quote_pos == 0) {
  39. return false;
  40. }
  41. string_set_n(word, args, 1, second_quote_pos - 1);
  42. string_right(args, second_quote_pos + 1);
  43. string_strim(args);
  44. return true;
  45. } else {
  46. return args_read_string_and_trim(args, word);
  47. }
  48. }
  49. bool args_char_to_hex(char hi_nibble, char low_nibble, uint8_t* byte) {
  50. uint8_t hi_nibble_value = 0;
  51. uint8_t low_nibble_value = 0;
  52. bool result = false;
  53. if(hex_char_to_hex_nibble(hi_nibble, &hi_nibble_value)) {
  54. if(hex_char_to_hex_nibble(low_nibble, &low_nibble_value)) {
  55. result = true;
  56. *byte = (hi_nibble_value << 4) | low_nibble_value;
  57. }
  58. }
  59. return result;
  60. }
  61. bool args_read_hex_bytes(string_t args, uint8_t* bytes, size_t bytes_count) {
  62. bool result = true;
  63. const char* str_pointer = string_get_cstr(args);
  64. if(args_get_first_word_length(args) == (bytes_count * 2)) {
  65. for(size_t i = 0; i < bytes_count; i++) {
  66. if(!args_char_to_hex(str_pointer[i * 2], str_pointer[i * 2 + 1], &(bytes[i]))) {
  67. result = false;
  68. break;
  69. }
  70. }
  71. } else {
  72. result = false;
  73. }
  74. return result;
  75. }