1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
|
2012-05-01 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/i-special.boot (interpREPEAT): Use CATCH directly.
* interp/int-top.boot (intloopSpadProcess): Likewise.
* interp/sys-macros.lisp (funcall): Remove.
(Catch): Likewise.
(Throw): Likewise.
(UnwindProtect): Likewise.
(SPADCATCH): Likewise.
(SPADTHROW): Likewise.
(YIELD): Likewise.
2012-04-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/integer.spad.pamphlet (Integer): Use %iaddmod, %isubmod,
%imulmod.
* algebra/si.spad.pamphlet (SingleInteger): Likewise.
* interp/c-util.boot (devaluate): Use # in lieu of QVSIZE.
* interp/g-opt.boot: %ilfshift and %irshift are now builtin
side-effect free operations.
* interp/lisp-backend.boot: Translate them.
* interp/g-util.boot (mergeSort): Avoid QSDIFFERENCE.
* interp/slam.boot: Likewise.
* interp/sys-macros.lisp: Likewise.
* interp/macros.lisp: Avoid QVMAXINDEX.
* interp/vmlisp.lisp (QSDIFFERENCE): Remove.
(QSGREATERP): Likewise.
(QSLEFTSHIFT): Likewise.
(QSLESSP): Likewise.
(QSMAX): Likewise.
(QSMIN): Likewise.
(QSMINUS): Likewise.
(QSMINUSP): Likewise.
(QSODDP): Likewise.
(QSABSVAL): Likewise.
(QSPLUS): Likewise.
(QSZEROP): Likewise.
(QVMAXINDEX): Likewise.
(QVSIZE): Likewise.
(ZERO?): Likewise.
2012-04-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/si.spad.pamphlet (SingleInteger): Use %iaddmod,
%isubmod, and %imulmod.
* interp/g-opt.boot: These are now builtin side-effect free operators.
(optIaddmod): New optimizer. Register.
(optIsubmod): Likewise.
(optImulmod): Likewise.
* interp/sys-macros.lisp (QSADDMOD): Remove.
(QSDIFMOD): Likewise.
(QSMULMOD): Likewise.
2012-04-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot: Use float? in lieu of FLOATP.
* interp/fortcall.boot: Likewise.
* interp/i-object.boot: Likewise.
* interp/newfort.boot: Likewise.
* interp/i-analy.boot: Compare to 0 in lieu of ZEROP.
* interp/i-special.boot: Likewise.
* interp/i-syscmd.boot: Likewise.
* interp/sfsfun.boot: Likewise.
* interp/sys-driver.boot: Likewise.
* interp/macros.lisp: Directly use 1+ instead of QADD1.
* interp/preparse.lisp: Likewise.
* interp/slam.boot: Likewise.
* interp/sys-macros.lisp: Likewise.
* interp/sys-constants.boot ($BasicPredicates): Remove as unused.
* interp/vmlisp.lisp (ADD1): Remove.
(QSADD1): Likewise.
(QSSUB1): Likewise.
(QSTIMES): Likewise.
2012-04-30 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/fortcall.boot: Use copyTree, not COPY-TREE.
* interp/i-intern.boot: Likewise.
* interp/setvars.boot: Likewise.
* interp/i-output.boot: Use abstractChar, not EBCDIC.
* interp/i-util.boot: Likewise.
* interp/vmlisp.lisp (EBCDIC): Remove.
(CALLBELOW): Likewise.
(RE-ENABLE-INT): Likewise.
(QUOREM): Likewise.
2012-04-29 Gabriel Dos Reis <gdr@cs.tamu.edu>
* lisp/core.lisp.in (fixnum?): New.
* algebra/sex.spad.pamphlet: Use %float? instead of RNUM.
Use %integer? instead of INTP.
* interp/g-timer.boot: Use float? instead of RNUMP.
* interp/i-coerce.boot: Use fixnum? instead of SINTP or SMINTP.
* interp/i-intern.boot: Likewise.
* interp/lisp-backend.boot: Likewise.
* interp/slam.boot: Likewise.
* interp/trace.boot: Likewise.
* interp/vmlisp.lisp: Likewise.
(INTP): Remove.
(BINTP): Likewise.
(LESSP): Likewise.
(LINTP): Likewise.
(MAKESTRING): Likewise.
(MAPELT): Likewise.
(NUMP): Likewise.
(RNUMP): Likewise.
(SINTP): Likewise.
(SMINTP): Likewise.
2012-04-29 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/debug.lisp: ident? in lieu of IDENTP.
* interp/macros.lisp: Likewise.
* interp/parsing.lisp: Likewise.
* interp/sys-macros.lisp: Likewise.
* interp/vmlisp.lisp: Likewise.
(IDENTP): Remove.
2012-04-29 Gabriel Dos Reis <gdr@cs.tamu.edu>
* boot/ast.boot (bfNumber?): Rename from bfSmintable. Check for
floating point literals too. Adjust callers.
(bfLessp): Check for integer or floating pointer numbers.
* interp/vmlisp.lisp (complex?): New.
(complex): Likewise.
(realPart): Likewise.
(imagPart): Likewise.
(conjugate): Likewise.
(sqrt): Likewise.
2012-04-28 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (finishLambdaExpression): Tidy.
(compWithMappingMode): Use %lambda not LAMBDA.
* interp/g-opt.boot (changeVariableDefinitionToStore): Handle %closure.
2012-04-28 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/boot-pkg.lisp (gensym?): Check for non-null object.
* interp/clammed.boot: Use it in lieu of GENSYMP.
* interp/debug.lisp: Likewise.
* interp/g-opt.boot: Likewise.
* interp/g-util.boot: Likewise.
* interp/i-analy.boot: Likewise.
* interp/trace.boot: Likewise.
* interp/vmlisp.lisp (GENSYMP): Remove.
2012-03-02 Gabriel Dos Reis <gdr@cse.tamu.edu>
* algebra/catdef.spad.pamphlet (MonoidOperation): Noew CoercibleTo
SemiGroupOperation T.
2012-02-27 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/nruncomp.boot (markOperation): New.
(optDeltaEntry): Implement better patch for last change.
* interp/compiler.boot (compFormWithModemap): Undo last change.
2012-02-26 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (compFormWithModemap): Mark implementation
resolution as appropriate.
2012-02-26 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (emitLocalCallInsn): Mark external
operators as such, and local functions as such.
(freeVarUsage): Do not count external and local functions.
(extractCode): Tidy. Handle closure literals.
* interp/g-opt.boot (optCall): Optimize external calls where
possible.
%external is a side-effect free operator.
2012-02-26 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/g-util.boot (usedSymbol?): Remove.
(bindingForm?): New.
(usesVariable?): Likewise.
* interp/compiler.boot (declareUnusedParameters): Use it.
* interp/g-opt.boot (inlineLocals): Likewise.
(optClosure): Likewise.
(optBind): Likewise.
* interp/define.boot (compContained): Remove.
2012-02-26 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/c-util.boot (numOfOccurencesOf): Tidy.
* interp/compiler.boot (compUnnamedMapping): Fix thinko.
* interp/g-opt.boot (semiSimpleRelativeTo?): Likewise.
2012-02-25 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (compTopLevel): Do not bind $killOptimizeIfTrue.
(compWithMappingMode): Likewise.
(compUnnamedMapping): Likewise.
(extractCode): Simplify.
* interp/g-opt.boot (optClosure): New. Register.
(semiSimpleRelativeTo?): An abstraction is always semisimple.
* interp/nruncomp.boot ($killOptimizeIfTrue): Remove.
(optDeltaEntry): Don't test for it.
2012-02-25 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (extractCode): Rename from
extractCodeAndConstructTriple. Change Arity. Tidy. Adjust callers.
2012-02-25 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (finishLambdaExpression): Use %closure.
(extractCodeAndConstructTriple): Likewise.
* interp/g-opt.boot (optCall): Adjust.
2012-02-25 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/nruncomp.boot (genDeltaEntry): Fix thinko.
2012-02-24 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/catdef.spad.pamphlet (BinaryOperatorCategory): New.
(BinaryOperation): Likewise.
(IdempotentOperatorCategory): Likewise.
(SemiGroupOperatorCategory): Likewise.
(SemiGroupOperation): Likewise.
(MonoidOperatorCategory): Likewise.
(MonoidOperation): Likewise.
* algebra/exposed.lsp.pamphlet: Expose them.
* algebra/Makefile.in (oa_algebra_layer_0): Include IDEMOPC,
SGPOPC, SPGOP, MONOPC, BINOPC.
(axiom_algebra_layer_1): Include MONOP.
2012-02-24 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/lexing.boot: "assume" is now also a keyword for the compiler.
* interp/spad-parser.boot (parseCategory): Accept exported properties.
(parseFormula): New.
2012-02-23 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/nruncomp.boot (genDeltaEntry): Replace applyFun with %apply.
* interp/lisp-backend.boot (expandApply): Remove.
Unregister expander.
* interp/g-opt.boot (optCall): applyFun is not longer an opcode.
Look for %apply.
* interp/compiler.boot (applyMapping): Generate ['%call,['%apply,.]]
form, not ['%apply,..] form.
(extractCodeAndConstructTriple): Tidy.
(compApplication): Likewise.
2012-02-19 Gabriel Dos Reis <gdr@cse.tamu.edu>
* interp/lexing.boot (getNumberToken): New.
(getArgumentDesignator): Likewise.
(getToken): Use it.
* interp/parsing.lisp (GET-NUMBER-TOKEN): Remove.
* interp/bootlex.lisp (INIT-BOOT/SPAD-READER): Move to spad.lisp.
(SPAD): Likewise.
(READ-SPAD1): Likewise.
(TEST): Remove.
(GET-ARGUMENT-DESIGNATOR-TOKEN): Likewise.
2012-02-19 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (compBuiltinDomain): Compute the exports
from parentsOfBuiltinInstance.
* interp/buildom.boot (parentsOfBuiltinInstance): Tidy.
2012-02-19 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/compiler.boot (compBuiltinDomain): Rename from compCat.
2012-02-19 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/br-data.boot (libConstructorSig): Rename T$ to T for
external name printing. Do not call ncParseFromString.
2012-02-15 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/catdef.spad.pamphlet (Ring): Extends SemiRing.
(Dioid): New. Extend OrderedAbelianMonoid and SemiRing.
* algebra/exposed.lsp.pamphlet: Expose Dioid.
2012-02-13 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/g-util.boot (stripTags): Rename from stripUnionTags.
Adjust callers.
* interp/database.boot (genericInstanceForm): New.
* interp/buildom.boot (parentsOfBuiltinInstance): New.
(builtinInstanceForm): Likewise.
* interp/br-data.boot (genericParentsOf): New.
(parentsOfForm): Use it,
(ancestorsRecur): Likewise.
* interp/br-con.boot (originInOrder): Use parentsOfForm.
2012-02-12 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/define.boot (getCatAncestors): Remove. Adjust caller.
(depthAssoc): Tidy.
(NRTmakeCategoryAlist): Tidy.
2012-02-12 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/define.boot (NRTcatCompare): Remove.
(NRTmakeCategoryAlist): Don't call NRTcatCompare. Tidy.
2012-02-12 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/define.boot (depthAssocList): Take the cache as second
argument. Avoid globals. Adjust Callers.
(depthAssoc): Likewise. Adjust Caller.
(NRTmakeCategoryAlist): Remove uses of $depthAssocCache.
2012-02-12 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/coerce.spad.pamphlet (Type): Redefine as empty Join.
* interp/category.boot (Join): Handle empty argument list.
2012-02-11 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/define.boot (getParentsFor): Lose second parameter. Tidy.
Adjust callers.
* interp/br-data.boot (getParentsForDomain): Remove.
(parentsOf): Call getParentsFor in lieu of getParentsForDomain.
(folks): Move to define.boot.
2012-02-11 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/br-data.boot (ancestorsRecur): Tidy.
* interp/define.boot (compDefineCategory2): Likewise.
2012-02-11 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/br-data.boot (getParentsFor): Move to define.boot.
(explodeIfs): Likewise.
(getParentsForDomain): Tidy.
(ancestorsRecur): Likewise.
2012-02-09 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/define.boot (mkEvalableCategoryForm): Compile only
CATEGORY and SubsetCategory forms.
2012-02-09 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/database.boot (categoryConstructor?): New.
* interp/define.boot (mkEvalableCategoryForm): Use it. Tidy.
2012-02-08 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/g-opt.boot (optCall): Simplify SPADCALL of atomic
function expressions.
($VMsideEffectFreeOperators): Don't include %funcall.
($simpleVMoperators): Include it.
2012-02-07 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/Makefile.in (oa_algebra_layer_0): Include FINITE-.
2012-02-06 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/lisplib.boot (dbLocateModule): New.
(findModule): Use it. Simplify.
(loadLib): Tidy.
(genericLoadDB): New.
(loadDB): Use it.
(loadDBIfCan): New.
* interp/c-util.boot (lookupDefiningFunction): Give up gracefully
if the domain of computation is not compiled yet.
* algebra/Makefile.in ($(OUT)/SPADAST.$(FASLEXT)): Require
$(OUT)/SUCHTAST.$(FASLEXT).
2012-02-04 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/nruncomp.boot (getLocalIndex): Fast track niladic
constructors.
* algebra/syntax.spad.pamphlet: Miscellaneous cleanup.
2012-02-03 Gabriel Dos Reis <gdr@cs.tamu.edu>
* utils/vm.H: Add more VM data structures.
* utils/vm.cc (BasicContext::make_operator): Define.
* algebra/Makefile.in (SPADFILES): Include syntax.spad and
spad-parser.spad.
2012-01-14 Gabriel Dos Reis <gdr@cs.tamu.edu>
* algebra/catdef.spad.pamphlet (Finite) [random]: Provide default
implementation.
* algebra/boolean.spad.pamphlet (KleeneTrivalentLogic): Now
satisfy Finite. Use Maybe Boolean as representation.
2012-01-14 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/i-util.boot ($intTopLevel): Move to sys-constants.boot.
* interp/g-error.boot (returnToTopLevel): Tidy.
* interp/macros.lisp (applyWithOutputToString): Likewise.
2012-01-14 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/spaderror.lisp: Move convent to spad.lisp. Remove.
2012-01-14 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/patches.lisp: Move content to msgdb.boot. Remove.
2012-01-14 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/word.boot: Add import and scope statements. Include in
final executables.
(infix?): Remove as duplicate in match.boot.
(prefix?): Likewise.
(suffix?): Likewise.
* interp/g-error.boot (returnToTopLevel): Tidy.
* interp/debug.lisp (/D-2): Use spadThrow in lieu of UNWIND.
* interp/patches.lisp (CATCHALL): Remove.
(DBRINIT): Likewise.
(TOPLEVEL): Likewise.
(TOP-LEVEL): Likewise.
(UNWIND): Likewise.
(RESUME): Likewise.
(booFind): Likewise.
2012-01-14 Gabriel Dos Reis <gdr@cs.tamu.edu>
* lisp/core.lisp.in (mkIntArray): New. Export.
* interp/patches.lisp (/RF): Move to cparse.boot.
(/RQ): Likewise.
(/RQ,LIB): Likewise.
(/RF-1): Likewise.
(/EF): Move to spad.lisp.
(construct): Remove.
(READSPADEXPR): Likewise.
(SHAREDITEMS): Likewise.
(installStandardTestPackages): Likewise.
(spadtestValueHook): Likewise.
(testError): Likewise.
($TestOptions): Likewise.
(rebuild): Likewise.
($ViewportProcessToWatch): Likewise.
(setViewportProcess): Likewise.
(waitForViewport): Likewise.
* interp/i-analy.boot (pushDownOp?): Use mkIntArray in place of
GETZEROVEC.
* interp/i-funsel.boot (argCouldBelongToSubdomain): Likewise.
* interp/i-intern.boot (flagArguments): Likewise.
2012-01-12 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/category.boot: Rename AncestorP to ancestor?.
Rename DescendantP to descendant?.
* interp/define.boot: Likewise.
* interp/functor.boot: Likewise.
2012-01-12 Gabriel Dos Reis <gdr@cs.tamu.edu>
* boot/parser.boot (bpFunction): New.
(bpConstTok): Include it.
* boot/ast.boot (bfFunction): New.
* boot/tokens.boot: `function' is now a keyword.
2012-01-11 Gabriel Dos Reis <gdr@cs.tamu.edu>
* boot/tokens.boot (keywordId): New.
* boot/parser.boot (bpSexpKey): Use it.
* interp/i-map.boot (mapPredTran): Fix thinko.
2012-01-09 Gabriel Dos Reis <gdr@cs.tamu.edu>
* boot/parser.boot (bpRequire): New. Use it throughout this module.
2012-01-08 Gabriel Dos Reis <gdr@cs.tamu.edu>
* boot/ast.boot (bfEnum): New.
* boot/translator.boot (translateToplevel): Use it to translate
enumeration definitions.
* interp/types.boot (%ConstructorKind): Use new syntax.
2012-01-01 Gabriel Dos Reis <gdr@cs.tamu.edu>
* interp/define.boot (evalCategoryForm): New.
(mkCategoryPackage): Use it.
(compMakeCategoryObject): Likewise.
* interp/nruncomp.boot (NRTsetVector4a): Likewise.
|