Rev 293 | Rev 309 | 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" |
||
33 | #include "misc.h" |
||
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 | PARM_TYPE = 'PARM', |
||
55 | PARM_ID = 16000, |
||
56 | OBFUSCDATA_ID = 16001, |
||
57 | TEXT_FILETYPE = 'TEXT', |
||
58 | SIG_SIMPLETEXT = 'ttxt', |
||
59 | PS_FILTER_FILETYPE = '8BFM', |
||
60 | |||
271 | daniel-mar | 61 | // Obfuscated data will be read, but it will not be read if it is additionally protected |
259 | daniel-mar | 62 | READ_OBFUSC = 1 |
63 | }; |
||
64 | |||
65 | typedef struct{ |
||
66 | Boolean standalone,parmloaded,obfusc; |
||
67 | PARM_T parm; |
||
68 | #ifdef _WIN32 |
||
69 | HWND hWndMainDlg; |
||
70 | #endif /* _WIN32 */ |
||
71 | } globals_t; |
||
72 | |||
73 | extern globals_t *gdata; |
||
74 | |||
75 | #define NUM_CELLS 0x100 |
||
76 | |||
77 | extern struct node *tree[4]; |
||
78 | extern char *err[4]; |
||
79 | extern int errpos[4],errstart[4];//,nplanes; |
||
301 | daniel-mar | 80 | extern uint8_t slider[8],map[4][0x100]; |
81 | extern value_type cell[NUM_CELLS]; |
||
259 | daniel-mar | 82 | extern char *expr[4]; |
83 | // extern long maxSpace; |
||
84 | |||
85 | extern int tokpos,tokstart,varused[]; |
||
86 | extern char *errstr; |
||
87 | |||
88 | #define DBG(x) {} |
||
89 | //#define DEBUG |
||
90 | |||
271 | daniel-mar | 91 | // from main.c |
276 | daniel-mar | 92 | unsigned long get_parm_hash(PARM_T *parm); |
259 | daniel-mar | 93 | void DoPrepare (FilterRecordPtr epb); |
94 | void DoStart (FilterRecordPtr epb); |
||
95 | OSErr DoContinue (FilterRecordPtr epb); |
||
96 | void DoFinish (FilterRecordPtr epb); |
||
97 | void RequestNext (FilterRecordPtr epb,long); |
||
98 | |||
271 | daniel-mar | 99 | // from read.c |
259 | daniel-mar | 100 | Boolean readparams(Handle h,Boolean alerts,char **reason); |
101 | void convert_premiere_to_photoshop(PARM_T* photoshop, PARM_T_PREMIERE* premiere); |
||
102 | Boolean read8bfplugin(StandardFileReply *sfr,char **reason); |
||
103 | Handle readfileintohandle(FILEREF r); |
||
104 | Boolean readfile(StandardFileReply *sfr,char **reason); |
||
105 | Boolean readPARM(Ptr h,PARM_T *parm,char **reasonstr,int fromwin); |
||
106 | |||
271 | daniel-mar | 107 | // from save.c |
259 | daniel-mar | 108 | OSErr saveparams(Handle h); |
109 | OSErr savehandleintofile(Handle h,FILEREF r); |
||
110 | Boolean savefile(StandardFileReply *sfr); |
||
111 | |||
271 | daniel-mar | 112 | // from make_*.c |
259 | daniel-mar | 113 | OSErr make_standalone(StandardFileReply *sfr); |
114 | |||
271 | daniel-mar | 115 | // from process.c |
259 | daniel-mar | 116 | Boolean setup(FilterRecordPtr pb); |
117 | void evalpixel(unsigned char *outp,unsigned char *inp); |
||
118 | |||
271 | daniel-mar | 119 | // from make.c |
259 | daniel-mar | 120 | unsigned long printablehash(unsigned long hash); |
121 | size_t fixpipl(PIPropertyList *pipl,size_t origsize,StringPtr title, long *event_id); |
||
122 | size_t aete_generate(void* aeteptr, PARM_T *pparm, long event_id); |
||
292 | daniel-mar | 123 | |
124 | // from obfusc.c |
||
125 | extern const volatile uint32_t cObfuscV4Seed; // this value will be manipulated during the building of each individual filter (see make_win.c) |
||
293 | daniel-mar | 126 | int obfuscation_version(PARM_T* pparm); |
292 | daniel-mar | 127 | unsigned int obfusc(PARM_T* pparm); |
271 | daniel-mar | 128 | void deobfusc(PARM_T* pparm); |
259 | daniel-mar | 129 | |
271 | daniel-mar | 130 | // from loadfile_*.c |
259 | daniel-mar | 131 | Boolean loadfile(StandardFileReply *sfr,char **reason); |
132 | Boolean readPARMresource(HMODULE hm,char **reason,int readobfusc); |
||
133 | |||
134 | // from main.c |
||
135 | int64_t maxspace(); |
||
136 | Boolean maxspace_available(); |
||
137 | Boolean host_preserves_parameters(); |
||
138 | |||
139 | // from parser.y |
||
140 | struct node *parseexpr(char *s); |
||
141 | |||
286 | daniel-mar | 142 | // from funcs.c |
143 | void factory_initialize_rnd_variables(); |
||
144 | |||
271 | daniel-mar | 145 | // Useful macros |
259 | daniel-mar | 146 | #define HAS_BIG_DOC(x) ((x)->bigDocumentData != NULL) |
147 | |||
148 | #define BIGDOC_IMAGE_SIZE(x) ((x)->bigDocumentData->imageSize32) |
||
149 | #define IMAGE_SIZE(x) ((x)->imageSize) |
||
150 | |||
151 | #define BIGDOC_FILTER_RECT(x) ((x)->bigDocumentData->filterRect32) |
||
152 | #define FILTER_RECT(x) ((x)->filterRect) |
||
153 | |||
154 | #define BIGDOC_IN_RECT(x) ((x)->bigDocumentData->inRect32) |
||
155 | #define IN_RECT(x) ((x)->inRect) |
||
156 | |||
157 | #define BIGDOC_OUT_RECT(x) ((x)->bigDocumentData->outRect32) |
||
158 | #define OUT_RECT(x) ((x)->outRect) |
||
159 | |||
160 | #define BIGDOC_MASK_RECT(x) ((x)->bigDocumentData->maskRect32) |
||
161 | #define MASK_RECT(x) ((x)->maskRect) |
||
162 | |||
163 | #define BIGDOC_FLOAT_COORD(x) ((x)->bigDocumentData->floatCoord32) |
||
164 | #define FLOAT_COORD(x) ((x)->floatCoord) |
||
165 | |||
166 | #define BIGDOC_WHOLE_SIZE(x) ((x)->bigDocumentData->wholeSize32) |
||
167 | #define WHOLE_SIZE(x) ((x)->wholeSize) |
||
168 | |||
169 | |||
170 | #ifdef _MSC_VER |
||
171 | // Microsoft dumbassery |
||
172 | #define strcasecmp _stricmp |
||
173 | #define snprintf _snprintf |
||
174 | #endif /* _MSC_VER */ |
||
175 | |||
176 | #endif /* INCLUDED_FF_H */ |
||
276 | daniel-mar | 177 |