gutil.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. // Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
  2. //
  3. // This Source Code Form is subject to the terms of the MIT License.
  4. // If a copy of the MIT was not distributed with this file,
  5. // You can obtain one at https://github.com/gogf/gf.
  6. // Package gutil provides utility functions.
  7. package gutil
  8. import (
  9. "fmt"
  10. "github.com/gogf/gf/internal/empty"
  11. "github.com/gogf/gf/util/gconv"
  12. "reflect"
  13. )
  14. // Throw throws out an exception, which can be caught be TryCatch or recover.
  15. func Throw(exception interface{}) {
  16. panic(exception)
  17. }
  18. // Try implements try... logistics using internal panic...recover.
  19. // It returns error if any exception occurs, or else it returns nil.
  20. func Try(try func()) (err error) {
  21. defer func() {
  22. if e := recover(); e != nil {
  23. err = fmt.Errorf(`%v`, e)
  24. }
  25. }()
  26. try()
  27. return
  28. }
  29. // TryCatch implements try...catch... logistics using internal panic...recover.
  30. // It automatically calls function `catch` if any exception occurs ans passes the exception as an error.
  31. func TryCatch(try func(), catch ...func(exception error)) {
  32. defer func() {
  33. if exception := recover(); exception != nil && len(catch) > 0 {
  34. if err, ok := exception.(error); ok {
  35. catch[0](err)
  36. } else {
  37. catch[0](fmt.Errorf(`%v`, exception))
  38. }
  39. }
  40. }()
  41. try()
  42. }
  43. // IsEmpty checks given `value` empty or not.
  44. // It returns false if `value` is: integer(0), bool(false), slice/map(len=0), nil;
  45. // or else returns true.
  46. func IsEmpty(value interface{}) bool {
  47. return empty.IsEmpty(value)
  48. }
  49. // Keys retrieves and returns the keys from given map or struct.
  50. func Keys(mapOrStruct interface{}) (keysOrAttrs []string) {
  51. keysOrAttrs = make([]string, 0)
  52. if m, ok := mapOrStruct.(map[string]interface{}); ok {
  53. for k, _ := range m {
  54. keysOrAttrs = append(keysOrAttrs, k)
  55. }
  56. return
  57. }
  58. var (
  59. reflectValue reflect.Value
  60. reflectKind reflect.Kind
  61. )
  62. if v, ok := mapOrStruct.(reflect.Value); ok {
  63. reflectValue = v
  64. } else {
  65. reflectValue = reflect.ValueOf(mapOrStruct)
  66. }
  67. reflectKind = reflectValue.Kind()
  68. for reflectKind == reflect.Ptr {
  69. if !reflectValue.IsValid() || reflectValue.IsNil() {
  70. reflectValue = reflect.New(reflectValue.Type().Elem()).Elem()
  71. reflectKind = reflectValue.Kind()
  72. } else {
  73. reflectValue = reflectValue.Elem()
  74. reflectKind = reflectValue.Kind()
  75. }
  76. }
  77. switch reflectKind {
  78. case reflect.Map:
  79. for _, k := range reflectValue.MapKeys() {
  80. keysOrAttrs = append(keysOrAttrs, gconv.String(k.Interface()))
  81. }
  82. case reflect.Struct:
  83. var (
  84. fieldType reflect.StructField
  85. reflectType = reflectValue.Type()
  86. )
  87. for i := 0; i < reflectValue.NumField(); i++ {
  88. fieldType = reflectType.Field(i)
  89. if fieldType.Anonymous {
  90. keysOrAttrs = append(keysOrAttrs, Keys(reflectValue.Field(i))...)
  91. } else {
  92. keysOrAttrs = append(keysOrAttrs, fieldType.Name)
  93. }
  94. }
  95. }
  96. return
  97. }
  98. // Values retrieves and returns the values from given map or struct.
  99. func Values(mapOrStruct interface{}) (values []interface{}) {
  100. values = make([]interface{}, 0)
  101. if m, ok := mapOrStruct.(map[string]interface{}); ok {
  102. for _, v := range m {
  103. values = append(values, v)
  104. }
  105. return
  106. }
  107. var (
  108. reflectValue reflect.Value
  109. reflectKind reflect.Kind
  110. )
  111. if v, ok := mapOrStruct.(reflect.Value); ok {
  112. reflectValue = v
  113. } else {
  114. reflectValue = reflect.ValueOf(mapOrStruct)
  115. }
  116. reflectKind = reflectValue.Kind()
  117. for reflectKind == reflect.Ptr {
  118. reflectValue = reflectValue.Elem()
  119. reflectKind = reflectValue.Kind()
  120. }
  121. switch reflectKind {
  122. case reflect.Map:
  123. for _, k := range reflectValue.MapKeys() {
  124. values = append(values, reflectValue.MapIndex(k).Interface())
  125. }
  126. case reflect.Struct:
  127. var (
  128. fieldType reflect.StructField
  129. reflectType = reflectValue.Type()
  130. )
  131. for i := 0; i < reflectValue.NumField(); i++ {
  132. fieldType = reflectType.Field(i)
  133. if fieldType.Anonymous {
  134. values = append(values, Values(reflectValue.Field(i))...)
  135. } else {
  136. values = append(values, reflectValue.Field(i).Interface())
  137. }
  138. }
  139. }
  140. return
  141. }