Sha256: bf339eb02e5c0dd14b0692a39f1ad32946e23e18b0d38d66f72f360fb0ca5749
Contents?: true
Size: 1.1 KB
Versions: 120
Compression:
Stored size: 1.1 KB
Contents
require_relative '../../../puppet/file_system' Puppet::Parser::Functions::newfunction( :file, :arity => -2, :type => :rvalue, :doc => "Loads a file from a module and returns its contents as a string. The argument to this function should be a `<MODULE NAME>/<FILE>` reference, which will load `<FILE>` from a module's `files` directory. (For example, the reference `mysql/mysqltuner.pl` will load the file `<MODULES DIRECTORY>/mysql/files/mysqltuner.pl`.) This function can also accept: * An absolute path, which can load a file from anywhere on disk. * Multiple arguments, which will return the contents of the **first** file found, skipping any files that don't exist. " ) do |vals| path = nil vals.each do |file| found = Puppet::Parser::Files.find_file(file, compiler.environment) if found && Puppet::FileSystem.exist?(found) path = found break end end if path Puppet::FileSystem.read_preserve_line_endings(path) else raise Puppet::ParseError, _("Could not find any files from %{values}") % { values: vals.join(", ") } end end
Version data entries
120 entries across 120 versions & 1 rubygems