filenames.scm 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. ; Copyright (c) 1993-2005 by Richard Kelsey and Jonathan Rees. See file COPYING.
  2. ; Generate filenames.make from *-packages.scm.
  3. ; Define DEFINE-STRUCTURE and friends
  4. (for-each load
  5. '("scheme/bcomp/module-language.scm"
  6. "scheme/alt/dummy-interface.scm"
  7. "scheme/alt/config.scm"
  8. "scheme/env/flatload.scm"))
  9. ; The following bogus structures are required in order to load
  10. ; scheme/more-interfaces.scm.
  11. (define ascii (structure (make-simple-interface 'ascii '())))
  12. (define bitwise (structure (make-simple-interface 'bitwise '())))
  13. (define vm-data (structure (make-simple-interface 'vm-data '())))
  14. (define enumerated (structure (make-simple-interface 'enumerated '())))
  15. (define tables (structure (make-simple-interface 'tables '())))
  16. (define cells (structure (make-simple-interface 'cells '())))
  17. ; The following loads are unnecessary; they only serve to suppress
  18. ; annoying "undefined" warnings for interfaces.
  19. (for-each load
  20. '("scheme/interfaces.scm"
  21. "scheme/vm/shared-interfaces.scm"
  22. "scheme/more-interfaces.scm"
  23. "scheme/sort/interfaces.scm"))
  24. (load-configuration "scheme/packages.scm")
  25. ; The following defines are unnecessary; they only serve to suppress
  26. ; annoying "undefined" warnings for some forward references.
  27. (define methods 0)
  28. (define tables 0)
  29. (flatload linker-structures)
  30. (define q-f (all-file-names link-config))
  31. ; (display "Initial structures") (newline)
  32. (flatload initial-structures)
  33. (define scheme (make-scheme environments evaluation))
  34. (define initial-system
  35. (structure (export)
  36. (open ;; Cf. initial.scm
  37. (make-initial-system scheme (make-mini-command scheme))
  38. module-system
  39. ensures-loaded
  40. for-reification))) ;foo...
  41. (define i-f (all-file-names initial-system))
  42. ; (display "Usual structures") (newline)
  43. (flatload usual-structures)
  44. (define u-f (all-file-names usual-features initial-system))
  45. (define (write-file-names mumble comment . stuff)
  46. (comment "#### This file was generated automatically. ####")
  47. (do ((stuff stuff (cddr stuff)))
  48. ((null? stuff))
  49. (mumble (car stuff) (cadr stuff))
  50. ;; (mumble 'all-files (reverse *all-files*))
  51. ))
  52. ;; Unix
  53. (begin
  54. (display "Writing ") (display "build/filenames.make") (newline)
  55. (call-with-output-file "build/filenames.make"
  56. (lambda (port)
  57. (write-file-names (lambda (name filenames)
  58. (newline port)
  59. (display name port)
  60. (display " = " port)
  61. (for-each (lambda (filename)
  62. (display filename port)
  63. (display " " port))
  64. filenames)
  65. (newline port))
  66. (lambda (comment)
  67. (display "#" port)
  68. (display comment port)
  69. (newline port))
  70. 'initial-files i-f
  71. 'usual-files u-f
  72. 'linker-files q-f))))
  73. ;; Windows
  74. (begin
  75. (display "Writing ") (display "build/filenames.bat") (newline)
  76. (call-with-output-file "build/filenames.bat"
  77. (lambda (port)
  78. (write-file-names (lambda (name filenames)
  79. (newline port)
  80. (display "@set " port)
  81. (display name port)
  82. (display "=" port)
  83. (for-each (lambda (filename)
  84. (display filename port)
  85. (display " " port))
  86. filenames)
  87. (newline port))
  88. (lambda (comment)
  89. (display "@rem " port)
  90. (display comment port)
  91. (newline port))
  92. 'initial-files i-f
  93. 'usual-files u-f
  94. 'linker-files q-f))))