a19f3b1691
* I do not use 1.9.3 * Also keeping them in each file increases mental overhead (true it *can* be autoamted) * None of the files encodes NON ASCII chars. * I do not expect it makes any difference, since nobody programmatically will consume strings generated by mutant under the assumption they are UTF-8 encoded. * 1.9.3 Users have to deal with the encoding fuckup under ruby anyways.
60 lines
1.1 KiB
Ruby
60 lines
1.1 KiB
Ruby
module Mutant
|
|
# Abstract matcher to find subjects to mutate
|
|
class Matcher
|
|
include Adamantium::Flat, Enumerable, AbstractType
|
|
|
|
# Enumerate subjects
|
|
#
|
|
# @param [Object] input
|
|
#
|
|
# @return [self]
|
|
# if block given
|
|
#
|
|
# @return [Enumerable<Subject>]
|
|
# otherwise
|
|
#
|
|
# @api private
|
|
#
|
|
def self.each(cache, input, &block)
|
|
return to_enum(__method__, cache, input) unless block_given?
|
|
|
|
build(cache, input).each(&block)
|
|
|
|
self
|
|
end
|
|
|
|
# Default matcher build implementation
|
|
#
|
|
# @param [Cache] cache
|
|
# @param [Object] input
|
|
#
|
|
# @return [undefined]
|
|
#
|
|
# @api private
|
|
#
|
|
def self.build(*arguments)
|
|
new(*arguments)
|
|
end
|
|
|
|
# Enumerate subjects
|
|
#
|
|
# @api private
|
|
#
|
|
# @return [self]
|
|
# if block given
|
|
#
|
|
# @return [Enumerabe<Subject>]
|
|
# otherwise
|
|
#
|
|
abstract_method :each
|
|
|
|
# Return identification
|
|
#
|
|
# @return [String
|
|
#
|
|
# @api private
|
|
#
|
|
abstract_method :identification
|
|
|
|
end # Matcher
|
|
end # Mutant
|