(in-package :gacela)
+(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 <FTGL/ftgl.h>")
+(mapcconst int "int" "ft_encoding_unicode")
+(mapcconst int "int" "FTGL_RENDER_ALL")
+
;;; FTGL Functions
(defcfun "int gacela_ftglCreateTextureFont (char *file)" 0
"return ftglCreateTextureFont (file);")
(defcfun "int gacela_ftglSetFontFaceSize (int font, int size, int res)" 0
"return ftglSetFontFaceSize (font, size, res);")
-(defcfun "int gacela_ftglSetFontCharMap(int font, int encoding)" 0
- "return ftglSetFontCharMap(font, encoding);")
+(defcfun "int gacela_ftglSetFontCharMap (int font, int encoding)" 0
+ "return ftglSetFontCharMap (font, encoding);")
+
+(defcfun "void gacela_ftglRenderFont (int font, char *string, int mode)" 0
+ "ftglRenderFont (font, string, mode);")
+
+(defcfun "void gacela_ftglDestroyFont (int font)" 0
+ "ftglDestroyFont (font);")
(defentry ftglCreateTextureFont (string) (int "gacela_ftglCreateTextureFont"))
(defentry ftglSetFontFaceSize (int int int) (int "gacela_ftglSetFontFaceSize"))
(defentry ftglSetFontCharMap (int int) (int "gacela_ftglSetFontCharMap"))
+(defentry ftglRenderFont (int string int) (void "gacela_ftglRenderFont"))
+(defentry ftglDestroyFont (int) (void "gacela_ftglDestroyFont"))