(herald "Function constraint test protocol"
  (comment "Skeletons 2, 4, and 7 should have no shapes."))
(comment "CPSA 3.4.0")
(comment "All input read from fnof_test.scm")

Trees: 0 2 3 5 6 8 10.

Tree 0.

1 0
(defprotocol fnoftest basic
  (defrole init
    (vars (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)))

Item 0, Child: 1.

n1 (cat n0 (enc an0 an1 n0 n1 k)) ((an0 an0) (an1 an1) (n0 n0) (n1 n1) (k k)) init fnoftest 0
(defskeleton fnoftest
  (vars (an0 an1 n0 n1 text) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n0) (n1 n1) (k k))
  (non-orig k)
  (uniq-orig n0 n1)
  (label 0)
  (unrealized (0 1))
  (origs (n0 (0 0)) (n1 (0 0)))
  (comment "1 in cohort - 1 not yet seen"))

Item 1, Parent: 0.

n0 (cat n0 (enc an0 an1 n0 n0 k)) ((an0 an0) (an1 an1) (n0 n0) (n1 n0) (k k)) init fnoftest 1 (realized)
(defskeleton fnoftest
  (vars (an0 an1 n0 text) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n0) (n1 n0) (k k))
  (non-orig k)
  (uniq-orig n0)
  (operation nonce-test (displaced 1 0 init 1) n1 (0 1)
    (enc an0 an1 n0 n1 k))
  (label 1)
  (parent 0)
  (unrealized)
  (shape)
  (maps ((0) ((an0 an0) (an1 an1) (n0 n0) (n1 n0) (k k))))
  (origs (n0 (0 0))))

Tree 2.

2
(defprotocol fnoftest basic
  (defrole init
    (vars (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)))

Item 2.

n1 (cat n0 (enc an0 an1 n0 n1 k)) ((an0 an0) (an1 an1) (n0 n0) (n1 n1) (k k)) init fnoftest 2
(defskeleton fnoftest
  (vars (an0 an1 n0 n1 text) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n0) (n1 n1) (k k))
  (fn-of (a (an0 n0) (an1 n1)))
  (neq (an0 an1))
  (non-orig k)
  (uniq-orig n0 n1)
  (label 2)
  (unrealized (0 1))
  (origs (n0 (0 0)) (n1 (0 0)))
  (comment "empty cohort"))

Tree 3.

4 3
(defprotocol fnoftest basic
  (defrole init
    (vars (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)))

Item 3, Child: 4.

n1 (cat n1 (enc an0 an1 n1 n1 k)) ((an0 an0) (an1 an1) (n0 n1) (n1 n1) (k k)) init fnoftest 3 (realized)
(defskeleton fnoftest
  (vars (an0 an1 n1 text) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n1) (n1 n1) (k k))
  (fn-of (a (an0 n1) (an1 n1)))
  (non-orig k)
  (uniq-orig n1)
  (label 3)
  (unrealized)
  (preskeleton)
  (comment "Not a skeleton"))

Item 4, Parent: 3.

n1 (cat n1 (enc an1 an1 n1 n1 k)) ((an0 an1) (an1 an1) (n0 n1) (n1 n1) (k k)) init fnoftest 4 (realized)
(defskeleton fnoftest
  (vars (an1 n1 text) (k skey))
  (defstrand init 2 (an0 an1) (an1 an1) (n0 n1) (n1 n1) (k k))
  (fn-of (a (an1 n1)))
  (non-orig k)
  (uniq-orig n1)
  (label 4)
  (parent 3)
  (unrealized)
  (shape)
  (maps ((0) ((an1 an1) (n1 n1) (k k))))
  (origs (n1 (0 0))))

Tree 5.

5
(defprotocol fnoftest basic
  (defrole init
    (vars (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)))

Item 5.

n1 (cat n1 (enc an0 an1 n1 n1 k)) ((an0 an0) (an1 an1) (n0 n1) (n1 n1) (k k)) init fnoftest 5 (realized)
(defskeleton fnoftest
  (vars (an0 an1 n1 text) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n1) (n1 n1) (k k))
  (fn-of (a (an0 n1) (an1 n1)))
  (neq (an0 an1))
  (non-orig k)
  (uniq-orig n1)
  (label 5)
  (unrealized)
  (comment "Input cannot be made into a skeleton--nothing to do"))

Tree 6.

7 6
(defprotocol fnoftest2 basic
  (defrole init
    (vars (bn0 bn1 name) (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc bn0 bn1 an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)
    (fn-of (a (an0 n0) (an1 n1)) (b ((pubk bn0) an0)))))

Item 6, Child: 7.

n1 (cat n0 (enc bn0 bn1 an0 an1 n0 n1 k)) ((an0 an0) (an1 an1) (n0 n0) (n1 n1) (bn0 bn0) (bn1 bn1) (k k)) init fnoftest2 6
(defskeleton fnoftest2
  (vars (an0 an1 n0 n1 text) (bn0 bn1 name) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n0) (n1 n1) (bn0 bn0)
    (bn1 bn1) (k k))
  (fn-of (a (an0 n0) (an1 n1)) (b ((pubk bn1) an1) ((pubk bn0) an0)))
  (non-orig k)
  (uniq-orig n0 n1)
  (label 6)
  (unrealized (0 1))
  (origs (n0 (0 0)) (n1 (0 0)))
  (comment "1 in cohort - 1 not yet seen"))

