aboutsummaryrefslogtreecommitdiffstats
path: root/commands
diff options
context:
space:
mode:
authorMichael Muré <batolettre@gmail.com>2018-09-24 17:11:50 +0200
committerMichael Muré <batolettre@gmail.com>2018-09-24 17:11:50 +0200
commit2282cbb595ff5cc603d11645ddc833d70de9ad9d (patch)
tree635bfafb7c907d3f510b516773e32ddb44d85287 /commands
parent061e83d4b4aa66c2691b3699a3e770b2a58d26df (diff)
downloadgit-bug-2282cbb595ff5cc603d11645ddc833d70de9ad9d.tar.gz
commands: add "bridge pull"
Diffstat (limited to 'commands')
-rw-r--r--commands/bridge_pull.go45
1 files changed, 45 insertions, 0 deletions
diff --git a/commands/bridge_pull.go b/commands/bridge_pull.go
new file mode 100644
index 00000000..fc12d369
--- /dev/null
+++ b/commands/bridge_pull.go
@@ -0,0 +1,45 @@
+package commands
+
+import (
+ "github.com/MichaelMure/git-bug/bridge"
+ "github.com/MichaelMure/git-bug/bridge/core"
+ "github.com/MichaelMure/git-bug/cache"
+ "github.com/spf13/cobra"
+)
+
+func runBridgePull(cmd *cobra.Command, args []string) error {
+ backend, err := cache.NewRepoCache(repo)
+ if err != nil {
+ return err
+ }
+ defer backend.Close()
+
+ var b *core.Bridge
+
+ if len(args) == 0 {
+ b, err = bridge.DefaultBridge(backend)
+ } else {
+ b, err = bridge.NewBridgeFullName(backend, args[0])
+ }
+
+ if err != nil {
+ return err
+ }
+
+ err = b.ImportAll()
+ if err != nil {
+ return err
+ }
+
+ return nil
+}
+
+var bridgePullCmd = &cobra.Command{
+ Use: "pull [<name>]",
+ Short: "Pull updates",
+ RunE: runBridgePull,
+}
+
+func init() {
+ bridgeCmd.AddCommand(bridgePullCmd)
+}