Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@glimmer/reference

Package Overview
Dependencies
Maintainers
12
Versions
286
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@glimmer/reference - npm Package Compare versions

Comparing version 0.76.0 to 0.77.0

6

dist/amd/es5/glimmer-reference.js

@@ -266,3 +266,3 @@ define('@glimmer/reference', ['exports', '@glimmer/env', '@glimmer/global-context', '@glimmer/util', '@glimmer/validator'], function (exports, env, globalContext, util, validator) { 'use strict';

_proto.set = function set(key, value) {
if (util.isObject(key) || typeof key === 'function') {
if (util.isObject(key)) {
this.weakMap.set(key, value);

@@ -275,3 +275,3 @@ } else {

_proto.get = function get(key) {
if (util.isObject(key) || typeof key === 'function') {
if (util.isObject(key)) {
return this.weakMap.get(key);

@@ -495,2 +495,2 @@ } else {

});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"glimmer-reference.js","sources":["../../../../../../packages/@glimmer/reference/lib/reference.ts","../../../../../../packages/@glimmer/reference/lib/iterable.ts"],"sourcesContent":["import { DEBUG } from '@glimmer/env';\nimport { getProp, setProp } from '@glimmer/global-context';\nimport { Option } from '@glimmer/interfaces';\nimport { expect, isDict, symbol } from '@glimmer/util';\nimport {\n  CONSTANT_TAG,\n  consumeTag,\n  INITIAL,\n  Revision,\n  Tag,\n  track,\n  validateTag,\n  valueForTag,\n} from '@glimmer/validator';\n\nexport const REFERENCE: unique symbol = symbol('REFERENCE');\n\nconst enum ReferenceType {\n  Constant,\n  Compute,\n  Unbound,\n  Invokable,\n}\n\nexport interface Reference<_T = unknown> {\n  [REFERENCE]: ReferenceType;\n  debugLabel?: string;\n}\n\nexport default Reference;\n\n//////////\n\nexport interface ReferenceEnvironment {\n  getProp(obj: unknown, path: string): unknown;\n  setProp(obj: unknown, path: string, value: unknown): unknown;\n}\n\nclass ReferenceImpl<T = unknown> implements Reference {\n  [REFERENCE]: ReferenceType;\n  public tag: Option<Tag> = null;\n  public lastRevision: Revision = INITIAL;\n  public lastValue?: T;\n\n  public children: Option<Map<string | Reference, Reference>> = null;\n\n  public compute: Option<() => T> = null;\n  public update: Option<(val: T) => void> = null;\n\n  public debugLabel?: string;\n\n  constructor(type: ReferenceType) {\n    this[REFERENCE] = type;\n  }\n}\n\nexport function createPrimitiveRef(value: unknown): Reference {\n  let ref = new ReferenceImpl(ReferenceType.Unbound);\n\n  ref.tag = CONSTANT_TAG;\n  ref.lastValue = value;\n\n  if (DEBUG) {\n    ref.debugLabel = String(value);\n  }\n\n  return ref;\n}\n\nexport const UNDEFINED_REFERENCE = createPrimitiveRef(undefined);\nexport const NULL_REFERENCE = createPrimitiveRef(null);\nexport const TRUE_REFERENCE = createPrimitiveRef(true);\nexport const FALSE_REFERENCE = createPrimitiveRef(false);\n\nexport function createConstRef(value: unknown, debugLabel: false | string): Reference {\n  let ref = new ReferenceImpl(ReferenceType.Constant);\n\n  ref.lastValue = value;\n  ref.tag = CONSTANT_TAG;\n\n  if (DEBUG) {\n    ref.debugLabel = debugLabel as string;\n  }\n\n  return ref;\n}\n\nexport function createUnboundRef(value: unknown, debugLabel: false | string): Reference {\n  let ref = new ReferenceImpl(ReferenceType.Unbound);\n\n  ref.lastValue = value;\n  ref.tag = CONSTANT_TAG;\n\n  if (DEBUG) {\n    ref.debugLabel = debugLabel as string;\n  }\n\n  return ref;\n}\n\nexport function createComputeRef<T = unknown>(\n  compute: () => T,\n  update: Option<(value: T) => void> = null,\n  debugLabel: false | string = 'unknown'\n): Reference<T> {\n  let ref = new ReferenceImpl<T>(ReferenceType.Compute);\n\n  ref.compute = compute;\n  ref.update = update;\n\n  if (DEBUG) {\n    ref.debugLabel = `(result of a \\`${debugLabel}\\` helper)`;\n  }\n\n  return ref;\n}\n\nexport function createReadOnlyRef(ref: Reference): Reference {\n  if (!isUpdatableRef(ref)) return ref;\n\n  return createComputeRef(() => valueForRef(ref), null, ref.debugLabel);\n}\n\nexport function isInvokableRef(ref: Reference) {\n  return ref[REFERENCE] === ReferenceType.Invokable;\n}\n\nexport function createInvokableRef(inner: Reference): Reference {\n  let ref = createComputeRef(\n    () => valueForRef(inner),\n    (value) => updateRef(inner, value)\n  );\n  ref.debugLabel = inner.debugLabel;\n  ref[REFERENCE] = ReferenceType.Invokable;\n\n  return ref;\n}\n\nexport function isConstRef(_ref: Reference) {\n  let ref = _ref as ReferenceImpl;\n\n  return ref.tag === CONSTANT_TAG;\n}\n\nexport function isUpdatableRef(_ref: Reference) {\n  let ref = _ref as ReferenceImpl;\n\n  return ref.update !== null;\n}\n\nexport function valueForRef<T>(_ref: Reference<T>): T {\n  let ref = _ref as ReferenceImpl<T>;\n\n  let { tag } = ref;\n\n  if (tag === CONSTANT_TAG) {\n    return ref.lastValue as T;\n  }\n\n  let { lastRevision } = ref;\n  let lastValue;\n\n  if (tag === null || !validateTag(tag, lastRevision)) {\n    let { compute } = ref;\n\n    tag = ref.tag = track(() => {\n      lastValue = ref.lastValue = compute!();\n    }, DEBUG && ref.debugLabel);\n\n    ref.lastRevision = valueForTag(tag);\n  } else {\n    lastValue = ref.lastValue;\n  }\n\n  consumeTag(tag);\n\n  return lastValue as T;\n}\n\nexport function updateRef(_ref: Reference, value: unknown) {\n  let ref = _ref as ReferenceImpl;\n\n  let update = expect(ref.update, 'called update on a non-updatable reference');\n\n  update(value);\n}\n\nexport function childRefFor(_parentRef: Reference, path: string): Reference {\n  let parentRef = _parentRef as ReferenceImpl;\n\n  let type = parentRef[REFERENCE];\n\n  let children = parentRef.children;\n  let child: Reference;\n\n  if (children === null) {\n    children = parentRef.children = new Map();\n  } else {\n    child = children.get(path)!;\n\n    if (child !== undefined) {\n      return child;\n    }\n  }\n\n  if (type === ReferenceType.Unbound) {\n    let parent = valueForRef(parentRef);\n\n    if (isDict(parent)) {\n      child = createUnboundRef(\n        (parent as Record<string, unknown>)[path],\n        DEBUG && `${parentRef.debugLabel}.${path}`\n      );\n    } else {\n      child = UNDEFINED_REFERENCE;\n    }\n  } else {\n    child = createComputeRef(\n      () => {\n        let parent = valueForRef(parentRef);\n\n        if (isDict(parent)) {\n          return getProp(parent, path);\n        }\n      },\n      (val) => {\n        let parent = valueForRef(parentRef);\n\n        if (isDict(parent)) {\n          return setProp(parent, path, val);\n        }\n      }\n    );\n\n    if (DEBUG) {\n      child.debugLabel = `${parentRef.debugLabel}.${path}`;\n    }\n  }\n\n  children.set(path, child);\n\n  return child;\n}\n\nexport function childRefFromParts(root: Reference, parts: string[]): Reference {\n  let reference = root;\n\n  for (let i = 0; i < parts.length; i++) {\n    reference = childRefFor(reference, parts[i]);\n  }\n\n  return reference;\n}\n\nexport let createDebugAliasRef: undefined | ((debugLabel: string, inner: Reference) => Reference);\n\nif (DEBUG) {\n  createDebugAliasRef = (debugLabel: string, inner: Reference) => {\n    let update = isUpdatableRef(inner) ? (value: unknown) => updateRef(inner, value) : null;\n    let ref = createComputeRef(() => valueForRef(inner), update);\n\n    ref[REFERENCE] = inner[REFERENCE];\n\n    ref.debugLabel = debugLabel;\n\n    return ref;\n  };\n}\n","import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key) || typeof key === 'function') {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key) || typeof key === 'function') {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"names":["symbol","INITIAL","CONSTANT_TAG","DEBUG","validateTag","track","valueForTag","consumeTag","isDict","getProp","setProp","createDebugAliasRef","getPath","isObject","toIterator","EMPTY_ARRAY","createTag","dirtyTag"],"mappings":"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"}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"glimmer-reference.js","sources":["../../../../../../packages/@glimmer/reference/lib/reference.ts","../../../../../../packages/@glimmer/reference/lib/iterable.ts"],"sourcesContent":["import { DEBUG } from '@glimmer/env';\nimport { getProp, setProp } from '@glimmer/global-context';\nimport { Option } from '@glimmer/interfaces';\nimport { expect, isDict, symbol } from '@glimmer/util';\nimport {\n  CONSTANT_TAG,\n  consumeTag,\n  INITIAL,\n  Revision,\n  Tag,\n  track,\n  validateTag,\n  valueForTag,\n} from '@glimmer/validator';\n\nexport const REFERENCE: unique symbol = symbol('REFERENCE');\n\nconst enum ReferenceType {\n  Constant,\n  Compute,\n  Unbound,\n  Invokable,\n}\n\nexport interface Reference<_T = unknown> {\n  [REFERENCE]: ReferenceType;\n  debugLabel?: string;\n}\n\nexport default Reference;\n\n//////////\n\nexport interface ReferenceEnvironment {\n  getProp(obj: unknown, path: string): unknown;\n  setProp(obj: unknown, path: string, value: unknown): unknown;\n}\n\nclass ReferenceImpl<T = unknown> implements Reference {\n  [REFERENCE]: ReferenceType;\n  public tag: Option<Tag> = null;\n  public lastRevision: Revision = INITIAL;\n  public lastValue?: T;\n\n  public children: Option<Map<string | Reference, Reference>> = null;\n\n  public compute: Option<() => T> = null;\n  public update: Option<(val: T) => void> = null;\n\n  public debugLabel?: string;\n\n  constructor(type: ReferenceType) {\n    this[REFERENCE] = type;\n  }\n}\n\nexport function createPrimitiveRef(value: unknown): Reference {\n  let ref = new ReferenceImpl(ReferenceType.Unbound);\n\n  ref.tag = CONSTANT_TAG;\n  ref.lastValue = value;\n\n  if (DEBUG) {\n    ref.debugLabel = String(value);\n  }\n\n  return ref;\n}\n\nexport const UNDEFINED_REFERENCE = createPrimitiveRef(undefined);\nexport const NULL_REFERENCE = createPrimitiveRef(null);\nexport const TRUE_REFERENCE = createPrimitiveRef(true);\nexport const FALSE_REFERENCE = createPrimitiveRef(false);\n\nexport function createConstRef(value: unknown, debugLabel: false | string): Reference {\n  let ref = new ReferenceImpl(ReferenceType.Constant);\n\n  ref.lastValue = value;\n  ref.tag = CONSTANT_TAG;\n\n  if (DEBUG) {\n    ref.debugLabel = debugLabel as string;\n  }\n\n  return ref;\n}\n\nexport function createUnboundRef(value: unknown, debugLabel: false | string): Reference {\n  let ref = new ReferenceImpl(ReferenceType.Unbound);\n\n  ref.lastValue = value;\n  ref.tag = CONSTANT_TAG;\n\n  if (DEBUG) {\n    ref.debugLabel = debugLabel as string;\n  }\n\n  return ref;\n}\n\nexport function createComputeRef<T = unknown>(\n  compute: () => T,\n  update: Option<(value: T) => void> = null,\n  debugLabel: false | string = 'unknown'\n): Reference<T> {\n  let ref = new ReferenceImpl<T>(ReferenceType.Compute);\n\n  ref.compute = compute;\n  ref.update = update;\n\n  if (DEBUG) {\n    ref.debugLabel = `(result of a \\`${debugLabel}\\` helper)`;\n  }\n\n  return ref;\n}\n\nexport function createReadOnlyRef(ref: Reference): Reference {\n  if (!isUpdatableRef(ref)) return ref;\n\n  return createComputeRef(() => valueForRef(ref), null, ref.debugLabel);\n}\n\nexport function isInvokableRef(ref: Reference) {\n  return ref[REFERENCE] === ReferenceType.Invokable;\n}\n\nexport function createInvokableRef(inner: Reference): Reference {\n  let ref = createComputeRef(\n    () => valueForRef(inner),\n    (value) => updateRef(inner, value)\n  );\n  ref.debugLabel = inner.debugLabel;\n  ref[REFERENCE] = ReferenceType.Invokable;\n\n  return ref;\n}\n\nexport function isConstRef(_ref: Reference) {\n  let ref = _ref as ReferenceImpl;\n\n  return ref.tag === CONSTANT_TAG;\n}\n\nexport function isUpdatableRef(_ref: Reference) {\n  let ref = _ref as ReferenceImpl;\n\n  return ref.update !== null;\n}\n\nexport function valueForRef<T>(_ref: Reference<T>): T {\n  let ref = _ref as ReferenceImpl<T>;\n\n  let { tag } = ref;\n\n  if (tag === CONSTANT_TAG) {\n    return ref.lastValue as T;\n  }\n\n  let { lastRevision } = ref;\n  let lastValue;\n\n  if (tag === null || !validateTag(tag, lastRevision)) {\n    let { compute } = ref;\n\n    tag = ref.tag = track(() => {\n      lastValue = ref.lastValue = compute!();\n    }, DEBUG && ref.debugLabel);\n\n    ref.lastRevision = valueForTag(tag);\n  } else {\n    lastValue = ref.lastValue;\n  }\n\n  consumeTag(tag);\n\n  return lastValue as T;\n}\n\nexport function updateRef(_ref: Reference, value: unknown) {\n  let ref = _ref as ReferenceImpl;\n\n  let update = expect(ref.update, 'called update on a non-updatable reference');\n\n  update(value);\n}\n\nexport function childRefFor(_parentRef: Reference, path: string): Reference {\n  let parentRef = _parentRef as ReferenceImpl;\n\n  let type = parentRef[REFERENCE];\n\n  let children = parentRef.children;\n  let child: Reference;\n\n  if (children === null) {\n    children = parentRef.children = new Map();\n  } else {\n    child = children.get(path)!;\n\n    if (child !== undefined) {\n      return child;\n    }\n  }\n\n  if (type === ReferenceType.Unbound) {\n    let parent = valueForRef(parentRef);\n\n    if (isDict(parent)) {\n      child = createUnboundRef(\n        (parent as Record<string, unknown>)[path],\n        DEBUG && `${parentRef.debugLabel}.${path}`\n      );\n    } else {\n      child = UNDEFINED_REFERENCE;\n    }\n  } else {\n    child = createComputeRef(\n      () => {\n        let parent = valueForRef(parentRef);\n\n        if (isDict(parent)) {\n          return getProp(parent, path);\n        }\n      },\n      (val) => {\n        let parent = valueForRef(parentRef);\n\n        if (isDict(parent)) {\n          return setProp(parent, path, val);\n        }\n      }\n    );\n\n    if (DEBUG) {\n      child.debugLabel = `${parentRef.debugLabel}.${path}`;\n    }\n  }\n\n  children.set(path, child);\n\n  return child;\n}\n\nexport function childRefFromParts(root: Reference, parts: string[]): Reference {\n  let reference = root;\n\n  for (let i = 0; i < parts.length; i++) {\n    reference = childRefFor(reference, parts[i]);\n  }\n\n  return reference;\n}\n\nexport let createDebugAliasRef: undefined | ((debugLabel: string, inner: Reference) => Reference);\n\nif (DEBUG) {\n  createDebugAliasRef = (debugLabel: string, inner: Reference) => {\n    let update = isUpdatableRef(inner) ? (value: unknown) => updateRef(inner, value) : null;\n    let ref = createComputeRef(() => valueForRef(inner), update);\n\n    ref[REFERENCE] = inner[REFERENCE];\n\n    ref.debugLabel = debugLabel;\n\n    return ref;\n  };\n}\n","import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key)) {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key)) {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"names":["symbol","INITIAL","CONSTANT_TAG","DEBUG","validateTag","track","valueForTag","consumeTag","isDict","getProp","setProp","createDebugAliasRef","getPath","isObject","toIterator","EMPTY_ARRAY","createTag","dirtyTag"],"mappings":"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"}

@@ -77,3 +77,3 @@ "use strict";

set(key, value) {
if ((0, _util.isObject)(key) || typeof key === 'function') {
if ((0, _util.isObject)(key)) {
this.weakMap.set(key, value);

@@ -86,3 +86,3 @@ } else {

get(key) {
if ((0, _util.isObject)(key) || typeof key === 'function') {
if ((0, _util.isObject)(key)) {
return this.weakMap.get(key);

@@ -255,2 +255,2 @@ } else {

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key) || typeof key === 'function') {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key) || typeof key === 'function') {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key)) {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key)) {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}

@@ -87,3 +87,3 @@ "use strict";

_proto.set = function set(key, value) {
if ((0, _util.isObject)(key) || typeof key === 'function') {
if ((0, _util.isObject)(key)) {
this.weakMap.set(key, value);

@@ -96,3 +96,3 @@ } else {

_proto.get = function get(key) {
if ((0, _util.isObject)(key) || typeof key === 'function') {
if ((0, _util.isObject)(key)) {
return this.weakMap.get(key);

@@ -292,2 +292,2 @@ } else {

}();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key) || typeof key === 'function') {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key) || typeof key === 'function') {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key)) {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key)) {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}

@@ -64,3 +64,3 @@ import { getPath, toIterator } from '@glimmer/global-context';

set(key, value) {
if (isObject(key) || typeof key === 'function') {
if (isObject(key)) {
this.weakMap.set(key, value);

@@ -73,3 +73,3 @@ } else {

get(key) {
if (isObject(key) || typeof key === 'function') {
if (isObject(key)) {
return this.weakMap.get(key);

@@ -241,2 +241,2 @@ } else {

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key) || typeof key === 'function') {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key) || typeof key === 'function') {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key)) {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key)) {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}

@@ -62,3 +62,3 @@ function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }

_proto.set = function set(key, value) {
if (isObject(key) || typeof key === 'function') {
if (isObject(key)) {
this.weakMap.set(key, value);

@@ -71,3 +71,3 @@ } else {

_proto.get = function get(key) {
if (isObject(key) || typeof key === 'function') {
if (isObject(key)) {
return this.weakMap.get(key);

@@ -266,2 +266,2 @@ } else {

}();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key) || typeof key === 'function') {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key) || typeof key === 'function') {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/reference/lib/iterable.ts"],"names":[],"mappings":"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","sourcesContent":["import { getPath, toIterator } from '@glimmer/global-context';\nimport { Option, Dict } from '@glimmer/interfaces';\nimport { EMPTY_ARRAY, isObject } from '@glimmer/util';\nimport { DEBUG } from '@glimmer/env';\nimport { createTag, consumeTag, dirtyTag } from '@glimmer/validator';\nimport { Reference, ReferenceEnvironment, valueForRef, createComputeRef } from './reference';\n\nexport interface IterationItem<T, U> {\n  key: unknown;\n  value: T;\n  memo: U;\n}\n\nexport interface AbstractIterator<T, U, V extends IterationItem<T, U>> {\n  isEmpty(): boolean;\n  next(): Option<V>;\n}\n\nexport type OpaqueIterationItem = IterationItem<unknown, unknown>;\nexport type OpaqueIterator = AbstractIterator<unknown, unknown, OpaqueIterationItem>;\n\nexport interface IteratorDelegate {\n  isEmpty(): boolean;\n  next(): { value: unknown; memo: unknown } | null;\n}\n\nexport interface IteratorReferenceEnvironment extends ReferenceEnvironment {\n  getPath(obj: unknown, path: string): unknown;\n  toIterator(obj: unknown): Option<IteratorDelegate>;\n}\n\ntype KeyFor = (item: unknown, index: unknown) => unknown;\n\nconst NULL_IDENTITY = {};\n\nconst KEY: KeyFor = (_, index) => index;\nconst INDEX: KeyFor = (_, index) => String(index);\nconst IDENTITY: KeyFor = (item) => {\n  if (item === null) {\n    // Returning null as an identity will cause failures since the iterator\n    // can't tell that it's actually supposed to be null\n    return NULL_IDENTITY;\n  }\n\n  return item;\n};\n\nfunction keyForPath(path: string): KeyFor {\n  if (DEBUG && path[0] === '@') {\n    throw new Error(`invalid keypath: '${path}', valid keys: @index, @identity, or a path`);\n  }\n  return uniqueKeyFor((item) => getPath(item as object, path));\n}\n\nfunction makeKeyFor(key: string) {\n  switch (key) {\n    case '@key':\n      return uniqueKeyFor(KEY);\n    case '@index':\n      return uniqueKeyFor(INDEX);\n    case '@identity':\n      return uniqueKeyFor(IDENTITY);\n    default:\n      return keyForPath(key);\n  }\n}\n\nclass WeakMapWithPrimitives<T> {\n  private _weakMap?: WeakMap<object, T>;\n  private _primitiveMap?: Map<unknown, T>;\n\n  private get weakMap() {\n    if (this._weakMap === undefined) {\n      this._weakMap = new WeakMap();\n    }\n\n    return this._weakMap;\n  }\n\n  private get primitiveMap() {\n    if (this._primitiveMap === undefined) {\n      this._primitiveMap = new Map();\n    }\n\n    return this._primitiveMap;\n  }\n\n  set(key: unknown, value: T) {\n    if (isObject(key)) {\n      this.weakMap.set(key as object, value);\n    } else {\n      this.primitiveMap.set(key, value);\n    }\n  }\n\n  get(key: unknown): T | undefined {\n    if (isObject(key)) {\n      return this.weakMap.get(key as object);\n    } else {\n      return this.primitiveMap.get(key);\n    }\n  }\n}\n\nconst IDENTITIES = new WeakMapWithPrimitives<object[]>();\n\nfunction identityForNthOccurence(value: any, count: number) {\n  let identities = IDENTITIES.get(value);\n\n  if (identities === undefined) {\n    identities = [];\n    IDENTITIES.set(value, identities);\n  }\n\n  let identity = identities[count];\n\n  if (identity === undefined) {\n    identity = { value, count };\n    identities[count] = identity;\n  }\n\n  return identity;\n}\n\n/**\n * When iterating over a list, it's possible that an item with the same unique\n * key could be encountered twice:\n *\n * ```js\n * let arr = ['same', 'different', 'same', 'same'];\n * ```\n *\n * In general, we want to treat these items as _unique within the list_. To do\n * this, we track the occurences of every item as we iterate the list, and when\n * an item occurs more than once, we generate a new unique key just for that\n * item, and that occurence within the list. The next time we iterate the list,\n * and encounter an item for the nth time, we can get the _same_ key, and let\n * Glimmer know that it should reuse the DOM for the previous nth occurence.\n */\nfunction uniqueKeyFor(keyFor: KeyFor) {\n  let seen = new WeakMapWithPrimitives<number>();\n\n  return (value: unknown, memo: unknown) => {\n    let key = keyFor(value, memo);\n    let count = seen.get(key) || 0;\n\n    seen.set(key, count + 1);\n\n    if (count === 0) {\n      return key;\n    }\n\n    return identityForNthOccurence(key, count);\n  };\n}\n\nexport function createIteratorRef(listRef: Reference, key: string) {\n  return createComputeRef(() => {\n    let iterable = valueForRef(listRef) as { [Symbol.iterator]: any } | null | false;\n\n    let keyFor = makeKeyFor(key);\n\n    if (Array.isArray(iterable)) {\n      return new ArrayIterator(iterable, keyFor);\n    }\n\n    let maybeIterator = toIterator(iterable);\n\n    if (maybeIterator === null) {\n      return new ArrayIterator(EMPTY_ARRAY, () => null);\n    }\n\n    return new IteratorWrapper(maybeIterator, keyFor);\n  });\n}\n\nexport function createIteratorItemRef(_value: unknown) {\n  let value = _value;\n  let tag = createTag();\n\n  return createComputeRef(\n    () => {\n      consumeTag(tag);\n      return value;\n    },\n    (newValue) => {\n      if (value !== newValue) {\n        value = newValue;\n        dirtyTag(tag);\n      }\n    }\n  );\n}\n\nclass IteratorWrapper implements OpaqueIterator {\n  constructor(private inner: IteratorDelegate, private keyFor: KeyFor) {}\n\n  isEmpty() {\n    return this.inner.isEmpty();\n  }\n\n  next() {\n    let nextValue = this.inner.next() as OpaqueIterationItem;\n\n    if (nextValue !== null) {\n      nextValue.key = this.keyFor(nextValue.value, nextValue.memo);\n    }\n\n    return nextValue;\n  }\n}\n\nclass ArrayIterator implements OpaqueIterator {\n  private current: { kind: 'empty' } | { kind: 'first'; value: unknown } | { kind: 'progress' };\n  private pos = 0;\n\n  constructor(private iterator: unknown[] | readonly unknown[], private keyFor: KeyFor) {\n    if (iterator.length === 0) {\n      this.current = { kind: 'empty' };\n    } else {\n      this.current = { kind: 'first', value: iterator[this.pos] };\n    }\n  }\n\n  isEmpty(): boolean {\n    return this.current.kind === 'empty';\n  }\n\n  next(): Option<IterationItem<unknown, number>> {\n    let value: unknown;\n\n    let current = this.current;\n    if (current.kind === 'first') {\n      this.current = { kind: 'progress' };\n      value = current.value;\n    } else if (this.pos >= this.iterator.length - 1) {\n      return null;\n    } else {\n      value = this.iterator[++this.pos];\n    }\n\n    let { keyFor } = this;\n\n    let key = keyFor(value as Dict, this.pos);\n    let memo = this.pos;\n\n    return { key, value, memo };\n  }\n}\n"],"sourceRoot":""}
{
"name": "@glimmer/reference",
"version": "0.76.0",
"version": "0.77.0",
"description": "Objects used to track values and their dirtiness in Glimmer",

@@ -8,6 +8,6 @@ "license": "MIT",

"@glimmer/env": "^0.1.7",
"@glimmer/global-context": "0.76.0",
"@glimmer/interfaces": "0.76.0",
"@glimmer/util": "0.76.0",
"@glimmer/validator": "0.76.0"
"@glimmer/global-context": "0.77.0",
"@glimmer/interfaces": "0.77.0",
"@glimmer/util": "0.77.0",
"@glimmer/validator": "0.77.0"
},

@@ -14,0 +14,0 @@ "main": "dist/commonjs/es2017/index.js",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc