| # Copyright 2015 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. |
| """mini_tar: A limited functionality tar utility.""" |
| |
| # Filetype to restrict inputs |
| tar_filetype = [".tar", ".tar.gz", ".tgz", ".tar.bz2"] |
| |
| def _quote(filename, protect = "="): |
| """Quote the filename, by escaping = by \\= and \\ by \\\\""" |
| return filename.replace("\\", "\\\\").replace(protect, "\\" + protect) |
| |
| def _mini_tar_impl(ctx): |
| """Implementation of the mini_tar rule.""" |
| |
| to_strip = ctx.label.package + "/" |
| |
| def dest_path(file): |
| # print('FILE', file.path, file.short_path) |
| ret = file.short_path |
| if ret.startswith(to_strip): |
| ret = ret[len(to_strip):] |
| return ret |
| |
| # Start building the arguments. |
| args = ctx.actions.args() |
| args.add("--output", ctx.outputs.out.path) |
| args.add("--mode", ctx.attr.mode) |
| args.add("--owner", ctx.attr.owner) |
| if ctx.attr.package_dir: |
| args.add("--directory", ctx.attr.package_dir) |
| if ctx.attr.mtime != -1: # Note: Must match default in rule def. |
| args.append("--mtime=%d" % ctx.attr.mtime) |
| |
| file_inputs = ctx.files.srcs[:] |
| for f in file_inputs: |
| args.add("--file=%s=%s" % (_quote(f.path), dest_path(f))) |
| args.set_param_file_format("flag_per_line") |
| args.use_param_file("@%s", use_always = False) |
| ctx.actions.run( |
| inputs = file_inputs, |
| executable = ctx.executable._mini_tar, |
| arguments = [args], |
| outputs = [ctx.outputs.out], |
| mnemonic = "PackageTar", |
| use_default_shell_env = True, |
| ) |
| |
| # A rule for creating a tar file, see README.md |
| _real_mini_tar = rule( |
| implementation = _mini_tar_impl, |
| attrs = { |
| "mode": attr.string(default = "0555"), |
| "mtime": attr.int(default = -1), |
| "out": attr.output(), |
| "owner": attr.string(default = "0.0"), |
| "package_dir": attr.string(), |
| "srcs": attr.label_list(allow_files = True), |
| |
| # Implicit dependencies. |
| "_mini_tar": attr.label( |
| default = Label("//tools/mini_tar:mini_tar"), |
| cfg = "exec", |
| executable = True, |
| allow_files = True, |
| ), |
| }, |
| ) |
| |
| def mini_tar(name, out = None, **kwargs): |
| if not out: |
| out = name + ".tar" |
| _real_mini_tar( |
| name = name, |
| out = out, |
| **kwargs |
| ) |