blob: 86ee4ef84df809c6f95531481ef00aecad61930d [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 Ossman570cd5c2015-11-12 13:07:42 +010030 class Region;
31
Steve Kondik1f5d4b12017-07-08 02:00:49 -070032 struct Rect;
33
Pierre Ossman570cd5c2015-11-12 13:07:42 +010034 enum DecoderFlags {
35 // A constant for decoders that don't need anything special
36 DecoderPlain = 0,
Pierre Ossmana862add2015-11-12 13:18:22 +010037 // All rects for this decoder must be handled in order
38 DecoderOrdered = 1 << 0,
Pierre Ossmane6ad4452015-11-13 10:47:28 +010039 // Only some of the rects must be handled in order,
40 // see doesRectsConflict()
41 DecoderPartiallyOrdered = 1 << 1,
Pierre Ossman570cd5c2015-11-12 13:07:42 +010042 };
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000043
44 class Decoder {
45 public:
Pierre Ossman570cd5c2015-11-12 13:07:42 +010046 Decoder(enum DecoderFlags flags);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000047 virtual ~Decoder();
Pierre Ossman0c9bd4b2014-07-09 16:44:11 +020048
Pierre Ossman80b42092015-11-10 17:17:34 +010049 // These functions are the main interface to an individual decoder
50
51 // readRect() transfers data for the given rectangle from the
52 // InStream to the OutStream, possibly changing it along the way to
Pierre Ossman504afa22015-11-12 12:21:58 +010053 // make it easier to decode. This function will always be called in
54 // a serial manner on the main thread.
Pierre Ossman86350622015-11-10 13:02:12 +010055 virtual void readRect(const Rect& r, rdr::InStream* is,
Pierre Ossman80b42092015-11-10 17:17:34 +010056 const ConnParams& cp, rdr::OutStream* os)=0;
Pierre Ossman504afa22015-11-12 12:21:58 +010057
58 // These functions will be called from any of the worker threads.
59 // A lock will be held whilst these are called so it is safe to
60 // read and update internal state as necessary.
61
Pierre Ossman14127892015-11-12 13:17:42 +010062 // getAffectedRegion() returns the parts of the frame buffer will
63 // be either read from or written do when decoding this rect. The
64 // default implementation simply returns the given rectangle.
65 virtual void getAffectedRegion(const Rect& rect, const void* buffer,
66 size_t buflen, const ConnParams& cp,
67 Region* region);
68
Pierre Ossmane6ad4452015-11-13 10:47:28 +010069 // doesRectsConflict() determines if two rectangles must be decoded
70 // in the order they were received. This will only be called if the
71 // DecoderPartiallyOrdered flag has been set.
72 virtual bool doRectsConflict(const Rect& rectA,
73 const void* bufferA,
74 size_t buflenA,
75 const Rect& rectB,
76 const void* bufferB,
77 size_t buflenB,
78 const ConnParams& cp);
79
Pierre Ossman80b42092015-11-10 17:17:34 +010080 // decodeRect() decodes the given rectangle with data from the
81 // given buffer, onto the ModifiablePixelBuffer. The PixelFormat of
82 // the PixelBuffer might not match the ConnParams and it is up to
83 // the decoder to do any necessary conversion.
84 virtual void decodeRect(const Rect& r, const void* buffer,
85 size_t buflen, const ConnParams& cp,
86 ModifiablePixelBuffer* pb)=0;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000087
Pierre Ossman504afa22015-11-12 12:21:58 +010088 public:
Peter Åstrand98fe98c2010-02-10 07:43:02 +000089 static bool supported(int encoding);
Pierre Ossman86350622015-11-10 13:02:12 +010090 static Decoder* createDecoder(int encoding);
Pierre Ossman570cd5c2015-11-12 13:07:42 +010091
92 public:
93 const enum DecoderFlags flags;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000094 };
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000095}
96
97#endif