Skip to content

Commit

Permalink
refactor: makeTrapsForGetters function
Browse files Browse the repository at this point in the history
  • Loading branch information
aleclarson committed Apr 23, 2019
1 parent 4164f0d commit c90cd57
Showing 1 changed file with 25 additions and 33 deletions.
58 changes: 25 additions & 33 deletions src/proxy.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@ import {
} from "./common"
import {ImmerScope} from "./scope"

const reflectTraps = makeReflectTraps()

// Do nothing before being finalized.
export function willFinalize() {}

Expand Down Expand Up @@ -181,7 +183,7 @@ arrayTraps.set = function(state, prop, value) {
* Map drafts
*/

const mapGetters = {
const mapTraps = makeTrapsForGetters({
[DRAFT_STATE]: state => state,
size: state => source(state).size,
has(state, prop) {
Expand Down Expand Up @@ -244,8 +246,7 @@ const mapGetters = {
values: iterateMapValues,
entries: iterateMapValues,
[Symbol.iterator]: iterateMapValues
}
const mapTraps = makeTrapsForGetters(mapGetters)
})

/** Map.prototype.values _-or-_ Map.prototype.entries */
function iterateMapValues(state, prop, receiver) {
Expand All @@ -270,7 +271,7 @@ function iterateMapValues(state, prop, receiver) {
* Set drafts
*/

const setGetters = {
const setTraps = makeTrapsForGetters({
[DRAFT_STATE]: state => state,
size: state => source(state).size,
has(state, prop) {
Expand Down Expand Up @@ -304,8 +305,7 @@ const setGetters = {
values: iterateSetValues,
entries: iterateSetValues,
[Symbol.iterator]: iterateSetValues
}
const setTraps = makeTrapsForGetters(setGetters)
})

function iterateSetValues(state, prop) {
return () => {
Expand Down Expand Up @@ -393,40 +393,32 @@ function makeIterable(next) {
})
}

/** Create traps that all use the `Reflect` API on the `source(state)` */
function makeReflectTraps() {
return [
"ownKeys",
"has",
"set",
"deleteProperty",
"defineProperty",
"getOwnPropertyDescriptor",
"preventExtensions",
"isExtensible",
"getPrototypeOf"
].reduce((traps, name) => {
traps[name] = (state, ...args) => Reflect[name](source(state), ...args)
return traps
}, {})
}

function makeTrapsForGetters(getters) {
return {
...reflectTraps,
get(state, prop, receiver) {
return getters.hasOwnProperty(prop)
? getters[prop](state, prop, receiver)
: Reflect.get(state, prop, receiver)
},
ownKeys(state) {
return Reflect.ownKeys(source(state))
},
set(state, ...args) {
return Reflect.set(source(state), ...args)
},
has(state, ...args) {
return Reflect.has(source(state), ...args)
},
deleteProperty(state, ...args) {
return Reflect.deleteProperty(source(state), ...args)
},
defineProperty(state, ...args) {
return Reflect.defineProperty(source(state), ...args)
},
getOwnPropertyDescriptor(state, ...args) {
return Reflect.getOwnPropertyDescriptor(source(state), ...args)
},
preventExtensions(state) {
return Reflect.preventExtensions(source(state))
},
isExtensible(state) {
return Reflect.isExtensible(source(state))
},
getPrototypeOf(state) {
return Reflect.getPrototypeOf(source(state))
},
setPrototypeOf(state) {
throw new Error("Object.setPrototypeOf() cannot be used on an Immer draft") // prettier-ignore
}
Expand Down

0 comments on commit c90cd57

Please sign in to comment.