helpers.go 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. // package helpers -- содержит всякие полезняшки
  2. //
  3. // Пакет импортировать где нужно в нотации `. "gitlab.c2g.pw/back/uaj-abstract-client/pkg/helpers"`
  4. package helpers
  5. import (
  6. "fmt"
  7. "os"
  8. "time"
  9. . "gitp78su.ipnodns.ru/svi/kern/v2/krn/kalias"
  10. )
  11. var (
  12. IsStageLocal bool
  13. IsStageProd bool
  14. )
  15. // FnAssert -- проверка на правильность утверждения с падением в панику на локальном стенде (soft assert)
  16. //
  17. // (isCond bool, msgFormat string, args ...any)
  18. type FnAssert func(isCond bool, msgFormat string, args ...any)
  19. // Assert -- проверка на правильность утверждения с падением в панику на локальном стенде (soft assert)
  20. func Assert(isCond bool, msgFormat string, args ...any) {
  21. if isCond {
  22. return
  23. }
  24. msg := fmt.Sprintf("SOFT ASSERT "+msgFormat+"\n", args...)
  25. if IsStageLocal {
  26. panic(msg)
  27. }
  28. fmt.Print(msg)
  29. }
  30. // FnHassert -- проверяет с жёстким падением условие
  31. //
  32. // (isCond bool, msgFormat string, args ...any)
  33. type FnHassert func(isCond bool, msgFormat string, args ...any)
  34. // Hassert -- проверка на правильность утверждения с безусловным падением в панику (hard assert)
  35. func Hassert(isCond bool, msgFormat string, args ...any) {
  36. if isCond {
  37. return
  38. }
  39. msg := fmt.Sprintf("HARD ASSERT "+msgFormat+"\n", args...)
  40. panic(msg)
  41. }
  42. // TimeNowStr -- возвращает стандартную строку локального сейчас-времени "2006-01-02 15:04:05.000 -07 MST"
  43. func TimeNowStr() ATime {
  44. strTime := time.Now().Local().Format("2006-01-02 15:04:05.000 -07 MST")
  45. return ATime(strTime)
  46. }
  47. // TimeNow -- возвращает Unix сейчас-время (мсек, не зависит от положения)
  48. func TimeNow() int64 {
  49. timeNow := time.Now().Local().UnixMilli()
  50. return timeNow
  51. }
  52. // SleepMs -- спит миллисекунду
  53. func SleepMs() {
  54. time.Sleep(time.Millisecond * 1)
  55. }
  56. func init_() {
  57. strStage := os.Getenv("STAGE")
  58. switch strStage {
  59. case "local":
  60. IsStageLocal = true
  61. IsStageProd = false
  62. case "prod":
  63. IsStageProd = true
  64. IsStageLocal = false
  65. case "":
  66. IsStageLocal = true
  67. IsStageProd = false
  68. default:
  69. panic(fmt.Sprintf("lepers.init_(): unknown env STAGE (%v)\n", strStage))
  70. }
  71. }
  72. func init() {
  73. init_()
  74. }