Item 7, Parent: 6.

n0 (cat n0 (enc bn1 bn1 an1 an1 n0 n0 k)) ((an0 an1) (an1 an1) (n0 n0) (n1 n0) (bn0 bn1) (bn1 bn1) (k k)) init fnoftest2 7 (realized)
(defskeleton fnoftest2
  (vars (an1 n0 text) (bn1 name) (k skey))
  (defstrand init 2 (an0 an1) (an1 an1) (n0 n0) (n1 n0) (bn0 bn1)
    (bn1 bn1) (k k))
  (fn-of (a (an1 n0)) (b ((pubk bn1) an1)))
  (non-orig k)
  (uniq-orig n0)
  (operation nonce-test (displaced 1 0 init 1) n1 (0 1)
    (enc bn0 bn1 an0 an1 n0 n1 k))
  (label 7)
  (parent 6)
  (unrealized)
  (shape)
  (maps
    ((0)
      ((bn0 bn1) (bn1 bn1) (an0 an1) (an1 an1) (n0 n0) (n1 n0) (k k))))
  (origs (n0 (0 0))))

Tree 8.

9 8
(defprotocol fnoftest2 basic
  (defrole init
    (vars (bn0 bn1 name) (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc bn0 bn1 an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)
    (fn-of (a (an0 n0) (an1 n1)) (b ((pubk bn0) an0)))))

Item 8, Child: 9.

n1 (cat n0 (enc bn0 bn1 an0 an1 n0 n1 k)) ((an0 an0) (an1 an1) (n0 n0) (n1 n1) (bn0 bn0) (bn1 bn1) (k k)) init fnoftest2 8
(defskeleton fnoftest2
  (vars (an0 an1 n0 n1 text) (bn0 bn1 name) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n0) (n1 n1) (bn0 bn0)
    (bn1 bn1) (k k))
  (decl foo ((n0 n1) (0 1)) ((k k k n0) (0 0) (0 0) (0 1)))
  (fn-of (a (an0 n0) (an1 n1)) (b ((pubk bn0) an0))
    (c ((pubk bn1) an1)))
  (non-orig k)
  (uniq-orig n0 n1)
  (label 8)
  (unrealized (0 1))
  (origs (n0 (0 0)) (n1 (0 0)))
  (comment "1 in cohort - 1 not yet seen"))

Item 9, Parent: 8.

n0 (cat n0 (enc bn0 bn1 an1 an1 n0 n0 k)) ((an0 an1) (an1 an1) (n0 n0) (n1 n0) (bn0 bn0) (bn1 bn1) (k k)) init fnoftest2 9 (realized)
(defskeleton fnoftest2
  (vars (an1 n0 text) (bn0 bn1 name) (k skey))
  (defstrand init 2 (an0 an1) (an1 an1) (n0 n0) (n1 n0) (bn0 bn0)
    (bn1 bn1) (k k))
  (decl foo ((n0 n0) (0 1)) ((k k k n0) (0 0) (0 0) (0 1)))
  (fn-of (a (an1 n0)) (b ((pubk bn0) an1)) (c ((pubk bn1) an1)))
  (non-orig k)
  (uniq-orig n0)
  (operation nonce-test (displaced 1 0 init 1) n1 (0 1)
    (enc bn0 bn1 an0 an1 n0 n1 k))
  (label 9)
  (parent 8)
  (unrealized)
  (shape)
  (maps
    ((0)
      ((bn0 bn0) (bn1 bn1) (an0 an1) (an1 an1) (n0 n0) (n1 n0) (k k))))
  (origs (n0 (0 0))))

Tree 10.

10
(defprotocol fnoftest2 basic
  (defrole init
    (vars (bn0 bn1 name) (an0 an1 n0 n1 text) (k skey))
    (trace (send (cat n0 (enc bn0 bn1 an0 an1 n0 n1 k))) (recv n1))
    (non-orig k)
    (uniq-orig n0 n1)
    (fn-of (a (an0 n0) (an1 n1)) (b ((pubk bn0) an0)))))

Item 10.

n1 (cat n0 (enc bn0 bn1 an0 an1 n0 n1 k)) ((an0 an0) (an1 an1) (n0 n0) (n1 n1) (bn0 bn0) (bn1 bn1) (k k)) init fnoftest2 10
(defskeleton fnoftest2
  (vars (an0 an1 n0 n1 text) (bn0 bn1 name) (k skey))
  (defstrand init 2 (an0 an0) (an1 an1) (n0 n0) (n1 n1) (bn0 bn0)
    (bn1 bn1) (k k))
  (decl foo ((n0 n1) (0 1)) ((k k k n0) (0 0) (0 0) (0 1)))
  (fn-of (a (an0 n0) (an1 n1)) (b ((privk bn0) an1) ((pubk bn0) an0)))
  (non-orig k)
  (uniq-orig n0 n1)
  (label 10)
  (unrealized (0 1))
  (origs (n0 (0 0)) (n1 (0 0)))
  (comment "empty cohort"))