msi: Fix the CHAR column type.

Signed-off-by: Hans Leidekker <hans@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Hans Leidekker 2016-02-15 10:16:12 +01:00 committed by Alexandre Julliard
parent 477b713a72
commit 7b21373bf1
2 changed files with 16 additions and 8 deletions

View File

@ -355,7 +355,7 @@ data_type_l:
data_type: data_type:
TK_CHAR TK_CHAR
{ {
$$ = MSITYPE_STRING | 1; $$ = MSITYPE_STRING | 0x400;
} }
| TK_CHAR TK_LP data_count TK_RP | TK_CHAR TK_LP data_count TK_RP
{ {

View File

@ -1286,13 +1286,15 @@ static void test_viewgetcolumninfo(void)
r = run_query( hdb, 0, r = run_query( hdb, 0,
"CREATE TABLE `Properties` " "CREATE TABLE `Properties` "
"( `Property` CHAR(255), " "( `Property` CHAR(255), "
" `Value` CHAR(1), " " `Value` CHAR(1), "
" `Intvalue` INT, " " `Intvalue` INT, "
" `Integervalue` INTEGER, " " `Integervalue` INTEGER, "
" `Shortvalue` SHORT, " " `Shortvalue` SHORT, "
" `Longvalue` LONG, " " `Longvalue` LONG, "
" `Longcharvalue` LONGCHAR " " `Longcharvalue` LONGCHAR, "
" PRIMARY KEY `Property`)" ); " `Charvalue` CHAR, "
" `Localizablevalue` CHAR LOCALIZABLE "
" PRIMARY KEY `Property`)" );
ok( r == ERROR_SUCCESS , "Failed to create table\n" ); ok( r == ERROR_SUCCESS , "Failed to create table\n" );
/* check the column types */ /* check the column types */
@ -1306,6 +1308,8 @@ static void test_viewgetcolumninfo(void)
ok( check_record( rec, 5, "I2"), "wrong record type\n"); ok( check_record( rec, 5, "I2"), "wrong record type\n");
ok( check_record( rec, 6, "I4"), "wrong record type\n"); ok( check_record( rec, 6, "I4"), "wrong record type\n");
ok( check_record( rec, 7, "S0"), "wrong record type\n"); ok( check_record( rec, 7, "S0"), "wrong record type\n");
ok( check_record( rec, 8, "S0"), "wrong record type\n");
ok( check_record( rec, 9, "L0"), "wrong record type\n");
MsiCloseHandle( rec ); MsiCloseHandle( rec );
@ -1317,6 +1321,8 @@ static void test_viewgetcolumninfo(void)
ok( 0x1502 == get_columns_table_type(hdb, "Properties", 5 ), "_columns table wrong\n"); ok( 0x1502 == get_columns_table_type(hdb, "Properties", 5 ), "_columns table wrong\n");
ok( 0x1104 == get_columns_table_type(hdb, "Properties", 6 ), "_columns table wrong\n"); ok( 0x1104 == get_columns_table_type(hdb, "Properties", 6 ), "_columns table wrong\n");
ok( 0x1d00 == get_columns_table_type(hdb, "Properties", 7 ), "_columns table wrong\n"); ok( 0x1d00 == get_columns_table_type(hdb, "Properties", 7 ), "_columns table wrong\n");
ok( 0x1d00 == get_columns_table_type(hdb, "Properties", 8 ), "_columns table wrong\n");
ok( 0x1f00 == get_columns_table_type(hdb, "Properties", 9 ), "_columns table wrong\n");
/* now try the names */ /* now try the names */
rec = get_column_info( hdb, "select * from `Properties`", MSICOLINFO_NAMES ); rec = get_column_info( hdb, "select * from `Properties`", MSICOLINFO_NAMES );
@ -1329,6 +1335,8 @@ static void test_viewgetcolumninfo(void)
ok( check_record( rec, 5, "Shortvalue"), "wrong record type\n"); ok( check_record( rec, 5, "Shortvalue"), "wrong record type\n");
ok( check_record( rec, 6, "Longvalue"), "wrong record type\n"); ok( check_record( rec, 6, "Longvalue"), "wrong record type\n");
ok( check_record( rec, 7, "Longcharvalue"), "wrong record type\n"); ok( check_record( rec, 7, "Longcharvalue"), "wrong record type\n");
ok( check_record( rec, 8, "Charvalue"), "wrong record type\n");
ok( check_record( rec, 9, "Localizablevalue"), "wrong record type\n");
MsiCloseHandle( rec ); MsiCloseHandle( rec );