feat: auto guess port for monitoring
This commit is contained in:
@@ -36,6 +36,8 @@ var Cmd = &base.Command{
|
|||||||
func init() {
|
func init() {
|
||||||
Cmd.Run = runCmd
|
Cmd.Run = runCmd
|
||||||
base.PassBuildFlags(Cmd)
|
base.PassBuildFlags(Cmd)
|
||||||
|
|
||||||
|
flags.AddCommonFlags(&Cmd.Flag)
|
||||||
flags.AddBuildFlags(&Cmd.Flag)
|
flags.AddBuildFlags(&Cmd.Flag)
|
||||||
flags.AddOutputFlags(&Cmd.Flag)
|
flags.AddOutputFlags(&Cmd.Flag)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,6 +31,7 @@ var Cmd = &base.Command{
|
|||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
Cmd.Run = runCmd
|
Cmd.Run = runCmd
|
||||||
|
flags.AddCommonFlags(&Cmd.Flag)
|
||||||
flags.AddBuildFlags(&Cmd.Flag)
|
flags.AddBuildFlags(&Cmd.Flag)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -27,8 +27,11 @@ var CheckLinkArgs bool
|
|||||||
var CheckLLFiles bool
|
var CheckLLFiles bool
|
||||||
var GenLLFiles bool
|
var GenLLFiles bool
|
||||||
|
|
||||||
|
func AddCommonFlags(fs *flag.FlagSet) {
|
||||||
|
fs.BoolVar(&Verbose, "v", false, "Verbose output")
|
||||||
|
}
|
||||||
|
|
||||||
func AddBuildFlags(fs *flag.FlagSet) {
|
func AddBuildFlags(fs *flag.FlagSet) {
|
||||||
fs.BoolVar(&Verbose, "v", false, "Verbose mode")
|
|
||||||
fs.StringVar(&Tags, "tags", "", "Build tags")
|
fs.StringVar(&Tags, "tags", "", "Build tags")
|
||||||
fs.StringVar(&BuildEnv, "buildenv", "", "Build environment")
|
fs.StringVar(&BuildEnv, "buildenv", "", "Build environment")
|
||||||
if buildenv.Dev {
|
if buildenv.Dev {
|
||||||
|
|||||||
@@ -35,6 +35,7 @@ var Cmd = &base.Command{
|
|||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
Cmd.Run = runCmd
|
Cmd.Run = runCmd
|
||||||
|
flags.AddCommonFlags(&Cmd.Flag)
|
||||||
flags.AddBuildFlags(&Cmd.Flag)
|
flags.AddBuildFlags(&Cmd.Flag)
|
||||||
flags.AddEmbeddedFlags(&Cmd.Flag)
|
flags.AddEmbeddedFlags(&Cmd.Flag)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ import (
|
|||||||
|
|
||||||
"github.com/goplus/llgo/cmd/internal/base"
|
"github.com/goplus/llgo/cmd/internal/base"
|
||||||
"github.com/goplus/llgo/cmd/internal/flags"
|
"github.com/goplus/llgo/cmd/internal/flags"
|
||||||
|
"github.com/goplus/llgo/internal/crosscompile"
|
||||||
"github.com/goplus/llgo/internal/monitor"
|
"github.com/goplus/llgo/internal/monitor"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -32,6 +33,7 @@ var Cmd = &base.Command{
|
|||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
flags.AddCommonFlags(&Cmd.Flag)
|
||||||
flags.AddEmbeddedFlags(&Cmd.Flag)
|
flags.AddEmbeddedFlags(&Cmd.Flag)
|
||||||
Cmd.Run = runMonitor
|
Cmd.Run = runMonitor
|
||||||
}
|
}
|
||||||
@@ -45,24 +47,30 @@ func runMonitor(cmd *base.Command, args []string) {
|
|||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
if flags.Port == "" && flags.Target == "" {
|
|
||||||
fmt.Fprintf(os.Stderr, "llgo monitor: must specify either -port or -target\n")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
var executable string
|
var executable string
|
||||||
if len(args) == 1 {
|
if len(args) == 1 {
|
||||||
executable = args[0]
|
executable = args[0]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var serialPort []string
|
||||||
|
if flags.Target != "" {
|
||||||
|
conf, err := crosscompile.UseTarget(flags.Target)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(os.Stderr, "llgo monitor: %v\n", err)
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
serialPort = conf.Flash.SerialPort
|
||||||
|
}
|
||||||
|
|
||||||
config := monitor.MonitorConfig{
|
config := monitor.MonitorConfig{
|
||||||
Port: flags.Port,
|
Port: flags.Port,
|
||||||
Target: flags.Target,
|
Target: flags.Target,
|
||||||
BaudRate: flags.BaudRate,
|
BaudRate: flags.BaudRate,
|
||||||
Executable: executable,
|
Executable: executable,
|
||||||
|
SerialPort: serialPort,
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := monitor.Monitor(config, true); err != nil {
|
if err := monitor.Monitor(config, flags.Verbose); err != nil {
|
||||||
fmt.Fprintf(os.Stderr, "llgo monitor: %v\n", err)
|
fmt.Fprintf(os.Stderr, "llgo monitor: %v\n", err)
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -48,11 +48,13 @@ func init() {
|
|||||||
Cmd.Run = runCmd
|
Cmd.Run = runCmd
|
||||||
CmpTestCmd.Run = runCmpTest
|
CmpTestCmd.Run = runCmpTest
|
||||||
base.PassBuildFlags(Cmd)
|
base.PassBuildFlags(Cmd)
|
||||||
|
flags.AddCommonFlags(&Cmd.Flag)
|
||||||
flags.AddBuildFlags(&Cmd.Flag)
|
flags.AddBuildFlags(&Cmd.Flag)
|
||||||
flags.AddEmulatorFlags(&Cmd.Flag)
|
flags.AddEmulatorFlags(&Cmd.Flag)
|
||||||
flags.AddEmbeddedFlags(&Cmd.Flag) // for -target support
|
flags.AddEmbeddedFlags(&Cmd.Flag) // for -target support
|
||||||
|
|
||||||
base.PassBuildFlags(CmpTestCmd)
|
base.PassBuildFlags(CmpTestCmd)
|
||||||
|
flags.AddCommonFlags(&CmpTestCmd.Flag)
|
||||||
flags.AddBuildFlags(&CmpTestCmd.Flag)
|
flags.AddBuildFlags(&CmpTestCmd.Flag)
|
||||||
flags.AddEmulatorFlags(&CmpTestCmd.Flag)
|
flags.AddEmulatorFlags(&CmpTestCmd.Flag)
|
||||||
flags.AddEmbeddedFlags(&CmpTestCmd.Flag) // for -target support
|
flags.AddEmbeddedFlags(&CmpTestCmd.Flag) // for -target support
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ var Cmd = &base.Command{
|
|||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
Cmd.Run = runCmd
|
Cmd.Run = runCmd
|
||||||
|
flags.AddCommonFlags(&Cmd.Flag)
|
||||||
flags.AddBuildFlags(&Cmd.Flag)
|
flags.AddBuildFlags(&Cmd.Flag)
|
||||||
flags.AddEmulatorFlags(&Cmd.Flag)
|
flags.AddEmulatorFlags(&Cmd.Flag)
|
||||||
flags.AddEmbeddedFlags(&Cmd.Flag)
|
flags.AddEmbeddedFlags(&Cmd.Flag)
|
||||||
|
|||||||
@@ -360,12 +360,16 @@ func Do(args []string, conf *Config) ([]Package, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
err = monitor.Monitor(monitor.MonitorConfig{
|
monitorConfig := monitor.MonitorConfig{
|
||||||
Port: ctx.buildConf.Port,
|
Port: ctx.buildConf.Port,
|
||||||
Target: conf.Target,
|
Target: conf.Target,
|
||||||
Executable: finalApp,
|
Executable: finalApp,
|
||||||
BaudRate: conf.BaudRate,
|
BaudRate: conf.BaudRate,
|
||||||
}, verbose)
|
}
|
||||||
|
if ctx.crossCompile.Flash.Method != "openocd" {
|
||||||
|
monitorConfig.SerialPort = ctx.crossCompile.Flash.SerialPort
|
||||||
|
}
|
||||||
|
err = monitor.Monitor(monitorConfig, verbose)
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|||||||
@@ -491,8 +491,8 @@ func use(goos, goarch string, wasiThreads bool) (export Export, err error) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// useTarget loads configuration from a target name (e.g., "rp2040", "wasi")
|
// UseTarget loads configuration from a target name (e.g., "rp2040", "wasi")
|
||||||
func useTarget(targetName string) (export Export, err error) {
|
func UseTarget(targetName string) (export Export, err error) {
|
||||||
resolver := targets.NewDefaultResolver()
|
resolver := targets.NewDefaultResolver()
|
||||||
|
|
||||||
config, err := resolver.Resolve(targetName)
|
config, err := resolver.Resolve(targetName)
|
||||||
@@ -716,7 +716,7 @@ func useTarget(targetName string) (export Export, err error) {
|
|||||||
// If targetName is provided, it takes precedence over goos/goarch
|
// If targetName is provided, it takes precedence over goos/goarch
|
||||||
func Use(goos, goarch string, wasiThreads bool, targetName string) (export Export, err error) {
|
func Use(goos, goarch string, wasiThreads bool, targetName string) (export Export, err error) {
|
||||||
if targetName != "" && !strings.HasPrefix(targetName, "wasm") && !strings.HasPrefix(targetName, "wasi") {
|
if targetName != "" && !strings.HasPrefix(targetName, "wasm") && !strings.HasPrefix(targetName, "wasi") {
|
||||||
return useTarget(targetName)
|
return UseTarget(targetName)
|
||||||
}
|
}
|
||||||
return use(goos, goarch, wasiThreads)
|
return use(goos, goarch, wasiThreads)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -214,7 +214,7 @@ func TestUseTarget(t *testing.T) {
|
|||||||
|
|
||||||
for _, tc := range testCases {
|
for _, tc := range testCases {
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
t.Run(tc.name, func(t *testing.T) {
|
||||||
export, err := useTarget(tc.targetName)
|
export, err := UseTarget(tc.targetName)
|
||||||
|
|
||||||
if tc.expectError {
|
if tc.expectError {
|
||||||
if err == nil {
|
if err == nil {
|
||||||
|
|||||||
@@ -22,11 +22,12 @@ import (
|
|||||||
|
|
||||||
// MonitorConfig contains configuration for the monitor
|
// MonitorConfig contains configuration for the monitor
|
||||||
type MonitorConfig struct {
|
type MonitorConfig struct {
|
||||||
Port string // Serial port device
|
Port string // Serial port device
|
||||||
Target string // Target name for crosscompile config
|
Target string // Target name for crosscompile config
|
||||||
BaudRate int // Baudrate of serial monitor
|
BaudRate int // Baudrate of serial monitor
|
||||||
Executable string // Optional path to executable for debug info
|
Executable string // Optional path to executable for debug info
|
||||||
WaitTime int // Wait time for port connection (ms)
|
WaitTime int // Wait time for port connection (ms)
|
||||||
|
SerialPort []string // List of serial ports to use
|
||||||
}
|
}
|
||||||
|
|
||||||
// Monitor starts serial monitoring with the given configuration
|
// Monitor starts serial monitoring with the given configuration
|
||||||
@@ -40,7 +41,7 @@ func Monitor(config MonitorConfig, verbose bool) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Resolve port using flash.GetPort
|
// Resolve port using flash.GetPort
|
||||||
port, err := flash.GetPort(config.Port, nil)
|
port, err := flash.GetPort(config.Port, config.SerialPort)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("failed to find port: %w", err)
|
return fmt.Errorf("failed to find port: %w", err)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user