1 /* Copyright (C) 2005-2008 by George Williams */
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions are met:
6 * Redistributions of source code must retain the above copyright notice, this
7 * list of conditions and the following disclaimer.
9 * Redistributions in binary form must reproduce the above copyright notice,
10 * this list of conditions and the following disclaimer in the documentation
11 * and/or other materials provided with the distribution.
13 * The name of the author may not be used to endorse or promote products
14 * derived from this software without specific prior written permission.
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
19 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
22 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
23 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
24 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
25 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 #include "fontforgevw.h"
35 /* If users want to write user defined scripting built-in functions they will */
36 /* need this file. The most relevant structure is the Context */
44 struct dictentry
*entries
;
48 typedef struct array
{
54 enum token_type
{ tt_name
, tt_string
, tt_number
, tt_unicode
, tt_real
,
55 tt_lparen
, tt_rparen
, tt_comma
, tt_eos
, /* eos is end of statement, semicolon, newline */
56 tt_lbracket
, tt_rbracket
,
57 tt_minus
, tt_plus
, tt_not
, tt_bitnot
, tt_colon
,
58 tt_mul
, tt_div
, tt_mod
, tt_and
, tt_or
, tt_bitand
, tt_bitor
, tt_xor
,
59 tt_eq
, tt_ne
, tt_gt
, tt_lt
, tt_ge
, tt_le
,
60 tt_assign
, tt_pluseq
, tt_minuseq
, tt_muleq
, tt_diveq
, tt_modeq
,
63 tt_if
, tt_else
, tt_elseif
, tt_endif
, tt_while
, tt_foreach
, tt_endloop
,
64 tt_shift
, tt_return
, tt_break
,
71 typedef struct context
{
72 struct context
*caller
; /* The context of the script that called us */
73 Array a
; /* The argument array */
74 Array
**dontfree
; /* Irrelevant for user defined funcs */
75 struct dictionary locals
; /* Irrelevant for user defined funcs */
76 FILE *script
; /* Irrelevant for user defined funcs */
77 unsigned int backedup
: 1; /* Irrelevant for user defined funcs */
78 unsigned int donteval
: 1; /* Irrelevant for user defined funcs */
79 unsigned int returned
: 1; /* Irrelevant for user defined funcs */
80 unsigned int broken
: 1; /* Irrelevant for user defined funcs */
81 char tok_text
[TOK_MAX
+1]; /* Irrelevant for user defined funcs */
82 enum token_type tok
; /* Irrelevant for user defined funcs */
83 Val tok_val
; /* Irrelevant for user defined funcs */
84 Val return_val
; /* Initialized to void. If user wants */
85 /* return something set the return */
87 Val trace
; /* Irrelevant for user defined funcs */
88 Val argsval
; /* Irrelevant for user defined funcs */
89 char *filename
; /* Irrelevant for user defined funcs */
90 int lineno
; /* Irrelevant for user defined funcs */
91 int ungotch
; /* Irrelevant for user defined funcs */
92 FontViewBase
*curfv
; /* Current fontview */
93 jmp_buf *err_env
; /* place to longjump to on an error */
96 void arrayfree(Array
*);
98 void FontImage(SplineFont
*sf
,char *filename
,Array
*arr
,int width
,int height
);
100 /* Adds a user defined scripting function to the interpretter */
101 /* (you can't override a built-in name) */
102 /* (you can replace a previous user defined function */
103 /* Most functions will require a font to be loaded, but a few do not */
104 /* Open(), Exit(), Sin() don't. ff uses the needs_font flag to perform */
105 /* this check for you */
106 /* Returns 1 if the addition was successful, 2 if it replaced a previous func */
107 /* Returns 0 on failure (ie. if it attempts to replace a builtin function) */
108 typedef void (*UserDefScriptFunc
)(Context
*);
109 extern int AddScriptingCommand(char *name
,UserDefScriptFunc func
,int needs_font
);
111 /* Returns whether a user defined scripting command already exists with the */
113 extern UserDefScriptFunc
HasUserScriptingCommand(char *name
);
115 /* Scripts used to be in latin1, and we still support that if the user sets */
116 /* an environment variable. Now scripts are by default utf8. These two funcs */
117 /* will interconvert between latin1 & utf8 if appropriate, or just make a */
118 /* utf8 copy if not. They always make a copy. */
119 extern char *utf82script_copy(const char *ustr
);
120 extern char *script2utf8_copy(const char *str
);
122 /* Various error routines. */
123 void ScriptError( Context
*c
, const char *msg
);
124 /* Prints an error message and exits. msg is in the script's encoding */
125 void ScriptErrorString( Context
*c
, const char *msg
, const char *name
);
126 /* Prints an error message followed by a string and exits. */
127 /* both strings are in the script's encoding */
128 void ScriptErrorF( Context
*c
, const char *fmt
, ... );
129 /* Standard printf-style spec. All string arguments assumed to be in */
132 extern int running_script
;
134 /* Hooks so a scripting dlg can execute fontforge's legacy scripting language */
135 extern void ff_VerboseCheck(void);
136 extern enum token_type
ff_NextToken(Context
*c
);
137 extern void ff_backuptok(Context
*c
);
138 extern void ff_statement(Context
*);
140 #endif /* _SCRIPTING_H */