2024-03-07 16:45:49 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
/*
|
|
|
|
this parses the command line arguements
|
|
|
|
|
|
|
|
this enables command line options from other packages like 'gui' and 'log'
|
|
|
|
*/
|
|
|
|
|
|
|
|
type args struct {
|
2024-11-01 23:08:10 -05:00
|
|
|
Repo string `arg:"positional" help:"go import path"`
|
|
|
|
NoWork bool `arg:"--no-work" default:"true" help:"do not make or modify the go.work file"`
|
|
|
|
GoSrc bool `arg:"--go-src" default:"true" help:"only work in ~/go/src"`
|
|
|
|
DryRun bool `arg:"--dry-run" help:"show what would be run"`
|
|
|
|
Recursive bool `arg:"--recursive" default:"false" help:"resursively clone all dependencies"`
|
2024-03-07 16:45:49 -06:00
|
|
|
}
|
|
|
|
|
2024-03-07 22:07:40 -06:00
|
|
|
func (a args) Description() string {
|
2024-03-07 16:45:49 -06:00
|
|
|
return `
|
2024-03-21 22:47:17 -05:00
|
|
|
By default, go-clone will find your go.work file and work from there.
|
|
|
|
Otherwise, it will create a work/ directory.
|
|
|
|
|
2024-11-01 23:19:34 -05:00
|
|
|
This will clone the sources into ~/go/src/ for go-clone:
|
|
|
|
go-clone go.wit.com/apps/go-clone
|
2024-03-07 16:45:49 -06:00
|
|
|
|
2024-11-01 23:19:34 -05:00
|
|
|
This will recursively clone the app and all the build requirements:
|
|
|
|
go-clone --recursive go.wit.com/apps/go-clone
|
2024-03-21 19:43:26 -05:00
|
|
|
`
|
2024-03-07 16:45:49 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func (args) Version() string {
|
2024-03-21 19:43:26 -05:00
|
|
|
return "go-clone " + Version
|
2024-03-07 16:45:49 -06:00
|
|
|
}
|