type.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package main
  2. import (
  3. "fmt"
  4. "regexp"
  5. "strconv"
  6. )
  7. func isName(s string) bool {
  8. reg := regexp.MustCompile(`^"[A-Za-z]\w*$`)
  9. return reg.MatchString(s)
  10. }
  11. func toName(s string) string {
  12. if !isName(s) {
  13. panic(fmt.Errorf("name: %s (%s)", errInvalidName, s))
  14. }
  15. return s[1:]
  16. }
  17. func isNumber(s string) bool {
  18. if s != "" && s[0] == '"' {
  19. s = s[1:]
  20. }
  21. _, err := strconv.ParseFloat(s, 64)
  22. return err == nil
  23. }
  24. func toNumber(s string) float64 {
  25. if s != "" && s[0] == '"' {
  26. s = s[1:]
  27. }
  28. val, err := strconv.ParseFloat(s, 64)
  29. if err != nil {
  30. panic(fmt.Errorf("number: %s (%s)", errInvalidNumber, s))
  31. }
  32. return val
  33. }
  34. func isWord(s string) bool {
  35. return s != "" && s[0] == '"'
  36. }
  37. func isList(s string) bool {
  38. return s != "" && s[0] == '['
  39. }
  40. func isBool(s string) bool {
  41. if s != "" && s[0] == '"' {
  42. s = s[1:]
  43. }
  44. _, err := strconv.ParseBool(s)
  45. return err == nil
  46. }
  47. func toBool(s string) bool {
  48. if s != "" && s[0] == '"' {
  49. s = s[1:]
  50. }
  51. val, err := strconv.ParseBool(s)
  52. if err != nil {
  53. panic(fmt.Errorf("bool: %s (%s)", errInvalidBool, s))
  54. }
  55. return val
  56. }
  57. func isEmpty(s string) bool {
  58. return s == `"` || s == "[ ]"
  59. }
  60. func isValue(s string) bool {
  61. return isNumber(s) || isWord(s) || isList(s) || isBool(s)
  62. }
  63. func opIsName(val1 value) value {
  64. return value{val: strconv.FormatBool(isName(val1.val))}
  65. }
  66. func opIsNumber(val1 value) value {
  67. return value{val: strconv.FormatBool(isNumber(val1.val))}
  68. }
  69. func opIsWord(val1 value) value {
  70. return value{val: strconv.FormatBool(isWord(val1.val))}
  71. }
  72. func opIsList(val1 value) value {
  73. return value{val: strconv.FormatBool(isList(val1.val))}
  74. }
  75. func opIsBool(val1 value) value {
  76. return value{val: strconv.FormatBool(isBool(val1.val))}
  77. }
  78. func opIsEmpty(val1 value) value {
  79. return value{val: strconv.FormatBool(isEmpty(val1.val))}
  80. }