gopy/main.go

104 lines
2.0 KiB
Go
Raw Permalink Normal View History

2015-01-30 17:01:15 +00:00
// Copyright 2015 The go-python Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package main
import (
"fmt"
2019-01-11 11:00:12 +00:00
"io"
2015-01-30 17:01:15 +00:00
"log"
"os"
2019-01-11 11:00:12 +00:00
"path"
2015-07-24 14:16:31 +00:00
"github.com/gonuts/commander"
"github.com/gonuts/flag"
2019-01-11 11:00:12 +00:00
"github.com/pkg/errors"
"github.com/go-python/gopy/bind"
)
// BuildCfg contains command options and binding generation options
type BuildCfg struct {
bind.BindCfg
// include symbols in output
Symbols bool
// suppress warning messages, which may be expected
NoWarn bool
// do not generate a Makefile, e.g., when called from Makefile
NoMake bool
// link resulting library dynamically
DynamicLinking bool
// BuildTags to be passed into `go build`.
BuildTags string
}
// NewBuildCfg returns a newly constructed build config
func NewBuildCfg() *BuildCfg {
var cfg BuildCfg
cfg.Cmd = argStr()
return &cfg
}
func run(args []string) error {
app := &commander.Command{
2015-07-24 14:16:31 +00:00
UsageLine: "gopy",
Subcommands: []*commander.Command{
gopyMakeCmdGen(),
gopyMakeCmdBuild(),
gopyMakeCmdPkg(),
gopyMakeCmdExe(),
2015-07-24 14:16:31 +00:00
},
Flag: *flag.NewFlagSet("gopy", flag.ExitOnError),
}
2015-01-30 17:01:15 +00:00
err := app.Flag.Parse(args)
2015-01-30 17:01:15 +00:00
if err != nil {
return fmt.Errorf("could not parse flags: %v", err)
2015-01-30 17:01:15 +00:00
}
appArgs := app.Flag.Args()
err = app.Dispatch(appArgs)
2015-01-30 17:01:15 +00:00
if err != nil {
return fmt.Errorf("error dispatching command: %v", err)
2015-01-30 17:01:15 +00:00
}
return nil
}
2015-01-30 17:01:15 +00:00
func main() {
err := run(os.Args[1:])
if err != nil {
log.Fatal(err)
}
2015-01-30 17:01:15 +00:00
os.Exit(0)
}
2019-01-11 11:00:12 +00:00
func copyCmd(src, dst string) error {
srcf, err := os.Open(src)
if err != nil {
return errors.Wrap(err, "could not open source for copy")
}
defer srcf.Close()
os.MkdirAll(path.Dir(dst), 0755)
dstf, err := os.Create(dst)
if err != nil {
return errors.Wrap(err, "could not create destination for copy")
}
defer dstf.Close()
_, err = io.Copy(dstf, srcf)
if err != nil {
return errors.Wrap(err, "could not copy bytes to destination")
}
err = dstf.Sync()
if err != nil {
return errors.Wrap(err, "could not synchronize destination")
}
return dstf.Close()
}