2015-05-13 23:20:16 +00:00
|
|
|
chai = require 'chai'
|
|
|
|
chai.should()
|
2015-06-23 00:03:21 +00:00
|
|
|
expect = chai.expect
|
2015-05-13 23:20:16 +00:00
|
|
|
|
2015-06-23 14:35:06 +00:00
|
|
|
{listToVector, vectorToList, cons, list, nil,
|
2015-07-23 02:43:59 +00:00
|
|
|
cellp, pairp, listp, nilp,
|
2015-06-23 14:35:06 +00:00
|
|
|
metacadr, car, cdr, cadr} = require '../src/lists'
|
2015-05-13 23:20:16 +00:00
|
|
|
|
|
|
|
describe "Basic list building", ->
|
|
|
|
for [t, v] in [
|
|
|
|
[cons(), cons()]
|
2015-06-27 17:45:20 +00:00
|
|
|
[cons(nil), cons(nil)]
|
2015-05-13 23:20:16 +00:00
|
|
|
[cons('a'), cons('a')]
|
|
|
|
[cons('a', cons('b', cons('c'))), cons('a', cons('b', cons('c')))]
|
|
|
|
[cons('a', cons('b', cons('c'))), cons('a', cons('b', cons('c', nil)))]
|
2015-06-23 00:03:21 +00:00
|
|
|
[cons('a', cons('b', cons('c', nil))), cons('a', cons('b', cons('c')))]]
|
2015-05-13 23:20:16 +00:00
|
|
|
do (t, v) ->
|
|
|
|
it "should match #{t}", ->
|
|
|
|
expect(t).to.deep.equal(v)
|
|
|
|
|
2015-06-23 14:35:06 +00:00
|
|
|
mcsimple = cons('a', cons('b', cons('c')))
|
|
|
|
|
|
|
|
describe "Basic list traversing", ->
|
|
|
|
it "should car", ->
|
|
|
|
expect(car mcsimple).to.equal("a")
|
|
|
|
it "should cadr", ->
|
|
|
|
expect(cadr mcsimple).to.equal("b")
|
|
|
|
it "should car cdr cdr", ->
|
|
|
|
expect(car cdr cdr mcsimple).to.equal("c")
|
|
|
|
|
2015-07-23 02:43:59 +00:00
|
|
|
describe "Basic list typing", ->
|
|
|
|
it "Should recognize an empty cell", ->
|
|
|
|
expect(cellp(cons())).to.equal(true)
|
|
|
|
it "Should recognize a nil cell", ->
|
|
|
|
expect(nilp(cons())).to.equal(true)
|
|
|
|
it "Should recognize a paired cell", ->
|
|
|
|
expect(cellp(cons("a", "b"))).to.equal(true)
|
|
|
|
expect(pairp(cons("a", "b"))).to.equal(true)
|
|
|
|
expect(listp(cons("a", "b"))).to.equal(false)
|
|
|
|
it "Should recognize a list", ->
|
|
|
|
expect(cellp(cons("a"))).to.equal(true)
|
|
|
|
expect(pairp(cons("a"))).to.equal(true)
|
|
|
|
expect(listp(cons("a", cons("b")))).to.equal(true)
|
|
|
|
|
2015-05-13 23:20:16 +00:00
|
|
|
describe 'Round trip equivalence', ->
|
|
|
|
for [t, v] in [
|
|
|
|
[[], []]
|
|
|
|
[['a'], ['a']]
|
|
|
|
[['a', 'b'], ['a', 'b']]
|
|
|
|
[['a', 'b', 'c'], ['a', 'b', 'c']]]
|
|
|
|
do (t, v) ->
|
|
|
|
it "should successfully round-trip #{t}", ->
|
|
|
|
expect(listToVector vectorToList t).to.deep.equal(v)
|
2015-06-23 00:03:21 +00:00
|
|
|
|
2015-05-13 23:20:16 +00:00
|
|
|
describe 'List Building', ->
|
|
|
|
for [t, v] in [
|
|
|
|
[cons(), []]
|
2015-07-23 02:43:59 +00:00
|
|
|
[cons(nil), []]
|
2015-05-13 23:20:16 +00:00
|
|
|
[cons('a'), ['a']]
|
|
|
|
[cons('a', cons('b')), ['a', 'b']]
|
2015-07-23 02:43:59 +00:00
|
|
|
[cons('a', cons('b', cons(nil))), ['a', 'b']]
|
2015-05-13 23:20:16 +00:00
|
|
|
[cons('a', cons('b', cons('c'))), ['a', 'b', 'c']]
|
|
|
|
[cons('a', cons('b', cons('c'), nil)), ['a', 'b', 'c']]]
|
|
|
|
do (t, v) ->
|
|
|
|
it "should cons a list into #{v}", ->
|
2015-06-23 00:03:21 +00:00
|
|
|
expect(listToVector t).to.deep.equal(v)
|
2015-05-13 23:20:16 +00:00
|
|
|
|
2015-06-23 00:03:21 +00:00
|
|
|
describe 'Dynamic list constructor', ->
|
2015-05-13 23:20:16 +00:00
|
|
|
for [t, v] in [
|
|
|
|
[list(), []]
|
|
|
|
[list('a'), ['a']]
|
|
|
|
[list('a', 'b'), ['a', 'b']]
|
|
|
|
[list('a', 'b', 'c'), ['a', 'b', 'c']]]
|
|
|
|
do (t, v) ->
|
|
|
|
it "should round trip list arguments into #{v}", ->
|
|
|
|
expect(listToVector t).to.deep.equal(v)
|
|
|
|
|
|
|
|
mcsimple = cons('a', cons('b', cons('c')))
|
|
|
|
|
2015-06-23 00:03:21 +00:00
|
|
|
describe 'Metacadr Simple', ->
|
2015-05-13 23:20:16 +00:00
|
|
|
for [t, v, r] in [
|
|
|
|
['car', 'a']
|
|
|
|
['cadr', 'b']
|
|
|
|
['caddr', 'c']]
|
|
|
|
do (t, v) ->
|
|
|
|
it "The #{t} should read #{v}", ->
|
|
|
|
expect(metacadr(t)(mcsimple)).to.equal(v)
|
|
|
|
|
2015-06-23 00:03:21 +00:00
|
|
|
mccomplex = vectorToList([
|
|
|
|
['a', 'b', 'c'],
|
|
|
|
['1', '2', '3'],
|
|
|
|
['X', 'Y', 'Z'],
|
|
|
|
['f', 'g', 'h']])
|
2015-05-13 23:20:16 +00:00
|
|
|
|
2015-06-23 00:03:21 +00:00
|
|
|
describe 'Metacadr Complex', ->
|
2015-05-13 23:20:16 +00:00
|
|
|
for [t, v, r] in [
|
|
|
|
['cadar', 'b']
|
|
|
|
['caadddr', 'f']
|
|
|
|
['caadr', '1']
|
|
|
|
['caaddr', 'X']]
|
|
|
|
do (t, v) ->
|
|
|
|
it "The #{t} should read #{v}", ->
|
2015-05-21 05:33:17 +00:00
|
|
|
mcadr = metacadr(t)
|
|
|
|
expect(mcadr mccomplex).to.equal(v)
|
|
|
|
expect(mcadr mccomplex).to.equal(v)
|
|
|
|
expect(mcadr mccomplex).to.equal(v)
|