Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
968d07dd
Commit
968d07dd
authored
Jul 16, 2015
by
Iván Matellanes
Committed by
Alexandre Julliard
Jul 17, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msvcirt: Implement ios::setf.
parent
6f89103b
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
38 additions
and
4 deletions
+38
-4
msvcirt.c
dlls/msvcirt/msvcirt.c
+18
-4
msvcirt.c
dlls/msvcirt/tests/msvcirt.c
+20
-0
No files found.
dlls/msvcirt/msvcirt.c
View file @
968d07dd
...
@@ -82,6 +82,8 @@ typedef struct {
...
@@ -82,6 +82,8 @@ typedef struct {
}
ios
;
}
ios
;
ios
*
__thiscall
ios_assign
(
ios
*
,
const
ios
*
);
ios
*
__thiscall
ios_assign
(
ios
*
,
const
ios
*
);
void
__cdecl
ios_lock
(
ios
*
);
void
__cdecl
ios_unlock
(
ios
*
);
/* class ostream */
/* class ostream */
typedef
struct
_ostream
{
typedef
struct
_ostream
{
...
@@ -1086,8 +1088,14 @@ int __thiscall ios_rdstate(const ios *this)
...
@@ -1086,8 +1088,14 @@ int __thiscall ios_rdstate(const ios *this)
DEFINE_THISCALL_WRAPPER
(
ios_setf
,
8
)
DEFINE_THISCALL_WRAPPER
(
ios_setf
,
8
)
LONG
__thiscall
ios_setf
(
ios
*
this
,
LONG
flags
)
LONG
__thiscall
ios_setf
(
ios
*
this
,
LONG
flags
)
{
{
FIXME
(
"(%p %x) stub
\n
"
,
this
,
flags
);
LONG
prev
=
this
->
flags
;
return
0
;
TRACE
(
"(%p %x)
\n
"
,
this
,
flags
);
ios_lock
(
this
);
this
->
flags
|=
flags
;
ios_unlock
(
this
);
return
prev
;
}
}
/* ?setf@ios@@QAEJJJ@Z */
/* ?setf@ios@@QAEJJJ@Z */
...
@@ -1095,8 +1103,14 @@ LONG __thiscall ios_setf(ios *this, LONG flags)
...
@@ -1095,8 +1103,14 @@ LONG __thiscall ios_setf(ios *this, LONG flags)
DEFINE_THISCALL_WRAPPER
(
ios_setf_mask
,
12
)
DEFINE_THISCALL_WRAPPER
(
ios_setf_mask
,
12
)
LONG
__thiscall
ios_setf_mask
(
ios
*
this
,
LONG
flags
,
LONG
mask
)
LONG
__thiscall
ios_setf_mask
(
ios
*
this
,
LONG
flags
,
LONG
mask
)
{
{
FIXME
(
"(%p %x %x) stub
\n
"
,
this
,
flags
,
mask
);
LONG
prev
=
this
->
flags
;
return
0
;
TRACE
(
"(%p %x %x)
\n
"
,
this
,
flags
,
mask
);
ios_lock
(
this
);
this
->
flags
=
(
this
->
flags
&
(
~
mask
))
|
(
flags
&
mask
);
ios_unlock
(
this
);
return
prev
;
}
}
/* ?setlock@ios@@QAAXXZ */
/* ?setlock@ios@@QAAXXZ */
...
...
dlls/msvcirt/tests/msvcirt.c
View file @
968d07dd
...
@@ -139,6 +139,8 @@ static void (*__cdecl p_ios_lockc)(void);
...
@@ -139,6 +139,8 @@ static void (*__cdecl p_ios_lockc)(void);
static
void
(
*
__cdecl
p_ios_unlockc
)(
void
);
static
void
(
*
__cdecl
p_ios_unlockc
)(
void
);
static
LONG
(
*
__thiscall
p_ios_flags_set
)(
ios
*
,
LONG
);
static
LONG
(
*
__thiscall
p_ios_flags_set
)(
ios
*
,
LONG
);
static
LONG
(
*
__thiscall
p_ios_flags_get
)(
const
ios
*
);
static
LONG
(
*
__thiscall
p_ios_flags_get
)(
const
ios
*
);
static
LONG
(
*
__thiscall
p_ios_setf
)(
ios
*
,
LONG
);
static
LONG
(
*
__thiscall
p_ios_setf_mask
)(
ios
*
,
LONG
,
LONG
);
/* Emulate a __thiscall */
/* Emulate a __thiscall */
#ifdef __i386__
#ifdef __i386__
...
@@ -249,6 +251,8 @@ static BOOL init(void)
...
@@ -249,6 +251,8 @@ static BOOL init(void)
SET
(
p_ios_unlockbuf
,
"?unlockbuf@ios@@QEAAXXZ"
);
SET
(
p_ios_unlockbuf
,
"?unlockbuf@ios@@QEAAXXZ"
);
SET
(
p_ios_flags_set
,
"?flags@ios@@QEAAJJ@Z"
);
SET
(
p_ios_flags_set
,
"?flags@ios@@QEAAJJ@Z"
);
SET
(
p_ios_flags_get
,
"?flags@ios@@QEBAJXZ"
);
SET
(
p_ios_flags_get
,
"?flags@ios@@QEBAJXZ"
);
SET
(
p_ios_setf
,
"?setf@ios@@QEAAJJ@Z"
);
SET
(
p_ios_setf_mask
,
"?setf@ios@@QEAAJJJ@Z"
);
}
else
{
}
else
{
p_operator_new
=
(
void
*
)
GetProcAddress
(
msvcrt
,
"??2@YAPAXI@Z"
);
p_operator_new
=
(
void
*
)
GetProcAddress
(
msvcrt
,
"??2@YAPAXI@Z"
);
...
@@ -289,6 +293,8 @@ static BOOL init(void)
...
@@ -289,6 +293,8 @@ static BOOL init(void)
SET
(
p_ios_unlockbuf
,
"?unlockbuf@ios@@QAAXXZ"
);
SET
(
p_ios_unlockbuf
,
"?unlockbuf@ios@@QAAXXZ"
);
SET
(
p_ios_flags_set
,
"?flags@ios@@QAEJJ@Z"
);
SET
(
p_ios_flags_set
,
"?flags@ios@@QAEJJ@Z"
);
SET
(
p_ios_flags_get
,
"?flags@ios@@QBEJXZ"
);
SET
(
p_ios_flags_get
,
"?flags@ios@@QBEJXZ"
);
SET
(
p_ios_setf
,
"?setf@ios@@QAEJJ@Z"
);
SET
(
p_ios_setf_mask
,
"?setf@ios@@QAEJJJ@Z"
);
}
}
SET
(
p_ios_static_lock
,
"?x_lockc@ios@@0U_CRT_CRITICAL_SECTION@@A"
);
SET
(
p_ios_static_lock
,
"?x_lockc@ios@@0U_CRT_CRITICAL_SECTION@@A"
);
SET
(
p_ios_lockc
,
"?lockc@ios@@KAXXZ"
);
SET
(
p_ios_lockc
,
"?lockc@ios@@KAXXZ"
);
...
@@ -1002,6 +1008,20 @@ static void test_ios(void)
...
@@ -1002,6 +1008,20 @@ static void test_ios(void)
ok
(
ret
==
0x444
,
"expected %x got %x
\n
"
,
0x444
,
ret
);
ok
(
ret
==
0x444
,
"expected %x got %x
\n
"
,
0x444
,
ret
);
ok
(
ios_obj
.
flags
==
0
,
"expected %x got %x
\n
"
,
0
,
ios_obj
.
flags
);
ok
(
ios_obj
.
flags
==
0
,
"expected %x got %x
\n
"
,
0
,
ios_obj
.
flags
);
/* setf */
ios_obj
.
do_lock
=
0
;
ios_obj
.
flags
=
0x8400
;
ret
=
(
LONG
)
call_func2
(
p_ios_setf
,
&
ios_obj
,
0x444
);
ok
(
ret
==
0x8400
,
"expected %x got %x
\n
"
,
0x8400
,
ret
);
ok
(
ios_obj
.
flags
==
0x8444
,
"expected %x got %x
\n
"
,
0x8444
,
ios_obj
.
flags
);
ret
=
(
LONG
)
call_func3
(
p_ios_setf_mask
,
&
ios_obj
,
0x111
,
0
);
ok
(
ret
==
0x8444
,
"expected %x got %x
\n
"
,
0x8444
,
ret
);
ok
(
ios_obj
.
flags
==
0x8444
,
"expected %x got %x
\n
"
,
0x8444
,
ios_obj
.
flags
);
ret
=
(
LONG
)
call_func3
(
p_ios_setf_mask
,
&
ios_obj
,
0x111
,
0x105
);
ok
(
ret
==
0x8444
,
"expected %x got %x
\n
"
,
0x8444
,
ret
);
ok
(
ios_obj
.
flags
==
0x8541
,
"expected %x got %x
\n
"
,
0x8541
,
ios_obj
.
flags
);
ios_obj
.
do_lock
=
-
1
;
SetEvent
(
lock_arg
.
release
[
0
]);
SetEvent
(
lock_arg
.
release
[
0
]);
SetEvent
(
lock_arg
.
release
[
1
]);
SetEvent
(
lock_arg
.
release
[
1
]);
SetEvent
(
lock_arg
.
release
[
2
]);
SetEvent
(
lock_arg
.
release
[
2
]);
...
...
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