UNPKG

leveldb

Version:

Bindings for using LevelDB through node.

422 lines (283 loc) 11.6 kB
binding = require '../../build/Release/leveldb.node' {Batch} = require './batch' {Iterator} = require './iterator' noop = -> ### Open a leveldb database. @param {String} path The path to the database file. @param {Object} [options] Optional options corresponding to the leveldb options. See also the `leveldb/options.h` header file. @param {Boolean} [options.create_if_missing=false] If true, the database will be created if it is missing. @param {Boolean} [options.error_if_exists=false] If true, an error is raised if the database already exists. @param {Boolean} [options.paranoid_checks=false] If true, the implementation will do aggressive checking of the data it is processing and will stop early if it detects any errors. This may have unforeseen ramifications: for example, a corruption of one DB entry may cause a large number of entries to become unreadable or for the entire DB to become unopenable. @param {Integer} [options.write_buffer_size=4*1024*1024] Amount of data to build up in memory (backed by an unsorted log on disk) before converting to a sorted on-disk file, in bytes. @param {Integer} [options.max_open_files=1000] Maximum number of open files that can be used by the database. You may need to increase this if your database has a large working set (budget one open file per 2MB of working set). @param {Integer} [options.block_size=4096] Approximate size of user data packed per block, in bytes. Note that the block size specified here corresponds to uncompressed data. The actual size of the unit read from disk may be smaller if compression is enabled. This parameter can be changed dynamically. @param {Integer} [options.block_restart_interval=16] Number of keys between restart points for delta encoding of keys. This parameter can be changed dynamically. Most clients should leave this parameter alone. @param {Boolean} [options.compression=true] Set to false to disable Snappy compression. @param {Function} [callback] Optional callback. If not given, returns the database handle synchronously. @param {Error} error The error value on error, null otherwise. @param {leveldb.Handle} handle If successful, the database handle. ### exports.open = (path, options, callback) -> # optional options if typeof options is 'function' callback = options options = null throw new Error 'Missing callback' unless callback binding.open path, options, (err, self) -> handle = self and new Handle self callback err, handle ### Destroy a leveldb database. @param {String} path The path to the database file. @param {Object} [options] Optional options. See `leveldb.open()`. @param {Function} [callback] Optional callback. @param {Error} error The error value on error, null otherwise. ### exports.destroy = (path, options, callback) -> # optional options if typeof options is 'function' callback = options options = null # call native binding binding.destroy path, options, callback or noop ### Repair a leveldb database. @param {String} path The path to the database file. @param {Object} [options] Optional options. See `leveldb.open()`. @param {Function} [callback] Optional callback. @param {Error} error The error value on error, null otherwise. ### exports.repair = (path, options, callback) -> # optional options if typeof options is 'function' callback = options options = null # call native binding binding.repair path, options, callback or noop ### A handle represents an open leveldb database. ### class Handle ### Constructor. @param {Native} self The native handle binding. ### constructor: (@self) -> ### Get a value from the database. @param {String|Buffer} key The key to get. @param {Object} [options] Optional options. See also the `leveldb/options.h` header file. @param {Boolean} [options.verify_checksums=false] If true, all data read from underlying storage will be verified against corresponding checksums. @param {Boolean} [options.fill_cache=true] If true, data read from disk will be cached in memory. @param {Boolean} [options.as_buffer=false] If true, data will be returned as a `Buffer`. @param {Function} callback The callback function. @param {Error} error The error value on error, null otherwise. @param {String|Buffer} value If successful, the value. ### get: (key, options, callback) -> # optional options if typeof options is 'function' callback = options options = null throw new Error 'Missing callback' unless callback # to buffer if string key = new Buffer key unless Buffer.isBuffer key @self.get key, options, (err, value) -> # to string unless returning as buffer value = value.toString 'utf8' if value and not options?.as_buffer callback err, value @ ### Apply a callback over a range. See `Iterator.forRange()`. ### forRange: -> args = arguments # required callback callback = args[args.length - 1] throw new Error 'Missing callback' unless callback # optional options options = args[args.length - 2] options = null unless typeof options isnt 'object' or Buffer.isBuffer options @iterator options, (err, it) -> return callback err if err it.forRange.apply it, args ### Put a key-value pair in the database. @param {String|Buffer} key The key to put. @param {String|Buffer} val The value to put. @param {Object} [options] Optional options. See `Handle.write()`. @param {Function} [callback] Optional callback. @param {Error} error The error value on error, null otherwise. ### put: (key, val, options, callback) -> @batch().put(key, val).write options, callback @ ### Delete a key-value pair from the database. @param {String|Buffer} key The key to put. @param {Object} [options] Optional options. See `Handle.write()`. @param {Function} [callback] Optional callback. @param {Error} error The error value on error, null otherwise. ### del: (key, options, callback) -> @batch().del(key).write options, callback @ ### Commit batch operations to disk. @param {leveldb.Batch} batch The batch object. @param {Object} [options] Optional options. See also the `leveldb/options.h` header file. @param {Boolean} [options.sync=false] If true, the write will be flushed from the operating system buffer cache (by calling WritableFile::Sync()) before the write is considered complete. If this flag is true, writes will be slower. @param {Function} [callback] Optional callback. @param {Error} error The error value on error, null otherwise. ### write: (batch, options, callback = noop) -> # optional options if typeof options is 'function' callback = options options = null # read lock ++batch.readLock_ @self.write batch.self, options, (err) -> # read unlock --batch.readLock_ callback err @ ### Create a new batch object supporting `Batch.write()` using this database handle. ### batch: -> new Batch @self ### Create a new iterator. @param {Object} [options] Optional options. See also the `leveldb/options.h` header file. @param {Boolean} [options.verify_checksums=false] If true, all data read from underlying storage will be verified against corresponding checksums. @param {Boolean} [options.fill_cache=true] If true, data read from disk will be cached in memory. @param {Function} callback The callback function. @param {Error} error The error value on error, null otherwise. @param {leveldb.Iterator} iterator The iterator if successful. ### iterator: (options, callback) -> # optional options if typeof options is 'function' callback = options options = null throw new Error 'Missing callback' unless callback @self.iterator options, (err, it) -> wrap = new Iterator it unless err callback err, wrap @ ### Create a new snapshot. @param {Function} callback The callback function. @param {Error} error The error value on error, null otherwise. @param {leveldb.Snapshot} snapshot The snapshot if successful. ### snapshot: (callback) -> throw new Error 'Missing callback' unless callback @self.snapshot (err, snap) => wrap = new Snapshot @, snap unless err callback err, wrap @ ### Get a database property. @param {String} name The database property name. See the `leveldb/db.h` header file for property names. @param {Function} callback The callback function. @param {Error} error The error value on error, null otherwise. @param {String} value The property value if successful. ### property: (name, callback) -> throw new Error 'Missing callback' unless callback @self.property name, callback @ ### Approximate the on-disk storage bytes for key ranges. Usage: db.approximateSize(['foo', 'bar'], ['baz', 'zee'], callback); db.approximateSize([['foo', 'bar'], ['baz', 'zee']], callback); @param {Array} slices An array of start/limit key ranges. @param {String|Buffer} start The start key in the range, inclusive. @param {String|Buffer} limit The limit key in the range, exclusive. @param {Function} callback The callback function. @param {Error} error The error value on error, null otherwise. @param {String} value The property value if successful. ### approximateSizes: -> # variable args args = Array.prototype.slice.call arguments # required callback callback = args.pop() if typeof args[args.length - 1] is 'function' throw new Error 'Missing callback' unless callback # (['foo', 'bar'], ['baz', 'zee']) or ([['foo', 'bar'], ['baz', 'zee']]) args = if Array.isArray args[0][0] then args[0] else args # flatten bounds slices = [] for [ start, limit ] in args # to buffer if string slices.push if Buffer.isBuffer start then start else Buffer start slices.push if Buffer.isBuffer limit then limit else Buffer limit @self.approximateSizes slices, callback @ # TODO: compactRange ### A Snapshot represents the state of the database when the snapshot was created. Get operations return the value of the key when the snapshot was created. ### class Snapshot ### Constructor. @param {leveldb.Handle} self The database handle from which this snapshot was created. @param {Native} snapshot The native snapshot object. ### constructor: (@self, @snapshot) -> ### Get a value from the database snapshot. See `Handle.get()`. ### get: (key, options = {}, callback) -> # optional options if typeof options is 'function' callback = options options = {} # set snapshot option options.snapshot = @snapshot # call handle get @self.get key, options, callback