ds-store

0.1.6 • Public • Published

node-ds-store

.DS_Store manipulation and creation from node.js

Status

Currently the implementation uses a pre-created .DS_Store file which it then modifies to suit the needs. This places several limitations and also only allows creating new files from scratch.

Installation

npm install ds-store

Usage

var DSStore = require('ds-store');
 
var file = new DSStore();

API

file.setBackgroundPath(path)

Set the background image to file specified by path.

file.setBackgroundColor(red, green, blue)

Set the background color to the color specified by three floats between 0 and 1.

file.setIconSize(size)

Set the size of all icons in the folder to size.

file.setIconPos(name, x, y)

Position a file icon for file named name at x, y.

file.setWindowPos(x, y)

Set the Finder window position to x, y.

file.setWindowSize(w, h)

Set the Finder window size to w, h.

file.vSrn(value)

Set the vSrn value to either 0 or 1.

Effect currently unknown.

file.write(path, cb)

Write the .DS_Store information to file at path.

cb will get called with err upon file creation.

Future

I have started work on a Buddy Allocator and B-Tree implementation, but there is still lots of work required. Having theese would make it easy to both read and manipulate files. It also wouldn't require shipping a DSStore-clean file.

Thanks

A special thanks to Wim Lewis who have written a complete implementation in perl. His documentation of the file format helped me very much.

http://search.cpan.org/~wiml/Mac-Finder-DSStore/DSStoreFormat.pod

Readme

Keywords

none

Package Sidebar

Install

npm i ds-store

Weekly Downloads

44,378

Version

0.1.6

License

MIT

Last publish

Collaborators

  • cstruct
  • linusu