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
1ba4fff9
Commit
1ba4fff9
authored
Aug 19, 2010
by
Piotr Caban
Committed by
Alexandre Julliard
Aug 20, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msvcp90: Added _String_base::Xlen implementation.
parent
8f78375d
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
113 additions
and
2 deletions
+113
-2
exception.c
dlls/msvcp90/exception.c
+99
-0
msvcp90.h
dlls/msvcp90/msvcp90.h
+2
-1
msvcp90.spec
dlls/msvcp90/msvcp90.spec
+1
-1
string.c
dlls/msvcp90/string.c
+11
-0
No files found.
dlls/msvcp90/exception.c
View file @
1ba4fff9
...
@@ -100,6 +100,7 @@ void CDECL _CxxThrowException(exception*,const cxx_exception_type*);
...
@@ -100,6 +100,7 @@ void CDECL _CxxThrowException(exception*,const cxx_exception_type*);
extern
const
vtable_ptr
MSVCP_bad_alloc_vtable
;
extern
const
vtable_ptr
MSVCP_bad_alloc_vtable
;
extern
const
vtable_ptr
MSVCP_logic_error_vtable
;
extern
const
vtable_ptr
MSVCP_logic_error_vtable
;
extern
const
vtable_ptr
MSVCP_length_error_vtable
;
/* exception class data */
/* exception class data */
static
type_info
exception_type_info
=
{
static
type_info
exception_type_info
=
{
...
@@ -427,11 +428,103 @@ static const cxx_exception_type logic_error_cxx_type = {
...
@@ -427,11 +428,103 @@ static const cxx_exception_type logic_error_cxx_type = {
&
logic_error_cxx_type_table
&
logic_error_cxx_type_table
};
};
/* length_error class data */
typedef
logic_error
length_error
;
DEFINE_THISCALL_WRAPPER
(
MSVCP_length_error_ctor
,
8
)
length_error
*
__stdcall
MSVCP_length_error_ctor
(
length_error
*
this
,
const
char
**
name
)
{
TRACE
(
"%p %s
\n
"
,
this
,
*
name
);
MSVCP_logic_error_ctor
(
this
,
name
);
this
->
e
.
vtable
=
&
MSVCP_length_error_vtable
;
return
this
;
}
DEFINE_THISCALL_WRAPPER
(
MSVCP_length_error_copy_ctor
,
8
)
length_error
*
__stdcall
MSVCP_length_error_copy_ctor
(
length_error
*
this
,
length_error
*
rhs
)
{
TRACE
(
"%p %p
\n
"
,
this
,
rhs
);
MSVCP_logic_error_copy_ctor
(
this
,
rhs
);
this
->
e
.
vtable
=
&
MSVCP_length_error_vtable
;
return
this
;
}
DEFINE_THISCALL_WRAPPER
(
MSVCP_length_error_vector_dtor
,
8
)
void
*
__stdcall
MSVCP_length_error_vector_dtor
(
length_error
*
this
,
unsigned
int
flags
)
{
TRACE
(
"%p %x
\n
"
,
this
,
flags
);
return
MSVCP_logic_error_vector_dtor
(
this
,
flags
);
}
static
const
type_info
length_error_type_info
=
{
&
MSVCP_length_error_vtable
,
NULL
,
".?AVlength_error@std@@"
};
static
const
rtti_base_descriptor
length_error_rtti_base_descriptor
=
{
&
length_error_type_info
,
2
,
{
0
,
-
1
,
0
},
64
};
static
const
rtti_base_array
length_error_rtti_base_array
=
{
{
&
length_error_rtti_base_descriptor
,
&
logic_error_rtti_base_descriptor
,
&
exception_rtti_base_descriptor
}
};
static
const
rtti_object_hierarchy
length_error_type_hierarchy
=
{
0
,
0
,
3
,
&
length_error_rtti_base_array
};
const
rtti_object_locator
length_error_rtti
=
{
0
,
0
,
0
,
&
length_error_type_info
,
&
length_error_type_hierarchy
};
static
const
cxx_type_info
length_error_cxx_type_info
=
{
0
,
&
length_error_type_info
,
{
0
,
-
1
,
0
},
sizeof
(
length_error
),
(
cxx_copy_ctor
)
THISCALL
(
MSVCP_length_error_copy_ctor
)
};
static
const
cxx_type_info_table
length_error_cxx_type_table
=
{
3
,
{
&
length_error_cxx_type_info
,
&
logic_error_cxx_type_info
,
&
exception_cxx_type_info
}
};
static
const
cxx_exception_type
length_error_cxx_type
=
{
0
,
(
cxx_copy_ctor
)
THISCALL
(
MSVCP_logic_error_dtor
),
NULL
,
&
length_error_cxx_type_table
};
#ifndef __GNUC__
#ifndef __GNUC__
void
__asm_dummy_vtables
(
void
)
{
void
__asm_dummy_vtables
(
void
)
{
#endif
#endif
__ASM_EXCEPTION_VTABLE
(
bad_alloc
)
__ASM_EXCEPTION_VTABLE
(
bad_alloc
)
__ASM_EXCEPTION_STRING_VTABLE
(
logic_error
)
__ASM_EXCEPTION_STRING_VTABLE
(
logic_error
)
__ASM_EXCEPTION_STRING_VTABLE
(
length_error
)
#ifndef __GNUC__
#ifndef __GNUC__
}
}
#endif
#endif
...
@@ -460,5 +553,11 @@ void throw_exception(exception_type et, const char *str)
...
@@ -460,5 +553,11 @@ void throw_exception(exception_type et, const char *str)
_CxxThrowException
((
exception
*
)
&
e
,
&
logic_error_cxx_type
);
_CxxThrowException
((
exception
*
)
&
e
,
&
logic_error_cxx_type
);
return
;
return
;
}
}
case
EXCEPTION_LENGTH_ERROR
:
{
length_error
e
;
MSVCP_length_error_ctor
(
&
e
,
&
addr
);
_CxxThrowException
((
exception
*
)
&
e
,
&
length_error_cxx_type
);
return
;
}
}
}
}
}
dlls/msvcp90/msvcp90.h
View file @
1ba4fff9
...
@@ -60,7 +60,8 @@ typedef struct __exception
...
@@ -60,7 +60,8 @@ typedef struct __exception
typedef
enum
__exception_type
{
typedef
enum
__exception_type
{
EXCEPTION
,
EXCEPTION
,
EXCEPTION_BAD_ALLOC
,
EXCEPTION_BAD_ALLOC
,
EXCEPTION_LOGIC_ERROR
EXCEPTION_LOGIC_ERROR
,
EXCEPTION_LENGTH_ERROR
}
exception_type
;
}
exception_type
;
void
throw_exception
(
exception_type
,
const
char
*
);
void
throw_exception
(
exception_type
,
const
char
*
);
void
set_exception_vtable
(
void
);
void
set_exception_vtable
(
void
);
...
...
dlls/msvcp90/msvcp90.spec
View file @
1ba4fff9
...
@@ -2878,7 +2878,7 @@
...
@@ -2878,7 +2878,7 @@
@ stub -arch=win32 ?_Xinvalid@tr1@std@@YAXPBD@Z
@ stub -arch=win32 ?_Xinvalid@tr1@std@@YAXPBD@Z
@ stub -arch=win64 ?_Xinvalid@tr1@std@@YAXPEBD@Z
@ stub -arch=win64 ?_Xinvalid@tr1@std@@YAXPEBD@Z
@ stub ?_Xinvarg@_String_base@std@@SAXXZ
@ stub ?_Xinvarg@_String_base@std@@SAXXZ
@
stub ?_Xlen@_String_base@std@@SAXXZ
@
cdecl ?_Xlen@_String_base@std@@SAXXZ() MSVCP__String_base_Xlen
@ stub ?_Xmem@tr1@std@@YAXXZ
@ stub ?_Xmem@tr1@std@@YAXXZ
@ stub ?_Xoutrange@tr1@std@@YAXXZ
@ stub ?_Xoutrange@tr1@std@@YAXXZ
@ stub ?_Xran@_String_base@std@@SAXXZ
@ stub ?_Xran@_String_base@std@@SAXXZ
...
...
dlls/msvcp90/string.c
View file @
1ba4fff9
...
@@ -466,6 +466,17 @@ unsigned short CDECL MSVCP_char_traits_short_not_eof(const unsigned short *in)
...
@@ -466,6 +466,17 @@ unsigned short CDECL MSVCP_char_traits_short_not_eof(const unsigned short *in)
}
}
/* _String_base */
/* ?_Xlen@_String_base@std@@SAXXZ */
void
CDECL
MSVCP__String_base_Xlen
(
void
)
{
static
const
char
msg
[]
=
"string too long"
;
TRACE
(
"
\n
"
);
throw_exception
(
EXCEPTION_LENGTH_ERROR
,
msg
);
}
/* basic_string<char, char_traits<char>, allocator<char>> */
/* basic_string<char, char_traits<char>, allocator<char>> */
/* ?npos@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@2IB */
/* ?npos@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@2IB */
const
size_t
MSVCP_basic_string_char_npos
=
-
1
;
const
size_t
MSVCP_basic_string_char_npos
=
-
1
;
...
...
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