X-Git-Url: http://git.kpe.io/?p=clsql.git;a=blobdiff_plain;f=sql%2Fsyntax.lisp;h=f00545e9c22d288fd2afffbf985790e1264195e5;hp=5ad83d8ca2c27f6ed6859cf7845abf823191e389;hb=1b07d2fd927cf8f1943ac0a0b8c980d1dc707076;hpb=daa416b0cddb7d18a9bc4c85988203aad4429ad6 diff --git a/sql/syntax.lisp b/sql/syntax.lisp index 5ad83d8..f00545e 100644 --- a/sql/syntax.lisp +++ b/sql/syntax.lisp @@ -16,9 +16,7 @@ (in-package #:clsql-sys) -(defvar *original-reader-enter* nil) - -(defvar *original-reader-exit* nil) +(defvar *original-readtable* nil) (defvar *sql-macro-open-char* #\[) @@ -45,9 +43,9 @@ the current syntax state." (%disable-sql-reader-syntax))) (defun %disable-sql-reader-syntax () - (when *original-reader-enter* - (set-macro-character *sql-macro-open-char* *original-reader-enter*)) - (setf *original-reader-enter* nil) + (when *original-readtable* + (setf *readtable* *original-readtable* + *original-readtable* nil)) (values)) @@ -69,10 +67,11 @@ the current syntax state." (%enable-sql-reader-syntax))) (defun %enable-sql-reader-syntax () - (unless *original-reader-enter* - (setf *original-reader-enter* (get-macro-character *sql-macro-open-char*))) - (set-macro-character *sql-macro-open-char* #'sql-reader-open) - (enable-sql-close-syntax) + (unless *original-readtable* + (setf *original-readtable* *readtable* + *readtable* (copy-readtable)) + (set-macro-character *sql-macro-open-char* #'sql-reader-open) + (set-macro-character *sql-macro-close-char* (get-macro-character #\)))) (values)) (defmacro restore-sql-reader-syntax-state () @@ -102,18 +101,6 @@ reader syntax is disabled." :message (format nil "Error ~A occured while attempting to parse '~A' at file position ~A" (sql-user-error-message c) sqllist (file-position stream)))))))) -(defun disable-sql-close-syntax () - "Internal function that disables the close syntax when leaving - sql context." - (set-macro-character *sql-macro-close-char* *original-reader-exit*) - (setf *original-reader-exit* nil)) - -(defun enable-sql-close-syntax () - "Internal function that enables close syntax when entering SQL - context." - (setf *original-reader-exit* (get-macro-character *sql-macro-close-char*)) - (set-macro-character *sql-macro-close-char* (get-macro-character #\)))) - (defun generate-sql-reference (&rest arglist) (cond ((= (length arglist) 1) ; string, table or attribute (if (stringp (car arglist))