22c9e0471c
Previously we used the word "Environment" as the term for a deployment target, but since then we've started to use the term Stack. Adopt this across the CLI. From a user's point of view, there are a few changes: 1. The `env` verb has been renamed to `stack` 2. The `-e` and `--env` options to commands which operate on an environment now take `-s` or `--stack` instead. 3. Becase of (2), the commands that used `-s` to display a summary now only support passing the full option name (`--summary`). On the local file system, we still store checkpoint data in the `env` sub-folder under `.pulumi` (so we can reuse existing checkpoint files that were written to the old folder)
37 lines
991 B
Go
37 lines
991 B
Go
// Copyright 2016-2017, Pulumi Corporation. All rights reserved.
|
|
|
|
package cmd
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/pulumi/pulumi/pkg/tokens"
|
|
"github.com/spf13/cobra"
|
|
|
|
"github.com/pulumi/pulumi/pkg/util/cmdutil"
|
|
)
|
|
|
|
func newStackSelectCmd() *cobra.Command {
|
|
return &cobra.Command{
|
|
Use: "select [<stack>]",
|
|
Short: "Switch the current workspace to the given stack",
|
|
Long: "Switch the current workspace to the given stack. This allows you to use\n" +
|
|
"other commands like `config`, `preview`, and `push` without needing to specify the\n" +
|
|
"stack name each and every time.\n" +
|
|
"\n" +
|
|
"If no <stack> argument is supplied, the current stack is printed.",
|
|
Run: cmdutil.RunFunc(func(cmd *cobra.Command, args []string) error {
|
|
// Read in the name of the stack to switch to.
|
|
if len(args) == 0 {
|
|
name, err := getCurrentStack()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
fmt.Printf("%v\n", name)
|
|
}
|
|
|
|
return setCurrentStack(tokens.QName(args[0]), true)
|
|
}),
|
|
}
|
|
}
|