File: file.rb

package info (click to toggle)
puppet-agent 8.10.0-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 27,404 kB
  • sloc: ruby: 286,820; sh: 492; xml: 116; makefile: 88; cs: 68
file content (35 lines) | stat: -rw-r--r-- 1,137 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# frozen_string_literal: true

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