Skip to content

Latest commit

 

History

History
129 lines (105 loc) · 4.54 KB

README.md

File metadata and controls

129 lines (105 loc) · 4.54 KB

fs-watcher

This module is a utility to allow you to easily monitor any given directory for changes such as file creation, file modification, file deletion and allow you to run code when any of those events happen.

Installation

Get this module from lit with the following install command

lit install TohruMKDM/fs-watcher

Usage

Using this module is extremely easy, below is a detailed example of use.

-- First we require the module
local fs_watcher = require('fs-watcher')

-- Create a new watcher for the current directory
fs_watcher.watch(
    './', -- Current directory
    false, -- Do not recursively monitor directories
    function(event, filepath, newpath) -- Assign callback function
        if event == 'update' then
            print(filepath..' was updated')
        elseif event == 'create' then
            print(filepath..' was created')
        elseif event == 'delete' then
            print(filepath..' was deleted')
        elseif event == 'rename' then
            print(filepath..' was renamed to '..newpath)
        end
        if event == 'error' then
            -- An error occured, 
            -- should be rare but just to be safe 
            -- it's probably best to stop monitoring past this point
            print('An error occured! '..filepath)
            fs_watcher.stop('./')
        end
    end
)

-- Wait for example
-- Waits for a file to be created with the name 'file.txt' in the current directory for 1 second
local success, _, filepath = fs_watcher.waitForChange('./', false, 1000, function(event, filepath)
    if event == 'create' and filepath = 'file.txt' then
        return true
    end
    return false
end)
if success then
    print('file.txt was created within a second!')
else
    print('file.txt was not created within a second.')
end

Functions

A detailed explanation on what each function this module provides does.

fs_watcher.watch(directory, recursive, callback)

Parameter Type Optional
directory string
recursive boolean
callback function

Creates a new watcher to monitor the given directory for changes and returns the assigned callback for convenience
The callback's parameters are defined below

Returns: function, uv_fs_event_t

callback(event, filepath, newpath)

Parameter Type
event string
filepath string
newpath string?

filepath will be the filepath of the relevant file relative to the directory the watcher is monitoring
newpath will the new filepath in the event of a rename and filepath would be the old name
If the callback returns a truthy value then it will automatically cancel the watcher for the directory the callback is assigned to.
List of all possible events are defined below

create

Fired when a file is created

update

Fired when a file is modified

delete

Fired when a file is deleted

rename

Fired when a file is renamed

error

Fired when an error occurs

fs_watcher.stop(callback)

Parameter Type
callback function

Stops triggering a callback

Returns: boolean, string?

fs_watcher.stopAll(directory)

Parameter Type Optional
directory string

Stops all active watchers for a given directory

Returns: boolean, string?

fs_watcher.waitForChange(directory, recursive, timeout, predicate)

Parameter Type Optional
directory string
recursive boolean
timeout number
predicate function

Waits for a singular change in a given directory with a optional timeout and predicate
The predicate is called with the same arguments as the callback from fs_watcher.watch

Returns: boolean, string?, string?, string?

Note

Every active watcher is a handle that will keep your event loop alive and as such your program will not exit until all of them are stopped or closed. Make sure you call fs_watcher.stop on all directories a watcher is monitoring after you're done with them.