Unverified Commit 27a91066 authored by Giampaolo Mancini's avatar Giampaolo Mancini Committed by GitHub

Read upload port from sketch.json (#454)

* Read upload port from sketch.json

* Fix 'attach' help message
parent d80f1199
...@@ -38,6 +38,7 @@ type Metadata struct { ...@@ -38,6 +38,7 @@ type Metadata struct {
type BoardMetadata struct { type BoardMetadata struct {
Fqbn string `json:"fqbn,required"` Fqbn string `json:"fqbn,required"`
Name string `json:"name,omitempty"` Name string `json:"name,omitempty"`
Port string `json:"port,omitepty"`
} }
// NewSketchFromPath loads a sketch from the specified path // NewSketchFromPath loads a sketch from the specified path
......
...@@ -35,14 +35,14 @@ func initAttachCommand() *cobra.Command { ...@@ -35,14 +35,14 @@ func initAttachCommand() *cobra.Command {
Use: "attach <port>|<FQBN> [sketchPath]", Use: "attach <port>|<FQBN> [sketchPath]",
Short: "Attaches a sketch to a board.", Short: "Attaches a sketch to a board.",
Long: "Attaches a sketch to a board.", Long: "Attaches a sketch to a board.",
Example: " " + os.Args[0] + " board attach serial:///dev/tty/ACM0\n" + Example: " " + os.Args[0] + " board attach serial:///dev/ttyACM0\n" +
" " + os.Args[0] + " board attach serial:///dev/tty/ACM0 HelloWorld\n" + " " + os.Args[0] + " board attach serial:///dev/ttyACM0 HelloWorld\n" +
" " + os.Args[0] + " board attach arduino:samd:mkr1000", " " + os.Args[0] + " board attach arduino:samd:mkr1000",
Args: cobra.RangeArgs(1, 2), Args: cobra.RangeArgs(1, 2),
Run: runAttachCommand, Run: runAttachCommand,
} }
attachCommand.Flags().StringVar(&attachFlags.searchTimeout, "timeout", "5s", attachCommand.Flags().StringVar(&attachFlags.searchTimeout, "timeout", "5s",
"The timeout of the search of connected devices, try to high it if your board is not found (e.g. to 10s).") "The connected devices search timeout, raise it if your board doesn't show up (e.g. to 10s).")
return attachCommand return attachCommand
} }
......
...@@ -96,6 +96,7 @@ func Attach(ctx context.Context, req *rpc.BoardAttachReq, taskCB commands.TaskPr ...@@ -96,6 +96,7 @@ func Attach(ctx context.Context, req *rpc.BoardAttachReq, taskCB commands.TaskPr
sketch.Metadata.CPU = sketches.BoardMetadata{ sketch.Metadata.CPU = sketches.BoardMetadata{
Fqbn: board.FQBN(), Fqbn: board.FQBN(),
Name: board.Name(), Name: board.Name(),
Port: deviceURI.String(),
} }
} }
......
...@@ -19,6 +19,7 @@ import ( ...@@ -19,6 +19,7 @@ import (
"context" "context"
"fmt" "fmt"
"io" "io"
"net/url"
"os" "os"
"path/filepath" "path/filepath"
"strings" "strings"
...@@ -53,6 +54,15 @@ func Upload(ctx context.Context, req *rpc.UploadReq, outStream io.Writer, errStr ...@@ -53,6 +54,15 @@ func Upload(ctx context.Context, req *rpc.UploadReq, outStream io.Writer, errStr
// FIXME: make a specification on how a port is specified via command line // FIXME: make a specification on how a port is specified via command line
port := req.GetPort() port := req.GetPort()
if port == "" && sketch != nil && sketch.Metadata != nil {
deviceURI, err := url.Parse(sketch.Metadata.CPU.Port)
if err != nil {
return nil, fmt.Errorf("invalid Device URL format: %s", err)
}
if deviceURI.Scheme == "serial" {
port = deviceURI.Host + deviceURI.Path
}
}
if port == "" { if port == "" {
return nil, fmt.Errorf("no upload port provided") return nil, fmt.Errorf("no upload port provided")
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment