todo.txt 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. --*- Mode: Indented-text; -*-
  2. Scheme 48: list of bugs and things to do.
  3. Last update by RAK on 26 Feb 2001.
  4. Programming environment:
  5. Fuller on-line documentation.
  6. Error recovery. Can do better than ,proceed. LOAD should set up
  7. restart continuations.
  8. Types in scheme-interface (and elsewhere) aren't as tight as they
  9. could be.
  10. Add LET continuation "pessimization" to retain the environment longer.
  11. Have the disassembler display local variable names.
  12. This ought to be recoverable, but isn't always:
  13. > (let loop ((x '())) (loop (cons 3 x)))
  14. not enough room in heap for stack
  15. ,exit 'not-a-fixnum should not exit
  16. Semicolon comments don't quite work after commands (extra newline
  17. required).
  18. Command (and procedure) to change current directory.
  19. Some procedure in EXEC to take the place of ## in moving values from
  20. one package to another: (transport <from-package> <exp> <to-package>
  21. [<id>]), and/or have eval etc. commands return the value
  22. Batch mode should write error messages to (error-output).
  23. In command preferred mode you have to do
  24. in foo run bar
  25. instead of
  26. in foo bar
  27. if foo is a read-only package
  28. ,reset should flush the input buffer
  29. Export the VM's preview displayer as a procedure for debugging.
  30. Performance:
  31. Generational GC.
  32. More compact representation for debugging data?
  33. Leaf procedure compilation (RK's rts/no-leaf-env.scm): if no
  34. continuations or lambdas, skip the make-env and access locals
  35. using stack-ref. Expected to gain about 6% in speed.
  36. Optimize loops somehow (maybe using call-template opcode and/or
  37. opportunistic compilation).
  38. The CAML light implementation has good documentation and patches
  39. for optimizing the interpreter's switch (*pc++); perhaps we
  40. could lift some of it. (Range check isn't necessary.)
  41. Floating point support in VM.
  42. Faster bignum printer (e.g. the one Richard wrote - but it would be
  43. nice if it were an option tied to bignums, not built in to the
  44. initial image).
  45. Ratnum multiplication and division might be made more efficient by
  46. taking cross-GCD's.
  47. Native code compiler...
  48. Compiler bugs / features:
  49. Inliner is buggy: if (lambda (x) (f) x) is in-lined the call to
  50. F fill occur before the argument is evaluated.
  51. It would be nice if macro's and inliner's sources were saved only
  52. if we are going to be doing doing any reificiation.
  53. Big Scheme bugs / features:
  54. It would be nice to be able to simulate control-C interrupts on
  55. a port other than the initial input port - e.g., on a socket.
  56. This would require creating a new thread to act as a front end.
  57. The new thread would read characters eagerly, buffering
  58. everything except control-C's for the thread that is doing the
  59. real work, and converting control-C's into interrupts.
  60. big/pipe.scm uses the old port interface
  61. Tracking output ports are not thread safe.
  62. Module system bugs:
  63. ,untrace should undefine as well if the variable wasn't bound
  64. before.
  65. Compound signatures don't get updated when a component signature
  66. changes. They contain a list of signatures with no reinitialization
  67. thunk a la structures and packages.
  68. Module system features:
  69. Check for name conflicts between opened structures.
  70. Check for cycles in structure inheritance.
  71. Deal with package system state better (for linker). Maybe each
  72. package should point to a data structure containing
  73. *location-uid*, location-name-table, *package-uid*,
  74. package-name-table, and perhaps the compiler-state as well (see
  75. segment.scm).
  76. VM:
  77. Heaps that can grow larger.
  78. Add a test to configure.in that can determine whether ld -A works.
  79. If both it and dlopen() work, then both kinds of dynamic loading
  80. should be made available.
  81. Interrupt while writing out image causes an exit. [Fixed?]
  82. A jump-back instruction? Might be easier to use than call-template.
  83. Scrutinize all VM fatal errors to see if any can be recovered
  84. from. E.g. "out of ports" shouldn't cause a VM halt, it should
  85. just cause open-port to return #f or an error code. [Fixed?]
  86. Get VM interp.scm-without-gc.scm working again.
  87. Documentation:
  88. Describe (optimize auto-integrate).
  89. How to use the static linker.
  90. How initial.image and scheme48.image get built, really.
  91. Techniques for debugging the runtime system (debug/for-debugging.scm).
  92. Cleanup:
  93. VM:
  94. Rename "unassigned" to "uninitialized"? Or phase it out entirely.
  95. In unix.c, use getrusage(), when available, to get run time.
  96. Run-time / features / development environment:
  97. A DIVIDE procedure (maybe an instruction as well) that returns two
  98. values.
  99. Figure out how to merge the two type systems (META-METHODS and
  100. META-TYPES). The generic function system could make use of the
  101. SUBTYPE? and INTERSECT? predicates.
  102. Correct floating point, esp. reading and printing. And
  103. (= 1/3 (/ 1. 3.)) returns #t, but ought to return #f.
  104. Parameterize over file name syntax somehow. Currently
  105. big/filename.scm assumes Unix (cf. DIRECTORY-COMPONENT-SEPARATOR,
  106. FILE-NAME-PREFERRED-CASE). Perhaps there should be VM support for
  107. this.
  108. Make sure that the disassembler and assembler are inverses of one
  109. another.
  110. Disassembler should generate S-expression first, and then print
  111. it independently.
  112. Combine conditions, signals, and handle into a single structure?
  113. Figure out a better way to implement ##.
  114. Be consistent about "filename" versus "file-name".
  115. Compiler / linker / module system:
  116. The fluids $losers and $package-losers in env/pedit.scm are never
  117. bound. Could they be replaced with cells?
  118. The "reflective tower" isn't really a reflective tower, it's a
  119. syntactic tower. Rename it.
  120. The scanner (file loader) should operate on streams, not lists.
  121. This would result in more uniform and flexible internal
  122. protocols for reading files, scanning for DEFINEs, compiling,
  123. and running - passes could be interleaved or separated easily.
  124. Flush link/data.scm. Linker should instead open the VM module
  125. that includes vm/data.scm.
  126. Flush (optimize ...) clause in DEFINE-STRUCTURE in favor of
  127. optimizer argument to SCAN-STRUCTURES.
  128. Vector templates ought to be supported in SYNTAX-RULES.
  129. The DEFINE-INTERFACE forms should contain types for every exported
  130. variable; the code in cprim.scm (and recon.scm?) shouldn't have
  131. to worry about setting up types.
  132. Add ENVIRONMENT-DEFINED? ?
  133. Make USUAL-TRANSFORM return a transform?
  134. make-c-header-file should put definitions for the interrupt
  135. enumeration into scheme48.h, and unix.c et al should use them.
  136. Flatloading and loading are very different operations, so FLATLOAD
  137. shouldn't do SET-PACKAGE-LOADED?!; instead it should maintain its
  138. own list of flatloaded packages (in a global variable, say).
  139. Etc:
  140. Start using a source control system (like rcs or Perforce).
  141. There ought to be a sanity check to ensure that the size of the
  142. area as computed by static.scm agrees with the size as computed
  143. by C's sizeof() operator.
  144. What should (syntax-rules (x) ((foo ?body) (let ((x 1)) ?body))) do?
  145. To: jar@cs.cornell.edu
  146. Subject: Not a bug this time. :-)
  147. Date: Tue, 22 Feb 94 19:13:37 -0500
  148. From: Paul Stodghill <stodghil@cs.cornell.edu>
  149. The result of ,expand can be confusing. In particular, it doesn't
  150. distinguish between different identifiers that have the same name.
  151. For instance, in the example below, it would be more useful if the result
  152. of the ,expand was something like,
  153. '((lambda (.x.1) (set! x (- .x.1))) x)
  154. Welcome to Scheme 48 0.31 (made by jar on Sun Feb 13 18:33:57 EST 1994).
  155. Copyright (c) 1993, 1994 by Richard Kelsey and Jonathan Rees.
  156. Please report bugs to scheme-48-bugs@altdorf.ai.mit.edu.
  157. Type ,? (comma question-mark) for help.
  158. > (define-syntax foo
  159. (syntax-rules ()
  160. ((foo var) ((lambda (x) (set! var (- x))) var))))
  161. > (define x 1)
  162. > ,expand (foo x)
  163. '((lambda (x) (set! x (- x))) x)
  164. >