funcs.go 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. package templates
  2. import (
  3. "encoding/base64"
  4. "encoding/json"
  5. "fmt"
  6. "reflect"
  7. "strconv"
  8. )
  9. //Use the name json in func map
  10. func JsonMarshal(v interface{}) (string, error) {
  11. if a, err := json.Marshal(v); err != nil {
  12. return "", err
  13. } else {
  14. return string(a), nil
  15. }
  16. }
  17. func Base64Encode(para interface{}) (string, error) {
  18. v := reflect.ValueOf(para)
  19. if !v.IsValid() {
  20. return "", fmt.Errorf("based64 error for nil")
  21. }
  22. switch v.Kind() {
  23. case reflect.Bool:
  24. bv := strconv.FormatBool(v.Bool())
  25. return base64.StdEncoding.EncodeToString([]byte(bv)), nil
  26. case reflect.Int, reflect.Int64:
  27. iv := strconv.FormatInt(v.Int(), 10)
  28. return base64.StdEncoding.EncodeToString([]byte(iv)), nil
  29. case reflect.Uint64:
  30. iv := strconv.FormatUint(v.Uint(), 10)
  31. return base64.StdEncoding.EncodeToString([]byte(iv)), nil
  32. case reflect.Float32:
  33. fv := strconv.FormatFloat(v.Float(), 'f', -1, 32)
  34. return base64.StdEncoding.EncodeToString([]byte(fv)), nil
  35. case reflect.Float64:
  36. fv := strconv.FormatFloat(v.Float(), 'f', -1, 64)
  37. return base64.StdEncoding.EncodeToString([]byte(fv)), nil
  38. case reflect.String:
  39. return base64.StdEncoding.EncodeToString([]byte(v.String())), nil
  40. case reflect.Map:
  41. if a, err := json.Marshal(para); err != nil {
  42. return "", err
  43. } else {
  44. en := base64.StdEncoding.EncodeToString(a)
  45. return en, nil
  46. }
  47. default:
  48. return "", fmt.Errorf("Unsupported data type %s for base64 function.", v.Kind())
  49. }
  50. }
  51. func Add(para1 interface{}, para2 interface{}) (interface{}, error) {
  52. v1 := reflect.ValueOf(para1)
  53. v2 := reflect.ValueOf(para2)
  54. if !v1.IsValid() {
  55. return "", fmt.Errorf("Add error for nil for para1")
  56. } else if !v2.IsValid() {
  57. return "", fmt.Errorf("Add error for nil for para2")
  58. }
  59. switch v1.Kind() {
  60. case reflect.Int, reflect.Int64:
  61. vi := v1.Int()
  62. switch v2.Kind() {
  63. case reflect.Int, reflect.Int64:
  64. return vi + v2.Int(), nil
  65. case reflect.Float32, reflect.Float64:
  66. return vi + int64(v2.Float()), nil
  67. default:
  68. return "", fmt.Errorf("Unsupported data type %s of para2 for Add function when para1 type is %s.", v2.Kind(), v1.Kind())
  69. }
  70. case reflect.Uint64:
  71. vi := v1.Uint()
  72. switch v2.Kind() {
  73. case reflect.Uint64:
  74. return uint64(vi) + v2.Uint(), nil
  75. default:
  76. return "", fmt.Errorf("Unsupported data type %s of para2 for Add function when para1 type is %s.", v2.Kind(), v1.Kind())
  77. }
  78. case reflect.Float32, reflect.Float64:
  79. fi := v1.Float()
  80. switch v2.Kind() {
  81. case reflect.Int, reflect.Int64:
  82. return fi + float64(v2.Int()), nil
  83. case reflect.Float32, reflect.Float64:
  84. return fi + v2.Float(), nil
  85. default:
  86. return "", fmt.Errorf("Unsupported data type %s of para2 for Add function when para1 type is %s.", v2.Kind(), v1.Kind())
  87. }
  88. default:
  89. return "", fmt.Errorf("Unsupported data type %s for para1 with Add function.", v1.Kind())
  90. }
  91. }