blob: 3840b3fd52edc810101bced50f5a652fb0292b7f [file] [log] [blame]
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00001/* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved.
Pierre Ossman316a3242014-01-15 12:40:20 +01002 * Copyright 2014 Pierre Ossman for Cendio AB
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00003 *
4 * This is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
8 *
9 * This software is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this software; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
17 * USA.
18 */
19#ifndef __RFB_DECODER_H__
20#define __RFB_DECODER_H__
21
Pierre Ossman80b42092015-11-10 17:17:34 +010022namespace rdr {
23 class InStream;
24 class OutStream;
25}
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000026
27namespace rfb {
Pierre Ossman86350622015-11-10 13:02:12 +010028 class ConnParams;
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020029 class ModifiablePixelBuffer;
Pierre Ossman86350622015-11-10 13:02:12 +010030 class Rect;
Pierre Ossman570cd5c2015-11-12 13:07:42 +010031 class Region;
32
33 enum DecoderFlags {
34 // A constant for decoders that don't need anything special
35 DecoderPlain = 0,
Pierre Ossmana862add2015-11-12 13:18:22 +010036 // All rects for this decoder must be handled in order
37 DecoderOrdered = 1 << 0,
Pierre Ossmane6ad4452015-11-13 10:47:28 +010038 // Only some of the rects must be handled in order,
39 // see doesRectsConflict()
40 DecoderPartiallyOrdered = 1 << 1,
Pierre Ossman570cd5c2015-11-12 13:07:42 +010041 };
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000042
43 class Decoder {
44 public:
Pierre Ossman570cd5c2015-11-12 13:07:42 +010045 Decoder(enum DecoderFlags flags);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000046 virtual ~Decoder();
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020047
Pierre Ossman80b42092015-11-10 17:17:34 +010048 // These functions are the main interface to an individual decoder
49
50 // readRect() transfers data for the given rectangle from the
51 // InStream to the OutStream, possibly changing it along the way to
Pierre Ossman504afa22015-11-12 12:21:58 +010052 // make it easier to decode. This function will always be called in
53 // a serial manner on the main thread.
Pierre Ossman86350622015-11-10 13:02:12 +010054 virtual void readRect(const Rect& r, rdr::InStream* is,
Pierre Ossman80b42092015-11-10 17:17:34 +010055 const ConnParams& cp, rdr::OutStream* os)=0;
Pierre Ossman504afa22015-11-12 12:21:58 +010056
57 // These functions will be called from any of the worker threads.
58 // A lock will be held whilst these are called so it is safe to
59 // read and update internal state as necessary.
60
Pierre Ossman14127892015-11-12 13:17:42 +010061 // getAffectedRegion() returns the parts of the frame buffer will
62 // be either read from or written do when decoding this rect. The
63 // default implementation simply returns the given rectangle.
64 virtual void getAffectedRegion(const Rect& rect, const void* buffer,
65 size_t buflen, const ConnParams& cp,
66 Region* region);
67
Pierre Ossmane6ad4452015-11-13 10:47:28 +010068 // doesRectsConflict() determines if two rectangles must be decoded
69 // in the order they were received. This will only be called if the
70 // DecoderPartiallyOrdered flag has been set.
71 virtual bool doRectsConflict(const Rect& rectA,
72 const void* bufferA,
73 size_t buflenA,
74 const Rect& rectB,
75 const void* bufferB,
76 size_t buflenB,
77 const ConnParams& cp);
78
Pierre Ossman80b42092015-11-10 17:17:34 +010079 // decodeRect() decodes the given rectangle with data from the
80 // given buffer, onto the ModifiablePixelBuffer. The PixelFormat of
81 // the PixelBuffer might not match the ConnParams and it is up to
82 // the decoder to do any necessary conversion.
83 virtual void decodeRect(const Rect& r, const void* buffer,
84 size_t buflen, const ConnParams& cp,
85 ModifiablePixelBuffer* pb)=0;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000086
Pierre Ossman504afa22015-11-12 12:21:58 +010087 public:
Peter Åstrand98fe98c2010-02-10 07:43:02 +000088 static bool supported(int encoding);
Pierre Ossman86350622015-11-10 13:02:12 +010089 static Decoder* createDecoder(int encoding);
Pierre Ossman570cd5c2015-11-12 13:07:42 +010090
91 public:
92 const enum DecoderFlags flags;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000093 };
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000094}
95
96#endif