Skip to content

Commit

Permalink
Rewrite //:combine_distfiles.sh in Python
Browse files Browse the repository at this point in the history
It can only pack to zip for now (packing to tar is
not trivial and I haven't figured it out yet).

This allows building //:bazel-distfile on Windows.
Previously it was either timing out or taking so
long that it was unbearable (over 10 minutes).
I never waited long enough to see it build.

The new Python version runs under just a few
seconds.

Change-Id: I3264eb7132dd58c581c4216e5bbab035a79d716d
PiperOrigin-RevId: 164954162
  • Loading branch information
laszlocsomor authored and hlopko committed Aug 11, 2017
1 parent 5f99fda commit 0783b9e
Show file tree
Hide file tree
Showing 4 changed files with 64 additions and 11 deletions.
15 changes: 11 additions & 4 deletions BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -68,15 +68,22 @@ pkg_tar(
visibility = ["//:__subpackages__"],
)

py_binary(
name = "combine_distfiles",
srcs = ["combine_distfiles.py"],
visibility = ["//visibility:private"],
deps = ["//src:create_embedded_tools_lib"],
)

genrule(
name = "bazel-distfile",
srcs = [
":bazel-srcs",
"//src:derived_java_srcs",
],
outs = ["bazel-distfile.zip"],
cmd = "$(location :combine_distfiles.sh) $@ $(SRCS)",
tools = ["combine_distfiles.sh"],
cmd = "$(location :combine_distfiles) $@ $(SRCS)",
tools = [":combine_distfiles"],
# Public but bazel-only visibility.
visibility = ["//:__subpackages__"],
)
Expand All @@ -88,8 +95,8 @@ genrule(
"//src:derived_java_srcs",
],
outs = ["bazel-distfile.tar"],
cmd = "env USE_TAR=YES $(location :combine_distfiles.sh) $@ $(SRCS)",
tools = ["combine_distfiles.sh"],
cmd = "$(location :combine_distfiles_to_tar.sh) $@ $(SRCS)",
tools = ["combine_distfiles_to_tar.sh"],
# Public but bazel-only visibility.
visibility = ["//:__subpackages__"],
)
Expand Down
50 changes: 50 additions & 0 deletions combine_distfiles.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
# pylint: disable=g-bad-file-header
# pylint: disable=g-direct-third-party-import
#
# Copyright 2017 The Bazel Authors. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http:#www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Creates the Bazel source distribution archive."""

import contextlib
import os.path
import sys
import zipfile

from src.create_embedded_tools_lib import copy_tar_to_zip
from src.create_embedded_tools_lib import copy_zip_to_zip


def main():
output_zip = os.path.join(os.getcwd(), sys.argv[1])
input_files = sorted(sys.argv[2:])

# Copy all the input_files into output_zip.
# Adding contextlib.closing to be python 2.6 (for centos 6.7) compatible
with contextlib.closing(
zipfile.ZipFile(output_zip, "w", zipfile.ZIP_DEFLATED)) as output_zip:

def _normalize(path):
return path[2:] if path.startswith("./") else path

for input_file in input_files:
if input_file.endswith(".tar"):
copy_tar_to_zip(output_zip, input_file, _normalize)
elif input_file.endswith(".zip"):
copy_zip_to_zip(output_zip, input_file, _normalize)
else:
raise Exception("unknown archive type \"%s\"" % input_file)


if __name__ == "__main__":
main()
9 changes: 2 additions & 7 deletions combine_distfiles.sh → combine_distfiles_to_tar.sh
Original file line number Diff line number Diff line change
Expand Up @@ -40,10 +40,5 @@ do
(cd "${PACKAGE_DIR}" && ${UNPACK} "${ARCHIVE}")
done

if [ -n "${USE_TAR:-}" ]
then
(cd "${PACKAGE_DIR}" && tar -c -f "${OUTPUT}" --group=0 --owner=0 \
$(find . -type f | sort))
else
(cd "${PACKAGE_DIR}" && find . -type f | sort | zip -qDX@ "${OUTPUT}")
fi
(cd "${PACKAGE_DIR}" && tar -c -f "${OUTPUT}" --group=0 --owner=0 \
$(find . -type f | sort))
1 change: 1 addition & 0 deletions src/BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ filegroup(
py_library(
name = "create_embedded_tools_lib",
srcs = ["create_embedded_tools_lib.py"],
visibility = ["//:__pkg__"],
)

py_binary(
Expand Down

0 comments on commit 0783b9e

Please sign in to comment.