Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
# Copyright 2017 Pants project contributors (see CONTRIBUTORS.md).
# Licensed under the Apache License, Version 2.0 (see LICENSE).

from pants.base.payload import Payload
from pants.build_graph.target import Target


class Files(Target):
    """A collection of loose files."""

    @classmethod
    def alias(cls):
        return "files"

    def __init__(self, address=None, payload=None, sources=None, **kwargs):
        """
        :API: public

        :param sources: Files to "include". Paths are relative to the BUILD file's directory.
        :type sources: :class:`pants.source.wrapped_globs.FilesetWithSpec` or list of strings
        """
        payload = payload or Payload()
        payload.add_fields(
            {
                "sources": self.create_sources_field(
                    sources, sources_rel_path=address.spec_path, key_arg="sources"
                ),
            }
        )
        super().__init__(address=address, payload=payload, **kwargs)

    def has_sources(self, extension=None):
        """`Files` targets never logically "own" sources of any particular type (extension).

        `JavaLibrary` targets, in contrast, logically "own" `.java` files and so target consumers
        (tasks) may collect targets to operate on by checking `has_sources('.java')` instead of
        performing a target type test.

        A `Files` target may have `.java` sources - for example, a java compiler test might use
        loose `.java` source files in the test tree as compiler inputs - but it does not logically
        "own" `.java` sources like `JavaLibrary` and so any query of `has_sources` with an `extension`
        will return `False` to prevent standard compilation by a `javac` task in this example.

        :API: public

        :param string extension: Suffix of filenames to test for.
        :return: `True` if this target owns at least one source file and `extension` is `None`.
        :rtype: bool
        """
        return extension is None and super().has_sources()