summaryrefslogtreecommitdiff
path: root/cmd/podman
diff options
context:
space:
mode:
Diffstat (limited to 'cmd/podman')
-rw-r--r--cmd/podman/build.go101
1 files changed, 101 insertions, 0 deletions
diff --git a/cmd/podman/build.go b/cmd/podman/build.go
index c7f95f5e5..92823f72b 100644
--- a/cmd/podman/build.go
+++ b/cmd/podman/build.go
@@ -1,6 +1,7 @@
package main
import (
+ "fmt"
"os"
"os/exec"
"strconv"
@@ -11,6 +12,8 @@ import (
var (
buildFlags = []cli.Flag{
+ // The following flags are emulated from:
+ // src/github.com/projectatomic/buildah/cmd/bud.go
cli.StringFlag{
Name: "authfile",
Usage: "path of the authentication file. Default is ${XDG_RUNTIME_DIR}/containers/auth.json",
@@ -65,6 +68,61 @@ var (
Name: "tls-verify",
Usage: "require HTTPS and verify certificates when accessing the registry",
},
+ // The following flags are emulated from:
+ // src/github.com/projectatomic/buildah/cmd/common.go fromAndBudFlags
+ cli.StringSliceFlag{
+ Name: "add-host",
+ Usage: "add a custom host-to-IP mapping (host:ip) (default [])",
+ },
+ cli.StringFlag{
+ Name: "cgroup-parent",
+ Usage: "optional parent cgroup for the container",
+ },
+ cli.Uint64Flag{
+ Name: "cpu-period",
+ Usage: "limit the CPU CFS (Completely Fair Scheduler) period",
+ },
+ cli.Int64Flag{
+ Name: "cpu-quota",
+ Usage: "limit the CPU CFS (Completely Fair Scheduler) quota",
+ },
+ cli.Uint64Flag{
+ Name: "cpu-shares",
+ Usage: "CPU shares (relative weight)",
+ },
+ cli.StringFlag{
+ Name: "cpuset-cpus",
+ Usage: "CPUs in which to allow execution (0-3, 0,1)",
+ },
+ cli.StringFlag{
+ Name: "cpuset-mems",
+ Usage: "memory nodes (MEMs) in which to allow execution (0-3, 0,1). Only effective on NUMA systems.",
+ },
+ cli.StringFlag{
+ Name: "memory, m",
+ Usage: "memory limit (format: <number>[<unit>], where unit = b, k, m or g)",
+ },
+ cli.StringFlag{
+ Name: "memory-swap",
+ Usage: "swap limit equal to memory plus swap: '-1' to enable unlimited swap",
+ },
+ cli.StringSliceFlag{
+ Name: "security-opt",
+ Usage: "security Options (default [])",
+ },
+ cli.StringFlag{
+ Name: "shm-size",
+ Usage: "size of `/dev/shm`. The format is `<number><unit>`.",
+ Value: "65536k",
+ },
+ cli.StringSliceFlag{
+ Name: "ulimit",
+ Usage: "ulimit options (default [])",
+ },
+ cli.StringSliceFlag{
+ Name: "volume, v",
+ Usage: "bind mount a volume into the container (default [])",
+ },
}
buildDescription = "podman build launches the Buildah command to build an OCI Image. Buildah must be installed for this command to work."
buildCommand = cli.Command{
@@ -81,6 +139,7 @@ func buildCmd(c *cli.Context) error {
budCmdArgs := []string{}
+ // Handle Global Options
logLevel := c.GlobalString("log-level")
if logLevel == "debug" {
budCmdArgs = append(budCmdArgs, "--debug")
@@ -100,6 +159,7 @@ func buildCmd(c *cli.Context) error {
budCmdArgs = append(budCmdArgs, "bud")
+ // Buildah bud specific options
if c.IsSet("authfile") {
budCmdArgs = append(budCmdArgs, "--authfile", c.String("authfile"))
}
@@ -142,6 +202,47 @@ func buildCmd(c *cli.Context) error {
budCmdArgs = append(budCmdArgs, tlsParam)
}
+ // Buildah bud and from options from cmd/buildah/common.go
+ for _, addHostArg := range c.StringSlice("add-host") {
+ budCmdArgs = append(budCmdArgs, "--add-host", addHostArg)
+ }
+ if c.IsSet("cgroup-parent") {
+ budCmdArgs = append(budCmdArgs, "--cgroup-parent", c.String("cgroup-parent"))
+ }
+ if c.IsSet("cpu-period") {
+ budCmdArgs = append(budCmdArgs, "--cpu-period", fmt.Sprintf("%v", c.Int64("cpu-period")))
+ }
+ if c.IsSet("cpu-quota") {
+ budCmdArgs = append(budCmdArgs, "--cpu-quota", fmt.Sprintf("%v", c.Uint64("cpu-quota")))
+ }
+ if c.IsSet("cpu-shares") {
+ budCmdArgs = append(budCmdArgs, "--cpu-shares", fmt.Sprintf("%v", c.Uint64("cpu-shares")))
+ }
+ if c.IsSet("cpuset-cpus") {
+ budCmdArgs = append(budCmdArgs, "--cpuset-cpus", c.String("cpuset-cpus"))
+ }
+ if c.IsSet("cpuset-mems") {
+ budCmdArgs = append(budCmdArgs, "--cpuset-mems", c.String("cpuset-mems"))
+ }
+ if c.IsSet("memory") {
+ budCmdArgs = append(budCmdArgs, "--memory", c.String("memory"))
+ }
+ if c.IsSet("memory-swap") {
+ budCmdArgs = append(budCmdArgs, "--memory-swap", c.String("memory-swap"))
+ }
+ for _, securityOptArg := range c.StringSlice("security-opt") {
+ budCmdArgs = append(budCmdArgs, "--security-opt", securityOptArg)
+ }
+ if c.IsSet("shm-size") {
+ budCmdArgs = append(budCmdArgs, "--shm-size", c.String("shm-size"))
+ }
+ for _, ulimitArg := range c.StringSlice("ulimit") {
+ budCmdArgs = append(budCmdArgs, "--ulimit", ulimitArg)
+ }
+ for _, volumeArg := range c.StringSlice("volume") {
+ budCmdArgs = append(budCmdArgs, "--volume", volumeArg)
+ }
+
if len(c.Args()) > 0 {
budCmdArgs = append(budCmdArgs, c.Args()...)
}