Subversion Repositories filter_foundry

Rev

Rev 430 | Rev 440 | 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
 
439 daniel-mar 21
#ifndef FF_H_
22
#define FF_H_
23
 
259 daniel-mar 24
#include "world.h"
25
 
26
#include "PIFilter.h"
27
 
28
#include "entry.h"
29
 
30
#include "choosefile.h"
31
#include "ui.h"
32
#include "file_compat.h"
33
#include "symtab.h"
34
#include "PARM.h"
35
#include "preview.h"
330 daniel-mar 36
#include "ff_misc.h"
259 daniel-mar 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{
408 daniel-mar 63
        Boolean standalone;
64
        Boolean parmloaded; // this means that the filter is loaded, but without PARM (title, author, etc.)
65
        Boolean obfusc;
259 daniel-mar 66
        PARM_T parm;
67
        #ifdef _WIN32
68
        HWND hWndMainDlg;
430 daniel-mar 69
        HMODULE pluginDllModule;
422 daniel-mar 70
        DWORD pluginDllSliderMessageId;
259 daniel-mar 71
        #endif /* _WIN32 */
72
} globals_t;
73
 
74
extern globals_t *gdata;
75
 
76
#define NUM_CELLS 0x100
77
 
78
extern struct node *tree[4];
79
extern char *err[4];
80
extern int errpos[4],errstart[4];//,nplanes;
379 daniel-mar 81
extern uint8_t slider[8];
301 daniel-mar 82
extern value_type cell[NUM_CELLS];
259 daniel-mar 83
extern char *expr[4];
84
// extern long maxSpace;
85
 
86
extern int tokpos,tokstart,varused[];
87
extern char *errstr;
88
 
89
#define DBG(x) {}
90
//#define DEBUG
91
 
430 daniel-mar 92
typedef struct InternalState_ {
379 daniel-mar 93
        Boolean bak_obfusc;
94
        Boolean bak_standalone;
95
        Boolean bak_parmloaded;
96
        char* bak_expr[4];
97
        uint8_t bak_slider[8];
98
        PARM_T bak_parm;
430 daniel-mar 99
} InternalState;
379 daniel-mar 100
 
271 daniel-mar 101
// from main.c
276 daniel-mar 102
unsigned long get_parm_hash(PARM_T *parm);
373 daniel-mar 103
void get_temp_afs(char* outfilename, Boolean isStandalone, PARM_T* parm);
259 daniel-mar 104
void DoPrepare (FilterRecordPtr epb);
105
void DoStart (FilterRecordPtr epb);
106
OSErr DoContinue (FilterRecordPtr epb);
107
void DoFinish (FilterRecordPtr epb);
108
void RequestNext (FilterRecordPtr epb,long);
430 daniel-mar 109
InternalState saveInternalState();
110
void restoreInternalState(InternalState state);
259 daniel-mar 111
 
271 daniel-mar 112
// from read.c
408 daniel-mar 113
Boolean readparams_afs_pff(Handle h,char **reason);
259 daniel-mar 114
void convert_premiere_to_photoshop(PARM_T* photoshop, PARM_T_PREMIERE* premiere);
373 daniel-mar 115
Boolean readfile_8bf(StandardFileReply *sfr,char **reason);
259 daniel-mar 116
Handle readfileintohandle(FILEREF r);
366 daniel-mar 117
Boolean readfile_afs_pff(StandardFileReply* sfr, char** reason);
118
Boolean readfile_ffx(StandardFileReply* sfr, char** reason);
385 daniel-mar 119
Boolean readfile_picotxt(StandardFileReply* sfr, char** reason);
394 daniel-mar 120
Boolean readPARM(PARM_T* parm,Ptr h);
259 daniel-mar 121
 
271 daniel-mar 122
// from save.c
389 daniel-mar 123
OSErr saveparams_afs_pff(Handle h);
124
OSErr saveparams_picotxt(Handle h, Boolean useparm);
259 daniel-mar 125
OSErr savehandleintofile(Handle h,FILEREF r);
389 daniel-mar 126
Boolean savefile_afs_pff_picotxt(StandardFileReply *sfr);
259 daniel-mar 127
 
271 daniel-mar 128
// from make_*.c
259 daniel-mar 129
OSErr make_standalone(StandardFileReply *sfr);
130
 
271 daniel-mar 131
// from process.c
259 daniel-mar 132
Boolean setup(FilterRecordPtr pb);
133
void evalpixel(unsigned char *outp,unsigned char *inp);
134
 
271 daniel-mar 135
// from make.c
259 daniel-mar 136
unsigned long printablehash(unsigned long hash);
393 daniel-mar 137
size_t fixpipl(PIPropertyList *pipl,size_t origsize,char* title, long *event_id);
259 daniel-mar 138
size_t aete_generate(void* aeteptr, PARM_T *pparm, long event_id);
292 daniel-mar 139
 
140
// from obfusc.c
347 daniel-mar 141
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 142
int obfuscation_version(PARM_T* pparm);
347 daniel-mar 143
uint64_t obfusc(PARM_T* pparm);
271 daniel-mar 144
void deobfusc(PARM_T* pparm);
259 daniel-mar 145
 
271 daniel-mar 146
// from loadfile_*.c
259 daniel-mar 147
Boolean loadfile(StandardFileReply *sfr,char **reason);
148
Boolean readPARMresource(HMODULE hm,char **reason,int readobfusc);
149
 
150
// from main.c
151
int64_t maxspace();
152
Boolean maxspace_available();
153
Boolean host_preserves_parameters();
154
 
155
// from parser.y
156
struct node *parseexpr(char *s);
157
 
286 daniel-mar 158
// from funcs.c
159
void factory_initialize_rnd_variables();
160
 
271 daniel-mar 161
// Useful macros
259 daniel-mar 162
#define HAS_BIG_DOC(x) ((x)->bigDocumentData != NULL)
163
 
164
#define BIGDOC_IMAGE_SIZE(x) ((x)->bigDocumentData->imageSize32)
165
#define IMAGE_SIZE(x) ((x)->imageSize)
166
 
167
#define BIGDOC_FILTER_RECT(x) ((x)->bigDocumentData->filterRect32)
168
#define FILTER_RECT(x) ((x)->filterRect)
169
 
170
#define BIGDOC_IN_RECT(x) ((x)->bigDocumentData->inRect32)
171
#define IN_RECT(x) ((x)->inRect)
172
 
173
#define BIGDOC_OUT_RECT(x) ((x)->bigDocumentData->outRect32)
174
#define OUT_RECT(x) ((x)->outRect)
175
 
176
#define BIGDOC_MASK_RECT(x) ((x)->bigDocumentData->maskRect32)
177
#define MASK_RECT(x) ((x)->maskRect)
178
 
179
#define BIGDOC_FLOAT_COORD(x) ((x)->bigDocumentData->floatCoord32)
180
#define FLOAT_COORD(x) ((x)->floatCoord)
181
 
182
#define BIGDOC_WHOLE_SIZE(x) ((x)->bigDocumentData->wholeSize32)
183
#define WHOLE_SIZE(x) ((x)->wholeSize)
184
 
439 daniel-mar 185
#endif