vfile

[![Build][build-badge]][build] [![Coverage][coverage-badge]][coverage] [![Downloads][downloads-badge]][downloads] [![Size][size-badge]][size] [![Sponsors][sponsors-badge]][collective] [![Backers][backers-badge]][collective] [![Chat][chat-badge]][chat] **vfile** is a small and browser friendly virtual file format that tracks metadata (such as a file’s `path` and `contents`) and [messages][]. It was made specifically for **[unified][]** and generally for the common task of parsing, transforming, and serializing data, where `vfile` handles everything about the document being compiled. This is useful for example when building linters, compilers, static site generators, or other build tools. **vfile** is part of the [unified collective][site]. * for updates, see [Twitter][] * for more about us, see [`unifiedjs.com`][site] * for questions, see [Discussions][chat] * to help, see [contribute][] or [sponsor][] below > **vfile** is different from the excellent [`vinyl`][vinyl] in that it has > a smaller API, a smaller size, and focuses on [messages][]. ## Contents * [Install](#install) * [Use](#use) * [API](#api) * [`VFile(options?)`](#vfileoptions) * [`vfile.contents`](#vfilecontents) * [`vfile.cwd`](#vfilecwd) * [`vfile.path`](#vfilepath) * [`vfile.basename`](#vfilebasename) * [`vfile.stem`](#vfilestem) * [`vfile.extname`](#vfileextname) * [`vfile.dirname`](#vfiledirname) * [`vfile.history`](#vfilehistory) * [`vfile.messages`](#vfilemessages) * [`vfile.data`](#vfiledata) * [`VFile#toString(encoding?)`](#vfiletostringencoding) * [`VFile#message(reason[, position][, origin])`](#vfilemessagereason-position-origin) * [`VFile#info(reason[, position][, origin])`](#vfileinforeason-position-origin) * [`VFile#fail(reason[, position][, origin])`](#vfilefailreason-position-origin) * [List of utilities](#list-of-utilities) * [Reporters](#reporters) * [Contribute](#contribute) * [Sponsor](#sponsor) * [Acknowledgments](#acknowledgments) * [License](#license) ## Install [npm][]: ```sh npm install vfile ``` ## Use ```js var vfile = require('vfile') var file = vfile({path: '~/example.txt', contents: 'Alpha *braavo* charlie.'}) file.path // => '~/example.txt' file.dirname // => '~' file.extname = '.md' file.basename // => 'example.md' file.basename = 'index.text' file.history // => ['~/example.txt', '~/example.md', '~/index.text'] file.message('`braavo` is misspelt; did you mean `bravo`?', { line: 1, column: 8 }) console.log(file.messages) ``` Yields: ```js [ { [~/index.text:1:8: `braavo` is misspelt; did you mean `bravo`?] message: '`braavo` is misspelt; did you mean `bravo`?', name: '~/index.text:1:8', file: '~/index.text', reason: '`braavo` is misspelt; did you mean `bravo`?', line: 1, column: 8, location: { start: [Object], end: [Object] }, ruleId: null, source: null, fatal: false } ] ``` ## API ### `VFile(options?)` Create a new virtual file. If `options` is `string` or `Buffer`, treats it as `{contents: options}`. If `options` is a `VFile`, returns it. All other options are set on the newly created `vfile`. Path related properties are set in the following order (least specific to most specific): `history`, `path`, `basename`, `stem`, `extname`, `dirname`. It’s not possible to set either `dirname` or `extname` without setting either `history`, `path`, `basename`, or `stem` as well. ###### Example ```js vfile() vfile('console.log("alpha");') vfile(Buffer.from('exit 1')) vfile({path: path.join(__dirname, 'readme.md')}) vfile({stem: 'readme', extname: '.md', dirname: __dirname}) vfile({other: 'properties', are: 'copied', ov: {e: 'r'}}) ``` ### `vfile.contents` `Buffer`, `string`, `null` — Raw value. ### `vfile.cwd` `string` — Base of `path`. Defaults to `process.cwd()`. ### `vfile.path` `string?` — Path of `vfile`. Cannot be nullified. ### `vfile.basename` `string?` — Current name (including extension) of `vfile`. Cannot contain path separators. Cannot be nullified either (use `file.path = file.dirname` instead). ### `vfile.stem` `string?` — Name (without extension) of `vfile`. Cannot be nullified, and cannot contain path separators. ### `vfile.extname` `string?` — Extension (with dot) of `vfile`. Cannot be set if there’s no `path` yet and cannot contain path separators. ### `vfile.dirname` `string?` — Path to parent directory of `vfile`. Cannot be set if there’s no `path` yet. ### `vfile.history` `Array.` — List of file-paths the file moved between. ### `vfile.messages` [`Array.`][message] — List of messages associated with the file. ### `vfile.data` `Object` — Place to store custom information. It’s OK to store custom data directly on the `vfile`, moving it to `data` gives a *little* more privacy. ### `VFile#toString(encoding?)` Convert contents of `vfile` to string. When `contents` is a [`Buffer`][buffer], `encoding` is a [character encoding][encoding] to understand `doc` as (`string`, default: `'utf8'`). ### `VFile#message(reason[, position][, origin])` Associates a message with the file, where `fatal` is set to `false`. Constructs a new [`VMessage`][vmessage] and adds it to [`vfile.messages`][messages]. ##### Returns [`VMessage`][vmessage]. ### `VFile#info(reason[, position][, origin])` Associates an informational message with the file, where `fatal` is set to `null`. Calls [`#message()`][message] internally. ##### Returns [`VMessage`][vmessage]. ### `VFile#fail(reason[, position][, origin])` Associates a fatal message with the file, then immediately throws it. Note: fatal errors mean a file is no longer processable. Calls [`#message()`][message] internally. ##### Throws [`VMessage`][vmessage]. ## List of utilities The following list of projects includes tools for working with virtual files. See **[unist][]** for projects that work with nodes. * [`convert-vinyl-to-vfile`](https://github.com/dustinspecker/convert-vinyl-to-vfile) — transform from [Vinyl][] to vfile * [`to-vfile`](https://github.com/vfile/to-vfile) — create a vfile from a filepath * [`vfile-find-down`](https://github.com/vfile/vfile-find-down) — find files by searching the file system downwards * [`vfile-find-up`](https://github.com/vfile/vfile-find-up) — find files by searching the file system upwards * [`vfile-glob`](https://github.com/shinnn/vfile-glob) — find files by glob patterns * [`vfile-is`](https://github.com/vfile/vfile-is) — check if a vfile passes a test * [`vfile-location`](https://github.com/vfile/vfile-location) — convert between positional and offset locations * [`vfile-matter`](https://github.com/vfile/vfile-matter) — parse the YAML front matter * [`vfile-message`](https://github.com/vfile/vfile-message) — create a vfile message * [`vfile-messages-to-vscode-diagnostics`](https://github.com/shinnn/vfile-messages-to-vscode-diagnostics) — transform vfile messages to VS Code diagnostics * [`vfile-mkdirp`](https://github.com/vfile/vfile-mkdirp) — make sure the directory of a vfile exists on the file system * [`vfile-rename`](https://github.com/vfile/vfile-rename) — rename the path parts of a vfile * [`vfile-sort`](https://github.com/vfile/vfile-sort) — sort messages by line/column * [`vfile-statistics`](https://github.com/vfile/vfile-statistics) — count messages per category: failures, warnings, etc * [`vfile-to-eslint`](https://github.com/vfile/vfile-to-eslint) — convert to ESLint formatter compatible output ## Reporters The following list of projects show linting results for given virtual files. Reporters *must* accept `Array.` as their first argument, and return `string`. Reporters *may* accept other values too, in which case it’s suggested to stick to `vfile-reporter`s interface. * [`vfile-reporter`][reporter] — create a report * [`vfile-reporter-json`](https://github.com/vfile/vfile-reporter-json) — create a JSON report * [`vfile-reporter-folder-json`](https://github.com/vfile/vfile-reporter-folder-json) — create a JSON representation of vfiles * [`vfile-reporter-pretty`](https://github.com/vfile/vfile-reporter-pretty) — create a pretty report * [`vfile-reporter-junit`](https://github.com/kellyselden/vfile-reporter-junit) — create a jUnit report * [`vfile-reporter-position`](https://github.com/Hocdoc/vfile-reporter-position) — create a report with content excerpts ## Contribute See [`contributing.md`][contributing] in [`vfile/.github`][health] for ways to get started. See [`support.md`][support] for ways to get help. Ideas for new utilities and tools can be posted in [`vfile/ideas`][ideas]. This project has a [code of conduct][coc]. By interacting with this repository, organization, or community you agree to abide by its terms. ## Sponsor Support this effort and give back by sponsoring on [OpenCollective][collective]!
Gatsby 🥇

