feat(cmd): added flag for displaying binary data in tty, and cleaned up some old code
This commit is contained in:
parent
63ade13e7a
commit
990ff7ce40
4 changed files with 29 additions and 23 deletions
|
|
@ -56,10 +56,16 @@ func get(cmd *cobra.Command, args []string) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
store.Print("%s", v)
|
binary, err := cmd.Flags().GetBool("include-binary")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
store.Print("%s", binary, v)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
getCmd.Flags().BoolP("include-binary", "b", false, "include binary data in text output")
|
||||||
rootCmd.AddCommand(getCmd)
|
rootCmd.AddCommand(getCmd)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
26
cmd/list.go
26
cmd/list.go
|
|
@ -22,9 +22,6 @@ THE SOFTWARE.
|
||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"strconv"
|
|
||||||
|
|
||||||
"github.com/dgraph-io/badger/v4"
|
"github.com/dgraph-io/badger/v4"
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
@ -39,31 +36,29 @@ var listCmd = &cobra.Command{
|
||||||
|
|
||||||
func list(cmd *cobra.Command, args []string) error {
|
func list(cmd *cobra.Command, args []string) error {
|
||||||
store := &Store{}
|
store := &Store{}
|
||||||
var pf string
|
targetDB := "@default"
|
||||||
var err error
|
if len(args) == 1 {
|
||||||
pf, err = strconv.Unquote(fmt.Sprintf(`"%%s%s%%s\n"`, "\t\t"))
|
targetDB = args[0]
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(args) == 0 {
|
|
||||||
args = append(args, "@default")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
trans := TransactionArgs{
|
trans := TransactionArgs{
|
||||||
key: args[0],
|
key: targetDB,
|
||||||
readonly: true,
|
readonly: true,
|
||||||
sync: true,
|
sync: true,
|
||||||
transact: func(tx *badger.Txn, k []byte) error {
|
transact: func(tx *badger.Txn, k []byte) error {
|
||||||
|
binary, err := cmd.Flags().GetBool("include-binary")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
opts := badger.DefaultIteratorOptions
|
opts := badger.DefaultIteratorOptions
|
||||||
opts.PrefetchSize = 10
|
opts.PrefetchSize = 10
|
||||||
it := tx.NewIterator(opts)
|
it := tx.NewIterator(opts)
|
||||||
defer it.Close()
|
defer it.Close()
|
||||||
for it.Rewind(); it.Valid(); it.Next() {
|
for it.Rewind(); it.Valid(); it.Next() {
|
||||||
item := it.Item()
|
item := it.Item()
|
||||||
k := item.Key()
|
key := item.Key()
|
||||||
if err := item.Value(func(v []byte) error {
|
if err := item.Value(func(v []byte) error {
|
||||||
store.Print(pf, k, v)
|
store.Print("%s\t\t%s\n", binary, key, v)
|
||||||
return nil
|
return nil
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
@ -77,5 +72,6 @@ func list(cmd *cobra.Command, args []string) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
listCmd.Flags().BoolP("include-binary", "b", false, "include binary data in text output")
|
||||||
rootCmd.AddCommand(listCmd)
|
rootCmd.AddCommand(listCmd)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -65,4 +65,3 @@ func set(cmd *cobra.Command, args []string) error {
|
||||||
func init() {
|
func init() {
|
||||||
rootCmd.AddCommand(setCmd)
|
rootCmd.AddCommand(setCmd)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -23,7 +23,6 @@ package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
@ -75,19 +74,25 @@ func (s *Store) Transaction(args TransactionArgs) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
tx := db.NewTransaction(!args.readonly)
|
tx := db.NewTransaction(!args.readonly)
|
||||||
|
defer tx.Discard()
|
||||||
|
|
||||||
if err := args.transact(tx, k); err != nil {
|
if err := args.transact(tx, k); err != nil {
|
||||||
tx.Discard()
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if args.readonly {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
return tx.Commit()
|
return tx.Commit()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Store) Print(pf string, vs ...[]byte) {
|
func (s *Store) Print(pf string, includeBinary bool, vs ...[]byte) {
|
||||||
nb := "(omitted binary data)"
|
nb := "(omitted binary data)"
|
||||||
fvs := make([]any, 0)
|
fvs := make([]any, 0, len(vs))
|
||||||
tty := term.IsTerminal(int(os.Stdin.Fd()))
|
tty := term.IsTerminal(int(os.Stdout.Fd()))
|
||||||
for _, v := range vs {
|
for _, v := range vs {
|
||||||
if tty && !utf8.Valid(v) {
|
if tty && !includeBinary && !utf8.Valid(v) {
|
||||||
fvs = append(fvs, nb)
|
fvs = append(fvs, nb)
|
||||||
} else {
|
} else {
|
||||||
fvs = append(fvs, string(v))
|
fvs = append(fvs, string(v))
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue