Changed the loop protocol for :acc clauses
The third clause (the "check" clause) now breaks the entire iteration for :acc clauses instead of just exiting the current subloop. This is much saner, and was immediately usable in vectoring.
This commit is contained in:
parent
90c2c6bfdf
commit
172d0aa180
2 changed files with 32 additions and 38 deletions
|
@ -180,55 +180,55 @@
|
|||
((lets ...))
|
||||
((accs ...))
|
||||
vars
|
||||
((checks ...))
|
||||
checks
|
||||
((refs ...))
|
||||
(finals ...)
|
||||
ff ul uw ub uf clauses . body)
|
||||
(cl orig name
|
||||
((lets ... new-lets ...))
|
||||
((accs ... (accvar accinit accupdate) ...))
|
||||
vars
|
||||
((checks ... new-checks ...))
|
||||
((refs ... new-refs ...))
|
||||
(finals ... new-finals ...)
|
||||
ff ul uw ub uf clauses . body))
|
||||
ff ul uw ((cur-ub ...) . ub-rest) uf clauses . body)
|
||||
(cl orig name
|
||||
((lets ... new-lets ...))
|
||||
((accs ... (accvar accinit accupdate) ...))
|
||||
vars
|
||||
checks
|
||||
((refs ... new-refs ...))
|
||||
(finals ... new-finals ...)
|
||||
ff ul uw ((cur-ub ... new-checks ...) . ub-rest) uf clauses . body))
|
||||
;; We have ONE subloop!
|
||||
((_ (new-lets ...) ((accvar accinit accupdate) ...) (new-checks ...) (new-refs ...) (new-finals ...)
|
||||
orig name
|
||||
(lets ... (outermost-lets ...))
|
||||
((accs ...) ((oldacc oldinit oldupdate) ...))
|
||||
vars
|
||||
((checks ...) . checks-rest)
|
||||
checks
|
||||
((refs ...) . refs-rest)
|
||||
(finals ...)
|
||||
ff ul uw ub uf clauses . body)
|
||||
(cl orig name
|
||||
(lets ... (outermost-lets ... new-lets ...))
|
||||
((accs ... (accvar accvar accupdate) ...) ((oldacc oldinit oldupdate) ... (accvar accinit accvar) ...))
|
||||
vars
|
||||
((checks ... new-checks ...) . checks-rest)
|
||||
((refs ... new-refs ...) . refs-rest)
|
||||
(finals ... new-finals ...)
|
||||
ff ul uw ub uf clauses . body))
|
||||
ff ul uw ((cur-ub ...) . ub-rest) uf clauses . body)
|
||||
(cl orig name
|
||||
(lets ... (outermost-lets ... new-lets ...))
|
||||
((accs ... (accvar accvar accupdate) ...) ((oldacc oldinit oldupdate) ... (accvar accinit accvar) ...))
|
||||
vars
|
||||
checks
|
||||
((refs ... new-refs ...) . refs-rest)
|
||||
(finals ... new-finals ...)
|
||||
ff ul uw ((cur-ub ... new-checks ...) . ub-rest) uf clauses . body))
|
||||
;; We have several subloops!
|
||||
((_ (new-lets ...) ((accvar accinit accupdate) ...) (new-checks ...) (new-refs ...) (new-finals ...)
|
||||
orig name
|
||||
(lets ... (outermost-lets ...))
|
||||
((accs ...) ((oldacc oldinit oldupdate) ...) ... ((oldestacc oldestinit oldestupdate) ...))
|
||||
vars
|
||||
((checks ...) . checks-rest)
|
||||
checks
|
||||
((refs ...) . refs-rest)
|
||||
(finals ...)
|
||||
ff ul uw ub uf clauses . body)
|
||||
ff ul uw ((cur-ub ...) . ub-rest) uf clauses . body)
|
||||
(cl orig name
|
||||
(lets ... (outermost-lets ... new-lets ...))
|
||||
((accs ... (accvar accvar accupdate) ...) ((oldacc oldinit oldupdate) ... (accvar accvar accvar) ...) ...
|
||||
((oldestacc oldestinit oldestupdate) ... (accvar accinit accvar) ...))
|
||||
vars
|
||||
((checks ... new-checks ...) . checks-rest)
|
||||
((refs ... new-refs ...) . refs-rest)
|
||||
(finals ... new-finals ...)
|
||||
ff ul uw ub uf clauses . body))))
|
||||
(lets ... (outermost-lets ... new-lets ...))
|
||||
((accs ... (accvar accvar accupdate) ...) ((oldacc oldinit oldupdate) ... (accvar accvar accvar) ...) ...
|
||||
((oldestacc oldestinit oldestupdate) ... (accvar accinit accvar) ...))
|
||||
vars
|
||||
checks
|
||||
((refs ... new-refs ...) . refs-rest)
|
||||
(finals ... new-finals ...)
|
||||
ff ul uw ((cur-ub ... new-checks ...) . ub-rest) uf clauses . body))))
|
||||
|
||||
;; Integrating for clauses is not as involved, since they only want to be introduced into the current
|
||||
;; loop. Any propagation of for finalizers (ff) is done by push-new-subloop
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue