Class: Arachni::Support::Buffer::Base
- Includes:
- Mixins::Observable
- Defined in:
- lib/arachni/support/buffer/base.rb
Overview
Base buffer class to be extended by more specialised implementation.
Direct Known Subclasses
Instance Attribute Summary collapse
-
#max_size ⇒ Integer
readonly
Maximum buffer size.
Instance Method Summary collapse
- #<<(obj) ⇒ Object (also: #push)
- #batch_push(list) ⇒ Object
-
#empty? ⇒ Bool
`true` if the buffer is empty, `false` otherwise.
-
#flush ⇒ Object
Current buffer.
-
#full? ⇒ Bool
`true` if the buffer is full, `false` otherwise.
-
#initialize(max_size = nil, type = Array) ⇒ Base
constructor
A new instance of Base.
- #on_batch_push(&block) ⇒ Object
- #on_flush(&block) ⇒ Object
- #on_push(&block) ⇒ Object
-
#size ⇒ Integer
Number of object in the buffer.
Methods included from Mixins::Observable
Methods included from Utilities
#available_port, available_port_mutex, #bytes_to_kilobytes, #bytes_to_megabytes, #caller_name, #caller_path, #cookie_decode, #cookie_encode, #cookies_from_file, #cookies_from_parser, #cookies_from_response, #exception_jail, #exclude_path?, #follow_protocol?, #form_decode, #form_encode, #forms_from_parser, #forms_from_response, #full_and_absolute_url?, #generate_token, #get_path, #hms_to_seconds, #html_decode, #html_encode, #include_path?, #links_from_parser, #links_from_response, #normalize_url, #page_from_response, #page_from_url, #parse_set_cookie, #path_in_domain?, #path_too_deep?, #port_available?, #rand_port, #random_seed, #redundant_path?, #regexp_array_match, #remove_constants, #request_parse_body, #seconds_to_hms, #skip_page?, #skip_path?, #skip_resource?, #skip_response?, #to_absolute, #uri_decode, #uri_encode, #uri_parse, #uri_parse_query, #uri_parser, #uri_rewrite
Methods included from UI::Output
#debug?, #debug_level_1?, #debug_level_2?, #debug_level_3?, #debug_level_4?, #debug_off, #debug_on, #disable_only_positives, #included, #mute, #muted?, #only_positives, #only_positives?, #print_bad, #print_debug, #print_debug_backtrace, #print_debug_level_1, #print_debug_level_2, #print_debug_level_3, #print_debug_level_4, #print_error, #print_error_backtrace, #print_exception, #print_info, #print_line, #print_ok, #print_status, #print_verbose, #reroute_to_file, #reroute_to_file?, reset_output_options, #unmute, #verbose?, #verbose_on
Constructor Details
Instance Attribute Details
#max_size ⇒ Integer (readonly)
Returns Maximum buffer size.
33 34 35 |
# File 'lib/arachni/support/buffer/base.rb', line 33 def max_size @max_size end |
Instance Method Details
#<<(obj) ⇒ Object Also known as: push
Calls #on_push blocks with the given object and pushes an object to the buffer.
50 51 52 53 54 |
# File 'lib/arachni/support/buffer/base.rb', line 50 def <<( obj ) notify_on_push obj @buffer << obj self end |
#batch_push(list) ⇒ Object
Calls #on_batch_push blocks with the given list and merges the buffer with the contents of a list.
62 63 64 65 66 |
# File 'lib/arachni/support/buffer/base.rb', line 62 def batch_push( list ) notify_on_batch_push list @buffer |= list self end |
#empty? ⇒ Bool
Returns `true` if the buffer is empty, `false` otherwise.
76 77 78 |
# File 'lib/arachni/support/buffer/base.rb', line 76 def empty? @buffer.empty? end |
#flush ⇒ Object
Calls #on_flush blocks with the buffer and then empties it.
Returns current buffer.
89 90 91 92 93 94 95 |
# File 'lib/arachni/support/buffer/base.rb', line 89 def flush buffer = @buffer.dup notify_on_flush buffer buffer ensure @buffer.clear end |
#full? ⇒ Bool
Returns `true` if the buffer is full, `false` otherwise.
82 83 84 |
# File 'lib/arachni/support/buffer/base.rb', line 82 def full? !!(max_size && size >= max_size) end |
#on_batch_push(&block) ⇒ Object
26 |
# File 'lib/arachni/support/buffer/base.rb', line 26 advertise :on_batch_push |
#on_flush(&block) ⇒ Object
30 |
# File 'lib/arachni/support/buffer/base.rb', line 30 advertise :on_flush |
#on_push(&block) ⇒ Object
22 |
# File 'lib/arachni/support/buffer/base.rb', line 22 advertise :on_push |
#size ⇒ Integer
Returns Number of object in the buffer.
70 71 72 |
# File 'lib/arachni/support/buffer/base.rb', line 70 def size @buffer.size end |