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

@wellcaffeinated/resultify

v0.0.2

Published

Use the RUST-inspired Result pattern in javascript.

Downloads

5

Readme

resultify

Use the RUST-inspired Result pattern in javascript.

Motivation

Consider this:

// fetch from some db
let item
try {
  const db = await connect('somedb://localhost')
  const text = await db.fetch(query)
  item = JSON.parse(text)
} catch (e) {
  // hmm did i fail to connect? or did i not find it? Or... did it fail to parse json
}
return item

Maybe you could do this...

// fetch from some db
let db
let item
try {
  db = await connect('somedb://localhost')
} catch (e) {
  throw new DbConnectionError('Could not connect to database')
}
let text
try {
  text = await db.fetch(query)
  if (!text) {
    throw new NotFound()
  }
} catch (e) {
  throw new DataRetrievalError('Failed to retrieve entry from database')
}
try {
  return JSON.parse(text)
} catch (e) {
  throw new MalformedDataError('Data is corrupted')
}

Try this instead:

const connectToDb = resultify(connect)
const retrieve = resultify((db, query) => db?.fetch(query))
const parseJson = resultify(o => JSON.parse(o))

const conn = await connectToDb('somedb://localhost')
if (conn.failed){
  throw new DbConnectionError('Could not connect to database')
}
const record = await retrieve(conn.value, query)
if (record.failed){
  throw new DataRetrievalError('Failed to retrieve entry from database')
}
if (!record.value){
  throw new NotFound()
}
const json = parseJson(record.value)
if (json.failed){
  throw new MalformedDataError('Data is corrupted')
}
return json.value

Install

npm install @wellcaffeinated/resultify

Use

import { resultify } from '@wellcaffeinated/resultify'

const divide = (a, b) => {
  if (b === 0){ throw new Error('Can not divide by zero!')  }
  return a / b
}

const divideAsResult = resultify(divide)

const result = divideAsResult(1, 2)
console.log(result.value) // => 0.5

const failed = divideAsResult(1, 0)
console.log(result.error.message) // => "Error: Can not divide by zero!"

It can handle async functions too.

const someSketchyFunction = () => {
  if (Math.random() > 0.5){
    return Promise.resolve('it worked')
  } else {
    return Promise.reject(new Error('it failed'))
  }
}

const fn = resultify(someSketchyFunction)
const result = await fn()

if (result.ok){
  console.log('Everything is fine')
}

if (result.failed){
  console.log('Something went wrong')
}

Use results directly

You can use ok and fail directly if you like.

import { ok, fail, isOk, isFailed } from '@wellcaffeinated/resultify'

class Point {
  constructor(x, y){
    this.x = x
    this.y = y
  }
}

const parseCoords = (coordsText) => {
  const parts = coordsText?.split(',')
  if (!parts || parts.length !== 2){ return fail('Malformed input) }
  const x = parseFloat(parts[0])
  const y = parseFloat(parts[1])
  if (isNaN(x) || isNaN(y)){ return fail('Input does not contain numbers') }
  return ok(new Point(x, y))
}

const res = parseCoords('3,4')
let point
if (res.failed){
  point = new Point(0, 0) // default
} else {
  point = res.value
}

API

resultify(fn) - convert a sync or async function to return a result

resultify(promise) - convert a promise to an async result

ok(value) - create an OK result with value

fail(errorOrString) - create a FAILED result with specified error or generic error from specified string

isResult(thing) - determine if this thing is a result type

isOk(thing) - determine if this thing is an ok result (if unsure of type)

isFailed(thing) - determine if this thing is a failed result (if unsure of type)

Alternatives