Rev 385 | Rev 393 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
259 | daniel-mar | 1 | /* |
2 | This file is part of "Filter Foundry", a filter plugin for Adobe Photoshop |
||
3 | Copyright (C) 2003-2009 Toby Thain, toby@telegraphics.com.au |
||
4 | Copyright (C) 2018-2021 Daniel Marschall, ViaThinkSoft |
||
5 | |||
6 | This program is free software; you can redistribute it and/or modify |
||
7 | it under the terms of the GNU General Public License as published by |
||
8 | the Free Software Foundation; either version 2 of the License, or |
||
9 | (at your option) any later version. |
||
10 | |||
11 | This program is distributed in the hope that it will be useful, |
||
12 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
13 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
14 | GNU General Public License for more details. |
||
15 | |||
16 | You should have received a copy of the GNU General Public License |
||
17 | along with this program; if not, write to the Free Software |
||
18 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
||
19 | */ |
||
20 | |||
21 | #include "world.h" |
||
22 | |||
23 | #include "PIFilter.h" |
||
24 | |||
25 | #include "entry.h" |
||
26 | |||
27 | #include "choosefile.h" |
||
28 | #include "ui.h" |
||
29 | #include "file_compat.h" |
||
30 | #include "symtab.h" |
||
31 | #include "PARM.h" |
||
32 | #include "preview.h" |
||
330 | daniel-mar | 33 | #include "ff_misc.h" |
259 | daniel-mar | 34 | |
35 | #ifndef INCLUDED_FF_H |
||
36 | #define INCLUDED_FF_H |
||
37 | |||
38 | #define HOSTSIG_GIMP 'PMIG' // sic: NOT 'GIMP' |
||
39 | #define HOSTSIG_IRFANVIEW 'UP20' |
||
40 | #define HOSTSIG_PHOTOSHOP '8BIM' |
||
41 | //#define HOSTSIG_PLUGINCOMMANDER '8BIM' // meh. |
||
42 | //#define HOSTSIG_SERIF_PHOTOPLUS '8BIM' // meh. |
||
43 | #define HOSTSIG_JASC_PAINTSHOP_PRO_X 'PSP9' |
||
44 | #define HOSTSIG_PAINT_NET 'NDP.' |
||
45 | #define HOSTSIG_ADOBE_PREMIERE '8B)M'/*sic*/ |
||
46 | |||
47 | enum{ |
||
48 | TAB = 011, |
||
49 | LF = 012, |
||
50 | CR = 015, |
||
51 | |||
52 | CHUNK_ROWS = 64, |
||
53 | |||
54 | TEXT_FILETYPE = 'TEXT', |
||
55 | SIG_SIMPLETEXT = 'ttxt', |
||
56 | PS_FILTER_FILETYPE = '8BFM', |
||
57 | |||
271 | daniel-mar | 58 | // Obfuscated data will be read, but it will not be read if it is additionally protected |
259 | daniel-mar | 59 | READ_OBFUSC = 1 |
60 | }; |
||
61 | |||
62 | typedef struct{ |
||
63 | Boolean standalone,parmloaded,obfusc; |
||
64 | PARM_T parm; |
||
65 | #ifdef _WIN32 |
||
66 | HWND hWndMainDlg; |
||
67 | #endif /* _WIN32 */ |
||
68 | } globals_t; |
||
69 | |||
70 | extern globals_t *gdata; |
||
71 | |||
72 | #define NUM_CELLS 0x100 |
||
73 | |||
74 | extern struct node *tree[4]; |
||
75 | extern char *err[4]; |
||
76 | extern int errpos[4],errstart[4];//,nplanes; |
||
379 | daniel-mar | 77 | extern uint8_t slider[8]; |
301 | daniel-mar | 78 | extern value_type cell[NUM_CELLS]; |
259 | daniel-mar | 79 | extern char *expr[4]; |
80 | // extern long maxSpace; |
||
81 | |||
82 | extern int tokpos,tokstart,varused[]; |
||
83 | extern char *errstr; |
||
84 | |||
85 | #define DBG(x) {} |
||
86 | //#define DEBUG |
||
87 | |||
379 | daniel-mar | 88 | struct InternalState { |
89 | Boolean bak_obfusc; |
||
90 | Boolean bak_standalone; |
||
91 | Boolean bak_parmloaded; |
||
92 | char* bak_expr[4]; |
||
93 | uint8_t bak_slider[8]; |
||
94 | PARM_T bak_parm; |
||
95 | }; |
||
96 | |||
271 | daniel-mar | 97 | // from main.c |
276 | daniel-mar | 98 | unsigned long get_parm_hash(PARM_T *parm); |
373 | daniel-mar | 99 | void get_temp_afs(char* outfilename, Boolean isStandalone, PARM_T* parm); |
259 | daniel-mar | 100 | void DoPrepare (FilterRecordPtr epb); |
101 | void DoStart (FilterRecordPtr epb); |
||
102 | OSErr DoContinue (FilterRecordPtr epb); |
||
103 | void DoFinish (FilterRecordPtr epb); |
||
104 | void RequestNext (FilterRecordPtr epb,long); |
||
379 | daniel-mar | 105 | struct InternalState saveInternalState(); |
106 | void restoreInternalState(struct InternalState state); |
||
259 | daniel-mar | 107 | |
271 | daniel-mar | 108 | // from read.c |
389 | daniel-mar | 109 | Boolean readparams_afs_pff(Handle h,Boolean alerts,char **reason); |
259 | daniel-mar | 110 | void convert_premiere_to_photoshop(PARM_T* photoshop, PARM_T_PREMIERE* premiere); |
373 | daniel-mar | 111 | Boolean readfile_8bf(StandardFileReply *sfr,char **reason); |
259 | daniel-mar | 112 | Handle readfileintohandle(FILEREF r); |
366 | daniel-mar | 113 | Boolean readfile_afs_pff(StandardFileReply* sfr, char** reason); |
114 | Boolean readfile_ffx(StandardFileReply* sfr, char** reason); |
||
385 | daniel-mar | 115 | Boolean readfile_picotxt(StandardFileReply* sfr, char** reason); |
259 | daniel-mar | 116 | Boolean readPARM(Ptr h,PARM_T *parm,char **reasonstr,int fromwin); |
117 | |||
271 | daniel-mar | 118 | // from save.c |
389 | daniel-mar | 119 | OSErr saveparams_afs_pff(Handle h); |
120 | OSErr saveparams_picotxt(Handle h, Boolean useparm); |
||
259 | daniel-mar | 121 | OSErr savehandleintofile(Handle h,FILEREF r); |
389 | daniel-mar | 122 | Boolean savefile_afs_pff_picotxt(StandardFileReply *sfr); |
259 | daniel-mar | 123 | |
271 | daniel-mar | 124 | // from make_*.c |
259 | daniel-mar | 125 | OSErr make_standalone(StandardFileReply *sfr); |
126 | |||
271 | daniel-mar | 127 | // from process.c |
259 | daniel-mar | 128 | Boolean setup(FilterRecordPtr pb); |
129 | void evalpixel(unsigned char *outp,unsigned char *inp); |
||
130 | |||
271 | daniel-mar | 131 | // from make.c |
259 | daniel-mar | 132 | unsigned long printablehash(unsigned long hash); |
133 | size_t fixpipl(PIPropertyList *pipl,size_t origsize,StringPtr title, long *event_id); |
||
134 | size_t aete_generate(void* aeteptr, PARM_T *pparm, long event_id); |
||
292 | daniel-mar | 135 | |
136 | // from obfusc.c |
||
347 | daniel-mar | 137 | extern const volatile uint64_t cObfuscSeed; // this value will be manipulated during the building of each individual filter (see make_win.c) |
293 | daniel-mar | 138 | int obfuscation_version(PARM_T* pparm); |
347 | daniel-mar | 139 | uint64_t obfusc(PARM_T* pparm); |
271 | daniel-mar | 140 | void deobfusc(PARM_T* pparm); |
259 | daniel-mar | 141 | |
271 | daniel-mar | 142 | // from loadfile_*.c |
259 | daniel-mar | 143 | Boolean loadfile(StandardFileReply *sfr,char **reason); |
144 | Boolean readPARMresource(HMODULE hm,char **reason,int readobfusc); |
||
145 | |||
146 | // from main.c |
||
147 | int64_t maxspace(); |
||
148 | Boolean maxspace_available(); |
||
149 | Boolean host_preserves_parameters(); |
||
150 | |||
151 | // from parser.y |
||
152 | struct node *parseexpr(char *s); |
||
153 | |||
286 | daniel-mar | 154 | // from funcs.c |
155 | void factory_initialize_rnd_variables(); |
||
156 | |||
271 | daniel-mar | 157 | // Useful macros |
259 | daniel-mar | 158 | #define HAS_BIG_DOC(x) ((x)->bigDocumentData != NULL) |
159 | |||
160 | #define BIGDOC_IMAGE_SIZE(x) ((x)->bigDocumentData->imageSize32) |
||
161 | #define IMAGE_SIZE(x) ((x)->imageSize) |
||
162 | |||
163 | #define BIGDOC_FILTER_RECT(x) ((x)->bigDocumentData->filterRect32) |
||
164 | #define FILTER_RECT(x) ((x)->filterRect) |
||
165 | |||
166 | #define BIGDOC_IN_RECT(x) ((x)->bigDocumentData->inRect32) |
||
167 | #define IN_RECT(x) ((x)->inRect) |
||
168 | |||
169 | #define BIGDOC_OUT_RECT(x) ((x)->bigDocumentData->outRect32) |
||
170 | #define OUT_RECT(x) ((x)->outRect) |
||
171 | |||
172 | #define BIGDOC_MASK_RECT(x) ((x)->bigDocumentData->maskRect32) |
||
173 | #define MASK_RECT(x) ((x)->maskRect) |
||
174 | |||
175 | #define BIGDOC_FLOAT_COORD(x) ((x)->bigDocumentData->floatCoord32) |
||
176 | #define FLOAT_COORD(x) ((x)->floatCoord) |
||
177 | |||
178 | #define BIGDOC_WHOLE_SIZE(x) ((x)->bigDocumentData->wholeSize32) |
||
179 | #define WHOLE_SIZE(x) ((x)->wholeSize) |
||
180 | |||
181 | #endif /* INCLUDED_FF_H */ |