Vercel 🥇

Netlify

Holloway

ThemeIsle

Boost Hub

Expo


You?

## Acknowledgments The initial release of this project was authored by [**@wooorm**](https://github.com/wooorm). Thanks to [**@contra**](https://github.com/contra), [**@phated**](https://github.com/phated), and others for their work on [Vinyl][], which was a huge inspiration. Thanks to [**@brendo**](https://github.com/brendo), [**@shinnn**](https://github.com/shinnn), [**@KyleAMathews**](https://github.com/KyleAMathews), [**@sindresorhus**](https://github.com/sindresorhus), and [**@denysdovhan**](https://github.com/denysdovhan) for contributing commits since! ## License [MIT][license] © [Titus Wormer][author] [build-badge]: https://github.com/vfile/vfile/workflows/main/badge.svg [build]: https://github.com/vfile/vfile/actions [coverage-badge]: https://img.shields.io/codecov/c/github/vfile/vfile.svg [coverage]: https://codecov.io/github/vfile/vfile [downloads-badge]: https://img.shields.io/npm/dm/vfile.svg [downloads]: https://www.npmjs.com/package/vfile [size-badge]: https://img.shields.io/bundlephobia/minzip/vfile.svg [size]: https://bundlephobia.com/result?p=vfile [sponsors-badge]: https://opencollective.com/unified/sponsors/badge.svg [backers-badge]: https://opencollective.com/unified/backers/badge.svg [collective]: https://opencollective.com/unified [chat-badge]: https://img.shields.io/badge/chat-discussions-success.svg [chat]: https://github.com/vfile/vfile/discussions [npm]: https://docs.npmjs.com/cli/install [contributing]: https://github.com/vfile/.github/blob/HEAD/contributing.md [support]: https://github.com/vfile/.github/blob/HEAD/support.md [health]: https://github.com/vfile/.github [coc]: https://github.com/vfile/.github/blob/HEAD/code-of-conduct.md [license]: license [author]: https://wooorm.com [unified]: https://github.com/unifiedjs/unified [vinyl]: https://github.com/gulpjs/vinyl [site]: https://unifiedjs.com [twitter]: https://twitter.com/unifiedjs [contribute]: #contribute [sponsor]: #sponsor [unist]: https://github.com/syntax-tree/unist#list-of-utilities [reporter]: https://github.com/vfile/vfile-reporter [vmessage]: https://github.com/vfile/vfile-message [messages]: #vfilemessages [message]: #vfilemessagereason-position-origin [ideas]: https://github.com/vfile/ideas [encoding]: https://nodejs.org/api/buffer.html#buffer_buffers_and_character_encodings [buffer]: https://nodejs.org/api/buffer.html