Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
L
libvncserver
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
rasky
libvncserver
Commits
833f0602
Commit
833f0602
authored
Dec 29, 2006
by
runge
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
x11vnc -ncache on by default for beta test. fix -nofb & -rawfb modes.
parent
e4a397ed
Changes
16
Hide whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
193 additions
and
83 deletions
+193
-83
8to24.c
x11vnc/8to24.c
+7
-1
README
x11vnc/README
+3
-3
cursor.c
x11vnc/cursor.c
+1
-1
options.c
x11vnc/options.c
+5
-1
options.h
x11vnc/options.h
+1
-0
pointer.c
x11vnc/pointer.c
+2
-1
screen.c
x11vnc/screen.c
+28
-8
selection.c
x11vnc/selection.c
+5
-4
userinput.c
x11vnc/userinput.c
+68
-51
util.c
x11vnc/util.c
+1
-3
win_utils.c
x11vnc/win_utils.c
+5
-2
x11vnc.1
x11vnc/x11vnc.1
+1
-1
x11vnc.c
x11vnc/x11vnc.c
+54
-0
x11vnc_defs.c
x11vnc/x11vnc_defs.c
+1
-1
xevents.c
x11vnc/xevents.c
+2
-0
xwrappers.c
x11vnc/xwrappers.c
+9
-6
No files found.
x11vnc/8to24.c
View file @
833f0602
...
@@ -66,6 +66,7 @@ static unsigned int root_rgb[NCOLOR];
...
@@ -66,6 +66,7 @@ static unsigned int root_rgb[NCOLOR];
static
void
set_root_cmap
(
void
)
{
static
void
set_root_cmap
(
void
)
{
#if NO_X11
#if NO_X11
RAWFB_RET_VOID
return
;
return
;
#else
#else
static
time_t
last_set
=
0
;
static
time_t
last_set
=
0
;
...
@@ -245,6 +246,7 @@ double MV_start;
...
@@ -245,6 +246,7 @@ double MV_start;
void
check_for_multivis
(
void
)
{
void
check_for_multivis
(
void
)
{
#if NO_X11
#if NO_X11
RAWFB_RET_VOID
return
;
return
;
#else
#else
XWindowAttributes
attr
;
XWindowAttributes
attr
;
...
@@ -758,11 +760,12 @@ if (db24 > 1) fprintf(stderr, " ------------ 0x%lx i=%d\n", windows_8bp
...
@@ -758,11 +760,12 @@ if (db24 > 1) fprintf(stderr, " ------------ 0x%lx i=%d\n", windows_8bp
}
}
static
XImage
*
p_xi
(
XImage
*
xi
,
Visual
*
visual
,
int
win_depth
,
int
*
w
)
{
static
XImage
*
p_xi
(
XImage
*
xi
,
Visual
*
visual
,
int
win_depth
,
int
*
w
)
{
RAWFB_RET
(
NULL
)
#if NO_X11
#if NO_X11
if
(
!
xi
||
!
visual
||
!
win_depth
||
!
w
)
{}
if
(
!
xi
||
!
visual
||
!
win_depth
||
!
w
)
{}
return
NULL
;
return
NULL
;
#else
#else
RAWFB_RET
(
NULL
)
if
(
xi
==
NULL
||
*
w
<
dpy_x
)
{
if
(
xi
==
NULL
||
*
w
<
dpy_x
)
{
char
*
d
;
char
*
d
;
if
(
xi
)
{
if
(
xi
)
{
...
@@ -783,6 +786,7 @@ static XImage *p_xi(XImage *xi, Visual *visual, int win_depth, int *w) {
...
@@ -783,6 +786,7 @@ static XImage *p_xi(XImage *xi, Visual *visual, int win_depth, int *w) {
static
int
poll_line
(
int
x1
,
int
x2
,
int
y1
,
int
n
,
sraRegionPtr
mod
)
{
static
int
poll_line
(
int
x1
,
int
x2
,
int
y1
,
int
n
,
sraRegionPtr
mod
)
{
#if NO_X11
#if NO_X11
RAWFB_RET
(
1
)
if
(
!
x1
||
!
x2
||
!
y1
||
!
n
||
!
mod
)
{}
if
(
!
x1
||
!
x2
||
!
y1
||
!
n
||
!
mod
)
{}
return
1
;
return
1
;
#else
#else
...
@@ -1295,6 +1299,7 @@ int histo[256];
...
@@ -1295,6 +1299,7 @@ int histo[256];
static
int
get_cmap
(
int
j
,
Colormap
cmap
)
{
static
int
get_cmap
(
int
j
,
Colormap
cmap
)
{
#if NO_X11
#if NO_X11
RAWFB_RET
(
0
)
if
(
!
j
||
!
cmap
)
{}
if
(
!
j
||
!
cmap
)
{}
return
0
;
return
0
;
#else
#else
...
@@ -1460,6 +1465,7 @@ static XImage *cmap_xi(XImage *xi, Window win, int win_depth) {
...
@@ -1460,6 +1465,7 @@ static XImage *cmap_xi(XImage *xi, Window win, int win_depth) {
static
void
transform_rect
(
sraRect
rect
,
Window
win
,
int
win_depth
,
int
cm
)
{
static
void
transform_rect
(
sraRect
rect
,
Window
win
,
int
win_depth
,
int
cm
)
{
#if NO_X11
#if NO_X11
RAWFB_RET_VOID
if
(
!
rect
.
x1
||
!
win
||
!
win_depth
||
!
cm
)
{}
if
(
!
rect
.
x1
||
!
win
||
!
win_depth
||
!
cm
)
{}
return
;
return
;
#else
#else
...
...
x11vnc/README
View file @
833f0602
x11vnc
README
file
Date
:
Thu
Dec
28
15
:
22
:
02
EST
2006
x11vnc
README
file
Date
:
Fri
Dec
29
01
:
37
:
39
EST
2006
The
following
information
is
taken
from
these
URLs
:
The
following
information
is
taken
from
these
URLs
:
...
@@ -9262,7 +9262,7 @@ x11vnc: a VNC server for real X displays
...
@@ -9262,7 +9262,7 @@ x11vnc: a VNC server for real X displays
Here
are
all
of
x11vnc
command
line
options
:
Here
are
all
of
x11vnc
command
line
options
:
%
x11vnc
-
opts
(
see
below
for
-
help
long
descriptions
)
%
x11vnc
-
opts
(
see
below
for
-
help
long
descriptions
)
x11vnc
:
allow
VNC
connections
to
real
X11
displays
.
0.8.4
lastmod
:
2006
-
12
-
2
8
x11vnc
:
allow
VNC
connections
to
real
X11
displays
.
0.8.4
lastmod
:
2006
-
12
-
2
9
x11vnc
options
:
x11vnc
options
:
-
display
disp
-
auth
file
-
id
windowid
-
display
disp
-
auth
file
-
id
windowid
...
@@ -9369,7 +9369,7 @@ libvncserver-tight-extension options:
...
@@ -9369,7 +9369,7 @@ libvncserver-tight-extension options:
% x11vnc -help
% x11vnc -help
x11vnc: allow VNC connections to real X11 displays. 0.8.4 lastmod: 2006-12-2
8
x11vnc: allow VNC connections to real X11 displays. 0.8.4 lastmod: 2006-12-2
9
(type "x11vnc -opts" to just list the options.)
(type "x11vnc -opts" to just list the options.)
...
...
x11vnc/cursor.c
View file @
833f0602
...
@@ -1875,7 +1875,6 @@ int check_x11_pointer(void) {
...
@@ -1875,7 +1875,6 @@ int check_x11_pointer(void) {
if
(
unixpw_in_progress
)
return
0
;
if
(
unixpw_in_progress
)
return
0
;
#ifdef MACOSX
#ifdef MACOSX
if
(
macosx_console
)
{
if
(
macosx_console
)
{
ret
=
macosx_get_cursor_pos
(
&
root_x
,
&
root_y
);
ret
=
macosx_get_cursor_pos
(
&
root_x
,
&
root_y
);
...
@@ -1883,6 +1882,7 @@ int check_x11_pointer(void) {
...
@@ -1883,6 +1882,7 @@ int check_x11_pointer(void) {
RAWFB_RET
(
0
)
RAWFB_RET
(
0
)
}
}
#else
#else
RAWFB_RET
(
0
)
RAWFB_RET
(
0
)
# if NO_X11
# if NO_X11
...
...
x11vnc/options.c
View file @
833f0602
...
@@ -194,10 +194,14 @@ char *wireframe_copyrect_default = "never";
...
@@ -194,10 +194,14 @@ char *wireframe_copyrect_default = "never";
int
wireframe_in_progress
=
0
;
int
wireframe_in_progress
=
0
;
int
wireframe_local
=
1
;
int
wireframe_local
=
1
;
int
ncache
=
0
;
#ifndef NCACHE
#define NCACHE -10
#endif
int
ncache
=
NCACHE
;
int
ncache0
=
0
;
int
ncache0
=
0
;
int
ncache_copyrect
=
0
;
int
ncache_copyrect
=
0
;
int
macosx_ncache_macmenu
=
0
;
int
macosx_ncache_macmenu
=
0
;
int
ncache_beta_tester
=
0
;
#ifdef MACOSX
#ifdef MACOSX
int
ncache_pad
=
24
;
int
ncache_pad
=
24
;
#else
#else
...
...
x11vnc/options.h
View file @
833f0602
...
@@ -161,6 +161,7 @@ extern int ncache0;
...
@@ -161,6 +161,7 @@ extern int ncache0;
extern
int
ncache_copyrect
;
extern
int
ncache_copyrect
;
extern
int
ncache_pad
;
extern
int
ncache_pad
;
extern
int
macosx_ncache_macmenu
;
extern
int
macosx_ncache_macmenu
;
extern
int
ncache_beta_tester
;
extern
char
*
scroll_copyrect_str
;
extern
char
*
scroll_copyrect_str
;
extern
char
*
scroll_copyrect
;
extern
char
*
scroll_copyrect
;
...
...
x11vnc/pointer.c
View file @
833f0602
...
@@ -414,12 +414,13 @@ void do_button_mask_change(int mask, int button) {
...
@@ -414,12 +414,13 @@ void do_button_mask_change(int mask, int button) {
*/
*/
static
void
update_x11_pointer_mask
(
int
mask
)
{
static
void
update_x11_pointer_mask
(
int
mask
)
{
#if NO_X11
#if NO_X11
last_event
=
last_input
=
last_pointer_input
=
time
(
NULL
);
RAWFB_RET_VOID
RAWFB_RET_VOID
if
(
!
mask
)
{}
if
(
!
mask
)
{}
return
;
return
;
#else
#else
int
snapped
=
0
,
xr_mouse
=
1
,
i
;
int
snapped
=
0
,
xr_mouse
=
1
,
i
;
last_event
=
last_input
=
last_pointer_input
=
time
(
NULL
);
last_event
=
last_input
=
last_pointer_input
=
time
(
NULL
);
RAWFB_RET_VOID
RAWFB_RET_VOID
...
...
x11vnc/screen.c
View file @
833f0602
...
@@ -425,6 +425,7 @@ static void set_visual(char *str) {
...
@@ -425,6 +425,7 @@ static void set_visual(char *str) {
void
set_nofb_params
(
int
restore
)
{
void
set_nofb_params
(
int
restore
)
{
static
int
first
=
1
;
static
int
first
=
1
;
static
int
save
[
100
];
static
int
save
[
100
];
static
char
*
scroll
=
NULL
;
int
i
=
0
;
int
i
=
0
;
if
(
first
)
{
if
(
first
)
{
...
@@ -444,6 +445,9 @@ void set_nofb_params(int restore) {
...
@@ -444,6 +445,9 @@ void set_nofb_params(int restore) {
save
[
i
++
]
=
show_cursor
;
save
[
i
++
]
=
show_cursor
;
save
[
i
++
]
=
cursor_shape_updates
;
save
[
i
++
]
=
cursor_shape_updates
;
save
[
i
++
]
=
cursor_pos_updates
;
save
[
i
++
]
=
cursor_pos_updates
;
save
[
i
++
]
=
ncache
;
scroll
=
scroll_copyrect
;
}
}
if
(
restore
)
{
if
(
restore
)
{
i
=
0
;
i
=
0
;
...
@@ -462,6 +466,9 @@ void set_nofb_params(int restore) {
...
@@ -462,6 +466,9 @@ void set_nofb_params(int restore) {
show_cursor
=
save
[
i
++
];
show_cursor
=
save
[
i
++
];
cursor_shape_updates
=
save
[
i
++
];
cursor_shape_updates
=
save
[
i
++
];
cursor_pos_updates
=
save
[
i
++
];
cursor_pos_updates
=
save
[
i
++
];
ncache
=
save
[
i
++
];
scroll_copyrect
=
scroll
;
if
(
cursor_shape_updates
)
{
if
(
cursor_shape_updates
)
{
restore_cursor_shape_updates
(
screen
);
restore_cursor_shape_updates
(
screen
);
...
@@ -496,9 +503,13 @@ void set_nofb_params(int restore) {
...
@@ -496,9 +503,13 @@ void set_nofb_params(int restore) {
cursor_pos_updates
=
0
;
cursor_pos_updates
=
0
;
}
}
ncache
=
0
;
scroll_copyrect
=
"never"
;
if
(
!
quiet
)
{
if
(
!
quiet
)
{
rfbLog
(
"disabling: xfixes, xdamage, solid, overlay, shm,
\n
"
);
rfbLog
(
"disabling: xfixes, xdamage, solid, overlay, shm,
\n
"
);
rfbLog
(
" wireframe, scrollcopyrect,
\n
"
);
rfbLog
(
" wireframe, scrollcopyrect,
ncache,
\n
"
);
rfbLog
(
" noonetile, nap, cursor, %scursorshape
\n
"
,
rfbLog
(
" noonetile, nap, cursor, %scursorshape
\n
"
,
got_cursorpos
?
""
:
"cursorpos, "
);
got_cursorpos
?
""
:
"cursorpos, "
);
rfbLog
(
" in -nofb mode.
\n
"
);
rfbLog
(
" in -nofb mode.
\n
"
);
...
@@ -654,16 +665,22 @@ void set_raw_fb_params(int restore) {
...
@@ -654,16 +665,22 @@ void set_raw_fb_params(int restore) {
*/
*/
static
void
nofb_hook
(
rfbClientPtr
cl
)
{
static
void
nofb_hook
(
rfbClientPtr
cl
)
{
XImage
*
fb
;
XImage
*
fb
;
XImage
raw
;
rfbLog
(
"framebuffer requested in -nofb mode by client %s
\n
"
,
cl
->
host
);
rfbLog
(
"framebuffer requested in -nofb mode by client %s
\n
"
,
cl
->
host
);
/* ignore xrandr */
/* ignore xrandr */
if
(
raw_fb
&&
!
dpy
)
{
if
(
raw_fb
&&
!
dpy
)
{
XImage
raw
;
fb
=
&
raw
;
fb
=
&
raw
;
fb
->
data
=
(
char
*
)
malloc
(
32
);
fb
->
data
=
(
char
*
)
malloc
(
32
);
}
else
{
}
else
{
fb
=
XGetImage_wr
(
dpy
,
window
,
0
,
0
,
dpy_x
,
dpy_y
,
AllPlanes
,
ZPixmap
);
int
use_real_ximage
=
0
;
if
(
use_real_ximage
)
{
fb
=
XGetImage_wr
(
dpy
,
window
,
0
,
0
,
dpy_x
,
dpy_y
,
AllPlanes
,
ZPixmap
);
}
else
{
fb
=
&
raw
;
fb
->
data
=
(
char
*
)
calloc
(
dpy_x
*
dpy_y
*
bpp
/
8
,
1
);
}
}
}
main_fb
=
fb
->
data
;
main_fb
=
fb
->
data
;
rfb_fb
=
main_fb
;
rfb_fb
=
main_fb
;
...
@@ -1468,6 +1485,9 @@ static int wait_until_mapped(Window win) {
...
@@ -1468,6 +1485,9 @@ static int wait_until_mapped(Window win) {
*/
*/
XImage
*
initialize_xdisplay_fb
(
void
)
{
XImage
*
initialize_xdisplay_fb
(
void
)
{
#if NO_X11
#if NO_X11
if
(
raw_fb_str
)
{
return
initialize_raw_fb
(
0
);
}
return
NULL
;
return
NULL
;
#else
#else
XImage
*
fb
;
XImage
*
fb
;
...
@@ -2038,7 +2058,7 @@ void initialize_screen(int *argc, char **argv, XImage *fb) {
...
@@ -2038,7 +2058,7 @@ void initialize_screen(int *argc, char **argv, XImage *fb) {
}
}
#ifndef NO_NCACHE
#ifndef NO_NCACHE
if
(
ncache
>
0
)
{
if
(
ncache
>
0
&&
!
nofb
)
{
#ifdef MACOSX
#ifdef MACOSX
if
(
!
raw_fb_str
||
macosx_console
)
{
if
(
!
raw_fb_str
||
macosx_console
)
{
#else
#else
...
@@ -2552,18 +2572,18 @@ void announce(int lport, int ssl, char *iface) {
...
@@ -2552,18 +2572,18 @@ void announce(int lport, int ssl, char *iface) {
if
(
lport
>=
5900
)
{
if
(
lport
>=
5900
)
{
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
host
,
lport
-
5900
);
host
,
lport
-
5900
);
fprintf
(
stderr
,
"%s %s
\n
"
,
tvdt
,
fprintf
(
stderr
,
"
\n
%s %s
\n
"
,
tvdt
,
vnc_desktop_name
);
vnc_desktop_name
);
}
else
{
}
else
{
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
host
,
lport
);
host
,
lport
);
fprintf
(
stderr
,
"%s %s
\n
"
,
tvdt
,
fprintf
(
stderr
,
"
\n
%s %s
\n
"
,
tvdt
,
vnc_desktop_name
);
vnc_desktop_name
);
}
}
}
else
if
(
lport
>=
5900
)
{
}
else
if
(
lport
>=
5900
)
{
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
host
,
lport
-
5900
);
host
,
lport
-
5900
);
fprintf
(
stderr
,
"%s %s
\n
"
,
tvdt
,
vnc_desktop_name
);
fprintf
(
stderr
,
"
\n
%s %s
\n
"
,
tvdt
,
vnc_desktop_name
);
if
(
lport
>=
6000
)
{
if
(
lport
>=
6000
)
{
rfbLog
(
"possible aliases: %s:%d, "
rfbLog
(
"possible aliases: %s:%d, "
"%s::%d
\n
"
,
host
,
lport
,
"%s::%d
\n
"
,
host
,
lport
,
...
@@ -2572,7 +2592,7 @@ void announce(int lport, int ssl, char *iface) {
...
@@ -2572,7 +2592,7 @@ void announce(int lport, int ssl, char *iface) {
}
else
{
}
else
{
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
snprintf
(
vnc_desktop_name
,
sz
,
"%s:%d"
,
host
,
lport
);
host
,
lport
);
fprintf
(
stderr
,
"%s %s
\n
"
,
tvdt
,
vnc_desktop_name
);
fprintf
(
stderr
,
"
\n
%s %s
\n
"
,
tvdt
,
vnc_desktop_name
);
rfbLog
(
"possible alias: %s::%d
\n
"
,
rfbLog
(
"possible alias: %s::%d
\n
"
,
host
,
lport
);
host
,
lport
);
}
}
...
...
x11vnc/selection.c
View file @
833f0602
...
@@ -62,14 +62,14 @@ void selection_request(XEvent *ev, char *type) {
...
@@ -62,14 +62,14 @@ void selection_request(XEvent *ev, char *type) {
char
*
str
;
char
*
str
;
unsigned
int
length
;
unsigned
int
length
;
unsigned
char
*
data
;
unsigned
char
*
data
;
#ifndef XA_LENGTH
#
ifndef XA_LENGTH
unsigned
long
XA_LENGTH
;
unsigned
long
XA_LENGTH
;
#endif
#
endif
RAWFB_RET_VOID
RAWFB_RET_VOID
#ifndef XA_LENGTH
#
ifndef XA_LENGTH
XA_LENGTH
=
XInternAtom
(
dpy
,
"LENGTH"
,
True
);
XA_LENGTH
=
XInternAtom
(
dpy
,
"LENGTH"
,
True
);
#endif
#
endif
req_event
=
&
(
ev
->
xselectionrequest
);
req_event
=
&
(
ev
->
xselectionrequest
);
notify_event
.
type
=
SelectionNotify
;
notify_event
.
type
=
SelectionNotify
;
...
@@ -257,6 +257,7 @@ void cutbuffer_send(void) {
...
@@ -257,6 +257,7 @@ void cutbuffer_send(void) {
* Also: XFIXES has XFixesSelectSelectionInput().
* Also: XFIXES has XFixesSelectSelectionInput().
*/
*/
#define CHKSZ 32
#define CHKSZ 32
void
selection_send
(
XEvent
*
ev
)
{
void
selection_send
(
XEvent
*
ev
)
{
#if NO_X11
#if NO_X11
RAWFB_RET_VOID
RAWFB_RET_VOID
...
...
x11vnc/userinput.c
View file @
833f0602
...
@@ -3546,28 +3546,28 @@ static Window NPP_nwin = None;
...
@@ -3546,28 +3546,28 @@ static Window NPP_nwin = None;
void
clear_win_events
(
void
)
{
void
clear_win_events
(
void
)
{
#if !NO_X11
#if !NO_X11
if
(
dpy
&&
NPP_nwin
!=
None
)
{
if
(
dpy
&&
NPP_nwin
!=
None
)
{
XEvent
ev
;
XEvent
ev
;
XErrorHandler
old_handler
;
XErrorHandler
old_handler
;
old_handler
=
XSetErrorHandler
(
trap_xerror
);
old_handler
=
XSetErrorHandler
(
trap_xerror
);
trapped_xerror
=
0
;
trapped_xerror
=
0
;
while
(
XCheckTypedWindowEvent
(
dpy
,
NPP_nwin
,
ConfigureNotify
,
&
ev
))
{
while
(
XCheckTypedWindowEvent
(
dpy
,
NPP_nwin
,
ConfigureNotify
,
&
ev
))
{
fprintf
(
stderr
,
"."
);
fprintf
(
stderr
,
"."
);
if
(
trapped_xerror
)
{
if
(
trapped_xerror
)
{
break
;
break
;
}
trapped_xerror
=
0
;
}
}
while
(
XCheckTypedWindowEvent
(
dpy
,
NPP_nwin
,
VisibilityNotify
,
&
ev
))
{
trapped_xerror
=
0
;
fprintf
(
stderr
,
"+"
);
}
if
(
trapped_xerror
)
{
while
(
XCheckTypedWindowEvent
(
dpy
,
NPP_nwin
,
VisibilityNotify
,
&
ev
)
)
{
break
;
fprintf
(
stderr
,
"+"
)
;
}
if
(
trapped_xerror
)
{
trapped_xerror
=
0
;
break
;
}
}
XSetErrorHandler
(
old_handler
);
trapped_xerror
=
0
;
fprintf
(
stderr
,
" 0x%x
\n
"
,
(
unsigned
int
)
NPP_nwin
);
}
}
XSetErrorHandler
(
old_handler
);
fprintf
(
stderr
,
" 0x%x
\n
"
,
(
unsigned
int
)
NPP_nwin
);
}
#endif
#endif
}
}
...
@@ -5515,7 +5515,12 @@ void snapshot_cache_list(int free_only, double allowed_age) {
...
@@ -5515,7 +5515,12 @@ void snapshot_cache_list(int free_only, double allowed_age) {
RAWFB_RET_VOID
RAWFB_RET_VOID
#endif
#endif
#if NO_X11 && !defined(MACOSX)
#if NO_X11 && !defined(MACOSX)
num
=
rc
=
i
=
0
;
/* compiler warnings */
ui
=
0
;
r
=
w
=
None
;
list
=
NULL
;
return
;
return
;
#else
#else
...
@@ -6357,6 +6362,15 @@ fprintf(stderr, "free_rect: bad index: %d\n", idx);
...
@@ -6357,6 +6362,15 @@ fprintf(stderr, "free_rect: bad index: %d\n", idx);
fac1
=
0
.
18
;
fac1
=
0
.
18
;
fac2
=
0
.
35
;
fac2
=
0
.
35
;
}
}
if
(
macosx_console
&&
!
macosx_ncache_macmenu
)
{
if
(
cram
)
{
fac1
*=
1
.
5
;
fac2
*=
1
.
5
;
}
else
{
fac1
*=
2
.
5
;
fac2
*=
2
.
5
;
}
}
if
(
w
*
h
>
fac1
*
(
dpy_x
*
dpy_y
))
{
if
(
w
*
h
>
fac1
*
(
dpy_x
*
dpy_y
))
{
big1
=
1
;
big1
=
1
;
}
}
...
@@ -6559,7 +6573,7 @@ int valid_wr(int idx, Window win, XWindowAttributes *attr) {
...
@@ -6559,7 +6573,7 @@ int valid_wr(int idx, Window win, XWindowAttributes *attr) {
return
valid_window
(
win
,
attr
,
1
);
return
valid_window
(
win
,
attr
,
1
);
}
}
int
bs_save
(
int
idx
,
int
*
nbatch
)
{
int
bs_save
(
int
idx
,
int
*
nbatch
,
int
verb
)
{
Window
win
=
cache_list
[
idx
].
win
;
Window
win
=
cache_list
[
idx
].
win
;
XWindowAttributes
attr
;
XWindowAttributes
attr
;
int
x1
,
y1
,
w1
,
h1
;
int
x1
,
y1
,
w1
,
h1
;
...
@@ -6573,7 +6587,7 @@ int bs_save(int idx, int *nbatch) {
...
@@ -6573,7 +6587,7 @@ int bs_save(int idx, int *nbatch) {
w1
=
cache_list
[
idx
].
width
;
w1
=
cache_list
[
idx
].
width
;
h1
=
cache_list
[
idx
].
height
;
h1
=
cache_list
[
idx
].
height
;
fprintf
(
stderr
,
"backingstore save: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
if
(
verb
)
fprintf
(
stderr
,
"backingstore save: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
X_LOCK
;
X_LOCK
;
if
(
!
valid_wr
(
idx
,
win
,
&
attr
))
{
if
(
!
valid_wr
(
idx
,
win
,
&
attr
))
{
...
@@ -6630,12 +6644,12 @@ fprintf(stderr, "BS_save: FAIL FOR: %d\n", idx);
...
@@ -6630,12 +6644,12 @@ fprintf(stderr, "BS_save: FAIL FOR: %d\n", idx);
sraRgnOffset
(
r
,
dx
,
dy
);
sraRgnOffset
(
r
,
dx
,
dy
);
dtA
=
dnowx
();
dtA
=
dnowx
();
fprintf
(
stderr
,
"BS_save: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
verb
)
fprintf
(
stderr
,
"BS_save: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
w2
>
0
&&
h2
>
0
)
{
if
(
w2
>
0
&&
h2
>
0
)
{
cache_cr
(
r
,
dx
,
dy
,
save_delay0
,
save_delay1
,
nbatch
);
cache_cr
(
r
,
dx
,
dy
,
save_delay0
,
save_delay1
,
nbatch
);
}
}
dtB
=
dnowx
();
dtB
=
dnowx
();
fprintf
(
stderr
,
"BS_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
bs_time
-
x11vnc_start
,
dnowx
());
if
(
verb
)
fprintf
(
stderr
,
"BS_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
bs_time
-
x11vnc_start
,
dnowx
());
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r
);
sraRgnDestroy
(
r
);
...
@@ -6646,7 +6660,7 @@ fprintf(stderr, "BS_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
...
@@ -6646,7 +6660,7 @@ fprintf(stderr, "BS_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
return
1
;
return
1
;
}
}
int
su_save
(
int
idx
,
int
*
nbatch
)
{
int
su_save
(
int
idx
,
int
*
nbatch
,
int
verb
)
{
Window
win
=
cache_list
[
idx
].
win
;
Window
win
=
cache_list
[
idx
].
win
;
XWindowAttributes
attr
;
XWindowAttributes
attr
;
int
x1
,
y1
,
w1
,
h1
;
int
x1
,
y1
,
w1
,
h1
;
...
@@ -6655,7 +6669,7 @@ int su_save(int idx, int *nbatch) {
...
@@ -6655,7 +6669,7 @@ int su_save(int idx, int *nbatch) {
int
dx
,
dy
,
rc
=
1
;
int
dx
,
dy
,
rc
=
1
;
sraRegionPtr
r
,
r0
;
sraRegionPtr
r
,
r0
;
fprintf
(
stderr
,
"save-unders save: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
if
(
verb
)
fprintf
(
stderr
,
"save-unders save: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
x1
=
cache_list
[
idx
].
x
;
x1
=
cache_list
[
idx
].
x
;
y1
=
cache_list
[
idx
].
y
;
y1
=
cache_list
[
idx
].
y
;
...
@@ -6716,12 +6730,12 @@ fprintf(stderr, "SU_save: FAIL FOR: %d\n", idx);
...
@@ -6716,12 +6730,12 @@ fprintf(stderr, "SU_save: FAIL FOR: %d\n", idx);
sraRgnOffset
(
r
,
dx
,
dy
);
sraRgnOffset
(
r
,
dx
,
dy
);
dtA
=
dnowx
();
dtA
=
dnowx
();
fprintf
(
stderr
,
"SU_save: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
verb
)
fprintf
(
stderr
,
"SU_save: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
w2
>
0
&&
h2
>
0
)
{
if
(
w2
>
0
&&
h2
>
0
)
{
cache_cr
(
r
,
dx
,
dy
,
save_delay0
,
save_delay1
,
nbatch
);
cache_cr
(
r
,
dx
,
dy
,
save_delay0
,
save_delay1
,
nbatch
);
}
}
dtB
=
dnowx
();
dtB
=
dnowx
();
fprintf
(
stderr
,
"SU_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
su_time
-
x11vnc_start
,
dnowx
());
if
(
verb
)
fprintf
(
stderr
,
"SU_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
su_time
-
x11vnc_start
,
dnowx
());
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r
);
sraRgnDestroy
(
r
);
...
@@ -6732,7 +6746,7 @@ fprintf(stderr, "SU_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
...
@@ -6732,7 +6746,7 @@ fprintf(stderr, "SU_save: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
return
1
;
return
1
;
}
}
int
bs_restore
(
int
idx
,
int
*
nbatch
,
int
nopad
)
{
int
bs_restore
(
int
idx
,
int
*
nbatch
,
int
nopad
,
int
verb
)
{
Window
win
=
cache_list
[
idx
].
win
;
Window
win
=
cache_list
[
idx
].
win
;
XWindowAttributes
attr
;
XWindowAttributes
attr
;
int
x1
,
y1
,
w1
,
h1
;
int
x1
,
y1
,
w1
,
h1
;
...
@@ -6741,7 +6755,7 @@ int bs_restore(int idx, int *nbatch, int nopad) {
...
@@ -6741,7 +6755,7 @@ int bs_restore(int idx, int *nbatch, int nopad) {
int
dx
,
dy
;
int
dx
,
dy
;
sraRegionPtr
r
,
r0
;
sraRegionPtr
r
,
r0
;
fprintf
(
stderr
,
"backingstore restore: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
if
(
verb
)
fprintf
(
stderr
,
"backingstore restore: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
x1
=
cache_list
[
idx
].
x
;
x1
=
cache_list
[
idx
].
x
;
y1
=
cache_list
[
idx
].
y
;
y1
=
cache_list
[
idx
].
y
;
...
@@ -6807,12 +6821,12 @@ fprintf(stderr, "BS_restore: not a valid X window: 0x%x\n", (unsigned int) win);
...
@@ -6807,12 +6821,12 @@ fprintf(stderr, "BS_restore: not a valid X window: 0x%x\n", (unsigned int) win);
sraRgnAnd
(
r
,
r0
);
sraRgnAnd
(
r
,
r0
);
dtA
=
dnowx
();
dtA
=
dnowx
();
fprintf
(
stderr
,
"BS_rest: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
verb
)
fprintf
(
stderr
,
"BS_rest: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
w2
>
0
&&
h2
>
0
)
{
if
(
w2
>
0
&&
h2
>
0
)
{
cache_cr
(
r
,
dx
,
dy
,
restore_delay0
,
restore_delay1
,
nbatch
);
cache_cr
(
r
,
dx
,
dy
,
restore_delay0
,
restore_delay1
,
nbatch
);
}
}
dtB
=
dnowx
();
dtB
=
dnowx
();
fprintf
(
stderr
,
"BS_rest: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
bs_time
-
x11vnc_start
,
dnowx
());
if
(
verb
)
fprintf
(
stderr
,
"BS_rest: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
bs_time
-
x11vnc_start
,
dnowx
());
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r
);
sraRgnDestroy
(
r
);
...
@@ -6822,7 +6836,7 @@ fprintf(stderr, "BS_rest: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
...
@@ -6822,7 +6836,7 @@ fprintf(stderr, "BS_rest: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
return
1
;
return
1
;
}
}
int
su_restore
(
int
idx
,
int
*
nbatch
,
int
nopad
)
{
int
su_restore
(
int
idx
,
int
*
nbatch
,
int
nopad
,
int
verb
)
{
Window
win
=
cache_list
[
idx
].
win
;
Window
win
=
cache_list
[
idx
].
win
;
XWindowAttributes
attr
;
XWindowAttributes
attr
;
int
x1
,
y1
,
w1
,
h1
;
int
x1
,
y1
,
w1
,
h1
;
...
@@ -6832,7 +6846,7 @@ int su_restore(int idx, int *nbatch, int nopad) {
...
@@ -6832,7 +6846,7 @@ int su_restore(int idx, int *nbatch, int nopad) {
sraRegionPtr
r
,
r0
;
sraRegionPtr
r
,
r0
;
int
invalid
=
0
;
int
invalid
=
0
;
fprintf
(
stderr
,
"save-unders restore: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
if
(
verb
)
fprintf
(
stderr
,
"save-unders restore: 0x%x %3d
\n
"
,
(
unsigned
int
)
win
,
idx
);
x1
=
cache_list
[
idx
].
x
;
x1
=
cache_list
[
idx
].
x
;
y1
=
cache_list
[
idx
].
y
;
y1
=
cache_list
[
idx
].
y
;
...
@@ -6903,12 +6917,12 @@ fprintf(stderr, "SU_rest: su_x/bs_x/su_time: %d %d %.3f\n", x, cache_list[idx].b
...
@@ -6903,12 +6917,12 @@ fprintf(stderr, "SU_rest: su_x/bs_x/su_time: %d %d %.3f\n", x, cache_list[idx].b
sraRgnAnd
(
r
,
r0
);
sraRgnAnd
(
r
,
r0
);
dtA
=
dnowx
();
dtA
=
dnowx
();
fprintf
(
stderr
,
"SU_rest: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
verb
)
fprintf
(
stderr
,
"SU_rest: %.4f %d dx=%d dy=%d
\n
"
,
dtA
,
idx
,
dx
,
dy
);
if
(
w2
>
0
&&
h2
>
0
)
{
if
(
w2
>
0
&&
h2
>
0
)
{
cache_cr
(
r
,
dx
,
dy
,
restore_delay0
,
restore_delay1
,
nbatch
);
cache_cr
(
r
,
dx
,
dy
,
restore_delay0
,
restore_delay1
,
nbatch
);
}
}
dtB
=
dnowx
();
dtB
=
dnowx
();
fprintf
(
stderr
,
"SU_rest: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
su_time
-
x11vnc_start
,
dnowx
());
if
(
verb
)
fprintf
(
stderr
,
"SU_rest: %.4f %.2f %d done. %dx%d+%d+%d %dx%d+%d+%d %.2f %.2f
\n
"
,
dtB
,
dtB
-
dtA
,
idx
,
w1
,
h1
,
x1
,
y1
,
w2
,
h2
,
x2
,
y2
,
cache_list
[
idx
].
su_time
-
x11vnc_start
,
dnowx
());
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r0
);
sraRgnDestroy
(
r
);
sraRgnDestroy
(
r
);
...
@@ -7042,7 +7056,7 @@ Window sched_bs[NSCHED];
...
@@ -7042,7 +7056,7 @@ Window sched_bs[NSCHED];
double
sched_tm
[
NSCHED
];
double
sched_tm
[
NSCHED
];
double
last_sched_bs
=
0
.
0
;
double
last_sched_bs
=
0
.
0
;
#define SCHED(w) \
#define SCHED(w
, v
) \
{ \
{ \
int k, save = -1, empty = 1; \
int k, save = -1, empty = 1; \
for (k=0; k < NSCHED; k++) { \
for (k=0; k < NSCHED; k++) { \
...
@@ -7059,7 +7073,7 @@ double last_sched_bs = 0.0;
...
@@ -7059,7 +7073,7 @@ double last_sched_bs = 0.0;
sched_bs[save] = w; \
sched_bs[save] = w; \
if (empty) { \
if (empty) { \
sched_tm[save] = dnow(); \
sched_tm[save] = dnow(); \
fprintf(stderr, "SCHED: %d %f\n", save, dnowx()); \
if (v)
fprintf(stderr, "SCHED: %d %f\n", save, dnowx()); \
} \
} \
} \
} \
}
}
...
@@ -7174,7 +7188,7 @@ int check_ncache(int reset, int mode) {
...
@@ -7174,7 +7188,7 @@ int check_ncache(int reset, int mode) {
if
(
ncache0
)
{
if
(
ncache0
)
{
if
(
reset
)
{
if
(
reset
)
{
;
;
}
else
if
(
!
client_count
||
!
ncache
)
{
}
else
if
(
!
client_count
||
!
ncache
||
nofb
)
{
static
double
last_purge
=
0
.
0
;
static
double
last_purge
=
0
.
0
;
double
delay
=
client_count
?
0
.
5
:
2
.
0
;
double
delay
=
client_count
?
0
.
5
:
2
.
0
;
if
(
now
>
last_purge
+
delay
)
{
if
(
now
>
last_purge
+
delay
)
{
...
@@ -7209,6 +7223,9 @@ if (c) fprintf(stderr, "check_ncache purged %d events\n", c);
...
@@ -7209,6 +7223,9 @@ if (c) fprintf(stderr, "check_ncache purged %d events\n", c);
if
(
subwin
)
{
if
(
subwin
)
{
return
-
1
;
return
-
1
;
}
}
if
(
nofb
)
{
return
-
1
;
}
if
(
reset
)
{
if
(
reset
)
{
rfbLog
(
"check_ncache: resetting cache
\n
"
);
rfbLog
(
"check_ncache: resetting cache
\n
"
);
...
@@ -7352,7 +7369,7 @@ fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, (unsigned
...
@@ -7352,7 +7369,7 @@ fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, (unsigned
int
idx
=
lookup_win_index
(
topmapped
);
int
idx
=
lookup_win_index
(
topmapped
);
if
(
idx
>=
0
)
{
if
(
idx
>=
0
)
{
if
(
!
macosx_console
)
{
if
(
!
macosx_console
)
{
bs_save
(
idx
,
NULL
);
bs_save
(
idx
,
NULL
,
1
);
}
}
}
}
}
}
...
@@ -7387,8 +7404,8 @@ fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, (unsigned
...
@@ -7387,8 +7404,8 @@ fprintf(stderr, "Created window never mapped: freeing(%d) 0x%x\n", k, (unsigned
}
else
if
(
aw
*
ah
<
64
*
64
)
{
}
else
if
(
aw
*
ah
<
64
*
64
)
{
;
;
}
else
{
}
else
{
fprintf
(
stderr
,
"*
NEW
BS_save: 0x%x %d %d %d
\n
"
,
(
unsigned
int
)
win
,
aw
,
ah
,
cache_list
[
idx
].
map_state
);
fprintf
(
stderr
,
"*
SNAP
BS_save: 0x%x %d %d %d
\n
"
,
(
unsigned
int
)
win
,
aw
,
ah
,
cache_list
[
idx
].
map_state
);
bs_save
(
idx
,
bat
);
bs_save
(
idx
,
bat
,
0
);
}
}
}
}
}
}
...
@@ -7409,7 +7426,7 @@ fprintf(stderr, "*NEW BS_save: 0x%x %d %d %d\n", (unsigned int) win, aw, ah, cac
...
@@ -7409,7 +7426,7 @@ fprintf(stderr, "*NEW BS_save: 0x%x %d %d %d\n", (unsigned int) win, aw, ah, cac
if
(
cache_list
[
i
].
vis_state
==
VisibilityUnobscured
)
{
if
(
cache_list
[
i
].
vis_state
==
VisibilityUnobscured
)
{
if
(
cache_list
[
i
].
valid
)
{
if
(
cache_list
[
i
].
valid
)
{
if
(
cache_list
[
i
].
win
!=
None
)
{
if
(
cache_list
[
i
].
win
!=
None
)
{
SCHED
(
cache_list
[
i
].
win
)
SCHED
(
cache_list
[
i
].
win
,
0
)
}
}
}
}
}
}
...
@@ -7554,10 +7571,10 @@ fprintf(stderr, "\n"); rfbLog("IN check_ncache() %d events.\n", n);
...
@@ -7554,10 +7571,10 @@ fprintf(stderr, "\n"); rfbLog("IN check_ncache() %d events.\n", n);
if
(
create_tot
<=
6
&&
create_cnt
++
<
3
)
{
if
(
create_tot
<=
6
&&
create_cnt
++
<
3
)
{
if
(
w
*
h
>
64
*
64
)
{
if
(
w
*
h
>
64
*
64
)
{
X_UNLOCK
;
X_UNLOCK
;
su_save
(
idx
,
nbatch
);
su_save
(
idx
,
nbatch
,
1
);
X_LOCK
;
X_LOCK
;
if
(
cache_list
[
idx
].
valid
)
{
if
(
cache_list
[
idx
].
valid
)
{
SCHED
(
win2
)
SCHED
(
win2
,
1
)
}
}
create_cnt
++
;
create_cnt
++
;
}
}
...
@@ -7655,7 +7672,7 @@ fprintf(stderr, "----%02d: VisibilityNotify 0x%x %3d state: %s U/P %d/%d\n", i
...
@@ -7655,7 +7672,7 @@ fprintf(stderr, "----%02d: VisibilityNotify 0x%x %3d state: %s U/P %d/%d\n", i
}
}
if
(
ok
)
{
if
(
ok
)
{
X_UNLOCK
;
X_UNLOCK
;
bs_restore
(
idx
,
nbatch
,
1
);
bs_restore
(
idx
,
nbatch
,
1
,
1
);
X_LOCK
;
X_LOCK
;
cache_list
[
idx
].
time
=
dnow
();
cache_list
[
idx
].
time
=
dnow
();
cache_list
[
idx
].
vis_cnt
++
;
cache_list
[
idx
].
vis_cnt
++
;
...
@@ -7665,7 +7682,7 @@ fprintf(stderr, "----%02d: VisibilityNotify 0x%x %3d state: %s U/P %d/%d\n", i
...
@@ -7665,7 +7682,7 @@ fprintf(stderr, "----%02d: VisibilityNotify 0x%x %3d state: %s U/P %d/%d\n", i
Ev_rects
[
nrects
].
x2
=
cache_list
[
idx
].
width
;
Ev_rects
[
nrects
].
x2
=
cache_list
[
idx
].
width
;
Ev_rects
[
nrects
].
y2
=
cache_list
[
idx
].
height
;
Ev_rects
[
nrects
].
y2
=
cache_list
[
idx
].
height
;
nrects
++
;
nrects
++
;
SCHED
(
win
)
SCHED
(
win
,
1
)
}
}
}
}
cache_list
[
idx
].
vis_state
=
state
;
cache_list
[
idx
].
vis_state
=
state
;
...
@@ -7680,14 +7697,14 @@ fprintf(stderr, "----%02d: MapNotify 0x%x %3d\n", i, (unsigned int) win,
...
@@ -7680,14 +7697,14 @@ fprintf(stderr, "----%02d: MapNotify 0x%x %3d\n", i, (unsigned int) win,
if
(
cache_list
[
idx
].
map_state
==
IsUnmapped
||
macosx_console
)
{
if
(
cache_list
[
idx
].
map_state
==
IsUnmapped
||
macosx_console
)
{
X_UNLOCK
;
X_UNLOCK
;
su_save
(
idx
,
nbatch
);
su_save
(
idx
,
nbatch
,
1
);
bs_restore
(
idx
,
nbatch
,
0
);
bs_restore
(
idx
,
nbatch
,
0
,
1
);
if
(
macosx_console
)
{
if
(
macosx_console
)
{
#ifdef MACOSX
#ifdef MACOSX
macosxCGS_follow_animation_win
(
win
,
-
1
,
1
);
macosxCGS_follow_animation_win
(
win
,
-
1
,
1
);
if
(
valid_window
(
win
,
&
attr
,
1
))
{
if
(
valid_window
(
win
,
&
attr
,
1
))
{
STORE
(
idx
,
win
,
attr
);
STORE
(
idx
,
win
,
attr
);
SCHED
(
win
);
SCHED
(
win
,
1
);
}
}
/* XXX Y */
/* XXX Y */
if
(
cache_list
[
idx
].
vis_state
==
-
1
)
{
if
(
cache_list
[
idx
].
vis_state
==
-
1
)
{
...
@@ -7723,8 +7740,8 @@ fprintf(stderr, "----%02d: UnmapNotify 0x%x %3d\n", i, (unsigned int) win,
...
@@ -7723,8 +7740,8 @@ fprintf(stderr, "----%02d: UnmapNotify 0x%x %3d\n", i, (unsigned int) win,
if
(
cache_list
[
idx
].
map_state
==
IsViewable
||
macosx_console
)
{
if
(
cache_list
[
idx
].
map_state
==
IsViewable
||
macosx_console
)
{
X_UNLOCK
;
X_UNLOCK
;
bs_save
(
idx
,
nbatch
);
bs_save
(
idx
,
nbatch
,
1
);
su_restore
(
idx
,
nbatch
,
0
);
su_restore
(
idx
,
nbatch
,
0
,
1
);
X_LOCK
;
X_LOCK
;
pixels
+=
cache_list
[
idx
].
width
*
cache_list
[
idx
].
height
;
pixels
+=
cache_list
[
idx
].
width
*
cache_list
[
idx
].
height
;
cache_list
[
idx
].
time
=
dnow
();
cache_list
[
idx
].
time
=
dnow
();
...
...
x11vnc/util.c
View file @
833f0602
...
@@ -548,8 +548,8 @@ char *choose_title(char *display) {
...
@@ -548,8 +548,8 @@ char *choose_title(char *display) {
}
}
strncat
(
title
,
display
,
MAXN
-
strlen
(
title
));
strncat
(
title
,
display
,
MAXN
-
strlen
(
title
));
if
(
subwin
&&
dpy
&&
valid_window
(
subwin
,
NULL
,
0
))
{
if
(
subwin
&&
dpy
&&
valid_window
(
subwin
,
NULL
,
0
))
{
char
*
name
=
NULL
;
#if !NO_X11
#if !NO_X11
char
*
name
=
NULL
;
if
(
XFetchName
(
dpy
,
subwin
,
&
name
))
{
if
(
XFetchName
(
dpy
,
subwin
,
&
name
))
{
if
(
name
)
{
if
(
name
)
{
strncat
(
title
,
" "
,
MAXN
-
strlen
(
title
));
strncat
(
title
,
" "
,
MAXN
-
strlen
(
title
));
...
@@ -557,8 +557,6 @@ char *choose_title(char *display) {
...
@@ -557,8 +557,6 @@ char *choose_title(char *display) {
free
(
name
);
free
(
name
);
}
}
}
}
#else
if
(
!
name
)
{}
#endif
/* NO_X11 */
#endif
/* NO_X11 */
}
}
return
title
;
return
title
;
...
...
x11vnc/win_utils.c
View file @
833f0602
...
@@ -85,11 +85,13 @@ int valid_window(Window win, XWindowAttributes *attr_ret, int bequiet) {
...
@@ -85,11 +85,13 @@ int valid_window(Window win, XWindowAttributes *attr_ret, int bequiet) {
if
(
win
==
None
)
{
if
(
win
==
None
)
{
return
0
;
return
0
;
}
}
#ifdef MACOSX
#ifdef MACOSX
if
(
macosx_console
)
{
if
(
macosx_console
)
{
return
macosx_valid_window
(
win
,
attr_ret
);
return
macosx_valid_window
(
win
,
attr_ret
);
}
}
#endif
#endif
RAWFB_RET
(
0
)
RAWFB_RET
(
0
)
#if NO_X11
#if NO_X11
...
@@ -205,7 +207,7 @@ void snapshot_stack_list(int free_only, double allowed_age) {
...
@@ -205,7 +207,7 @@ void snapshot_stack_list(int free_only, double allowed_age) {
#endif
#endif
#if NO_X11 && !defined(MACOSX)
#if NO_X11 && !defined(MACOSX)
num
=
rc
=
i
=
j
=
0
;
num
=
rc
=
i
=
j
=
0
;
/* compiler warnings */
ui
=
0
;
ui
=
0
;
r
=
w
=
None
;
r
=
w
=
None
;
list
=
NULL
;
list
=
NULL
;
...
@@ -332,7 +334,7 @@ if (0) fprintf(stderr, "update_stack_list[%d]: %.4f %.4f\n", stack_list_num, no
...
@@ -332,7 +334,7 @@ if (0) fprintf(stderr, "update_stack_list[%d]: %.4f %.4f\n", stack_list_num, no
Window
query_pointer
(
Window
start
)
{
Window
query_pointer
(
Window
start
)
{
int
rx
,
ry
;
int
rx
,
ry
;
#if !NO_X11
#if !NO_X11
Window
r
,
c
;
Window
r
,
c
;
/* compiler warnings */
int
wx
,
wy
;
int
wx
,
wy
;
unsigned
int
mask
;
unsigned
int
mask
;
#endif
#endif
...
@@ -344,6 +346,7 @@ Window query_pointer(Window start) {
...
@@ -344,6 +346,7 @@ Window query_pointer(Window start) {
#endif
#endif
RAWFB_RET
(
None
)
RAWFB_RET
(
None
)
#if NO_X11
#if NO_X11
if
(
!
start
)
{
rx
=
ry
=
0
;
}
if
(
!
start
)
{
rx
=
ry
=
0
;
}
return
None
;
return
None
;
...
...
x11vnc/x11vnc.1
View file @
833f0602
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
.TH X11VNC "1" "December 2006" "x11vnc " "User Commands"
.TH X11VNC "1" "December 2006" "x11vnc " "User Commands"
.SH NAME
.SH NAME
x11vnc - allow VNC connections to real X11 displays
x11vnc - allow VNC connections to real X11 displays
version: 0.8.4, lastmod: 2006-12-2
8
version: 0.8.4, lastmod: 2006-12-2
9
.SH SYNOPSIS
.SH SYNOPSIS
.B x11vnc
.B x11vnc
[OPTION]...
[OPTION]...
...
...
x11vnc/x11vnc.c
View file @
833f0602
...
@@ -1443,6 +1443,50 @@ static void store_homedir_passwd(char *file) {
...
@@ -1443,6 +1443,50 @@ static void store_homedir_passwd(char *file) {
exit
(
0
);
exit
(
0
);
}
}
void
ncache_beta_tester_message
(
void
)
{
char
msg
[]
=
"
\n
"
"***************************************************************************
\n
"
"
\n
"
"Hello! Exciting News!!
\n
"
"
\n
"
"You have been selected at random to beta test the x11vnc '-ncache' VNC
\n
"
"client-side pixel caching feature!
\n
"
"
\n
"
"This scheme stores pixel data offscreen on the VNC viewer side for faster
\n
"
"retrieval. It should work with any VNC viewer.
\n
"
"
\n
"
"This method requires much testing and so we hope you will try it out and
\n
"
"perhaps even report back your observations. However, if you do not want
\n
"
"to test or use the feature, run x11vnc like this:
\n
"
"
\n
"
" x11vnc -ncache 0 ...
\n
"
"
\n
"
"The feature needs additional testing because we want to have x11vnc
\n
"
"performance enhancements on by default. Otherwise, only a relative few
\n
"
"would notice and use the -ncache option (e.g. the wireframe and scroll
\n
"
"detection features are on by default). A couple things to note:
\n
"
"
\n
"
" 1) It uses a large amount of RAM (on both viewer and server)
\n
"
"
\n
"
" 2) You can actually see the cached pixel data if you scroll down
\n
"
" to it in your viewer; adjust your viewer's size to hide it.
\n
"
"
\n
"
"More info: http://www.karlrunge.com/x11vnc/#faq-client-caching
\n
"
;
if
(
raw_fb_str
&&
!
macosx_console
)
{
return
;
}
if
(
nofb
)
{
return
;
}
fprintf
(
stderr
,
"%s"
,
msg
);
}
#define SHOW_NO_PASSWORD_WARNING \
#define SHOW_NO_PASSWORD_WARNING \
(!got_passwd && !got_rfbauth && (!got_passwdfile || !passwd_list) \
(!got_passwd && !got_rfbauth && (!got_passwdfile || !passwd_list) \
&& !query_cmd && !remote_cmd && !unixpw && !got_gui_pw \
&& !query_cmd && !remote_cmd && !unixpw && !got_gui_pw \
...
@@ -2920,6 +2964,11 @@ int main(int argc, char* argv[]) {
...
@@ -2920,6 +2964,11 @@ int main(int argc, char* argv[]) {
}
}
}
}
if
(
ncache
<
0
)
{
ncache_beta_tester
=
1
;
ncache
=
-
ncache
;
}
if
(
raw_fb_str
)
{
if
(
raw_fb_str
)
{
set_raw_fb_params
(
0
);
set_raw_fb_params
(
0
);
}
}
...
@@ -3349,6 +3398,7 @@ int main(int argc, char* argv[]) {
...
@@ -3349,6 +3398,7 @@ int main(int argc, char* argv[]) {
rfbLog
(
" client sides. This mode works with any VNC viewer,
\n
"
);
rfbLog
(
" client sides. This mode works with any VNC viewer,
\n
"
);
rfbLog
(
" however in most you can actually see the cached pixel
\n
"
);
rfbLog
(
" however in most you can actually see the cached pixel
\n
"
);
rfbLog
(
" data by scrolling down, so you need to re-adjust its size.
\n
"
);
rfbLog
(
" data by scrolling down, so you need to re-adjust its size.
\n
"
);
rfbLog
(
" See http://www.karlrunge.com/x11vnc/#faq-client-caching.
\n
"
);
rfbLog
(
" If this mode yields undesired behavior (poor response,
\n
"
);
rfbLog
(
" If this mode yields undesired behavior (poor response,
\n
"
);
rfbLog
(
" painting errors, etc) it may be disabled via: '-ncache 0'
\n
"
);
rfbLog
(
" painting errors, etc) it may be disabled via: '-ncache 0'
\n
"
);
rfbLog
(
" You can press 3 Alt_L's (Left
\"
Alt
\"
key) in a row to
\n
"
);
rfbLog
(
" You can press 3 Alt_L's (Left
\"
Alt
\"
key) in a row to
\n
"
);
...
@@ -3562,6 +3612,10 @@ int main(int argc, char* argv[]) {
...
@@ -3562,6 +3612,10 @@ int main(int argc, char* argv[]) {
}
}
set_vnc_desktop_name
();
set_vnc_desktop_name
();
if
(
ncache_beta_tester
)
{
ncache_beta_tester_message
();
}
#if LIBVNCSERVER_HAVE_FORK && LIBVNCSERVER_HAVE_SETSID
#if LIBVNCSERVER_HAVE_FORK && LIBVNCSERVER_HAVE_SETSID
if
(
bg
)
{
if
(
bg
)
{
/* fork into the background now */
/* fork into the background now */
...
...
x11vnc/x11vnc_defs.c
View file @
833f0602
...
@@ -15,7 +15,7 @@ int xtrap_base_event_type = 0;
...
@@ -15,7 +15,7 @@ int xtrap_base_event_type = 0;
int
xdamage_base_event_type
=
0
;
int
xdamage_base_event_type
=
0
;
/* date +'lastmod: %Y-%m-%d' */
/* date +'lastmod: %Y-%m-%d' */
char
lastmod
[]
=
"0.8.4 lastmod: 2006-12-2
8
"
;
char
lastmod
[]
=
"0.8.4 lastmod: 2006-12-2
9
"
;
/* X display info */
/* X display info */
...
...
x11vnc/xevents.c
View file @
833f0602
...
@@ -181,7 +181,9 @@ static void get_prop(char *str, int len, Atom prop) {
...
@@ -181,7 +181,9 @@ static void get_prop(char *str, int len, Atom prop) {
if
(
prop
==
None
)
{
if
(
prop
==
None
)
{
return
;
return
;
}
}
RAWFB_RET_VOID
RAWFB_RET_VOID
#if NO_X11
#if NO_X11
return
;
return
;
#else
#else
...
...
x11vnc/xwrappers.c
View file @
833f0602
...
@@ -318,7 +318,8 @@ XImage *XCreateImage_wr(Display *disp, Visual *visual, unsigned int depth,
...
@@ -318,7 +318,8 @@ XImage *XCreateImage_wr(Display *disp, Visual *visual, unsigned int depth,
#if NO_X11
#if NO_X11
nox11_exit
(
1
);
nox11_exit
(
1
);
if
(
!
disp
||
!
visual
||
!
depth
||
!
format
||
!
offset
||
!
data
||
!
width
||
!
height
||
!
width
||
!
bitmap_pad
||
!
bytes_per_line
)
{}
if
(
!
disp
||
!
visual
||
!
depth
||
!
format
||
!
offset
||
!
data
||
!
width
||
!
height
||
!
width
||
!
bitmap_pad
||
!
bytes_per_line
)
{}
return
NULL
;
return
NULL
;
#else
#else
if
(
overlay
)
{
if
(
overlay
)
{
...
@@ -632,16 +633,16 @@ void XTRAP_FakeKeyEvent_wr(Display* dpy, KeyCode key, Bool down,
...
@@ -632,16 +633,16 @@ void XTRAP_FakeKeyEvent_wr(Display* dpy, KeyCode key, Bool down,
/* unused vars warning: */
/* unused vars warning: */
if
(
key
||
down
||
delay
)
{}
if
(
key
||
down
||
delay
)
{}
#if LIBVNCSERVER_HAVE_LIBXTRAP
#
if LIBVNCSERVER_HAVE_LIBXTRAP
XESimulateXEventRequest
(
trap_ctx
,
down
?
KeyPress
:
KeyRelease
,
XESimulateXEventRequest
(
trap_ctx
,
down
?
KeyPress
:
KeyRelease
,
key
,
0
,
0
,
0
);
key
,
0
,
0
,
0
);
if
(
debug_keyboard
)
{
if
(
debug_keyboard
)
{
upup_downdown_warning
(
key
,
down
);
upup_downdown_warning
(
key
,
down
);
}
}
keycode_state
[(
int
)
key
]
=
down
?
1
:
0
;
keycode_state
[(
int
)
key
]
=
down
?
1
:
0
;
#else
#
else
DEBUG_SKIPPED_INPUT
(
debug_keyboard
,
"keyboard: no-XTRAP-build"
);
DEBUG_SKIPPED_INPUT
(
debug_keyboard
,
"keyboard: no-XTRAP-build"
);
#endif
#
endif
#endif
/* NO_X11 */
#endif
/* NO_X11 */
}
}
...
@@ -1112,7 +1113,8 @@ Bool XQueryPointer_wr(Display *display, Window w, Window *root_return,
...
@@ -1112,7 +1113,8 @@ Bool XQueryPointer_wr(Display *display, Window w, Window *root_return,
Window
*
child_return
,
int
*
root_x_return
,
int
*
root_y_return
,
Window
*
child_return
,
int
*
root_x_return
,
int
*
root_y_return
,
int
*
win_x_return
,
int
*
win_y_return
,
unsigned
int
*
mask_return
)
{
int
*
win_x_return
,
int
*
win_y_return
,
unsigned
int
*
mask_return
)
{
#if NO_X11
#if NO_X11
if
(
!
display
||
!
w
||
!
root_return
||
!
child_return
||
!
root_x_return
||
!
root_y_return
||
!
win_x_return
||
!
win_y_return
||
!
mask_return
)
{}
if
(
!
display
||
!
w
||
!
root_return
||
!
child_return
||
!
root_x_return
||
!
root_y_return
||
!
win_x_return
||
!
win_y_return
||
!
mask_return
)
{}
return
False
;
return
False
;
#else
#else
Bool
rc
;
Bool
rc
;
...
@@ -1163,7 +1165,8 @@ Status XQueryTree_wr(Display *display, Window w, Window *root_return,
...
@@ -1163,7 +1165,8 @@ Status XQueryTree_wr(Display *display, Window w, Window *root_return,
}
}
#endif
#endif
#if NO_X11
#if NO_X11
if
(
!
display
||
!
w
||
!
root_return
||
!
parent_return
||
!
children_return
||
!
nchildren_return
)
{}
if
(
!
display
||
!
w
||
!
root_return
||
!
parent_return
||
!
children_return
||
!
nchildren_return
)
{}
return
(
Status
)
0
;
return
(
Status
)
0
;
#else
#else
if
(
!
display
)
{
if
(
!
display
)
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment