diff-leven 0.3.2 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -7,6 +7,8 @@
7
7
  [![jsdelivr](https://data.jsdelivr.com/v1/package/npm/diff-leven/badge?style=rounded)](https://www.jsdelivr.com/package/npm/diff-leven)
8
8
  ![License](https://img.shields.io/npm/l/diff-leven.svg)
9
9
 
10
+ **Try now:** [link](https://kushalshit27.github.io/diff-leven/)
11
+
10
12
  ---
11
13
 
12
14
  ## ✨ Features
@@ -14,7 +16,7 @@
14
16
  - **Advanced Diff Generation**: Uses the Levenshtein distance algorithm for meaningful diffs
15
17
  - **Multiple Data Type Support**:
16
18
  - Objects (including nested structures)
17
- - Arrays (smart matching by content similarity)
19
+ - Arrays (positional comparison; no reordering/LCS)
18
20
  - Strings (character-level differences)
19
21
  - Numbers, Booleans, and any serializable value
20
22
  - **Rich Output Options**:
@@ -59,6 +61,8 @@ console.log(diff({ foo: 'bar' }, { foo: 'baz' }));
59
61
 
60
62
  Compare two values (strings, objects, arrays, etc.) and return a formatted diff string.
61
63
 
64
+ > **Note on arrays:** comparison is positional only (index-by-index). Reordered elements are treated as removals/additions rather than matched by similarity.
65
+
62
66
  #### **Parameters**
63
67
 
64
68
  - `a`, `b`: Anything serializable (object, array, string, number, etc.)
package/dist/index.js CHANGED
@@ -1,15 +1,15 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _leven = require('leven'); var _leven2 = _interopRequireDefault(_leven);var p=(f=>(f.ADDED="added",f.REMOVED="removed",f.CHANGED="changed",f.UNCHANGED="unchanged",f))(p||{});function y(e,t,a={},r=[]){let{keysOnly:f=!1,ignoreValues:g=!1}=a;if(e===void 0&&t===void 0)return{type:"unchanged"};if(e===void 0)return{type:"added",path:r,newValue:t};if(t===void 0)return{type:"removed",path:r,oldValue:e};if(typeof e!="object"||typeof t!="object"||e===null||t===null){if(f||g)return{type:"unchanged",path:r,oldValue:e,newValue:t,meta:{ignored:!0}};if(e===t)return{type:"unchanged",path:r,oldValue:e,newValue:t};if(typeof e=="string"&&typeof t=="string"){let c=_leven2.default.call(void 0, e,t),l=Math.max(e.length,t.length),n=l>0?1-c/l:1;return{type:"changed",path:r,oldValue:e,newValue:t,meta:{levenDistance:c,similarity:n}}}return{type:"changed",path:r,oldValue:e,newValue:t}}return Array.isArray(e)&&Array.isArray(t)?C(e,t,a,r):A(e,t,a,r)}function A(e,t,a,r){let{ignoreKeys:f=[]}=a,g=new Set([...Object.keys(e).filter(n=>!f.includes(n)),...Object.keys(t).filter(n=>!f.includes(n))]),c=[],l=!1;for(let n of g){let s=[...r,n],D=e[n],i=t[n],o=y(D,i,a,s);o.type!=="unchanged"&&(l=!0),c.push(o)}return l?{type:"changed",path:r,oldValue:e,newValue:t,children:c}:{type:"unchanged",path:r,oldValue:e,newValue:t}}function C(e,t,a,r){if(e.length!==t.length){let c=[],l=Math.max(e.length,t.length);for(let n=0;n<l;n++){let s=[...r,n.toString()];n>=e.length?c.push({type:"added",path:s,newValue:t[n]}):n>=t.length?c.push({type:"removed",path:s,oldValue:e[n]}):c.push(y(e[n],t[n],a,s))}return{type:"changed",path:r,oldValue:e,newValue:t,children:c}}let f=[],g=!1;for(let c=0;c<e.length;c++){let l=[...r,c.toString()],n=e[c],s=t[c],D;if(typeof n=="string"&&typeof s=="string")if(n===s)D={type:"unchanged",path:l,oldValue:n,newValue:s};else{let i=_leven2.default.call(void 0, n,s),o=Math.max(n.length,s.length),h=o>0?1-i/o:1;D={type:"changed",path:l,oldValue:n,newValue:s,meta:{levenDistance:i,similarity:h}},g=!0}else D=y(n,s,a,l),D.type!=="unchanged"&&(g=!0);f.push(D)}return g?{type:"changed",path:r,oldValue:e,newValue:t,children:f}:{type:"unchanged",path:r,oldValue:e,newValue:t}}var u={reset:"\x1B[0m",red:"\x1B[31m",green:"\x1B[32m",gray:"\x1B[90m"};function E(e,t={}){let{color:a=!0,full:r=!1,withSimilarity:f=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0)?"":!e.children||e.children.length===0?G(e,a,f):H(e,t,0)}function G(e,t,a=!1){let r=x(e.type),f="";switch(e.type){case"added":return f=$(e.newValue),t?`${u.green}${r} ${f}${u.reset}`:`${r} ${f}`;case"removed":return f=$(e.oldValue),t?`${u.red}${r} ${f}${u.reset}`:`${r} ${f}`;case"changed":let g=$(e.oldValue),c=$(e.newValue),l="";if(a&&_optionalChain([e, 'access', _ => _.meta, 'optionalAccess', _2 => _2.similarity])!==void 0&&typeof e.oldValue=="string"&&typeof e.newValue=="string"){let D=Math.round(e.meta.similarity*100);l=t?`${u.gray} (${D}% similar)${u.reset}`:` (${D}% similar)`}let n=t?`${u.green}+ ${c}${l}${u.reset}`:`+ ${c}${l}`,s=t?`${u.red}- ${g}${u.reset}`:`- ${g}`;return`${n}
2
- ${s}`;default:return f=$(_nullishCoalesce(e.newValue, () => (e.oldValue))),t?`${u.gray}${r} ${f}${u.reset}`:`${r} ${f}`}}function H(e,t,a=0){let{full:r=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0||typeof e.oldValue!="object"&&typeof e.newValue!="object")?"":Array.isArray(e.oldValue)||Array.isArray(e.newValue)?m(e,t,a):b(e,t,a)}function N(e,t,a,r,f,g){let{color:c,withSimilarity:l}=a,n="";l&&f!==void 0&&(n=c?`${u.gray} (${Math.round(f*100)}% similar)${u.reset}`:` (${Math.round(f*100)}% similar)`);let s=g?`${g}: `:"",D=c?`${r}${u.green}+ ${s}${$(e)}${n}${u.reset}`:`${r}+ ${s}${$(e)}${n}`,i=c?`${r}${u.red}- ${s}${$(t)}${u.reset}`:`${r}- ${s}${$(t)}`;return`${D}
3
- ${i}`}function m(e,t,a=0){let{color:r=!0,full:f=!1,withSimilarity:g=!1}=t,c=" ".repeat(a),l=" ".repeat(a+2),n=`[
4
- `,s=0;if(e.children)for(let D=0;D<e.children.length;D++){let i=e.children[D];if(!(i.type==="unchanged"&&!f&&(!i.children||i.children.length===0)))if(i.children&&i.children.length>0){let o=Array.isArray(i.newValue||i.oldValue)?m(i,t,a+2):b(i,t,a+2);o.trim().length>2&&(s>0&&(n+=`,
5
- `),n+=l,n+=o,s++)}else switch(s>0&&(n+=`,
6
- `),i.type){case"added":n+=r?`${l}${u.green}+ ${$(i.newValue)}${u.reset}`:`${l}+ ${$(i.newValue)}`,s++;break;case"removed":n+=r?`${l}${u.red}- ${$(i.oldValue)}${u.reset}`:`${l}- ${$(i.oldValue)}`,s++;break;case"unchanged":_optionalChain([i, 'access', _3 => _3.meta, 'optionalAccess', _4 => _4.ignored])&&i.path?n+=r?`${l}${u.gray} ${i.path[i.path.length-1]||""}${u.reset}`:`${l} ${i.path[i.path.length-1]||""}`:n+=r?`${l}${u.gray} ${$(i.newValue)}${u.reset}`:`${l} ${$(i.newValue)}`,s++;break;case"changed":n+=N(i.newValue,i.oldValue,{color:r,withSimilarity:g},l,_optionalChain([i, 'access', _5 => _5.meta, 'optionalAccess', _6 => _6.similarity])),s++;break}}return s>0&&(n+=`
7
- `),n+=`${c}]`,n}function b(e,t,a=0){let{color:r=!0,full:f=!1,withSimilarity:g=!1}=t,c=" ".repeat(a),l=" ".repeat(a+2),n=`{
8
- `,s=0;if(e.children){let D=e.children.filter(i=>{if(i.type!=="unchanged"||f||i.children&&i.children.length>0)return!0;let o=_optionalChain([i, 'access', _7 => _7.path, 'optionalAccess', _8 => _8[i.path.length-1]])||"";return!!_optionalChain([t, 'access', _9 => _9.outputKeys, 'optionalAccess', _10 => _10.includes, 'call', _11 => _11(o)])});for(let i=0;i<D.length;i++){let o=D[i],h=_optionalChain([o, 'access', _12 => _12.path, 'optionalAccess', _13 => _13[o.path.length-1]])||"",S=i===D.length-1;if(s>0&&!n.endsWith(`
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }var _leven = require('leven'); var _leven2 = _interopRequireDefault(_leven);var p=(u=>(u.ADDED="added",u.REMOVED="removed",u.CHANGED="changed",u.UNCHANGED="unchanged",u))(p||{});function y(e,t,s={},r=[]){let{keysOnly:u=!1,ignoreValues:g=!1}=s;if(e===void 0&&t===void 0)return{type:"unchanged"};if(e===void 0)return{type:"added",path:r,newValue:t};if(t===void 0)return{type:"removed",path:r,oldValue:e};if(typeof e!="object"||typeof t!="object"||e===null||t===null){if(u||g)return{type:"unchanged",path:r,oldValue:e,newValue:t,meta:{ignored:!0}};if(e===t)return{type:"unchanged",path:r,oldValue:e,newValue:t};if(typeof e=="string"&&typeof t=="string"){let o=_leven2.default.call(void 0, e,t),l=Math.max(e.length,t.length),n=l>0?1-o/l:1;return{type:"changed",path:r,oldValue:e,newValue:t,meta:{levenDistance:o,similarity:n}}}return{type:"changed",path:r,oldValue:e,newValue:t}}return Array.isArray(e)&&Array.isArray(t)?C(e,t,s,r):A(e,t,s,r)}function A(e,t,s,r){let{ignoreKeys:u=[]}=s,g=new Set([...Object.keys(e).filter(n=>!u.includes(n)),...Object.keys(t).filter(n=>!u.includes(n))]),o=[],l=!1;for(let n of g){let f=[...r,n],D=e[n],i=t[n],c=y(D,i,s,f);c.type!=="unchanged"&&(l=!0),o.push(c)}return l?{type:"changed",path:r,oldValue:e,newValue:t,children:o}:{type:"unchanged",path:r,oldValue:e,newValue:t}}function C(e,t,s,r){if(e.length!==t.length){let o=[],l=Math.max(e.length,t.length);for(let n=0;n<l;n++){let f=[...r,n.toString()];n>=e.length?o.push({type:"added",path:f,newValue:t[n]}):n>=t.length?o.push({type:"removed",path:f,oldValue:e[n]}):o.push(y(e[n],t[n],s,f))}return{type:"changed",path:r,oldValue:e,newValue:t,children:o}}let u=[],g=!1;for(let o=0;o<e.length;o++){let l=[...r,o.toString()],n=e[o],f=t[o],D=y(n,f,s,l);D.type!=="unchanged"&&(g=!0),u.push(D)}return g?{type:"changed",path:r,oldValue:e,newValue:t,children:u}:{type:"unchanged",path:r,oldValue:e,newValue:t}}var a={reset:"\x1B[0m",red:"\x1B[31m",green:"\x1B[32m",gray:"\x1B[90m"};function V(e,t={}){let{color:s=!0,full:r=!1,withSimilarity:u=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0)?"":!e.children||e.children.length===0?G(e,s,u):H(e,t,0)}function G(e,t,s=!1){let r=O(e.type),u="";switch(e.type){case"added":return u=$(e.newValue),t?`${a.green}${r} ${u}${a.reset}`:`${r} ${u}`;case"removed":return u=$(e.oldValue),t?`${a.red}${r} ${u}${a.reset}`:`${r} ${u}`;case"changed":let g=$(e.oldValue),o=$(e.newValue),l="";if(s&&_optionalChain([e, 'access', _ => _.meta, 'optionalAccess', _2 => _2.similarity])!==void 0&&typeof e.oldValue=="string"&&typeof e.newValue=="string"){let D=Math.round(e.meta.similarity*100);l=t?`${a.gray} (${D}% similar)${a.reset}`:` (${D}% similar)`}let n=t?`${a.green}+ ${o}${l}${a.reset}`:`+ ${o}${l}`,f=t?`${a.red}- ${g}${a.reset}`:`- ${g}`;return`${n}
2
+ ${f}`;default:return u=$(_nullishCoalesce(e.newValue, () => (e.oldValue))),t?`${a.gray}${r} ${u}${a.reset}`:`${r} ${u}`}}function H(e,t,s=0){let{full:r=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0||typeof e.oldValue!="object"&&typeof e.newValue!="object")?"":Array.isArray(e.oldValue)||Array.isArray(e.newValue)?m(e,t,s):b(e,t,s)}function E(e,t,s,r,u,g){let{color:o,withSimilarity:l}=s,n="";l&&u!==void 0&&(n=o?`${a.gray} (${Math.round(u*100)}% similar)${a.reset}`:` (${Math.round(u*100)}% similar)`);let f=g?`${g}: `:"",D=o?`${r}${a.green}+ ${f}${$(e)}${n}${a.reset}`:`${r}+ ${f}${$(e)}${n}`,i=o?`${r}${a.red}- ${f}${$(t)}${a.reset}`:`${r}- ${f}${$(t)}`;return`${D}
3
+ ${i}`}function m(e,t,s=0){let{color:r=!0,full:u=!1,withSimilarity:g=!1}=t,o=" ".repeat(s),l=" ".repeat(s+2),n=`[
4
+ `,f=0;if(e.children)for(let D=0;D<e.children.length;D++){let i=e.children[D];if(!(i.type==="unchanged"&&!u&&(!i.children||i.children.length===0)))if(i.children&&i.children.length>0){let c=Array.isArray(i.newValue||i.oldValue)?m(i,t,s+2):b(i,t,s+2);c.trim().length>2&&(f>0&&(n+=`,
5
+ `),n+=l,n+=c,f++)}else switch(f>0&&(n+=`,
6
+ `),i.type){case"added":n+=r?`${l}${a.green}+ ${$(i.newValue)}${a.reset}`:`${l}+ ${$(i.newValue)}`,f++;break;case"removed":n+=r?`${l}${a.red}- ${$(i.oldValue)}${a.reset}`:`${l}- ${$(i.oldValue)}`,f++;break;case"unchanged":_optionalChain([i, 'access', _3 => _3.meta, 'optionalAccess', _4 => _4.ignored])&&i.path?n+=r?`${l}${a.gray} ${i.path[i.path.length-1]||""}${a.reset}`:`${l} ${i.path[i.path.length-1]||""}`:n+=r?`${l}${a.gray} ${$(i.newValue)}${a.reset}`:`${l} ${$(i.newValue)}`,f++;break;case"changed":n+=E(i.newValue,i.oldValue,{color:r,withSimilarity:g},l,_optionalChain([i, 'access', _5 => _5.meta, 'optionalAccess', _6 => _6.similarity])),f++;break}}return f>0&&(n+=`
7
+ `),n+=`${o}]`,n}function b(e,t,s=0){let{color:r=!0,full:u=!1,withSimilarity:g=!1}=t,o=" ".repeat(s),l=" ".repeat(s+2),n=`{
8
+ `,f=0;if(e.children){let D=e.children.filter(i=>{if(i.type!=="unchanged"||u||i.children&&i.children.length>0)return!0;let c=_optionalChain([i, 'access', _7 => _7.path, 'optionalAccess', _8 => _8[i.path.length-1]])||"";return!!_optionalChain([t, 'access', _9 => _9.outputKeys, 'optionalAccess', _10 => _10.includes, 'call', _11 => _11(c)])});for(let i=0;i<D.length;i++){let c=D[i],h=_optionalChain([c, 'access', _12 => _12.path, 'optionalAccess', _13 => _13[c.path.length-1]])||"",R=i===D.length-1;if(f>0&&!n.endsWith(`
9
9
  `)&&(n+=`,
10
- `),o.children&&o.children.length>0){let d=Array.isArray(o.newValue||o.oldValue)?m(o,t,a+2):b(o,t,a+2);d.trim().length>2&&(n+=`${l}${h}: `,n+=d,s++)}else switch(o.type){case"added":n+=r?`${l}${u.green}+ ${h}: ${$(o.newValue)}${u.reset}`:`${l}+ ${h}: ${$(o.newValue)}`,s++;break;case"removed":n+=r?`${l}${u.red}- ${h}: ${$(o.oldValue)}${u.reset}`:`${l}- ${h}: ${$(o.oldValue)}`,s++;break;case"changed":n+=N(o.newValue,o.oldValue,{color:r,withSimilarity:g},l,_optionalChain([o, 'access', _14 => _14.meta, 'optionalAccess', _15 => _15.similarity]),h),s++;break;case"unchanged":(f||_optionalChain([t, 'access', _16 => _16.outputKeys, 'optionalAccess', _17 => _17.includes, 'call', _18 => _18(h)]))&&(_optionalChain([o, 'access', _19 => _19.meta, 'optionalAccess', _20 => _20.ignored])?n+=r?`${l}${u.gray} ${h}${u.reset}`:`${l} ${h}`:n+=r?`${l}${u.gray} ${h}: ${$(o.newValue)}${u.reset}`:`${l} ${h}: ${$(o.newValue)}`,s++);break}!S&&!n.endsWith(`
10
+ `),c.children&&c.children.length>0){let d=Array.isArray(c.newValue||c.oldValue)?m(c,t,s+2):b(c,t,s+2);d.trim().length>2&&(n+=`${l}${h}: `,n+=d,f++)}else switch(c.type){case"added":n+=r?`${l}${a.green}+ ${h}: ${$(c.newValue)}${a.reset}`:`${l}+ ${h}: ${$(c.newValue)}`,f++;break;case"removed":n+=r?`${l}${a.red}- ${h}: ${$(c.oldValue)}${a.reset}`:`${l}- ${h}: ${$(c.oldValue)}`,f++;break;case"changed":n+=E(c.newValue,c.oldValue,{color:r,withSimilarity:g},l,_optionalChain([c, 'access', _14 => _14.meta, 'optionalAccess', _15 => _15.similarity]),h),f++;break;case"unchanged":(u||_optionalChain([t, 'access', _16 => _16.outputKeys, 'optionalAccess', _17 => _17.includes, 'call', _18 => _18(h)]))&&(_optionalChain([c, 'access', _19 => _19.meta, 'optionalAccess', _20 => _20.ignored])?n+=r?`${l}${a.gray} ${h}${a.reset}`:`${l} ${h}`:n+=r?`${l}${a.gray} ${h}: ${$(c.newValue)}${a.reset}`:`${l} ${h}: ${$(c.newValue)}`,f++);break}!R&&!n.endsWith(`
11
11
  `)&&(n+=","),n.endsWith(`
12
12
  `)||(n+=`
13
- `)}}return s>0&&!n.endsWith(`
13
+ `)}}return f>0&&!n.endsWith(`
14
14
  `)&&(n+=`
15
- `),n+=`${c}}`,n}function x(e){switch(e){case"added":return"+";case"removed":return"-";case"changed":return"!";default:return" "}}function $(e){return e===void 0?"undefined":e===null?"null":typeof e=="string"?`'${e}'`:typeof e=="number"||typeof e=="boolean"?e.toString():typeof e=="object"?JSON.stringify(e,null,2):String(e)}function R(e,t,a={}){return y(e,t,a)}function F(e,t,a={}){let r=R(e,t,a);return E(r,a)}function Q(e,t,a={}){return R(e,t,a).type!=="unchanged"}exports.DiffType = p; exports.diff = F; exports.diffRaw = R; exports.isDiff = Q;
15
+ `),n+=`${o}}`,n}function O(e){switch(e){case"added":return"+";case"removed":return"-";case"changed":return"!";default:return" "}}function $(e){return e===void 0?"undefined":e===null?"null":typeof e=="string"?`'${e}'`:typeof e=="number"||typeof e=="boolean"?e.toString():typeof e=="object"?JSON.stringify(e,null,2):String(e)}function N(e,t,s={}){return y(e,t,s)}function Q(e,t,s={}){let r=N(e,t,s);return V(r,s)}function X(e,t,s={}){return N(e,t,s).type!=="unchanged"}exports.DiffType = p; exports.diff = Q; exports.diffRaw = N; exports.isDiff = X;
package/dist/index.mjs CHANGED
@@ -1,15 +1,15 @@
1
- import V from"leven";var p=(f=>(f.ADDED="added",f.REMOVED="removed",f.CHANGED="changed",f.UNCHANGED="unchanged",f))(p||{});function y(e,t,a={},r=[]){let{keysOnly:f=!1,ignoreValues:g=!1}=a;if(e===void 0&&t===void 0)return{type:"unchanged"};if(e===void 0)return{type:"added",path:r,newValue:t};if(t===void 0)return{type:"removed",path:r,oldValue:e};if(typeof e!="object"||typeof t!="object"||e===null||t===null){if(f||g)return{type:"unchanged",path:r,oldValue:e,newValue:t,meta:{ignored:!0}};if(e===t)return{type:"unchanged",path:r,oldValue:e,newValue:t};if(typeof e=="string"&&typeof t=="string"){let c=V(e,t),l=Math.max(e.length,t.length),n=l>0?1-c/l:1;return{type:"changed",path:r,oldValue:e,newValue:t,meta:{levenDistance:c,similarity:n}}}return{type:"changed",path:r,oldValue:e,newValue:t}}return Array.isArray(e)&&Array.isArray(t)?C(e,t,a,r):A(e,t,a,r)}function A(e,t,a,r){let{ignoreKeys:f=[]}=a,g=new Set([...Object.keys(e).filter(n=>!f.includes(n)),...Object.keys(t).filter(n=>!f.includes(n))]),c=[],l=!1;for(let n of g){let s=[...r,n],D=e[n],i=t[n],o=y(D,i,a,s);o.type!=="unchanged"&&(l=!0),c.push(o)}return l?{type:"changed",path:r,oldValue:e,newValue:t,children:c}:{type:"unchanged",path:r,oldValue:e,newValue:t}}function C(e,t,a,r){if(e.length!==t.length){let c=[],l=Math.max(e.length,t.length);for(let n=0;n<l;n++){let s=[...r,n.toString()];n>=e.length?c.push({type:"added",path:s,newValue:t[n]}):n>=t.length?c.push({type:"removed",path:s,oldValue:e[n]}):c.push(y(e[n],t[n],a,s))}return{type:"changed",path:r,oldValue:e,newValue:t,children:c}}let f=[],g=!1;for(let c=0;c<e.length;c++){let l=[...r,c.toString()],n=e[c],s=t[c],D;if(typeof n=="string"&&typeof s=="string")if(n===s)D={type:"unchanged",path:l,oldValue:n,newValue:s};else{let i=V(n,s),o=Math.max(n.length,s.length),h=o>0?1-i/o:1;D={type:"changed",path:l,oldValue:n,newValue:s,meta:{levenDistance:i,similarity:h}},g=!0}else D=y(n,s,a,l),D.type!=="unchanged"&&(g=!0);f.push(D)}return g?{type:"changed",path:r,oldValue:e,newValue:t,children:f}:{type:"unchanged",path:r,oldValue:e,newValue:t}}var u={reset:"\x1B[0m",red:"\x1B[31m",green:"\x1B[32m",gray:"\x1B[90m"};function E(e,t={}){let{color:a=!0,full:r=!1,withSimilarity:f=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0)?"":!e.children||e.children.length===0?G(e,a,f):H(e,t,0)}function G(e,t,a=!1){let r=x(e.type),f="";switch(e.type){case"added":return f=$(e.newValue),t?`${u.green}${r} ${f}${u.reset}`:`${r} ${f}`;case"removed":return f=$(e.oldValue),t?`${u.red}${r} ${f}${u.reset}`:`${r} ${f}`;case"changed":let g=$(e.oldValue),c=$(e.newValue),l="";if(a&&e.meta?.similarity!==void 0&&typeof e.oldValue=="string"&&typeof e.newValue=="string"){let D=Math.round(e.meta.similarity*100);l=t?`${u.gray} (${D}% similar)${u.reset}`:` (${D}% similar)`}let n=t?`${u.green}+ ${c}${l}${u.reset}`:`+ ${c}${l}`,s=t?`${u.red}- ${g}${u.reset}`:`- ${g}`;return`${n}
2
- ${s}`;default:return f=$(e.newValue??e.oldValue),t?`${u.gray}${r} ${f}${u.reset}`:`${r} ${f}`}}function H(e,t,a=0){let{full:r=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0||typeof e.oldValue!="object"&&typeof e.newValue!="object")?"":Array.isArray(e.oldValue)||Array.isArray(e.newValue)?m(e,t,a):b(e,t,a)}function N(e,t,a,r,f,g){let{color:c,withSimilarity:l}=a,n="";l&&f!==void 0&&(n=c?`${u.gray} (${Math.round(f*100)}% similar)${u.reset}`:` (${Math.round(f*100)}% similar)`);let s=g?`${g}: `:"",D=c?`${r}${u.green}+ ${s}${$(e)}${n}${u.reset}`:`${r}+ ${s}${$(e)}${n}`,i=c?`${r}${u.red}- ${s}${$(t)}${u.reset}`:`${r}- ${s}${$(t)}`;return`${D}
3
- ${i}`}function m(e,t,a=0){let{color:r=!0,full:f=!1,withSimilarity:g=!1}=t,c=" ".repeat(a),l=" ".repeat(a+2),n=`[
4
- `,s=0;if(e.children)for(let D=0;D<e.children.length;D++){let i=e.children[D];if(!(i.type==="unchanged"&&!f&&(!i.children||i.children.length===0)))if(i.children&&i.children.length>0){let o=Array.isArray(i.newValue||i.oldValue)?m(i,t,a+2):b(i,t,a+2);o.trim().length>2&&(s>0&&(n+=`,
5
- `),n+=l,n+=o,s++)}else switch(s>0&&(n+=`,
6
- `),i.type){case"added":n+=r?`${l}${u.green}+ ${$(i.newValue)}${u.reset}`:`${l}+ ${$(i.newValue)}`,s++;break;case"removed":n+=r?`${l}${u.red}- ${$(i.oldValue)}${u.reset}`:`${l}- ${$(i.oldValue)}`,s++;break;case"unchanged":i.meta?.ignored&&i.path?n+=r?`${l}${u.gray} ${i.path[i.path.length-1]||""}${u.reset}`:`${l} ${i.path[i.path.length-1]||""}`:n+=r?`${l}${u.gray} ${$(i.newValue)}${u.reset}`:`${l} ${$(i.newValue)}`,s++;break;case"changed":n+=N(i.newValue,i.oldValue,{color:r,withSimilarity:g},l,i.meta?.similarity),s++;break}}return s>0&&(n+=`
7
- `),n+=`${c}]`,n}function b(e,t,a=0){let{color:r=!0,full:f=!1,withSimilarity:g=!1}=t,c=" ".repeat(a),l=" ".repeat(a+2),n=`{
8
- `,s=0;if(e.children){let D=e.children.filter(i=>{if(i.type!=="unchanged"||f||i.children&&i.children.length>0)return!0;let o=i.path?.[i.path.length-1]||"";return!!t.outputKeys?.includes(o)});for(let i=0;i<D.length;i++){let o=D[i],h=o.path?.[o.path.length-1]||"",S=i===D.length-1;if(s>0&&!n.endsWith(`
1
+ import S from"leven";var p=(u=>(u.ADDED="added",u.REMOVED="removed",u.CHANGED="changed",u.UNCHANGED="unchanged",u))(p||{});function y(e,t,s={},r=[]){let{keysOnly:u=!1,ignoreValues:g=!1}=s;if(e===void 0&&t===void 0)return{type:"unchanged"};if(e===void 0)return{type:"added",path:r,newValue:t};if(t===void 0)return{type:"removed",path:r,oldValue:e};if(typeof e!="object"||typeof t!="object"||e===null||t===null){if(u||g)return{type:"unchanged",path:r,oldValue:e,newValue:t,meta:{ignored:!0}};if(e===t)return{type:"unchanged",path:r,oldValue:e,newValue:t};if(typeof e=="string"&&typeof t=="string"){let o=S(e,t),l=Math.max(e.length,t.length),n=l>0?1-o/l:1;return{type:"changed",path:r,oldValue:e,newValue:t,meta:{levenDistance:o,similarity:n}}}return{type:"changed",path:r,oldValue:e,newValue:t}}return Array.isArray(e)&&Array.isArray(t)?C(e,t,s,r):A(e,t,s,r)}function A(e,t,s,r){let{ignoreKeys:u=[]}=s,g=new Set([...Object.keys(e).filter(n=>!u.includes(n)),...Object.keys(t).filter(n=>!u.includes(n))]),o=[],l=!1;for(let n of g){let f=[...r,n],D=e[n],i=t[n],c=y(D,i,s,f);c.type!=="unchanged"&&(l=!0),o.push(c)}return l?{type:"changed",path:r,oldValue:e,newValue:t,children:o}:{type:"unchanged",path:r,oldValue:e,newValue:t}}function C(e,t,s,r){if(e.length!==t.length){let o=[],l=Math.max(e.length,t.length);for(let n=0;n<l;n++){let f=[...r,n.toString()];n>=e.length?o.push({type:"added",path:f,newValue:t[n]}):n>=t.length?o.push({type:"removed",path:f,oldValue:e[n]}):o.push(y(e[n],t[n],s,f))}return{type:"changed",path:r,oldValue:e,newValue:t,children:o}}let u=[],g=!1;for(let o=0;o<e.length;o++){let l=[...r,o.toString()],n=e[o],f=t[o],D=y(n,f,s,l);D.type!=="unchanged"&&(g=!0),u.push(D)}return g?{type:"changed",path:r,oldValue:e,newValue:t,children:u}:{type:"unchanged",path:r,oldValue:e,newValue:t}}var a={reset:"\x1B[0m",red:"\x1B[31m",green:"\x1B[32m",gray:"\x1B[90m"};function V(e,t={}){let{color:s=!0,full:r=!1,withSimilarity:u=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0)?"":!e.children||e.children.length===0?G(e,s,u):H(e,t,0)}function G(e,t,s=!1){let r=O(e.type),u="";switch(e.type){case"added":return u=$(e.newValue),t?`${a.green}${r} ${u}${a.reset}`:`${r} ${u}`;case"removed":return u=$(e.oldValue),t?`${a.red}${r} ${u}${a.reset}`:`${r} ${u}`;case"changed":let g=$(e.oldValue),o=$(e.newValue),l="";if(s&&e.meta?.similarity!==void 0&&typeof e.oldValue=="string"&&typeof e.newValue=="string"){let D=Math.round(e.meta.similarity*100);l=t?`${a.gray} (${D}% similar)${a.reset}`:` (${D}% similar)`}let n=t?`${a.green}+ ${o}${l}${a.reset}`:`+ ${o}${l}`,f=t?`${a.red}- ${g}${a.reset}`:`- ${g}`;return`${n}
2
+ ${f}`;default:return u=$(e.newValue??e.oldValue),t?`${a.gray}${r} ${u}${a.reset}`:`${r} ${u}`}}function H(e,t,s=0){let{full:r=!1}=t;return e.type==="unchanged"&&!r&&(!e.children||e.children.length===0||typeof e.oldValue!="object"&&typeof e.newValue!="object")?"":Array.isArray(e.oldValue)||Array.isArray(e.newValue)?m(e,t,s):b(e,t,s)}function E(e,t,s,r,u,g){let{color:o,withSimilarity:l}=s,n="";l&&u!==void 0&&(n=o?`${a.gray} (${Math.round(u*100)}% similar)${a.reset}`:` (${Math.round(u*100)}% similar)`);let f=g?`${g}: `:"",D=o?`${r}${a.green}+ ${f}${$(e)}${n}${a.reset}`:`${r}+ ${f}${$(e)}${n}`,i=o?`${r}${a.red}- ${f}${$(t)}${a.reset}`:`${r}- ${f}${$(t)}`;return`${D}
3
+ ${i}`}function m(e,t,s=0){let{color:r=!0,full:u=!1,withSimilarity:g=!1}=t,o=" ".repeat(s),l=" ".repeat(s+2),n=`[
4
+ `,f=0;if(e.children)for(let D=0;D<e.children.length;D++){let i=e.children[D];if(!(i.type==="unchanged"&&!u&&(!i.children||i.children.length===0)))if(i.children&&i.children.length>0){let c=Array.isArray(i.newValue||i.oldValue)?m(i,t,s+2):b(i,t,s+2);c.trim().length>2&&(f>0&&(n+=`,
5
+ `),n+=l,n+=c,f++)}else switch(f>0&&(n+=`,
6
+ `),i.type){case"added":n+=r?`${l}${a.green}+ ${$(i.newValue)}${a.reset}`:`${l}+ ${$(i.newValue)}`,f++;break;case"removed":n+=r?`${l}${a.red}- ${$(i.oldValue)}${a.reset}`:`${l}- ${$(i.oldValue)}`,f++;break;case"unchanged":i.meta?.ignored&&i.path?n+=r?`${l}${a.gray} ${i.path[i.path.length-1]||""}${a.reset}`:`${l} ${i.path[i.path.length-1]||""}`:n+=r?`${l}${a.gray} ${$(i.newValue)}${a.reset}`:`${l} ${$(i.newValue)}`,f++;break;case"changed":n+=E(i.newValue,i.oldValue,{color:r,withSimilarity:g},l,i.meta?.similarity),f++;break}}return f>0&&(n+=`
7
+ `),n+=`${o}]`,n}function b(e,t,s=0){let{color:r=!0,full:u=!1,withSimilarity:g=!1}=t,o=" ".repeat(s),l=" ".repeat(s+2),n=`{
8
+ `,f=0;if(e.children){let D=e.children.filter(i=>{if(i.type!=="unchanged"||u||i.children&&i.children.length>0)return!0;let c=i.path?.[i.path.length-1]||"";return!!t.outputKeys?.includes(c)});for(let i=0;i<D.length;i++){let c=D[i],h=c.path?.[c.path.length-1]||"",R=i===D.length-1;if(f>0&&!n.endsWith(`
9
9
  `)&&(n+=`,
10
- `),o.children&&o.children.length>0){let d=Array.isArray(o.newValue||o.oldValue)?m(o,t,a+2):b(o,t,a+2);d.trim().length>2&&(n+=`${l}${h}: `,n+=d,s++)}else switch(o.type){case"added":n+=r?`${l}${u.green}+ ${h}: ${$(o.newValue)}${u.reset}`:`${l}+ ${h}: ${$(o.newValue)}`,s++;break;case"removed":n+=r?`${l}${u.red}- ${h}: ${$(o.oldValue)}${u.reset}`:`${l}- ${h}: ${$(o.oldValue)}`,s++;break;case"changed":n+=N(o.newValue,o.oldValue,{color:r,withSimilarity:g},l,o.meta?.similarity,h),s++;break;case"unchanged":(f||t.outputKeys?.includes(h))&&(o.meta?.ignored?n+=r?`${l}${u.gray} ${h}${u.reset}`:`${l} ${h}`:n+=r?`${l}${u.gray} ${h}: ${$(o.newValue)}${u.reset}`:`${l} ${h}: ${$(o.newValue)}`,s++);break}!S&&!n.endsWith(`
10
+ `),c.children&&c.children.length>0){let d=Array.isArray(c.newValue||c.oldValue)?m(c,t,s+2):b(c,t,s+2);d.trim().length>2&&(n+=`${l}${h}: `,n+=d,f++)}else switch(c.type){case"added":n+=r?`${l}${a.green}+ ${h}: ${$(c.newValue)}${a.reset}`:`${l}+ ${h}: ${$(c.newValue)}`,f++;break;case"removed":n+=r?`${l}${a.red}- ${h}: ${$(c.oldValue)}${a.reset}`:`${l}- ${h}: ${$(c.oldValue)}`,f++;break;case"changed":n+=E(c.newValue,c.oldValue,{color:r,withSimilarity:g},l,c.meta?.similarity,h),f++;break;case"unchanged":(u||t.outputKeys?.includes(h))&&(c.meta?.ignored?n+=r?`${l}${a.gray} ${h}${a.reset}`:`${l} ${h}`:n+=r?`${l}${a.gray} ${h}: ${$(c.newValue)}${a.reset}`:`${l} ${h}: ${$(c.newValue)}`,f++);break}!R&&!n.endsWith(`
11
11
  `)&&(n+=","),n.endsWith(`
12
12
  `)||(n+=`
13
- `)}}return s>0&&!n.endsWith(`
13
+ `)}}return f>0&&!n.endsWith(`
14
14
  `)&&(n+=`
15
- `),n+=`${c}}`,n}function x(e){switch(e){case"added":return"+";case"removed":return"-";case"changed":return"!";default:return" "}}function $(e){return e===void 0?"undefined":e===null?"null":typeof e=="string"?`'${e}'`:typeof e=="number"||typeof e=="boolean"?e.toString():typeof e=="object"?JSON.stringify(e,null,2):String(e)}function R(e,t,a={}){return y(e,t,a)}function F(e,t,a={}){let r=R(e,t,a);return E(r,a)}function Q(e,t,a={}){return R(e,t,a).type!=="unchanged"}export{p as DiffType,F as diff,R as diffRaw,Q as isDiff};
15
+ `),n+=`${o}}`,n}function O(e){switch(e){case"added":return"+";case"removed":return"-";case"changed":return"!";default:return" "}}function $(e){return e===void 0?"undefined":e===null?"null":typeof e=="string"?`'${e}'`:typeof e=="number"||typeof e=="boolean"?e.toString():typeof e=="object"?JSON.stringify(e,null,2):String(e)}function N(e,t,s={}){return y(e,t,s)}function Q(e,t,s={}){let r=N(e,t,s);return V(r,s)}function X(e,t,s={}){return N(e,t,s).type!=="unchanged"}export{p as DiffType,Q as diff,N as diffRaw,X as isDiff};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "diff-leven",
3
- "version": "0.3.2",
3
+ "version": "1.0.0",
4
4
  "description": "Git like diff between two strings, using the Levenshtein distance algorithm",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.mjs",
@@ -52,20 +52,20 @@
52
52
  },
53
53
  "homepage": "https://github.com/kushalshit27/diff-leven#readme",
54
54
  "devDependencies": {
55
- "eslint": "^9.30.1",
55
+ "eslint": "^9.39.2",
56
56
  "husky": "9.1.7",
57
- "prettier": "^3.6.2",
57
+ "prettier": "^3.7.4",
58
58
  "ts-node": "^10.9.2",
59
- "tsup": "^8.5.0",
60
- "typescript": "^5.8.3",
61
- "typescript-eslint": "^8.35.1",
62
- "vitest": "^3.2.4"
59
+ "tsup": "^8.5.1",
60
+ "typescript": "^5.9.3",
61
+ "typescript-eslint": "^8.50.1",
62
+ "vitest": "^4.0.16"
63
63
  },
64
64
  "engines": {
65
65
  "node": ">=18"
66
66
  },
67
67
  "dependencies": {
68
- "leven": "^4.0.0"
68
+ "leven": "^4.1.0"
69
69
  },
70
70
  "optionalDependencies": {
71
71
  "@rollup/rollup-linux-x64-gnu": "^4.44.1"