Rob Rix
63ffe0a596
Use symbols for keys.
2015-10-16 15:22:07 -04:00
Rob Rix
e85566bfeb
Use symbols for leaves.
2015-10-16 15:21:58 -04:00
Rob Rix
057a847f30
Add a generator for symbols.
...
Right now just _<hex digit>
2015-10-16 15:21:27 -04:00
Rob Rix
d413f24e57
Delay the arbitrary sub-term.
2015-10-16 15:17:47 -04:00
Rob Rix
c9bc15bcc9
Revert "Add a delay combinator."
...
This reverts commit 2feeac9065de48f6e5cb412752a6a8e4d2fcf5ca.
2015-10-16 15:17:05 -04:00
Rob Rix
0622a984dc
Delay recurrence.
...
Inlined because Swift.
2015-10-16 15:17:00 -04:00
Rob Rix
989a2d7319
Add a delay combinator.
2015-10-16 15:12:08 -04:00
Rob Rix
e6ac782e84
Implement the computation of arbitrary ranged terms.
2015-10-16 15:06:27 -04:00
Rob Rix
541897aa43
Arrange unannotated terms.
2015-10-16 15:05:01 -04:00
joshvera
e7fa851420
parse arrays
2015-10-16 14:52:03 -04:00
joshvera
0628142d8b
parse members
2015-10-16 14:43:23 -04:00
Rob Rix
5beccbdca2
Compute the source of unannotated terms.
2015-10-16 14:40:18 -04:00
Rob Rix
4a24c3f872
Generate arbitrary keyed terms.
2015-10-16 14:30:53 -04:00
Rob Rix
cc1f0a07a3
Rename the branch case to indexed.
2015-10-16 14:26:58 -04:00
Rob Rix
c249f1de8a
Construct arbitrary unannotated branches.
2015-10-16 14:26:46 -04:00
Rob Rix
6a4e1dca39
Construct arbitrary unannotated leaves.
2015-10-16 14:26:32 -04:00
Rob Rix
412ea9cc04
Add unannotated terms.
2015-10-16 14:24:17 -04:00
Rob Rix
570d4efa5d
Generate arbitrary leaves.
2015-10-16 13:23:38 -04:00
joshvera
a93e8e90da
remove String.lift
2015-10-16 13:10:18 -04:00
joshvera
b6ec5e0bf8
Parse simple json
2015-10-16 13:08:49 -04:00
Rob Rix
a3ef491de4
Stub in Arbitrary conformance.
2015-10-16 12:28:49 -04:00
Rob Rix
c415a6aafd
Add a RangedTerm struct wrapping ranged terms.
2015-10-16 12:28:16 -04:00
Rob Rix
889f3ffef5
Link the tests against SwiftCheck.
2015-10-16 11:48:24 -04:00
Rob Rix
fa0b04d4cd
Add SwiftCheck to the workspace.
2015-10-16 11:48:18 -04:00
Rob Rix
b851fbc186
Add SwiftCheck.
2015-10-16 11:44:48 -04:00
joshvera
b16367635b
remove type declarations
2015-10-16 11:14:13 -04:00
Rob Rix
01d65a4245
Patches of terms annotated with ranges can produce JSON over source strings.
2015-10-16 11:09:30 -04:00
Rob Rix
8c341fc129
Terms annotated with ranges over a string can be printed to JSON.
2015-10-16 11:09:20 -04:00
Rob Rix
c058e81183
Syntax’s JSON parameter functions do not escape.
2015-10-16 11:09:07 -04:00
joshvera
409cca5b8d
++Madness
2015-10-16 11:06:59 -04:00
joshvera
4f529028a7
Upgrade to applicative Madness branch
2015-10-16 11:05:13 -04:00
Rob Rix
73fdb644b2
Use the typealias.
2015-10-16 10:07:06 -04:00
Rob Rix
20e5d25fbf
PatchType does not require construction with a Patch.
2015-10-16 09:30:25 -04:00
Rob Rix
0c786ed160
Use the PatchType init to delete.
2015-10-16 09:30:09 -04:00
Rob Rix
aa2cce5a39
Use the PatchType init to insert.
2015-10-16 09:29:56 -04:00
Rob Rix
902ce99172
Use the PatchType init to replace.
2015-10-16 09:29:43 -04:00
Rob Rix
bcdaff9c2c
PatchType requires constructors for deletions.
2015-10-16 09:28:45 -04:00
Rob Rix
64cd995e41
PatchType requires constructors for deletions.
2015-10-16 09:28:37 -04:00
Rob Rix
00115e422b
PatchType requires constructors for replacements.
2015-10-16 09:28:25 -04:00
Rob Rix
831eb1e521
PatchType does not require patch
.
2015-10-16 09:26:13 -04:00
Rob Rix
52dc661fc9
Use Patch
es’ inverse directly.
2015-10-16 09:24:12 -04:00
Rob Rix
1493b2938e
PatchType requires inverse
.
2015-10-16 09:23:51 -04:00
Rob Rix
c1cb797c6f
Use Patch
es’ state directly.
2015-10-16 09:23:33 -04:00
Rob Rix
9b15398f76
PatchType requires state
.
2015-10-16 09:22:41 -04:00
Rob Rix
38be68d95d
Rename PatchConvertible to PatchType.
2015-10-16 09:21:41 -04:00
Rob Rix
fcff1d8e9f
Correct a section marker.
2015-10-16 09:20:47 -04:00
Rob Rix
b43badaf04
🔥 FreeConvertible.
2015-10-16 09:20:14 -04:00
Rob Rix
c5fe7bec46
What why
2015-10-15 18:32:43 -04:00
Rob Rix
90d84593c8
Remove Algorithm.evaluate()
in all its many forms.
2015-10-15 18:30:16 -04:00
Rob Rix
bee0876bae
Correct the test of categorization.
2015-10-15 18:29:23 -04:00
Rob Rix
d833e65b50
Correct the test of restrictions.
2015-10-15 18:29:17 -04:00
Rob Rix
8595464342
Migrate the tests to Interpreter.
2015-10-15 18:25:35 -04:00
Rob Rix
690e8ef175
Rename AlgorithmTests → InterpreterTests.
2015-10-15 18:18:38 -04:00
Rob Rix
5584c2f653
Use the sum
combinator to compute a cost function.
2015-10-15 18:16:02 -04:00
Rob Rix
792a6b6654
Add a convenience for summing Free
s.
2015-10-15 18:13:22 -04:00
joshvera
360baa236c
parse some jsons
2015-10-15 17:40:57 -04:00
joshvera
9f29b877da
add Madness
2015-10-15 16:20:42 -04:00
Rob Rix
7871169f8d
Compute JSON diffs with Interpreter.
2015-10-15 15:50:46 -04:00
Rob Rix
5c85adaab0
Merge branch 'master' into interpreter
...
Conflicts:
prototype/Doubt/Algorithm.swift
2015-10-15 15:45:01 -04:00
Rob Rix
1690c71cb2
Convenience constructor for Interpreters with Categorizable annotations.
2015-10-15 15:43:18 -04:00
Rob Rix
1e53b446ab
Cofree conforms to CofreeType.
2015-10-15 15:42:39 -04:00
Rob Rix
522757c121
Replace CofreeConvertible with CofreeType.
2015-10-15 15:42:24 -04:00
Rob Rix
f8cd049280
Add a function from categorization functions to comparable functions.
2015-10-15 15:39:55 -04:00
Josh Vera
e6ec91cd64
Merge pull request #120 from github/patch-constructors-on-diff
...
Patch constructors on diff
2015-10-15 15:39:14 -04:00
Rob Rix
2d21447312
Replaces the convenience constructor with a diff cost constructor.
2015-10-15 15:34:59 -04:00
Rob Rix
8d93a77b86
Add a CofreeConvertible protocol.
2015-10-15 15:31:51 -04:00
Rob Rix
24c66eb1ff
Convenience constructor taking a Patch cost function.
2015-10-15 15:28:21 -04:00
Rob Rix
53c78fd546
It’s a type.
2015-10-15 15:28:12 -04:00
Rob Rix
1b86134377
Difference over Patch<Term: TermType>.
2015-10-15 15:25:04 -04:00
Rob Rix
e8a67fbdb0
Sum over Patch<Term: TermType>.
2015-10-15 15:24:58 -04:00
Rob Rix
e5fe5f448a
Parameterized difference over Patch.
2015-10-15 15:23:51 -04:00
Rob Rix
45d2697c46
Parameterized sum over Patch.
2015-10-15 15:23:36 -04:00
Rob Rix
856abbe611
I don’t know.
2015-10-15 15:08:06 -04:00
Rob Rix
e5f6d1acfa
Add a top-down, left-to-right reduce method to Free.
2015-10-15 15:07:13 -04:00
Rob Rix
662fbe7dbc
Don’t require equal
when the leaf type is Equatable.
2015-10-15 14:34:47 -04:00
Rob Rix
62c13aed65
Document run
.
2015-10-15 14:30:14 -04:00
Rob Rix
5aa7b7c26a
Document Interpreter
’s constructor.
2015-10-15 14:28:28 -04:00
Rob Rix
98398f6fd0
Move the run
method to the top.
2015-10-15 14:16:01 -04:00
Rob Rix
58b8fc2fe6
Merge branch 'master' into interpreter
2015-10-15 14:15:33 -04:00
Rob Rix
b453319db4
Merge branch 'master' into restrict-comparisons-by-category
2015-10-15 14:14:34 -04:00
Rob Rix
3a4f331b2e
Document the categorize
parameter.
2015-10-15 14:14:29 -04:00
Rob Rix
a34b5a34f4
Document the equals
parameter.
2015-10-15 14:12:39 -04:00
Rob Rix
e2e55ef041
Document the purpose of size
.
2015-10-15 13:45:30 -04:00
Rob Rix
5e947ae30a
Rename equals
to equal
.
2015-10-15 12:20:22 -04:00
Rob Rix
5c163d291b
Document the Diff typealias.
2015-10-15 12:16:58 -04:00
Rob Rix
c46d48b582
Public constructor.
2015-10-15 12:16:39 -04:00
Rob Rix
02e5ed7539
Bail if a and b are not comparable.
2015-10-15 12:15:50 -04:00
Rob Rix
482aa3b907
Document recur
.
2015-10-15 12:15:30 -04:00
Rob Rix
6263645728
Add a comparable
parameter.
2015-10-15 12:15:27 -04:00
Rob Rix
53ea4fcf36
Interpretation of .ByIndex
algorithms.
2015-10-15 11:51:01 -04:00
Rob Rix
932bc44778
Add a private cost
parameter to Interpreter
.
2015-10-15 11:50:43 -04:00
Rob Rix
5a6b96e38b
Interpret .ByKey algorithms.
2015-10-15 11:50:04 -04:00
Rob Rix
ca3023dce3
Document the interpretation of .Recursive nodes.
2015-10-15 11:48:49 -04:00
Rob Rix
7771edccf5
.Recursive replaces.
2015-10-15 11:47:27 -04:00
Rob Rix
2dbfd51f15
Recur through pairs of .Keyed
nodes with equal keys.
2015-10-15 11:45:40 -04:00
Rob Rix
52c1b581c6
Recur through pairs of equal-length indexed terms.
2015-10-15 11:33:13 -04:00
Rob Rix
8680bb4165
Infer a type.
2015-10-15 11:29:56 -04:00
Rob Rix
ac84875a4b
Return pure diffs.
2015-10-15 11:29:49 -04:00
Rob Rix
0960bdacf4
Extract a method recurring over algorithms.
2015-10-15 11:29:04 -04:00
Rob Rix
7a31fe7e75
The equality parameter is private.
2015-10-15 11:27:44 -04:00
Rob Rix
3c08972026
Extract a private recurrence method.
2015-10-15 11:26:35 -04:00
Rob Rix
9a98450cfe
Merge branch 'patch-constructors-on-diff' into interpreter
2015-10-15 11:23:18 -04:00
Rob Rix
0b916807a2
Use the patch constructors in recursive evaluation.
2015-10-15 11:21:23 -04:00
Rob Rix
d74e4fb231
Missed a couple of cases in SES.
2015-10-15 11:20:41 -04:00
Rob Rix
eda4ece5a8
Use the patch constructors in dictionary diffing.
2015-10-15 11:20:07 -04:00
Rob Rix
fed0d91d30
Use the patch constructors in SES.
2015-10-15 11:19:14 -04:00
Rob Rix
298a37c444
Section header for patch construction.
2015-10-15 11:18:16 -04:00
Rob Rix
6ee73cca06
We don’t need Cofree terms to construct patches.
2015-10-15 11:18:06 -04:00
Rob Rix
cd7e67c30d
Remove the convenience functions.
2015-10-15 11:16:27 -04:00
Rob Rix
b4ea7b70bc
Use the Diff/Patch constructors in the tests.
2015-10-15 11:16:21 -04:00
Rob Rix
9e80e0c903
Add a Delete constructor to Free when used as a diff.
2015-10-15 11:11:06 -04:00
Rob Rix
ce633f555a
Add an Insert constructor to Free when used as a diff.
2015-10-15 11:10:35 -04:00
Rob Rix
8366dc752a
Add a Replace constructor to Free when used as a Diff.
2015-10-15 11:10:16 -04:00
Rob Rix
787681eafc
Construct an algorithm.
2015-10-15 11:07:35 -04:00
Rob Rix
98d333d721
Test equality, otherwise replace.
2015-10-15 11:04:37 -04:00
Rob Rix
6f71a42509
Running takes a pair of Terms.
2015-10-15 11:03:15 -04:00
Rob Rix
0cedf87540
Interpreter has a Diff typealias.
2015-10-15 11:01:35 -04:00
Rob Rix
a9f5075d3e
Interpreter has an equality function.
2015-10-15 11:00:49 -04:00
Rob Rix
22cb1e00d5
Abstract Interpreter over a TermType.
2015-10-15 11:00:27 -04:00
Rob Rix
1a4151b2a9
Stub in running.
2015-10-15 10:58:57 -04:00
Rob Rix
28c5fb81a2
Rename B to Result.
2015-10-15 10:49:39 -04:00
Rob Rix
30e9ac9106
Stub in docs for Interpreter
.
2015-10-15 10:45:32 -04:00
Rob Rix
6a955d5e88
Stub in Interpreter
.
2015-10-15 10:45:11 -04:00
Rob Rix
a7192afc47
Merge branch 'patch-costs-are-proportional-to-the-size-of-their-trees' into interpreter
2015-10-15 10:42:02 -04:00
Rob Rix
dfa34aa13c
Merge branch 'master' into patch-costs-are-proportional-to-the-size-of-their-trees
2015-10-15 09:48:15 -04:00
Rob Rix
260a317194
Merge branch 'master' into restrict-comparisons-by-category
...
Conflicts:
prototype/Doubt.xcodeproj/project.pbxproj
2015-10-15 09:47:49 -04:00
Rob Rix
48234b71c2
Remove Hash.
2015-10-15 09:44:40 -04:00
Rob Rix
77a32f9e8d
Remove Patch hashing.
2015-10-15 09:44:36 -04:00
Rob Rix
f30d2d609a
Remove Syntax hashing.
2015-10-15 09:43:51 -04:00
Rob Rix
1cbc04100d
Remove Free hashing.
2015-10-15 09:43:27 -04:00
Rob Rix
8b5a269d5e
Remove Cofree hashing.
2015-10-15 09:43:23 -04:00
Rob Rix
9ac09dea2c
Remove Category.
2015-10-15 09:40:36 -04:00
Rob Rix
6fcfed8f37
Remove Info.
2015-10-15 09:39:20 -04:00
Rob Rix
9cc446b4ea
Merge branch 'master' into patch-costs-are-proportional-to-the-size-of-their-trees
...
Conflicts:
prototype/Doubt/Patch.swift
prototype/Doubt/TermType.swift
prototype/DoubtTests/SESTests.swift
2015-10-15 09:32:36 -04:00
Rob Rix
f0d5e1c05d
This got pulled in twice due to a cherry-pick followed by a merge.
...
I didn’t know that was even possible.
2015-10-15 09:29:26 -04:00
Rob Rix
c022085919
Merge branch 'master' into restrict-comparisons-by-category
...
Conflicts:
prototype/Doubt.xcodeproj/project.pbxproj
prototype/Doubt/Fix.swift
2015-10-15 09:28:21 -04:00
Rob Rix
59947a6581
Rename TermType.out to TermType.unwrap.
2015-10-15 09:18:55 -04:00
Rob Rix
cb5dde7bb1
Remove Fix.
2015-10-15 09:17:55 -04:00
Rob Rix
3d8027b6a1
Fix is no longer a TermType.
2015-10-15 09:17:40 -04:00
Rob Rix
3763d7354f
Remove the constrained extension providing JSON from diffs when their terms are Fix<A>.
...
This was not easy to reproduce with Cofree because you can’t introduce
a type variable to constrain the annotation to.
2015-10-15 09:16:49 -04:00
Rob Rix
dd48510b65
Original terms can be recovered without annotations.
2015-10-15 09:12:34 -04:00
Rob Rix
3356a11805
Remove the redundant Free/Fix construction.
...
This was handled by Free/TermType construction.
2015-10-15 09:09:58 -04:00
Rob Rix
89720c8e65
Test SES over Cofree terms.
2015-10-15 09:08:30 -04:00
Rob Rix
adca66f66c
Define parameterized equality over TermType.
2015-10-15 09:05:40 -04:00
Rob Rix
a40ae08ac5
Correct a comment.
2015-10-15 09:01:07 -04:00
Rob Rix
18d19173c0
Remove the Fix → Cofree constructor.
2015-10-15 08:58:48 -04:00
Rob Rix
70b7e56b9c
Remove Doc
.
2015-10-15 08:55:53 -04:00
Rob Rix
ca922b2283
Free is no longer CustomDocConvertible.
2015-10-15 08:55:26 -04:00
Rob Rix
2bfe2e2eab
Fix is no longer CustomDocConvertible.
2015-10-15 08:55:01 -04:00
Rob Rix
064e5f1faa
Patch is no longer CustomDocConvertible.
2015-10-15 08:54:33 -04:00
Rob Rix
eba7c9bfbd
Remove DocTests.swift
.
2015-10-15 08:54:04 -04:00
Rob Rix
31eb3f2b4a
Syntax is no longer CustomDocConvertible.
2015-10-15 08:53:46 -04:00
Rob Rix
f55ceade22
Replace the fixtures with newer, even more exciting ones.
2015-10-14 21:10:09 -04:00
Rob Rix
b93a605b37
Document cata
.
2015-10-14 21:07:30 -04:00
Rob Rix
e582f28972
Charge a constant cost for the tests.
2015-10-14 18:51:52 -04:00
Rob Rix
7c099bac6f
Parameterize SES by the cost function.
2015-10-14 18:51:18 -04:00
Rob Rix
230394bde2
Charge diffs a cost proportional to their size.
...
This can no longer be done in SES, as it requires knowledge that the
elements of the arrays are of TermType.
2015-10-14 18:51:07 -04:00
Rob Rix
32c55fd5ff
Add a section for PatchConvertible.
2015-10-14 18:48:15 -04:00
Rob Rix
b4a9564747
TermType has a size property.
2015-10-14 18:47:20 -04:00
Rob Rix
b0cb77ae74
Define catamorphisms over TermTypes.
2015-10-14 18:42:20 -04:00
Rob Rix
606614ffdf
🔥 Info.
2015-10-14 18:09:24 -04:00
Rob Rix
90b7ac4b21
Equals-or-intersects.
2015-10-14 18:08:56 -04:00
Rob Rix
5fccc3586c
Test that uncategorized terms are unrestricted.
2015-10-14 17:51:40 -04:00
Rob Rix
c75b2c134e
Correct the test of disjoint categorization to assign unique categories to each term.
2015-10-14 17:51:31 -04:00
Rob Rix
742fc0ea0f
Correct the categorization test.
...
This implies that uncategorized nodes can be compared with anything.
2015-10-14 17:51:01 -04:00
Rob Rix
2aef2114c3
Test that comparisons are unrestricted by default.
2015-10-14 17:47:07 -04:00
Rob Rix
1134f7a9e9
Add a fixture for an unrestricted diff.
2015-10-14 17:46:50 -04:00
Rob Rix
90864e397b
Avoid an annotation.
2015-10-14 17:46:41 -04:00
Rob Rix
0cb72943b1
Rename the test case.
2015-10-14 17:44:19 -04:00
Rob Rix
d9e7798dde
Test that comparisons of disjoint-categorized terms are restricted.
2015-10-14 17:41:51 -04:00
Rob Rix
1f23ec9e47
Extract the diff into a private global.
2015-10-14 17:39:53 -04:00
Rob Rix
48a9a741c7
Merge branch 'master' into restrict-comparisons-by-category
2015-10-14 17:36:47 -04:00
joshvera
46010e3096
Merge branch 'master' into diff-cofree-values
2015-10-14 16:49:28 -04:00
Josh Vera
df31170dc8
Merge pull request #107 from github/generalize-patch
...
Generalize Patch
2015-10-14 16:47:57 -04:00
Josh Vera
d49986c671
Merge pull request #102 from github/charge-a-constant-cost-to-patches
...
Charge a constant cost to patches
2015-10-14 16:47:47 -04:00
Rob Rix
025d43379e
Merge branch 'master' into diff-cofree-values
2015-10-14 16:46:07 -04:00
Rob Rix
4690ae6533
Merge branch 'master' into generalize-patch
2015-10-14 16:45:33 -04:00
Josh Vera
99c4e8556e
Merge pull request #109 from github/literal-syntax-construction
...
Literal syntax construction
2015-10-14 16:44:25 -04:00
Rob Rix
7a03f09fe9
Test that comparisons are restricted by nil returns from recur
.
2015-10-14 16:43:08 -04:00
Matt Diephouse
6eff8d6f82
Merge pull request #101 from github/parameterize-algorithm-evaluation-by-comparison-restriction
...
Parameterize Algorithm evaluation by comparison restriction
2015-10-14 16:42:03 -04:00
Rob Rix
e0692770b3
Cofree is CustomDebugStringConvertible.
2015-10-14 16:40:13 -04:00
Rob Rix
bf48944c83
Diff equality.
2015-10-14 16:32:01 -04:00
Rob Rix
92ec5b6130
Define parameterized equality over TermType.
2015-10-14 16:31:32 -04:00
Rob Rix
ed10ec1257
Write the fixtures using the typealias.
2015-10-14 16:10:23 -04:00
Rob Rix
35617fee70
Add typealiases for Diff and Term.
2015-10-14 16:09:58 -04:00
Rob Rix
ff559845d8
Add a couple of fixtures.
2015-10-14 16:07:07 -04:00
Rob Rix
9a6e8dea03
Merge branch 'literal-syntax-construction' into restrict-comparisons-by-category
2015-10-14 16:03:54 -04:00
Rob Rix
86df4c6a87
Syntax is DictionaryLiteralConvertible.
2015-10-14 16:03:14 -04:00
Rob Rix
76ca906097
Syntax is ArrayLiteralConvertible.
2015-10-14 16:02:33 -04:00
Rob Rix
0c78e344ad
Stub in a test suite for Algorithm.
2015-10-14 15:57:58 -04:00
Rob Rix
124d45a549
Cofree has categories when B: Categorizable.
2015-10-14 15:49:23 -04:00
Rob Rix
b60abdf5b0
Factoring.
2015-10-14 15:46:19 -04:00
Rob Rix
3117d26464
Fix up the categorization.
2015-10-14 15:44:58 -04:00
Rob Rix
6d0bfdb9d0
Add an evaluate method parameterized by categorization.
2015-10-14 15:43:24 -04:00
Rob Rix
80bda88082
Merge branch 'diff-cofree-values' into restrict-comparisons-by-category
...
Conflicts:
prototype/Doubt/SES.swift
prototype/DoubtTests/SESTests.swift
2015-10-14 15:35:18 -04:00
Rob Rix
105b57566b
Replace the JSON fixtures with much cooler JSON fixtures.
2015-10-14 14:40:47 -04:00
Rob Rix
ed004ca4c1
Annotate terms with their sizes.
2015-10-14 14:40:21 -04:00
Rob Rix
645e038982
Compute the size of syntax trees.
2015-10-14 14:32:26 -04:00
Rob Rix
6b781622b6
Add the annotations to the JSON.
2015-10-14 14:22:19 -04:00
Rob Rix
abd037796a
Annotate JSON with integers.
2015-10-14 14:21:12 -04:00
Rob Rix
1fc7771918
Int is CustomJSONConvertible.
2015-10-14 14:20:58 -04:00
Rob Rix
f34af098d3
String is CustomJSONConvertible.
2015-10-14 14:20:13 -04:00
Rob Rix
29001b713c
Diff JSON in Cofree.
2015-10-14 14:17:56 -04:00
Rob Rix
07690849a6
Convenience for constructing Cofree with autoclosures.
2015-10-14 14:17:29 -04:00
Rob Rix
9afc487776
Cofree is a TermType.
2015-10-14 14:05:43 -04:00
Rob Rix
714f99638e
Abstract Algorithm over a Term type.
2015-10-14 14:04:47 -04:00
Rob Rix
7e9a41dfbd
Make the Roll case indirect.
2015-10-14 14:04:35 -04:00
Rob Rix
b8dca6fe2a
Call evaluate with equality.
2015-10-14 14:03:46 -04:00
Rob Rix
79708346e0
Correct the Diff typealias.
2015-10-14 14:00:46 -04:00
Rob Rix
3e75895c4d
Fix is a TermType.
2015-10-14 13:57:21 -04:00
Rob Rix
92cb1927d1
Move Term/Diff to the top level.
2015-10-14 13:57:12 -04:00
Rob Rix
4fb38d612e
Add a constructor for Free over arbitrary TermType.
2015-10-14 13:52:43 -04:00
Rob Rix
6f886356aa
Add a TermType protocol.
2015-10-14 13:52:25 -04:00
Rob Rix
6188a5a2d7
Move FreeConvertible to Free.swift.
2015-10-14 13:34:29 -04:00
Rob Rix
01b32b010f
Rename Algorithm’s A type parameter to Leaf.
2015-10-14 13:33:51 -04:00
Rob Rix
31d905ac64
Merge branch 'generalize-patch' into diff-cofree-values
2015-10-14 13:31:00 -04:00
Rob Rix
436708bb3b
🔥 chaff.
2015-10-14 13:16:27 -04:00
Rob Rix
09fad58fd7
Correct a comment.
2015-10-14 12:46:16 -04:00
Rob Rix
b8f8953f1c
Return the identity diff when equal.
2015-10-14 12:29:40 -04:00
Rob Rix
517c87c303
Revert "Revert "SES does not take an equality test.""
...
This reverts commit bb73f6eac2b59599607369767e9e221e7e5e0f15.
2015-10-14 12:28:45 -04:00
Rob Rix
d0d96d569d
Revert "Pass the correct equality function to SES."
...
This reverts commit e78c6cde10ad70e93ab003ceacc07db290b061e4.
2015-10-14 12:28:41 -04:00
Rob Rix
432c9f7239
Pass the correct equality function to SES.
2015-10-14 12:26:25 -04:00
Rob Rix
a7f4d91d56
Revert "SES does not take an equality test."
...
This reverts commit 1db8bdf82c85a490188882b810cd9c516e4f210e.
Conflicts:
prototype/Doubt/SES.swift
prototype/DoubtTests/SESTests.swift
2015-10-14 12:25:38 -04:00
Rob Rix
8d4a91d3a9
Merge branch 'parameterize-algorithm-evaluation-by-comparison-restriction' into generalize-patch
...
Conflicts:
prototype/Doubt/SES.swift
prototype/DoubtTests/SESTests.swift
2015-10-14 12:24:04 -04:00
Rob Rix
6e5335c915
SES tests operate over strings.
2015-10-14 12:19:38 -04:00
Rob Rix
0acdd16db3
Generalize SES to arbitrary arrays.
2015-10-14 12:18:49 -04:00
Rob Rix
34258b98b8
Generalize Patch
from Fix<A>
to A
.
2015-10-14 12:17:39 -04:00
Rob Rix
e33f733d83
SES does not take an equality test.
2015-10-14 12:14:15 -04:00
Rob Rix
da11e0983a
Don’t test equality in SES.
2015-10-14 12:11:03 -04:00
Rob Rix
964204a3e6
Rename the PatchConvertible associated type to Element.
2015-10-14 12:02:57 -04:00
Rob Rix
ef5720ad17
Add a typealias representing the type of patches.
2015-10-14 11:56:30 -04:00
Rob Rix
49fb97594a
Move Operation’s Functor implementation to a separate extension.
2015-10-14 11:43:17 -04:00
Rob Rix
c9134b5867
Move Operation into its own file.
2015-10-14 11:40:43 -04:00
Rob Rix
ff2c904888
Abstract Operation over Term and Diff types.
2015-10-14 11:39:56 -04:00
Rob Rix
79969bb69d
Move FreeConvertible into Free.swift.
2015-10-14 11:24:23 -04:00
Rob Rix
1cc879dc5d
Merge branch 'master' into restrict-comparisons-by-category
2015-10-14 11:19:26 -04:00
Rob Rix
b9ac0d3c38
JSON property for cofree over CustomJSONConvertible types.
2015-10-14 11:01:41 -04:00
Rob Rix
8f86f9ab76
Parameterized JSON conversion for Cofree.
2015-10-14 10:59:41 -04:00
Rob Rix
e70cbe4235
Algebraic hashing over cofrees of Hashable types.
2015-10-14 10:57:25 -04:00
Rob Rix
db57734586
Parameterized hashing over Cofree.
2015-10-14 10:56:25 -04:00
Rob Rix
3dcfbc0d38
Equality over Cofrees of equatable types.
2015-10-14 10:53:29 -04:00
Rob Rix
889dab1df2
Parameterized equality over Cofree.
2015-10-14 10:52:27 -04:00
Rob Rix
84ea5248e3
Unroll does not need to be indirect.
2015-10-14 10:49:05 -04:00
Rob Rix
8f3ae52d29
Cofree’s recurrence is lazy.
2015-10-14 10:48:42 -04:00
Rob Rix
c8234d27a4
Document coiterate.
2015-10-14 10:44:53 -04:00
Rob Rix
c13023b85b
Add a constructor annotating terms into Cofrees.
2015-10-14 10:39:21 -04:00
Rob Rix
961e9ae7d7
Implement coiteration.
2015-10-14 10:39:01 -04:00
Rob Rix
fa2bfcd367
duplicate()
is just extend(id)
.
2015-10-14 10:24:16 -04:00
Rob Rix
5015238546
Document Cofree.document()
.
2015-10-14 10:23:43 -04:00
Rob Rix
b50ebdf21a
Document Cofree.extend()
.
2015-10-14 10:22:04 -04:00
Rob Rix
011719b752
map
’s transformation function is @noescape
.
2015-10-14 10:20:21 -04:00
Rob Rix
2c56ee66ea
extend
’s transformation function is @noescape
.
2015-10-14 10:20:05 -04:00
Rob Rix
7bff8f6f50
Document Cofree.extract
.
2015-10-14 10:19:38 -04:00
Rob Rix
ab3d297d95
Document Cofree.
2015-10-14 10:19:02 -04:00
Rob Rix
6774213fcd
Cofree is a Functor.
2015-10-14 10:09:38 -04:00
Rob Rix
a606d9d798
Implement duplicate
on Cofree.
2015-10-14 10:03:42 -04:00
Rob Rix
1a44f29778
Cofree.extend
is public.
2015-10-14 10:01:26 -04:00
Rob Rix
cc805f6610
Cofree.extract
is public.
2015-10-14 10:01:19 -04:00
Rob Rix
26f0ea419d
Implement extend
on Cofree.
2015-10-14 10:00:16 -04:00
Rob Rix
ab554c52a0
Unwrap Cofrees.
2015-10-14 09:59:04 -04:00
Rob Rix
3985ef0fea
Unroll should be indirect.
2015-10-14 09:56:46 -04:00
Rob Rix
59dd626361
Add a Syntax to Cofree.
2015-10-14 09:43:51 -04:00
Rob Rix
0d662ade08
Implement extract
on Cofree
.
2015-10-14 09:43:23 -04:00
Rob Rix
a83f77116d
Add an Unroll case to Cofree.
2015-10-14 09:42:21 -04:00
Rob Rix
59b60947f9
Stub in Cofree.
2015-10-14 09:34:18 -04:00
Rob Rix
3238bc14bd
Rename Category.swift to Categorizable.swift.
2015-10-14 09:02:38 -04:00
Rob Rix
c7ef3cc586
Remove Category.
2015-10-14 09:02:21 -04:00
Rob Rix
1f40f40869
Info just uses Strings as its categories.
2015-10-14 09:02:00 -04:00
Rob Rix
4d07ed6fe7
String is CustomJSONConvertible.
2015-10-14 09:01:41 -04:00
Rob Rix
a68ad254d5
Inheritances are in alphabetical order.
2015-10-14 08:59:56 -04:00
Rob Rix
58c0a7ff2c
Categories can be of any Hashable type.
2015-10-14 08:59:19 -04:00
Rob Rix
59b7d60349
Move Term and Diff to the top level.
2015-10-13 21:45:48 -04:00
Rob Rix
7b517af351
Convenience for A: Categorizable, A: Equatable, B == Diff<A>.
2015-10-13 21:41:41 -04:00
Rob Rix
f4dda1c315
If A is Categorizable, require empty categories or non-intersecting sets of categories.
2015-10-13 21:41:20 -04:00
Rob Rix
2c3716d91c
Don’t provide a default implementation of categories
.
2015-10-13 21:40:12 -04:00
Rob Rix
8190064f48
Terms have categories.
2015-10-13 21:36:14 -04:00
Rob Rix
30d1a5dee2
Info is Categorizable.
2015-10-13 21:33:42 -04:00
Rob Rix
346a4e17c7
Categorizable types have categories
.
2015-10-13 21:33:24 -04:00
Rob Rix
088624118b
Stub in a Categorizable protocol.
2015-10-13 21:33:01 -04:00
Rob Rix
4454f4b04f
Document Category, sorta.
2015-10-13 21:29:04 -04:00
Rob Rix
02c33cc006
Merge branch 'master' into charge-a-constant-cost-to-patches
2015-10-13 21:14:42 -04:00
Rob Rix
f2826c3bd2
Merge branch 'master' into parameterize-algorithm-evaluation-by-comparison-restriction
2015-10-13 21:14:30 -04:00
Rob Rix
fca262a6b2
Remove the submodule.
2015-10-13 21:10:20 -04:00
Rob Rix
1dcd2aea59
Remove the plist.
2015-10-13 21:08:37 -04:00
Rob Rix
77022447ea
Remove the fixtures.
2015-10-13 21:08:29 -04:00
Rob Rix
877fa88177
Remove the scheme.
2015-10-13 21:08:13 -04:00
Rob Rix
d3cb848d87
Remove doubt-swift’s dependencies from the workspace.
2015-10-13 21:07:02 -04:00
Rob Rix
368e700c1a
Remove doubt-swift from the project.
2015-10-13 21:06:40 -04:00
Rob Rix
9b66e550f3
Delete the doubt-swift target.
2015-10-13 21:06:21 -04:00
Rob Rix
24bf8f4497
Merge branch 'parameterize-algorithm-evaluation-by-comparison-restriction' into charge-a-constant-cost-to-patches
2015-10-13 18:35:43 -04:00
Rob Rix
7b37db6943
Replace the UI fixture.
2015-10-13 18:27:12 -04:00
Rob Rix
7786b8c40f
Remove the Patch.cost
property.
2015-10-13 18:20:11 -04:00
Rob Rix
ee0f8765aa
Charge a constant cost to Patch
es.
2015-10-13 18:19:56 -04:00
Rob Rix
4ea9aab8b2
Simplify control flow around recur
/replace
.
2015-10-13 18:14:20 -04:00
Rob Rix
a15687dca3
Correct a test fixture.
...
I am unbelievably glad to be rid of this.
2015-10-13 18:05:28 -04:00
Rob Rix
5f395c55cf
Disallow diagonal edges.
...
This technically still allows (in fact, requires) them for equal
elements, but it will never construct `Patch.Replace`.
2015-10-13 18:05:11 -04:00
Rob Rix
5771d7caf5
Merge branch 'master' into parameterize-algorithm-evaluation-by-comparison-restriction
2015-10-13 17:55:52 -04:00
Rob Rix
92cb10379f
Document the decision a little further.
2015-10-13 17:55:47 -04:00
Rob Rix
9f498f1099
Formatting.
2015-10-13 17:55:02 -04:00
Rob Rix
10122d62da
Abbreviate the selection of the best outgoing edge.
2015-10-13 17:53:04 -04:00
Rob Rix
6cbe0a18d3
Extract diagonal.
2015-10-13 17:51:03 -04:00
Rob Rix
32bfdc6766
Factor out right/down.
2015-10-13 17:50:22 -04:00
Rob Rix
e09d46d109
nil
responses restrict the traversal of diagonal edges.
2015-10-13 17:45:22 -04:00
Rob Rix
90b22cf9a8
Allow recurrence to opt out of comparing nodes by returning nil
.
2015-10-13 17:40:14 -04:00
Rob Rix
873a8e668f
Add a function to construct the replacement of one term by another.
2015-10-13 17:38:36 -04:00
Josh Vera
3211714bb2
Merge pull request #98 from github/side-by-side-diffs
...
Side by side diffs
2015-10-13 16:41:39 -04:00
Rob Rix
c455b59cbb
Note Xcode 7 requirement.
2015-10-13 16:34:03 -04:00
Rob Rix
7825e83ed2
Add a readme for the prototype.
2015-10-13 16:33:39 -04:00
Rob Rix
b9d96134ea
Merge branch 'master' into side-by-side-diffs
2015-10-13 13:18:05 -04:00
Rob Rix
f1bb19be12
Grey backgrounds for replacements.
2015-10-13 13:17:18 -04:00
Josh Vera
bd4f1e7fc1
Merge pull request #83 from github/recur-into-keyed-terms-with-equal-keys
...
Recur into Keyed terms with equal keys
2015-10-13 13:16:56 -04:00
joshvera
d2d2412260
Merge branch 'master' into recur-into-indexed-terms-of-equal-length
2015-10-13 13:03:13 -04:00
Matt Diephouse
692bb05a4e
Merge pull request #96 from github/generalize-array-extension
...
Generalize array extension
2015-10-13 12:48:20 -04:00
Rob Rix
c0ab5abd9f
Drop the outline from replacements.
2015-10-13 12:44:25 -04:00
Rob Rix
fad02bab81
Give replacements a background colour.
2015-10-13 11:47:07 -04:00
Rob Rix
4ed33b485a
Background colours for insertions/deletions.
2015-10-13 11:43:25 -04:00
Rob Rix
2a671d5403
Change up the outline colours.
2015-10-13 11:43:17 -04:00
Rob Rix
67a19682e8
HIghlight replacements.
2015-10-13 11:25:20 -04:00
Rob Rix
7aab1da72c
Shift things to either side.
2015-10-13 11:24:55 -04:00
Rob Rix
dd05a2d5ee
Skip empty branches.
2015-10-13 11:24:08 -04:00
Rob Rix
91093f1aac
Only wrap elements that exist.
2015-10-13 11:22:56 -04:00
Rob Rix
ec9c29e29d
Only add children that exist.
2015-10-13 11:22:34 -04:00
Rob Rix
b10f4e2507
Don’t float things.
2015-10-13 11:20:54 -04:00
Rob Rix
b5f8516ab7
Leaves are wrapped in paragraphs.
2015-10-13 11:16:52 -04:00
Rob Rix
6a9e71fcd5
Arrays wrap their children in <li> elements.
2015-10-13 11:15:33 -04:00
Rob Rix
69568fb622
Arrays add <ol> elements.
2015-10-13 11:15:23 -04:00
Rob Rix
208238ae6e
Add a function to wrap a node in another node.
2015-10-13 11:10:54 -04:00
Rob Rix
0dcecb9a00
Rename the DOM variable.
2015-10-13 11:09:30 -04:00
Rob Rix
f236cc9a52
Remove the left/right elements.
2015-10-13 11:08:12 -04:00
Rob Rix
90d3bee821
Disallow floating past other elements.
2015-10-13 11:07:55 -04:00
Rob Rix
27b5007eff
Style insertions/deletions a little.
2015-10-13 11:07:40 -04:00
Rob Rix
205449e197
Insert the diffs into a #diff element.
2015-10-13 11:05:13 -04:00
Rob Rix
d653790ee3
Add diffs to the body.
2015-10-13 11:04:21 -04:00
Rob Rix
6050677c3d
Ignore other keys, apparently.
2015-10-13 11:03:37 -04:00
Rob Rix
b8c5789786
Add before/after states.
2015-10-13 11:03:27 -04:00
Rob Rix
5d864a7f3d
Add replacements to the DOM.
2015-10-13 11:01:32 -04:00
Rob Rix
984858bb9c
Careful with your null checks, there.
2015-10-13 11:00:38 -04:00
Rob Rix
82918f0f4b
Add deletions.
2015-10-13 11:00:29 -04:00
Rob Rix
c7cc290f1d
Add insertions.
2015-10-13 10:59:45 -04:00
Rob Rix
549f482ebe
yes, she knows it’s a multipass
2015-10-13 10:57:24 -04:00
Rob Rix
cf64fbb7c7
Prefix categories.
2015-10-13 10:57:07 -04:00
Rob Rix
724e875a8e
Add categories.
2015-10-13 10:57:01 -04:00
Rob Rix
fff6bcf2fe
Add nodes’ text content.
2015-10-13 10:56:34 -04:00
Rob Rix
869322c69b
Tweak the fixture format.
2015-10-13 10:43:31 -04:00
Rob Rix
c5f2832663
Insert elements into the DOM.
2015-10-13 10:25:51 -04:00
Rob Rix
e9e6fe859e
Recur through arrays.
2015-10-13 10:25:35 -04:00
Rob Rix
0f3bc75982
Construct and return a div.
2015-10-13 10:17:17 -04:00
Rob Rix
b3c4daf904
Semicolons.
2015-10-13 10:16:54 -04:00
Rob Rix
80c0443820
Abbreviate the JSON for Info.
2015-10-13 09:49:56 -04:00
Rob Rix
26aabe9c58
Call the faux sum type thing.
2015-10-13 09:47:52 -04:00
Rob Rix
161b0b86e5
Add a function doing faux sum typing on JSON.
2015-10-13 09:47:47 -04:00
Rob Rix
afda174752
Rename the file.
2015-10-13 01:02:05 -04:00
Rob Rix
7fedcb2331
Generalize the Array extension to RangeReplaceableCollectionType.
2015-10-13 01:01:32 -04:00
Rob Rix
a45e286594
🔥 String.swift.
...
Unused.
2015-10-13 00:58:35 -04:00
Rob Rix
c72a5e2e85
Rename Prelude.swift to Optional.swift.
2015-10-13 00:56:27 -04:00
Rob Rix
27126cabf7
Use Prelude’s function composition operator.
2015-10-13 00:56:13 -04:00
Rob Rix
58bdd153cb
I think fix
was just unused.
2015-10-13 00:55:49 -04:00
Rob Rix
4580dfae7f
Use Prelude’s const.
2015-10-13 00:55:30 -04:00
Rob Rix
d32ac4c789
Use Prelude’s id.
2015-10-13 00:55:20 -04:00
Rob Rix
94182aac35
Everything links against the dependencies.
2015-10-13 00:53:54 -04:00
Rob Rix
0691637f66
Bump Stream to fix a runtime deadlock.
2015-10-13 00:52:41 -04:00
Rob Rix
5bf82fd366
🔥 Memo and Stream.
2015-10-13 00:51:43 -04:00
Rob Rix
cc7538bd40
Link against the dependencies.
2015-10-13 00:50:15 -04:00
Rob Rix
c9794d6c08
Add the other dependencies to the workspace.
2015-10-13 00:45:53 -04:00
Rob Rix
b06b241848
Bump Stream.
2015-10-13 00:45:45 -04:00
Rob Rix
2aa47c80b7
Add Stream to the workspace.
2015-10-13 00:43:33 -04:00
Rob Rix
d96c2b1629
Bump Stream.
2015-10-13 00:43:28 -04:00
Rob Rix
bacd52dda7
Include Stream.
2015-10-13 00:20:33 -04:00
Rob Rix
dd0e21866c
Move doubt-swift’s dependencies into its group.
2015-10-13 00:19:56 -04:00
Rob Rix
d2be94c409
🔥 most of the custom operators.
2015-10-13 00:06:15 -04:00
Rob Rix
46df3daa08
🔥 Parse.swift.
2015-10-13 00:05:16 -04:00
Rob Rix
48ce6b7a7f
Recur into Keyed nodes with equal keys.
2015-10-09 20:38:48 -04:00
Rob Rix
83b95a0e5d
Correct the comment.
2015-10-09 20:24:42 -04:00
Rob Rix
d0ee908d54
Recur into indexed terms of equal length.
2015-10-09 20:24:39 -04:00
Rob Rix
962e3fda24
Switch over a/b’s syntaxes.
2015-10-09 20:24:30 -04:00
Rob Rix
9e7b8275b9
Rearrange the decisions in .Recursive evaluation.
2015-10-09 20:22:38 -04:00
Rob Rix
b1cc34bf2b
doubt-json uses the construction conveniences.
2015-10-09 18:09:38 -04:00
Rob Rix
74e3caa9ce
doubt-swift uses the construction conveniences.
2015-10-09 18:09:32 -04:00
Rob Rix
290ff8853c
SESTests uses the constructor conveniences.
2015-10-09 18:09:15 -04:00
Rob Rix
67d861839f
SyntaxConvertible extension methods are public.
2015-10-09 18:07:31 -04:00
Rob Rix
3cf5ce3b43
Construct Fix directly in discardNullTerms
.
2015-10-09 18:05:50 -04:00
Rob Rix
da8d51e9ee
Free is SyntaxConvertible.
2015-10-09 18:04:29 -04:00
Rob Rix
13eff7f9df
Fix is SyntaxConvertible.
2015-10-09 18:03:23 -04:00
Rob Rix
30d594b4a3
SyntaxConvertible types can be constructed with shorthands.
2015-10-09 18:02:25 -04:00
Rob Rix
cdc1fbb99a
Add a protocol for Syntax wrapper construction.
2015-10-09 18:02:11 -04:00
Rob Rix
fed06df766
Replace the JSON with a more compact representation.
2015-10-09 14:31:58 -05:00
Rob Rix
d33703fd00
Flatten the Free representation.
2015-10-09 14:31:10 -05:00
Rob Rix
396624e9e4
Revert "Wrap Fix.JSON in a dictionary."
...
This reverts commit dbb75aa6beace787d411dab7392e75bc37ac14c2.
2015-10-09 14:29:30 -05:00
Rob Rix
f8f055907f
Add left/right divs.
2015-10-09 14:27:44 -05:00
Rob Rix
5a1059832c
Space.
2015-10-09 13:36:38 -05:00
Rob Rix
83e228f1aa
Parse the response text.
2015-10-09 13:36:18 -05:00
Rob Rix
bfffe03d81
Add a simple scaffold web page loading the doubt-swift JSON output fixture.
2015-10-09 13:31:06 -05:00
Rob Rix
8aa31288e5
Add a fixture with JSON output from doubt-swift.
2015-10-09 13:30:40 -05:00
Rob Rix
e2ae3dc533
Print Swift diffs as JSON.
2015-10-09 09:21:42 -05:00
Rob Rix
7c6481ef47
Print JSON diffs as JSON.
2015-10-09 09:20:46 -05:00
Rob Rix
e045a9063f
Serialization of JSON to NSData.
2015-10-09 09:18:05 -05:00
Rob Rix
07279ca344
JSON can be converted back to an object.
2015-10-09 09:17:57 -05:00
Rob Rix
23133fe3e8
JSONLeaf is CustomJSONConvertible.
2015-10-09 09:14:07 -05:00
Rob Rix
56ef476f70
JSONLeaf has a section header for CustomStringConvertible.
2015-10-09 09:13:09 -05:00
Rob Rix
a9dcb801f2
Free has a JSON property when A is CustomJSONConvertible and B is Patch<A>.
2015-10-09 09:11:48 -05:00
Rob Rix
b422f7d9e4
Free has a unary JSON method when A is CustomJSONConvertible.
2015-10-09 09:08:35 -05:00
Rob Rix
86c92e143a
Fix has a JSON property when A is CustomJSONConvertible.
2015-10-09 09:07:00 -05:00
Rob Rix
5fc16e86f8
Patch has a JSON property when A is CustomJSONConvertible.
2015-10-09 09:06:06 -05:00
Rob Rix
4512b6f2e7
Scope the JSON constructor correctly.
2015-10-09 09:02:31 -05:00
Rob Rix
05e1b97c90
I’m very confused as to how this has remained broken.
2015-10-09 09:02:02 -05:00
Rob Rix
bf7838170e
Wrap Fix.JSON in a dictionary.
2015-10-09 08:45:23 -04:00
Rob Rix
bf4abc5eaa
Infer the scope in Syntax.JSON.
2015-10-09 08:44:16 -04:00
Rob Rix
ea29b2846a
Construct Patch.JSON using dictionary literals.
2015-10-09 08:43:57 -04:00
Rob Rix
ce1ef77f49
Construct Info.JSON using dictionary literals.
2015-10-09 08:43:43 -04:00
Rob Rix
ed9dfd2f34
Construct Free.JSON using dictionary literals.
2015-10-09 08:43:32 -04:00
Rob Rix
be8a93363a
Construct Category.JSON using a dictionary literal.
2015-10-09 08:43:22 -04:00
Rob Rix
4b2fea5d13
Change Patch’s JSON heading.
2015-10-09 08:41:08 -04:00
Rob Rix
ef01e25d47
Change Syntax’s JSON heading.
2015-10-09 08:40:57 -04:00
Rob Rix
3e47d529cc
Change Free’s JSON heading.
2015-10-09 08:39:57 -04:00
Rob Rix
02dc992476
Change Fix’s JSON heading.
2015-10-09 08:39:44 -04:00
Rob Rix
0cb6b01c9c
JSON is NilLiteralConvertible.
2015-10-09 08:38:26 -04:00
Rob Rix
669ebed71c
JSON is DictionaryLiteralConvertible.
2015-10-09 08:37:48 -04:00
Rob Rix
82e5c00e6a
JSON is ArrayLiteralConvertible.
2015-10-09 08:36:46 -04:00
Rob Rix
3fac63ddc9
JSON is StringLiteralConvertible.
2015-10-09 08:35:47 -04:00
Rob Rix
c6b233b2bb
JSON is BooleanLiteralConvertible.
2015-10-09 08:34:54 -04:00
Rob Rix
d0e7e41553
JSON is FloatLiteralConvertible.
2015-10-09 08:34:11 -04:00
Rob Rix
97e0e8accd
JSON is IntegerLiteralConvertible.
2015-10-09 08:33:24 -04:00
Rob Rix
64ad2dc854
Section mark for Category hashing.
2015-10-09 08:31:23 -04:00
Rob Rix
b6f6042e10
Section mark for Category comparisons.
2015-10-09 08:31:10 -04:00
Rob Rix
9e51c130c4
Section mark for Category equality.
2015-10-09 08:31:04 -04:00
Rob Rix
4117b3c710
Info is CustomJSONConvertible.
2015-10-09 08:30:33 -04:00
Rob Rix
327249cb94
Category is CustomJSONConvertible.
2015-10-09 08:30:21 -04:00
Rob Rix
bb8b968994
Add a CustomJSONConvertible protocol.
2015-10-09 08:28:08 -04:00
Rob Rix
e739fcd2a5
Move JSONConvertible into JSON.swift.
2015-10-09 08:27:12 -04:00
Rob Rix
a917331f35
Section mark for Info’s CustomDebugStringConvertible implementation.
2015-10-09 08:25:26 -04:00
Rob Rix
41a3b53542
Section mark for Info’s AlgebraicHashable implementation.
2015-10-09 08:25:16 -04:00
Rob Rix
5b1b358d42
Section header for Info equality.
2015-10-09 08:21:45 -04:00
Rob Rix
341e18e84d
Patch encodes its cases inline.
2015-10-08 07:31:43 -04:00
Rob Rix
0ebed9599b
Free.Roll encodes its case explicitly.
2015-10-08 07:30:34 -04:00
Rob Rix
7dd861169f
Free.Pure encodes its case explicitly.
2015-10-08 07:30:02 -04:00
Rob Rix
5610b9737c
Parametric JSON conversion for Patch.
2015-10-08 07:28:03 -04:00
Rob Rix
d8e8d4d91f
Parametric JSON conversion for Fix.
2015-10-08 07:23:56 -04:00
Rob Rix
22b77ecd76
Parametric JSON conversion for Free.
2015-10-08 07:21:08 -04:00
Rob Rix
44d2804367
Parametric JSON conversion for Syntax.
2015-10-08 07:19:37 -04:00
Rob Rix
f512e665ef
Section header for hashing.
2015-10-08 07:15:52 -04:00
Rob Rix
a3341a71cb
JSON is JSONConvertible.
2015-10-08 07:13:05 -04:00
Rob Rix
04cc6607f3
Add JSONConvertible.
2015-10-08 07:10:13 -04:00
Rob Rix
0f09ea2201
The tests do not depend on SourceKitten.
2015-10-08 07:06:46 -04:00
Rob Rix
488d214503
JSON is Equatable.
2015-10-08 07:06:16 -04:00
Rob Rix
b182f9cd41
Share the doubt-json scheme.
2015-10-07 20:08:56 -04:00
Rob Rix
c2f847ba34
Add fixtures for doubt-json.
2015-10-07 20:08:44 -04:00
Rob Rix
97e8f1725f
JSONLeaf is CustomStringConvertible.
2015-10-07 20:08:34 -04:00
Rob Rix
f1cbb6d642
Compute the diff between two JSON files.
2015-10-07 19:43:22 -04:00
Rob Rix
551fb2b03d
JSONLeaf is Equatable.
2015-10-07 19:43:00 -04:00
Rob Rix
a41c620b0c
Merge branch 'shortest-edit-script-in-algorithm' into diff-json
...
Conflicts:
prototype/Doubt/Algorithm.swift
prototype/Doubt/Category.swift
2015-10-07 19:41:14 -04:00
Rob Rix
c60ce4052c
Compute the term for a given JSON node.
2015-10-07 19:38:24 -04:00
Rob Rix
7953cbed82
Spacing.
2015-10-07 19:36:58 -04:00
Rob Rix
eb62a4e08f
Dictionary.init(elements:) is public.
2015-10-07 19:36:53 -04:00
Rob Rix
16a933af86
Term typealias.
2015-10-07 19:36:43 -04:00
Rob Rix
6efa8249cd
Extension to construct JSON
with a path.
2015-10-07 19:32:02 -04:00
Rob Rix
ea8a4ee360
Link Doubt explicitly.
...
Otherwise dependencies don’t get rebuilt.
2015-10-07 19:27:17 -04:00
Rob Rix
9c98bc187a
BoundsCheckedArray.init is public.
2015-10-07 19:26:35 -04:00
Rob Rix
55a54be79f
Add a JSONLeaf type.
2015-10-07 19:21:26 -04:00
Rob Rix
e26062e107
Stub in a doubt-json target.
2015-10-07 19:20:40 -04:00
Rob Rix
a474ad26c3
Move BoundsCheckedArray into the framework.
2015-10-07 19:18:59 -04:00
Rob Rix
63edfe863f
Empty brackets are empty.
2015-10-07 17:47:45 -04:00
Rob Rix
3787f735fb
Don’t add spaces after separators.
2015-10-07 17:42:43 -04:00
Rob Rix
8d7968eb14
Pretty-print the resulting diff.
2015-10-07 17:37:20 -04:00
Rob Rix
f9de814a35
No need to compute layouts we’re not going to use.
2015-10-07 17:36:59 -04:00
Rob Rix
420dd640b8
joinWithSeparator can introduce newlines.
2015-10-07 17:31:07 -04:00
Rob Rix
15c93699d2
Flattening distributes through nesting.
2015-10-07 17:25:37 -04:00
Rob Rix
b8c17d62c1
Fix a find/replace error.
2015-10-07 17:25:15 -04:00
Rob Rix
3b8b10a4a2
Test that empty docs have empty layout.
2015-10-07 17:22:53 -04:00
Rob Rix
1d8ceac332
Doc is CustomDebugStringConvertible.
2015-10-07 17:20:20 -04:00
Rob Rix
14a2d9bc1c
Patch is CustomDocConvertible.
2015-10-07 17:20:13 -04:00
Rob Rix
2a8e017282
Free is CustomDocConvertible.
2015-10-07 17:20:09 -04:00
Rob Rix
804e831705
🔥 SwiftTests.
...
This was not really testing anything anyway.
2015-10-07 17:20:02 -04:00
Rob Rix
37e204a1e3
Fix is CustomDocConvertible.
...
It simply defers it to Syntax.
2015-10-07 17:19:56 -04:00
Rob Rix
519b8477fd
Diffing by key handles equal terms correctly.
2015-10-07 17:19:50 -04:00
Rob Rix
0ad285fb26
Document the Recursive operation a little.
2015-10-07 13:28:16 -04:00
Rob Rix
06c456f1cd
Document dictionary diffing as an approach stemming from set reconciliation.
2015-10-07 13:25:02 -04:00
Rob Rix
21ac5822a0
Sort categories alphabetically.
2015-10-07 13:20:41 -04:00
Rob Rix
f8b89bd93b
Category is Comparable.
2015-10-07 13:20:22 -04:00
Rob Rix
aef4c32754
Don’t bother destructuring tags.
2015-10-07 13:20:09 -04:00
Rob Rix
ba650f8080
Handle the zero-category case with a where clause.
2015-10-07 13:19:49 -04:00
Rob Rix
4bcc773fc6
🔥 chaff.
2015-10-07 13:13:51 -04:00
Rob Rix
c2b00c2230
Nominate the best interior edge using compare-parametric min.
2015-10-07 13:13:32 -04:00
Rob Rix
47dec5546d
Restore the compare-parametric min
function.
2015-10-07 13:09:22 -04:00
Rob Rix
10ddaab0ed
Use values
instead of mapping.
2015-10-07 13:04:03 -04:00
Rob Rix
ecef6f8370
Rename FreeAlgorithm
to Algorithm
.
2015-10-07 13:00:54 -04:00
Rob Rix
b8b5a26b46
Update doc comments.
2015-10-07 13:00:17 -04:00
Rob Rix
fa7a89c247
Rename Algorithm to Operation.
2015-10-07 12:59:22 -04:00
Rob Rix
1d7286a6a2
Reference the module map in the build settings.
2015-10-07 08:52:32 -04:00
Rob Rix
a8e38b1aa9
Add a module map.
2015-10-07 08:52:26 -04:00
Rob Rix
0b920df272
Diffing by key handles equal terms correctly.
2015-10-07 08:47:37 -04:00
Rob Rix
7852d8a515
Diffs have an inverse.
2015-10-07 08:43:30 -04:00
Rob Rix
0af93b4c68
Patches have an inverse.
2015-10-07 08:41:54 -04:00
Rob Rix
8a9f74a0ff
Use discardNullTerms to compute both states.
2015-10-06 21:39:11 -04:00
Rob Rix
321622d553
Extract the discarding of null terms into a private helper function.
2015-10-06 21:38:44 -04:00
Rob Rix
e1dd859db9
Implicit parameters.
2015-10-06 21:36:22 -04:00
Rob Rix
ee969a75fa
Compute the after state of diffs.
2015-10-06 21:35:47 -04:00
Rob Rix
b04d71ede3
Compute the before-state of diffs.
...
This is `Optional`, as some diffs have unrecoverable before states. For
example, the insertion of a term has no before state, but can still
produce a valid before state if it occurs within the context of an
`Indexed` or `Keyed` node.
However, certain malformed diffs (such as `.Pure(.Insert(…))` in
isolation) may lack a valid before state, and thus the public API has
to reflect this.
2015-10-06 21:35:19 -04:00
Rob Rix
75aaebe834
Free
has a Term
typealias when appropriate.
2015-10-06 21:32:38 -04:00
Rob Rix
85ac68d232
Document why PatchConvertible.
2015-10-06 21:25:21 -04:00
Rob Rix
6b3c66d801
Patch is trivially PatchConvertible.
2015-10-06 21:24:43 -04:00
Rob Rix
46f3f9431b
Add a PatchConvertible protocol to enable constrained extensions.
2015-10-06 21:24:01 -04:00
Rob Rix
eec173c560
Pass fixtures to the tool.
2015-10-06 21:17:17 -04:00
Rob Rix
6f7552bae0
Add a couple of fixtures.
2015-10-06 21:17:09 -04:00
Rob Rix
e736116211
Evaluate the algorithm.
2015-10-06 21:02:00 -04:00
Rob Rix
2b9993c5f4
Treat protocols as groups.
2015-10-06 21:01:53 -04:00
Rob Rix
38c50d4e4a
Term is not a proper noun any more.
2015-10-06 20:53:35 -04:00
Rob Rix
e152d8702a
/dev/null -> nil
...
`git difftool` will invoke us with /dev/null when a file has been
deleted.
2015-10-06 20:48:53 -04:00
Rob Rix
b3324a6c5f
Drop null JSON.
2015-10-06 20:46:24 -04:00
Rob Rix
7e4ca06cbc
Indexed, not Branch.
2015-10-06 20:45:50 -04:00
Rob Rix
706654552f
In, not Roll.
2015-10-06 20:45:37 -04:00
Rob Rix
771f03f1fa
Indentation.
2015-10-06 20:43:27 -04:00
Rob Rix
8a6a39f06a
Construct terms for section headings.
2015-10-06 20:43:23 -04:00
Rob Rix
87d547a670
Wrap constructors in .In.
2015-10-06 20:43:02 -04:00
Rob Rix
40ecf24c9e
Fix, not Term.
2015-10-06 20:39:57 -04:00
Rob Rix
f131f40752
Construct the terms in Fix
.
2015-10-06 20:39:51 -04:00
Rob Rix
ee151d0edc
Compute the diff in FreeAlgorithm
.
2015-10-06 20:39:37 -04:00
Rob Rix
c7d9216433
Info is StringConvertible.
2015-10-06 20:38:00 -04:00
Rob Rix
c16a8b3af2
Combine the extensions.
2015-10-06 20:35:52 -04:00
Rob Rix
1059a00db0
🔥 AnyEquatable.
2015-10-06 19:20:16 -04:00
Rob Rix
939a714807
🔥 AnyHashable.
2015-10-06 19:20:06 -04:00
Rob Rix
fb41713906
Replace roll()
with Diff()
.
2015-10-06 17:48:17 -04:00
Rob Rix
47dd0b4849
Construct with Diff(), not copy().
2015-10-06 17:47:10 -04:00
Rob Rix
c9d51049df
Construct with Diff(), not copy().
2015-10-06 17:47:04 -04:00
Rob Rix
de61021d32
Once more, call it Term.
2015-10-06 17:46:37 -04:00
Rob Rix
f51f6f39a2
Call it Term.
2015-10-06 17:46:02 -04:00
Rob Rix
22773917a3
Construct Free
with Fix
.
2015-10-06 17:45:24 -04:00
Rob Rix
d097f14fcb
Explain SES implementation details a little.
2015-10-06 17:36:49 -04:00
Rob Rix
6030731cc8
Extend the graph and return Stream.Nil
at the end.
2015-10-06 17:36:41 -04:00
Rob Rix
57fb8ff251
Document the purpose of the matrix.
2015-10-06 17:29:33 -04:00
Rob Rix
833d27c54a
Test an insertion at the end.
2015-10-06 17:29:06 -04:00
Rob Rix
6e799e0b79
Test a deletion at the end.
2015-10-06 17:28:25 -04:00
Rob Rix
d7db7415dc
Patches have different costs.
2015-10-06 17:08:22 -04:00
Rob Rix
4fdbcf948f
Patches have a cost.
...
This charges `Replace` patches at a higher cost than `Insert`/`Delete`
patches to avoid spurious replacements.
2015-10-06 17:07:16 -04:00
Rob Rix
bcc3da35f9
Recur at the corner.
...
This can’t be right.
2015-10-06 17:01:27 -04:00
Rob Rix
c7aad22838
Insert/delete/recur based on the edge being followed.
2015-10-06 17:01:17 -04:00
Rob Rix
c2d4c96d62
Recurrence checks for equality.
2015-10-06 16:59:29 -04:00
Rob Rix
a1a832012e
Implement a function copying terms into diffs.
2015-10-06 16:59:11 -04:00
Rob Rix
a628177722
Move SES to its own file.
2015-10-06 16:50:23 -04:00
Rob Rix
8e0cafbac4
Info’s debug description uses its categories’ debug descriptions.
2015-10-06 16:49:14 -04:00
Rob Rix
606d721dea
Category is CustomDebugStringConvertible.
2015-10-06 16:48:44 -04:00
Rob Rix
ee8794fd81
Patch is CustomDebugStringConvertible.
2015-10-06 16:45:36 -04:00
Rob Rix
0237d5991a
Fix is CustomDebugStringConvertible.
2015-10-06 16:44:00 -04:00
Rob Rix
29d889ef95
Free is CustomDebugStringConvertible.
2015-10-06 16:43:20 -04:00
Rob Rix
64830960e5
Info is CustomDebugStringConvertible.
2015-10-06 16:41:54 -04:00
Rob Rix
db63777dd9
Represent Insert/Delete explicitly in Patch.
...
Fixes #60 .
2015-10-06 16:31:44 -04:00
Rob Rix
17191dd8ab
Correct the tests to equate arrays of diffs by element, and not by memory (!).
...
- rdar://22996431
- rdar://22996542
2015-10-06 16:23:48 -04:00
Rob Rix
3cc732f54e
Rename DiffTests to SESTests.
2015-10-06 14:25:18 -04:00
Rob Rix
0a6a136bff
🔥 Vertex & VertexTests.
2015-10-06 14:24:56 -04:00
Rob Rix
9b6a3f6e36
Remove the fixme because it has been fixed.
2015-10-06 14:23:59 -04:00
Rob Rix
2726a43c83
Lazily, not eagerly.
...
`Memo.init` selected the eager version, of course, since the lazy
version takes a closure.
2015-10-06 14:19:39 -04:00
Rob Rix
1658219d59
Document constructRowMajor
.
2015-10-06 14:17:14 -04:00
Rob Rix
092087fc54
Extract row-major ordering into a private function.
2015-10-06 14:15:21 -04:00
Rob Rix
934390a0d5
Retrieve in row-major order.
2015-10-06 14:11:36 -04:00
Rob Rix
d12c95e296
Insert in row-major order.
2015-10-06 14:11:26 -04:00
Rob Rix
e178745c56
Cache the costs for the rest of the graph at each vertex.
2015-10-06 13:33:38 -04:00
Rob Rix
6c8ce1bcb2
Append, don’t subscript.
...
Subscripting only replaces, never appends.
2015-10-06 13:29:43 -04:00
Rob Rix
a9349c33dc
Port the SES example from the paper.
2015-10-06 13:27:06 -04:00
Rob Rix
48a0935d5c
Use the little API for deletion fixtures.
2015-10-06 13:26:44 -04:00
Rob Rix
69d42e121c
Port insertion/deletion in the middle.
2015-10-06 13:25:56 -04:00
Rob Rix
9761ba3d98
Port insertion/deletion at head.
2015-10-06 13:25:27 -04:00
Rob Rix
b23a8ac6f7
Rename copy
to roll
so we can actually call it from within the tests.
2015-10-06 13:25:09 -04:00
Rob Rix
1473d5648b
Port the pure insert/delete tests.
2015-10-06 13:22:54 -04:00
Rob Rix
0d8c080f35
Add a little API for diffs.
2015-10-06 13:22:37 -04:00
Rob Rix
5a86df7a8d
Assert equality using Assertions.assert.
2015-10-06 13:16:43 -04:00
Rob Rix
cd2faed7ce
Add a typealias for diffs.
2015-10-06 13:16:32 -04:00
Rob Rix
ea09799e58
import Assertions.
2015-10-06 13:16:23 -04:00
Rob Rix
b3e6a92224
The tests link against Assertions.framework.
2015-10-06 13:16:15 -04:00
Rob Rix
8825a92ec7
Include Assertions in the workspace.
2015-10-06 13:16:05 -04:00
Rob Rix
1c4a880b09
Add Assertions as a submodule.
2015-10-06 13:13:53 -04:00
Rob Rix
286b91a88d
Add a wrapper function to compute the SES.
2015-10-06 13:12:53 -04:00
Rob Rix
1ecafbff43
Import Doubt testably.
2015-10-06 13:10:45 -04:00
Rob Rix
648945fee0
FreeAlgorithm.evaluate()
calls out to SES
.
2015-10-06 13:09:17 -04:00
Rob Rix
d2b3f16cfc
Document SES.
2015-10-06 13:08:17 -04:00
Rob Rix
90b404b3ee
Extract the SES function.
2015-10-06 13:05:49 -04:00
Rob Rix
6cef3b9884
Matrix is public.
2015-10-06 13:00:07 -04:00
Rob Rix
bdabcc5c24
Matrix.values is private.
2015-10-06 13:00:01 -04:00
Rob Rix
e4689b9102
Fix hashing is public.
2015-10-06 12:59:13 -04:00
Rob Rix
c35e31ad4a
Define the Term fixtures using Fix.
2015-10-06 12:58:07 -04:00
Rob Rix
daf5f8ed9e
Add a typealias for the Term fixtures.
2015-10-06 12:57:48 -04:00
Rob Rix
900d364057
Link to @patrickt’s tutorials on recursion schemes.
2015-10-06 12:53:30 -04:00
Rob Rix
675d355b96
Document iterate
.
2015-10-06 12:47:33 -04:00
Rob Rix
67d35078d8
Call a Term
a Term
.
2015-10-06 12:25:40 -04:00
Rob Rix
cce1ed61aa
Document FreeAlgorithm.init
.
2015-10-06 12:24:58 -04:00
Rob Rix
511ef4d1a1
Document that out-of-bound indices are safe.
2015-10-06 12:20:58 -04:00
Rob Rix
25f29c328c
Document Matrix
a little.
2015-10-06 12:19:59 -04:00
Rob Rix
cb33717fb9
🔥 Syntax.reduce
.
2015-10-06 12:17:51 -04:00
Rob Rix
69b8028750
🔥 Term.swift.
2015-10-06 12:17:38 -04:00
Rob Rix
b1af1a63a4
🔥 Diff.swift.
2015-10-06 12:17:14 -04:00
Rob Rix
4f95704c97
Remove an obsolete fixme.
2015-10-06 12:16:37 -04:00
Rob Rix
c322386cb4
Recur in dictionary diffing.
2015-10-06 12:16:19 -04:00
Rob Rix
ebca63b01e
Recur in SES.
2015-10-06 12:15:48 -04:00
Rob Rix
e14c5a7f9d
FreeAlgorithm
doesn’t need equals
or recur
when A: Equatable
& B: FreeConvertible
.
2015-10-06 12:15:28 -04:00
Rob Rix
36c8fa03c9
FreeAlgorithm
doesn’t need recur
when B: FreeConvertible
.
2015-10-06 12:15:08 -04:00
Rob Rix
1fcba3fca0
recur
actually has to return Diff
.
...
`B` will only be identified with `Diff` when `B: FreeConvertible`.
2015-10-06 12:12:47 -04:00
Rob Rix
131ae72f1a
Note that we can’t call recur
in the Recursive
strategy.
...
Paradox.
2015-10-06 12:09:18 -04:00
Rob Rix
ac0b142a40
Recur through a parameter pairing Term
s.
2015-10-06 12:07:56 -04:00
Rob Rix
f30ebc8cdb
Diff/Term typealiases are public.
2015-10-06 12:03:58 -04:00
Rob Rix
d020d17f60
Note that we need to recur in SES.
2015-10-06 12:01:39 -04:00
Rob Rix
6a11a88dea
Compute the best diff to continue with.
2015-10-06 12:01:14 -04:00
Rob Rix
eb2b242d3a
Extract the nominated next diff into a temporary.
2015-10-06 11:58:36 -04:00
Rob Rix
28d5612c44
Use costOfStream
to implement cons
.
2015-10-06 11:57:37 -04:00
Rob Rix
1ac2f8d8c0
Add a function to compute the cost of the rest of the graph.
2015-10-06 11:57:04 -04:00
Rob Rix
d7c36a30c9
Remove here
.
2015-10-06 11:55:55 -04:00
Rob Rix
84a1122ed7
Write cost
as a func
.
2015-10-06 11:55:15 -04:00
Rob Rix
cc6627bb52
Write cons
as a func
.
2015-10-06 11:54:42 -04:00
Rob Rix
c0ab03e73d
Compute the cost of the remainder of the stream.
2015-10-06 11:52:56 -04:00
Rob Rix
97b4c59a81
Rewrite the sum to wrap stream construction.
2015-10-06 11:52:13 -04:00
Rob Rix
3cdc9bd745
Simplify the Stream-unconsing.
2015-10-06 11:48:50 -04:00
Rob Rix
5e144553fd
Add a function to compute the cost of the rest of the diff.
2015-10-06 11:48:04 -04:00
Rob Rix
4e6dd07e78
Extract the diff.
2015-10-06 11:46:30 -04:00
Rob Rix
3919a4c093
Interpret free algorithms where we’re computing a diff.
2015-10-06 11:43:17 -04:00
Rob Rix
6e1a7c6794
Memoize a cost for diffs.
2015-10-06 11:41:37 -04:00
Rob Rix
03c5f0b644
Stub diffing in the middle of the graph.
2015-10-06 11:40:54 -04:00
Rob Rix
1d993bb65b
Diff along the right of the edit graph.
2015-10-06 11:40:42 -04:00
Rob Rix
c090fc33d5
Diff along the bottom of the edit graph.
2015-10-06 11:39:34 -04:00
Rob Rix
f442f3594f
Stub in diffing with Matrix
.
2015-10-06 11:38:50 -04:00
Rob Rix
88030e217f
Short-circuit degenerate cases.
2015-10-06 11:30:41 -04:00
Rob Rix
8dd605bb54
Add a function computing the cost of a diff.
2015-10-06 11:30:21 -04:00
Rob Rix
b910fdba46
Section header for Syntax.map.
2015-10-06 11:08:39 -04:00
Rob Rix
286ff11f79
Rename iter
to iterate
.
2015-10-06 11:05:02 -04:00
Rob Rix
8800c57ca7
Oh yeah, method dispatch works too.
2015-10-06 11:04:36 -04:00
Rob Rix
8226285153
Implement iter
as a method.
2015-10-06 11:04:14 -04:00
Rob Rix
c0edc77185
Implement iter
by case analysis.
2015-10-06 11:03:03 -04:00
Rob Rix
3da765d32b
Identity.
2015-10-06 11:02:22 -04:00
Rob Rix
3d06b533bc
Implement iter
over Free
.
2015-10-06 11:02:15 -04:00
Rob Rix
24e113d2f0
The hash
property on Free
is public.
2015-10-06 11:00:47 -04:00
Rob Rix
0be3eeb8e1
Dictionary diffing should recur.
2015-10-06 09:28:30 -04:00
Rob Rix
3fb6f24d8b
Diff indexed terms.
2015-10-05 17:30:29 -04:00
Rob Rix
b08a51a360
Abbreviate further.
2015-10-05 17:29:20 -04:00
Rob Rix
071bf6bd6f
Stub in a matrix pairing the elements to be diffed.
2015-10-05 17:27:28 -04:00
Rob Rix
d00da3f90a
Remove evaluation from Algorithm.
2015-10-05 17:26:17 -04:00
Rob Rix
b7b56b1d01
Move the body of evaluation into FreeAlgebra.
2015-10-05 17:25:47 -04:00
Rob Rix
1ef04248cb
Bring the typealiases from Algorithm into FreeAlgorithm.
2015-10-05 17:25:17 -04:00
Rob Rix
3fdda99653
Matrix is a functor.
2015-10-05 17:18:40 -04:00
Rob Rix
0e8b74e830
Matrix has a private fieldwise constructor.
2015-10-05 17:18:35 -04:00
Rob Rix
81b6c172cf
Populate the matrix with a compute function.
2015-10-05 17:12:28 -04:00
Rob Rix
c935e4a3d9
Stub in a matrix of memoized values.
2015-10-05 17:11:56 -04:00
Rob Rix
9e2b6bd3b4
Document the ByIndex
case a bit more.
2015-10-05 14:54:03 -04:00
Rob Rix
b7ebabd529
Stub in ByIndex diffing.
2015-10-05 13:17:43 -04:00
Rob Rix
80ba5fb379
More thorough documentation of FreeAlgorithm
.
2015-10-05 13:15:23 -04:00
Rob Rix
437fbd269f
Algorithm is an operation.
2015-10-05 13:14:46 -04:00
Rob Rix
847216a942
Document some elements of FreeAlgorithm.
2015-10-05 13:05:31 -04:00
Rob Rix
49aa2b3dd5
Section headers.
2015-10-05 13:02:04 -04:00
Rob Rix
30d16f87e8
Remove the free diff
function.
2015-10-05 13:00:36 -04:00
Rob Rix
e2e6a0ea03
Note the need for SES.
2015-10-05 12:51:43 -04:00
Rob Rix
4b3b1ec3d4
Top-level construction of FreeAlgorithms from Terms.
2015-10-05 12:51:05 -04:00
Rob Rix
1af75347a1
Add a hack protocol to allow an ersatz same-type requirement.
2015-10-05 12:50:47 -04:00
Rob Rix
00ae25a932
Add a function computing the FreeAlgorithm for two terms.
2015-10-05 12:33:59 -04:00
Rob Rix
81e80eae50
Evaluation of FreeAlgorithm where A: Equatable.
2015-10-05 12:32:34 -04:00
Rob Rix
346a39fafc
Evaluation of FreeAlgorithm.
2015-10-05 12:32:21 -04:00
Rob Rix
fa3be5108e
FreeAlgorithm is a monad.
2015-10-05 12:30:10 -04:00
Rob Rix
c70ab9e9a4
FreeAlgorithm is a functor.
2015-10-05 12:29:35 -04:00
Rob Rix
eea4915d6a
Add a free monad over Algorithm
.
2015-10-05 12:19:55 -04:00
Rob Rix
8f9a47cd06
Simplify the evaluation of recursive algorithms.
2015-10-05 12:13:54 -04:00
Rob Rix
300f370bcb
Spacing.
2015-10-05 12:13:25 -04:00
Rob Rix
7834548250
Algorithm implements dictionary diffing.
2015-10-05 09:24:29 -04:00
Rob Rix
bd5deecce7
Spacing.
2015-10-02 17:49:03 -04:00
Rob Rix
fce352dd85
Document why copy
.
2015-10-02 17:48:58 -04:00
Rob Rix
51903b4434
Implement an interpreter for Algorithm.
2015-10-02 17:47:11 -04:00
Rob Rix
ad93456922
Algorithm is a Functor.
2015-10-02 17:34:14 -04:00
Rob Rix
f9dcf9569c
The Recursive case contains two Terms, not one.
2015-10-02 17:32:25 -04:00
Rob Rix
b30aa91502
Algorithm is public.
2015-10-02 17:30:09 -04:00
Rob Rix
1b13580eb3
Document the Recursive
case.
2015-10-02 17:29:13 -04:00
Rob Rix
bbd41b209d
Doc comments for the Term and Diff typealiases.
2015-10-02 17:25:52 -04:00
Rob Rix
f26d4349c7
Documentation comment for the Algorithm type.
2015-10-02 17:25:40 -04:00
Rob Rix
8da57b5e78
Stub in the language of diffing algorithms.
2015-10-02 17:21:51 -04:00
Rob Rix
20bea59868
Add a Keyed case to Syntax.
2015-10-02 17:18:38 -04:00
Rob Rix
6657c5c0a5
Fix the debug description.
2015-10-02 17:13:27 -04:00
Rob Rix
7c69de54bc
Rename Branch to Indexed.
2015-10-02 17:12:49 -04:00
Rob Rix
395fa8446f
Note my keen desire to 🔥 Syntax.reduce forever.
2015-10-02 17:11:35 -04:00
Rob Rix
5ff17c8fc0
Syntax.Branch holds an array again.
2015-10-02 17:11:02 -04:00
Rob Rix
ebb3f1350f
Conveniences for constructing insertions & deletions.
2015-10-02 16:53:43 -04:00
Rob Rix
ae7f30e922
Parameterized Patch hashing.
2015-10-02 16:50:59 -04:00
Rob Rix
ca6392e636
Parameterized Patch equality.
2015-10-02 16:49:04 -04:00
Rob Rix
9a19d477df
Parameterized Optional equality.
2015-10-02 16:48:44 -04:00
Rob Rix
40291e2715
Move the function composition operator into the Operators file.
2015-10-02 16:42:42 -04:00
Rob Rix
089bd51fb3
Rename the property.
2015-10-02 16:38:21 -04:00
Rob Rix
48c2112124
Add a property destructuring Patches.
2015-10-02 16:38:02 -04:00
Rob Rix
0c4fe23e78
Doc comment for Patch.
2015-10-02 16:36:05 -04:00
Rob Rix
5c10f5ccc9
Stub in Patch.
2015-10-02 16:34:00 -04:00
Rob Rix
76441c3775
Fix implements hash
where A is Hashable.
2015-10-02 16:31:49 -04:00
Rob Rix
bccc09d39b
Fix hashing.
2015-10-02 16:31:10 -04:00
Rob Rix
96e5cd0e7a
Abbreviate Fix equality.
2015-10-02 16:28:57 -04:00
Rob Rix
277757e3a2
Free implements hash
when A and B are Hashable.
2015-10-02 16:27:44 -04:00
Rob Rix
e4d0a41093
Express flatMap
with analysis
.
2015-10-02 14:36:01 -04:00
Rob Rix
b4479e3854
Express map
with analysis
.
2015-10-02 14:35:18 -04:00
Rob Rix
2b5b85e0b4
Define Free hashing.
2015-10-02 14:35:07 -04:00
Rob Rix
f14433871b
Parameterize by leaf hashing.
2015-10-02 14:33:41 -04:00
Rob Rix
3d40071b44
Give the hash parameter an external label.
2015-10-02 14:32:35 -04:00
Rob Rix
334bb3017e
The roll function doesn’t escape.
2015-10-02 14:29:45 -04:00
Rob Rix
7d49895796
Section headers for functor/monad instances.
2015-10-02 14:27:37 -04:00
Rob Rix
7e00f9297e
Implement case analysis for Free.
2015-10-02 14:26:53 -04:00
Rob Rix
de2dcf4bf4
== over Free.
2015-10-02 14:18:43 -04:00
Rob Rix
a0e77e2495
== over Fix.
2015-10-02 14:17:59 -04:00
Rob Rix
bc857f810b
Fix Equality.
2015-10-02 14:17:25 -04:00
Rob Rix
87994c824f
Free Equality.
2015-10-02 14:15:17 -04:00
Rob Rix
43bdcd45c9
Parameterize Syntax equality by leaf type equality.
2015-10-02 14:15:13 -04:00
Rob Rix
296dbeea8f
Add a section mark for Syntax equality.
2015-10-02 14:12:54 -04:00
Rob Rix
6d5fd97552
Add an external label for recurrence equality.
2015-10-02 14:12:46 -04:00
Rob Rix
45a7e372b5
Rename the recur parameter.
2015-10-02 14:12:19 -04:00
Rob Rix
f8c37695ae
Document Fix’s case.
2015-10-02 14:08:03 -04:00
Rob Rix
b2219feed7
Document Free’s cases.
2015-10-02 14:07:29 -04:00
Rob Rix
0a64dc8741
Free is indeed a Monad.
2015-10-02 14:03:34 -04:00
Rob Rix
97686157f3
Free is a Functor.
2015-10-02 13:59:55 -04:00
Rob Rix
e63ccff83f
Documentation for Free.
2015-10-02 13:54:39 -04:00
Rob Rix
ad3d4b6c3f
Backticks around types.
2015-10-02 13:54:34 -04:00
Rob Rix
0ff70be000
Stub in Free.
2015-10-02 13:43:43 -04:00
Rob Rix
da3c1041e0
Fix is public.
2015-10-02 13:42:55 -04:00
Rob Rix
bf75fcab61
Add Fix, the fixpoint of Syntax.
2015-10-02 13:21:43 -04:00
Rob Rix
cfb8cb92b9
Merge branch 'master' into optional-instead-of-empty
2015-10-02 13:06:42 -04:00
Rob Rix
ea5d9ef814
Merge branch 'master' into operators-alongside-operands
2015-10-02 13:05:23 -04:00
Rob Rix
cacba977dd
Expand on the documentation of Copy.
2015-10-02 13:02:51 -04:00
Rob Rix
a96a88cdf8
Document magnitude
a little.
2015-10-02 12:58:34 -04:00
Rob Rix
05a7c1a037
Remove Syntax.Empty.
2015-10-02 12:37:09 -04:00
Rob Rix
3cae5390b7
Inserts and Deletes Patch with nil.
2015-10-02 12:31:30 -04:00
Rob Rix
6eb840f795
Remove the Tree constructor wrappers.
2015-10-02 12:31:19 -04:00
Rob Rix
730790fec7
Patch states can be Optional.
2015-10-02 12:24:51 -04:00
Rob Rix
2ab10d6b3d
Empty Hashes.
2015-10-02 12:24:18 -04:00
Rob Rix
49721679b6
Move Term equality into its file.
2015-10-01 15:26:15 -04:00
Rob Rix
906e502def
Move Syntax equality into its file.
2015-10-01 15:25:49 -04:00
Rob Rix
4823a47f23
Rephrase parameterized equality as a static function.
2015-10-01 15:25:14 -04:00
Rob Rix
6a6b146863
Move Doc equality to its file.
2015-10-01 15:17:07 -04:00
Rob Rix
146f59bc23
Move Vertex equality to its file.
2015-10-01 15:16:25 -04:00
Rob Rix
91e119cde7
Diff’s Comparable implementation lives alongside it.
2015-10-01 15:15:30 -04:00
Rob Rix
bba8dacbc4
Some documentation comments.
2015-10-01 14:25:17 -04:00
Rob Rix
8961ee9168
Branch has only one child.
2015-10-01 14:08:13 -04:00
Rob Rix
0e7bc6b2b3
Stub in a ByIndex case for SES diffing.
2015-10-01 14:01:59 -04:00
Rob Rix
533e4578ea
Comma-separate.
2015-10-01 14:01:19 -04:00
Rob Rix
12663f1158
Add ByKey to Diff.
2015-10-01 13:54:23 -04:00
Rob Rix
dda95ed386
Require Term’s leaf type to be Equatable.
...
This is a bit of a hack.
2015-10-01 13:52:32 -04:00
Rob Rix
fb247732cc
Move diff equality into Diff.swift.
2015-10-01 11:34:17 -04:00
Rob Rix
8bac863ca0
Hash is AlgebraicHashable.
2015-10-01 10:46:25 -04:00
Rob Rix
009920606b
Add unordered hashing.
2015-10-01 10:45:47 -04:00
Rob Rix
cdd05ab556
Extract the calculation of the magnitude of a syntax node into a function.
2015-10-01 10:45:23 -04:00
Rob Rix
97da6a15e4
Document Diff’s cases.
2015-10-01 10:45:06 -04:00
Rob Rix
2394ea3545
Correct AnyEquatable equality.
2015-10-01 10:34:36 -04:00
Rob Rix
fae5fc5123
Correct Syntax.hash() to refer to Ordered.
2015-10-01 10:33:47 -04:00
Rob Rix
12491dde7a
AnyHashable convenience constructor.
2015-10-01 10:32:44 -04:00
Rob Rix
3ea42437f9
Abstract AnyHashable over AnyEquatable.
2015-10-01 10:31:18 -04:00
Rob Rix
39bbe4df42
AnyEquatable can unpack its value.
2015-10-01 10:29:48 -04:00
Rob Rix
72c1029d33
AnyHashable can unpack its value.
2015-10-01 10:28:24 -04:00
Rob Rix
079b3a479e
AnyEquatable.
2015-10-01 10:28:14 -04:00
Rob Rix
279aab6530
Rename Sequence to Ordered.
2015-10-01 10:09:44 -04:00
Rob Rix
a2a55531c9
AnyHashable.
2015-10-01 09:59:26 -04:00
Rob Rix
18d74a9d9c
Diff is AlgebraicHashable.
2015-10-01 09:54:56 -04:00
Rob Rix
0013475516
Terms of Hashable leaf type can be hashed.
2015-10-01 09:54:44 -04:00
Rob Rix
c698280fc2
Pass the hashing function for the Recur type in.
2015-10-01 09:53:30 -04:00
Rob Rix
1635b8ab8a
Info is AlgebraicHashable.
2015-10-01 09:46:02 -04:00
Rob Rix
5dd80cb0ce
Diff is defined over Term<Info>.
...
This enables diffs to operate on categorized Terms.
2015-09-30 16:05:39 -04:00
Rob Rix
84eeba6111
Info has a property for its Categories.
2015-09-30 16:02:01 -04:00
Rob Rix
d29e14508a
Info has a Set of Categories.
2015-09-30 16:01:47 -04:00
Rob Rix
1ed5fc0e88
Categories are Hashable.
2015-09-30 16:00:13 -04:00
Rob Rix
282f56fb90
Categories have an accessor for their tag.
2015-09-30 16:00:03 -04:00
Rob Rix
5abbd36a80
Replace Location with Info.
2015-09-30 15:58:01 -04:00
Rob Rix
ddbe0943ef
Location is Equatable.
2015-09-30 15:46:21 -04:00
Rob Rix
66281a6674
Document Literal Locations.
2015-09-30 15:46:16 -04:00
Rob Rix
0efffe3e3d
Add source locations.
2015-09-30 15:29:56 -04:00
Rob Rix
459bad4dd6
Categories are equatable.
2015-09-30 15:29:40 -04:00
Rob Rix
f3122f1bae
Move JSON construction of Term into doubt-swift.
2015-09-30 15:08:19 -04:00
Rob Rix
03d4fcfc53
Add Category.
2015-09-30 15:03:47 -04:00
Rob Rix
d7a8c64806
Abbreviate the properties.
2015-09-30 15:03:42 -04:00
Rob Rix
82720340ef
Wrap with Term().
2015-09-30 15:03:37 -04:00
Rob Rix
d8c718130b
Lose an annotation.
2015-09-30 15:03:30 -04:00
Rob Rix
a6358b22d4
Remove CustomHashConvertible.
2015-09-30 15:02:31 -04:00
Rob Rix
2d0991b91f
Abstract Term over a type parameter A.
2015-09-30 14:42:58 -04:00
Rob Rix
a2b9f9ce17
Implement Syntax equality using a function which expresses the equality of the functor.
2015-09-30 14:42:44 -04:00
Rob Rix
92d844f416
Extract the exception-for-control-flow ErrorType to global scope.
2015-09-30 14:40:30 -04:00
Rob Rix
88b677e1e0
Parameterize the type of Leaf.
2015-09-30 12:41:20 -04:00
Rob Rix
5529a502e3
Require Recur to be Hashable.
2015-09-30 12:40:49 -04:00
Rob Rix
de3ef64f48
Map using Hash.init.
2015-09-30 12:40:36 -04:00
Rob Rix
5fa07014a6
Replace all the other nodes with Branch.
2015-09-30 11:42:41 -04:00
Rob Rix
a0f562d25e
Leaves, not Literals.
2015-09-30 11:03:55 -04:00
Rob Rix
4712e1c2cc
Add CustomHashConvertible for non-Equatable objects that can be converted to Hashes.
2015-09-30 10:46:01 -04:00
Rob Rix
66b225fce3
Replace Case with a constructor.
2015-09-30 10:44:48 -04:00
Rob Rix
565800b1b0
Add a constructor for Int hashes.
2015-09-30 10:43:18 -04:00
Rob Rix
9841debe91
No longer need to disambiguate String.
2015-09-30 10:42:43 -04:00
Rob Rix
b581b8b71d
Rename String to Label.
2015-09-30 10:42:27 -04:00
Rob Rix
d9eb3f6a69
Don’t need to disambiguate Int now.
2015-09-30 10:40:45 -04:00
Rob Rix
0cdb09a964
Rename the Int case to Raw.
2015-09-30 10:40:28 -04:00
Rob Rix
66141c95af
Replace Literal/Variable with Leaf.
2015-09-30 10:36:25 -04:00
Rob Rix
1f253f4e12
Add a phantom type parameter to Syntax.
2015-09-30 10:31:48 -04:00
Rob Rix
308f81853d
Rename the Payload type to Recur.
2015-09-30 10:29:38 -04:00
Rob Rix
4348604e66
Remove the typealias.
2015-09-30 10:29:32 -04:00
Rob Rix
31d35c854b
Term is AlgebraicHashable.
2015-09-29 17:03:18 -04:00
Rob Rix
586def93cd
Syntax<A: AlgebraicHashable> implements hash
.
2015-09-29 17:03:11 -04:00
Rob Rix
7925347d21
Debug print abstraction bodies correctly.
2015-09-29 17:02:57 -04:00
Rob Rix
1cf92c94d0
Conveniences for labelled/numbered enum cases.
2015-09-29 17:02:35 -04:00
Rob Rix
f1c2f4b9e0
Algebraic hashing of RawRepresentable types whose RawValue is [Algebraic]Hashable.
2015-09-29 17:02:01 -04:00
Rob Rix
b60df96019
Construction of Hash from Hashable/AlgebraicallyHashable values.
2015-09-29 17:01:38 -04:00
Rob Rix
e32bb2af29
Add a protocol for algebraically hashable types.
...
They’ll get `hashValue` for free.
2015-09-29 17:00:52 -04:00
Rob Rix
278bba4f82
Add an algebraic Hash type.
2015-09-29 17:00:26 -04:00
Rob Rix
29de111b1c
How did this even build?
2015-09-29 12:57:17 -04:00
Rob Rix
60821016a2
Revert "Empty terms are copied, not patched."
...
This reverts commit 788dbaa07ceafc084dc0f10f74efc2aa2a6841ec.
2015-09-29 12:54:42 -04:00
Rob Rix
dfbfb9fe79
Short-circuit for equal terms.
2015-09-29 12:54:32 -04:00
Rob Rix
7d36421d6a
Empty terms are copied, not patched.
2015-09-29 12:53:04 -04:00
Rob Rix
94bcc7d3f0
Remove empty diffs.
2015-09-29 12:50:34 -04:00
Rob Rix
35581fa6d9
Resume using .Empty for Terms.
2015-09-29 12:49:36 -04:00
Rob Rix
50e8223f18
Whitespaaaace.
2015-09-29 12:49:19 -04:00
Rob Rix
c3e8d9a801
Remove Term.Empty.
2015-09-29 12:48:53 -04:00
Rob Rix
17271ff2ce
Add a constructor for empty terms.
2015-09-29 12:48:35 -04:00