%a{annotate:rdoc:skip} module YAML # # YAML + DBM = YDBM # # YAML::DBM provides the same interface as ::DBM. # # However, while DBM only allows strings for both keys and values, this library # allows one to use most Ruby objects for values by first converting them to # YAML. Keys must be strings. # # Conversion to and from YAML is performed automatically. # # See the documentation for ::DBM and ::YAML for more information. # class DBM < ::DBM VERSION: ::String # # Return value associated with `key` from database. # # Returns `nil` if there is no such `key`. # # See #fetch for more information. # def []: (String key) -> untyped # # Set `key` to `value` in database. # # `value` will be converted to YAML before storage. # # See #store for more information. # def []=: (String key, untyped val) -> untyped # # Return value associated with `key`. # # If there is no value for `key` and no block is given, returns `ifnone`. # # Otherwise, calls block passing in the given `key`. # # See ::DBM#fetch for more information. # def fetch: (String keystr, ?untyped? ifnone) { (untyped) -> untyped } -> untyped # # Deprecated, used YAML::DBM#key instead. # --- # Note: YAML::DBM#index makes warning from internal of ::DBM#index. It says # 'DBM#index is deprecated; use DBM#key', but DBM#key behaves not same as # DBM#index. # def index: (String keystr) -> untyped # # Returns the key for the specified value. # def key: (String keystr) -> String # # Returns an array containing the values associated with the given keys. # def values_at: (*untyped keys) -> Array[untyped] # # Deletes value from database associated with `key`. # # Returns value or `nil`. # def delete: (String key) -> untyped # # Calls the given block once for each `key`, `value` pair in the database. # Deletes all entries for which the block returns true. # # Returns `self`. # def delete_if: () { (untyped, untyped) -> untyped } -> untyped # # Converts the contents of the database to an in-memory Hash, then calls # Hash#reject with the specified code block, returning a new Hash. # def reject: () { (untyped, untyped) -> untyped } -> Hash[untyped, untyped] # # Calls the given block once for each `key`, `value` pair in the database. # # Returns `self`. # def each_pair: () { (untyped, untyped) -> untyped } -> untyped # # Calls the given block for each value in database. # # Returns `self`. # def each_value: () { (untyped) -> untyped } -> untyped # # Returns an array of values from the database. # def values: () -> untyped # # Returns true if specified `value` is found in the database. # def has_value?: (untyped val) -> (::TrueClass | ::FalseClass) # # Returns a Hash (not a DBM database) created by using each value in the # database as a key, with the corresponding key as its value. # # Note that all values in the hash will be Strings, but the keys will be actual # objects. # def invert: () -> Hash[untyped, untyped] # # Replaces the contents of the database with the contents of the specified # object. Takes any object which implements the each_pair method, including Hash # and DBM objects. # def replace: (Hash[untyped, untyped] | DBM hsh) -> YAML::DBM # # Removes a [key, value] pair from the database, and returns it. If the database # is empty, returns `nil`. # # The order in which values are removed/returned is not guaranteed. # def shift: () -> (Array[untyped] | untyped) # # If a block is provided, returns a new array containing [key, value] pairs for # which the block returns true. # # Otherwise, same as #values_at # def select: (*untyped keys) { (untyped, untyped) -> untyped } -> Array[untyped] # # Stores `value` in database with `key` as the index. `value` is converted to # YAML before being stored. # # Returns `value` # def store: (String key, untyped val) -> untyped # # Updates the database with multiple values from the specified object. Takes any # object which implements the each_pair method, including Hash and DBM objects. # # Returns `self`. # def update: (Hash[untyped, untyped]) -> YAML::DBM # # Converts the contents of the database to an array of [key, value] arrays, and # returns it. # def to_a: () -> Array[untyped] # # Converts the contents of the database to an in-memory Hash object, and returns # it. # def to_hash: () -> Hash[untyped, untyped] end end