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
7c1580a4
Commit
7c1580a4
authored
Nov 06, 2014
by
Alex Henrie
Committed by
Alexandre Julliard
Nov 06, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
kernel32/tests: Add UTF-7 non-encoded surrounding characters tests.
parent
4dea0b25
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
73 additions
and
0 deletions
+73
-0
codepage.c
dlls/kernel32/tests/codepage.c
+73
-0
No files found.
dlls/kernel32/tests/codepage.c
View file @
7c1580a4
...
...
@@ -20,6 +20,7 @@
*/
#include <stdarg.h>
#include <stdio.h>
#include <limits.h>
#include "wine/test.h"
...
...
@@ -412,6 +413,76 @@ static void test_string_conversion(LPBOOL bUsedDefaultChar)
ok
(
GetLastError
()
==
0xdeadbeef
,
"GetLastError() is %u
\n
"
,
GetLastError
());
}
static
void
test_utf7_encoding
(
void
)
{
WCHAR
input
[
16
];
char
output
[
16
],
expected
[
16
];
int
i
,
len
,
expected_len
;
static
const
BOOL
directly_encodable_table
[]
=
{
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
1
,
0
,
0
,
1
,
0
,
0
,
/* 0x00 - 0x0F */
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
/* 0x10 - 0x1F */
1
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
1
,
1
,
0
,
1
,
1
,
1
,
1
,
1
,
/* 0x20 - 0x2F */
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
0
,
0
,
0
,
0
,
1
,
/* 0x30 - 0x3F */
0
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
/* 0x40 - 0x4F */
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
0
,
0
,
0
,
0
,
0
,
/* 0x50 - 0x5F */
0
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
/* 0x60 - 0x6F */
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
1
,
0
,
0
,
0
,
0
,
0
/* 0x70 - 0x7F */
};
static
const
char
base64_encoding_table
[]
=
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
;
if
(
WideCharToMultiByte
(
CP_UTF7
,
0
,
foobarW
,
-
1
,
NULL
,
0
,
NULL
,
NULL
)
==
0
&&
GetLastError
()
==
ERROR_CALL_NOT_IMPLEMENTED
)
{
skip
(
"UTF-7 encoding not implemented
\n
"
);
return
;
}
/* test which characters are encoded if surrounded by non-encoded characters */
for
(
i
=
0
;
i
<=
0xFFFF
;
i
++
)
{
input
[
0
]
=
' '
;
input
[
1
]
=
i
;
input
[
2
]
=
' '
;
input
[
3
]
=
0
;
memset
(
output
,
'#'
,
sizeof
(
output
)
-
1
);
output
[
sizeof
(
output
)
-
1
]
=
0
;
len
=
WideCharToMultiByte
(
CP_UTF7
,
0
,
input
,
4
,
output
,
sizeof
(
output
)
-
1
,
NULL
,
NULL
);
if
(
i
==
'+'
)
{
/* '+' is a special case and is encoded as "+-" */
expected_len
=
5
;
strcpy
(
expected
,
" +- "
);
}
else
if
(
i
<=
0x7F
&&
directly_encodable_table
[
i
])
{
/* encodes directly */
expected_len
=
4
;
sprintf
(
expected
,
" %c "
,
i
);
}
else
{
/* base64-encodes */
expected_len
=
8
;
sprintf
(
expected
,
" +%c%c%c- "
,
base64_encoding_table
[(
i
&
0xFC00
)
>>
10
],
base64_encoding_table
[(
i
&
0x03F0
)
>>
4
],
base64_encoding_table
[(
i
&
0x000F
)
<<
2
]);
}
ok
(
len
==
expected_len
,
"i=0x%04x: expected len=%i, got len=%i
\n
"
,
i
,
expected_len
,
len
);
ok
(
memcmp
(
output
,
expected
,
expected_len
)
==
0
,
"i=0x%04x: expected output='%s', got output='%s'
\n
"
,
i
,
expected
,
output
);
ok
(
output
[
expected_len
]
==
'#'
,
"i=0x%04x: expected output[%i]='#', got output[%i]=%i
\n
"
,
i
,
expected_len
,
expected_len
,
output
[
expected_len
]);
}
}
static
void
test_undefined_byte_char
(
void
)
{
static
const
struct
tag_testset
{
...
...
@@ -618,6 +689,8 @@ START_TEST(codepage)
test_string_conversion
(
NULL
);
test_string_conversion
(
&
bUsedDefaultChar
);
test_utf7_encoding
();
test_undefined_byte_char
();
test_threadcp
();
}
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