;;; -*-scheme-*- ;;; Mes --- Maxwell Equations of Software ;;; Copyright © 2016,2017,2018 Jan (janneke) Nieuwenhuizen ;;; ;;; This file is part of Mes. ;;; ;;; Mes is free software; you can redistribute it and/or modify it ;;; under the terms of the GNU General Public License as published by ;;; the Free Software Foundation; either version 3 of the License, or (at ;;; your option) any later version. ;;; ;;; Mes is distributed in the hope that it will be useful, but ;;; WITHOUT ANY WARRANTY; without even the implied warranty of ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;;; GNU General Public License for more details. ;;; ;;; You should have received a copy of the GNU General Public License ;;; along with Mes. If not, see . ;;; Commentary: ;;; Code: (define-module (language c99 compiler) #:use-module (srfi srfi-1) #:use-module (srfi srfi-26) #:use-module (system base pmatch) #:use-module (ice-9 optargs) #:use-module (ice-9 pretty-print) #:use-module (nyacc lang c99 parser) ;;#:use-module (nyacc lang c99 pprint) #:use-module (mes guile) #:use-module (mes as) #:use-module (mes as-i386) #:use-module (mes elf) #:use-module (mes M1) #:use-module (language c99 info) #:export (c99-ast->info c99-input->ast c99-input->elf c99-input->info c99-input->object info->object)) (cond-expand (guile-2 (use-modules (nyacc lang c99 pprint))) (guile (debug-set! stack 0) (use-modules (ice-9 optargs)) (use-modules (ice-9 syncase))) ;; guile-1.8 does not have (sxml match), short-circuit me (define* (pretty-print-c99 tree #:optional (port (current-output-port)) #:key ugly per-line-prefix (basic-offset 2)) (write tree port)) (mes)) (include-from-path "language/c99/compiler.mes")