Skip to content

A lightweight immutability library compatible with JS built-in collections.

Notifications You must be signed in to change notification settings

steadicat/mutatis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Mutatis

A lightweight immutability library.

Mutatis mutandis is a Medieval Latin phrase meaning “the necessary changes having been made” or “once the necessary changes have been made”.

Like immutable, but compatible with standard JS data structures, and with ~50Kb less code (minified).

Like seamless-immutable, but with the nice mutability helpers.

Like the React Immutability helpers, but without the weird MongoDB-inspired syntax.

Usage

import mutatis from 'mutatis';

const x = mutatis({a: 12, b: [23, 56]});
mutatis.size; // 2
mutatis.a = 78; // Throws

const y = x.set('c', {d: {e: 'string'});
// {a: 12, b: [23, 56], c: {d: {e: 'string'}}};

const z = y
  .setIn(['c', 'd', 'f'], 'another string')
  .update('b', l => l.concat(78));
// {a: 12, b: [23, 56, 78], c: {d: {e: 'string', f: 'another string'}}};

const a = mutatis([12, 34]);
a.push(56); // Throws

About

A lightweight immutability library compatible with JS built-in collections.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published