Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

fobject

Package Overview
Dependencies
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

fobject

A simple promise-based wrapper for file operations that treats files as objects.

  • 0.0.2
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4.2K
decreased by-33.9%
Maintainers
1
Weekly downloads
 
Created
Source

fobject

Build Status

A simple promise-based wrapper for file operations that treats files as objects.

File = require 'fobject'
configFile = new File('config.json')
configFile.read().done((data) ->
	console.log "contents of #{configFile.path}: #{data}"
)

Also, this includes a 2nd wrapper that extends the first and lets you cache the contents of the file directly in the object

File = require 'fobject/cached'
logFile = new File('log')
logFile.load().then( ->
  console.log logFile.content # print out the logs
  logFile.content += 'this is a demo\n' # add a line
).then(
  logFile.save
).done( ->
  console.log('the logs are saved, and since we only added to the string, the
  `File.save()` call was optimized into a single `append()`')
)

why?

The default fs module has a really ugly interface (including sync and async copies of almost every function) and doesn't make it easy to work with files that may or may not actually be written to the file-system. fobject abstracts out interaction with the file system so if you want to implement caching, or work with files without writing them to the disk, or whatever else you want: you can do so easily.

docs

new File(path)
Parameters:
NameTypeArgumentDefaultDescription
path String

The path to the file. This will be resolved to an absolute path, so even if you change your cwd you can still access the same file.

options.base String <optional>
./

Used for relative pathing. This will not be resolved to an absolute path. Typically where a glob starts.

Source:
append(data) → {Promise}

Append data to the file

Parameters:
NameTypeArgumentDefaultDescription
data String | Buffer
options.encoding String | null <optional>
'utf8'

ignored if data is a buffer

options.mode Number <optional>
438

default is 0666 in Octal

options.flag String <optional>
'w'
Source:
Returns:
Type
Promise
dirname() → {String}

Get the dirname of the file

Source:
Returns:
Type
String
extname() → {String}

Get the extension of a file

Source:
Returns:
Type
String
read() → {Promise}

Read from the file

Parameters:
NameTypeArgumentDefaultDescription
options.encoding String | null <optional>
null
options.flag String <optional>
'r'
Source:
Returns:
Type
Promise
rename(newPath) → {Promise}

Rename the file

Parameters:
NameTypeDescription
newPath String

The new path for the file. Will be resolved relative to File.base.

Source:
Returns:
Type
Promise
stat() → {Promise}

Return a Stat object for the file

Source:
Returns:
Type
Promise

Delete the file

Source:
Returns:
Type
Promise
write(data) → {Promise}

Write data to the file

Parameters:
NameTypeArgumentDefaultDescription
data String | Buffer
options.encoding String | null <optional>
'utf8'

ignored if data is a buffer

options.mode Number <optional>
438

default is 0666 in Octal

options.flag String <optional>
'w'
Source:
Returns:
Type
Promise

generated with docme

Keywords

FAQs

Package last updated on 30 Oct 2014

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc