http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/toolchain/deps.go
----------------------------------------------------------------------
diff --git a/newt/toolchain/deps.go b/newt/toolchain/deps.go
deleted file mode 100644
index db04e6d..0000000
--- a/newt/toolchain/deps.go
+++ /dev/null
@@ -1,452 +0,0 @@
-/**
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements.  See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership.  The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License.  You may obtain a copy of the License at
- *
- *  http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied.  See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
-
-package toolchain
-
-import (
-       "bytes"
-       "io/ioutil"
-       "os"
-       "path/filepath"
-       "strings"
-       "time"
-
-       "mynewt.apache.org/newt/util"
-)
-
-type DepTracker struct {
-       // Most recent .o modification time.
-       MostRecent time.Time
-
-       compiler *Compiler
-}
-
-func NewDepTracker(c *Compiler) DepTracker {
-       tracker := DepTracker{
-               MostRecent: time.Unix(0, 0),
-               compiler:   c,
-       }
-
-       return tracker
-}
-
-// @return string               The name of the dependent file (i.e., the first
-//                                  .o file encountered).
-// @return []string             Populated with the dependencies' filenames.
-func parseDepsLine(line string) (string, []string, error) {
-       tokens := strings.Fields(line)
-       if len(tokens) == 0 {
-               return "", nil, nil
-       }
-
-       dFileTok := tokens[0]
-       if dFileTok[len(dFileTok)-1:] != ":" {
-               return "", nil, util.NewNewtError("line missing ':'")
-       }
-
-       dFileName := dFileTok[:len(dFileTok)-1]
-       return dFileName, tokens[1:], nil
-
-}
-
-// Parses a dependency (.d) file generated by gcc.  On success, the returned
-// string array is populated with the dependency filenames.  This function
-// expects each line of a dependency file to have the following format:
-//
-// <file>.o: <file>.c a.h b.h c.h \
-//  d.h e.h f.h
-//
-// Only the first dependent object(<file>.o) is considered.
-//
-// @return []string             Populated with the dependencies' filenames.
-func ParseDepsFile(filename string) ([]string, error) {
-       lines, err := util.ReadLines(filename)
-       if err != nil {
-               return nil, err
-       }
-
-       if len(lines) == 0 {
-               return []string{}, nil
-       }
-
-       var dFile string
-       allDeps := []string{}
-       for _, line := range lines {
-               src, deps, err := parseDepsLine(line)
-               if err != nil {
-                       return nil, util.FmtNewtError(
-                               "Invalid Makefile dependency file \"%s\"; %s",
-                               filename, err.Error())
-               }
-
-               if dFile == "" {
-                       dFile = src
-               }
-
-               if src == dFile {
-                       allDeps = append(allDeps, deps...)
-               }
-       }
-
-       return allDeps, nil
-}
-
-// Updates the dependency tracker's most recent timestamp according to the
-// modification time of the specified file.  If the specified file is older
-// than the tracker's currently most-recent time, this function has no effect.
-func (tracker *DepTracker) ProcessFileTime(file string) error {
-       modTime, err := util.FileModificationTime(file)
-       if err != nil {
-               return err
-       }
-
-       if modTime.After(tracker.MostRecent) {
-               tracker.MostRecent = modTime
-       }
-
-       return nil
-}
-
-// Determines if a file was previously built with a command line invocation
-// different from the one specified.
-//
-// @param dstFile               The output file whose build invocation is being
-//                                  tested.
-// @param cmd                   The command that would be used to generate the
-//                                  specified destination file.
-//
-// @return                      true if the command has changed or if the
-//                                  destination file was never built;
-//                              false otherwise.
-func commandHasChanged(dstFile string, cmd []string) bool {
-       cmdFile := dstFile + ".cmd"
-       prevCmd, err := ioutil.ReadFile(cmdFile)
-       if err != nil {
-               return true
-       }
-
-       curCmd := serializeCommand(cmd)
-
-       changed := bytes.Compare(prevCmd, curCmd) != 0
-       return changed
-}
-
-// Determines if the specified C or assembly file needs to be built.  A compile
-// is required if any of the following is true:
-//     * The destination object file does not exist.
-//     * The existing object file was built with a different compiler
-//       invocation.
-//     * The source file has a newer modification time than the object file.
-//     * One or more included header files has a newer modification time than
-//       the object file.
-func (tracker *DepTracker) CompileRequired(srcFile string,
-       compilerType int) (bool, error) {
-
-       objPath := tracker.compiler.dstFilePath(srcFile) + ".o"
-       depPath := tracker.compiler.dstFilePath(srcFile) + ".d"
-
-       // If the object was previously built with a different set of options, a
-       // rebuild is necessary.
-       cmd, err := tracker.compiler.CompileFileCmd(srcFile, compilerType)
-       if err != nil {
-               return false, err
-       }
-
-       if commandHasChanged(objPath, cmd) {
-               util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - rebuild 
required; "+
-                       "different command\n", srcFile)
-               err := tracker.compiler.GenDepsForFile(srcFile)
-               if err != nil {
-                       return false, err
-               }
-               return true, nil
-       }
-
-       if util.NodeNotExist(depPath) {
-               err := tracker.compiler.GenDepsForFile(srcFile)
-               if err != nil {
-                       return false, err
-               }
-       }
-
-       srcModTime, err := util.FileModificationTime(srcFile)
-       if err != nil {
-               return false, err
-       }
-
-       objModTime, err := util.FileModificationTime(objPath)
-       if err != nil {
-               return false, err
-       }
-
-       // If the object doesn't exist or is older than the source file, a 
build is
-       // required; no need to check dependencies.
-       if srcModTime.After(objModTime) {
-               util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - rebuild 
required; "+
-                       "source newer than obj\n", srcFile)
-               return true, nil
-       }
-
-       // Determine if the dependency (.d) file needs to be generated.  If it
-       // doesn't exist or is older than the source file, it is out of date and
-       // needs to be created.
-       depModTime, err := util.FileModificationTime(depPath)
-       if err != nil {
-               return false, err
-       }
-
-       if srcModTime.After(depModTime) {
-               err := tracker.compiler.GenDepsForFile(srcFile)
-               if err != nil {
-                       return false, err
-               }
-       }
-
-       // Extract the dependency filenames from the dependency file.
-       deps, err := ParseDepsFile(depPath)
-       if err != nil {
-               return false, err
-       }
-
-       // Check if any dependencies are newer than the destination object file.
-       for _, dep := range deps {
-               if util.NodeNotExist(dep) {
-                       // The dependency has been deleted; a rebuild is 
required.  Also,
-                       // the dependency file is out of date, so it needs to 
be deleted.
-                       // We cannot regenerate it now because the source file 
might be
-                       // including a nonexistent header.
-                       util.StatusMessage(util.VERBOSITY_VERBOSE,
-                               "%s - rebuild required; dependency \"%s\" has 
been deleted\n",
-                               srcFile, dep)
-                       os.Remove(depPath)
-                       return true, nil
-               } else {
-                       depModTime, err = util.FileModificationTime(dep)
-                       if err != nil {
-                               return false, err
-                       }
-               }
-
-               if depModTime.After(objModTime) {
-                       util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - 
rebuild required; obj older than dependency (%s)\n", srcFile, dep)
-                       return true, nil
-               }
-       }
-
-       return false, nil
-}
-
-// Determines if the specified static library needs to be rearchived.  The
-// library needs to be archived if any of the following is true:
-//     * The destination library file does not exist.
-//     * The existing library file was built with a different compiler
-//       invocation.
-//     * One or more source object files has a newer modification time than the
-//       library file.
-func (tracker *DepTracker) ArchiveRequired(archiveFile string,
-       objFiles []string) (bool, error) {
-
-       // If the archive was previously built with a different set of options, 
a
-       // rebuild is required.
-       cmd := tracker.compiler.CompileArchiveCmd(archiveFile, objFiles)
-       if commandHasChanged(archiveFile, cmd) {
-               return true, nil
-       }
-
-       // If the archive doesn't exist or is older than any object file, a 
rebuild
-       // is required.
-       aModTime, err := util.FileModificationTime(archiveFile)
-       if err != nil {
-               return false, err
-       }
-       if tracker.MostRecent.After(aModTime) {
-               return true, nil
-       }
-
-       // The library is up to date.
-       return false, nil
-}
-
-func (tracker *DepTracker) TrimmedArchiveRequired(dstFile string,
-       srcFile string, elfLib string) (bool, error) {
-
-       // If the .A file doesn't exist or is older than the input file, a 
rebuild
-       // is required.
-       dstModTime, err := util.FileModificationTime(dstFile)
-       if err != nil {
-               return false, err
-       }
-
-       // If the elf file doesn't exist or is older than any input file,
-       // a rebuild is required.
-       if elfLib != "" {
-               elfDstModTime, err := util.FileModificationTime(elfLib)
-               if err != nil {
-                       return false, err
-               }
-
-               if elfDstModTime.After(dstModTime) {
-                       return true, nil
-               }
-       }
-       objModTime, err := util.FileModificationTime(srcFile)
-       if err != nil {
-               return false, err
-       }
-
-       if objModTime.After(dstModTime) {
-               return true, nil
-       }
-       return false, nil
-}
-
-// Determines if the specified elf file needs to be linked.  Linking is
-// necessary if the elf file does not exist or has an older modification time
-// than any source object or library file.
-// Determines if the specified static library needs to be rearchived.  The
-// library needs to be archived if any of the following is true:
-//     * The destination library file does not exist.
-//     * The existing library file was built with a different compiler
-//       invocation.
-//     * One or more source object files has a newer modification time than the
-//       library file.
-func (tracker *DepTracker) LinkRequired(dstFile string,
-       options map[string]bool, objFiles []string,
-       keepSymbols []string, elfLib string) (bool, error) {
-
-       // If the elf file was previously built with a different set of 
options, a
-       // rebuild is required.
-       cmd := tracker.compiler.CompileBinaryCmd(dstFile, options, objFiles, 
keepSymbols, elfLib)
-       if commandHasChanged(dstFile, cmd) {
-               util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - link required; 
"+
-                       "different command\n", dstFile)
-               return true, nil
-       }
-
-       // If the elf file doesn't exist or is older than any input file, a 
rebuild
-       // is required.
-       dstModTime, err := util.FileModificationTime(dstFile)
-       if err != nil {
-               return false, err
-       }
-
-       // If the elf file doesn't exist or is older than any input file, a 
rebuild
-       // is required.
-       if elfLib != "" {
-               elfDstModTime, err := util.FileModificationTime(elfLib)
-               if err != nil {
-                       return false, err
-               }
-               if elfDstModTime.After(dstModTime) {
-                       util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - link 
required; "+
-                               "old elf file\n", elfLib)
-                       return true, nil
-               }
-       }
-
-       // Check timestamp of each .o file in the project.
-       if tracker.MostRecent.After(dstModTime) {
-               util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - link required; 
"+
-                       "source newer than elf\n", dstFile)
-               return true, nil
-       }
-
-       // Check timestamp of the linker script and all input libraries.
-       for _, ls := range tracker.compiler.LinkerScripts {
-               objFiles = append(objFiles, ls)
-       }
-       for _, obj := range objFiles {
-               objModTime, err := util.FileModificationTime(obj)
-               if err != nil {
-                       return false, err
-               }
-
-               if objModTime.After(dstModTime) {
-                       util.StatusMessage(util.VERBOSITY_VERBOSE, "%s - 
rebuild "+
-                               "required; obj older than dependency (%s)\n", 
dstFile, obj)
-                       return true, nil
-               }
-       }
-
-       return false, nil
-}
-
-/* Building a ROM elf is used for shared application linking.
- * A ROM elf requires a rebuild if any of archives (.a files) are newer
- * than the rom elf, or if the elf file is newer than the rom_elf */
-func (tracker *DepTracker) RomElfBuildRequired(dstFile string, elfFile string,
-       archFiles []string) (bool, error) {
-
-       // If the rom_elf file doesn't exist or is older than any input file, a
-       // rebuild is required.
-       dstModTime, err := util.FileModificationTime(dstFile)
-       if err != nil {
-               return false, err
-       }
-
-       // If the elf file doesn't exist or is older than any input file, a 
rebuild
-       // is required.
-       elfDstModTime, err := util.FileModificationTime(elfFile)
-       if err != nil {
-               return false, err
-       }
-
-       if elfDstModTime.After(dstModTime) {
-               return true, nil
-       }
-
-       for _, arch := range archFiles {
-               objModTime, err := util.FileModificationTime(arch)
-               if err != nil {
-                       return false, err
-               }
-
-               if objModTime.After(dstModTime) {
-                       return true, nil
-               }
-       }
-       return false, nil
-}
-
-// Determines if the specified static library needs to be copied.  The
-// library needs to be archived if any of the following is true:
-//     * The destination library file does not exist.
-//     * Source object files has a newer modification time than the
-//       target file.
-func (tracker *DepTracker) CopyRequired(srcFile string) (bool, error) {
-
-       tgtFile := tracker.compiler.DstDir() + "/" + filepath.Base(srcFile)
-
-       // If the target doesn't exist or is older than source file, a copy
-       // is required.
-       srcModTime, err := util.FileModificationTime(srcFile)
-       if err != nil {
-               return false, err
-       }
-       tgtModTime, err := util.FileModificationTime(tgtFile)
-       if err != nil {
-               return false, err
-       }
-       if srcModTime.After(tgtModTime) {
-               return true, nil
-       }
-
-       // The target is up to date.
-       return false, nil
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/.gitignore
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/.gitignore 
b/newt/vendor/github.com/Sirupsen/logrus/.gitignore
deleted file mode 100644
index 66be63a..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-logrus

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/.travis.yml
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/.travis.yml 
b/newt/vendor/github.com/Sirupsen/logrus/.travis.yml
deleted file mode 100644
index ec7dd78..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/.travis.yml
+++ /dev/null
@@ -1,9 +0,0 @@
-language: go
-go:
-  - 1.6
-  - 1.7
-  - tip
-install:
-  - go get -t $(go list ./... | grep -v /examples/)
-script:
-  - GOMAXPROCS=4 GORACE="halt_on_error=1" go test -race -v $(go list ./... | 
grep -v /examples/)

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/CHANGELOG.md
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/CHANGELOG.md 
b/newt/vendor/github.com/Sirupsen/logrus/CHANGELOG.md
deleted file mode 100644
index f2c2bc2..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/CHANGELOG.md
+++ /dev/null
@@ -1,66 +0,0 @@
-# 0.10.0
-
-* feature: Add a test hook (#180)
-* feature: `ParseLevel` is now case-insensitive (#326)
-* feature: `FieldLogger` interface that generalizes `Logger` and `Entry` (#308)
-* performance: avoid re-allocations on `WithFields` (#335)
-
-# 0.9.0
-
-* logrus/text_formatter: don't emit empty msg
-* logrus/hooks/airbrake: move out of main repository
-* logrus/hooks/sentry: move out of main repository
-* logrus/hooks/papertrail: move out of main repository
-* logrus/hooks/bugsnag: move out of main repository
-* logrus/core: run tests with `-race`
-* logrus/core: detect TTY based on `stderr`
-* logrus/core: support `WithError` on logger
-* logrus/core: Solaris support
-
-# 0.8.7
-
-* logrus/core: fix possible race (#216)
-* logrus/doc: small typo fixes and doc improvements
-
-
-# 0.8.6
-
-* hooks/raven: allow passing an initialized client
-
-# 0.8.5
-
-* logrus/core: revert #208
-
-# 0.8.4
-
-* formatter/text: fix data race (#218)
-
-# 0.8.3
-
-* logrus/core: fix entry log level (#208)
-* logrus/core: improve performance of text formatter by 40%
-* logrus/core: expose `LevelHooks` type
-* logrus/core: add support for DragonflyBSD and NetBSD
-* formatter/text: print structs more verbosely
-
-# 0.8.2
-
-* logrus: fix more Fatal family functions
-
-# 0.8.1
-
-* logrus: fix not exiting on `Fatalf` and `Fatalln`
-
-# 0.8.0
-
-* logrus: defaults to stderr instead of stdout
-* hooks/sentry: add special field for `*http.Request`
-* formatter/text: ignore Windows for colors
-
-# 0.7.3
-
-* formatter/\*: allow configuration of timestamp layout
-
-# 0.7.2
-
-* formatter/text: Add configuration option for time format (#158)

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/LICENSE
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/LICENSE 
b/newt/vendor/github.com/Sirupsen/logrus/LICENSE
deleted file mode 100644
index f090cb4..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/LICENSE
+++ /dev/null
@@ -1,21 +0,0 @@
-The MIT License (MIT)
-
-Copyright (c) 2014 Simon Eskildsen
-
-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/Sirupsen/logrus/README.md
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/README.md 
b/newt/vendor/github.com/Sirupsen/logrus/README.md
deleted file mode 100644
index f9cfb0a..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/README.md
+++ /dev/null
@@ -1,426 +0,0 @@
-# Logrus <img src="http://i.imgur.com/hTeVwmJ.png"; width="40" height="40" 
alt=":walrus:" class="emoji" title=":walrus:"/>&nbsp;[![Build 
Status](https://travis-ci.org/Sirupsen/logrus.svg?branch=master)](https://travis-ci.org/Sirupsen/logrus)&nbsp;[![GoDoc](https://godoc.org/github.com/Sirupsen/logrus?status.svg)](https://godoc.org/github.com/Sirupsen/logrus)
-
-Logrus is a structured logger for Go (golang), completely API compatible with
-the standard library logger. [Godoc][godoc]. **Please note the Logrus API is 
not
-yet stable (pre 1.0). Logrus itself is completely stable and has been used in
-many large deployments. The core API is unlikely to change much but please
-version control your Logrus to make sure you aren't fetching latest `master` on
-every build.**
-
-Nicely color-coded in development (when a TTY is attached, otherwise just
-plain text):
-
-![Colored](http://i.imgur.com/PY7qMwd.png)
-
-With `log.SetFormatter(&log.JSONFormatter{})`, for easy parsing by logstash
-or Splunk:
-
-```json
-{"animal":"walrus","level":"info","msg":"A group of walrus emerges from the
-ocean","size":10,"time":"2014-03-10 19:57:38.562264131 -0400 EDT"}
-
-{"level":"warning","msg":"The group's number increased tremendously!",
-"number":122,"omg":true,"time":"2014-03-10 19:57:38.562471297 -0400 EDT"}
-
-{"animal":"walrus","level":"info","msg":"A giant walrus appears!",
-"size":10,"time":"2014-03-10 19:57:38.562500591 -0400 EDT"}
-
-{"animal":"walrus","level":"info","msg":"Tremendously sized cow enters the 
ocean.",
-"size":9,"time":"2014-03-10 19:57:38.562527896 -0400 EDT"}
-
-{"level":"fatal","msg":"The ice breaks!","number":100,"omg":true,
-"time":"2014-03-10 19:57:38.562543128 -0400 EDT"}
-```
-
-With the default `log.SetFormatter(&log.TextFormatter{})` when a TTY is not
-attached, the output is compatible with the
-[logfmt](http://godoc.org/github.com/kr/logfmt) format:
-
-```text
-time="2015-03-26T01:27:38-04:00" level=debug msg="Started observing beach" 
animal=walrus number=8
-time="2015-03-26T01:27:38-04:00" level=info msg="A group of walrus emerges 
from the ocean" animal=walrus size=10
-time="2015-03-26T01:27:38-04:00" level=warning msg="The group's number 
increased tremendously!" number=122 omg=true
-time="2015-03-26T01:27:38-04:00" level=debug msg="Temperature changes" 
temperature=-4
-time="2015-03-26T01:27:38-04:00" level=panic msg="It's over 9000!" animal=orca 
size=9009
-time="2015-03-26T01:27:38-04:00" level=fatal msg="The ice breaks!" 
err=&{0x2082280c0 map[animal:orca size:9009] 2015-03-26 01:27:38.441574009 
-0400 EDT panic It's over 9000!} number=100 omg=true
-exit status 1
-```
-
-#### Example
-
-The simplest way to use Logrus is simply the package-level exported logger:
-
-```go
-package main
-
-import (
-  log "github.com/Sirupsen/logrus"
-)
-
-func main() {
-  log.WithFields(log.Fields{
-    "animal": "walrus",
-  }).Info("A walrus appears")
-}
-```
-
-Note that it's completely api-compatible with the stdlib logger, so you can
-replace your `log` imports everywhere with `log "github.com/Sirupsen/logrus"`
-and you'll now have the flexibility of Logrus. You can customize it all you
-want:
-
-```go
-package main
-
-import (
-  "os"
-  log "github.com/Sirupsen/logrus"
-)
-
-func init() {
-  // Log as JSON instead of the default ASCII formatter.
-  log.SetFormatter(&log.JSONFormatter{})
-
-  // Output to stderr instead of stdout, could also be a file.
-  log.SetOutput(os.Stderr)
-
-  // Only log the warning severity or above.
-  log.SetLevel(log.WarnLevel)
-}
-
-func main() {
-  log.WithFields(log.Fields{
-    "animal": "walrus",
-    "size":   10,
-  }).Info("A group of walrus emerges from the ocean")
-
-  log.WithFields(log.Fields{
-    "omg":    true,
-    "number": 122,
-  }).Warn("The group's number increased tremendously!")
-
-  log.WithFields(log.Fields{
-    "omg":    true,
-    "number": 100,
-  }).Fatal("The ice breaks!")
-
-  // A common pattern is to re-use fields between logging statements by 
re-using
-  // the logrus.Entry returned from WithFields()
-  contextLogger := log.WithFields(log.Fields{
-    "common": "this is a common field",
-    "other": "I also should be logged always",
-  })
-
-  contextLogger.Info("I'll be logged with common and other field")
-  contextLogger.Info("Me too")
-}
-```
-
-For more advanced usage such as logging to multiple locations from the same
-application, you can also create an instance of the `logrus` Logger:
-
-```go
-package main
-
-import (
-  "github.com/Sirupsen/logrus"
-)
-
-// Create a new instance of the logger. You can have any number of instances.
-var log = logrus.New()
-
-func main() {
-  // The API for setting attributes is a little different than the package 
level
-  // exported logger. See Godoc.
-  log.Out = os.Stderr
-
-  log.WithFields(logrus.Fields{
-    "animal": "walrus",
-    "size":   10,
-  }).Info("A group of walrus emerges from the ocean")
-}
-```
-
-#### Fields
-
-Logrus encourages careful, structured logging though logging fields instead of
-long, unparseable error messages. For example, instead of: `log.Fatalf("Failed
-to send event %s to topic %s with key %d")`, you should log the much more
-discoverable:
-
-```go
-log.WithFields(log.Fields{
-  "event": event,
-  "topic": topic,
-  "key": key,
-}).Fatal("Failed to send event")
-```
-
-We've found this API forces you to think about logging in a way that produces
-much more useful logging messages. We've been in countless situations where 
just
-a single added field to a log statement that was already there would've saved 
us
-hours. The `WithFields` call is optional.
-
-In general, with Logrus using any of the `printf`-family functions should be
-seen as a hint you should add a field, however, you can still use the
-`printf`-family functions with Logrus.
-
-#### Hooks
-
-You can add hooks for logging levels. For example to send errors to an 
exception
-tracking service on `Error`, `Fatal` and `Panic`, info to StatsD or log to
-multiple places simultaneously, e.g. syslog.
-
-Logrus comes with [built-in hooks](hooks/). Add those, or your custom hook, in
-`init`:
-
-```go
-import (
-  log "github.com/Sirupsen/logrus"
-  "gopkg.in/gemnasium/logrus-airbrake-hook.v2" // the package is named 
"aibrake"
-  logrus_syslog "github.com/Sirupsen/logrus/hooks/syslog"
-  "log/syslog"
-)
-
-func init() {
-
-  // Use the Airbrake hook to report errors that have Error severity or above 
to
-  // an exception tracker. You can create custom hooks, see the Hooks section.
-  log.AddHook(airbrake.NewHook(123, "xyz", "production"))
-
-  hook, err := logrus_syslog.NewSyslogHook("udp", "localhost:514", 
syslog.LOG_INFO, "")
-  if err != nil {
-    log.Error("Unable to connect to local syslog daemon")
-  } else {
-    log.AddHook(hook)
-  }
-}
-```
-Note: Syslog hook also support connecting to local syslog (Ex. "/dev/log" or 
"/var/run/syslog" or "/var/run/log"). For the detail, please check the [syslog 
hook README](hooks/syslog/README.md).
-
-| Hook  | Description |
-| ----- | ----------- |
-| [Airbrake](https://github.com/gemnasium/logrus-airbrake-hook) | Send errors 
to the Airbrake API V3. Uses the official 
[`gobrake`](https://github.com/airbrake/gobrake) behind the scenes. |
-| [Airbrake 
"legacy"](https://github.com/gemnasium/logrus-airbrake-legacy-hook) | Send 
errors to an exception tracking service compatible with the Airbrake API V2. 
Uses [`airbrake-go`](https://github.com/tobi/airbrake-go) behind the scenes. |
-| [Papertrail](https://github.com/polds/logrus-papertrail-hook) | Send errors 
to the [Papertrail](https://papertrailapp.com) hosted logging service via UDP. |
-| 
[Syslog](https://github.com/Sirupsen/logrus/blob/master/hooks/syslog/syslog.go) 
| Send errors to remote syslog server. Uses standard library `log/syslog` 
behind the scenes. |
-| [Bugsnag](https://github.com/Shopify/logrus-bugsnag/blob/master/bugsnag.go) 
| Send errors to the Bugsnag exception tracking service. |
-| [Sentry](https://github.com/evalphobia/logrus_sentry) | Send errors to the 
Sentry error logging and aggregation service. |
-| [Hiprus](https://github.com/nubo/hiprus) | Send errors to a channel in 
hipchat. |
-| [Logrusly](https://github.com/sebest/logrusly) | Send logs to 
[Loggly](https://www.loggly.com/) |
-| [Slackrus](https://github.com/johntdyer/slackrus) | Hook for Slack chat. |
-| [Journalhook](https://github.com/wercker/journalhook) | Hook for logging to 
`systemd-journald` |
-| [Graylog](https://github.com/gemnasium/logrus-graylog-hook) | Hook for 
logging to [Graylog](http://graylog2.org/) |
-| [Raygun](https://github.com/squirkle/logrus-raygun-hook) | Hook for logging 
to [Raygun.io](http://raygun.io/) |
-| [LFShook](https://github.com/rifflock/lfshook) | Hook for logging to the 
local filesystem |
-| [Honeybadger](https://github.com/agonzalezro/logrus_honeybadger) | Hook for 
sending exceptions to Honeybadger |
-| [Mail](https://github.com/zbindenren/logrus_mail) | Hook for sending 
exceptions via mail |
-| [Rollrus](https://github.com/heroku/rollrus) | Hook for sending errors to 
rollbar |
-| [Fluentd](https://github.com/evalphobia/logrus_fluent) | Hook for logging to 
fluentd |
-| [Mongodb](https://github.com/weekface/mgorus) | Hook for logging to mongodb |
-| [Influxus] (http://github.com/vlad-doru/influxus) | Hook for concurrently 
logging to [InfluxDB] (http://influxdata.com/) |
-| [InfluxDB](https://github.com/Abramovic/logrus_influxdb) | Hook for logging 
to influxdb |
-| [Octokit](https://github.com/dorajistyle/logrus-octokit-hook) | Hook for 
logging to github via octokit |
-| [DeferPanic](https://github.com/deferpanic/dp-logrus) | Hook for logging to 
DeferPanic |
-| [Redis-Hook](https://github.com/rogierlommers/logrus-redis-hook) | Hook for 
logging to a ELK stack (through Redis) |
-| [Amqp-Hook](https://github.com/vladoatanasov/logrus_amqp) | Hook for logging 
to Amqp broker (Like RabbitMQ) |
-| [KafkaLogrus](https://github.com/goibibo/KafkaLogrus) | Hook for logging to 
kafka |
-| [Typetalk](https://github.com/dragon3/logrus-typetalk-hook) | Hook for 
logging to [Typetalk](https://www.typetalk.in/) |
-| [ElasticSearch](https://github.com/sohlich/elogrus) | Hook for logging to 
ElasticSearch|
-| [Sumorus](https://github.com/doublefree/sumorus) | Hook for logging to 
[SumoLogic](https://www.sumologic.com/)|
-| [Scribe](https://github.com/sagar8192/logrus-scribe-hook) | Hook for logging 
to [Scribe](https://github.com/facebookarchive/scribe)|
-| [Logstash](https://github.com/bshuster-repo/logrus-logstash-hook) | Hook for 
logging to [Logstash](https://www.elastic.co/products/logstash) |
-| [logz.io](https://github.com/ripcurld00d/logrus-logzio-hook) | Hook for 
logging to [logz.io](https://logz.io), a Log as a Service using Logstash |
-| [Logmatic.io](https://github.com/logmatic/logmatic-go) | Hook for logging to 
[Logmatic.io](http://logmatic.io/) |
-| [Pushover](https://github.com/toorop/logrus_pushover) | Send error via 
[Pushover](https://pushover.net) |
-| [PostgreSQL](https://github.com/gemnasium/logrus-postgresql-hook) | Send 
logs to [PostgreSQL](http://postgresql.org) |
-
-
-#### Level logging
-
-Logrus has six logging levels: Debug, Info, Warning, Error, Fatal and Panic.
-
-```go
-log.Debug("Useful debugging information.")
-log.Info("Something noteworthy happened!")
-log.Warn("You should probably take a look at this.")
-log.Error("Something failed but I'm not quitting.")
-// Calls os.Exit(1) after logging
-log.Fatal("Bye.")
-// Calls panic() after logging
-log.Panic("I'm bailing.")
-```
-
-You can set the logging level on a `Logger`, then it will only log entries with
-that severity or anything above it:
-
-```go
-// Will log anything that is info or above (warn, error, fatal, panic). 
Default.
-log.SetLevel(log.InfoLevel)
-```
-
-It may be useful to set `log.Level = logrus.DebugLevel` in a debug or verbose
-environment if your application has that.
-
-#### Entries
-
-Besides the fields added with `WithField` or `WithFields` some fields are
-automatically added to all logging events:
-
-1. `time`. The timestamp when the entry was created.
-2. `msg`. The logging message passed to `{Info,Warn,Error,Fatal,Panic}` after
-   the `AddFields` call. E.g. `Failed to send event.`
-3. `level`. The logging level. E.g. `info`.
-
-#### Environments
-
-Logrus has no notion of environment.
-
-If you wish for hooks and formatters to only be used in specific environments,
-you should handle that yourself. For example, if your application has a global
-variable `Environment`, which is a string representation of the environment you
-could do:
-
-```go
-import (
-  log "github.com/Sirupsen/logrus"
-)
-
-init() {
-  // do something here to set environment depending on an environment variable
-  // or command-line flag
-  if Environment == "production" {
-    log.SetFormatter(&log.JSONFormatter{})
-  } else {
-    // The TextFormatter is default, you don't actually have to do this.
-    log.SetFormatter(&log.TextFormatter{})
-  }
-}
-```
-
-This configuration is how `logrus` was intended to be used, but JSON in
-production is mostly only useful if you do log aggregation with tools like
-Splunk or Logstash.
-
-#### Formatters
-
-The built-in logging formatters are:
-
-* `logrus.TextFormatter`. Logs the event in colors if stdout is a tty, 
otherwise
-  without colors.
-  * *Note:* to force colored output when there is no TTY, set the `ForceColors`
-    field to `true`.  To force no colored output even if there is a TTY  set 
the
-    `DisableColors` field to `true`
-* `logrus.JSONFormatter`. Logs fields as JSON.
-
-Third party logging formatters:
-
-* [`logstash`](https://github.com/bshuster-repo/logrus-logstash-hook). Logs 
fields as [Logstash](http://logstash.net) Events.
-* [`prefixed`](https://github.com/x-cray/logrus-prefixed-formatter). Displays 
log entry source along with alternative layout.
-* [`zalgo`](https://github.com/aybabtme/logzalgo). Invoking the 
P͉̫o̳̼̊w̖͈̰͎e̬͔̭͂r͚̼̹̲ ̫͓͉̳͈ō̠͕͖̚f̝͍̠ 
͕̲̞͖͑Z̖̫̤̫ͪa͉̬͈̗l͖͎g̳̥o̰̥̅!̣͔̲̻͊̄ ̙̘̦̹̦.
-
-You can define your formatter by implementing the `Formatter` interface,
-requiring a `Format` method. `Format` takes an `*Entry`. `entry.Data` is a
-`Fields` type (`map[string]interface{}`) with all your fields as well as the
-default ones (see Entries section above):
-
-```go
-type MyJSONFormatter struct {
-}
-
-log.SetFormatter(new(MyJSONFormatter))
-
-func (f *MyJSONFormatter) Format(entry *Entry) ([]byte, error) {
-  // Note this doesn't include Time, Level and Message which are available on
-  // the Entry. Consult `godoc` on information about those fields or read the
-  // source of the official loggers.
-  serialized, err := json.Marshal(entry.Data)
-    if err != nil {
-      return nil, fmt.Errorf("Failed to marshal fields to JSON, %v", err)
-    }
-  return append(serialized, '\n'), nil
-}
-```
-
-#### Logger as an `io.Writer`
-
-Logrus can be transformed into an `io.Writer`. That writer is the end of an 
`io.Pipe` and it is your responsibility to close it.
-
-```go
-w := logger.Writer()
-defer w.Close()
-
-srv := http.Server{
-    // create a stdlib log.Logger that writes to
-    // logrus.Logger.
-    ErrorLog: log.New(w, "", 0),
-}
-```
-
-Each line written to that writer will be printed the usual way, using 
formatters
-and hooks. The level for those entries is `info`.
-
-#### Rotation
-
-Log rotation is not provided with Logrus. Log rotation should be done by an
-external program (like `logrotate(8)`) that can compress and delete old log
-entries. It should not be a feature of the application-level logger.
-
-#### Tools
-
-| Tool | Description |
-| ---- | ----------- |
-|[Logrus Mate](https://github.com/gogap/logrus_mate)|Logrus mate is a tool for 
Logrus to manage loggers, you can initial logger's level, hook and formatter by 
config file, the logger will generated with different config at different 
environment.|
-|[Logrus Viper 
Helper](https://github.com/heirko/go-contrib/tree/master/logrusHelper)|An 
Helper arround Logrus to wrap with spf13/Viper to load configuration with 
fangs! And to simplify Logrus configuration use some behavior of [Logrus 
Mate](https://github.com/gogap/logrus_mate). 
[sample](https://github.com/heirko/iris-contrib/blob/master/middleware/logrus-logger/example)
 |
-
-#### Testing
-
-Logrus has a built in facility for asserting the presence of log messages. 
This is implemented through the `test` hook and provides:
-
-* decorators for existing logger (`test.NewLocal` and `test.NewGlobal`) which 
basically just add the `test` hook
-* a test logger (`test.NewNullLogger`) that just records log messages (and 
does not output any):
-
-```go
-logger, hook := NewNullLogger()
-logger.Error("Hello error")
-
-assert.Equal(1, len(hook.Entries))
-assert.Equal(logrus.ErrorLevel, hook.LastEntry().Level)
-assert.Equal("Hello error", hook.LastEntry().Message)
-
-hook.Reset()
-assert.Nil(hook.LastEntry())
-```
-
-#### Fatal handlers
-
-Logrus can register one or more functions that will be called when any `fatal`
-level message is logged. The registered handlers will be executed before
-logrus performs a `os.Exit(1)`. This behavior may be helpful if callers need
-to gracefully shutdown. Unlike a `panic("Something went wrong...")` call which 
can be intercepted with a deferred `recover` a call to `os.Exit(1)` can not be 
intercepted.
-
-```
-...
-handler := func() {
-  // gracefully shutdown something...
-}
-logrus.RegisterExitHandler(handler)
-...
-```
-
-#### Thread safty
-
-By default Logger is protected by mutex for concurrent writes, this mutex is 
invoked when calling hooks and writing logs.
-If you are sure such locking is not needed, you can call logger.SetNoLock() to 
disable the locking.
-
-Situation when locking is not needed includes:
-
-* You have no hooks registered, or hooks calling is already thread-safe.
-
-* Writing to logger.Out is already thread-safe, for example:
-
-  1) logger.Out is protected by locks.
-
-  2) logger.Out is a os.File handler opened with `O_APPEND` flag, and every 
write is smaller than 4k. (This allow multi-thread/multi-process writing)
-
-     (Refer to 
http://www.notthewizard.com/2014/06/17/are-files-appends-really-atomic/)

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/alt_exit.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/alt_exit.go 
b/newt/vendor/github.com/Sirupsen/logrus/alt_exit.go
deleted file mode 100644
index b4c9e84..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/alt_exit.go
+++ /dev/null
@@ -1,64 +0,0 @@
-package logrus
-
-// The following code was sourced and modified from the
-// https://bitbucket.org/tebeka/atexit package governed by the following 
license:
-//
-// Copyright (c) 2012 Miki Tebeka <[email protected]>.
-//
-// 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.
-
-import (
-       "fmt"
-       "os"
-)
-
-var handlers = []func(){}
-
-func runHandler(handler func()) {
-       defer func() {
-               if err := recover(); err != nil {
-                       fmt.Fprintln(os.Stderr, "Error: Logrus exit handler 
error:", err)
-               }
-       }()
-
-       handler()
-}
-
-func runHandlers() {
-       for _, handler := range handlers {
-               runHandler(handler)
-       }
-}
-
-// Exit runs all the Logrus atexit handlers and then terminates the program 
using os.Exit(code)
-func Exit(code int) {
-       runHandlers()
-       os.Exit(code)
-}
-
-// RegisterExitHandler adds a Logrus Exit handler, call logrus.Exit to invoke
-// all handlers. The handlers will also be invoked when any Fatal log entry is
-// made.
-//
-// This method is useful when a caller wishes to use logrus to log a fatal
-// message but also needs to gracefully shutdown. An example usecase could be
-// closing database connections, or sending a alert that the application is
-// closing.
-func RegisterExitHandler(handler func()) {
-       handlers = append(handlers, handler)
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/doc.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/doc.go 
b/newt/vendor/github.com/Sirupsen/logrus/doc.go
deleted file mode 100644
index dddd5f8..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/doc.go
+++ /dev/null
@@ -1,26 +0,0 @@
-/*
-Package logrus is a structured logger for Go, completely API compatible with 
the standard library logger.
-
-
-The simplest way to use Logrus is simply the package-level exported logger:
-
-  package main
-
-  import (
-    log "github.com/Sirupsen/logrus"
-  )
-
-  func main() {
-    log.WithFields(log.Fields{
-      "animal": "walrus",
-      "number": 1,
-      "size":   10,
-    }).Info("A walrus appears")
-  }
-
-Output:
-  time="2015-09-07T08:48:33Z" level=info msg="A walrus appears" animal=walrus 
number=1 size=10
-
-For a full guide visit https://github.com/Sirupsen/logrus
-*/
-package logrus

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/entry.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/entry.go 
b/newt/vendor/github.com/Sirupsen/logrus/entry.go
deleted file mode 100644
index 4edbe7a..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/entry.go
+++ /dev/null
@@ -1,275 +0,0 @@
-package logrus
-
-import (
-       "bytes"
-       "fmt"
-       "os"
-       "sync"
-       "time"
-)
-
-var bufferPool *sync.Pool
-
-func init() {
-       bufferPool = &sync.Pool{
-               New: func() interface{} {
-                       return new(bytes.Buffer)
-               },
-       }
-}
-
-// Defines the key when adding errors using WithError.
-var ErrorKey = "error"
-
-// An entry is the final or intermediate Logrus logging entry. It contains all
-// the fields passed with WithField{,s}. It's finally logged when Debug, Info,
-// Warn, Error, Fatal or Panic is called on it. These objects can be reused and
-// passed around as much as you wish to avoid field duplication.
-type Entry struct {
-       Logger *Logger
-
-       // Contains all the fields set by the user.
-       Data Fields
-
-       // Time at which the log entry was created
-       Time time.Time
-
-       // Level the log entry was logged at: Debug, Info, Warn, Error, Fatal 
or Panic
-       Level Level
-
-       // Message passed to Debug, Info, Warn, Error, Fatal or Panic
-       Message string
-
-       // When formatter is called in entry.log(), an Buffer may be set to 
entry
-       Buffer *bytes.Buffer
-}
-
-func NewEntry(logger *Logger) *Entry {
-       return &Entry{
-               Logger: logger,
-               // Default is three fields, give a little extra room
-               Data: make(Fields, 5),
-       }
-}
-
-// Returns the string representation from the reader and ultimately the
-// formatter.
-func (entry *Entry) String() (string, error) {
-       serialized, err := entry.Logger.Formatter.Format(entry)
-       if err != nil {
-               return "", err
-       }
-       str := string(serialized)
-       return str, nil
-}
-
-// Add an error as single field (using the key defined in ErrorKey) to the 
Entry.
-func (entry *Entry) WithError(err error) *Entry {
-       return entry.WithField(ErrorKey, err)
-}
-
-// Add a single field to the Entry.
-func (entry *Entry) WithField(key string, value interface{}) *Entry {
-       return entry.WithFields(Fields{key: value})
-}
-
-// Add a map of fields to the Entry.
-func (entry *Entry) WithFields(fields Fields) *Entry {
-       data := make(Fields, len(entry.Data)+len(fields))
-       for k, v := range entry.Data {
-               data[k] = v
-       }
-       for k, v := range fields {
-               data[k] = v
-       }
-       return &Entry{Logger: entry.Logger, Data: data}
-}
-
-// This function is not declared with a pointer value because otherwise
-// race conditions will occur when using multiple goroutines
-func (entry Entry) log(level Level, msg string) {
-       var buffer *bytes.Buffer
-       entry.Time = time.Now()
-       entry.Level = level
-       entry.Message = msg
-
-       if err := entry.Logger.Hooks.Fire(level, &entry); err != nil {
-               entry.Logger.mu.Lock()
-               fmt.Fprintf(os.Stderr, "Failed to fire hook: %v\n", err)
-               entry.Logger.mu.Unlock()
-       }
-       buffer = bufferPool.Get().(*bytes.Buffer)
-       buffer.Reset()
-       defer bufferPool.Put(buffer)
-       entry.Buffer = buffer
-       serialized, err := entry.Logger.Formatter.Format(&entry)
-       entry.Buffer = nil
-       if err != nil {
-               entry.Logger.mu.Lock()
-               fmt.Fprintf(os.Stderr, "Failed to obtain reader, %v\n", err)
-               entry.Logger.mu.Unlock()
-       } else {
-               entry.Logger.mu.Lock()
-               _, err = entry.Logger.Out.Write(serialized)
-               if err != nil {
-                       fmt.Fprintf(os.Stderr, "Failed to write to log, %v\n", 
err)
-               }
-               entry.Logger.mu.Unlock()
-       }
-
-       // To avoid Entry#log() returning a value that only would make sense for
-       // panic() to use in Entry#Panic(), we avoid the allocation by checking
-       // directly here.
-       if level <= PanicLevel {
-               panic(&entry)
-       }
-}
-
-func (entry *Entry) Debug(args ...interface{}) {
-       if entry.Logger.Level >= DebugLevel {
-               entry.log(DebugLevel, fmt.Sprint(args...))
-       }
-}
-
-func (entry *Entry) Print(args ...interface{}) {
-       entry.Info(args...)
-}
-
-func (entry *Entry) Info(args ...interface{}) {
-       if entry.Logger.Level >= InfoLevel {
-               entry.log(InfoLevel, fmt.Sprint(args...))
-       }
-}
-
-func (entry *Entry) Warn(args ...interface{}) {
-       if entry.Logger.Level >= WarnLevel {
-               entry.log(WarnLevel, fmt.Sprint(args...))
-       }
-}
-
-func (entry *Entry) Warning(args ...interface{}) {
-       entry.Warn(args...)
-}
-
-func (entry *Entry) Error(args ...interface{}) {
-       if entry.Logger.Level >= ErrorLevel {
-               entry.log(ErrorLevel, fmt.Sprint(args...))
-       }
-}
-
-func (entry *Entry) Fatal(args ...interface{}) {
-       if entry.Logger.Level >= FatalLevel {
-               entry.log(FatalLevel, fmt.Sprint(args...))
-       }
-       Exit(1)
-}
-
-func (entry *Entry) Panic(args ...interface{}) {
-       if entry.Logger.Level >= PanicLevel {
-               entry.log(PanicLevel, fmt.Sprint(args...))
-       }
-       panic(fmt.Sprint(args...))
-}
-
-// Entry Printf family functions
-
-func (entry *Entry) Debugf(format string, args ...interface{}) {
-       if entry.Logger.Level >= DebugLevel {
-               entry.Debug(fmt.Sprintf(format, args...))
-       }
-}
-
-func (entry *Entry) Infof(format string, args ...interface{}) {
-       if entry.Logger.Level >= InfoLevel {
-               entry.Info(fmt.Sprintf(format, args...))
-       }
-}
-
-func (entry *Entry) Printf(format string, args ...interface{}) {
-       entry.Infof(format, args...)
-}
-
-func (entry *Entry) Warnf(format string, args ...interface{}) {
-       if entry.Logger.Level >= WarnLevel {
-               entry.Warn(fmt.Sprintf(format, args...))
-       }
-}
-
-func (entry *Entry) Warningf(format string, args ...interface{}) {
-       entry.Warnf(format, args...)
-}
-
-func (entry *Entry) Errorf(format string, args ...interface{}) {
-       if entry.Logger.Level >= ErrorLevel {
-               entry.Error(fmt.Sprintf(format, args...))
-       }
-}
-
-func (entry *Entry) Fatalf(format string, args ...interface{}) {
-       if entry.Logger.Level >= FatalLevel {
-               entry.Fatal(fmt.Sprintf(format, args...))
-       }
-       Exit(1)
-}
-
-func (entry *Entry) Panicf(format string, args ...interface{}) {
-       if entry.Logger.Level >= PanicLevel {
-               entry.Panic(fmt.Sprintf(format, args...))
-       }
-}
-
-// Entry Println family functions
-
-func (entry *Entry) Debugln(args ...interface{}) {
-       if entry.Logger.Level >= DebugLevel {
-               entry.Debug(entry.sprintlnn(args...))
-       }
-}
-
-func (entry *Entry) Infoln(args ...interface{}) {
-       if entry.Logger.Level >= InfoLevel {
-               entry.Info(entry.sprintlnn(args...))
-       }
-}
-
-func (entry *Entry) Println(args ...interface{}) {
-       entry.Infoln(args...)
-}
-
-func (entry *Entry) Warnln(args ...interface{}) {
-       if entry.Logger.Level >= WarnLevel {
-               entry.Warn(entry.sprintlnn(args...))
-       }
-}
-
-func (entry *Entry) Warningln(args ...interface{}) {
-       entry.Warnln(args...)
-}
-
-func (entry *Entry) Errorln(args ...interface{}) {
-       if entry.Logger.Level >= ErrorLevel {
-               entry.Error(entry.sprintlnn(args...))
-       }
-}
-
-func (entry *Entry) Fatalln(args ...interface{}) {
-       if entry.Logger.Level >= FatalLevel {
-               entry.Fatal(entry.sprintlnn(args...))
-       }
-       Exit(1)
-}
-
-func (entry *Entry) Panicln(args ...interface{}) {
-       if entry.Logger.Level >= PanicLevel {
-               entry.Panic(entry.sprintlnn(args...))
-       }
-}
-
-// Sprintlnn => Sprint no newline. This is to get the behavior of how
-// fmt.Sprintln where spaces are always added between operands, regardless of
-// their type. Instead of vendoring the Sprintln implementation to spare a
-// string allocation, we do the simplest thing.
-func (entry *Entry) sprintlnn(args ...interface{}) string {
-       msg := fmt.Sprintln(args...)
-       return msg[:len(msg)-1]
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/exported.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/exported.go 
b/newt/vendor/github.com/Sirupsen/logrus/exported.go
deleted file mode 100644
index 9a0120a..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/exported.go
+++ /dev/null
@@ -1,193 +0,0 @@
-package logrus
-
-import (
-       "io"
-)
-
-var (
-       // std is the name of the standard logger in stdlib `log`
-       std = New()
-)
-
-func StandardLogger() *Logger {
-       return std
-}
-
-// SetOutput sets the standard logger output.
-func SetOutput(out io.Writer) {
-       std.mu.Lock()
-       defer std.mu.Unlock()
-       std.Out = out
-}
-
-// SetFormatter sets the standard logger formatter.
-func SetFormatter(formatter Formatter) {
-       std.mu.Lock()
-       defer std.mu.Unlock()
-       std.Formatter = formatter
-}
-
-// SetLevel sets the standard logger level.
-func SetLevel(level Level) {
-       std.mu.Lock()
-       defer std.mu.Unlock()
-       std.Level = level
-}
-
-// GetLevel returns the standard logger level.
-func GetLevel() Level {
-       std.mu.Lock()
-       defer std.mu.Unlock()
-       return std.Level
-}
-
-// AddHook adds a hook to the standard logger hooks.
-func AddHook(hook Hook) {
-       std.mu.Lock()
-       defer std.mu.Unlock()
-       std.Hooks.Add(hook)
-}
-
-// WithError creates an entry from the standard logger and adds an error to 
it, using the value defined in ErrorKey as key.
-func WithError(err error) *Entry {
-       return std.WithField(ErrorKey, err)
-}
-
-// WithField creates an entry from the standard logger and adds a field to
-// it. If you want multiple fields, use `WithFields`.
-//
-// Note that it doesn't log until you call Debug, Print, Info, Warn, Fatal
-// or Panic on the Entry it returns.
-func WithField(key string, value interface{}) *Entry {
-       return std.WithField(key, value)
-}
-
-// WithFields creates an entry from the standard logger and adds multiple
-// fields to it. This is simply a helper for `WithField`, invoking it
-// once for each field.
-//
-// Note that it doesn't log until you call Debug, Print, Info, Warn, Fatal
-// or Panic on the Entry it returns.
-func WithFields(fields Fields) *Entry {
-       return std.WithFields(fields)
-}
-
-// Debug logs a message at level Debug on the standard logger.
-func Debug(args ...interface{}) {
-       std.Debug(args...)
-}
-
-// Print logs a message at level Info on the standard logger.
-func Print(args ...interface{}) {
-       std.Print(args...)
-}
-
-// Info logs a message at level Info on the standard logger.
-func Info(args ...interface{}) {
-       std.Info(args...)
-}
-
-// Warn logs a message at level Warn on the standard logger.
-func Warn(args ...interface{}) {
-       std.Warn(args...)
-}
-
-// Warning logs a message at level Warn on the standard logger.
-func Warning(args ...interface{}) {
-       std.Warning(args...)
-}
-
-// Error logs a message at level Error on the standard logger.
-func Error(args ...interface{}) {
-       std.Error(args...)
-}
-
-// Panic logs a message at level Panic on the standard logger.
-func Panic(args ...interface{}) {
-       std.Panic(args...)
-}
-
-// Fatal logs a message at level Fatal on the standard logger.
-func Fatal(args ...interface{}) {
-       std.Fatal(args...)
-}
-
-// Debugf logs a message at level Debug on the standard logger.
-func Debugf(format string, args ...interface{}) {
-       std.Debugf(format, args...)
-}
-
-// Printf logs a message at level Info on the standard logger.
-func Printf(format string, args ...interface{}) {
-       std.Printf(format, args...)
-}
-
-// Infof logs a message at level Info on the standard logger.
-func Infof(format string, args ...interface{}) {
-       std.Infof(format, args...)
-}
-
-// Warnf logs a message at level Warn on the standard logger.
-func Warnf(format string, args ...interface{}) {
-       std.Warnf(format, args...)
-}
-
-// Warningf logs a message at level Warn on the standard logger.
-func Warningf(format string, args ...interface{}) {
-       std.Warningf(format, args...)
-}
-
-// Errorf logs a message at level Error on the standard logger.
-func Errorf(format string, args ...interface{}) {
-       std.Errorf(format, args...)
-}
-
-// Panicf logs a message at level Panic on the standard logger.
-func Panicf(format string, args ...interface{}) {
-       std.Panicf(format, args...)
-}
-
-// Fatalf logs a message at level Fatal on the standard logger.
-func Fatalf(format string, args ...interface{}) {
-       std.Fatalf(format, args...)
-}
-
-// Debugln logs a message at level Debug on the standard logger.
-func Debugln(args ...interface{}) {
-       std.Debugln(args...)
-}
-
-// Println logs a message at level Info on the standard logger.
-func Println(args ...interface{}) {
-       std.Println(args...)
-}
-
-// Infoln logs a message at level Info on the standard logger.
-func Infoln(args ...interface{}) {
-       std.Infoln(args...)
-}
-
-// Warnln logs a message at level Warn on the standard logger.
-func Warnln(args ...interface{}) {
-       std.Warnln(args...)
-}
-
-// Warningln logs a message at level Warn on the standard logger.
-func Warningln(args ...interface{}) {
-       std.Warningln(args...)
-}
-
-// Errorln logs a message at level Error on the standard logger.
-func Errorln(args ...interface{}) {
-       std.Errorln(args...)
-}
-
-// Panicln logs a message at level Panic on the standard logger.
-func Panicln(args ...interface{}) {
-       std.Panicln(args...)
-}
-
-// Fatalln logs a message at level Fatal on the standard logger.
-func Fatalln(args ...interface{}) {
-       std.Fatalln(args...)
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/formatter.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/formatter.go 
b/newt/vendor/github.com/Sirupsen/logrus/formatter.go
deleted file mode 100644
index b5fbe93..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/formatter.go
+++ /dev/null
@@ -1,45 +0,0 @@
-package logrus
-
-import "time"
-
-const DefaultTimestampFormat = time.RFC3339
-
-// The Formatter interface is used to implement a custom Formatter. It takes an
-// `Entry`. It exposes all the fields, including the default ones:
-//
-// * `entry.Data["msg"]`. The message passed from Info, Warn, Error ..
-// * `entry.Data["time"]`. The timestamp.
-// * `entry.Data["level"]. The level the entry was logged at.
-//
-// Any additional fields added with `WithField` or `WithFields` are also in
-// `entry.Data`. Format is expected to return an array of bytes which are then
-// logged to `logger.Out`.
-type Formatter interface {
-       Format(*Entry) ([]byte, error)
-}
-
-// This is to not silently overwrite `time`, `msg` and `level` fields when
-// dumping it. If this code wasn't there doing:
-//
-//  logrus.WithField("level", 1).Info("hello")
-//
-// Would just silently drop the user provided level. Instead with this code
-// it'll logged as:
-//
-//  {"level": "info", "fields.level": 1, "msg": "hello", "time": "..."}
-//
-// It's not exported because it's still using Data in an opinionated way. It's 
to
-// avoid code duplication between the two default formatters.
-func prefixFieldClashes(data Fields) {
-       if t, ok := data["time"]; ok {
-               data["fields.time"] = t
-       }
-
-       if m, ok := data["msg"]; ok {
-               data["fields.msg"] = m
-       }
-
-       if l, ok := data["level"]; ok {
-               data["fields.level"] = l
-       }
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/hooks.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/hooks.go 
b/newt/vendor/github.com/Sirupsen/logrus/hooks.go
deleted file mode 100644
index 3f151cd..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/hooks.go
+++ /dev/null
@@ -1,34 +0,0 @@
-package logrus
-
-// A hook to be fired when logging on the logging levels returned from
-// `Levels()` on your implementation of the interface. Note that this is not
-// fired in a goroutine or a channel with workers, you should handle such
-// functionality yourself if your call is non-blocking and you don't wish for
-// the logging calls for levels returned from `Levels()` to block.
-type Hook interface {
-       Levels() []Level
-       Fire(*Entry) error
-}
-
-// Internal type for storing the hooks on a logger instance.
-type LevelHooks map[Level][]Hook
-
-// Add a hook to an instance of logger. This is called with
-// `log.Hooks.Add(new(MyHook))` where `MyHook` implements the `Hook` interface.
-func (hooks LevelHooks) Add(hook Hook) {
-       for _, level := range hook.Levels() {
-               hooks[level] = append(hooks[level], hook)
-       }
-}
-
-// Fire all the hooks for the passed level. Used by `entry.log` to fire
-// appropriate hooks for a log entry.
-func (hooks LevelHooks) Fire(level Level, entry *Entry) error {
-       for _, hook := range hooks[level] {
-               if err := hook.Fire(entry); err != nil {
-                       return err
-               }
-       }
-
-       return nil
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/json_formatter.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/json_formatter.go 
b/newt/vendor/github.com/Sirupsen/logrus/json_formatter.go
deleted file mode 100644
index f3729bf..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/json_formatter.go
+++ /dev/null
@@ -1,69 +0,0 @@
-package logrus
-
-import (
-       "encoding/json"
-       "fmt"
-)
-
-type fieldKey string
-type FieldMap map[fieldKey]string
-
-const (
-       FieldKeyMsg   = "msg"
-       FieldKeyLevel = "level"
-       FieldKeyTime  = "time"
-)
-
-func (f FieldMap) resolve(key fieldKey) string {
-       if k, ok := f[key]; ok {
-               return k
-       }
-
-       return string(key)
-}
-
-type JSONFormatter struct {
-       // TimestampFormat sets the format used for marshaling timestamps.
-       TimestampFormat string
-
-       // FieldMap allows users to customize the names of keys for various 
fields.
-       // As an example:
-       // formatter := &JSONFormatter{
-       //      FieldMap: FieldMap{
-       //               FieldKeyTime: "@timestamp",
-       //               FieldKeyLevel: "@level",
-       //               FieldKeyLevel: "@message",
-       //    },
-       // }
-       FieldMap FieldMap
-}
-
-func (f *JSONFormatter) Format(entry *Entry) ([]byte, error) {
-       data := make(Fields, len(entry.Data)+3)
-       for k, v := range entry.Data {
-               switch v := v.(type) {
-               case error:
-                       // Otherwise errors are ignored by `encoding/json`
-                       // https://github.com/Sirupsen/logrus/issues/137
-                       data[k] = v.Error()
-               default:
-                       data[k] = v
-               }
-       }
-       prefixFieldClashes(data)
-
-       timestampFormat := f.TimestampFormat
-       if timestampFormat == "" {
-               timestampFormat = DefaultTimestampFormat
-       }
-
-       data[f.FieldMap.resolve(FieldKeyTime)] = 
entry.Time.Format(timestampFormat)
-       data[f.FieldMap.resolve(FieldKeyMsg)] = entry.Message
-       data[f.FieldMap.resolve(FieldKeyLevel)] = entry.Level.String()
-
-       serialized, err := json.Marshal(data)
-       if err != nil {
-               return nil, fmt.Errorf("Failed to marshal fields to JSON, %v", 
err)
-       }
-       return append(serialized, '\n'), nil
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/logger.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/logger.go 
b/newt/vendor/github.com/Sirupsen/logrus/logger.go
deleted file mode 100644
index b769f3d..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/logger.go
+++ /dev/null
@@ -1,308 +0,0 @@
-package logrus
-
-import (
-       "io"
-       "os"
-       "sync"
-)
-
-type Logger struct {
-       // The logs are `io.Copy`'d to this in a mutex. It's common to set this 
to a
-       // file, or leave it default which is `os.Stderr`. You can also set 
this to
-       // something more adventorous, such as logging to Kafka.
-       Out io.Writer
-       // Hooks for the logger instance. These allow firing events based on 
logging
-       // levels and log entries. For example, to send errors to an error 
tracking
-       // service, log to StatsD or dump the core on fatal errors.
-       Hooks LevelHooks
-       // All log entries pass through the formatter before logged to Out. The
-       // included formatters are `TextFormatter` and `JSONFormatter` for which
-       // TextFormatter is the default. In development (when a TTY is 
attached) it
-       // logs with colors, but to a file it wouldn't. You can easily 
implement your
-       // own that implements the `Formatter` interface, see the `README` or 
included
-       // formatters for examples.
-       Formatter Formatter
-       // The logging level the logger should log at. This is typically (and 
defaults
-       // to) `logrus.Info`, which allows Info(), Warn(), Error() and Fatal() 
to be
-       // logged. `logrus.Debug` is useful in
-       Level Level
-       // Used to sync writing to the log. Locking is enabled by Default
-       mu MutexWrap
-       // Reusable empty entry
-       entryPool sync.Pool
-}
-
-type MutexWrap struct {
-       lock     sync.Mutex
-       disabled bool
-}
-
-func (mw *MutexWrap) Lock() {
-       if !mw.disabled {
-               mw.lock.Lock()
-       }
-}
-
-func (mw *MutexWrap) Unlock() {
-       if !mw.disabled {
-               mw.lock.Unlock()
-       }
-}
-
-func (mw *MutexWrap) Disable() {
-       mw.disabled = true
-}
-
-// Creates a new logger. Configuration should be set by changing `Formatter`,
-// `Out` and `Hooks` directly on the default logger instance. You can also just
-// instantiate your own:
-//
-//    var log = &Logger{
-//      Out: os.Stderr,
-//      Formatter: new(JSONFormatter),
-//      Hooks: make(LevelHooks),
-//      Level: logrus.DebugLevel,
-//    }
-//
-// It's recommended to make this a global instance called `log`.
-func New() *Logger {
-       return &Logger{
-               Out:       os.Stderr,
-               Formatter: new(TextFormatter),
-               Hooks:     make(LevelHooks),
-               Level:     InfoLevel,
-       }
-}
-
-func (logger *Logger) newEntry() *Entry {
-       entry, ok := logger.entryPool.Get().(*Entry)
-       if ok {
-               return entry
-       }
-       return NewEntry(logger)
-}
-
-func (logger *Logger) releaseEntry(entry *Entry) {
-       logger.entryPool.Put(entry)
-}
-
-// Adds a field to the log entry, note that it doesn't log until you call
-// Debug, Print, Info, Warn, Fatal or Panic. It only creates a log entry.
-// If you want multiple fields, use `WithFields`.
-func (logger *Logger) WithField(key string, value interface{}) *Entry {
-       entry := logger.newEntry()
-       defer logger.releaseEntry(entry)
-       return entry.WithField(key, value)
-}
-
-// Adds a struct of fields to the log entry. All it does is call `WithField` 
for
-// each `Field`.
-func (logger *Logger) WithFields(fields Fields) *Entry {
-       entry := logger.newEntry()
-       defer logger.releaseEntry(entry)
-       return entry.WithFields(fields)
-}
-
-// Add an error as single field to the log entry.  All it does is call
-// `WithError` for the given `error`.
-func (logger *Logger) WithError(err error) *Entry {
-       entry := logger.newEntry()
-       defer logger.releaseEntry(entry)
-       return entry.WithError(err)
-}
-
-func (logger *Logger) Debugf(format string, args ...interface{}) {
-       if logger.Level >= DebugLevel {
-               entry := logger.newEntry()
-               entry.Debugf(format, args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Infof(format string, args ...interface{}) {
-       if logger.Level >= InfoLevel {
-               entry := logger.newEntry()
-               entry.Infof(format, args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Printf(format string, args ...interface{}) {
-       entry := logger.newEntry()
-       entry.Printf(format, args...)
-       logger.releaseEntry(entry)
-}
-
-func (logger *Logger) Warnf(format string, args ...interface{}) {
-       if logger.Level >= WarnLevel {
-               entry := logger.newEntry()
-               entry.Warnf(format, args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Warningf(format string, args ...interface{}) {
-       if logger.Level >= WarnLevel {
-               entry := logger.newEntry()
-               entry.Warnf(format, args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Errorf(format string, args ...interface{}) {
-       if logger.Level >= ErrorLevel {
-               entry := logger.newEntry()
-               entry.Errorf(format, args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Fatalf(format string, args ...interface{}) {
-       if logger.Level >= FatalLevel {
-               entry := logger.newEntry()
-               entry.Fatalf(format, args...)
-               logger.releaseEntry(entry)
-       }
-       Exit(1)
-}
-
-func (logger *Logger) Panicf(format string, args ...interface{}) {
-       if logger.Level >= PanicLevel {
-               entry := logger.newEntry()
-               entry.Panicf(format, args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Debug(args ...interface{}) {
-       if logger.Level >= DebugLevel {
-               entry := logger.newEntry()
-               entry.Debug(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Info(args ...interface{}) {
-       if logger.Level >= InfoLevel {
-               entry := logger.newEntry()
-               entry.Info(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Print(args ...interface{}) {
-       entry := logger.newEntry()
-       entry.Info(args...)
-       logger.releaseEntry(entry)
-}
-
-func (logger *Logger) Warn(args ...interface{}) {
-       if logger.Level >= WarnLevel {
-               entry := logger.newEntry()
-               entry.Warn(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Warning(args ...interface{}) {
-       if logger.Level >= WarnLevel {
-               entry := logger.newEntry()
-               entry.Warn(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Error(args ...interface{}) {
-       if logger.Level >= ErrorLevel {
-               entry := logger.newEntry()
-               entry.Error(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Fatal(args ...interface{}) {
-       if logger.Level >= FatalLevel {
-               entry := logger.newEntry()
-               entry.Fatal(args...)
-               logger.releaseEntry(entry)
-       }
-       Exit(1)
-}
-
-func (logger *Logger) Panic(args ...interface{}) {
-       if logger.Level >= PanicLevel {
-               entry := logger.newEntry()
-               entry.Panic(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Debugln(args ...interface{}) {
-       if logger.Level >= DebugLevel {
-               entry := logger.newEntry()
-               entry.Debugln(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Infoln(args ...interface{}) {
-       if logger.Level >= InfoLevel {
-               entry := logger.newEntry()
-               entry.Infoln(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Println(args ...interface{}) {
-       entry := logger.newEntry()
-       entry.Println(args...)
-       logger.releaseEntry(entry)
-}
-
-func (logger *Logger) Warnln(args ...interface{}) {
-       if logger.Level >= WarnLevel {
-               entry := logger.newEntry()
-               entry.Warnln(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Warningln(args ...interface{}) {
-       if logger.Level >= WarnLevel {
-               entry := logger.newEntry()
-               entry.Warnln(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Errorln(args ...interface{}) {
-       if logger.Level >= ErrorLevel {
-               entry := logger.newEntry()
-               entry.Errorln(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-func (logger *Logger) Fatalln(args ...interface{}) {
-       if logger.Level >= FatalLevel {
-               entry := logger.newEntry()
-               entry.Fatalln(args...)
-               logger.releaseEntry(entry)
-       }
-       Exit(1)
-}
-
-func (logger *Logger) Panicln(args ...interface{}) {
-       if logger.Level >= PanicLevel {
-               entry := logger.newEntry()
-               entry.Panicln(args...)
-               logger.releaseEntry(entry)
-       }
-}
-
-//When file is opened with appending mode, it's safe to
-//write concurrently to a file (within 4k message on Linux).
-//In these cases user can choose to disable the lock.
-func (logger *Logger) SetNoLock() {
-       logger.mu.Disable()
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/logrus.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/logrus.go 
b/newt/vendor/github.com/Sirupsen/logrus/logrus.go
deleted file mode 100644
index e596691..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/logrus.go
+++ /dev/null
@@ -1,143 +0,0 @@
-package logrus
-
-import (
-       "fmt"
-       "log"
-       "strings"
-)
-
-// Fields type, used to pass to `WithFields`.
-type Fields map[string]interface{}
-
-// Level type
-type Level uint8
-
-// Convert the Level to a string. E.g. PanicLevel becomes "panic".
-func (level Level) String() string {
-       switch level {
-       case DebugLevel:
-               return "debug"
-       case InfoLevel:
-               return "info"
-       case WarnLevel:
-               return "warning"
-       case ErrorLevel:
-               return "error"
-       case FatalLevel:
-               return "fatal"
-       case PanicLevel:
-               return "panic"
-       }
-
-       return "unknown"
-}
-
-// ParseLevel takes a string level and returns the Logrus log level constant.
-func ParseLevel(lvl string) (Level, error) {
-       switch strings.ToLower(lvl) {
-       case "panic":
-               return PanicLevel, nil
-       case "fatal":
-               return FatalLevel, nil
-       case "error":
-               return ErrorLevel, nil
-       case "warn", "warning":
-               return WarnLevel, nil
-       case "info":
-               return InfoLevel, nil
-       case "debug":
-               return DebugLevel, nil
-       }
-
-       var l Level
-       return l, fmt.Errorf("not a valid logrus Level: %q", lvl)
-}
-
-// A constant exposing all logging levels
-var AllLevels = []Level{
-       PanicLevel,
-       FatalLevel,
-       ErrorLevel,
-       WarnLevel,
-       InfoLevel,
-       DebugLevel,
-}
-
-// These are the different logging levels. You can set the logging level to log
-// on your instance of logger, obtained with `logrus.New()`.
-const (
-       // PanicLevel level, highest level of severity. Logs and then calls 
panic with the
-       // message passed to Debug, Info, ...
-       PanicLevel Level = iota
-       // FatalLevel level. Logs and then calls `os.Exit(1)`. It will exit 
even if the
-       // logging level is set to Panic.
-       FatalLevel
-       // ErrorLevel level. Logs. Used for errors that should definitely be 
noted.
-       // Commonly used for hooks to send errors to an error tracking service.
-       ErrorLevel
-       // WarnLevel level. Non-critical entries that deserve eyes.
-       WarnLevel
-       // InfoLevel level. General operational entries about what's going on 
inside the
-       // application.
-       InfoLevel
-       // DebugLevel level. Usually only enabled when debugging. Very verbose 
logging.
-       DebugLevel
-)
-
-// Won't compile if StdLogger can't be realized by a log.Logger
-var (
-       _ StdLogger = &log.Logger{}
-       _ StdLogger = &Entry{}
-       _ StdLogger = &Logger{}
-)
-
-// StdLogger is what your logrus-enabled library should take, that way
-// it'll accept a stdlib logger and a logrus logger. There's no standard
-// interface, this is the closest we get, unfortunately.
-type StdLogger interface {
-       Print(...interface{})
-       Printf(string, ...interface{})
-       Println(...interface{})
-
-       Fatal(...interface{})
-       Fatalf(string, ...interface{})
-       Fatalln(...interface{})
-
-       Panic(...interface{})
-       Panicf(string, ...interface{})
-       Panicln(...interface{})
-}
-
-// The FieldLogger interface generalizes the Entry and Logger types
-type FieldLogger interface {
-       WithField(key string, value interface{}) *Entry
-       WithFields(fields Fields) *Entry
-       WithError(err error) *Entry
-
-       Debugf(format string, args ...interface{})
-       Infof(format string, args ...interface{})
-       Printf(format string, args ...interface{})
-       Warnf(format string, args ...interface{})
-       Warningf(format string, args ...interface{})
-       Errorf(format string, args ...interface{})
-       Fatalf(format string, args ...interface{})
-       Panicf(format string, args ...interface{})
-
-       Debug(args ...interface{})
-       Info(args ...interface{})
-       Print(args ...interface{})
-       Warn(args ...interface{})
-       Warning(args ...interface{})
-       Error(args ...interface{})
-       Fatal(args ...interface{})
-       Panic(args ...interface{})
-
-       Debugln(args ...interface{})
-       Infoln(args ...interface{})
-       Println(args ...interface{})
-       Warnln(args ...interface{})
-       Warningln(args ...interface{})
-       Errorln(args ...interface{})
-       Fatalln(args ...interface{})
-       Panicln(args ...interface{})
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/terminal_appengine.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/terminal_appengine.go 
b/newt/vendor/github.com/Sirupsen/logrus/terminal_appengine.go
deleted file mode 100644
index 1960169..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/terminal_appengine.go
+++ /dev/null
@@ -1,8 +0,0 @@
-// +build appengine
-
-package logrus
-
-// IsTerminal returns true if stderr's file descriptor is a terminal.
-func IsTerminal() bool {
-       return true
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/terminal_bsd.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/terminal_bsd.go 
b/newt/vendor/github.com/Sirupsen/logrus/terminal_bsd.go
deleted file mode 100644
index 5f6be4d..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/terminal_bsd.go
+++ /dev/null
@@ -1,10 +0,0 @@
-// +build darwin freebsd openbsd netbsd dragonfly
-// +build !appengine
-
-package logrus
-
-import "syscall"
-
-const ioctlReadTermios = syscall.TIOCGETA
-
-type Termios syscall.Termios

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/terminal_linux.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/terminal_linux.go 
b/newt/vendor/github.com/Sirupsen/logrus/terminal_linux.go
deleted file mode 100644
index 308160c..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/terminal_linux.go
+++ /dev/null
@@ -1,14 +0,0 @@
-// Based on ssh/terminal:
-// Copyright 2013 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build !appengine
-
-package logrus
-
-import "syscall"
-
-const ioctlReadTermios = syscall.TCGETS
-
-type Termios syscall.Termios

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/terminal_notwindows.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/terminal_notwindows.go 
b/newt/vendor/github.com/Sirupsen/logrus/terminal_notwindows.go
deleted file mode 100644
index 329038f..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/terminal_notwindows.go
+++ /dev/null
@@ -1,22 +0,0 @@
-// Based on ssh/terminal:
-// Copyright 2011 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build linux darwin freebsd openbsd netbsd dragonfly
-// +build !appengine
-
-package logrus
-
-import (
-       "syscall"
-       "unsafe"
-)
-
-// IsTerminal returns true if stderr's file descriptor is a terminal.
-func IsTerminal() bool {
-       fd := syscall.Stderr
-       var termios Termios
-       _, _, err := syscall.Syscall6(syscall.SYS_IOCTL, uintptr(fd), 
ioctlReadTermios, uintptr(unsafe.Pointer(&termios)), 0, 0, 0)
-       return err == 0
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/terminal_solaris.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/terminal_solaris.go 
b/newt/vendor/github.com/Sirupsen/logrus/terminal_solaris.go
deleted file mode 100644
index a3c6f6e..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/terminal_solaris.go
+++ /dev/null
@@ -1,15 +0,0 @@
-// +build solaris,!appengine
-
-package logrus
-
-import (
-       "os"
-
-       "golang.org/x/sys/unix"
-)
-
-// IsTerminal returns true if the given file descriptor is a terminal.
-func IsTerminal() bool {
-       _, err := unix.IoctlGetTermios(int(os.Stdout.Fd()), unix.TCGETA)
-       return err == nil
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/terminal_windows.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/terminal_windows.go 
b/newt/vendor/github.com/Sirupsen/logrus/terminal_windows.go
deleted file mode 100644
index 3727e8a..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/terminal_windows.go
+++ /dev/null
@@ -1,27 +0,0 @@
-// Based on ssh/terminal:
-// Copyright 2011 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-// +build windows,!appengine
-
-package logrus
-
-import (
-       "syscall"
-       "unsafe"
-)
-
-var kernel32 = syscall.NewLazyDLL("kernel32.dll")
-
-var (
-       procGetConsoleMode = kernel32.NewProc("GetConsoleMode")
-)
-
-// IsTerminal returns true if stderr's file descriptor is a terminal.
-func IsTerminal() bool {
-       fd := syscall.Stderr
-       var st uint32
-       r, _, e := syscall.Syscall(procGetConsoleMode.Addr(), 2, uintptr(fd), 
uintptr(unsafe.Pointer(&st)), 0)
-       return r != 0 && e == 0
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/text_formatter.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/text_formatter.go 
b/newt/vendor/github.com/Sirupsen/logrus/text_formatter.go
deleted file mode 100644
index 9114b3c..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/text_formatter.go
+++ /dev/null
@@ -1,168 +0,0 @@
-package logrus
-
-import (
-       "bytes"
-       "fmt"
-       "runtime"
-       "sort"
-       "strings"
-       "time"
-)
-
-const (
-       nocolor = 0
-       red     = 31
-       green   = 32
-       yellow  = 33
-       blue    = 34
-       gray    = 37
-)
-
-var (
-       baseTimestamp time.Time
-       isTerminal    bool
-)
-
-func init() {
-       baseTimestamp = time.Now()
-       isTerminal = IsTerminal()
-}
-
-func miniTS() int {
-       return int(time.Since(baseTimestamp) / time.Second)
-}
-
-type TextFormatter struct {
-       // Set to true to bypass checking for a TTY before outputting colors.
-       ForceColors bool
-
-       // Force disabling colors.
-       DisableColors bool
-
-       // Disable timestamp logging. useful when output is redirected to 
logging
-       // system that already adds timestamps.
-       DisableTimestamp bool
-
-       // Enable logging the full timestamp when a TTY is attached instead of 
just
-       // the time passed since beginning of execution.
-       FullTimestamp bool
-
-       // TimestampFormat to use for display when a full timestamp is printed
-       TimestampFormat string
-
-       // The fields are sorted by default for a consistent output. For 
applications
-       // that log extremely frequently and don't use the JSON formatter this 
may not
-       // be desired.
-       DisableSorting bool
-}
-
-func (f *TextFormatter) Format(entry *Entry) ([]byte, error) {
-       var b *bytes.Buffer
-       var keys []string = make([]string, 0, len(entry.Data))
-       for k := range entry.Data {
-               keys = append(keys, k)
-       }
-
-       if !f.DisableSorting {
-               sort.Strings(keys)
-       }
-       if entry.Buffer != nil {
-               b = entry.Buffer
-       } else {
-               b = &bytes.Buffer{}
-       }
-
-       prefixFieldClashes(entry.Data)
-
-       isColorTerminal := isTerminal && (runtime.GOOS != "windows")
-       isColored := (f.ForceColors || isColorTerminal) && !f.DisableColors
-
-       timestampFormat := f.TimestampFormat
-       if timestampFormat == "" {
-               timestampFormat = DefaultTimestampFormat
-       }
-       if isColored {
-               f.printColored(b, entry, keys, timestampFormat)
-       } else {
-               if !f.DisableTimestamp {
-                       f.appendKeyValue(b, "time", 
entry.Time.Format(timestampFormat))
-               }
-               f.appendKeyValue(b, "level", entry.Level.String())
-               if entry.Message != "" {
-                       f.appendKeyValue(b, "msg", entry.Message)
-               }
-               for _, key := range keys {
-                       f.appendKeyValue(b, key, entry.Data[key])
-               }
-       }
-
-       b.WriteByte('\n')
-       return b.Bytes(), nil
-}
-
-func (f *TextFormatter) printColored(b *bytes.Buffer, entry *Entry, keys 
[]string, timestampFormat string) {
-       var levelColor int
-       switch entry.Level {
-       case DebugLevel:
-               levelColor = gray
-       case WarnLevel:
-               levelColor = yellow
-       case ErrorLevel, FatalLevel, PanicLevel:
-               levelColor = red
-       default:
-               levelColor = blue
-       }
-
-       levelText := strings.ToUpper(entry.Level.String())[0:4]
-
-       if !f.FullTimestamp {
-               fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m[%04d] %-44s ", levelColor, 
levelText, miniTS(), entry.Message)
-       } else {
-               fmt.Fprintf(b, "\x1b[%dm%s\x1b[0m[%s] %-44s ", levelColor, 
levelText, entry.Time.Format(timestampFormat), entry.Message)
-       }
-       for _, k := range keys {
-               v := entry.Data[k]
-               fmt.Fprintf(b, " \x1b[%dm%s\x1b[0m=", levelColor, k)
-               f.appendValue(b, v)
-       }
-}
-
-func needsQuoting(text string) bool {
-       for _, ch := range text {
-               if !((ch >= 'a' && ch <= 'z') ||
-                       (ch >= 'A' && ch <= 'Z') ||
-                       (ch >= '0' && ch <= '9') ||
-                       ch == '-' || ch == '.') {
-                       return true
-               }
-       }
-       return false
-}
-
-func (f *TextFormatter) appendKeyValue(b *bytes.Buffer, key string, value 
interface{}) {
-
-       b.WriteString(key)
-       b.WriteByte('=')
-       f.appendValue(b, value)
-       b.WriteByte(' ')
-}
-
-func (f *TextFormatter) appendValue(b *bytes.Buffer, value interface{}) {
-       switch value := value.(type) {
-       case string:
-               if !needsQuoting(value) {
-                       b.WriteString(value)
-               } else {
-                       fmt.Fprintf(b, "%q", value)
-               }
-       case error:
-               errmsg := value.Error()
-               if !needsQuoting(errmsg) {
-                       b.WriteString(errmsg)
-               } else {
-                       fmt.Fprintf(b, "%q", errmsg)
-               }
-       default:
-               fmt.Fprint(b, value)
-       }
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/Sirupsen/logrus/writer.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/Sirupsen/logrus/writer.go 
b/newt/vendor/github.com/Sirupsen/logrus/writer.go
deleted file mode 100644
index f74d2aa..0000000
--- a/newt/vendor/github.com/Sirupsen/logrus/writer.go
+++ /dev/null
@@ -1,53 +0,0 @@
-package logrus
-
-import (
-       "bufio"
-       "io"
-       "runtime"
-)
-
-func (logger *Logger) Writer() *io.PipeWriter {
-       return logger.WriterLevel(InfoLevel)
-}
-
-func (logger *Logger) WriterLevel(level Level) *io.PipeWriter {
-       reader, writer := io.Pipe()
-
-       var printFunc func(args ...interface{})
-       switch level {
-       case DebugLevel:
-               printFunc = logger.Debug
-       case InfoLevel:
-               printFunc = logger.Info
-       case WarnLevel:
-               printFunc = logger.Warn
-       case ErrorLevel:
-               printFunc = logger.Error
-       case FatalLevel:
-               printFunc = logger.Fatal
-       case PanicLevel:
-               printFunc = logger.Panic
-       default:
-               printFunc = logger.Print
-       }
-
-       go logger.writerScanner(reader, printFunc)
-       runtime.SetFinalizer(writer, writerFinalizer)
-
-       return writer
-}
-
-func (logger *Logger) writerScanner(reader *io.PipeReader, printFunc func(args 
...interface{})) {
-       scanner := bufio.NewScanner(reader)
-       for scanner.Scan() {
-               printFunc(scanner.Text())
-       }
-       if err := scanner.Err(); err != nil {
-               logger.Errorf("Error while reading from Writer: %s", err)
-       }
-       reader.Close()
-}
-
-func writerFinalizer(writer *io.PipeWriter) {
-       writer.Close()
-}

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/inconshreveable/mousetrap/LICENSE
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/inconshreveable/mousetrap/LICENSE 
b/newt/vendor/github.com/inconshreveable/mousetrap/LICENSE
deleted file mode 100644
index 5f0d1fb..0000000
--- a/newt/vendor/github.com/inconshreveable/mousetrap/LICENSE
+++ /dev/null
@@ -1,13 +0,0 @@
-Copyright 2014 Alan Shreve
-
-Licensed under the Apache License, Version 2.0 (the "License");
-you may not use this file except in compliance with the License.
-You may obtain a copy of the License at
-
-   http://www.apache.org/licenses/LICENSE-2.0
-
-Unless required by applicable law or agreed to in writing, software
-distributed under the License is distributed on an "AS IS" BASIS,
-WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-See the License for the specific language governing permissions and
-limitations under the License.

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/inconshreveable/mousetrap/README.md
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/inconshreveable/mousetrap/README.md 
b/newt/vendor/github.com/inconshreveable/mousetrap/README.md
deleted file mode 100644
index 7a950d1..0000000
--- a/newt/vendor/github.com/inconshreveable/mousetrap/README.md
+++ /dev/null
@@ -1,23 +0,0 @@
-# mousetrap
-
-mousetrap is a tiny library that answers a single question.
-
-On a Windows machine, was the process invoked by someone double clicking on
-the executable file while browsing in explorer?
-
-### Motivation
-
-Windows developers unfamiliar with command line tools will often "double-click"
-the executable for a tool. Because most CLI tools print the help and then exit
-when invoked without arguments, this is often very frustrating for those users.
-
-mousetrap provides a way to detect these invocations so that you can provide
-more helpful behavior and instructions on how to run the CLI tool. To see what
-this looks like, both from an organizational and a technical perspective, see
-https://inconshreveable.com/09-09-2014/sweat-the-small-stuff/
-
-### The interface
-
-The library exposes a single interface:
-
-    func StartedByExplorer() (bool)

http://git-wip-us.apache.org/repos/asf/incubator-mynewt-newtmgr/blob/e31a7d31/newt/vendor/github.com/inconshreveable/mousetrap/trap_others.go
----------------------------------------------------------------------
diff --git a/newt/vendor/github.com/inconshreveable/mousetrap/trap_others.go 
b/newt/vendor/github.com/inconshreveable/mousetrap/trap_others.go
deleted file mode 100644
index 9d2d8a4..0000000
--- a/newt/vendor/github.com/inconshreveable/mousetrap/trap_others.go
+++ /dev/null
@@ -1,15 +0,0 @@
-// +build !windows
-
-package mousetrap
-
-// 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
-//
-// On non-Windows platforms, it always returns false.
-func StartedByExplorer() bool {
-       return false
-}

Reply via email to