Base class for file collectors. More...
#include <text_file_backend.hpp>
Public Member Functions | |
virtual | ~collector () |
Default constructor. More... | |
virtual void | store_file (filesystem::path const &src_path)=0 |
The function stores the specified file in the storage. More... | |
virtual uintmax_t | scan_for_files (scan_method method, filesystem::path const &pattern=filesystem::path(), unsigned int *counter=0)=0 |
Scans the target directory for the files that have already been stored. More... | |
Base class for file collectors.
All file collectors, supported by file sink backends, should inherit this class.
|
inlinevirtual |
Default constructor.
Virtual destructor
|
pure virtual |
Scans the target directory for the files that have already been stored.
The found files are added to the collector in order to be tracked and erased, if needed.
The function may scan the directory in two ways: it will either consider every file in the directory a log file, or will only consider files with names that match the specified pattern. The pattern may contain the following placeholders:
All other placeholders are not supported.
method | The method of scanning. If no_scan is specified, the call has no effect. |
pattern | The file name pattern if method is scan_matching . Otherwise the parameter is not used. |
counter | If not NULL and method is scan_matching , the method suggests initial value of a file counter that may be used in the file name pattern. The parameter is not used otherwise. |
scan_matching
the effect of this function is highly dependent on the pattern definition. It is recommended to choose patterns with easily distinguished placeholders (i.e. having delimiters between them). Otherwise either some files can be mistakenly found or not found, which in turn may lead to an incorrect file deletion.
|
pure virtual |
The function stores the specified file in the storage.
May lead to an older file deletion and a long file moving.
src_path | The name of the file to be stored |