X-Git-Url: https://git.jsancho.org/?a=blobdiff_plain;ds=sidebyside;f=gacela_GL.lisp;h=c17b049cc0f8688c232f931390a30565ef1570bc;hb=a807d13b26724e7219b3e7e82915a43ff9d327cc;hp=8b532f33e7f3a21022e8cfe76081d074f9e20eda;hpb=90f83164ea36dae4c0f3370f8ebbf7e30fe83297;p=gacela.git
diff --git a/gacela_GL.lisp b/gacela_GL.lisp
index 8b532f3..c17b049 100644
--- a/gacela_GL.lisp
+++ b/gacela_GL.lisp
@@ -15,7 +15,20 @@
;;; along with this program. If not, see .
-(in-package :gacela)
+(eval-when (compile load eval)
+ (when (not (find-package 'gacela)) (make-package 'gacela :nicknames '(gg) :use '(lisp)))
+ (in-package 'gacela :nicknames '(gg) :use '(lisp)))
+
+
+(defmacro mapcconst (type c-type name)
+ (let ((c-header (concatenate 'string c-type " gacela_" name " (void)"))
+ (c-body (concatenate 'string "return " name ";"))
+ (c-name (concatenate 'string "gacela_" name))
+ (lisp-name (intern (string-upcase name))))
+ `(progn
+ (defcfun ,c-header 0 ,c-body)
+ (defentry ,lisp-name () (,type ,c-name))
+ (eval-when (load) (defconstant ,lisp-name (,lisp-name))))))
(clines "#include ")
(clines "#include ")
@@ -190,12 +203,21 @@
(defcfun "void gacela_glOrtho (float left, float right, float bottom, float top, float near_val, float far_val)" 0
"glOrtho (left, right, bottom, top, near_val, far_val);")
+(defcfun "void gacela_glPushMatrix (void)" 0
+ "glPushMatrix ();")
+
+(defcfun "void gacela_glPopMatrix (void)" 0
+ "glPopMatrix ();")
+
(defcfun "void gacela_gluPerspective (double fovy, double aspect, double zNear, double zFar)" 0
"gluPerspective (fovy, aspect, zNear, zFar);")
(defcfun "int gacela_gluBuild2DMipmaps (int target, int internalFormat, int width, int height, int format, int type, int data)" 0
"return gluBuild2DMipmaps (target, internalFormat, width, height, format, type, data);")
+(defcfun "void gacela_gluLookAt (double eyeX, double eyeY, double eyeZ, double centerX, double centerY, double centerZ, double upX, double upY, double upZ)" 0
+ "gluLookAt (eyeX, eyeY, eyeZ, centerX, centerY, centerZ, upX, upY, upZ);")
+
(defentry glBegin (int) (void "gacela_glBegin"))
(defentry glClear (int) (void "gacela_glClear"))
(defentry glClearColor (float float float float) (void "gacela_glClearColor"))
@@ -225,6 +247,9 @@
(defentry glNormal3f (float float float) (void "gacela_glNormal3f"))
(defentry glBlendFunc (int int) (void "gacela_glBlendFunc"))
(defentry glOrtho (float float float float float float) (void "gacela_glOrtho"))
+(defentry glPushMatrix () (void "gacela_glPushMatrix"))
+(defentry glPopMatrix () (void "gacela_glPopMatrix"))
(defentry gluPerspective (double double double double) (void "gacela_gluPerspective"))
(defentry gluBuild2DMipmaps (int int int int int int int) (int "gacela_gluBuild2DMipmaps"))
+(defentry gluLookAt (double double double double double double double double double) (void "gacela_gluLookAt"))