chiark / gitweb /
test/Makefile.am: Distribute the test program source.
[sod] / src / pset-parse.lisp
index 11b400353b3acba616ddad13274c2a409ce30f60..ddc34e04f96eed91c43ed700ff10b3ae7a9a766c 100644 (file)
@@ -7,7 +7,7 @@
 
 ;;;----- Licensing notice ---------------------------------------------------
 ;;;
-;;; This file is part of the Sensble Object Design, an object system for C.
+;;; This file is part of the Sensible Object Design, an object system for C.
 ;;;
 ;;; SOD is free software; you can redistribute it and/or modify
 ;;; it under the terms of the GNU General Public License as published by
@@ -83,7 +83,7 @@     (defun parse-expression (scanner)
    term: factor | term `*' factor | term `/' factor
    factor: primary | `+' factor | `-' factor
    primary: int | id | string | `(' expression `)' | `{' fragment `}'
-     | `?' lisp-expression
+     | `<' declspec+ declarator[empty] `>' | `?' lisp-expression
 
    Only operators for dealing with integers are provided."
       (with-parser-context (token-scanner-context :scanner scanner)
@@ -107,6 +107,17 @@     (defun parse-expression (scanner)
                                          (parse-delimited-fragment scanner
                                                                    #\{ #\}))
                                          t t))
+                          (#\<
+                           (parse (seq (#\<
+                                        (ds (parse-c-type scanner))
+                                        (dc (parse-declarator
+                                             scanner ds
+                                             :kernel (lambda ()
+                                                       (values nil t nil))
+                                             :abstractp t))
+                                        #\>)
+                                    (values (cons :type (car dc))
+                                            t t))))
                           (t
                            (values (list :int :id :char :string #\?)
                                    nil nil)))))