http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows.go 
b/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows.go
deleted file mode 100644
index 336142a..0000000
--- a/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows.go
+++ /dev/null
@@ -1,98 +0,0 @@
-// +build windows
-// +build !go1.4
-
-package mousetrap
-
-import (
-       "fmt"
-       "os"
-       "syscall"
-       "unsafe"
-)
-
-const (
-       // defined by the Win32 API
-       th32cs_snapprocess uintptr = 0x2
-)
-
-var (
-       kernel                   = syscall.MustLoadDLL("kernel32.dll")
-       CreateToolhelp32Snapshot = 
kernel.MustFindProc("CreateToolhelp32Snapshot")
-       Process32First           = kernel.MustFindProc("Process32FirstW")
-       Process32Next            = kernel.MustFindProc("Process32NextW")
-)
-
-// ProcessEntry32 structure defined by the Win32 API
-type processEntry32 struct {
-       dwSize              uint32
-       cntUsage            uint32
-       th32ProcessID       uint32
-       th32DefaultHeapID   int
-       th32ModuleID        uint32
-       cntThreads          uint32
-       th32ParentProcessID uint32
-       pcPriClassBase      int32
-       dwFlags             uint32
-       szExeFile           [syscall.MAX_PATH]uint16
-}
-
-func getProcessEntry(pid int) (pe *processEntry32, err error) {
-       snapshot, _, e1 := CreateToolhelp32Snapshot.Call(th32cs_snapprocess, 
uintptr(0))
-       if snapshot == uintptr(syscall.InvalidHandle) {
-               err = fmt.Errorf("CreateToolhelp32Snapshot: %v", e1)
-               return
-       }
-       defer syscall.CloseHandle(syscall.Handle(snapshot))
-
-       var processEntry processEntry32
-       processEntry.dwSize = uint32(unsafe.Sizeof(processEntry))
-       ok, _, e1 := Process32First.Call(snapshot, 
uintptr(unsafe.Pointer(&processEntry)))
-       if ok == 0 {
-               err = fmt.Errorf("Process32First: %v", e1)
-               return
-       }
-
-       for {
-               if processEntry.th32ProcessID == uint32(pid) {
-                       pe = &processEntry
-                       return
-               }
-
-               ok, _, e1 = Process32Next.Call(snapshot, 
uintptr(unsafe.Pointer(&processEntry)))
-               if ok == 0 {
-                       err = fmt.Errorf("Process32Next: %v", e1)
-                       return
-               }
-       }
-}
-
-func getppid() (pid int, err error) {
-       pe, err := getProcessEntry(os.Getpid())
-       if err != nil {
-               return
-       }
-
-       pid = int(pe.th32ParentProcessID)
-       return
-}
-
-// StartedByExplorer returns true if the program was invoked by the user 
double-clicking
-// on the executable from explorer.exe
-//
-// It is conservative and returns false if any of the internal calls fail.
-// It does not guarantee that the program was run from a terminal. It only can 
tell you
-// whether it was launched from explorer.exe
-func StartedByExplorer() bool {
-       ppid, err := getppid()
-       if err != nil {
-               return false
-       }
-
-       pe, err := getProcessEntry(ppid)
-       if err != nil {
-               return false
-       }
-
-       name := syscall.UTF16ToString(pe.szExeFile[:])
-       return name == "explorer.exe"
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows_1.4.go
----------------------------------------------------------------------
diff --git 
a/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows_1.4.go 
b/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows_1.4.go
deleted file mode 100644
index 9a28e57..0000000
--- a/newt/vendor/github.com/inconshreveable/mousetrap/trap_windows_1.4.go
+++ /dev/null
@@ -1,46 +0,0 @@
-// +build windows
-// +build go1.4
-
-package mousetrap
-
-import (
-       "os"
-       "syscall"
-       "unsafe"
-)
-
-func getProcessEntry(pid int) (*syscall.ProcessEntry32, error) {
-       snapshot, err := 
syscall.CreateToolhelp32Snapshot(syscall.TH32CS_SNAPPROCESS, 0)
-       if err != nil {
-               return nil, err
-       }
-       defer syscall.CloseHandle(snapshot)
-       var procEntry syscall.ProcessEntry32
-       procEntry.Size = uint32(unsafe.Sizeof(procEntry))
-       if err = syscall.Process32First(snapshot, &procEntry); err != nil {
-               return nil, err
-       }
-       for {
-               if procEntry.ProcessID == uint32(pid) {
-                       return &procEntry, nil
-               }
-               err = syscall.Process32Next(snapshot, &procEntry)
-               if err != nil {
-                       return nil, err
-               }
-       }
-}
-
-// StartedByExplorer returns true if the program was invoked by the user 
double-clicking
-// on the executable from explorer.exe
-//
-// It is conservative and returns false if any of the internal calls fail.
-// It does not guarantee that the program was run from a terminal. It only can 
tell you
-// whether it was launched from explorer.exe
-func StartedByExplorer() bool {
-       pe, err := getProcessEntry(os.Getppid())
-       if err != nil {
-               return false
-       }
-       return "explorer.exe" == syscall.UTF16ToString(pe.ExeFile[:])
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/.gitignore
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/.gitignore 
b/newt/vendor/github.com/kr/pretty/.gitignore
deleted file mode 100644
index 1f0a99f..0000000
--- a/newt/vendor/github.com/kr/pretty/.gitignore
+++ /dev/null
@@ -1,4 +0,0 @@
-[568].out
-_go*
-_test*
-_obj

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/License
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/License 
b/newt/vendor/github.com/kr/pretty/License
deleted file mode 100644
index 05c783c..0000000
--- a/newt/vendor/github.com/kr/pretty/License
+++ /dev/null
@@ -1,21 +0,0 @@
-The MIT License (MIT)
-
-Copyright 2012 Keith Rarick
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in
-all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/Readme
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/Readme 
b/newt/vendor/github.com/kr/pretty/Readme
deleted file mode 100644
index c589fc6..0000000
--- a/newt/vendor/github.com/kr/pretty/Readme
+++ /dev/null
@@ -1,9 +0,0 @@
-package pretty
-
-    import "github.com/kr/pretty"
-
-    Package pretty provides pretty-printing for Go values.
-
-Documentation
-
-    http://godoc.org/github.com/kr/pretty

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/diff.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/diff.go 
b/newt/vendor/github.com/kr/pretty/diff.go
deleted file mode 100644
index 6aa7f74..0000000
--- a/newt/vendor/github.com/kr/pretty/diff.go
+++ /dev/null
@@ -1,265 +0,0 @@
-package pretty
-
-import (
-       "fmt"
-       "io"
-       "reflect"
-)
-
-type sbuf []string
-
-func (p *sbuf) Printf(format string, a ...interface{}) {
-       s := fmt.Sprintf(format, a...)
-       *p = append(*p, s)
-}
-
-// Diff returns a slice where each element describes
-// a difference between a and b.
-func Diff(a, b interface{}) (desc []string) {
-       Pdiff((*sbuf)(&desc), a, b)
-       return desc
-}
-
-// wprintfer calls Fprintf on w for each Printf call
-// with a trailing newline.
-type wprintfer struct{ w io.Writer }
-
-func (p *wprintfer) Printf(format string, a ...interface{}) {
-       fmt.Fprintf(p.w, format+"\n", a...)
-}
-
-// Fdiff writes to w a description of the differences between a and b.
-func Fdiff(w io.Writer, a, b interface{}) {
-       Pdiff(&wprintfer{w}, a, b)
-}
-
-type Printfer interface {
-       Printf(format string, a ...interface{})
-}
-
-// Pdiff prints to p a description of the differences between a and b.
-// It calls Printf once for each difference, with no trailing newline.
-// The standard library log.Logger is a Printfer.
-func Pdiff(p Printfer, a, b interface{}) {
-       diffPrinter{w: p}.diff(reflect.ValueOf(a), reflect.ValueOf(b))
-}
-
-type Logfer interface {
-       Logf(format string, a ...interface{})
-}
-
-// logprintfer calls Fprintf on w for each Printf call
-// with a trailing newline.
-type logprintfer struct{ l Logfer }
-
-func (p *logprintfer) Printf(format string, a ...interface{}) {
-       p.l.Logf(format, a...)
-}
-
-// Ldiff prints to l a description of the differences between a and b.
-// It calls Logf once for each difference, with no trailing newline.
-// The standard library testing.T and testing.B are Logfers.
-func Ldiff(l Logfer, a, b interface{}) {
-       Pdiff(&logprintfer{l}, a, b)
-}
-
-type diffPrinter struct {
-       w Printfer
-       l string // label
-}
-
-func (w diffPrinter) printf(f string, a ...interface{}) {
-       var l string
-       if w.l != "" {
-               l = w.l + ": "
-       }
-       w.w.Printf(l+f, a...)
-}
-
-func (w diffPrinter) diff(av, bv reflect.Value) {
-       if !av.IsValid() && bv.IsValid() {
-               w.printf("nil != %# v", formatter{v: bv, quote: true})
-               return
-       }
-       if av.IsValid() && !bv.IsValid() {
-               w.printf("%# v != nil", formatter{v: av, quote: true})
-               return
-       }
-       if !av.IsValid() && !bv.IsValid() {
-               return
-       }
-
-       at := av.Type()
-       bt := bv.Type()
-       if at != bt {
-               w.printf("%v != %v", at, bt)
-               return
-       }
-
-       switch kind := at.Kind(); kind {
-       case reflect.Bool:
-               if a, b := av.Bool(), bv.Bool(); a != b {
-                       w.printf("%v != %v", a, b)
-               }
-       case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, 
reflect.Int64:
-               if a, b := av.Int(), bv.Int(); a != b {
-                       w.printf("%d != %d", a, b)
-               }
-       case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, 
reflect.Uint64, reflect.Uintptr:
-               if a, b := av.Uint(), bv.Uint(); a != b {
-                       w.printf("%d != %d", a, b)
-               }
-       case reflect.Float32, reflect.Float64:
-               if a, b := av.Float(), bv.Float(); a != b {
-                       w.printf("%v != %v", a, b)
-               }
-       case reflect.Complex64, reflect.Complex128:
-               if a, b := av.Complex(), bv.Complex(); a != b {
-                       w.printf("%v != %v", a, b)
-               }
-       case reflect.Array:
-               n := av.Len()
-               for i := 0; i < n; i++ {
-                       w.relabel(fmt.Sprintf("[%d]", i)).diff(av.Index(i), 
bv.Index(i))
-               }
-       case reflect.Chan, reflect.Func, reflect.UnsafePointer:
-               if a, b := av.Pointer(), bv.Pointer(); a != b {
-                       w.printf("%#x != %#x", a, b)
-               }
-       case reflect.Interface:
-               w.diff(av.Elem(), bv.Elem())
-       case reflect.Map:
-               ak, both, bk := keyDiff(av.MapKeys(), bv.MapKeys())
-               for _, k := range ak {
-                       w := w.relabel(fmt.Sprintf("[%#v]", k))
-                       w.printf("%q != (missing)", av.MapIndex(k))
-               }
-               for _, k := range both {
-                       w := w.relabel(fmt.Sprintf("[%#v]", k))
-                       w.diff(av.MapIndex(k), bv.MapIndex(k))
-               }
-               for _, k := range bk {
-                       w := w.relabel(fmt.Sprintf("[%#v]", k))
-                       w.printf("(missing) != %q", bv.MapIndex(k))
-               }
-       case reflect.Ptr:
-               switch {
-               case av.IsNil() && !bv.IsNil():
-                       w.printf("nil != %# v", formatter{v: bv, quote: true})
-               case !av.IsNil() && bv.IsNil():
-                       w.printf("%# v != nil", formatter{v: av, quote: true})
-               case !av.IsNil() && !bv.IsNil():
-                       w.diff(av.Elem(), bv.Elem())
-               }
-       case reflect.Slice:
-               lenA := av.Len()
-               lenB := bv.Len()
-               if lenA != lenB {
-                       w.printf("%s[%d] != %s[%d]", av.Type(), lenA, 
bv.Type(), lenB)
-                       break
-               }
-               for i := 0; i < lenA; i++ {
-                       w.relabel(fmt.Sprintf("[%d]", i)).diff(av.Index(i), 
bv.Index(i))
-               }
-       case reflect.String:
-               if a, b := av.String(), bv.String(); a != b {
-                       w.printf("%q != %q", a, b)
-               }
-       case reflect.Struct:
-               for i := 0; i < av.NumField(); i++ {
-                       w.relabel(at.Field(i).Name).diff(av.Field(i), 
bv.Field(i))
-               }
-       default:
-               panic("unknown reflect Kind: " + kind.String())
-       }
-}
-
-func (d diffPrinter) relabel(name string) (d1 diffPrinter) {
-       d1 = d
-       if d.l != "" && name[0] != '[' {
-               d1.l += "."
-       }
-       d1.l += name
-       return d1
-}
-
-// keyEqual compares a and b for equality.
-// Both a and b must be valid map keys.
-func keyEqual(av, bv reflect.Value) bool {
-       if !av.IsValid() && !bv.IsValid() {
-               return true
-       }
-       if !av.IsValid() || !bv.IsValid() || av.Type() != bv.Type() {
-               return false
-       }
-       switch kind := av.Kind(); kind {
-       case reflect.Bool:
-               a, b := av.Bool(), bv.Bool()
-               return a == b
-       case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, 
reflect.Int64:
-               a, b := av.Int(), bv.Int()
-               return a == b
-       case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, 
reflect.Uint64, reflect.Uintptr:
-               a, b := av.Uint(), bv.Uint()
-               return a == b
-       case reflect.Float32, reflect.Float64:
-               a, b := av.Float(), bv.Float()
-               return a == b
-       case reflect.Complex64, reflect.Complex128:
-               a, b := av.Complex(), bv.Complex()
-               return a == b
-       case reflect.Array:
-               for i := 0; i < av.Len(); i++ {
-                       if !keyEqual(av.Index(i), bv.Index(i)) {
-                               return false
-                       }
-               }
-               return true
-       case reflect.Chan, reflect.UnsafePointer, reflect.Ptr:
-               a, b := av.Pointer(), bv.Pointer()
-               return a == b
-       case reflect.Interface:
-               return keyEqual(av.Elem(), bv.Elem())
-       case reflect.String:
-               a, b := av.String(), bv.String()
-               return a == b
-       case reflect.Struct:
-               for i := 0; i < av.NumField(); i++ {
-                       if !keyEqual(av.Field(i), bv.Field(i)) {
-                               return false
-                       }
-               }
-               return true
-       default:
-               panic("invalid map key type " + av.Type().String())
-       }
-}
-
-func keyDiff(a, b []reflect.Value) (ak, both, bk []reflect.Value) {
-       for _, av := range a {
-               inBoth := false
-               for _, bv := range b {
-                       if keyEqual(av, bv) {
-                               inBoth = true
-                               both = append(both, av)
-                               break
-                       }
-               }
-               if !inBoth {
-                       ak = append(ak, av)
-               }
-       }
-       for _, bv := range b {
-               inBoth := false
-               for _, av := range a {
-                       if keyEqual(av, bv) {
-                               inBoth = true
-                               break
-                       }
-               }
-               if !inBoth {
-                       bk = append(bk, bv)
-               }
-       }
-       return
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/formatter.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/formatter.go 
b/newt/vendor/github.com/kr/pretty/formatter.go
deleted file mode 100644
index a317d7b..0000000
--- a/newt/vendor/github.com/kr/pretty/formatter.go
+++ /dev/null
@@ -1,328 +0,0 @@
-package pretty
-
-import (
-       "fmt"
-       "io"
-       "reflect"
-       "strconv"
-       "text/tabwriter"
-
-       "github.com/kr/text"
-)
-
-type formatter struct {
-       v     reflect.Value
-       force bool
-       quote bool
-}
-
-// Formatter makes a wrapper, f, that will format x as go source with line
-// breaks and tabs. Object f responds to the "%v" formatting verb when both the
-// "#" and " " (space) flags are set, for example:
-//
-//     fmt.Sprintf("%# v", Formatter(x))
-//
-// If one of these two flags is not set, or any other verb is used, f will
-// format x according to the usual rules of package fmt.
-// In particular, if x satisfies fmt.Formatter, then x.Format will be called.
-func Formatter(x interface{}) (f fmt.Formatter) {
-       return formatter{v: reflect.ValueOf(x), quote: true}
-}
-
-func (fo formatter) String() string {
-       return fmt.Sprint(fo.v.Interface()) // unwrap it
-}
-
-func (fo formatter) passThrough(f fmt.State, c rune) {
-       s := "%"
-       for i := 0; i < 128; i++ {
-               if f.Flag(i) {
-                       s += string(i)
-               }
-       }
-       if w, ok := f.Width(); ok {
-               s += fmt.Sprintf("%d", w)
-       }
-       if p, ok := f.Precision(); ok {
-               s += fmt.Sprintf(".%d", p)
-       }
-       s += string(c)
-       fmt.Fprintf(f, s, fo.v.Interface())
-}
-
-func (fo formatter) Format(f fmt.State, c rune) {
-       if fo.force || c == 'v' && f.Flag('#') && f.Flag(' ') {
-               w := tabwriter.NewWriter(f, 4, 4, 1, ' ', 0)
-               p := &printer{tw: w, Writer: w, visited: make(map[visit]int)}
-               p.printValue(fo.v, true, fo.quote)
-               w.Flush()
-               return
-       }
-       fo.passThrough(f, c)
-}
-
-type printer struct {
-       io.Writer
-       tw      *tabwriter.Writer
-       visited map[visit]int
-       depth   int
-}
-
-func (p *printer) indent() *printer {
-       q := *p
-       q.tw = tabwriter.NewWriter(p.Writer, 4, 4, 1, ' ', 0)
-       q.Writer = text.NewIndentWriter(q.tw, []byte{'\t'})
-       return &q
-}
-
-func (p *printer) printInline(v reflect.Value, x interface{}, showType bool) {
-       if showType {
-               io.WriteString(p, v.Type().String())
-               fmt.Fprintf(p, "(%#v)", x)
-       } else {
-               fmt.Fprintf(p, "%#v", x)
-       }
-}
-
-// printValue must keep track of already-printed pointer values to avoid
-// infinite recursion.
-type visit struct {
-       v   uintptr
-       typ reflect.Type
-}
-
-func (p *printer) printValue(v reflect.Value, showType, quote bool) {
-       if p.depth > 10 {
-               io.WriteString(p, "!%v(DEPTH EXCEEDED)")
-               return
-       }
-
-       switch v.Kind() {
-       case reflect.Bool:
-               p.printInline(v, v.Bool(), showType)
-       case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, 
reflect.Int64:
-               p.printInline(v, v.Int(), showType)
-       case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, 
reflect.Uint64, reflect.Uintptr:
-               p.printInline(v, v.Uint(), showType)
-       case reflect.Float32, reflect.Float64:
-               p.printInline(v, v.Float(), showType)
-       case reflect.Complex64, reflect.Complex128:
-               fmt.Fprintf(p, "%#v", v.Complex())
-       case reflect.String:
-               p.fmtString(v.String(), quote)
-       case reflect.Map:
-               t := v.Type()
-               if showType {
-                       io.WriteString(p, t.String())
-               }
-               writeByte(p, '{')
-               if nonzero(v) {
-                       expand := !canInline(v.Type())
-                       pp := p
-                       if expand {
-                               writeByte(p, '\n')
-                               pp = p.indent()
-                       }
-                       keys := v.MapKeys()
-                       for i := 0; i < v.Len(); i++ {
-                               showTypeInStruct := true
-                               k := keys[i]
-                               mv := v.MapIndex(k)
-                               pp.printValue(k, false, true)
-                               writeByte(pp, ':')
-                               if expand {
-                                       writeByte(pp, '\t')
-                               }
-                               showTypeInStruct = t.Elem().Kind() == 
reflect.Interface
-                               pp.printValue(mv, showTypeInStruct, true)
-                               if expand {
-                                       io.WriteString(pp, ",\n")
-                               } else if i < v.Len()-1 {
-                                       io.WriteString(pp, ", ")
-                               }
-                       }
-                       if expand {
-                               pp.tw.Flush()
-                       }
-               }
-               writeByte(p, '}')
-       case reflect.Struct:
-               t := v.Type()
-               if v.CanAddr() {
-                       addr := v.UnsafeAddr()
-                       vis := visit{addr, t}
-                       if vd, ok := p.visited[vis]; ok && vd < p.depth {
-                               p.fmtString(t.String()+"{(CYCLIC REFERENCE)}", 
false)
-                               break // don't print v again
-                       }
-                       p.visited[vis] = p.depth
-               }
-
-               if showType {
-                       io.WriteString(p, t.String())
-               }
-               writeByte(p, '{')
-               if nonzero(v) {
-                       expand := !canInline(v.Type())
-                       pp := p
-                       if expand {
-                               writeByte(p, '\n')
-                               pp = p.indent()
-                       }
-                       for i := 0; i < v.NumField(); i++ {
-                               showTypeInStruct := true
-                               if f := t.Field(i); f.Name != "" {
-                                       io.WriteString(pp, f.Name)
-                                       writeByte(pp, ':')
-                                       if expand {
-                                               writeByte(pp, '\t')
-                                       }
-                                       showTypeInStruct = labelType(f.Type)
-                               }
-                               pp.printValue(getField(v, i), showTypeInStruct, 
true)
-                               if expand {
-                                       io.WriteString(pp, ",\n")
-                               } else if i < v.NumField()-1 {
-                                       io.WriteString(pp, ", ")
-                               }
-                       }
-                       if expand {
-                               pp.tw.Flush()
-                       }
-               }
-               writeByte(p, '}')
-       case reflect.Interface:
-               switch e := v.Elem(); {
-               case e.Kind() == reflect.Invalid:
-                       io.WriteString(p, "nil")
-               case e.IsValid():
-                       pp := *p
-                       pp.depth++
-                       pp.printValue(e, showType, true)
-               default:
-                       io.WriteString(p, v.Type().String())
-                       io.WriteString(p, "(nil)")
-               }
-       case reflect.Array, reflect.Slice:
-               t := v.Type()
-               if showType {
-                       io.WriteString(p, t.String())
-               }
-               if v.Kind() == reflect.Slice && v.IsNil() && showType {
-                       io.WriteString(p, "(nil)")
-                       break
-               }
-               if v.Kind() == reflect.Slice && v.IsNil() {
-                       io.WriteString(p, "nil")
-                       break
-               }
-               writeByte(p, '{')
-               expand := !canInline(v.Type())
-               pp := p
-               if expand {
-                       writeByte(p, '\n')
-                       pp = p.indent()
-               }
-               for i := 0; i < v.Len(); i++ {
-                       showTypeInSlice := t.Elem().Kind() == reflect.Interface
-                       pp.printValue(v.Index(i), showTypeInSlice, true)
-                       if expand {
-                               io.WriteString(pp, ",\n")
-                       } else if i < v.Len()-1 {
-                               io.WriteString(pp, ", ")
-                       }
-               }
-               if expand {
-                       pp.tw.Flush()
-               }
-               writeByte(p, '}')
-       case reflect.Ptr:
-               e := v.Elem()
-               if !e.IsValid() {
-                       writeByte(p, '(')
-                       io.WriteString(p, v.Type().String())
-                       io.WriteString(p, ")(nil)")
-               } else {
-                       pp := *p
-                       pp.depth++
-                       writeByte(pp, '&')
-                       pp.printValue(e, true, true)
-               }
-       case reflect.Chan:
-               x := v.Pointer()
-               if showType {
-                       writeByte(p, '(')
-                       io.WriteString(p, v.Type().String())
-                       fmt.Fprintf(p, ")(%#v)", x)
-               } else {
-                       fmt.Fprintf(p, "%#v", x)
-               }
-       case reflect.Func:
-               io.WriteString(p, v.Type().String())
-               io.WriteString(p, " {...}")
-       case reflect.UnsafePointer:
-               p.printInline(v, v.Pointer(), showType)
-       case reflect.Invalid:
-               io.WriteString(p, "nil")
-       }
-}
-
-func canInline(t reflect.Type) bool {
-       switch t.Kind() {
-       case reflect.Map:
-               return !canExpand(t.Elem())
-       case reflect.Struct:
-               for i := 0; i < t.NumField(); i++ {
-                       if canExpand(t.Field(i).Type) {
-                               return false
-                       }
-               }
-               return true
-       case reflect.Interface:
-               return false
-       case reflect.Array, reflect.Slice:
-               return !canExpand(t.Elem())
-       case reflect.Ptr:
-               return false
-       case reflect.Chan, reflect.Func, reflect.UnsafePointer:
-               return false
-       }
-       return true
-}
-
-func canExpand(t reflect.Type) bool {
-       switch t.Kind() {
-       case reflect.Map, reflect.Struct,
-               reflect.Interface, reflect.Array, reflect.Slice,
-               reflect.Ptr:
-               return true
-       }
-       return false
-}
-
-func labelType(t reflect.Type) bool {
-       switch t.Kind() {
-       case reflect.Interface, reflect.Struct:
-               return true
-       }
-       return false
-}
-
-func (p *printer) fmtString(s string, quote bool) {
-       if quote {
-               s = strconv.Quote(s)
-       }
-       io.WriteString(p, s)
-}
-
-func writeByte(w io.Writer, b byte) {
-       w.Write([]byte{b})
-}
-
-func getField(v reflect.Value, i int) reflect.Value {
-       val := v.Field(i)
-       if val.Kind() == reflect.Interface && !val.IsNil() {
-               val = val.Elem()
-       }
-       return val
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/pretty.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/pretty.go 
b/newt/vendor/github.com/kr/pretty/pretty.go
deleted file mode 100644
index 49423ec..0000000
--- a/newt/vendor/github.com/kr/pretty/pretty.go
+++ /dev/null
@@ -1,108 +0,0 @@
-// Package pretty provides pretty-printing for Go values. This is
-// useful during debugging, to avoid wrapping long output lines in
-// the terminal.
-//
-// It provides a function, Formatter, that can be used with any
-// function that accepts a format string. It also provides
-// convenience wrappers for functions in packages fmt and log.
-package pretty
-
-import (
-       "fmt"
-       "io"
-       "log"
-       "reflect"
-)
-
-// Errorf is a convenience wrapper for fmt.Errorf.
-//
-// Calling Errorf(f, x, y) is equivalent to
-// fmt.Errorf(f, Formatter(x), Formatter(y)).
-func Errorf(format string, a ...interface{}) error {
-       return fmt.Errorf(format, wrap(a, false)...)
-}
-
-// Fprintf is a convenience wrapper for fmt.Fprintf.
-//
-// Calling Fprintf(w, f, x, y) is equivalent to
-// fmt.Fprintf(w, f, Formatter(x), Formatter(y)).
-func Fprintf(w io.Writer, format string, a ...interface{}) (n int, error 
error) {
-       return fmt.Fprintf(w, format, wrap(a, false)...)
-}
-
-// Log is a convenience wrapper for log.Printf.
-//
-// Calling Log(x, y) is equivalent to
-// log.Print(Formatter(x), Formatter(y)), but each operand is
-// formatted with "%# v".
-func Log(a ...interface{}) {
-       log.Print(wrap(a, true)...)
-}
-
-// Logf is a convenience wrapper for log.Printf.
-//
-// Calling Logf(f, x, y) is equivalent to
-// log.Printf(f, Formatter(x), Formatter(y)).
-func Logf(format string, a ...interface{}) {
-       log.Printf(format, wrap(a, false)...)
-}
-
-// Logln is a convenience wrapper for log.Printf.
-//
-// Calling Logln(x, y) is equivalent to
-// log.Println(Formatter(x), Formatter(y)), but each operand is
-// formatted with "%# v".
-func Logln(a ...interface{}) {
-       log.Println(wrap(a, true)...)
-}
-
-// Print pretty-prints its operands and writes to standard output.
-//
-// Calling Print(x, y) is equivalent to
-// fmt.Print(Formatter(x), Formatter(y)), but each operand is
-// formatted with "%# v".
-func Print(a ...interface{}) (n int, errno error) {
-       return fmt.Print(wrap(a, true)...)
-}
-
-// Printf is a convenience wrapper for fmt.Printf.
-//
-// Calling Printf(f, x, y) is equivalent to
-// fmt.Printf(f, Formatter(x), Formatter(y)).
-func Printf(format string, a ...interface{}) (n int, errno error) {
-       return fmt.Printf(format, wrap(a, false)...)
-}
-
-// Println pretty-prints its operands and writes to standard output.
-//
-// Calling Print(x, y) is equivalent to
-// fmt.Println(Formatter(x), Formatter(y)), but each operand is
-// formatted with "%# v".
-func Println(a ...interface{}) (n int, errno error) {
-       return fmt.Println(wrap(a, true)...)
-}
-
-// Sprint is a convenience wrapper for fmt.Sprintf.
-//
-// Calling Sprint(x, y) is equivalent to
-// fmt.Sprint(Formatter(x), Formatter(y)), but each operand is
-// formatted with "%# v".
-func Sprint(a ...interface{}) string {
-       return fmt.Sprint(wrap(a, true)...)
-}
-
-// Sprintf is a convenience wrapper for fmt.Sprintf.
-//
-// Calling Sprintf(f, x, y) is equivalent to
-// fmt.Sprintf(f, Formatter(x), Formatter(y)).
-func Sprintf(format string, a ...interface{}) string {
-       return fmt.Sprintf(format, wrap(a, false)...)
-}
-
-func wrap(a []interface{}, force bool) []interface{} {
-       w := make([]interface{}, len(a))
-       for i, x := range a {
-               w[i] = formatter{v: reflect.ValueOf(x), force: force}
-       }
-       return w
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/pretty/zero.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/pretty/zero.go 
b/newt/vendor/github.com/kr/pretty/zero.go
deleted file mode 100644
index abb5b6f..0000000
--- a/newt/vendor/github.com/kr/pretty/zero.go
+++ /dev/null
@@ -1,41 +0,0 @@
-package pretty
-
-import (
-       "reflect"
-)
-
-func nonzero(v reflect.Value) bool {
-       switch v.Kind() {
-       case reflect.Bool:
-               return v.Bool()
-       case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, 
reflect.Int64:
-               return v.Int() != 0
-       case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, 
reflect.Uint64, reflect.Uintptr:
-               return v.Uint() != 0
-       case reflect.Float32, reflect.Float64:
-               return v.Float() != 0
-       case reflect.Complex64, reflect.Complex128:
-               return v.Complex() != complex(0, 0)
-       case reflect.String:
-               return v.String() != ""
-       case reflect.Struct:
-               for i := 0; i < v.NumField(); i++ {
-                       if nonzero(getField(v, i)) {
-                               return true
-                       }
-               }
-               return false
-       case reflect.Array:
-               for i := 0; i < v.Len(); i++ {
-                       if nonzero(v.Index(i)) {
-                               return true
-                       }
-               }
-               return false
-       case reflect.Map, reflect.Interface, reflect.Slice, reflect.Ptr, 
reflect.Chan, reflect.Func:
-               return !v.IsNil()
-       case reflect.UnsafePointer:
-               return v.Pointer() != 0
-       }
-       return true
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/text/License
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/text/License 
b/newt/vendor/github.com/kr/text/License
deleted file mode 100644
index 480a328..0000000
--- a/newt/vendor/github.com/kr/text/License
+++ /dev/null
@@ -1,19 +0,0 @@
-Copyright 2012 Keith Rarick
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in
-all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/text/Readme
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/text/Readme 
b/newt/vendor/github.com/kr/text/Readme
deleted file mode 100644
index 7e6e7c0..0000000
--- a/newt/vendor/github.com/kr/text/Readme
+++ /dev/null
@@ -1,3 +0,0 @@
-This is a Go package for manipulating paragraphs of text.
-
-See http://go.pkgdoc.org/github.com/kr/text for full documentation.

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/text/doc.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/text/doc.go 
b/newt/vendor/github.com/kr/text/doc.go
deleted file mode 100644
index cf4c198..0000000
--- a/newt/vendor/github.com/kr/text/doc.go
+++ /dev/null
@@ -1,3 +0,0 @@
-// Package text provides rudimentary functions for manipulating text in
-// paragraphs.
-package text

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/text/indent.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/text/indent.go 
b/newt/vendor/github.com/kr/text/indent.go
deleted file mode 100644
index 4ebac45..0000000
--- a/newt/vendor/github.com/kr/text/indent.go
+++ /dev/null
@@ -1,74 +0,0 @@
-package text
-
-import (
-       "io"
-)
-
-// Indent inserts prefix at the beginning of each non-empty line of s. The
-// end-of-line marker is NL.
-func Indent(s, prefix string) string {
-       return string(IndentBytes([]byte(s), []byte(prefix)))
-}
-
-// IndentBytes inserts prefix at the beginning of each non-empty line of b.
-// The end-of-line marker is NL.
-func IndentBytes(b, prefix []byte) []byte {
-       var res []byte
-       bol := true
-       for _, c := range b {
-               if bol && c != '\n' {
-                       res = append(res, prefix...)
-               }
-               res = append(res, c)
-               bol = c == '\n'
-       }
-       return res
-}
-
-// Writer indents each line of its input.
-type indentWriter struct {
-       w   io.Writer
-       bol bool
-       pre [][]byte
-       sel int
-       off int
-}
-
-// NewIndentWriter makes a new write filter that indents the input
-// lines. Each line is prefixed in order with the corresponding
-// element of pre. If there are more lines than elements, the last
-// element of pre is repeated for each subsequent line.
-func NewIndentWriter(w io.Writer, pre ...[]byte) io.Writer {
-       return &indentWriter{
-               w:   w,
-               pre: pre,
-               bol: true,
-       }
-}
-
-// The only errors returned are from the underlying indentWriter.
-func (w *indentWriter) Write(p []byte) (n int, err error) {
-       for _, c := range p {
-               if w.bol {
-                       var i int
-                       i, err = w.w.Write(w.pre[w.sel][w.off:])
-                       w.off += i
-                       if err != nil {
-                               return n, err
-                       }
-               }
-               _, err = w.w.Write([]byte{c})
-               if err != nil {
-                       return n, err
-               }
-               n++
-               w.bol = c == '\n'
-               if w.bol {
-                       w.off = 0
-                       if w.sel < len(w.pre)-1 {
-                               w.sel++
-                       }
-               }
-       }
-       return n, nil
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/kr/text/wrap.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/kr/text/wrap.go 
b/newt/vendor/github.com/kr/text/wrap.go
deleted file mode 100644
index b09bb03..0000000
--- a/newt/vendor/github.com/kr/text/wrap.go
+++ /dev/null
@@ -1,86 +0,0 @@
-package text
-
-import (
-       "bytes"
-       "math"
-)
-
-var (
-       nl = []byte{'\n'}
-       sp = []byte{' '}
-)
-
-const defaultPenalty = 1e5
-
-// Wrap wraps s into a paragraph of lines of length lim, with minimal
-// raggedness.
-func Wrap(s string, lim int) string {
-       return string(WrapBytes([]byte(s), lim))
-}
-
-// WrapBytes wraps b into a paragraph of lines of length lim, with minimal
-// raggedness.
-func WrapBytes(b []byte, lim int) []byte {
-       words := bytes.Split(bytes.Replace(bytes.TrimSpace(b), nl, sp, -1), sp)
-       var lines [][]byte
-       for _, line := range WrapWords(words, 1, lim, defaultPenalty) {
-               lines = append(lines, bytes.Join(line, sp))
-       }
-       return bytes.Join(lines, nl)
-}
-
-// WrapWords is the low-level line-breaking algorithm, useful if you need more
-// control over the details of the text wrapping process. For most uses, either
-// Wrap or WrapBytes will be sufficient and more convenient.
-//
-// WrapWords splits a list of words into lines with minimal "raggedness",
-// treating each byte as one unit, accounting for spc units between adjacent
-// words on each line, and attempting to limit lines to lim units. Raggedness
-// is the total error over all lines, where error is the square of the
-// difference of the length of the line and lim. Too-long lines (which only
-// happen when a single word is longer than lim units) have pen penalty units
-// added to the error.
-func WrapWords(words [][]byte, spc, lim, pen int) [][][]byte {
-       n := len(words)
-
-       length := make([][]int, n)
-       for i := 0; i < n; i++ {
-               length[i] = make([]int, n)
-               length[i][i] = len(words[i])
-               for j := i + 1; j < n; j++ {
-                       length[i][j] = length[i][j-1] + spc + len(words[j])
-               }
-       }
-
-       nbrk := make([]int, n)
-       cost := make([]int, n)
-       for i := range cost {
-               cost[i] = math.MaxInt32
-       }
-       for i := n - 1; i >= 0; i-- {
-               if length[i][n-1] <= lim || i == n-1 {
-                       cost[i] = 0
-                       nbrk[i] = n
-               } else {
-                       for j := i + 1; j < n; j++ {
-                               d := lim - length[i][j-1]
-                               c := d*d + cost[j]
-                               if length[i][j-1] > lim {
-                                       c += pen // too-long lines get a worse 
penalty
-                               }
-                               if c < cost[i] {
-                                       cost[i] = c
-                                       nbrk[i] = j
-                               }
-                       }
-               }
-       }
-
-       var lines [][][]byte
-       i := 0
-       for i < n {
-               lines = append(lines, words[i:nbrk[i]])
-               i = nbrk[i]
-       }
-       return lines
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/mitchellh/mapstructure/.travis.yml
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/mitchellh/mapstructure/.travis.yml 
b/newt/vendor/github.com/mitchellh/mapstructure/.travis.yml
deleted file mode 100644
index 7f3fe9a..0000000
--- a/newt/vendor/github.com/mitchellh/mapstructure/.travis.yml
+++ /dev/null
@@ -1,7 +0,0 @@
-language: go 
-
-go: 
-  - 1.4
-  
-script:
-  - go test 

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/mitchellh/mapstructure/LICENSE
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/mitchellh/mapstructure/LICENSE 
b/newt/vendor/github.com/mitchellh/mapstructure/LICENSE
deleted file mode 100644
index f9c841a..0000000
--- a/newt/vendor/github.com/mitchellh/mapstructure/LICENSE
+++ /dev/null
@@ -1,21 +0,0 @@
-The MIT License (MIT)
-
-Copyright (c) 2013 Mitchell Hashimoto
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in
-all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/mitchellh/mapstructure/README.md
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/mitchellh/mapstructure/README.md 
b/newt/vendor/github.com/mitchellh/mapstructure/README.md
deleted file mode 100644
index 659d688..0000000
--- a/newt/vendor/github.com/mitchellh/mapstructure/README.md
+++ /dev/null
@@ -1,46 +0,0 @@
-# mapstructure
-
-mapstructure is a Go library for decoding generic map values to structures
-and vice versa, while providing helpful error handling.
-
-This library is most useful when decoding values from some data stream (JSON,
-Gob, etc.) where you don't _quite_ know the structure of the underlying data
-until you read a part of it. You can therefore read a `map[string]interface{}`
-and use this library to decode it into the proper underlying native Go
-structure.
-
-## Installation
-
-Standard `go get`:
-
-```
-$ go get github.com/mitchellh/mapstructure
-```
-
-## Usage & Example
-
-For usage and examples see the 
[Godoc](http://godoc.org/github.com/mitchellh/mapstructure).
-
-The `Decode` function has examples associated with it there.
-
-## But Why?!
-
-Go offers fantastic standard libraries for decoding formats such as JSON.
-The standard method is to have a struct pre-created, and populate that struct
-from the bytes of the encoded format. This is great, but the problem is if
-you have configuration or an encoding that changes slightly depending on
-specific fields. For example, consider this JSON:
-
-```json
-{
-  "type": "person",
-  "name": "Mitchell"
-}
-```
-
-Perhaps we can't populate a specific structure without first reading
-the "type" field from the JSON. We could always do two passes over the
-decoding of the JSON (reading the "type" first, and the rest later).
-However, it is much simpler to just decode this into a `map[string]interface{}`
-structure, read the "type" key, then use something like this library
-to decode it into the proper structure.

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/mitchellh/mapstructure/decode_hooks.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/mitchellh/mapstructure/decode_hooks.go 
b/newt/vendor/github.com/mitchellh/mapstructure/decode_hooks.go
deleted file mode 100644
index 115ae67..0000000
--- a/newt/vendor/github.com/mitchellh/mapstructure/decode_hooks.go
+++ /dev/null
@@ -1,154 +0,0 @@
-package mapstructure
-
-import (
-       "errors"
-       "reflect"
-       "strconv"
-       "strings"
-       "time"
-)
-
-// typedDecodeHook takes a raw DecodeHookFunc (an interface{}) and turns
-// it into the proper DecodeHookFunc type, such as DecodeHookFuncType.
-func typedDecodeHook(h DecodeHookFunc) DecodeHookFunc {
-       // Create variables here so we can reference them with the reflect pkg
-       var f1 DecodeHookFuncType
-       var f2 DecodeHookFuncKind
-
-       // Fill in the variables into this interface and the rest is done
-       // automatically using the reflect package.
-       potential := []interface{}{f1, f2}
-
-       v := reflect.ValueOf(h)
-       vt := v.Type()
-       for _, raw := range potential {
-               pt := reflect.ValueOf(raw).Type()
-               if vt.ConvertibleTo(pt) {
-                       return v.Convert(pt).Interface()
-               }
-       }
-
-       return nil
-}
-
-// DecodeHookExec executes the given decode hook. This should be used
-// since it'll naturally degrade to the older backwards compatible 
DecodeHookFunc
-// that took reflect.Kind instead of reflect.Type.
-func DecodeHookExec(
-       raw DecodeHookFunc,
-       from reflect.Type, to reflect.Type,
-       data interface{}) (interface{}, error) {
-       // Build our arguments that reflect expects
-       argVals := make([]reflect.Value, 3)
-       argVals[0] = reflect.ValueOf(from)
-       argVals[1] = reflect.ValueOf(to)
-       argVals[2] = reflect.ValueOf(data)
-
-       switch f := typedDecodeHook(raw).(type) {
-       case DecodeHookFuncType:
-               return f(from, to, data)
-       case DecodeHookFuncKind:
-               return f(from.Kind(), to.Kind(), data)
-       default:
-               return nil, errors.New("invalid decode hook signature")
-       }
-}
-
-// ComposeDecodeHookFunc creates a single DecodeHookFunc that
-// automatically composes multiple DecodeHookFuncs.
-//
-// The composed funcs are called in order, with the result of the
-// previous transformation.
-func ComposeDecodeHookFunc(fs ...DecodeHookFunc) DecodeHookFunc {
-       return func(
-               f reflect.Type,
-               t reflect.Type,
-               data interface{}) (interface{}, error) {
-               var err error
-               for _, f1 := range fs {
-                       data, err = DecodeHookExec(f1, f, t, data)
-                       if err != nil {
-                               return nil, err
-                       }
-
-                       // Modify the from kind to be correct with the new data
-                       f = nil
-                       if val := reflect.ValueOf(data); val.IsValid() {
-                               f = val.Type()
-                       }
-               }
-
-               return data, nil
-       }
-}
-
-// StringToSliceHookFunc returns a DecodeHookFunc that converts
-// string to []string by splitting on the given sep.
-func StringToSliceHookFunc(sep string) DecodeHookFunc {
-       return func(
-               f reflect.Kind,
-               t reflect.Kind,
-               data interface{}) (interface{}, error) {
-               if f != reflect.String || t != reflect.Slice {
-                       return data, nil
-               }
-
-               raw := data.(string)
-               if raw == "" {
-                       return []string{}, nil
-               }
-
-               return strings.Split(raw, sep), nil
-       }
-}
-
-// StringToTimeDurationHookFunc returns a DecodeHookFunc that converts
-// strings to time.Duration.
-func StringToTimeDurationHookFunc() DecodeHookFunc {
-       return func(
-               f reflect.Type,
-               t reflect.Type,
-               data interface{}) (interface{}, error) {
-               if f.Kind() != reflect.String {
-                       return data, nil
-               }
-               if t != reflect.TypeOf(time.Duration(5)) {
-                       return data, nil
-               }
-
-               // Convert it by parsing
-               return time.ParseDuration(data.(string))
-       }
-}
-
-func WeaklyTypedHook(
-       f reflect.Kind,
-       t reflect.Kind,
-       data interface{}) (interface{}, error) {
-       dataVal := reflect.ValueOf(data)
-       switch t {
-       case reflect.String:
-               switch f {
-               case reflect.Bool:
-                       if dataVal.Bool() {
-                               return "1", nil
-                       } else {
-                               return "0", nil
-                       }
-               case reflect.Float32:
-                       return strconv.FormatFloat(dataVal.Float(), 'f', -1, 
64), nil
-               case reflect.Int:
-                       return strconv.FormatInt(dataVal.Int(), 10), nil
-               case reflect.Slice:
-                       dataType := dataVal.Type()
-                       elemKind := dataType.Elem().Kind()
-                       if elemKind == reflect.Uint8 {
-                               return string(dataVal.Interface().([]uint8)), 
nil
-                       }
-               case reflect.Uint:
-                       return strconv.FormatUint(dataVal.Uint(), 10), nil
-               }
-       }
-
-       return data, nil
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/mitchellh/mapstructure/error.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/mitchellh/mapstructure/error.go 
b/newt/vendor/github.com/mitchellh/mapstructure/error.go
deleted file mode 100644
index 47a99e5..0000000
--- a/newt/vendor/github.com/mitchellh/mapstructure/error.go
+++ /dev/null
@@ -1,50 +0,0 @@
-package mapstructure
-
-import (
-       "errors"
-       "fmt"
-       "sort"
-       "strings"
-)
-
-// Error implements the error interface and can represents multiple
-// errors that occur in the course of a single decode.
-type Error struct {
-       Errors []string
-}
-
-func (e *Error) Error() string {
-       points := make([]string, len(e.Errors))
-       for i, err := range e.Errors {
-               points[i] = fmt.Sprintf("* %s", err)
-       }
-
-       sort.Strings(points)
-       return fmt.Sprintf(
-               "%d error(s) decoding:\n\n%s",
-               len(e.Errors), strings.Join(points, "\n"))
-}
-
-// WrappedErrors implements the errwrap.Wrapper interface to make this
-// return value more useful with the errwrap and go-multierror libraries.
-func (e *Error) WrappedErrors() []error {
-       if e == nil {
-               return nil
-       }
-
-       result := make([]error, len(e.Errors))
-       for i, e := range e.Errors {
-               result[i] = errors.New(e)
-       }
-
-       return result
-}
-
-func appendErrors(errors []string, err error) []string {
-       switch e := err.(type) {
-       case *Error:
-               return append(errors, e.Errors...)
-       default:
-               return append(errors, e.Error())
-       }
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/mitchellh/mapstructure/mapstructure.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/mitchellh/mapstructure/mapstructure.go 
b/newt/vendor/github.com/mitchellh/mapstructure/mapstructure.go
deleted file mode 100644
index b0ab89b..0000000
--- a/newt/vendor/github.com/mitchellh/mapstructure/mapstructure.go
+++ /dev/null
@@ -1,782 +0,0 @@
-// The mapstructure package exposes functionality to convert an
-// abitrary map[string]interface{} into a native Go structure.
-//
-// The Go structure can be arbitrarily complex, containing slices,
-// other structs, etc. and the decoder will properly decode nested
-// maps and so on into the proper structures in the native Go struct.
-// See the examples to see what the decoder is capable of.
-package mapstructure
-
-import (
-       "encoding/json"
-       "errors"
-       "fmt"
-       "reflect"
-       "sort"
-       "strconv"
-       "strings"
-)
-
-// DecodeHookFunc is the callback function that can be used for
-// data transformations. See "DecodeHook" in the DecoderConfig
-// struct.
-//
-// The type should be DecodeHookFuncType or DecodeHookFuncKind.
-// Either is accepted. Types are a superset of Kinds (Types can return
-// Kinds) and are generally a richer thing to use, but Kinds are simpler
-// if you only need those.
-//
-// The reason DecodeHookFunc is multi-typed is for backwards compatibility:
-// we started with Kinds and then realized Types were the better solution,
-// but have a promise to not break backwards compat so we now support
-// both.
-type DecodeHookFunc interface{}
-
-type DecodeHookFuncType func(reflect.Type, reflect.Type, interface{}) 
(interface{}, error)
-type DecodeHookFuncKind func(reflect.Kind, reflect.Kind, interface{}) 
(interface{}, error)
-
-// DecoderConfig is the configuration that is used to create a new decoder
-// and allows customization of various aspects of decoding.
-type DecoderConfig struct {
-       // DecodeHook, if set, will be called before any decoding and any
-       // type conversion (if WeaklyTypedInput is on). This lets you modify
-       // the values before they're set down onto the resulting struct.
-       //
-       // If an error is returned, the entire decode will fail with that
-       // error.
-       DecodeHook DecodeHookFunc
-
-       // If ErrorUnused is true, then it is an error for there to exist
-       // keys in the original map that were unused in the decoding process
-       // (extra keys).
-       ErrorUnused bool
-
-       // ZeroFields, if set to true, will zero fields before writing them.
-       // For example, a map will be emptied before decoded values are put in
-       // it. If this is false, a map will be merged.
-       ZeroFields bool
-
-       // If WeaklyTypedInput is true, the decoder will make the following
-       // "weak" conversions:
-       //
-       //   - bools to string (true = "1", false = "0")
-       //   - numbers to string (base 10)
-       //   - bools to int/uint (true = 1, false = 0)
-       //   - strings to int/uint (base implied by prefix)
-       //   - int to bool (true if value != 0)
-       //   - string to bool (accepts: 1, t, T, TRUE, true, True, 0, f, F,
-       //     FALSE, false, False. Anything else is an error)
-       //   - empty array = empty map and vice versa
-       //   - negative numbers to overflowed uint values (base 10)
-       //   - slice of maps to a merged map
-       //
-       WeaklyTypedInput bool
-
-       // Metadata is the struct that will contain extra metadata about
-       // the decoding. If this is nil, then no metadata will be tracked.
-       Metadata *Metadata
-
-       // Result is a pointer to the struct that will contain the decoded
-       // value.
-       Result interface{}
-
-       // The tag name that mapstructure reads for field names. This
-       // defaults to "mapstructure"
-       TagName string
-}
-
-// A Decoder takes a raw interface value and turns it into structured
-// data, keeping track of rich error information along the way in case
-// anything goes wrong. Unlike the basic top-level Decode method, you can
-// more finely control how the Decoder behaves using the DecoderConfig
-// structure. The top-level Decode method is just a convenience that sets
-// up the most basic Decoder.
-type Decoder struct {
-       config *DecoderConfig
-}
-
-// Metadata contains information about decoding a structure that
-// is tedious or difficult to get otherwise.
-type Metadata struct {
-       // Keys are the keys of the structure which were successfully decoded
-       Keys []string
-
-       // Unused is a slice of keys that were found in the raw value but
-       // weren't decoded since there was no matching field in the result 
interface
-       Unused []string
-}
-
-// Decode takes a map and uses reflection to convert it into the
-// given Go native structure. val must be a pointer to a struct.
-func Decode(m interface{}, rawVal interface{}) error {
-       config := &DecoderConfig{
-               Metadata: nil,
-               Result:   rawVal,
-       }
-
-       decoder, err := NewDecoder(config)
-       if err != nil {
-               return err
-       }
-
-       return decoder.Decode(m)
-}
-
-// WeakDecode is the same as Decode but is shorthand to enable
-// WeaklyTypedInput. See DecoderConfig for more info.
-func WeakDecode(input, output interface{}) error {
-       config := &DecoderConfig{
-               Metadata:         nil,
-               Result:           output,
-               WeaklyTypedInput: true,
-       }
-
-       decoder, err := NewDecoder(config)
-       if err != nil {
-               return err
-       }
-
-       return decoder.Decode(input)
-}
-
-// NewDecoder returns a new decoder for the given configuration. Once
-// a decoder has been returned, the same configuration must not be used
-// again.
-func NewDecoder(config *DecoderConfig) (*Decoder, error) {
-       val := reflect.ValueOf(config.Result)
-       if val.Kind() != reflect.Ptr {
-               return nil, errors.New("result must be a pointer")
-       }
-
-       val = val.Elem()
-       if !val.CanAddr() {
-               return nil, errors.New("result must be addressable (a pointer)")
-       }
-
-       if config.Metadata != nil {
-               if config.Metadata.Keys == nil {
-                       config.Metadata.Keys = make([]string, 0)
-               }
-
-               if config.Metadata.Unused == nil {
-                       config.Metadata.Unused = make([]string, 0)
-               }
-       }
-
-       if config.TagName == "" {
-               config.TagName = "mapstructure"
-       }
-
-       result := &Decoder{
-               config: config,
-       }
-
-       return result, nil
-}
-
-// Decode decodes the given raw interface to the target pointer specified
-// by the configuration.
-func (d *Decoder) Decode(raw interface{}) error {
-       return d.decode("", raw, reflect.ValueOf(d.config.Result).Elem())
-}
-
-// Decodes an unknown data type into a specific reflection value.
-func (d *Decoder) decode(name string, data interface{}, val reflect.Value) 
error {
-       if data == nil {
-               // If the data is nil, then we don't set anything.
-               return nil
-       }
-
-       dataVal := reflect.ValueOf(data)
-       if !dataVal.IsValid() {
-               // If the data value is invalid, then we just set the value
-               // to be the zero value.
-               val.Set(reflect.Zero(val.Type()))
-               return nil
-       }
-
-       if d.config.DecodeHook != nil {
-               // We have a DecodeHook, so let's pre-process the data.
-               var err error
-               data, err = DecodeHookExec(
-                       d.config.DecodeHook,
-                       dataVal.Type(), val.Type(), data)
-               if err != nil {
-                       return err
-               }
-       }
-
-       var err error
-       dataKind := getKind(val)
-       switch dataKind {
-       case reflect.Bool:
-               err = d.decodeBool(name, data, val)
-       case reflect.Interface:
-               err = d.decodeBasic(name, data, val)
-       case reflect.String:
-               err = d.decodeString(name, data, val)
-       case reflect.Int:
-               err = d.decodeInt(name, data, val)
-       case reflect.Uint:
-               err = d.decodeUint(name, data, val)
-       case reflect.Float32:
-               err = d.decodeFloat(name, data, val)
-       case reflect.Struct:
-               err = d.decodeStruct(name, data, val)
-       case reflect.Map:
-               err = d.decodeMap(name, data, val)
-       case reflect.Ptr:
-               err = d.decodePtr(name, data, val)
-       case reflect.Slice:
-               err = d.decodeSlice(name, data, val)
-       default:
-               // If we reached this point then we weren't able to decode it
-               return fmt.Errorf("%s: unsupported type: %s", name, dataKind)
-       }
-
-       // If we reached here, then we successfully decoded SOMETHING, so
-       // mark the key as used if we're tracking metadata.
-       if d.config.Metadata != nil && name != "" {
-               d.config.Metadata.Keys = append(d.config.Metadata.Keys, name)
-       }
-
-       return err
-}
-
-// This decodes a basic type (bool, int, string, etc.) and sets the
-// value to "data" of that type.
-func (d *Decoder) decodeBasic(name string, data interface{}, val 
reflect.Value) error {
-       dataVal := reflect.ValueOf(data)
-       if !dataVal.IsValid() {
-               dataVal = reflect.Zero(val.Type())
-       }
-
-       dataValType := dataVal.Type()
-       if !dataValType.AssignableTo(val.Type()) {
-               return fmt.Errorf(
-                       "'%s' expected type '%s', got '%s'",
-                       name, val.Type(), dataValType)
-       }
-
-       val.Set(dataVal)
-       return nil
-}
-
-func (d *Decoder) decodeString(name string, data interface{}, val 
reflect.Value) error {
-       dataVal := reflect.ValueOf(data)
-       dataKind := getKind(dataVal)
-
-       converted := true
-       switch {
-       case dataKind == reflect.String:
-               val.SetString(dataVal.String())
-       case dataKind == reflect.Bool && d.config.WeaklyTypedInput:
-               if dataVal.Bool() {
-                       val.SetString("1")
-               } else {
-                       val.SetString("0")
-               }
-       case dataKind == reflect.Int && d.config.WeaklyTypedInput:
-               val.SetString(strconv.FormatInt(dataVal.Int(), 10))
-       case dataKind == reflect.Uint && d.config.WeaklyTypedInput:
-               val.SetString(strconv.FormatUint(dataVal.Uint(), 10))
-       case dataKind == reflect.Float32 && d.config.WeaklyTypedInput:
-               val.SetString(strconv.FormatFloat(dataVal.Float(), 'f', -1, 64))
-       case dataKind == reflect.Slice && d.config.WeaklyTypedInput:
-               dataType := dataVal.Type()
-               elemKind := dataType.Elem().Kind()
-               switch {
-               case elemKind == reflect.Uint8:
-                       val.SetString(string(dataVal.Interface().([]uint8)))
-               default:
-                       converted = false
-               }
-       default:
-               converted = false
-       }
-
-       if !converted {
-               return fmt.Errorf(
-                       "'%s' expected type '%s', got unconvertible type '%s'",
-                       name, val.Type(), dataVal.Type())
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodeInt(name string, data interface{}, val reflect.Value) 
error {
-       dataVal := reflect.ValueOf(data)
-       dataKind := getKind(dataVal)
-       dataType := dataVal.Type()
-
-       switch {
-       case dataKind == reflect.Int:
-               val.SetInt(dataVal.Int())
-       case dataKind == reflect.Uint:
-               val.SetInt(int64(dataVal.Uint()))
-       case dataKind == reflect.Float32:
-               val.SetInt(int64(dataVal.Float()))
-       case dataKind == reflect.Bool && d.config.WeaklyTypedInput:
-               if dataVal.Bool() {
-                       val.SetInt(1)
-               } else {
-                       val.SetInt(0)
-               }
-       case dataKind == reflect.String && d.config.WeaklyTypedInput:
-               i, err := strconv.ParseInt(dataVal.String(), 0, 
val.Type().Bits())
-               if err == nil {
-                       val.SetInt(i)
-               } else {
-                       return fmt.Errorf("cannot parse '%s' as int: %s", name, 
err)
-               }
-       case dataType.PkgPath() == "encoding/json" && dataType.Name() == 
"Number":
-               jn := data.(json.Number)
-               i, err := jn.Int64()
-               if err != nil {
-                       return fmt.Errorf(
-                               "error decoding json.Number into %s: %s", name, 
err)
-               }
-               val.SetInt(i)
-       default:
-               return fmt.Errorf(
-                       "'%s' expected type '%s', got unconvertible type '%s'",
-                       name, val.Type(), dataVal.Type())
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodeUint(name string, data interface{}, val reflect.Value) 
error {
-       dataVal := reflect.ValueOf(data)
-       dataKind := getKind(dataVal)
-
-       switch {
-       case dataKind == reflect.Int:
-               i := dataVal.Int()
-               if i < 0 && !d.config.WeaklyTypedInput {
-                       return fmt.Errorf("cannot parse '%s', %d overflows 
uint",
-                               name, i)
-               }
-               val.SetUint(uint64(i))
-       case dataKind == reflect.Uint:
-               val.SetUint(dataVal.Uint())
-       case dataKind == reflect.Float32:
-               f := dataVal.Float()
-               if f < 0 && !d.config.WeaklyTypedInput {
-                       return fmt.Errorf("cannot parse '%s', %f overflows 
uint",
-                               name, f)
-               }
-               val.SetUint(uint64(f))
-       case dataKind == reflect.Bool && d.config.WeaklyTypedInput:
-               if dataVal.Bool() {
-                       val.SetUint(1)
-               } else {
-                       val.SetUint(0)
-               }
-       case dataKind == reflect.String && d.config.WeaklyTypedInput:
-               i, err := strconv.ParseUint(dataVal.String(), 0, 
val.Type().Bits())
-               if err == nil {
-                       val.SetUint(i)
-               } else {
-                       return fmt.Errorf("cannot parse '%s' as uint: %s", 
name, err)
-               }
-       default:
-               return fmt.Errorf(
-                       "'%s' expected type '%s', got unconvertible type '%s'",
-                       name, val.Type(), dataVal.Type())
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodeBool(name string, data interface{}, val reflect.Value) 
error {
-       dataVal := reflect.ValueOf(data)
-       dataKind := getKind(dataVal)
-
-       switch {
-       case dataKind == reflect.Bool:
-               val.SetBool(dataVal.Bool())
-       case dataKind == reflect.Int && d.config.WeaklyTypedInput:
-               val.SetBool(dataVal.Int() != 0)
-       case dataKind == reflect.Uint && d.config.WeaklyTypedInput:
-               val.SetBool(dataVal.Uint() != 0)
-       case dataKind == reflect.Float32 && d.config.WeaklyTypedInput:
-               val.SetBool(dataVal.Float() != 0)
-       case dataKind == reflect.String && d.config.WeaklyTypedInput:
-               b, err := strconv.ParseBool(dataVal.String())
-               if err == nil {
-                       val.SetBool(b)
-               } else if dataVal.String() == "" {
-                       val.SetBool(false)
-               } else {
-                       return fmt.Errorf("cannot parse '%s' as bool: %s", 
name, err)
-               }
-       default:
-               return fmt.Errorf(
-                       "'%s' expected type '%s', got unconvertible type '%s'",
-                       name, val.Type(), dataVal.Type())
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodeFloat(name string, data interface{}, val 
reflect.Value) error {
-       dataVal := reflect.ValueOf(data)
-       dataKind := getKind(dataVal)
-       dataType := dataVal.Type()
-
-       switch {
-       case dataKind == reflect.Int:
-               val.SetFloat(float64(dataVal.Int()))
-       case dataKind == reflect.Uint:
-               val.SetFloat(float64(dataVal.Uint()))
-       case dataKind == reflect.Float32:
-               val.SetFloat(float64(dataVal.Float()))
-       case dataKind == reflect.Bool && d.config.WeaklyTypedInput:
-               if dataVal.Bool() {
-                       val.SetFloat(1)
-               } else {
-                       val.SetFloat(0)
-               }
-       case dataKind == reflect.String && d.config.WeaklyTypedInput:
-               f, err := strconv.ParseFloat(dataVal.String(), 
val.Type().Bits())
-               if err == nil {
-                       val.SetFloat(f)
-               } else {
-                       return fmt.Errorf("cannot parse '%s' as float: %s", 
name, err)
-               }
-       case dataType.PkgPath() == "encoding/json" && dataType.Name() == 
"Number":
-               jn := data.(json.Number)
-               i, err := jn.Float64()
-               if err != nil {
-                       return fmt.Errorf(
-                               "error decoding json.Number into %s: %s", name, 
err)
-               }
-               val.SetFloat(i)
-       default:
-               return fmt.Errorf(
-                       "'%s' expected type '%s', got unconvertible type '%s'",
-                       name, val.Type(), dataVal.Type())
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodeMap(name string, data interface{}, val reflect.Value) 
error {
-       valType := val.Type()
-       valKeyType := valType.Key()
-       valElemType := valType.Elem()
-
-       // By default we overwrite keys in the current map
-       valMap := val
-
-       // If the map is nil or we're purposely zeroing fields, make a new map
-       if valMap.IsNil() || d.config.ZeroFields {
-               // Make a new map to hold our result
-               mapType := reflect.MapOf(valKeyType, valElemType)
-               valMap = reflect.MakeMap(mapType)
-       }
-
-       // Check input type
-       dataVal := reflect.Indirect(reflect.ValueOf(data))
-       if dataVal.Kind() != reflect.Map {
-               // In weak mode, we accept a slice of maps as an input...
-               if d.config.WeaklyTypedInput {
-                       switch dataVal.Kind() {
-                       case reflect.Array, reflect.Slice:
-                               // Special case for BC reasons (covered by 
tests)
-                               if dataVal.Len() == 0 {
-                                       val.Set(valMap)
-                                       return nil
-                               }
-
-                               for i := 0; i < dataVal.Len(); i++ {
-                                       err := d.decode(
-                                               fmt.Sprintf("%s[%d]", name, i),
-                                               dataVal.Index(i).Interface(), 
val)
-                                       if err != nil {
-                                               return err
-                                       }
-                               }
-
-                               return nil
-                       }
-               }
-
-               return fmt.Errorf("'%s' expected a map, got '%s'", name, 
dataVal.Kind())
-       }
-
-       // Accumulate errors
-       errors := make([]string, 0)
-
-       for _, k := range dataVal.MapKeys() {
-               fieldName := fmt.Sprintf("%s[%s]", name, k)
-
-               // First decode the key into the proper type
-               currentKey := reflect.Indirect(reflect.New(valKeyType))
-               if err := d.decode(fieldName, k.Interface(), currentKey); err 
!= nil {
-                       errors = appendErrors(errors, err)
-                       continue
-               }
-
-               // Next decode the data into the proper type
-               v := dataVal.MapIndex(k).Interface()
-               currentVal := reflect.Indirect(reflect.New(valElemType))
-               if err := d.decode(fieldName, v, currentVal); err != nil {
-                       errors = appendErrors(errors, err)
-                       continue
-               }
-
-               valMap.SetMapIndex(currentKey, currentVal)
-       }
-
-       // Set the built up map to the value
-       val.Set(valMap)
-
-       // If we had errors, return those
-       if len(errors) > 0 {
-               return &Error{errors}
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodePtr(name string, data interface{}, val reflect.Value) 
error {
-       // Create an element of the concrete (non pointer) type and decode
-       // into that. Then set the value of the pointer to this type.
-       valType := val.Type()
-       valElemType := valType.Elem()
-       realVal := reflect.New(valElemType)
-       if err := d.decode(name, data, reflect.Indirect(realVal)); err != nil {
-               return err
-       }
-
-       val.Set(realVal)
-       return nil
-}
-
-func (d *Decoder) decodeSlice(name string, data interface{}, val 
reflect.Value) error {
-       dataVal := reflect.Indirect(reflect.ValueOf(data))
-       dataValKind := dataVal.Kind()
-       valType := val.Type()
-       valElemType := valType.Elem()
-       sliceType := reflect.SliceOf(valElemType)
-
-       // Check input type
-       if dataValKind != reflect.Array && dataValKind != reflect.Slice {
-               // Accept empty map instead of array/slice in weakly typed mode
-               if d.config.WeaklyTypedInput && dataVal.Kind() == reflect.Map 
&& dataVal.Len() == 0 {
-                       val.Set(reflect.MakeSlice(sliceType, 0, 0))
-                       return nil
-               } else {
-                       return fmt.Errorf(
-                               "'%s': source data must be an array or slice, 
got %s", name, dataValKind)
-               }
-       }
-
-       // Make a new slice to hold our result, same size as the original data.
-       valSlice := reflect.MakeSlice(sliceType, dataVal.Len(), dataVal.Len())
-
-       // Accumulate any errors
-       errors := make([]string, 0)
-
-       for i := 0; i < dataVal.Len(); i++ {
-               currentData := dataVal.Index(i).Interface()
-               currentField := valSlice.Index(i)
-
-               fieldName := fmt.Sprintf("%s[%d]", name, i)
-               if err := d.decode(fieldName, currentData, currentField); err 
!= nil {
-                       errors = appendErrors(errors, err)
-               }
-       }
-
-       // Finally, set the value to the slice we built up
-       val.Set(valSlice)
-
-       // If there were errors, we return those
-       if len(errors) > 0 {
-               return &Error{errors}
-       }
-
-       return nil
-}
-
-func (d *Decoder) decodeStruct(name string, data interface{}, val 
reflect.Value) error {
-       dataVal := reflect.Indirect(reflect.ValueOf(data))
-
-       // If the type of the value to write to and the data match directly,
-       // then we just set it directly instead of recursing into the structure.
-       if dataVal.Type() == val.Type() {
-               val.Set(dataVal)
-               return nil
-       }
-
-       dataValKind := dataVal.Kind()
-       if dataValKind != reflect.Map {
-               return fmt.Errorf("'%s' expected a map, got '%s'", name, 
dataValKind)
-       }
-
-       dataValType := dataVal.Type()
-       if kind := dataValType.Key().Kind(); kind != reflect.String && kind != 
reflect.Interface {
-               return fmt.Errorf(
-                       "'%s' needs a map with string keys, has '%s' keys",
-                       name, dataValType.Key().Kind())
-       }
-
-       dataValKeys := make(map[reflect.Value]struct{})
-       dataValKeysUnused := make(map[interface{}]struct{})
-       for _, dataValKey := range dataVal.MapKeys() {
-               dataValKeys[dataValKey] = struct{}{}
-               dataValKeysUnused[dataValKey.Interface()] = struct{}{}
-       }
-
-       errors := make([]string, 0)
-
-       // This slice will keep track of all the structs we'll be decoding.
-       // There can be more than one struct if there are embedded structs
-       // that are squashed.
-       structs := make([]reflect.Value, 1, 5)
-       structs[0] = val
-
-       // Compile the list of all the fields that we're going to be decoding
-       // from all the structs.
-       fields := make(map[*reflect.StructField]reflect.Value)
-       for len(structs) > 0 {
-               structVal := structs[0]
-               structs = structs[1:]
-
-               structType := structVal.Type()
-
-               for i := 0; i < structType.NumField(); i++ {
-                       fieldType := structType.Field(i)
-                       fieldKind := fieldType.Type.Kind()
-
-                       // If "squash" is specified in the tag, we squash the 
field down.
-                       squash := false
-                       tagParts := 
strings.Split(fieldType.Tag.Get(d.config.TagName), ",")
-                       for _, tag := range tagParts[1:] {
-                               if tag == "squash" {
-                                       squash = true
-                                       break
-                               }
-                       }
-
-                       if squash {
-                               if fieldKind != reflect.Struct {
-                                       errors = appendErrors(errors,
-                                               fmt.Errorf("%s: unsupported 
type for squash: %s", fieldType.Name, fieldKind))
-                               } else {
-                                       structs = append(structs, 
val.FieldByName(fieldType.Name))
-                               }
-                               continue
-                       }
-
-                       // Normal struct field, store it away
-                       fields[&fieldType] = structVal.Field(i)
-               }
-       }
-
-       for fieldType, field := range fields {
-               fieldName := fieldType.Name
-
-               tagValue := fieldType.Tag.Get(d.config.TagName)
-               tagValue = strings.SplitN(tagValue, ",", 2)[0]
-               if tagValue != "" {
-                       fieldName = tagValue
-               }
-
-               rawMapKey := reflect.ValueOf(fieldName)
-               rawMapVal := dataVal.MapIndex(rawMapKey)
-               if !rawMapVal.IsValid() {
-                       // Do a slower search by iterating over each key and
-                       // doing case-insensitive search.
-                       for dataValKey := range dataValKeys {
-                               mK, ok := dataValKey.Interface().(string)
-                               if !ok {
-                                       // Not a string key
-                                       continue
-                               }
-
-                               if strings.EqualFold(mK, fieldName) {
-                                       rawMapKey = dataValKey
-                                       rawMapVal = dataVal.MapIndex(dataValKey)
-                                       break
-                               }
-                       }
-
-                       if !rawMapVal.IsValid() {
-                               // There was no matching key in the map for the 
value in
-                               // the struct. Just ignore.
-                               continue
-                       }
-               }
-
-               // Delete the key we're using from the unused map so we stop 
tracking
-               delete(dataValKeysUnused, rawMapKey.Interface())
-
-               if !field.IsValid() {
-                       // This should never happen
-                       panic("field is not valid")
-               }
-
-               // If we can't set the field, then it is unexported or 
something,
-               // and we just continue onwards.
-               if !field.CanSet() {
-                       continue
-               }
-
-               // If the name is empty string, then we're at the root, and we
-               // don't dot-join the fields.
-               if name != "" {
-                       fieldName = fmt.Sprintf("%s.%s", name, fieldName)
-               }
-
-               if err := d.decode(fieldName, rawMapVal.Interface(), field); 
err != nil {
-                       errors = appendErrors(errors, err)
-               }
-       }
-
-       if d.config.ErrorUnused && len(dataValKeysUnused) > 0 {
-               keys := make([]string, 0, len(dataValKeysUnused))
-               for rawKey := range dataValKeysUnused {
-                       keys = append(keys, rawKey.(string))
-               }
-               sort.Strings(keys)
-
-               err := fmt.Errorf("'%s' has invalid keys: %s", name, 
strings.Join(keys, ", "))
-               errors = appendErrors(errors, err)
-       }
-
-       if len(errors) > 0 {
-               return &Error{errors}
-       }
-
-       // Add the unused keys to the list of unused keys if we're tracking 
metadata
-       if d.config.Metadata != nil {
-               for rawKey := range dataValKeysUnused {
-                       key := rawKey.(string)
-                       if name != "" {
-                               key = fmt.Sprintf("%s.%s", name, key)
-                       }
-
-                       d.config.Metadata.Unused = 
append(d.config.Metadata.Unused, key)
-               }
-       }
-
-       return nil
-}
-
-func getKind(val reflect.Value) reflect.Kind {
-       kind := val.Kind()
-
-       switch {
-       case kind >= reflect.Int && kind <= reflect.Int64:
-               return reflect.Int
-       case kind >= reflect.Uint && kind <= reflect.Uint64:
-               return reflect.Uint
-       case kind >= reflect.Float32 && kind <= reflect.Float64:
-               return reflect.Float32
-       default:
-               return kind
-       }
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/spf13/cast/.gitignore
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/spf13/cast/.gitignore 
b/newt/vendor/github.com/spf13/cast/.gitignore
deleted file mode 100644
index 53053a8..0000000
--- a/newt/vendor/github.com/spf13/cast/.gitignore
+++ /dev/null
@@ -1,25 +0,0 @@
-# Compiled Object files, Static and Dynamic libs (Shared Objects)
-*.o
-*.a
-*.so
-
-# Folders
-_obj
-_test
-
-# Architecture specific extensions/prefixes
-*.[568vq]
-[568vq].out
-
-*.cgo1.go
-*.cgo2.c
-_cgo_defun.c
-_cgo_gotypes.go
-_cgo_export.*
-
-_testmain.go
-
-*.exe
-*.test
-
-*.bench

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/spf13/cast/LICENSE
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/spf13/cast/LICENSE 
b/newt/vendor/github.com/spf13/cast/LICENSE
deleted file mode 100644
index 4527efb..0000000
--- a/newt/vendor/github.com/spf13/cast/LICENSE
+++ /dev/null
@@ -1,21 +0,0 @@
-The MIT License (MIT)
-
-Copyright (c) 2014 Steve Francia
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
-SOFTWARE.
\ No newline at end of file

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/spf13/cast/README.md
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/spf13/cast/README.md 
b/newt/vendor/github.com/spf13/cast/README.md
deleted file mode 100644
index af7a1fd..0000000
--- a/newt/vendor/github.com/spf13/cast/README.md
+++ /dev/null
@@ -1,72 +0,0 @@
-cast
-====
-
-Easy and safe casting from one type to another in Go
-
-Don’t Panic! ... Cast
-
-## What is Cast?
-
-Cast is a library to convert between different go types in a consistent and 
easy way.
-
-Cast provides simple functions to easily convert a number to a string, an
-interface into a bool, etc. Cast does this intelligently when an obvious
-conversion is possible. It doesn’t make any attempts to guess what you meant,
-for example you can only convert a string to an int when it is a string
-representation of an int such as “8”. Cast was developed for use in
-[Hugo](http://hugo.spf13.com), a website engine which uses YAML, TOML or JSON
-for meta data.
-
-## Why use Cast?
-
-When working with dynamic data in Go you often need to cast or convert the data
-from one type into another. Cast goes beyond just using type assertion (though
-it uses that when possible) to provide a very straightforward and convenient
-library.
-
-If you are working with interfaces to handle things like dynamic content
-you’ll need an easy way to convert an interface into a given type. This
-is the library for you.
-
-If you are taking in data from YAML, TOML or JSON or other formats which lack
-full types, then Cast is the library for you.
-
-## Usage
-
-Cast provides a handful of To_____ methods. These methods will always return
-the desired type. **If input is provided that will not convert to that type, 
the
-0 or nil value for that type will be returned**.
-
-Cast also provides identical methods To_____E. These return the same result as
-the To_____ methods, plus an additional error which tells you if it 
successfully
-converted. Using these methods you can tell the difference between when the
-input matched the zero value or when the conversion failed and the zero value
-was returned.
-
-The following examples are merely a sample of what is available. Please review
-the code for a complete set.
-
-### Example ‘ToString’:
-
-    cast.ToString("mayonegg")         // "mayonegg"
-    cast.ToString(8)                  // "8"
-    cast.ToString(8.31)               // "8.31"
-    cast.ToString([]byte("one time")) // "one time"
-    cast.ToString(nil)                // ""
-
-       var foo interface{} = "one more time"
-    cast.ToString(foo)                // "one more time"
-
-
-### Example ‘ToInt’:
-
-    cast.ToInt(8)                  // 8
-    cast.ToInt(8.31)               // 8
-    cast.ToInt("8")                // 8
-    cast.ToInt(true)               // 1
-    cast.ToInt(false)              // 0
-
-       var eight interface{} = 8
-    cast.ToInt(eight)              // 8
-    cast.ToInt(nil)                // 0
-

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/spf13/cast/cast.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/spf13/cast/cast.go 
b/newt/vendor/github.com/spf13/cast/cast.go
deleted file mode 100644
index 6ca3e0e..0000000
--- a/newt/vendor/github.com/spf13/cast/cast.go
+++ /dev/null
@@ -1,83 +0,0 @@
-// Copyright © 2014 Steve Francia <[email protected]>.
-//
-// Use of this source code is governed by an MIT-style
-// license that can be found in the LICENSE file.
-
-package cast
-
-import "time"
-
-func ToBool(i interface{}) bool {
-       v, _ := ToBoolE(i)
-       return v
-}
-
-func ToTime(i interface{}) time.Time {
-       v, _ := ToTimeE(i)
-       return v
-}
-
-func ToDuration(i interface{}) time.Duration {
-       v, _ := ToDurationE(i)
-       return v
-}
-
-func ToFloat64(i interface{}) float64 {
-       v, _ := ToFloat64E(i)
-       return v
-}
-
-func ToInt64(i interface{}) int64 {
-       v, _ := ToInt64E(i)
-       return v
-}
-
-func ToInt(i interface{}) int {
-       v, _ := ToIntE(i)
-       return v
-}
-
-func ToString(i interface{}) string {
-       v, _ := ToStringE(i)
-       return v
-}
-
-func ToStringMapString(i interface{}) map[string]string {
-       v, _ := ToStringMapStringE(i)
-       return v
-}
-
-func ToStringMapStringSlice(i interface{}) map[string][]string {
-       v, _ := ToStringMapStringSliceE(i)
-       return v
-}
-
-func ToStringMapBool(i interface{}) map[string]bool {
-       v, _ := ToStringMapBoolE(i)
-       return v
-}
-
-func ToStringMap(i interface{}) map[string]interface{} {
-       v, _ := ToStringMapE(i)
-       return v
-}
-
-func ToSlice(i interface{}) []interface{} {
-       v, _ := ToSliceE(i)
-       return v
-}
-
-func ToBoolSlice(i interface{}) []bool {
-       v, _ := ToBoolSliceE(i)
-       return v
-}
-
-func ToStringSlice(i interface{}) []string {
-       v, _ := ToStringSliceE(i)
-       return v
-}
-
-func ToIntSlice(i interface{}) []int {
-       v, _ := ToIntSliceE(i)
-       return v
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/spf13/cast/caste.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/spf13/cast/caste.go 
b/newt/vendor/github.com/spf13/cast/caste.go
deleted file mode 100644
index 23f0fe8..0000000
--- a/newt/vendor/github.com/spf13/cast/caste.go
+++ /dev/null
@@ -1,527 +0,0 @@
-// Copyright © 2014 Steve Francia <[email protected]>.
-//
-// Use of this source code is governed by an MIT-style
-// license that can be found in the LICENSE file.
-
-package cast
-
-import (
-       "fmt"
-       "html/template"
-       "reflect"
-       "strconv"
-       "strings"
-       "time"
-)
-
-// ToTimeE casts an empty interface to time.Time.
-func ToTimeE(i interface{}) (tim time.Time, err error) {
-       i = indirect(i)
-
-       switch s := i.(type) {
-       case time.Time:
-               return s, nil
-       case string:
-               d, e := StringToDate(s)
-               if e == nil {
-                       return d, nil
-               }
-               return time.Time{}, fmt.Errorf("Could not parse Date/Time 
format: %v\n", e)
-       default:
-               return time.Time{}, fmt.Errorf("Unable to Cast %#v to Time\n", 
i)
-       }
-}
-
-// ToDurationE casts an empty interface to time.Duration.
-func ToDurationE(i interface{}) (d time.Duration, err error) {
-       i = indirect(i)
-
-       switch s := i.(type) {
-       case time.Duration:
-               return s, nil
-       case int64, int32, int16, int8, int:
-               d = time.Duration(ToInt64(s))
-               return
-       case float32, float64:
-               d = time.Duration(ToFloat64(s))
-               return
-       case string:
-               if strings.ContainsAny(s, "nsuµmh") {
-                       d, err = time.ParseDuration(s)
-               } else {
-                       d, err = time.ParseDuration(s + "ns")
-               }
-               return
-       default:
-               err = fmt.Errorf("Unable to Cast %#v to Duration\n", i)
-               return
-       }
-}
-
-// ToBoolE casts an empty interface to a bool.
-func ToBoolE(i interface{}) (bool, error) {
-
-       i = indirect(i)
-
-       switch b := i.(type) {
-       case bool:
-               return b, nil
-       case nil:
-               return false, nil
-       case int:
-               if i.(int) != 0 {
-                       return true, nil
-               }
-               return false, nil
-       case string:
-               return strconv.ParseBool(i.(string))
-       default:
-               return false, fmt.Errorf("Unable to Cast %#v to bool", i)
-       }
-}
-
-// ToFloat64E casts an empty interface to a float64.
-func ToFloat64E(i interface{}) (float64, error) {
-       i = indirect(i)
-
-       switch s := i.(type) {
-       case float64:
-               return s, nil
-       case float32:
-               return float64(s), nil
-       case int64:
-               return float64(s), nil
-       case int32:
-               return float64(s), nil
-       case int16:
-               return float64(s), nil
-       case int8:
-               return float64(s), nil
-       case int:
-               return float64(s), nil
-       case string:
-               v, err := strconv.ParseFloat(s, 64)
-               if err == nil {
-                       return float64(v), nil
-               }
-               return 0.0, fmt.Errorf("Unable to Cast %#v to float", i)
-       default:
-               return 0.0, fmt.Errorf("Unable to Cast %#v to float", i)
-       }
-}
-
-// ToInt64E casts an empty interface to an int64.
-func ToInt64E(i interface{}) (int64, error) {
-       i = indirect(i)
-
-       switch s := i.(type) {
-       case int64:
-               return s, nil
-       case int:
-               return int64(s), nil
-       case int32:
-               return int64(s), nil
-       case int16:
-               return int64(s), nil
-       case int8:
-               return int64(s), nil
-       case string:
-               v, err := strconv.ParseInt(s, 0, 0)
-               if err == nil {
-                       return v, nil
-               }
-               return 0, fmt.Errorf("Unable to Cast %#v to int64", i)
-       case float64:
-               return int64(s), nil
-       case bool:
-               if bool(s) {
-                       return int64(1), nil
-               }
-               return int64(0), nil
-       case nil:
-               return int64(0), nil
-       default:
-               return int64(0), fmt.Errorf("Unable to Cast %#v to int64", i)
-       }
-}
-
-// ToIntE casts an empty interface to an int.
-func ToIntE(i interface{}) (int, error) {
-       i = indirect(i)
-
-       switch s := i.(type) {
-       case int:
-               return s, nil
-       case int64:
-               return int(s), nil
-       case int32:
-               return int(s), nil
-       case int16:
-               return int(s), nil
-       case int8:
-               return int(s), nil
-       case string:
-               v, err := strconv.ParseInt(s, 0, 0)
-               if err == nil {
-                       return int(v), nil
-               }
-               return 0, fmt.Errorf("Unable to Cast %#v to int", i)
-       case float64:
-               return int(s), nil
-       case bool:
-               if bool(s) {
-                       return 1, nil
-               }
-               return 0, nil
-       case nil:
-               return 0, nil
-       default:
-               return 0, fmt.Errorf("Unable to Cast %#v to int", i)
-       }
-}
-
-// From html/template/content.go
-// Copyright 2011 The Go Authors. All rights reserved.
-// indirect returns the value, after dereferencing as many times
-// as necessary to reach the base type (or nil).
-func indirect(a interface{}) interface{} {
-       if a == nil {
-               return nil
-       }
-       if t := reflect.TypeOf(a); t.Kind() != reflect.Ptr {
-               // Avoid creating a reflect.Value if it's not a pointer.
-               return a
-       }
-       v := reflect.ValueOf(a)
-       for v.Kind() == reflect.Ptr && !v.IsNil() {
-               v = v.Elem()
-       }
-       return v.Interface()
-}
-
-// From html/template/content.go
-// Copyright 2011 The Go Authors. All rights reserved.
-// indirectToStringerOrError returns the value, after dereferencing as many 
times
-// as necessary to reach the base type (or nil) or an implementation of 
fmt.Stringer
-// or error,
-func indirectToStringerOrError(a interface{}) interface{} {
-       if a == nil {
-               return nil
-       }
-
-       var errorType = reflect.TypeOf((*error)(nil)).Elem()
-       var fmtStringerType = reflect.TypeOf((*fmt.Stringer)(nil)).Elem()
-
-       v := reflect.ValueOf(a)
-       for !v.Type().Implements(fmtStringerType) && 
!v.Type().Implements(errorType) && v.Kind() == reflect.Ptr && !v.IsNil() {
-               v = v.Elem()
-       }
-       return v.Interface()
-}
-
-// ToStringE casts an empty interface to a string.
-func ToStringE(i interface{}) (string, error) {
-       i = indirectToStringerOrError(i)
-
-       switch s := i.(type) {
-       case string:
-               return s, nil
-       case bool:
-               return strconv.FormatBool(s), nil
-       case float64:
-               return strconv.FormatFloat(i.(float64), 'f', -1, 64), nil
-       case int64:
-               return strconv.FormatInt(i.(int64), 10), nil
-       case int:
-               return strconv.FormatInt(int64(i.(int)), 10), nil
-       case []byte:
-               return string(s), nil
-       case template.HTML:
-               return string(s), nil
-       case template.URL:
-               return string(s), nil
-       case template.JS:
-               return string(s), nil
-       case template.CSS:
-               return string(s), nil
-       case template.HTMLAttr:
-               return string(s), nil
-       case nil:
-               return "", nil
-       case fmt.Stringer:
-               return s.String(), nil
-       case error:
-               return s.Error(), nil
-       default:
-               return "", fmt.Errorf("Unable to Cast %#v to string", i)
-       }
-}
-
-// ToStringMapStringE casts an empty interface to a map[string]string.
-func ToStringMapStringE(i interface{}) (map[string]string, error) {
-
-       var m = map[string]string{}
-
-       switch v := i.(type) {
-       case map[string]string:
-               return v, nil
-       case map[string]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = ToString(val)
-               }
-               return m, nil
-       case map[interface{}]string:
-               for k, val := range v {
-                       m[ToString(k)] = ToString(val)
-               }
-               return m, nil
-       case map[interface{}]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = ToString(val)
-               }
-               return m, nil
-       default:
-               return m, fmt.Errorf("Unable to Cast %#v to map[string]string", 
i)
-       }
-}
-
-// ToStringMapStringSliceE casts an empty interface to a map[string][]string.
-func ToStringMapStringSliceE(i interface{}) (map[string][]string, error) {
-
-       var m = map[string][]string{}
-
-       switch v := i.(type) {
-       case map[string][]string:
-               return v, nil
-       case map[string][]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = ToStringSlice(val)
-               }
-               return m, nil
-       case map[string]string:
-               for k, val := range v {
-                       m[ToString(k)] = []string{val}
-               }
-       case map[string]interface{}:
-               for k, val := range v {
-                       switch vt := val.(type) {
-                       case []interface{}:
-                               m[ToString(k)] = ToStringSlice(vt)
-                       case []string:
-                               m[ToString(k)] = vt
-                       default:
-                               m[ToString(k)] = []string{ToString(val)}
-                       }
-               }
-               return m, nil
-       case map[interface{}][]string:
-               for k, val := range v {
-                       m[ToString(k)] = ToStringSlice(val)
-               }
-               return m, nil
-       case map[interface{}]string:
-               for k, val := range v {
-                       m[ToString(k)] = ToStringSlice(val)
-               }
-               return m, nil
-       case map[interface{}][]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = ToStringSlice(val)
-               }
-               return m, nil
-       case map[interface{}]interface{}:
-               for k, val := range v {
-                       key, err := ToStringE(k)
-                       if err != nil {
-                               return m, fmt.Errorf("Unable to Cast %#v to 
map[string][]string", i)
-                       }
-                       value, err := ToStringSliceE(val)
-                       if err != nil {
-                               return m, fmt.Errorf("Unable to Cast %#v to 
map[string][]string", i)
-                       }
-                       m[key] = value
-               }
-       default:
-               return m, fmt.Errorf("Unable to Cast %#v to 
map[string][]string", i)
-       }
-       return m, nil
-}
-
-// ToStringMapBoolE casts an empty interface to a map[string]bool.
-func ToStringMapBoolE(i interface{}) (map[string]bool, error) {
-
-       var m = map[string]bool{}
-
-       switch v := i.(type) {
-       case map[interface{}]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = ToBool(val)
-               }
-               return m, nil
-       case map[string]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = ToBool(val)
-               }
-               return m, nil
-       case map[string]bool:
-               return v, nil
-       default:
-               return m, fmt.Errorf("Unable to Cast %#v to map[string]bool", i)
-       }
-}
-
-// ToStringMapE casts an empty interface to a map[string]interface{}.
-func ToStringMapE(i interface{}) (map[string]interface{}, error) {
-
-       var m = map[string]interface{}{}
-
-       switch v := i.(type) {
-       case map[interface{}]interface{}:
-               for k, val := range v {
-                       m[ToString(k)] = val
-               }
-               return m, nil
-       case map[string]interface{}:
-               return v, nil
-       default:
-               return m, fmt.Errorf("Unable to Cast %#v to 
map[string]interface{}", i)
-       }
-}
-
-// ToSliceE casts an empty interface to a []interface{}.
-func ToSliceE(i interface{}) ([]interface{}, error) {
-
-       var s []interface{}
-
-       switch v := i.(type) {
-       case []interface{}:
-               for _, u := range v {
-                       s = append(s, u)
-               }
-               return s, nil
-       case []map[string]interface{}:
-               for _, u := range v {
-                       s = append(s, u)
-               }
-               return s, nil
-       default:
-               return s, fmt.Errorf("Unable to Cast %#v of type %v to 
[]interface{}", i, reflect.TypeOf(i))
-       }
-}
-
-// ToBoolSliceE casts an empty interface to a []bool.
-func ToBoolSliceE(i interface{}) ([]bool, error) {
-
-       if i == nil {
-               return []bool{}, fmt.Errorf("Unable to Cast %#v to []bool", i)
-       }
-
-       switch v := i.(type) {
-       case []bool:
-               return v, nil
-       }
-
-       kind := reflect.TypeOf(i).Kind()
-       switch kind {
-       case reflect.Slice, reflect.Array:
-               s := reflect.ValueOf(i)
-               a := make([]bool, s.Len())
-               for j := 0; j < s.Len(); j++ {
-                       val, err := ToBoolE(s.Index(j).Interface())
-                       if err != nil {
-                               return []bool{}, fmt.Errorf("Unable to Cast %#v 
to []bool", i)
-                       }
-                       a[j] = val
-               }
-               return a, nil
-       default:
-               return []bool{}, fmt.Errorf("Unable to Cast %#v to []bool", i)
-       }
-}
-
-// ToStringSliceE casts an empty interface to a []string.
-func ToStringSliceE(i interface{}) ([]string, error) {
-
-       var a []string
-
-       switch v := i.(type) {
-       case []interface{}:
-               for _, u := range v {
-                       a = append(a, ToString(u))
-               }
-               return a, nil
-       case []string:
-               return v, nil
-       case string:
-               return strings.Fields(v), nil
-       case interface{}:
-               str, err := ToStringE(v)
-               if err != nil {
-                       return a, fmt.Errorf("Unable to Cast %#v to []string", 
i)
-               }
-               return []string{str}, nil
-       default:
-               return a, fmt.Errorf("Unable to Cast %#v to []string", i)
-       }
-}
-
-// ToIntSliceE casts an empty interface to a []int.
-func ToIntSliceE(i interface{}) ([]int, error) {
-
-       if i == nil {
-               return []int{}, fmt.Errorf("Unable to Cast %#v to []int", i)
-       }
-
-       switch v := i.(type) {
-       case []int:
-               return v, nil
-       }
-
-       kind := reflect.TypeOf(i).Kind()
-       switch kind {
-       case reflect.Slice, reflect.Array:
-               s := reflect.ValueOf(i)
-               a := make([]int, s.Len())
-               for j := 0; j < s.Len(); j++ {
-                       val, err := ToIntE(s.Index(j).Interface())
-                       if err != nil {
-                               return []int{}, fmt.Errorf("Unable to Cast %#v 
to []int", i)
-                       }
-                       a[j] = val
-               }
-               return a, nil
-       default:
-               return []int{}, fmt.Errorf("Unable to Cast %#v to []int", i)
-       }
-}
-
-// StringToDate casts an empty interface to a time.Time.
-func StringToDate(s string) (time.Time, error) {
-       return parseDateWith(s, []string{
-               time.RFC3339,
-               "2006-01-02T15:04:05", // iso8601 without timezone
-               time.RFC1123Z,
-               time.RFC1123,
-               time.RFC822Z,
-               time.RFC822,
-               time.ANSIC,
-               time.UnixDate,
-               time.RubyDate,
-               "2006-01-02 15:04:05Z07:00",
-               "02 Jan 06 15:04 MST",
-               "2006-01-02",
-               "02 Jan 2006",
-               "2006-01-02 15:04:05 -07:00",
-               "2006-01-02 15:04:05 -0700",
-               "2006-01-02 15:04:05",
-       })
-}
-
-func parseDateWith(s string, dates []string) (d time.Time, e error) {
-       for _, dateType := range dates {
-               if d, e = time.Parse(dateType, s); e == nil {
-                       return
-               }
-       }
-       return d, fmt.Errorf("Unable to parse date: %s", s)
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/spf13/cobra/.gitignore
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/spf13/cobra/.gitignore 
b/newt/vendor/github.com/spf13/cobra/.gitignore
deleted file mode 100644
index 1b8c7c2..0000000
--- a/newt/vendor/github.com/spf13/cobra/.gitignore
+++ /dev/null
@@ -1,36 +0,0 @@
-# Compiled Object files, Static and Dynamic libs (Shared Objects)
-*.o
-*.a
-*.so
-
-# Folders
-_obj
-_test
-
-# Architecture specific extensions/prefixes
-*.[568vq]
-[568vq].out
-
-*.cgo1.go
-*.cgo2.c
-_cgo_defun.c
-_cgo_gotypes.go
-_cgo_export.*
-
-_testmain.go
-
-# Vim files 
https://github.com/github/gitignore/blob/master/Global/Vim.gitignore
-# swap
-[._]*.s[a-w][a-z]
-[._]s[a-w][a-z]
-# session
-Session.vim
-# temporary
-.netrwhist
-*~
-# auto-generated tag files
-tags
-
-*.exe
-
-cobra.test


Reply via email to