mirror of https://github.com/etcd-io/bbolt.git
145 lines
2.6 KiB
Go
145 lines
2.6 KiB
Go
package main
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"log"
|
|
"os"
|
|
|
|
"github.com/codegangsta/cli"
|
|
)
|
|
|
|
func main() {
|
|
log.SetFlags(0)
|
|
NewApp().Run(os.Args)
|
|
}
|
|
|
|
// NewApp creates an Application instance.
|
|
func NewApp() *cli.App {
|
|
app := cli.NewApp()
|
|
app.Name = "bolt"
|
|
app.Usage = "BoltDB toolkit"
|
|
app.Version = "0.1.0"
|
|
app.Commands = []cli.Command{
|
|
{
|
|
Name: "get",
|
|
Usage: "Retrieve a value for given key in a bucket",
|
|
Action: func(c *cli.Context) {
|
|
path, name, key := c.Args().Get(0), c.Args().Get(1), c.Args().Get(2)
|
|
Get(path, name, key)
|
|
},
|
|
},
|
|
{
|
|
Name: "set",
|
|
Usage: "Sets a value for given key in a bucket",
|
|
Action: func(c *cli.Context) {
|
|
path, name, key, value := c.Args().Get(0), c.Args().Get(1), c.Args().Get(2), c.Args().Get(3)
|
|
Set(path, name, key, value)
|
|
},
|
|
},
|
|
{
|
|
Name: "keys",
|
|
Usage: "Retrieve a list of all keys in a bucket",
|
|
Action: func(c *cli.Context) {
|
|
path, name := c.Args().Get(0), c.Args().Get(1)
|
|
Keys(path, name)
|
|
},
|
|
},
|
|
{
|
|
Name: "buckets",
|
|
Usage: "Retrieves a list of all buckets",
|
|
Action: func(c *cli.Context) {
|
|
path := c.Args().Get(0)
|
|
Buckets(path)
|
|
},
|
|
},
|
|
{
|
|
Name: "pages",
|
|
Usage: "Dumps page information for a database",
|
|
Action: func(c *cli.Context) {
|
|
path := c.Args().Get(0)
|
|
Pages(path)
|
|
},
|
|
},
|
|
{
|
|
Name: "check",
|
|
Usage: "Performs a consistency check on the database",
|
|
Action: func(c *cli.Context) {
|
|
path := c.Args().Get(0)
|
|
Check(path)
|
|
},
|
|
},
|
|
}
|
|
return app
|
|
}
|
|
|
|
var logger = log.New(os.Stderr, "", 0)
|
|
var logBuffer *bytes.Buffer
|
|
|
|
func print(v ...interface{}) {
|
|
if testMode {
|
|
logger.Print(v...)
|
|
} else {
|
|
fmt.Print(v...)
|
|
}
|
|
}
|
|
|
|
func printf(format string, v ...interface{}) {
|
|
if testMode {
|
|
logger.Printf(format, v...)
|
|
} else {
|
|
fmt.Printf(format, v...)
|
|
}
|
|
}
|
|
|
|
func println(v ...interface{}) {
|
|
if testMode {
|
|
logger.Println(v...)
|
|
} else {
|
|
fmt.Println(v...)
|
|
}
|
|
}
|
|
|
|
func fatal(v ...interface{}) {
|
|
logger.Print(v...)
|
|
if !testMode {
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
func fatalf(format string, v ...interface{}) {
|
|
logger.Printf(format, v...)
|
|
if !testMode {
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
func fatalln(v ...interface{}) {
|
|
logger.Println(v...)
|
|
if !testMode {
|
|
os.Exit(1)
|
|
}
|
|
}
|
|
|
|
// LogBuffer returns the contents of the log.
|
|
// This only works while the CLI is in test mode.
|
|
func LogBuffer() string {
|
|
if logBuffer != nil {
|
|
return logBuffer.String()
|
|
}
|
|
return ""
|
|
}
|
|
|
|
var testMode bool
|
|
|
|
// SetTestMode sets whether the CLI is running in test mode and resets the logger.
|
|
func SetTestMode(value bool) {
|
|
testMode = value
|
|
if testMode {
|
|
logBuffer = bytes.NewBuffer(nil)
|
|
logger = log.New(logBuffer, "", 0)
|
|
} else {
|
|
logger = log.New(os.Stderr, "", 0)
|
|
}
|
|
}
|