Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
2dbf14ee
Commit
2dbf14ee
authored
Aug 31, 2020
by
Jacek Caban
Committed by
Alexandre Julliard
Aug 31, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
conhost: Implement IOCTL_CONDRV_FILL_OUTPUT.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
c1c61bf2
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
55 additions
and
0 deletions
+55
-0
conhost.c
programs/conhost/conhost.c
+55
-0
No files found.
programs/conhost/conhost.c
View file @
2dbf14ee
...
@@ -623,6 +623,56 @@ static NTSTATUS read_output( struct screen_buffer *screen_buffer, const struct c
...
@@ -623,6 +623,56 @@ static NTSTATUS read_output( struct screen_buffer *screen_buffer, const struct c
return
STATUS_SUCCESS
;
return
STATUS_SUCCESS
;
}
}
static
NTSTATUS
fill_output
(
struct
screen_buffer
*
screen_buffer
,
const
struct
condrv_fill_output_params
*
params
)
{
char_info_t
*
end
,
*
dest
;
DWORD
i
,
count
,
*
result
;
TRACE
(
"(%u %u) mode %u
\n
"
,
params
->
x
,
params
->
y
,
params
->
mode
);
dest
=
screen_buffer
->
data
+
params
->
y
*
screen_buffer
->
width
+
params
->
x
;
if
(
params
->
y
>=
screen_buffer
->
height
)
return
STATUS_SUCCESS
;
if
(
params
->
wrap
)
end
=
screen_buffer
->
data
+
screen_buffer
->
height
*
screen_buffer
->
width
;
else
end
=
screen_buffer
->
data
+
(
params
->
y
+
1
)
*
screen_buffer
->
width
;
count
=
params
->
count
;
if
(
count
>
end
-
dest
)
count
=
end
-
dest
;
switch
(
params
->
mode
)
{
case
CHAR_INFO_MODE_TEXT
:
for
(
i
=
0
;
i
<
count
;
i
++
)
dest
[
i
].
ch
=
params
->
ch
;
break
;
case
CHAR_INFO_MODE_ATTR
:
for
(
i
=
0
;
i
<
count
;
i
++
)
dest
[
i
].
attr
=
params
->
attr
;
break
;
case
CHAR_INFO_MODE_TEXTATTR
:
for
(
i
=
0
;
i
<
count
;
i
++
)
{
dest
[
i
].
ch
=
params
->
ch
;
dest
[
i
].
attr
=
params
->
attr
;
}
break
;
case
CHAR_INFO_MODE_TEXTSTDATTR
:
for
(
i
=
0
;
i
<
count
;
i
++
)
{
dest
[
i
].
ch
=
params
->
ch
;
dest
[
i
].
attr
=
screen_buffer
->
attr
;
}
break
;
default:
return
STATUS_INVALID_PARAMETER
;
}
if
(
!
(
result
=
alloc_ioctl_buffer
(
sizeof
(
*
result
)
)))
return
STATUS_NO_MEMORY
;
*
result
=
count
;
return
STATUS_SUCCESS
;
}
static
NTSTATUS
set_console_title
(
struct
console
*
console
,
const
WCHAR
*
in_title
,
size_t
size
)
static
NTSTATUS
set_console_title
(
struct
console
*
console
,
const
WCHAR
*
in_title
,
size_t
size
)
{
{
WCHAR
*
title
=
NULL
;
WCHAR
*
title
=
NULL
;
...
@@ -689,6 +739,11 @@ static NTSTATUS screen_buffer_ioctl( struct screen_buffer *screen_buffer, unsign
...
@@ -689,6 +739,11 @@ static NTSTATUS screen_buffer_ioctl( struct screen_buffer *screen_buffer, unsign
if
(
in_size
<
sizeof
(
struct
condrv_output_info
)
||
*
out_size
)
return
STATUS_INVALID_PARAMETER
;
if
(
in_size
<
sizeof
(
struct
condrv_output_info
)
||
*
out_size
)
return
STATUS_INVALID_PARAMETER
;
return
set_output_info
(
screen_buffer
,
in_data
,
in_size
);
return
set_output_info
(
screen_buffer
,
in_data
,
in_size
);
case
IOCTL_CONDRV_FILL_OUTPUT
:
if
(
in_size
!=
sizeof
(
struct
condrv_fill_output_params
)
||
*
out_size
!=
sizeof
(
DWORD
))
return
STATUS_INVALID_PARAMETER
;
return
fill_output
(
screen_buffer
,
in_data
);
default:
default:
FIXME
(
"unsupported ioctl %x
\n
"
,
code
);
FIXME
(
"unsupported ioctl %x
\n
"
,
code
);
return
STATUS_NOT_SUPPORTED
;
return
STATUS_NOT_SUPPORTED
;
...
...
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