Age | Commit message (Collapse) | Author |
|
|
|
* update & test Track.referencedByTracks
* update & test Track.sampledByTracks
* update & test Track.featuredInFlashes
* update Thing.common.reverseReferenceList
* add Thing.composite.withReverseReferenceList
* add Track.composite.trackReverseReferenceList
|
|
|
|
|
|
Only the internal implementation. This should really be updated to
take key/value-style parameters, and probably be renamed, but this
helps to confirm a swathe of expected behavior continues to work
with an existing `common` utility reimplemented compositionally.
|
|
|
|
* add earlyExitWithoutUpdateValue
* add raiseWithoutDependency
* add raiseWithoutUpdateValue
* add earlyExitIfAvailabilityCheckFailed (internal)
* refactor earlyExitWithoutDependency
The "raise" utilities make use of the new `raiseAbove` continuation
feature.
|
|
|
|
Sublime Text doesn't index the key in `key: () => {}` as a symbol
for function definitions if the parameter list takes up more than
one line, but always works for `key() {}`.
This also just makes it a little easier to add "preamble" before
the main return value, when relevant. Consistent syntax is usually
a plus for recurring behavioral forms!
|
|
|
|
...in the final composition's dependencies.
|
|
* print annotation next to every log message, instead of just
the begin/end messages
* add Thing.composite.debug() to conveniently wrap one property
access
* don't output (and don't access) track album in inspect.custom
when depth < 0
|
|
|
|
Thing.composite.from:
* Transparently support expose.transform steps inside nested
compositions, w/ various Thing.composite.from clean-up
* Support continuation.raise() without provided dependencies
* add Thing.composite.exposeConstant
* add Thing.composite.withResultOfAvailabilityCheck
* supports {mode: 'null' | 'empty' | 'falsy'}
* works with dependency or update value
* add Thing.composite.earlyExitWithoutDependency
* refactor Thing.composite.exposeDependencyOrContinue
* refactor Thing.composite.exposeUpdateValueOrContinue
* add Track.withHasUniqueCoverArt
* refactor Track.coverArtFileExtension
* refactor Track.hasUniqueCoverArt
|
|
|
|
|
|
|
|
* Thing.composite.expose
* Thing.composite.exposeUpdateValueOrContinue
* Track.composite.withAlbumProperty
* refactor: Track.color, Track.album, Track.date
* refactor: Track.coverArtistContribs
* test: Track.album (unit)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The `earlyExitIfNotFound` flag is only supposed to exit if the
reference really existed and failed to match anything. If it was
null in the first place, withResolvedReferences should always
just pass null ahead.
|
|
|
|
|
|
|
|
|
|
* Thing.composite.from() only provides the dependencies specified
in each step and the base, and prevents '#'-prefixed keys from
being specified on the main (composite) dependency list.
* CacheableObject no longer provides a "reflection" dependency to
every compute/transform function, and now requires the property
'this' to be specified instead of the constructor.instance
symbol. (The static CacheableObject.instance, inherited by all
subclasses, was also removed.)
* Also minor improvements to sugar.js data processing utility
functions.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Fixes #178.
This commit also cleans up the documentation for the utility
used here, dynamicInheritContribs. These are the only two uses
of that utility at all but like, code comments very rarely hurt
and d'accord are probably even more useful here lol
|
|
* generateContributionLinks replaced with linkContribution,
tests still need updating
* album pages respect albums without cover art
* track pages without unique art inherit art tags from album
(fixes #13)
not heavily tested, this commit probably breaks some pages
which were loading correctly before
|
|
|
|
|