npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@kikiutils/fs-extra

v2.3.10

Published

Wraps node:fs, node:fs/promises, and fs-extra functions with try-catch, returning success/failure indicators. Includes additional file and path utilities.

Downloads

235

Readme

@kikiutils/fs-extra

npm version npm downloads License

Wraps node:fs, node:fs/promises, and fs-extra functions with try-catch, returning success/failure indicators. Includes additional file and path utilities.

Features

  • 🛡️ Wraps node:fs, node:fs/promises, and fs-extra functions with try-catch for error prevention
  • ✔️ Returns true on success and false on failure for functions that originally return void
  • 📊 Returns data on success and undefined on failure for functions that originally return data
  • 🌐 Provides support for most node:fs, node:fs/promises, and fs-extra functions
  • 🔧 Additional utility functions for file and path operations

Environmental Requirements

  • Node.js version 18 or higher

Installation

Add dependency (example using pnpm).

pnpm add @kikiutils/fs-extra

You can also use yarn, npm, or bun to add the dependency.

That's it! You're ready to use this package in your project. Check out the usage instructions below ✨.

Usage

When using node:fs, node:fs/promises, or fs-extra functions, you may only care about whether the operation succeeds, not the reason for any errors.

This package wraps these functions with try-catch to prevent errors from stopping the entire program.

Functions that originally return void now return true on success and false on failure.

Functions that originally return data now return the data on success and undefined on failure.

[!IMPORTANT] If the function you are executing does not have a corresponding feature in the runtime, it will throw a ToWrapFunctionIsUndefinedError error.

import kFse, { rename } from '@kikiutils/fs-extra';

const data = await kFse.readJson(path);
// Any json data - successfully read
// undefined - an error occurred

const result = await rename(oldPath, newPath);
// true - successfully renamed
// false - an error occurred

See the description below to find out which functions are available.

Available Functions

You can use most of the functions provided by node:fs, node:fs/promises, and fs-extra, but all functions that do not end with "Sync" will return a Promise.

All functions do not have a callback parameter because errors are passed to the callback if used.

If you need to use the callback functionality, please import and use the functions directly from the original package.

Additional Functions

The following functions have corresponding sync versions.

  • getFileSize - Uses stat to get the file size.
  • pathIsBlockDevice - Uses stat to check if a path is a block device.
  • pathIsCharacterDevice - Uses stat to check if a path is a character device.
  • pathIsDirectory, pathIsDir - Uses stat to check if a path is a directory.
  • pathIsFIFO - Uses stat to check if a path is a FIFO (named pipe).
  • pathIsFile - Uses stat to check if a path is a file.
  • pathIsSocket - Uses stat to check if a path is a socket.
  • pathIsSymbolicLink - Uses stat to check if a path is a symbolic link.
  • readFileToBlob - Reads a file and returns its contents as a Blob.

Unexported Functions

Deprecated functions are not exported.

The following functions do not need to be wrapped with try-catch. If you need to use them, please import them directly from node:fs or node:fs/promises:

  • fs.watch
  • fs.watchFile
  • fs.promise.watch

License

MIT License