fmap 0.3.0+2 copy "fmap: ^0.3.0+2" to clipboard
fmap: ^0.3.0+2 copied to clipboard

outdated

Easy-to-use approach to caching or persistent blob storage. Key-value collection stored on the filesystem.

fmap #

Easy-to-use approach to caching or persistent blob storage. Key-value collection stored on the filesystem.

var fmap = Fmap(directory);

fmap['keyA'] = 'my string';         // saved string into a file
fmap['keyB'] = 777;                 // saved int into a file
fmap['keyC'] = [0x12, 0x34, 0x56];  // saved three-bytes into a file

print(fmap['keyA']); // read from file

Fmap implements a Map, so it can be used the same way.

print('Count of items: ${fmap.length}');

for (var entry in fmap.entries) {
    print('Item ${entry.key}: ${entry.value}'); 
}

Creating #

For permanent data storage

var fmap = Fmap(Directory('/path/to/my_precious_data'));

To cache data in the system temporary directory

var fmap = Fmap.temp(); // will be placed into {temp}/fmap dir

To cache data in a specific subdirectory of the system temporary directory

var images = Fmap.temp(subdir: 'images_cache'); // {temp}/images_cache
var jsons  = Fmap.temp(subdir: 'jsons_cache');  // {temp}/jsons_cache

If all the storage items have the same type, you can set the type with generics

var strings1 = Fmap<String>(directory);
var strings2 = Fmap.temp<String>();

Types #

The collection allows you to store only values of certain types. Supported types are String, List<int>, int, double and bool.

var fmap = Fmap(directory);
fmap['string'] = '^_^';
fmap['int'] = 5;
fmap['double'] = 5.0; 
fmap['bool'] = true;

Any List<int> is treated as list of bytes.

fmap['blob1'] = [0x12, 0x34, 0x56];
fmap['blob2'] = utf8.encode('my string'); // List<int>
fmap['blob3'] = myFile.readAsBytesSync(); // Uint8List implements List<int> 

Since numbers are bytes, each int inside a list is truncated to the range 0..255.

fmap['blob4'] = [1, 10, -1, 777]; // saves 1, 10, 255, 9 

Keep in mind that each value is saved in a separate file. Therefore, storing a lot of small values like double may not be very practical. Conversely, saving large objects such as strings or blobs is efficient. It's almost like writing directly to files, but without restrictions on key names.

Purging #

If the storage has become too large, you can delete the oldest data.

// leave only the newest 16 megabytes
fmap.purge(16*1024*1024);

Which elements are removed depends on the policy argument passed to the constructor.

var fmap = Fmap(dir, policy: Policy.fifo);

Two policies are supported: FIFO and LRU. By default, this is FIFO.

If you want the purge method to purge storage with LRU policy, you must not only create Fmap(policy: Policy.lru) before purging but always create the object this way. It will force Fmap to update the last-used timestamps every time an entry is read.

When you do not specify this argument, the timestamps are only updated on writes, but not on reads.

0
likes
0
points
17
downloads

Publisher

verified publisherrevercode.com

Weekly Downloads

Easy-to-use approach to caching or persistent blob storage. Key-value collection stored on the filesystem.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

crypto, file_errors, meta, path

More

Packages that depend on fmap