-rw-r--r-- | core/multimedia/opieplayer/libflash/config.in | 2 | ||||
-rw-r--r-- | core/multimedia/opieplayer/libflash/shape.cc | 2 | ||||
-rw-r--r-- | core/multimedia/opieplayer/libmad/config.in | 2 | ||||
-rw-r--r-- | core/multimedia/opieplayer/libmpeg3/config.in | 2 | ||||
-rw-r--r-- | core/multimedia/opieplayer/modplug/config.in | 2 | ||||
-rw-r--r-- | core/multimedia/opieplayer/wavplugin/config.in | 2 |
6 files changed, 7 insertions, 5 deletions
diff --git a/core/multimedia/opieplayer/libflash/config.in b/core/multimedia/opieplayer/libflash/config.in index 91a57da..258e8ee 100644 --- a/core/multimedia/opieplayer/libflash/config.in +++ b/core/multimedia/opieplayer/libflash/config.in | |||
@@ -1,4 +1,4 @@ | |||
1 | # config #LIBFLASH | 1 | # config #LIBFLASH |
2 | # boolean "libflash" | 2 | # boolean "libflash" |
3 | # default "y" | 3 | # default "y" |
4 | # depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE | 4 | # depends ( LIBQPE || LIBQPE-X11 ) |
diff --git a/core/multimedia/opieplayer/libflash/shape.cc b/core/multimedia/opieplayer/libflash/shape.cc index 0d8df93..4d4ecb8 100644 --- a/core/multimedia/opieplayer/libflash/shape.cc +++ b/core/multimedia/opieplayer/libflash/shape.cc | |||
@@ -1,280 +1,282 @@ | |||
1 | ///////////////////////////////////////////////////////////// | 1 | ///////////////////////////////////////////////////////////// |
2 | // Flash Plugin and Player | 2 | // Flash Plugin and Player |
3 | // Copyright (C) 1998,1999 Olivier Debon | 3 | // Copyright (C) 1998,1999 Olivier Debon |
4 | // | 4 | // |
5 | // This program is free software; you can redistribute it and/or | 5 | // This program is free software; you can redistribute it and/or |
6 | // modify it under the terms of the GNU General Public License | 6 | // modify it under the terms of the GNU General Public License |
7 | // as published by the Free Software Foundation; either version 2 | 7 | // as published by the Free Software Foundation; either version 2 |
8 | // of the License, or (at your option) any later version. | 8 | // of the License, or (at your option) any later version. |
9 | // | 9 | // |
10 | // This program is distributed in the hope that it will be useful, | 10 | // This program is distributed in the hope that it will be useful, |
11 | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 11 | // but WITHOUT ANY WARRANTY; without even the implied warranty of |
12 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 12 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
13 | // GNU General Public License for more details. | 13 | // GNU General Public License for more details. |
14 | // | 14 | // |
15 | // You should have received a copy of the GNU General Public License | 15 | // You should have received a copy of the GNU General Public License |
16 | // along with this program; if not, write to the Free Software | 16 | // along with this program; if not, write to the Free Software |
17 | // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 17 | // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
18 | // | 18 | // |
19 | /////////////////////////////////////////////////////////////// | 19 | /////////////////////////////////////////////////////////////// |
20 | // Author : Olivier Debon <odebon@club-internet.fr> | 20 | // Author : Olivier Debon <odebon@club-internet.fr> |
21 | // | 21 | // |
22 | 22 | ||
23 | #include "swf.h" | 23 | #include "swf.h" |
24 | 24 | ||
25 | #include "math.h" | ||
26 | |||
25 | #ifdef RCSID | 27 | #ifdef RCSID |
26 | static char *rcsid = "$Id$"; | 28 | static char *rcsid = "$Id$"; |
27 | #endif | 29 | #endif |
28 | 30 | ||
29 | #define PRINT 0 | 31 | #define PRINT 0 |
30 | 32 | ||
31 | #define ABS(v) ((v) < 0 ? -(v) : (v)) | 33 | #define ABS(v) ((v) < 0 ? -(v) : (v)) |
32 | 34 | ||
33 | static void prepareStyles(GraphicDevice *gd, Matrix *matrix, Cxform *cxform, FillStyleDef *f, long n); | 35 | static void prepareStyles(GraphicDevice *gd, Matrix *matrix, Cxform *cxform, FillStyleDef *f, long n); |
34 | 36 | ||
35 | static void clearStyles(GraphicDevice *gd, FillStyleDef *f, long n); | 37 | static void clearStyles(GraphicDevice *gd, FillStyleDef *f, long n); |
36 | 38 | ||
37 | static void drawShape(GraphicDevice *gd, Matrix *matrix1, Cxform *cxform, Shape *shape, | 39 | static void drawShape(GraphicDevice *gd, Matrix *matrix1, Cxform *cxform, Shape *shape, |
38 | ShapeAction shapeAction, void *id,ScanLineFunc scan_line_func); | 40 | ShapeAction shapeAction, void *id,ScanLineFunc scan_line_func); |
39 | 41 | ||
40 | // Constructor | 42 | // Constructor |
41 | 43 | ||
42 | Shape::Shape(long id, int level) : Character(ShapeType, id) | 44 | Shape::Shape(long id, int level) : Character(ShapeType, id) |
43 | { | 45 | { |
44 | defLevel = level; | 46 | defLevel = level; |
45 | 47 | ||
46 | defaultFillStyle.type = f_Solid; | 48 | defaultFillStyle.type = f_Solid; |
47 | defaultFillStyle.color.red = 0; | 49 | defaultFillStyle.color.red = 0; |
48 | defaultFillStyle.color.green = 0; | 50 | defaultFillStyle.color.green = 0; |
49 | defaultFillStyle.color.blue = 0; | 51 | defaultFillStyle.color.blue = 0; |
50 | defaultFillStyle.color.alpha = ALPHA_OPAQUE; | 52 | defaultFillStyle.color.alpha = ALPHA_OPAQUE; |
51 | 53 | ||
52 | defaultLineStyle.width = 0; | 54 | defaultLineStyle.width = 0; |
53 | 55 | ||
54 | // This is to force a first update | 56 | // This is to force a first update |
55 | lastMat.a = 0; | 57 | lastMat.a = 0; |
56 | lastMat.d = 0; | 58 | lastMat.d = 0; |
57 | shape_size += sizeof(Shape); | 59 | shape_size += sizeof(Shape); |
58 | shape_nb ++; | 60 | shape_nb ++; |
59 | 61 | ||
60 | file_ptr = NULL; | 62 | file_ptr = NULL; |
61 | getStyles = 0; | 63 | getStyles = 0; |
62 | getAlpha = 0; | 64 | getAlpha = 0; |
63 | } | 65 | } |
64 | 66 | ||
65 | Shape::~Shape() | 67 | Shape::~Shape() |
66 | { | 68 | { |
67 | if (file_ptr) { | 69 | if (file_ptr) { |
68 | free(file_ptr); | 70 | free(file_ptr); |
69 | } | 71 | } |
70 | } | 72 | } |
71 | 73 | ||
72 | void | 74 | void |
73 | Shape::setBoundingBox(Rect rect) | 75 | Shape::setBoundingBox(Rect rect) |
74 | { | 76 | { |
75 | boundary = rect; | 77 | boundary = rect; |
76 | } | 78 | } |
77 | 79 | ||
78 | void | 80 | void |
79 | Shape::getBoundingBox(Rect *bb, DisplayListEntry *e) | 81 | Shape::getBoundingBox(Rect *bb, DisplayListEntry *e) |
80 | { | 82 | { |
81 | *bb = boundary; | 83 | *bb = boundary; |
82 | } | 84 | } |
83 | 85 | ||
84 | int | 86 | int |
85 | Shape::execute(GraphicDevice *gd, Matrix *matrix, Cxform *cxform) | 87 | Shape::execute(GraphicDevice *gd, Matrix *matrix, Cxform *cxform) |
86 | { | 88 | { |
87 | //printf("TagId = %d\n", getTagId()); | 89 | //printf("TagId = %d\n", getTagId()); |
88 | //if (getTagId() != 220) return 0; | 90 | //if (getTagId() != 220) return 0; |
89 | 91 | ||
90 | if (cxform) { | 92 | if (cxform) { |
91 | defaultFillStyle.color = cxform->getColor(gd->getForegroundColor()); | 93 | defaultFillStyle.color = cxform->getColor(gd->getForegroundColor()); |
92 | } else { | 94 | } else { |
93 | defaultFillStyle.color = gd->getForegroundColor(); | 95 | defaultFillStyle.color = gd->getForegroundColor(); |
94 | } | 96 | } |
95 | defaultFillStyle.color.pixel = gd->allocColor(defaultFillStyle.color); | 97 | defaultFillStyle.color.pixel = gd->allocColor(defaultFillStyle.color); |
96 | 98 | ||
97 | drawShape(gd, matrix, cxform, this, ShapeDraw, NULL, 0); | 99 | drawShape(gd, matrix, cxform, this, ShapeDraw, NULL, 0); |
98 | return 0; | 100 | return 0; |
99 | } | 101 | } |
100 | 102 | ||
101 | void | 103 | void |
102 | Shape::getRegion(GraphicDevice *gd, Matrix *matrix, void *id, ScanLineFunc scan_line_func) | 104 | Shape::getRegion(GraphicDevice *gd, Matrix *matrix, void *id, ScanLineFunc scan_line_func) |
103 | { | 105 | { |
104 | gd->setClipping(0); | 106 | gd->setClipping(0); |
105 | drawShape(gd,matrix,0,this,ShapeGetRegion,id,scan_line_func); | 107 | drawShape(gd,matrix,0,this,ShapeGetRegion,id,scan_line_func); |
106 | gd->setClipping(1); | 108 | gd->setClipping(1); |
107 | } | 109 | } |
108 | 110 | ||
109 | /************************************************************************/ | 111 | /************************************************************************/ |
110 | 112 | ||
111 | /* create a new path */ | 113 | /* create a new path */ |
112 | 114 | ||
113 | static void newPath(ShapeParser *shape, | 115 | static void newPath(ShapeParser *shape, |
114 | long x, long y) | 116 | long x, long y) |
115 | { | 117 | { |
116 | Path *p; | 118 | Path *p; |
117 | long x1,y1; | 119 | long x1,y1; |
118 | 120 | ||
119 | p=&shape->curPath; | 121 | p=&shape->curPath; |
120 | 122 | ||
121 | x1 = shape->matrix->getX(x, y); | 123 | x1 = shape->matrix->getX(x, y); |
122 | y1 = shape->matrix->getY(x, y); | 124 | y1 = shape->matrix->getY(x, y); |
123 | 125 | ||
124 | p->lastX = x1; | 126 | p->lastX = x1; |
125 | p->lastY = y1; | 127 | p->lastY = y1; |
126 | 128 | ||
127 | p->nb_edges = 0; | 129 | p->nb_edges = 0; |
128 | p->nb_segments = 0; | 130 | p->nb_segments = 0; |
129 | } | 131 | } |
130 | 132 | ||
131 | 133 | ||
132 | static void addSegment1(ShapeParser *shape, | 134 | static void addSegment1(ShapeParser *shape, |
133 | long x, long y, | 135 | long x, long y, |
134 | FillStyleDef *f0, | 136 | FillStyleDef *f0, |
135 | FillStyleDef *f1, | 137 | FillStyleDef *f1, |
136 | LineStyleDef *l) | 138 | LineStyleDef *l) |
137 | { | 139 | { |
138 | Path *p; | 140 | Path *p; |
139 | p=&shape->curPath; | 141 | p=&shape->curPath; |
140 | 142 | ||
141 | if (l) { | 143 | if (l) { |
142 | /* a line is defined ... it will be drawn later */ | 144 | /* a line is defined ... it will be drawn later */ |
143 | LineSegment *ls; | 145 | LineSegment *ls; |
144 | 146 | ||
145 | ls = new LineSegment; | 147 | ls = new LineSegment; |
146 | if (ls != NULL) { | 148 | if (ls != NULL) { |
147 | ls->l = l; | 149 | ls->l = l; |
148 | ls->x1 = p->lastX; | 150 | ls->x1 = p->lastX; |
149 | ls->y1 = p->lastY; | 151 | ls->y1 = p->lastY; |
150 | ls->x2 = x; | 152 | ls->x2 = x; |
151 | ls->y2 = y; | 153 | ls->y2 = y; |
152 | ls->first = (p->nb_segments == 0); | 154 | ls->first = (p->nb_segments == 0); |
153 | ls->next = NULL; | 155 | ls->next = NULL; |
154 | if (shape->last_line == NULL) { | 156 | if (shape->last_line == NULL) { |
155 | shape->first_line = ls; | 157 | shape->first_line = ls; |
156 | } else { | 158 | } else { |
157 | shape->last_line->next = ls; | 159 | shape->last_line->next = ls; |
158 | } | 160 | } |
159 | shape->last_line = ls; | 161 | shape->last_line = ls; |
160 | } | 162 | } |
161 | } | 163 | } |
162 | 164 | ||
163 | /* anti antialiasing not needed if line */ | 165 | /* anti antialiasing not needed if line */ |
164 | if (!shape->reverse) { | 166 | if (!shape->reverse) { |
165 | shape->gd->addSegment(p->lastX,p->lastY,x,y,f0,f1,l ? 0 : 1); | 167 | shape->gd->addSegment(p->lastX,p->lastY,x,y,f0,f1,l ? 0 : 1); |
166 | } else { | 168 | } else { |
167 | shape->gd->addSegment(p->lastX,p->lastY,x,y,f1,f0,l ? 0 : 1); | 169 | shape->gd->addSegment(p->lastX,p->lastY,x,y,f1,f0,l ? 0 : 1); |
168 | } | 170 | } |
169 | 171 | ||
170 | p->lastX = x; | 172 | p->lastX = x; |
171 | p->lastY = y; | 173 | p->lastY = y; |
172 | 174 | ||
173 | p->nb_segments++; | 175 | p->nb_segments++; |
174 | } | 176 | } |
175 | 177 | ||
176 | 178 | ||
177 | static void addLine(ShapeParser *shape, long x, long y, | 179 | static void addLine(ShapeParser *shape, long x, long y, |
178 | FillStyleDef *f0, | 180 | FillStyleDef *f0, |
179 | FillStyleDef *f1, | 181 | FillStyleDef *f1, |
180 | LineStyleDef *l) | 182 | LineStyleDef *l) |
181 | { | 183 | { |
182 | long x1,y1; | 184 | long x1,y1; |
183 | Path *p; | 185 | Path *p; |
184 | 186 | ||
185 | p=&shape->curPath; | 187 | p=&shape->curPath; |
186 | 188 | ||
187 | x1 = shape->matrix->getX(x, y); | 189 | x1 = shape->matrix->getX(x, y); |
188 | y1 = shape->matrix->getY(x, y); | 190 | y1 = shape->matrix->getY(x, y); |
189 | 191 | ||
190 | addSegment1(shape,x1,y1,f0,f1,l); | 192 | addSegment1(shape,x1,y1,f0,f1,l); |
191 | 193 | ||
192 | p->nb_edges++; | 194 | p->nb_edges++; |
193 | } | 195 | } |
194 | 196 | ||
195 | 197 | ||
196 | // This is based on Divide and Conquer algorithm. | 198 | // This is based on Divide and Conquer algorithm. |
197 | 199 | ||
198 | #define BFRAC_BITS 0 | 200 | #define BFRAC_BITS 0 |
199 | #define BFRAC (1 << BFRAC_BITS) | 201 | #define BFRAC (1 << BFRAC_BITS) |
200 | 202 | ||
201 | static void | 203 | static void |
202 | bezierBuildPoints (ShapeParser *s, | 204 | bezierBuildPoints (ShapeParser *s, |
203 | int subdivisions, | 205 | int subdivisions, |
204 | long a1X, long a1Y, | 206 | long a1X, long a1Y, |
205 | long cX, long cY, | 207 | long cX, long cY, |
206 | long a2X, long a2Y) | 208 | long a2X, long a2Y) |
207 | { | 209 | { |
208 | long c1X,c1Y; | 210 | long c1X,c1Y; |
209 | long c2X,c2Y; | 211 | long c2X,c2Y; |
210 | long X,Y; | 212 | long X,Y; |
211 | long xmin,ymin,xmax,ymax; | 213 | long xmin,ymin,xmax,ymax; |
212 | 214 | ||
213 | if (subdivisions != 0) { | 215 | if (subdivisions != 0) { |
214 | 216 | ||
215 | /* find the bounding box */ | 217 | /* find the bounding box */ |
216 | 218 | ||
217 | if (a1X < cX) { | 219 | if (a1X < cX) { |
218 | xmin = a1X; | 220 | xmin = a1X; |
219 | xmax = cX; | 221 | xmax = cX; |
220 | } else { | 222 | } else { |
221 | xmin = cX; | 223 | xmin = cX; |
222 | xmax = a1X; | 224 | xmax = a1X; |
223 | } | 225 | } |
224 | if (a2X < xmin) xmin = a2X; | 226 | if (a2X < xmin) xmin = a2X; |
225 | if (a2X > xmax) xmax = a2X; | 227 | if (a2X > xmax) xmax = a2X; |
226 | 228 | ||
227 | if (a1Y < cY) { | 229 | if (a1Y < cY) { |
228 | ymin = a1Y; | 230 | ymin = a1Y; |
229 | ymax = cY; | 231 | ymax = cY; |
230 | } else { | 232 | } else { |
231 | ymin = cY; | 233 | ymin = cY; |
232 | ymax = a1Y; | 234 | ymax = a1Y; |
233 | } | 235 | } |
234 | if (a2Y < ymin) ymin = a2Y; | 236 | if (a2Y < ymin) ymin = a2Y; |
235 | if (a2Y > ymax) ymax = a2Y; | 237 | if (a2Y > ymax) ymax = a2Y; |
236 | 238 | ||
237 | if (((xmax - xmin) + (ymax - ymin)) >= (BFRAC*FRAC*2)) { | 239 | if (((xmax - xmin) + (ymax - ymin)) >= (BFRAC*FRAC*2)) { |
238 | // Control point 1 | 240 | // Control point 1 |
239 | c1X = (a1X+cX) >> 1; | 241 | c1X = (a1X+cX) >> 1; |
240 | c1Y = (a1Y+cY) >> 1; | 242 | c1Y = (a1Y+cY) >> 1; |
241 | 243 | ||
242 | // Control point 2 | 244 | // Control point 2 |
243 | c2X = (a2X+cX) >> 1; | 245 | c2X = (a2X+cX) >> 1; |
244 | c2Y = (a2Y+cY) >> 1; | 246 | c2Y = (a2Y+cY) >> 1; |
245 | 247 | ||
246 | // New point | 248 | // New point |
247 | X = (c1X+c2X) >> 1; | 249 | X = (c1X+c2X) >> 1; |
248 | Y = (c1Y+c2Y) >> 1; | 250 | Y = (c1Y+c2Y) >> 1; |
249 | 251 | ||
250 | subdivisions--; | 252 | subdivisions--; |
251 | 253 | ||
252 | bezierBuildPoints(s, subdivisions, | 254 | bezierBuildPoints(s, subdivisions, |
253 | a1X, a1Y, c1X, c1Y, X, Y); | 255 | a1X, a1Y, c1X, c1Y, X, Y); |
254 | bezierBuildPoints(s, subdivisions, | 256 | bezierBuildPoints(s, subdivisions, |
255 | X, Y, c2X, c2Y, a2X, a2Y); | 257 | X, Y, c2X, c2Y, a2X, a2Y); |
256 | 258 | ||
257 | return; | 259 | return; |
258 | } | 260 | } |
259 | } | 261 | } |
260 | 262 | ||
261 | addSegment1(s, (a2X+(BFRAC/2)) >> BFRAC_BITS, | 263 | addSegment1(s, (a2X+(BFRAC/2)) >> BFRAC_BITS, |
262 | (a2Y+(BFRAC/2)) >> BFRAC_BITS, s->f0, s->f1, s->l); | 264 | (a2Y+(BFRAC/2)) >> BFRAC_BITS, s->f0, s->f1, s->l); |
263 | } | 265 | } |
264 | 266 | ||
265 | /* this code is broken, but useful to get something */ | 267 | /* this code is broken, but useful to get something */ |
266 | static void flushPaths(ShapeParser *s) | 268 | static void flushPaths(ShapeParser *s) |
267 | { | 269 | { |
268 | LineSegment *ls; | 270 | LineSegment *ls; |
269 | LineStyleDef *l; | 271 | LineStyleDef *l; |
270 | long nx,ny,nn,w; | 272 | long nx,ny,nn,w; |
271 | GraphicDevice *gd = s->gd; | 273 | GraphicDevice *gd = s->gd; |
272 | 274 | ||
273 | /* draw the filled polygon */ | 275 | /* draw the filled polygon */ |
274 | gd->drawPolygon(); | 276 | gd->drawPolygon(); |
275 | 277 | ||
276 | /* draw the lines */ | 278 | /* draw the lines */ |
277 | ls = s->first_line; | 279 | ls = s->first_line; |
278 | if (ls != NULL) { | 280 | if (ls != NULL) { |
279 | do { | 281 | do { |
280 | l = ls->l; | 282 | l = ls->l; |
diff --git a/core/multimedia/opieplayer/libmad/config.in b/core/multimedia/opieplayer/libmad/config.in index 72249dc..f38e52d 100644 --- a/core/multimedia/opieplayer/libmad/config.in +++ b/core/multimedia/opieplayer/libmad/config.in | |||
@@ -1,4 +1,4 @@ | |||
1 | config LIBMAD | 1 | config LIBMAD |
2 | boolean "opieplayer1-libmadplugin (plugin with shoutcast/icecast support to play MP3 files)" | 2 | boolean "opieplayer1-libmadplugin (plugin with shoutcast/icecast support to play MP3 files)" |
3 | default "y" | 3 | default "y" |
4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE && OPIEPLAYER | 4 | depends ( LIBQPE || LIBQPE-X11 ) && OPIEPLAYER |
diff --git a/core/multimedia/opieplayer/libmpeg3/config.in b/core/multimedia/opieplayer/libmpeg3/config.in index b965a40..d964fb9 100644 --- a/core/multimedia/opieplayer/libmpeg3/config.in +++ b/core/multimedia/opieplayer/libmpeg3/config.in | |||
@@ -1,4 +1,4 @@ | |||
1 | config LIBMPEG3 | 1 | config LIBMPEG3 |
2 | boolean "opieplayer1-libmpeg3plugin (play MPEG3 video files)" | 2 | boolean "opieplayer1-libmpeg3plugin (play MPEG3 video files)" |
3 | default "y" | 3 | default "y" |
4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE && OPIEPLAYER | 4 | depends ( LIBQPE || LIBQPE-X11 ) && OPIEPLAYER |
diff --git a/core/multimedia/opieplayer/modplug/config.in b/core/multimedia/opieplayer/modplug/config.in index 86e4725..d7496b0 100644 --- a/core/multimedia/opieplayer/modplug/config.in +++ b/core/multimedia/opieplayer/modplug/config.in | |||
@@ -1,4 +1,4 @@ | |||
1 | config MODPLUG | 1 | config MODPLUG |
2 | boolean "opieplayer1-modplugin (play MOD/XM/S3M/IT amiga tracker modules)" | 2 | boolean "opieplayer1-modplugin (play MOD/XM/S3M/IT amiga tracker modules)" |
3 | default "y" | 3 | default "y" |
4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE && OPIEPLAYER | 4 | depends ( LIBQPE || LIBQPE-X11 ) && OPIEPLAYER |
diff --git a/core/multimedia/opieplayer/wavplugin/config.in b/core/multimedia/opieplayer/wavplugin/config.in index 56bdfab..b7dddc5 100644 --- a/core/multimedia/opieplayer/wavplugin/config.in +++ b/core/multimedia/opieplayer/wavplugin/config.in | |||
@@ -1,4 +1,4 @@ | |||
1 | config WAVPLUGIN | 1 | config WAVPLUGIN |
2 | boolean "opieplayer1-wavplugin (play WAV files)" | 2 | boolean "opieplayer1-wavplugin (play WAV files)" |
3 | default "y" | 3 | default "y" |
4 | depends ( LIBQPE || LIBQPE-X11 ) && LIBOPIE && OPIEPLAYER | 4 | depends ( LIBQPE || LIBQPE-X11 ) && OPIEPLAYER |