gin/mode.go

64 lines
1.0 KiB
Go
Raw Normal View History

2014-08-29 21:49:50 +04:00
// Copyright 2014 Manu Martinez-Almeida. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
package gin
import (
"log"
"os"
)
const GIN_MODE = "GIN_MODE"
const (
DebugMode string = "debug"
ReleaseMode string = "release"
2014-08-21 03:01:05 +04:00
TestMode string = "test"
)
const (
debugCode = iota
releaseCode = iota
2014-08-21 03:01:05 +04:00
testCode = iota
)
var gin_mode int = debugCode
var mode_name string = DebugMode
2014-10-09 03:40:42 +04:00
func init() {
value := os.Getenv(GIN_MODE)
if len(value) == 0 {
SetMode(DebugMode)
} else {
SetMode(value)
}
}
func SetMode(value string) {
switch value {
case DebugMode:
gin_mode = debugCode
case ReleaseMode:
gin_mode = releaseCode
2014-08-21 03:01:05 +04:00
case TestMode:
gin_mode = testCode
default:
2015-03-23 07:50:10 +03:00
log.Panic("gin mode unknown: " + value)
}
mode_name = value
}
func Mode() string {
return mode_name
}
2014-10-08 23:37:26 +04:00
func IsDebugging() bool {
return gin_mode == debugCode
}
2014-10-09 03:40:42 +04:00
func debugPrint(format string, values ...interface{}) {
if IsDebugging() {
log.Printf("[GIN-debug] "+format, values...)
}
}