Class: Listen::Adapters::Windows
- Inherits:
-
Listen::Adapter
- Object
- Listen::Adapter
- Listen::Adapters::Windows
- Extended by:
- DependencyManager
- Defined in:
- lib/listen/adapters/windows.rb
Overview
Adapter implementation for Windows ‘wdm`.
Constant Summary
Constants included from DependencyManager
DependencyManager::BUNDLER_DECLARE_GEM, DependencyManager::GEM_INSTALL_COMMAND, DependencyManager::GEM_LOAD_MESSAGE
Constants inherited from Listen::Adapter
Listen::Adapter::DEFAULT_LATENCY, Listen::Adapter::MISSING_DEPENDENCY_MESSAGE, Listen::Adapter::POLLING_FALLBACK_MESSAGE
Instance Attribute Summary
Attributes inherited from Listen::Adapter
#directories, #latency, #paused
Class Method Summary collapse
-
.usable? ⇒ Boolean
Checks if the adapter is usable on the current OS.
Instance Method Summary collapse
-
#initialize(directories, options = {}, &callback) ⇒ Windows
constructor
Initializes the Adapter.
-
#start(blocking = true) ⇒ Object
Starts the adapter.
-
#stop ⇒ Object
Stops the adapter.
Methods included from DependencyManager
add_loaded, already_loaded?, clear_loaded, dependencies_loaded?, dependency, extended, load_depenencies
Methods inherited from Listen::Adapter
#report_changes, select_and_initialize, #started?, usable_and_works?, #wait_for_callback, #wait_for_changes, works?
Constructor Details
#initialize(directories, options = {}, &callback) ⇒ Windows
Initializes the Adapter. See Listen::Adapter#initialize for more info.
16 17 18 19 |
# File 'lib/listen/adapters/windows.rb', line 16 def initialize(directories, = {}, &callback) super @worker = init_worker end |
Class Method Details
.usable? ⇒ Boolean
Checks if the adapter is usable on the current OS.
59 60 61 62 |
# File 'lib/listen/adapters/windows.rb', line 59 def self.usable? return false unless RbConfig::CONFIG['target_os'] =~ /mswin|mingw/i super end |
Instance Method Details
#start(blocking = true) ⇒ Object
Starts the adapter.
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
# File 'lib/listen/adapters/windows.rb', line 25 def start(blocking = true) @mutex.synchronize do return if @stop == false super end @worker_thread = Thread.new { @worker.run! } # Wait for the worker to start. This is needed to avoid a deadlock # when stopping immediately after starting. sleep 0.1 @poll_thread = Thread.new { poll_changed_dirs } if @report_changes @worker_thread.join if blocking end |
#stop ⇒ Object
Stops the adapter.
44 45 46 47 48 49 50 51 52 53 |
# File 'lib/listen/adapters/windows.rb', line 44 def stop @mutex.synchronize do return if @stop == true super end @worker.stop @worker_thread.join if @worker_thread @poll_thread.join if @poll_thread end |