partial.lenses
Advanced tools
Comparing version 3.0.0 to 3.1.0
@@ -6,3 +6,3 @@ "use strict"; | ||
}); | ||
exports.props = exports.identity = exports.pick = exports.augment = exports.filter = exports.append = exports.index = exports.findWith = exports.find = exports.prop = exports.normalize = exports.define = exports.required = exports.defaults = exports.replace = exports.choice = exports.orElse = exports.nothing = exports.choose = exports.get = exports.set = exports.modify = exports.lens = exports.removeAll = exports.remove = exports.compose = exports.toRamda = exports.fromRamda = undefined; | ||
exports.props = exports.identity = exports.pick = exports.augment = exports.filter = exports.append = exports.index = exports.findWith = exports.find = exports.prop = exports.normalize = exports.define = exports.required = exports.defaults = exports.replace = exports.choice = exports.orElse = exports.nothing = exports.choose = exports.just = exports.chain = exports.get = exports.set = exports.modify = exports.lens = exports.removeAll = exports.remove = exports.compose = exports.toRamda = exports.fromRamda = undefined; | ||
@@ -136,2 +136,12 @@ var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; | ||
var chain = exports.chain = R.curry(function (x2yL, xL) { | ||
return compose(xL, choose(function (xO) { | ||
return xO === undefined ? nothing : x2yL(xO); | ||
})); | ||
}); | ||
var just = exports.just = function just(x) { | ||
return lens(R.always(x), snd); | ||
}; | ||
var choose = exports.choose = function choose(x2yL) { | ||
@@ -306,2 +316,2 @@ return function (toFunctor) { | ||
exports.default = compose; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/partial.lenses.js"],"names":[],"mappings":";;;;;;;;;AAAA;;IAAY;;;;;;;;;;AAIZ,IAAM,KAAK,SAAL,EAAK;SAAK;CAAL;AACX,IAAM,MAAM,SAAN,GAAM,CAAC,CAAD,EAAI,CAAJ;SAAU;CAAV;;;;AAIZ,IAAM,QAAQ,SAAR,KAAQ,CAAC,QAAD,EAAW,SAAX;SAAyB,aAAK;AAC1C,QAAI,UAAU,CAAV,CAAJ,EACE,OAAO,CAAP,CADF,KAGE,MAAM,IAAI,KAAJ,eAAsB,0BAAqB,OAA3C,CAAN,CAHF;GADqC;CAAzB;;AAOd,IAAM,SAAS,QAAQ,GAAR,CAAY,QAAZ,KAAyB,YAAzB,GAAwC;SAAM;CAAN,GAAW,KAAnD;;;;AAIf,IAAM,QAAQ,EAAR;;AAEN,IAAM,YAAY,SAAZ,SAAY,CAAC,CAAD,EAAI,CAAJ,EAAU;AAC1B,MAAI,MAAM,SAAN,IAAmB,EAAE,KAAK,CAAL,CAAF,EACrB,OAAO,CAAP,CADF;AAEA,MAAI,UAAJ,CAH0B;AAI1B,OAAK,IAAM,CAAN,IAAW,CAAhB,EAAmB;AACjB,QAAI,MAAM,CAAN,EAAS;AACX,UAAI,cAAc,CAAd,EACF,IAAI,EAAJ,CADF;AAEA,QAAE,CAAF,IAAO,EAAE,CAAF,CAAP,CAHW;KAAb;GADF;AAOA,SAAO,CAAP,CAX0B;CAAV;;AAclB,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAa;AAC1B,MAAI,MAAM,SAAN,EACF,2BAAS,GAAI,EAAb,CADF;AAEA,MAAI,KAAK,CAAL,IAAU,EAAE,MAAF,CAAS,CAAT,EAAY,EAAE,CAAF,CAAZ,CAAV,EACF,OAAO,CAAP,CADF;AAEA,MAAM,wBAAM,GAAI,EAAV,CALoB;AAM1B,OAAK,IAAM,CAAN,IAAW,CAAhB;AACE,QAAI,MAAM,CAAN,EACF,EAAE,CAAF,IAAO,EAAE,CAAF,CAAP,CADF;GADF,OAGO,CAAP,CAT0B;CAAb;;;;AAcf,IAAM,UAAU,SAAV,OAAU;SAAM,OAAO,IAAP,CAAY,EAAZ,EAAgB,MAAhB,KAA2B,CAA3B,GAA+B,SAA/B,GAA2C,EAA3C;CAAN;;;;AAIhB,IAAM,YAAY,SAAZ,SAAY;SAAa;WAAK,cAAc,CAAd,GAAkB,CAAlB,GAAsB,UAAU,CAAV,CAAtB;GAAL;CAAb;;;;AAIlB,IAAM,WAAW,SAAX,QAAW,CAAC,EAAD,EAAK,EAAL;SAAY,EAAE,MAAF,CAAS,EAAT,EAAa,EAAb,IAAmB,EAAnB,GAAwB,EAAxB;CAAZ;;AAEjB,IAAM,aAAa,SAAb,UAAa;SAAK,UAAC,CAAD,EAAI,EAAJ;WAAW,SAAS,EAAE,CAAF,EAAK,EAAL,CAAT,EAAmB,EAAnB;GAAX;CAAL;;;;AAInB,IAAM,YAAY,SAAZ,SAAY;SAAK,OAAO,CAAP,KAAa,UAAb,IAA2B,EAAE,MAAF,KAAa,CAAb;CAAhC;;AAEX,IAAM,gCAAY,OAAO,QAAP,EAAiB,SAAjB,CAAZ;;AAEN,IAAM,4BAAU,SAAV,OAAU,IAAK;AAC1B,MAAI,OAAO,CAAP,CAAJ,EAAgB,OAAO,YAAY,CAAZ,CAAP,CAAhB;AACA,MAAI,QAAQ,CAAR,CAAJ,EAAgB,OAAO,aAAa,CAAb,CAAP,CAAhB;AACA,SAAO,UAAU,CAAV,CAAP,CAH0B;CAAL;;AAMhB,IAAM,4BAAU,SAAV,OAAU;oCAAI;;;;SACzB,GAAG,MAAH,KAAc,CAAd,GAAkB,QAAlB,GACA,GAAG,MAAH,KAAc,CAAd,GAAkB,GAAG,CAAH,CAAlB,GACA,EAAE,OAAF,6BAAa,GAAG,GAAH,CAAO,OAAP,EAAb,CADA;CAFqB;;AAKhB,IAAM,0BAAS,EAAE,KAAF,CAAQ,UAAC,CAAD,EAAI,CAAJ;SAAU,EAAE,GAAF,CAAM,QAAQ,CAAR,CAAN,EAAkB,SAAlB,EAA6B,CAA7B;CAAV,CAAjB;;AAEN,IAAM,gCAAY,EAAE,KAAF,CAAQ,UAAC,IAAD,EAAO,IAAP,EAAgB;AAC/C,SAAO,IAAI,IAAJ,EAAU,IAAV,MAAoB,SAApB;AACL,WAAO,OAAO,IAAP,EAAa,IAAb,CAAP;GADF,OAEO,IAAP,CAH+C;CAAhB,CAApB;;AAMN,IAAM,sBAAO,EAAE,IAAF;AACb,IAAM,0BAAS,EAAE,KAAF,CAAQ,UAAC,CAAD,EAAI,GAAJ,EAAS,CAAT;SAAe,EAAE,IAAF,CAAO,QAAQ,CAAR,CAAP,EAAmB,GAAnB,EAAwB,CAAxB;CAAf,CAAjB;AACN,IAAM,oBAAM,EAAE,KAAF,CAAQ,UAAC,CAAD,EAAI,CAAJ,EAAO,CAAP;SAAa,EAAE,GAAF,CAAM,QAAQ,CAAR,CAAN,EAAkB,CAAlB,EAAqB,CAArB;CAAb,CAAd;AACN,IAAM,oBAAM,EAAE,KAAF,CAAQ,UAAC,CAAD,EAAI,CAAJ;SAAU,EAAE,IAAF,CAAO,QAAQ,CAAR,CAAP,EAAmB,CAAnB;CAAV,CAAd;;AAEN,IAAM,0BAAS,SAAT,MAAS;SAAQ;WAAa,kBAAU;AACnD,UAAM,IAAI,QAAQ,KAAK,MAAL,CAAR,CAAJ,CAD6C;AAEnD,aAAO,EAAE,GAAF,CAAM;eAAS,EAAE,GAAF,CAAM,CAAN,EAAS,KAAT,EAAgB,MAAhB;OAAT,EAAkC,UAAU,EAAE,IAAF,CAAO,CAAP,EAAU,MAAV,CAAV,CAAxC,CAAP,CAFmD;KAAV;GAAb;CAAR;;AAKf,IAAM,4BAAU,KAAK,GAAL,EAAU,GAAV,CAAV;;AAEN,IAAM,0BACX,EAAE,KAAF,CAAQ,UAAC,CAAD,EAAI,CAAJ;SAAU,OAAO;WAAK,IAAI,CAAJ,EAAO,CAAP,MAAc,SAAd,GAA0B,CAA1B,GAA8B,CAA9B;GAAL;CAAjB,CADG;;AAGN,IAAM,0BAAS,SAAT,MAAS;qCAAI;;;;SAAO,OAAO,aAAK;AAC3C,QAAM,IAAI,GAAG,SAAH,CAAa;aAAK,IAAI,CAAJ,EAAO,CAAP,MAAc,SAAd;KAAL,CAAjB,CADqC;AAE3C,WAAO,KAAK,CAAL,GAAS,GAAG,CAAH,CAAT,GAAiB,OAAjB,CAFoC;GAAL;CAAlB;;AAKf,IAAM,4BAAU,EAAE,KAAF,CAAQ,UAAC,GAAD,EAAM,GAAN;SAC7B,KAAK;WAAK,EAAE,MAAF,CAAS,CAAT,EAAY,GAAZ,IAAmB,GAAnB,GAAyB,CAAzB;GAAL,EACA,WAAW;WAAK,EAAE,MAAF,CAAS,CAAT,EAAY,GAAZ,IAAmB,GAAnB,GAAyB,CAAzB;GAAL,CADhB;CAD6B,CAAlB;;AAIN,IAAM,8BAAW,QAAQ,SAAR,CAAX;AACN,IAAM,8BAAW,SAAX,QAAW;SAAO,QAAQ,GAAR,EAAa,SAAb;CAAP;AACjB,IAAM,0BAAS,SAAT,MAAS;SAAK,EAAE,OAAF,CAAU,SAAS,CAAT,CAAV,EAAuB,SAAS,CAAT,CAAvB;CAAL;;AAEf,IAAM,gCAAY,SAAZ,SAAY;SACvB,KAAK,UAAU,SAAV,CAAL,EAA2B,WAAW,UAAU,SAAV,CAAX,CAA3B;CADuB;;AAGzB,IAAM,SAAS,SAAT,MAAS;SAAK,OAAO,CAAP,KAAa,QAAb;CAAL;;AAER,IAAM,sBAAO,OAAO,UAAP,EAAmB,MAAnB,CAAP;;AAEb,IAAM,cAAc,SAAd,WAAc;SAClB,KAAK;WAAK,KAAK,EAAE,CAAF,CAAL;GAAL,EACA,UAAC,CAAD,EAAI,CAAJ;WAAU,MAAM,SAAN,GAAkB,UAAU,CAAV,EAAa,CAAb,CAAlB,GAAoC,OAAO,CAAP,EAAU,CAAV,EAAa,CAAb,CAApC;GAAV;CAFa;;AAIb,IAAM,sBAAO,SAAP,IAAO;SAAa,OAAO,cAAM;AAC5C,QAAI,OAAO,SAAP,EACF,OAAO,MAAP,CADF;AAEA,QAAM,IAAI,GAAG,SAAH,CAAa,SAAb,CAAJ,CAHsC;AAI5C,WAAO,IAAI,CAAJ,GAAQ,MAAR,GAAiB,CAAjB,CAJqC;GAAN;CAApB;;AAOb,IAAM,8BAAW,SAAX,QAAW,GAAW;AACjC,MAAM,MAAM,QAAQ,mCAAR,CAAN,CAD2B;AAEjC,SAAO,QAAQ,KAAK;WAAK,EAAE,IAAF,CAAO,GAAP,EAAY,CAAZ,MAAmB,SAAnB;GAAL,CAAb,EAAiD,GAAjD,CAAP,CAFiC;CAAX;;AAKxB,IAAM,UAAU,SAAV,OAAU;SAAK,OAAO,SAAP,CAAiB,CAAjB,KAAuB,KAAK,CAAL;CAA5B;;AAET,IAAM,wBAAQ,OAAO,wBAAP,EAAiC,OAAjC,CAAR;;AAEb,IAAM,eAAe,SAAf,YAAe;SAAK,KAAK;WAAM,MAAM,GAAG,CAAH,CAAN;GAAN,EAAmB,UAAC,CAAD,EAAI,EAAJ,EAAW;AAC3D,QAAI,MAAM,SAAN,EAAiB;AACnB,UAAI,OAAO,SAAP,EACF,OAAO,SAAP,CADF;AAEA,UAAI,IAAI,GAAG,MAAH,EACN,OAAO,QAAQ,GAAG,KAAH,CAAS,CAAT,EAAY,CAAZ,EAAe,MAAf,CAAsB,GAAG,KAAH,CAAS,IAAE,CAAF,CAA/B,CAAR,CAAP,CADF;AAEA,aAAO,EAAP,CALmB;KAArB,MAMO;AACL,UAAI,OAAO,SAAP,EACF,OAAO,MAAM,CAAN,EAAS,MAAT,CAAgB,CAAC,CAAD,CAAhB,CAAP,CADF;AAEA,UAAI,GAAG,MAAH,IAAa,CAAb,EACF,OAAO,GAAG,MAAH,CAAU,MAAM,IAAI,GAAG,MAAH,CAApB,EAAgC,CAAC,CAAD,CAAhC,CAAP,CADF;AAEA,UAAI,EAAE,MAAF,CAAS,CAAT,EAAY,GAAG,CAAH,CAAZ,CAAJ,EACE,OAAO,EAAP,CADF;AAEA,aAAO,GAAG,KAAH,CAAS,CAAT,EAAY,CAAZ,EAAe,MAAf,CAAsB,CAAC,CAAD,CAAtB,EAA2B,GAAG,KAAH,CAAS,IAAE,CAAF,CAApC,CAAP,CAPK;KANP;GADgD;CAA7B;;AAkBd,IAAM,0BAAS,KAAK,GAAL,EAAU,UAAC,CAAD,EAAI,EAAJ;SAC9B,MAAM,SAAN,GAAkB,EAAlB,GAAuB,OAAO,SAAP,GAAmB,CAAC,CAAD,CAAnB,GAAyB,GAAG,MAAH,CAAU,CAAC,CAAD,CAAV,CAAzB;CADO,CAAnB;;AAGN,IAAM,0BAAS,SAAT,MAAS;SAAK,KAAK;WAAM,MAAM,GAAG,MAAH,CAAU,CAAV,CAAN;GAAN,EAA0B,UAAC,EAAD,EAAK,EAAL;WACxD,SAAS,QAAQ,EAAE,MAAF,CAAS,MAAM,EAAN,EAAU,CAAC,MAAM,EAAN,CAAD,CAAW,MAAX,CAAkB,EAAE,UAAF,CAAa,CAAb,CAAlB,CAAnB,CAAR,CAAT,EAA0E,EAA1E;GADwD;CAApC;;AAGf,IAAM,4BAAU,SAAV,OAAU;SAAY,KACjC,UAAU,aAAK;AACb,QAAM,iBAAQ,EAAR,CADO;AAEb,SAAK,IAAM,CAAN,IAAW,QAAhB;AACE,QAAE,CAAF,IAAO,SAAS,CAAT,EAAY,CAAZ,CAAP;KADF,OAEO,CAAP,CAJa;GAAL,CADuB,EAOjC,WAAW,UAAC,CAAD,EAAI,CAAJ,EAAU;AACnB,QAAI,MAAM,SAAN,EACF,OAAO,SAAP,CADF;AAEA,QAAI,UAAJ,CAHmB;AAInB,QAAM,MAAM,SAAN,GAAM,CAAC,CAAD,EAAI,CAAJ,EAAU;AACpB,UAAI,cAAc,CAAd,EACF,IAAI,EAAJ,CADF;AAEA,QAAE,CAAF,IAAO,CAAP,CAHoB;KAAV,CAJO;AASnB,SAAK,IAAM,CAAN,IAAW,CAAhB,EAAmB;AACjB,UAAI,EAAE,KAAK,QAAL,CAAF,EACF,IAAI,CAAJ,EAAO,EAAE,CAAF,CAAP,EADF,KAGE,IAAI,KAAK,CAAL,EACF,IAAI,CAAJ,EAAO,EAAE,CAAF,CAAP,EADF;KAJJ;AAOA,WAAO,CAAP,CAhBmB;GAAV,CAPsB;CAAZ;;AA0BhB,IAAM,sBAAO,SAAP,IAAO;SAAY,KAC9B,aAAK;AACH,QAAI,UAAJ,CADG;AAEH,SAAK,IAAM,CAAN,IAAW,QAAhB,EAA0B;AACxB,UAAM,IAAI,IAAI,SAAS,CAAT,CAAJ,EAAiB,CAAjB,CAAJ,CADkB;AAExB,UAAI,MAAM,SAAN,EAAiB;AACnB,YAAI,MAAM,SAAN,EACF,IAAI,EAAJ,CADF;AAEA,UAAE,CAAF,IAAO,CAAP,CAHmB;OAArB;KAFF;AAQA,WAAO,CAAP,CAVG;GAAL,EAYA,YAAoB;QAAnB,0DAAI,qBAAe;QAAR,mBAAQ;;AAClB,QAAI,IAAI,GAAJ,CADc;AAElB,SAAK,IAAM,CAAN,IAAW,QAAhB;AACE,UAAI,IAAI,SAAS,CAAT,CAAJ,EAAiB,EAAE,CAAF,CAAjB,EAAuB,CAAvB,CAAJ;KADF,OAEO,CAAP,CAJkB;GAApB;CAbkB;;AAoBb,IAAM,8BAAW,KAAK,EAAL,EAAS,QAAT,CAAX;;AAEN,IAAM,wBAAQ,SAAR,KAAQ;qCAAI;;;;SAAO,KAAK,EAAE,MAAF,CAAS,EAAT,EAAa,EAAb,CAAL;CAAX;;kBAEN","file":"partial.lenses.js","sourcesContent":["import * as R from \"ramda\"\n\n//\n\nconst id = x => x\nconst snd = (_, c) => c\n\n//\n\nconst check = (expected, predicate) => x => {\n  if (predicate(x))\n    return x\n  else\n    throw new Error(`Expected ${expected}, but got ${x}.`)\n}\n\nconst assert = process.env.NODE_ENV === \"production\" ? () => id : check\n\n//\n\nconst empty = {}\n\nconst deleteKey = (k, o) => {\n  if (o === undefined || !(k in o))\n    return o\n  let r\n  for (const p in o) {\n    if (p !== k) {\n      if (undefined === r)\n        r = {}\n      r[p] = o[p]\n    }\n  }\n  return r\n}\n\nconst setKey = (k, v, o) => {\n  if (o === undefined)\n    return {[k]: v}\n  if (k in o && R.equals(v, o[k]))\n    return o\n  const r = {[k]: v}\n  for (const p in o)\n    if (p !== k)\n      r[p] = o[p]\n  return r\n}\n\n//\n\nconst dropped = xs => Object.keys(xs).length === 0 ? undefined : xs\n\n//\n\nconst toPartial = transform => x => undefined === x ? x : transform(x)\n\n//\n\nconst conserve = (c1, c0) => R.equals(c1, c0) ? c0 : c1\n\nconst toConserve = f => (y, c0) => conserve(f(y, c0), c0)\n\n//\n\nconst seemsLens = x => typeof x === \"function\" && x.length === 1\n\nexport const fromRamda = assert(\"a lens\", seemsLens)\n\nexport const toRamda = l => {\n  if (isProp(l))  return toRamdaProp(l)\n  if (isIndex(l)) return toRamdaIndex(l)\n  return fromRamda(l)\n}\n\nexport const compose = (...ls) =>\n  ls.length === 0 ? identity :\n  ls.length === 1 ? ls[0] :\n  R.compose(...ls.map(toRamda))\n\nexport const remove = R.curry((l, s) => R.set(toRamda(l), undefined, s))\n\nexport const removeAll = R.curry((lens, data) => {\n  while (get(lens, data) !== undefined)\n    data = remove(lens, data)\n  return data\n})\n\nexport const lens = R.lens\nexport const modify = R.curry((l, x2x, s) => R.over(toRamda(l), x2x, s))\nexport const set = R.curry((l, x, s) => R.set(toRamda(l), x, s))\nexport const get = R.curry((l, s) => R.view(toRamda(l), s))\n\nexport const choose = x2yL => toFunctor => target => {\n  const l = toRamda(x2yL(target))\n  return R.map(focus => R.set(l, focus, target), toFunctor(R.view(l, target)))\n}\n\nexport const nothing = lens(snd, snd)\n\nexport const orElse =\n  R.curry((d, l) => choose(x => get(l, x) !== undefined ? l : d))\n\nexport const choice = (...ls) => choose(x => {\n  const i = ls.findIndex(l => get(l, x) !== undefined)\n  return 0 <= i ? ls[i] : nothing\n})\n\nexport const replace = R.curry((inn, out) =>\n  lens(x => R.equals(x, inn) ? out : x,\n       toConserve(y => R.equals(y, out) ? inn : y)))\n\nexport const defaults = replace(undefined)\nexport const required = inn => replace(inn, undefined)\nexport const define = v => R.compose(required(v), defaults(v))\n\nexport const normalize = transform =>\n  lens(toPartial(transform), toConserve(toPartial(transform)))\n\nconst isProp = x => typeof x === \"string\"\n\nexport const prop = assert(\"a string\", isProp)\n\nconst toRamdaProp = k =>\n  lens(o => o && o[k],\n       (v, o) => v === undefined ? deleteKey(k, o) : setKey(k, v, o))\n\nexport const find = predicate => choose(xs => {\n  if (xs === undefined)\n    return append\n  const i = xs.findIndex(predicate)\n  return i < 0 ? append : i\n})\n\nexport const findWith = (...ls) => {\n  const lls = toRamda(compose(...ls))\n  return compose(find(x => R.view(lls, x) !== undefined), lls)\n}\n\nconst isIndex = x => Number.isInteger(x) && 0 <= x\n\nexport const index = assert(\"a non-negative integer\", isIndex)\n\nconst toRamdaIndex = i => lens(xs => xs && xs[i], (x, xs) => {\n  if (x === undefined) {\n    if (xs === undefined)\n      return undefined\n    if (i < xs.length)\n      return dropped(xs.slice(0, i).concat(xs.slice(i+1)))\n    return xs\n  } else {\n    if (xs === undefined)\n      return Array(i).concat([x])\n    if (xs.length <= i)\n      return xs.concat(Array(i - xs.length), [x])\n    if (R.equals(x, xs[i]))\n      return xs\n    return xs.slice(0, i).concat([x], xs.slice(i+1))\n  }\n})\n\nexport const append = lens(snd, (x, xs) =>\n  x === undefined ? xs : xs === undefined ? [x] : xs.concat([x]))\n\nexport const filter = p => lens(xs => xs && xs.filter(p), (ys, xs) =>\n  conserve(dropped(R.concat(ys || [], (xs || []).filter(R.complement(p)))), xs))\n\nexport const augment = template => lens(\n  toPartial(x => {\n    const z = {...x}\n    for (const k in template)\n      z[k] = template[k](x)\n    return z\n  }),\n  toConserve((y, c) => {\n    if (y === undefined)\n      return undefined\n    let z\n    const set = (k, v) => {\n      if (undefined === z)\n        z = {}\n      z[k] = v\n    }\n    for (const k in y) {\n      if (!(k in template))\n        set(k, y[k])\n      else\n        if (k in c)\n          set(k, c[k])\n    }\n    return z\n  }))\n\nexport const pick = template => lens(\n  c => {\n    let r\n    for (const k in template) {\n      const v = get(template[k], c)\n      if (v !== undefined) {\n        if (r === undefined)\n          r = {}\n        r[k] = v\n      }\n    }\n    return r\n  },\n  (o = empty, cIn) => {\n    let c = cIn\n    for (const k in template)\n      c = set(template[k], o[k], c)\n    return c\n  })\n\nexport const identity = lens(id, conserve)\n\nexport const props = (...ks) => pick(R.zipObj(ks, ks))\n\nexport default compose\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/partial.lenses.js"],"names":[],"mappings":"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","file":"partial.lenses.js","sourcesContent":["import * as R from \"ramda\"\n\n//\n\nconst id = x => x\nconst snd = (_, c) => c\n\n//\n\nconst check = (expected, predicate) => x => {\n  if (predicate(x))\n    return x\n  else\n    throw new Error(`Expected ${expected}, but got ${x}.`)\n}\n\nconst assert = process.env.NODE_ENV === \"production\" ? () => id : check\n\n//\n\nconst empty = {}\n\nconst deleteKey = (k, o) => {\n  if (o === undefined || !(k in o))\n    return o\n  let r\n  for (const p in o) {\n    if (p !== k) {\n      if (undefined === r)\n        r = {}\n      r[p] = o[p]\n    }\n  }\n  return r\n}\n\nconst setKey = (k, v, o) => {\n  if (o === undefined)\n    return {[k]: v}\n  if (k in o && R.equals(v, o[k]))\n    return o\n  const r = {[k]: v}\n  for (const p in o)\n    if (p !== k)\n      r[p] = o[p]\n  return r\n}\n\n//\n\nconst dropped = xs => Object.keys(xs).length === 0 ? undefined : xs\n\n//\n\nconst toPartial = transform => x => undefined === x ? x : transform(x)\n\n//\n\nconst conserve = (c1, c0) => R.equals(c1, c0) ? c0 : c1\n\nconst toConserve = f => (y, c0) => conserve(f(y, c0), c0)\n\n//\n\nconst seemsLens = x => typeof x === \"function\" && x.length === 1\n\nexport const fromRamda = assert(\"a lens\", seemsLens)\n\nexport const toRamda = l => {\n  if (isProp(l))  return toRamdaProp(l)\n  if (isIndex(l)) return toRamdaIndex(l)\n  return fromRamda(l)\n}\n\nexport const compose = (...ls) =>\n  ls.length === 0 ? identity :\n  ls.length === 1 ? ls[0] :\n  R.compose(...ls.map(toRamda))\n\nexport const remove = R.curry((l, s) => R.set(toRamda(l), undefined, s))\n\nexport const removeAll = R.curry((lens, data) => {\n  while (get(lens, data) !== undefined)\n    data = remove(lens, data)\n  return data\n})\n\nexport const lens = R.lens\nexport const modify = R.curry((l, x2x, s) => R.over(toRamda(l), x2x, s))\nexport const set = R.curry((l, x, s) => R.set(toRamda(l), x, s))\nexport const get = R.curry((l, s) => R.view(toRamda(l), s))\n\nexport const chain = R.curry((x2yL, xL) =>\n  compose(xL, choose(xO => xO === undefined ? nothing : x2yL(xO))))\n\nexport const just = x => lens(R.always(x), snd)\n\nexport const choose = x2yL => toFunctor => target => {\n  const l = toRamda(x2yL(target))\n  return R.map(focus => R.set(l, focus, target), toFunctor(R.view(l, target)))\n}\n\nexport const nothing = lens(snd, snd)\n\nexport const orElse =\n  R.curry((d, l) => choose(x => get(l, x) !== undefined ? l : d))\n\nexport const choice = (...ls) => choose(x => {\n  const i = ls.findIndex(l => get(l, x) !== undefined)\n  return 0 <= i ? ls[i] : nothing\n})\n\nexport const replace = R.curry((inn, out) =>\n  lens(x => R.equals(x, inn) ? out : x,\n       toConserve(y => R.equals(y, out) ? inn : y)))\n\nexport const defaults = replace(undefined)\nexport const required = inn => replace(inn, undefined)\nexport const define = v => R.compose(required(v), defaults(v))\n\nexport const normalize = transform =>\n  lens(toPartial(transform), toConserve(toPartial(transform)))\n\nconst isProp = x => typeof x === \"string\"\n\nexport const prop = assert(\"a string\", isProp)\n\nconst toRamdaProp = k =>\n  lens(o => o && o[k],\n       (v, o) => v === undefined ? deleteKey(k, o) : setKey(k, v, o))\n\nexport const find = predicate => choose(xs => {\n  if (xs === undefined)\n    return append\n  const i = xs.findIndex(predicate)\n  return i < 0 ? append : i\n})\n\nexport const findWith = (...ls) => {\n  const lls = toRamda(compose(...ls))\n  return compose(find(x => R.view(lls, x) !== undefined), lls)\n}\n\nconst isIndex = x => Number.isInteger(x) && 0 <= x\n\nexport const index = assert(\"a non-negative integer\", isIndex)\n\nconst toRamdaIndex = i => lens(xs => xs && xs[i], (x, xs) => {\n  if (x === undefined) {\n    if (xs === undefined)\n      return undefined\n    if (i < xs.length)\n      return dropped(xs.slice(0, i).concat(xs.slice(i+1)))\n    return xs\n  } else {\n    if (xs === undefined)\n      return Array(i).concat([x])\n    if (xs.length <= i)\n      return xs.concat(Array(i - xs.length), [x])\n    if (R.equals(x, xs[i]))\n      return xs\n    return xs.slice(0, i).concat([x], xs.slice(i+1))\n  }\n})\n\nexport const append = lens(snd, (x, xs) =>\n  x === undefined ? xs : xs === undefined ? [x] : xs.concat([x]))\n\nexport const filter = p => lens(xs => xs && xs.filter(p), (ys, xs) =>\n  conserve(dropped(R.concat(ys || [], (xs || []).filter(R.complement(p)))), xs))\n\nexport const augment = template => lens(\n  toPartial(x => {\n    const z = {...x}\n    for (const k in template)\n      z[k] = template[k](x)\n    return z\n  }),\n  toConserve((y, c) => {\n    if (y === undefined)\n      return undefined\n    let z\n    const set = (k, v) => {\n      if (undefined === z)\n        z = {}\n      z[k] = v\n    }\n    for (const k in y) {\n      if (!(k in template))\n        set(k, y[k])\n      else\n        if (k in c)\n          set(k, c[k])\n    }\n    return z\n  }))\n\nexport const pick = template => lens(\n  c => {\n    let r\n    for (const k in template) {\n      const v = get(template[k], c)\n      if (v !== undefined) {\n        if (r === undefined)\n          r = {}\n        r[k] = v\n      }\n    }\n    return r\n  },\n  (o = empty, cIn) => {\n    let c = cIn\n    for (const k in template)\n      c = set(template[k], o[k], c)\n    return c\n  })\n\nexport const identity = lens(id, conserve)\n\nexport const props = (...ks) => pick(R.zipObj(ks, ks))\n\nexport default compose\n"]} |
{ | ||
"name": "partial.lenses", | ||
"version": "3.0.0", | ||
"version": "3.1.0", | ||
"description": "Partial lenses", | ||
@@ -5,0 +5,0 @@ "main": "lib/partial.lenses.js", |
@@ -416,6 +416,6 @@ [ [Tutorial](#tutorial) | [Reference](#reference) | [Background](#background) ] | ||
`L.append` is a special lens that operates on arrays. The view of `L.append` is | ||
always undefined. Setting `L.append` to undefined has no effect by itself. | ||
Setting `L.append` to a defined value appends the value to the end of the | ||
focused array. | ||
`L.append` is a special semi-degenerate lens that operates on arrays. The view | ||
of `L.append` is always undefined. Setting `L.append` to undefined has no | ||
effect by itself. Setting `L.append` to a defined value appends the value to | ||
the end of the focused array. | ||
@@ -444,2 +444,18 @@ For example: | ||
#### [`L.chain(a2bPLens, aPLens)`](#lchaina2bplens-aplens "L.chain :: (a -> PLens s b) -> PLens s a -> PLens s b") | ||
`L.chain(a2bPLens, aPLens)` is equivalent to | ||
```js | ||
L.compose(aPLens, L.choose(aMaybe => | ||
aMaybe === undefined | ||
? L.nothing | ||
: a2bPLens(aMaybe))) | ||
``` | ||
With the `just`, `chain`, `choice` and `nothing` combinators, one can view | ||
partial lenses as subsuming the maybe monad. Of course, the whole point of | ||
lenses is that they are bidirectional and the special lenses `just` and | ||
`nothing` are essentially degenerate. | ||
#### [`L.choose(maybeValue => PLens)`](#lchoosemaybevalue--plens "L.choose :: (Maybe s -> PLens s a) -> PLens s a") | ||
@@ -450,4 +466,3 @@ | ||
lens. In other words, the `L.choose` combinator allows a lens to be constructed | ||
*after* examining the data structure being manipulated. The lens returned by | ||
the function given to `L.choose` will be lifted. | ||
*after* examining the data structure being manipulated. | ||
@@ -475,4 +490,4 @@ For example, given: | ||
`L.choice(...ls)` returns a partial lens that acts like the first of the given | ||
lenses, `...ls`, whose view is not undefined on the given target. When the | ||
views of all of the given lenses are undefined, the returned lens acts like | ||
lenses, `ls`, whose view is not undefined on the given target. When the views | ||
of all of the given lenses are undefined, the returned lens acts like | ||
`L.nothing`, which is the identity element of `L.choice`. | ||
@@ -620,2 +635,15 @@ | ||
#### [`L.just(value)`](#ljustvalue "L.just :: a -> PLens s a") | ||
`L.just(x)` is equivalent to `L.compose(L.nothing, L.defaults(x))` and is a | ||
special degenerate lens whose view is always `x` and writing through the lens | ||
has no effect. In other words, for all `x`, `y` and `z`: | ||
```js | ||
L.get(L.just(z), x) = z | ||
L.set(L.just(z), y, x) = x | ||
``` | ||
`L.just` can be seen as the unit function of the monad formed with `L.chain`. | ||
#### [`L.lens(get, set)`](#llensget-set "L.lens :: (Maybe s -> Maybe a) -> (Maybe a -> Maybe s -> Maybe s) -> PLens s a") | ||
@@ -675,4 +703,4 @@ | ||
`L.nothing` is a special lens whose view is always undefined and setting through | ||
`L.nothing` has no effect. In other words, for all `x` and `y`: | ||
`L.nothing` is a special degenerate lens whose view is always undefined and | ||
setting through `L.nothing` has no effect. In other words, for all `x` and `y`: | ||
@@ -679,0 +707,0 @@ ```js |
@@ -93,2 +93,7 @@ import * as R from "ramda" | ||
export const chain = R.curry((x2yL, xL) => | ||
compose(xL, choose(xO => xO === undefined ? nothing : x2yL(xO)))) | ||
export const just = x => lens(R.always(x), snd) | ||
export const choose = x2yL => toFunctor => target => { | ||
@@ -95,0 +100,0 @@ const l = toRamda(x2yL(target)) |
@@ -154,2 +154,14 @@ import * as R from "ramda" | ||
describe("L.just", () => { | ||
testEq('L.get(L.just("always"), "anything")', "always") | ||
testEq('L.set(L.just("always"), "anything", "original")', "original") | ||
}) | ||
describe("L.chain", () => { | ||
testEq('L.get(L.chain(elems => elems instanceof Array ? 0 : L.identity, "elems"), {elems: ["x"]})', "x") | ||
testEq('L.set(L.chain(elems => elems instanceof Array ? 0 : L.identity, "elems"), "y", {elems: ["x"]})', {elems: ["y"]}) | ||
testEq('L.get(L.chain(elems => elems instanceof Array ? 0 : L.identity, "elems"), {notit: true})', undefined) | ||
testEq('L.set(L.chain(elems => elems instanceof Array ? 0 : L.identity, "elems"), false, {notit: true})', {notit: true}) | ||
}) | ||
describe("L.orElse", () => { | ||
@@ -156,0 +168,0 @@ testEq('L.get(L.orElse("b", "a"), {a: 2, b: 1})', 2) |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
892
131749
14
693