blob: 405a99ccfa1c5da902a623d3c92a8132db258ba1 [file] [log] [blame]
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00001/* Copyright (C) 2002-2005 RealVNC Ltd. All Rights Reserved.
DRCb4a83232011-08-19 04:57:18 +00002 * Copyright (C) 2011 D. R. Commander. All Rights Reserved.
Pierre Ossmanb948a912014-01-15 13:23:43 +01003 * Copyright 2014 Pierre Ossman for Cendio AB
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +00004 *
5 * This is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This software is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this software; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
18 * USA.
19 */
Adam Tkac20e0d712008-11-14 14:48:21 +000020#include <stdio.h>
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000021#include <rfb/Exception.h>
22#include <rfb/encodings.h>
Pierre Ossman2fa63f82016-12-05 15:26:21 +010023#include <rfb/ledStates.h>
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000024#include <rfb/ConnParams.h>
25#include <rfb/util.h>
26
27using namespace rfb;
28
29ConnParams::ConnParams()
Adam Tkac3d0af202010-11-18 15:19:47 +000030 : majorVersion(0), minorVersion(0),
Constantin Kaplinskyce0907d2006-09-08 12:55:37 +000031 width(0), height(0), useCopyRect(false),
Pierre Ossmanc5e25602009-03-20 12:59:05 +000032 supportsLocalCursor(false), supportsLocalXCursor(false),
Pierre Ossman8053c8e2017-02-21 12:59:04 +010033 supportsLocalCursorWithAlpha(false),
Pierre Ossmanc5e25602009-03-20 12:59:05 +000034 supportsDesktopResize(false), supportsExtendedDesktopSize(false),
35 supportsDesktopRename(false), supportsLastRect(false),
Pierre Ossman5ae28212017-05-16 14:30:38 +020036 supportsLEDState(false), supportsQEMUKeyEvent(false),
37 supportsSetDesktopSize(false), supportsFence(false),
38 supportsContinuousUpdates(false),
Pierre Ossmana22459d2014-03-17 14:42:10 +010039 compressLevel(2), qualityLevel(-1), fineQualityLevel(-1),
Pierre Ossmanea7ede92018-06-18 16:51:53 +020040 subsampling(subsampleUndefined), name_(0),
Pierre Ossman2fa63f82016-12-05 15:26:21 +010041 ledState_(ledUnknown)
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000042{
43 setName("");
Pierre Ossman6a1a0d02017-02-19 15:48:17 +010044 cursor_ = new Cursor(0, 0, Point(), NULL);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000045}
46
47ConnParams::~ConnParams()
48{
49 delete [] name_;
Pierre Ossman6a1a0d02017-02-19 15:48:17 +010050 delete cursor_;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000051}
52
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000053void ConnParams::setPF(const PixelFormat& pf)
54{
55 pf_ = pf;
56
57 if (pf.bpp != 8 && pf.bpp != 16 && pf.bpp != 32)
58 throw Exception("setPF: not 8, 16 or 32 bpp?");
59}
60
61void ConnParams::setName(const char* name)
62{
63 delete [] name_;
Adam Tkacd36b6262009-09-04 10:57:20 +000064 name_ = strDup(name);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000065}
66
Pierre Ossman126e5642014-02-13 14:40:25 +010067void ConnParams::setCursor(const Cursor& other)
68{
Pierre Ossman6a1a0d02017-02-19 15:48:17 +010069 delete cursor_;
70 cursor_ = new Cursor(other);
Pierre Ossman126e5642014-02-13 14:40:25 +010071}
72
Pierre Ossmanf22d3502015-11-10 12:58:49 +010073bool ConnParams::supportsEncoding(rdr::S32 encoding) const
Pierre Ossmanc0397262014-03-14 15:59:46 +010074{
75 return encodings_.count(encoding) != 0;
76}
77
Peter Åstrand98fe98c2010-02-10 07:43:02 +000078void ConnParams::setEncodings(int nEncodings, const rdr::S32* encodings)
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000079{
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000080 useCopyRect = false;
81 supportsLocalCursor = false;
Pierre Ossman8053c8e2017-02-21 12:59:04 +010082 supportsLocalCursorWithAlpha = false;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000083 supportsDesktopResize = false;
Pierre Ossmanc5e25602009-03-20 12:59:05 +000084 supportsExtendedDesktopSize = false;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000085 supportsLocalXCursor = false;
86 supportsLastRect = false;
Pierre Ossman5ae28212017-05-16 14:30:38 +020087 supportsQEMUKeyEvent = false;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000088 compressLevel = -1;
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000089 qualityLevel = -1;
DRCb4a83232011-08-19 04:57:18 +000090 fineQualityLevel = -1;
Pierre Ossmanb948a912014-01-15 13:23:43 +010091 subsampling = subsampleUndefined;
Pierre Ossmanc0397262014-03-14 15:59:46 +010092
93 encodings_.clear();
94 encodings_.insert(encodingRaw);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000095
96 for (int i = nEncodings-1; i >= 0; i--) {
Pierre Ossman6bcf1372014-01-15 13:44:04 +010097 switch (encodings[i]) {
98 case encodingCopyRect:
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +000099 useCopyRect = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100100 break;
101 case pseudoEncodingCursor:
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000102 supportsLocalCursor = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100103 break;
104 case pseudoEncodingXCursor:
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000105 supportsLocalXCursor = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100106 break;
Pierre Ossman8053c8e2017-02-21 12:59:04 +0100107 case pseudoEncodingCursorWithAlpha:
108 supportsLocalCursorWithAlpha = true;
109 break;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100110 case pseudoEncodingDesktopSize:
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000111 supportsDesktopResize = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100112 break;
113 case pseudoEncodingExtendedDesktopSize:
Pierre Ossmanc5e25602009-03-20 12:59:05 +0000114 supportsExtendedDesktopSize = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100115 break;
116 case pseudoEncodingDesktopName:
Peter Åstrandc39e0782009-01-15 12:21:42 +0000117 supportsDesktopRename = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100118 break;
119 case pseudoEncodingLastRect:
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000120 supportsLastRect = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100121 break;
Pierre Ossman2fa63f82016-12-05 15:26:21 +0100122 case pseudoEncodingLEDState:
123 supportsLEDState = true;
Pierre Ossman58a4c132018-03-28 12:33:22 +0200124 break;
Pierre Ossman5ae28212017-05-16 14:30:38 +0200125 case pseudoEncodingQEMUKeyEvent:
126 supportsQEMUKeyEvent = true;
Pierre Ossman2fa63f82016-12-05 15:26:21 +0100127 break;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100128 case pseudoEncodingFence:
Pierre Ossmanc754cce2011-11-14 15:44:11 +0000129 supportsFence = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100130 break;
131 case pseudoEncodingContinuousUpdates:
Pierre Ossmanc898d9a2011-11-14 16:22:23 +0000132 supportsContinuousUpdates = true;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100133 break;
134 case pseudoEncodingSubsamp1X:
135 subsampling = subsampleNone;
136 break;
137 case pseudoEncodingSubsampGray:
138 subsampling = subsampleGray;
139 break;
140 case pseudoEncodingSubsamp2X:
141 subsampling = subsample2X;
142 break;
143 case pseudoEncodingSubsamp4X:
144 subsampling = subsample4X;
145 break;
146 case pseudoEncodingSubsamp8X:
147 subsampling = subsample8X;
148 break;
149 case pseudoEncodingSubsamp16X:
150 subsampling = subsample16X;
151 break;
152 }
153
154 if (encodings[i] >= pseudoEncodingCompressLevel0 &&
155 encodings[i] <= pseudoEncodingCompressLevel9)
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000156 compressLevel = encodings[i] - pseudoEncodingCompressLevel0;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100157
158 if (encodings[i] >= pseudoEncodingQualityLevel0 &&
159 encodings[i] <= pseudoEncodingQualityLevel9)
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000160 qualityLevel = encodings[i] - pseudoEncodingQualityLevel0;
Pierre Ossman6bcf1372014-01-15 13:44:04 +0100161
162 if (encodings[i] >= pseudoEncodingFineQualityLevel0 &&
163 encodings[i] <= pseudoEncodingFineQualityLevel100)
164 fineQualityLevel = encodings[i] - pseudoEncodingFineQualityLevel0;
165
Pierre Ossmanc0397262014-03-14 15:59:46 +0100166 if (encodings[i] > 0)
167 encodings_.insert(encodings[i]);
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000168 }
Constantin Kaplinskya2adc8d2006-05-25 05:01:55 +0000169}
Pierre Ossman2fa63f82016-12-05 15:26:21 +0100170
171void ConnParams::setLEDState(unsigned int state)
172{
173 ledState_ = state;
174}