blob: c4ed1cb0b5e6994b90c5c83af49b81cf65c32993 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
% Copyright (C) 2001-2019 Artifex Software, Inc.
% All Rights Reserved.
%
% This software is provided AS-IS with no warranty, either express or
% implied.
%
% This software is distributed under license and may not be copied,
% modified or distributed except as expressly authorized under the terms
% of the license contained in the file LICENSE in this distribution.
%
% Refer to licensing information at http://www.artifex.com or contact
% Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
% CA 94945, U.S.A., +1(415)492-9861, for further information.
%
% Implementation of ReusableStreamDecode filter.
% This file must be loaded after gs_lev2.ps and gs_res.ps.
level2dict begin
% ------ ReusableStreamDecode filter ------ %
/.reusablestreamdecode { % <source> <dict> .reusablestreamdecode <file>
% <source> .reusablestreamdecode <file>
% Collect the filter parameters.
dup type /dicttype eq { 2 copy } { dup 0 dict } ifelse
dup .rsdparams
% Construct the filter pipeline.
% The very first filter should use the value of CloseSource
% from the RSD dictionary; all the others should have
% CloseSource = true.
% Stack: source dict filters parms
2 index /CloseSource .knownget not { //false } if 5 -1 roll
% Stack: dict filters parms CloseSource source
0 1 5 index length 1 sub {
4 index 1 index get
% Stack: dict filters parms CloseSource source index filtname
4 index //null eq {
0 dict
} {
4 index 2 index get dup //null eq { pop 0 dict} if
} ifelse
3 -1 roll pop exch filter
exch pop //true exch % set CloseSource for further filters
} for
% If AsyncRead is true, try to create the filter directly.
% Stack: dict filters parms CloseSource source
4 index /AsyncRead .knownget not { //false } if {
1 index { .reusablestream } //.internalstopped exec
} {
//null //true
} ifelse {
pop
% No luck. Read the entire contents of the stream now.
dup type /filetype ne {
% Make a stream from a procedure or string data source.
0 () .subfiledecode
} if
% We must allocate the string in the same VM space as its
% source, since the reusable stream must be allocated there.
.currentglobal 1 index gcheck .setglobal exch
currentpacking //false setpacking exch
% Stack: dict filters parms CloseSource oldglobal oldpacking file
[ exch { dup 40000 string readstring not { exit } if exch } loop
exch pop
]
% Stack: dict filters parms CloseSource oldglobal oldpacking [()...]
3 1 roll setpacking setglobal
% Stack: dict filters parms CloseSource [()...]
1 index .reusablestream
} if
% We created the stream successfully: clean up.
4 { exch pop } repeat
1 index type /dicttype eq { exch pop } if exch pop
} odef
filterdict /ReusableStreamDecode /.reusablestreamdecode load put
end % level2dict
|