Sha256: 1b836e9fef9c1250a422ee2fd0e5c376cd0fb6d2b827c4876e14ff273fa2d934

Contents?: true

Size: 1.88 KB

Versions: 33

Compression:

Stored size: 1.88 KB

Contents

# This class provides a simple API for managing a lock file
# whose contents are an (optional) String.  In addition
# to querying the basic state (#locked?) of the lock, managing
# the lock (#lock, #unlock), the contents can be retrieved at
# any time while the lock is held (#lock_data).  This can be
# used to store pids, messages, etc.
#
# @see Puppet::Util::JsonLockfile
class Puppet::Util::Lockfile
  attr_reader :file_path

  def initialize(file_path)
    @file_path = file_path
  end

  # Lock the lockfile.  You may optionally pass a data object, which will be
  # retrievable for the duration of time during which the file is locked.
  #
  # @param [String] lock_data an optional String data object to associate
  #   with the lock.  This may be used to store pids, descriptive messages,
  #   etc.  The data may be retrieved at any time while the lock is held by
  #   calling the #lock_data method.

  # @return [boolean] true if lock is successfully acquired, false otherwise.
  def lock(lock_data = nil)
    return false if locked?

    File.open(@file_path, 'w') { |fd| fd.print(lock_data) }
    true
  end

  def unlock
    if locked?
      File.unlink(@file_path)
      true
    else
      false
    end
  end

  def locked?
    # delegate logic to a more explicit private method
    file_locked?
  end

  # Retrieve the (optional) lock data that was specified at the time the file
  #  was locked.
  # @return [String] the data object.
  def lock_data
    return File.read(@file_path) if file_locked?
  end

  # Private, internal utility method for encapsulating the logic about
  #  whether or not the file is locked.  This method can be called
  #  by other methods in this class without as much risk of accidentally
  #  being overridden by child classes.
  # @return [boolean] true if the file is locked, false if it is not.
  def file_locked?()
    File.exists? @file_path
  end
  private :file_locked?
end

Version data entries

33 entries across 33 versions & 2 rubygems

Version Path
puppet-3.3.2 lib/puppet/util/lockfile.rb
puppet-3.3.1 lib/puppet/util/lockfile.rb
puppet-3.3.1.rc3 lib/puppet/util/lockfile.rb
puppet-3.3.1.rc2 lib/puppet/util/lockfile.rb
puppet-3.3.1.rc1 lib/puppet/util/lockfile.rb
puppet-3.3.0 lib/puppet/util/lockfile.rb
puppet-3.3.0.rc3 lib/puppet/util/lockfile.rb
puppet-3.3.0.rc2 lib/puppet/util/lockfile.rb
puppet-3.2.4 lib/puppet/util/lockfile.rb
puppet-3.2.3 lib/puppet/util/lockfile.rb
puppet-3.2.3.rc1 lib/puppet/util/lockfile.rb
puppet-3.2.2 lib/puppet/util/lockfile.rb
puppet-3.2.1 lib/puppet/util/lockfile.rb
puppet-3.2.1.rc1 lib/puppet/util/lockfile.rb
puppet-3.2.0.rc2 lib/puppet/util/lockfile.rb
librarian-puppet-0.9.9 vendor/gems/ruby/1.9.1/gems/puppet-3.1.0/lib/puppet/util/lockfile.rb
puppet-3.2.0.rc1 lib/puppet/util/lockfile.rb
puppet-3.1.1 lib/puppet/util/lockfile.rb
librarian-puppet-0.9.8 vendor/gems/ruby/1.9.1/gems/puppet-3.1.0/lib/puppet/util/lockfile.rb
puppet-3.1.0 lib/puppet/util/lockfile.rb