зеркало из https://github.com/microsoft/docker.git
Fix builder/parser so it keeps some whitespace on split lines.
If previous line ends with whitespace, or next line starts with whitepsace we need to preserve a space otherwise things line: RUN echo\ hello will appear as: RUN echohello Noticed this while looking at #5744 because he had lines ending in &&\ Signed-off-by: Doug Davis <dug@us.ibm.com>
This commit is contained in:
Родитель
f69a262464
Коммит
f440c6b224
|
@ -6,6 +6,7 @@ import (
|
||||||
"io"
|
"io"
|
||||||
"regexp"
|
"regexp"
|
||||||
"strings"
|
"strings"
|
||||||
|
"unicode"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Node is a structure used to represent a parse tree.
|
// Node is a structure used to represent a parse tree.
|
||||||
|
@ -96,14 +97,14 @@ func Parse(rwc io.Reader) (*Node, error) {
|
||||||
scanner := bufio.NewScanner(rwc)
|
scanner := bufio.NewScanner(rwc)
|
||||||
|
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
line, child, err := parseLine(strings.TrimSpace(scanner.Text()))
|
line, child, err := parseLine(strings.TrimLeftFunc(scanner.Text(), unicode.IsSpace))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if line != "" && child == nil {
|
if line != "" && child == nil {
|
||||||
for scanner.Scan() {
|
for scanner.Scan() {
|
||||||
newline := strings.TrimSpace(scanner.Text())
|
newline := scanner.Text()
|
||||||
|
|
||||||
if newline == "" {
|
if newline == "" {
|
||||||
continue
|
continue
|
||||||
|
|
|
@ -71,8 +71,8 @@ func TestTestData(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ast.Dump()+"\n" != string(content) {
|
if ast.Dump()+"\n" != string(content) {
|
||||||
fmt.Fprintln(os.Stderr, ast.Dump())
|
fmt.Fprintln(os.Stderr, "Result:\n"+ast.Dump())
|
||||||
fmt.Fprintln(os.Stderr, string(content))
|
fmt.Fprintln(os.Stderr, "Expected:\n"+string(content))
|
||||||
t.Fatalf("%s: AST dump of dockerfile does not match result", dir.Name())
|
t.Fatalf("%s: AST dump of dockerfile does not match result", dir.Name())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,4 +2,4 @@
|
||||||
(maintainer "brimstone@the.narro.ws")
|
(maintainer "brimstone@the.narro.ws")
|
||||||
(env "GOPATH" "/go")
|
(env "GOPATH" "/go")
|
||||||
(entrypoint "/usr/local/bin/consuldock")
|
(entrypoint "/usr/local/bin/consuldock")
|
||||||
(run "apt-get update && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.clean && apt-get install -y --no-install-recommends git golang ca-certificates && apt-get clean && rm -rf /var/lib/apt/lists && go get -v github.com/brimstone/consuldock && mv $GOPATH/bin/consuldock /usr/local/bin/consuldock && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.dirty && apt-get remove --purge -y $(diff /tmp/dpkg.clean /tmp/dpkg.dirty | awk '/^>/ {print $2}') && rm /tmp/dpkg.* && rm -rf $GOPATH")
|
(run "apt-get update && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.clean && apt-get install -y --no-install-recommends git golang ca-certificates && apt-get clean && rm -rf /var/lib/apt/lists && go get -v github.com/brimstone/consuldock && mv $GOPATH/bin/consuldock /usr/local/bin/consuldock && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.dirty && apt-get remove --purge -y $(diff /tmp/dpkg.clean /tmp/dpkg.dirty | awk '/^>/ {print $2}') && rm /tmp/dpkg.* && rm -rf $GOPATH")
|
||||||
|
|
|
@ -2,8 +2,8 @@
|
||||||
(cmd)
|
(cmd)
|
||||||
(entrypoint "/usr/bin/consul" "agent" "-server" "-data-dir=/consul" "-client=0.0.0.0" "-ui-dir=/webui")
|
(entrypoint "/usr/bin/consul" "agent" "-server" "-data-dir=/consul" "-client=0.0.0.0" "-ui-dir=/webui")
|
||||||
(expose "8500" "8600" "8400" "8301" "8302")
|
(expose "8500" "8600" "8400" "8301" "8302")
|
||||||
(run "apt-get update && apt-get install -y unzip wget && apt-get clean && rm -rf /var/lib/apt/lists")
|
(run "apt-get update && apt-get install -y unzip wget && apt-get clean && rm -rf /var/lib/apt/lists")
|
||||||
(run "cd /tmp && wget https://dl.bintray.com/mitchellh/consul/0.3.1_web_ui.zip -O web_ui.zip && unzip web_ui.zip && mv dist /webui && rm web_ui.zip")
|
(run "cd /tmp && wget https://dl.bintray.com/mitchellh/consul/0.3.1_web_ui.zip -O web_ui.zip && unzip web_ui.zip && mv dist /webui && rm web_ui.zip")
|
||||||
(run "apt-get update && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.clean && apt-get install -y --no-install-recommends unzip wget && apt-get clean && rm -rf /var/lib/apt/lists && cd /tmp && wget https://dl.bintray.com/mitchellh/consul/0.3.1_web_ui.zip -O web_ui.zip && unzip web_ui.zip && mv dist /webui && rm web_ui.zip && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.dirty && apt-get remove --purge -y $(diff /tmp/dpkg.clean /tmp/dpkg.dirty | awk '/^>/ {print $2}') && rm /tmp/dpkg.*")
|
(run "apt-get update && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.clean && apt-get install -y --no-install-recommends unzip wget && apt-get clean && rm -rf /var/lib/apt/lists && cd /tmp && wget https://dl.bintray.com/mitchellh/consul/0.3.1_web_ui.zip -O web_ui.zip && unzip web_ui.zip && mv dist /webui && rm web_ui.zip && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.dirty && apt-get remove --purge -y $(diff /tmp/dpkg.clean /tmp/dpkg.dirty | awk '/^>/ {print $2}') && rm /tmp/dpkg.*")
|
||||||
(env "GOPATH" "/go")
|
(env "GOPATH" "/go")
|
||||||
(run "apt-get update && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.clean && apt-get install -y --no-install-recommends git golang ca-certificates build-essential && apt-get clean && rm -rf /var/lib/apt/lists && go get -v github.com/hashicorp/consul && mv $GOPATH/bin/consul /usr/bin/consul && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.dirty && apt-get remove --purge -y $(diff /tmp/dpkg.clean /tmp/dpkg.dirty | awk '/^>/ {print $2}') && rm /tmp/dpkg.* && rm -rf $GOPATH")
|
(run "apt-get update && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.clean && apt-get install -y --no-install-recommends git golang ca-certificates build-essential && apt-get clean && rm -rf /var/lib/apt/lists && go get -v github.com/hashicorp/consul && mv $GOPATH/bin/consul /usr/bin/consul && dpkg -l | awk '/^ii/ {print $2}' > /tmp/dpkg.dirty && apt-get remove --purge -y $(diff /tmp/dpkg.clean /tmp/dpkg.dirty | awk '/^>/ {print $2}') && rm /tmp/dpkg.* && rm -rf $GOPATH")
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
FROM ubuntu:14.04
|
||||||
|
|
||||||
|
RUN echo hello\
|
||||||
|
world\
|
||||||
|
goodnight \
|
||||||
|
moon\
|
||||||
|
light\
|
||||||
|
ning
|
||||||
|
RUN echo hello \
|
||||||
|
world
|
||||||
|
RUN echo hello \
|
||||||
|
world
|
||||||
|
RUN echo hello \
|
||||||
|
goodbye\
|
||||||
|
frog
|
||||||
|
RUN echo hello \
|
||||||
|
RUN echo hi \
|
||||||
|
\
|
||||||
|
world \
|
||||||
|
\
|
||||||
|
good\
|
||||||
|
\
|
||||||
|
night
|
||||||
|
RUN echo goodbye\
|
||||||
|
frog
|
||||||
|
RUN echo good\
|
||||||
|
bye\
|
||||||
|
frog
|
|
@ -0,0 +1,9 @@
|
||||||
|
(from "ubuntu:14.04")
|
||||||
|
(run "echo hello world goodnight moon lightning")
|
||||||
|
(run "echo hello world")
|
||||||
|
(run "echo hello world")
|
||||||
|
(run "echo hello goodbyefrog")
|
||||||
|
(run "echo hello \\")
|
||||||
|
(run "echo hi world goodnight")
|
||||||
|
(run "echo goodbyefrog")
|
||||||
|
(run "echo goodbyefrog")
|
|
@ -25,7 +25,7 @@
|
||||||
(run "echo \"cfg_dir=${NAGIOS_HOME}/etc/conf.d\" >> ${NAGIOS_HOME}/etc/nagios.cfg")
|
(run "echo \"cfg_dir=${NAGIOS_HOME}/etc/conf.d\" >> ${NAGIOS_HOME}/etc/nagios.cfg")
|
||||||
(run "echo \"cfg_dir=${NAGIOS_HOME}/etc/monitor\" >> ${NAGIOS_HOME}/etc/nagios.cfg")
|
(run "echo \"cfg_dir=${NAGIOS_HOME}/etc/monitor\" >> ${NAGIOS_HOME}/etc/nagios.cfg")
|
||||||
(run "download-mibs && echo \"mibs +ALL\" > /etc/snmp/snmp.conf")
|
(run "download-mibs && echo \"mibs +ALL\" > /etc/snmp/snmp.conf")
|
||||||
(run "sed -i 's,/bin/mail,/usr/bin/mail,' /opt/nagios/etc/objects/commands.cfg && sed -i 's,/usr/usr,/usr,' /opt/nagios/etc/objects/commands.cfg")
|
(run "sed -i 's,/bin/mail,/usr/bin/mail,' /opt/nagios/etc/objects/commands.cfg && sed -i 's,/usr/usr,/usr,' /opt/nagios/etc/objects/commands.cfg")
|
||||||
(run "cp /etc/services /var/spool/postfix/etc/")
|
(run "cp /etc/services /var/spool/postfix/etc/")
|
||||||
(run "mkdir -p /etc/sv/nagios && mkdir -p /etc/sv/apache && rm -rf /etc/sv/getty-5 && mkdir -p /etc/sv/postfix")
|
(run "mkdir -p /etc/sv/nagios && mkdir -p /etc/sv/apache && rm -rf /etc/sv/getty-5 && mkdir -p /etc/sv/postfix")
|
||||||
(add "nagios.init" "/etc/sv/nagios/run")
|
(add "nagios.init" "/etc/sv/nagios/run")
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
(docker-version "0.6.1")
|
(docker-version "0.6.1")
|
||||||
(from "ubuntu:14.04")
|
(from "ubuntu:14.04")
|
||||||
(maintainer "Tianon Gravi <admwiggin@gmail.com> (@tianon)")
|
(maintainer "Tianon Gravi <admwiggin@gmail.com> (@tianon)")
|
||||||
(run "apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -yq apt-utils aufs-tools automake btrfs-tools build-essential curl dpkg-sig git iptables libapparmor-dev libcap-dev libsqlite3-dev lxc=1.0* mercurial pandoc parallel reprepro ruby1.9.1 ruby1.9.1-dev s3cmd=1.1.0* --no-install-recommends")
|
(run "apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -yq apt-utils aufs-tools automake btrfs-tools build-essential curl dpkg-sig git iptables libapparmor-dev libcap-dev libsqlite3-dev lxc=1.0* mercurial pandoc parallel reprepro ruby1.9.1 ruby1.9.1-dev s3cmd=1.1.0* --no-install-recommends")
|
||||||
(run "git clone --no-checkout https://git.fedorahosted.org/git/lvm2.git /usr/local/lvm2 && cd /usr/local/lvm2 && git checkout -q v2_02_103")
|
(run "git clone --no-checkout https://git.fedorahosted.org/git/lvm2.git /usr/local/lvm2 && cd /usr/local/lvm2 && git checkout -q v2_02_103")
|
||||||
(run "cd /usr/local/lvm2 && ./configure --enable-static_link && make device-mapper && make install_device-mapper")
|
(run "cd /usr/local/lvm2 && ./configure --enable-static_link && make device-mapper && make install_device-mapper")
|
||||||
(run "curl -sSL https://golang.org/dl/go1.3.src.tar.gz | tar -v -C /usr/local -xz")
|
(run "curl -sSL https://golang.org/dl/go1.3.src.tar.gz | tar -v -C /usr/local -xz")
|
||||||
(env "PATH" "/usr/local/go/bin:$PATH")
|
(env "PATH" "/usr/local/go/bin:$PATH")
|
||||||
(env "GOPATH" "/go:/go/src/github.com/docker/docker/vendor")
|
(env "GOPATH" "/go:/go/src/github.com/docker/docker/vendor")
|
||||||
(run "cd /usr/local/go/src && ./make.bash --no-clean 2>&1")
|
(run "cd /usr/local/go/src && ./make.bash --no-clean 2>&1")
|
||||||
(env "DOCKER_CROSSPLATFORMS" "linux/386 linux/arm darwin/amd64 darwin/386 freebsd/amd64 freebsd/386 freebsd/arm")
|
(env "DOCKER_CROSSPLATFORMS" "linux/386 linux/arm darwin/amd64 darwin/386 freebsd/amd64 freebsd/386 freebsd/arm")
|
||||||
(env "GOARM" "5")
|
(env "GOARM" "5")
|
||||||
(run "cd /usr/local/go/src && bash -xc 'for platform in $DOCKER_CROSSPLATFORMS; do GOOS=${platform%/*} GOARCH=${platform##*/} ./make.bash --no-clean 2>&1; done'")
|
(run "cd /usr/local/go/src && bash -xc 'for platform in $DOCKER_CROSSPLATFORMS; do GOOS=${platform%/*} GOARCH=${platform##*/} ./make.bash --no-clean 2>&1; done'")
|
||||||
(run "go get code.google.com/p/go.tools/cmd/cover")
|
(run "go get code.google.com/p/go.tools/cmd/cover")
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
(from "ubuntu:14.04")
|
(from "ubuntu:14.04")
|
||||||
(maintainer "Erik \\\\Hollensbe <erik@hollensbe.org>\\\"")
|
(maintainer "Erik \\\\Hollensbe <erik@hollensbe.org>\\\"")
|
||||||
(run "apt-get \\update && apt-get \\\"install znc -y")
|
(run "apt-get \\update && apt-get \\\"install znc -y")
|
||||||
(add "\\conf\\\\\"" "/.znc")
|
(add "\\conf\\\\\"" "/.znc")
|
||||||
(cmd "/usr\\\"/bin/znc" "-f" "-r")
|
(cmd "/usr\\\"/bin/znc" "-f" "-r")
|
||||||
|
|
|
@ -7,8 +7,8 @@
|
||||||
(run "echo" "'1234'")
|
(run "echo" "'1234'")
|
||||||
(run "echo \"1234\"")
|
(run "echo \"1234\"")
|
||||||
(run "echo 1234")
|
(run "echo 1234")
|
||||||
(run "echo '1234' && echo \"456\" && echo 789")
|
(run "echo '1234' && echo \"456\" && echo 789")
|
||||||
(run "sh -c 'echo root:testpass > /tmp/passwd'")
|
(run "sh -c 'echo root:testpass > /tmp/passwd'")
|
||||||
(run "mkdir -p /test /test2 /test3/test")
|
(run "mkdir -p /test /test2 /test3/test")
|
||||||
(env "SCUBA" "1 DUBA 3")
|
(env "SCUBA" "1 DUBA 3")
|
||||||
(env "SCUBA" "\"1 DUBA 3\"")
|
(env "SCUBA" "\"1 DUBA 3\"")
|
||||||
|
|
Загрузка…
Ссылка в новой задаче