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
c9b3bc11
Commit
c9b3bc11
authored
Mar 01, 2009
by
James Hawkins
Committed by
Alexandre Julliard
Mar 02, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Column attributes for temporary string and int columns should be g and j respectively.
parent
c07b554e
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
84 additions
and
54 deletions
+84
-54
alter.c
dlls/msi/alter.c
+2
-2
create.c
dlls/msi/create.c
+2
-2
delete.c
dlls/msi/delete.c
+4
-3
distinct.c
dlls/msi/distinct.c
+4
-3
insert.c
dlls/msi/insert.c
+8
-8
join.c
dlls/msi/join.c
+4
-3
msipriv.h
dlls/msi/msipriv.h
+1
-1
msiquery.c
dlls/msi/msiquery.c
+20
-7
select.c
dlls/msi/select.c
+5
-4
storages.c
dlls/msi/storages.c
+6
-3
streams.c
dlls/msi/streams.c
+6
-3
table.c
dlls/msi/table.c
+12
-6
db.c
dlls/msi/tests/db.c
+2
-2
update.c
dlls/msi/update.c
+3
-3
where.c
dlls/msi/where.c
+5
-4
No files found.
dlls/msi/alter.c
View file @
c9b3bc11
...
@@ -183,11 +183,11 @@ static UINT ALTER_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *col
...
@@ -183,11 +183,11 @@ static UINT ALTER_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *col
}
}
static
UINT
ALTER_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
ALTER_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIALTERVIEW
*
av
=
(
MSIALTERVIEW
*
)
view
;
MSIALTERVIEW
*
av
=
(
MSIALTERVIEW
*
)
view
;
TRACE
(
"%p %d %p %p
\n
"
,
av
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
av
,
n
,
name
,
type
,
temporary
);
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
}
}
...
...
dlls/msi/create.c
View file @
c9b3bc11
...
@@ -91,11 +91,11 @@ static UINT CREATE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
...
@@ -91,11 +91,11 @@ static UINT CREATE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
}
}
static
UINT
CREATE_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
CREATE_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSICREATEVIEW
*
cv
=
(
MSICREATEVIEW
*
)
view
;
MSICREATEVIEW
*
cv
=
(
MSICREATEVIEW
*
)
view
;
TRACE
(
"%p %d %p %p
\n
"
,
cv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
cv
,
n
,
name
,
type
,
temporary
);
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
}
}
...
...
dlls/msi/delete.c
View file @
c9b3bc11
...
@@ -127,16 +127,17 @@ static UINT DELETE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
...
@@ -127,16 +127,17 @@ static UINT DELETE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
}
}
static
UINT
DELETE_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
DELETE_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIDELETEVIEW
*
dv
=
(
MSIDELETEVIEW
*
)
view
;
MSIDELETEVIEW
*
dv
=
(
MSIDELETEVIEW
*
)
view
;
TRACE
(
"%p %d %p %p
\n
"
,
dv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
dv
,
n
,
name
,
type
,
temporary
);
if
(
!
dv
->
table
)
if
(
!
dv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
return
dv
->
table
->
ops
->
get_column_info
(
dv
->
table
,
n
,
name
,
type
);
return
dv
->
table
->
ops
->
get_column_info
(
dv
->
table
,
n
,
name
,
type
,
temporary
);
}
}
static
UINT
DELETE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
static
UINT
DELETE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
...
...
dlls/msi/distinct.c
View file @
c9b3bc11
...
@@ -205,16 +205,17 @@ static UINT DISTINCT_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *
...
@@ -205,16 +205,17 @@ static UINT DISTINCT_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *
}
}
static
UINT
DISTINCT_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
DISTINCT_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIDISTINCTVIEW
*
dv
=
(
MSIDISTINCTVIEW
*
)
view
;
MSIDISTINCTVIEW
*
dv
=
(
MSIDISTINCTVIEW
*
)
view
;
TRACE
(
"%p %d %p %p
\n
"
,
dv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
dv
,
n
,
name
,
type
,
temporary
);
if
(
!
dv
->
table
)
if
(
!
dv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
return
dv
->
table
->
ops
->
get_column_info
(
dv
->
table
,
n
,
name
,
type
);
return
dv
->
table
->
ops
->
get_column_info
(
dv
->
table
,
n
,
name
,
type
,
temporary
);
}
}
static
UINT
DISTINCT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
static
UINT
DISTINCT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
...
...
dlls/msi/insert.c
View file @
c9b3bc11
...
@@ -114,8 +114,8 @@ static BOOL msi_columns_in_order(MSIINSERTVIEW *iv, UINT col_count)
...
@@ -114,8 +114,8 @@ static BOOL msi_columns_in_order(MSIINSERTVIEW *iv, UINT col_count)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
{
{
iv
->
sv
->
ops
->
get_column_info
(
iv
->
sv
,
i
,
&
a
,
NULL
);
iv
->
sv
->
ops
->
get_column_info
(
iv
->
sv
,
i
,
&
a
,
NULL
,
NULL
);
iv
->
table
->
ops
->
get_column_info
(
iv
->
table
,
i
,
&
b
,
NULL
);
iv
->
table
->
ops
->
get_column_info
(
iv
->
table
,
i
,
&
b
,
NULL
,
NULL
);
res
=
lstrcmpW
(
a
,
b
);
res
=
lstrcmpW
(
a
,
b
);
msi_free
(
a
);
msi_free
(
a
);
...
@@ -157,13 +157,13 @@ static UINT msi_arrange_record(MSIINSERTVIEW *iv, MSIRECORD **values)
...
@@ -157,13 +157,13 @@ static UINT msi_arrange_record(MSIINSERTVIEW *iv, MSIRECORD **values)
for
(
colidx
=
1
;
colidx
<=
val_count
;
colidx
++
)
for
(
colidx
=
1
;
colidx
<=
val_count
;
colidx
++
)
{
{
r
=
iv
->
sv
->
ops
->
get_column_info
(
iv
->
sv
,
colidx
,
&
a
,
NULL
);
r
=
iv
->
sv
->
ops
->
get_column_info
(
iv
->
sv
,
colidx
,
&
a
,
NULL
,
NULL
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
goto
err
;
goto
err
;
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
{
{
r
=
iv
->
table
->
ops
->
get_column_info
(
iv
->
table
,
i
,
&
b
,
NULL
);
r
=
iv
->
table
->
ops
->
get_column_info
(
iv
->
table
,
i
,
&
b
,
NULL
,
NULL
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
goto
err
;
goto
err
;
...
@@ -200,7 +200,7 @@ static BOOL row_has_null_primary_keys(MSIINSERTVIEW *iv, MSIRECORD *row)
...
@@ -200,7 +200,7 @@ static BOOL row_has_null_primary_keys(MSIINSERTVIEW *iv, MSIRECORD *row)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
{
{
r
=
iv
->
table
->
ops
->
get_column_info
(
iv
->
table
,
i
,
NULL
,
&
type
);
r
=
iv
->
table
->
ops
->
get_column_info
(
iv
->
table
,
i
,
NULL
,
&
type
,
NULL
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
return
FALSE
;
return
FALSE
;
...
@@ -291,18 +291,18 @@ static UINT INSERT_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
...
@@ -291,18 +291,18 @@ static UINT INSERT_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
}
}
static
UINT
INSERT_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
INSERT_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIINSERTVIEW
*
iv
=
(
MSIINSERTVIEW
*
)
view
;
MSIINSERTVIEW
*
iv
=
(
MSIINSERTVIEW
*
)
view
;
MSIVIEW
*
sv
;
MSIVIEW
*
sv
;
TRACE
(
"%p %d %p %p
\n
"
,
iv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
iv
,
n
,
name
,
type
,
temporary
);
sv
=
iv
->
sv
;
sv
=
iv
->
sv
;
if
(
!
sv
)
if
(
!
sv
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
return
sv
->
ops
->
get_column_info
(
sv
,
n
,
name
,
type
);
return
sv
->
ops
->
get_column_info
(
sv
,
n
,
name
,
type
,
temporary
);
}
}
static
UINT
INSERT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
,
UINT
row
)
static
UINT
INSERT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
,
UINT
row
)
...
...
dlls/msi/join.c
View file @
c9b3bc11
...
@@ -194,13 +194,13 @@ static UINT JOIN_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *cols
...
@@ -194,13 +194,13 @@ static UINT JOIN_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *cols
}
}
static
UINT
JOIN_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
JOIN_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIJOINVIEW
*
jv
=
(
MSIJOINVIEW
*
)
view
;
MSIJOINVIEW
*
jv
=
(
MSIJOINVIEW
*
)
view
;
JOINTABLE
*
table
;
JOINTABLE
*
table
;
UINT
cols
=
0
;
UINT
cols
=
0
;
TRACE
(
"%p %d %p %p
\n
"
,
jv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
jv
,
n
,
name
,
type
,
temporary
);
if
(
n
==
0
||
n
>
jv
->
columns
)
if
(
n
==
0
||
n
>
jv
->
columns
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
...
@@ -208,7 +208,8 @@ static UINT JOIN_get_column_info( struct tagMSIVIEW *view,
...
@@ -208,7 +208,8 @@ static UINT JOIN_get_column_info( struct tagMSIVIEW *view,
LIST_FOR_EACH_ENTRY
(
table
,
&
jv
->
tables
,
JOINTABLE
,
entry
)
LIST_FOR_EACH_ENTRY
(
table
,
&
jv
->
tables
,
JOINTABLE
,
entry
)
{
{
if
(
n
<=
cols
+
table
->
columns
)
if
(
n
<=
cols
+
table
->
columns
)
return
table
->
view
->
ops
->
get_column_info
(
table
->
view
,
n
-
cols
,
name
,
type
);
return
table
->
view
->
ops
->
get_column_info
(
table
->
view
,
n
-
cols
,
name
,
type
,
temporary
);
cols
+=
table
->
columns
;
cols
+=
table
->
columns
;
}
}
...
...
dlls/msi/msipriv.h
View file @
c9b3bc11
...
@@ -231,7 +231,7 @@ typedef struct tagMSIVIEWOPS
...
@@ -231,7 +231,7 @@ typedef struct tagMSIVIEWOPS
* the caller.
* the caller.
* The column information can be queried at any time.
* The column information can be queried at any time.
*/
*/
UINT
(
*
get_column_info
)(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
);
UINT
(
*
get_column_info
)(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
);
/*
/*
* modify - not yet implemented properly
* modify - not yet implemented properly
...
...
dlls/msi/msiquery.c
View file @
c9b3bc11
...
@@ -70,7 +70,7 @@ UINT VIEW_find_column( MSIVIEW *table, LPCWSTR name, UINT *n )
...
@@ -70,7 +70,7 @@ UINT VIEW_find_column( MSIVIEW *table, LPCWSTR name, UINT *n )
INT
x
;
INT
x
;
col_name
=
NULL
;
col_name
=
NULL
;
r
=
table
->
ops
->
get_column_info
(
table
,
i
,
&
col_name
,
NULL
);
r
=
table
->
ops
->
get_column_info
(
table
,
i
,
&
col_name
,
NULL
,
NULL
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
return
r
;
return
r
;
x
=
lstrcmpW
(
name
,
col_name
);
x
=
lstrcmpW
(
name
,
col_name
);
...
@@ -308,7 +308,7 @@ UINT msi_view_get_row(MSIDATABASE *db, MSIVIEW *view, UINT row, MSIRECORD **rec)
...
@@ -308,7 +308,7 @@ UINT msi_view_get_row(MSIDATABASE *db, MSIVIEW *view, UINT row, MSIRECORD **rec)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
{
{
ret
=
view
->
ops
->
get_column_info
(
view
,
i
,
NULL
,
&
type
);
ret
=
view
->
ops
->
get_column_info
(
view
,
i
,
NULL
,
&
type
,
NULL
);
if
(
ret
)
if
(
ret
)
{
{
ERR
(
"Error getting column type for %d
\n
"
,
i
);
ERR
(
"Error getting column type for %d
\n
"
,
i
);
...
@@ -493,7 +493,8 @@ out:
...
@@ -493,7 +493,8 @@ out:
return
ret
;
return
ret
;
}
}
static
UINT
msi_set_record_type_string
(
MSIRECORD
*
rec
,
UINT
field
,
UINT
type
)
static
UINT
msi_set_record_type_string
(
MSIRECORD
*
rec
,
UINT
field
,
UINT
type
,
BOOL
temporary
)
{
{
static
const
WCHAR
fmt
[]
=
{
'%'
,
'd'
,
0
};
static
const
WCHAR
fmt
[]
=
{
'%'
,
'd'
,
0
};
WCHAR
szType
[
0x10
];
WCHAR
szType
[
0x10
];
...
@@ -503,9 +504,20 @@ static UINT msi_set_record_type_string( MSIRECORD *rec, UINT field, UINT type )
...
@@ -503,9 +504,20 @@ static UINT msi_set_record_type_string( MSIRECORD *rec, UINT field, UINT type )
else
if
(
type
&
MSITYPE_LOCALIZABLE
)
else
if
(
type
&
MSITYPE_LOCALIZABLE
)
szType
[
0
]
=
'l'
;
szType
[
0
]
=
'l'
;
else
if
(
type
&
MSITYPE_STRING
)
else
if
(
type
&
MSITYPE_STRING
)
szType
[
0
]
=
's'
;
{
if
(
temporary
)
szType
[
0
]
=
'g'
;
else
szType
[
0
]
=
's'
;
}
else
else
szType
[
0
]
=
'i'
;
{
if
(
temporary
)
szType
[
0
]
=
'j'
;
else
szType
[
0
]
=
'i'
;
}
if
(
type
&
MSITYPE_NULLABLE
)
if
(
type
&
MSITYPE_NULLABLE
)
szType
[
0
]
&=
~
0x20
;
szType
[
0
]
&=
~
0x20
;
...
@@ -522,6 +534,7 @@ UINT MSI_ViewGetColumnInfo( MSIQUERY *query, MSICOLINFO info, MSIRECORD **prec )
...
@@ -522,6 +534,7 @@ UINT MSI_ViewGetColumnInfo( MSIQUERY *query, MSICOLINFO info, MSIRECORD **prec )
MSIRECORD
*
rec
;
MSIRECORD
*
rec
;
MSIVIEW
*
view
=
query
->
view
;
MSIVIEW
*
view
=
query
->
view
;
LPWSTR
name
;
LPWSTR
name
;
BOOL
temporary
;
if
(
!
view
)
if
(
!
view
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
...
@@ -542,13 +555,13 @@ UINT MSI_ViewGetColumnInfo( MSIQUERY *query, MSICOLINFO info, MSIRECORD **prec )
...
@@ -542,13 +555,13 @@ UINT MSI_ViewGetColumnInfo( MSIQUERY *query, MSICOLINFO info, MSIRECORD **prec )
for
(
i
=
0
;
i
<
count
;
i
++
)
for
(
i
=
0
;
i
<
count
;
i
++
)
{
{
name
=
NULL
;
name
=
NULL
;
r
=
view
->
ops
->
get_column_info
(
view
,
i
+
1
,
&
name
,
&
type
);
r
=
view
->
ops
->
get_column_info
(
view
,
i
+
1
,
&
name
,
&
type
,
&
temporary
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
continue
;
continue
;
if
(
info
==
MSICOLINFO_NAMES
)
if
(
info
==
MSICOLINFO_NAMES
)
MSI_RecordSetStringW
(
rec
,
i
+
1
,
name
);
MSI_RecordSetStringW
(
rec
,
i
+
1
,
name
);
else
else
msi_set_record_type_string
(
rec
,
i
+
1
,
type
);
msi_set_record_type_string
(
rec
,
i
+
1
,
type
,
temporary
);
msi_free
(
name
);
msi_free
(
name
);
}
}
...
...
dlls/msi/select.c
View file @
c9b3bc11
...
@@ -209,11 +209,11 @@ static UINT SELECT_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
...
@@ -209,11 +209,11 @@ static UINT SELECT_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
}
}
static
UINT
SELECT_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
SELECT_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSISELECTVIEW
*
sv
=
(
MSISELECTVIEW
*
)
view
;
MSISELECTVIEW
*
sv
=
(
MSISELECTVIEW
*
)
view
;
TRACE
(
"%p %d %p %p
\n
"
,
sv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
sv
,
n
,
name
,
type
,
temporary
);
if
(
!
sv
->
table
)
if
(
!
sv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
...
@@ -223,7 +223,8 @@ static UINT SELECT_get_column_info( struct tagMSIVIEW *view,
...
@@ -223,7 +223,8 @@ static UINT SELECT_get_column_info( struct tagMSIVIEW *view,
n
=
sv
->
cols
[
n
-
1
];
n
=
sv
->
cols
[
n
-
1
];
return
sv
->
table
->
ops
->
get_column_info
(
sv
->
table
,
n
,
name
,
type
);
return
sv
->
table
->
ops
->
get_column_info
(
sv
->
table
,
n
,
name
,
type
,
temporary
);
}
}
static
UINT
msi_select_update
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
rec
,
UINT
row
)
static
UINT
msi_select_update
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
rec
,
UINT
row
)
...
@@ -246,7 +247,7 @@ static UINT msi_select_update(struct tagMSIVIEW *view, MSIRECORD *rec, UINT row)
...
@@ -246,7 +247,7 @@ static UINT msi_select_update(struct tagMSIVIEW *view, MSIRECORD *rec, UINT row)
{
{
col
=
sv
->
cols
[
i
];
col
=
sv
->
cols
[
i
];
r
=
SELECT_get_column_info
(
view
,
i
+
1
,
&
name
,
&
type
);
r
=
SELECT_get_column_info
(
view
,
i
+
1
,
&
name
,
&
type
,
NULL
);
msi_free
(
name
);
msi_free
(
name
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
{
{
...
...
dlls/msi/storages.c
View file @
c9b3bc11
...
@@ -288,15 +288,15 @@ static UINT STORAGES_get_dimensions(struct tagMSIVIEW *view, UINT *rows, UINT *c
...
@@ -288,15 +288,15 @@ static UINT STORAGES_get_dimensions(struct tagMSIVIEW *view, UINT *rows, UINT *c
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
static
UINT
STORAGES_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
STORAGES_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
LPCWSTR
name_ptr
=
NULL
;
LPCWSTR
name_ptr
=
NULL
;
static
const
WCHAR
Name
[]
=
{
'N'
,
'a'
,
'm'
,
'e'
,
0
};
static
const
WCHAR
Name
[]
=
{
'N'
,
'a'
,
'm'
,
'e'
,
0
};
static
const
WCHAR
Data
[]
=
{
'D'
,
'a'
,
't'
,
'a'
,
0
};
static
const
WCHAR
Data
[]
=
{
'D'
,
'a'
,
't'
,
'a'
,
0
};
TRACE
(
"(%p, %d, %p, %p
)
\n
"
,
view
,
n
,
name
,
type
);
TRACE
(
"(%p, %d, %p, %p
, %p)
\n
"
,
view
,
n
,
name
,
type
,
temporary
);
if
(
n
==
0
||
n
>
NUM_STORAGES_COLS
)
if
(
n
==
0
||
n
>
NUM_STORAGES_COLS
)
return
ERROR_INVALID_PARAMETER
;
return
ERROR_INVALID_PARAMETER
;
...
@@ -320,6 +320,9 @@ static UINT STORAGES_get_column_info(struct tagMSIVIEW *view,
...
@@ -320,6 +320,9 @@ static UINT STORAGES_get_column_info(struct tagMSIVIEW *view,
if
(
!*
name
)
return
ERROR_FUNCTION_FAILED
;
if
(
!*
name
)
return
ERROR_FUNCTION_FAILED
;
}
}
if
(
temporary
)
*
temporary
=
FALSE
;
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
...
...
dlls/msi/streams.c
View file @
c9b3bc11
...
@@ -254,15 +254,15 @@ static UINT STREAMS_get_dimensions(struct tagMSIVIEW *view, UINT *rows, UINT *co
...
@@ -254,15 +254,15 @@ static UINT STREAMS_get_dimensions(struct tagMSIVIEW *view, UINT *rows, UINT *co
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
static
UINT
STREAMS_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
STREAMS_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
LPCWSTR
name_ptr
=
NULL
;
LPCWSTR
name_ptr
=
NULL
;
static
const
WCHAR
Name
[]
=
{
'N'
,
'a'
,
'm'
,
'e'
,
0
};
static
const
WCHAR
Name
[]
=
{
'N'
,
'a'
,
'm'
,
'e'
,
0
};
static
const
WCHAR
Data
[]
=
{
'D'
,
'a'
,
't'
,
'a'
,
0
};
static
const
WCHAR
Data
[]
=
{
'D'
,
'a'
,
't'
,
'a'
,
0
};
TRACE
(
"(%p, %d, %p, %p
)
\n
"
,
view
,
n
,
name
,
type
);
TRACE
(
"(%p, %d, %p, %p
, %p)
\n
"
,
view
,
n
,
name
,
type
,
temporary
);
if
(
n
==
0
||
n
>
NUM_STREAMS_COLS
)
if
(
n
==
0
||
n
>
NUM_STREAMS_COLS
)
return
ERROR_INVALID_PARAMETER
;
return
ERROR_INVALID_PARAMETER
;
...
@@ -286,6 +286,9 @@ static UINT STREAMS_get_column_info(struct tagMSIVIEW *view,
...
@@ -286,6 +286,9 @@ static UINT STREAMS_get_column_info(struct tagMSIVIEW *view,
if
(
!*
name
)
return
ERROR_FUNCTION_FAILED
;
if
(
!*
name
)
return
ERROR_FUNCTION_FAILED
;
}
}
if
(
temporary
)
*
temporary
=
FALSE
;
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
...
...
dlls/msi/table.c
View file @
c9b3bc11
...
@@ -59,6 +59,7 @@ typedef struct tagMSICOLUMNINFO
...
@@ -59,6 +59,7 @@ typedef struct tagMSICOLUMNINFO
UINT
type
;
UINT
type
;
UINT
offset
;
UINT
offset
;
INT
ref_count
;
INT
ref_count
;
BOOL
temporary
;
MSICOLUMNHASHENTRY
**
hash_table
;
MSICOLUMNHASHENTRY
**
hash_table
;
}
MSICOLUMNINFO
;
}
MSICOLUMNINFO
;
...
@@ -102,14 +103,14 @@ static WCHAR szNumber[] = { 'N','u','m','b','e','r',0 };
...
@@ -102,14 +103,14 @@ static WCHAR szNumber[] = { 'N','u','m','b','e','r',0 };
static
WCHAR
szType
[]
=
{
'T'
,
'y'
,
'p'
,
'e'
,
0
};
static
WCHAR
szType
[]
=
{
'T'
,
'y'
,
'p'
,
'e'
,
0
};
static
const
MSICOLUMNINFO
_Columns_cols
[
4
]
=
{
static
const
MSICOLUMNINFO
_Columns_cols
[
4
]
=
{
{
szColumns
,
1
,
szTable
,
MSITYPE_VALID
|
MSITYPE_STRING
|
MSITYPE_KEY
|
64
,
0
,
0
,
NULL
},
{
szColumns
,
1
,
szTable
,
MSITYPE_VALID
|
MSITYPE_STRING
|
MSITYPE_KEY
|
64
,
0
,
0
,
0
,
NULL
},
{
szColumns
,
2
,
szNumber
,
MSITYPE_VALID
|
MSITYPE_KEY
|
2
,
2
,
0
,
NULL
},
{
szColumns
,
2
,
szNumber
,
MSITYPE_VALID
|
MSITYPE_KEY
|
2
,
2
,
0
,
0
,
NULL
},
{
szColumns
,
3
,
szName
,
MSITYPE_VALID
|
MSITYPE_STRING
|
64
,
4
,
0
,
NULL
},
{
szColumns
,
3
,
szName
,
MSITYPE_VALID
|
MSITYPE_STRING
|
64
,
4
,
0
,
0
,
NULL
},
{
szColumns
,
4
,
szType
,
MSITYPE_VALID
|
2
,
6
,
0
,
NULL
},
{
szColumns
,
4
,
szType
,
MSITYPE_VALID
|
2
,
6
,
0
,
0
,
NULL
},
};
};
static
const
MSICOLUMNINFO
_Tables_cols
[
1
]
=
{
static
const
MSICOLUMNINFO
_Tables_cols
[
1
]
=
{
{
szTables
,
1
,
szName
,
MSITYPE_VALID
|
MSITYPE_STRING
|
MSITYPE_KEY
|
64
,
0
,
0
,
NULL
},
{
szTables
,
1
,
szName
,
MSITYPE_VALID
|
MSITYPE_STRING
|
MSITYPE_KEY
|
64
,
0
,
0
,
0
,
NULL
},
};
};
#define MAX_STREAM_NAME 0x1f
#define MAX_STREAM_NAME 0x1f
...
@@ -659,6 +660,7 @@ UINT msi_create_table( MSIDATABASE *db, LPCWSTR name, column_info *col_info,
...
@@ -659,6 +660,7 @@ UINT msi_create_table( MSIDATABASE *db, LPCWSTR name, column_info *col_info,
table
->
colinfo
[
i
].
offset
=
0
;
table
->
colinfo
[
i
].
offset
=
0
;
table
->
colinfo
[
i
].
ref_count
=
0
;
table
->
colinfo
[
i
].
ref_count
=
0
;
table
->
colinfo
[
i
].
hash_table
=
NULL
;
table
->
colinfo
[
i
].
hash_table
=
NULL
;
table
->
colinfo
[
i
].
temporary
=
col
->
temporary
;
}
}
table_calc_column_offsets
(
db
,
table
->
colinfo
,
table
->
col_count
);
table_calc_column_offsets
(
db
,
table
->
colinfo
,
table
->
col_count
);
...
@@ -1438,7 +1440,7 @@ static UINT TABLE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *col
...
@@ -1438,7 +1440,7 @@ static UINT TABLE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *col
}
}
static
UINT
TABLE_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
TABLE_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSITABLEVIEW
*
tv
=
(
MSITABLEVIEW
*
)
view
;
MSITABLEVIEW
*
tv
=
(
MSITABLEVIEW
*
)
view
;
...
@@ -1453,9 +1455,13 @@ static UINT TABLE_get_column_info( struct tagMSIVIEW *view,
...
@@ -1453,9 +1455,13 @@ static UINT TABLE_get_column_info( struct tagMSIVIEW *view,
if
(
!*
name
)
if
(
!*
name
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
}
}
if
(
type
)
if
(
type
)
*
type
=
tv
->
columns
[
n
-
1
].
type
;
*
type
=
tv
->
columns
[
n
-
1
].
type
;
if
(
temporary
)
*
temporary
=
tv
->
columns
[
n
-
1
].
temporary
;
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
...
...
dlls/msi/tests/db.c
View file @
c9b3bc11
...
@@ -3309,12 +3309,12 @@ static void test_temporary_table(void)
...
@@ -3309,12 +3309,12 @@ static void test_temporary_table(void)
sz
=
sizeof
buf
;
sz
=
sizeof
buf
;
r
=
MsiRecordGetString
(
rec
,
1
,
buf
,
&
sz
);
r
=
MsiRecordGetString
(
rec
,
1
,
buf
,
&
sz
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to get string
\n
"
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to get string
\n
"
);
todo_wine
ok
(
0
==
strcmp
(
"G255"
,
buf
),
"wrong column type
\n
"
);
ok
(
0
==
strcmp
(
"G255"
,
buf
),
"wrong column type
\n
"
);
sz
=
sizeof
buf
;
sz
=
sizeof
buf
;
r
=
MsiRecordGetString
(
rec
,
2
,
buf
,
&
sz
);
r
=
MsiRecordGetString
(
rec
,
2
,
buf
,
&
sz
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to get string
\n
"
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to get string
\n
"
);
todo_wine
ok
(
0
==
strcmp
(
"j2"
,
buf
),
"wrong column type
\n
"
);
ok
(
0
==
strcmp
(
"j2"
,
buf
),
"wrong column type
\n
"
);
MsiCloseHandle
(
rec
);
MsiCloseHandle
(
rec
);
MsiCloseHandle
(
view
);
MsiCloseHandle
(
view
);
...
...
dlls/msi/update.c
View file @
c9b3bc11
...
@@ -155,18 +155,18 @@ static UINT UPDATE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
...
@@ -155,18 +155,18 @@ static UINT UPDATE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *co
}
}
static
UINT
UPDATE_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
UPDATE_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIUPDATEVIEW
*
uv
=
(
MSIUPDATEVIEW
*
)
view
;
MSIUPDATEVIEW
*
uv
=
(
MSIUPDATEVIEW
*
)
view
;
MSIVIEW
*
wv
;
MSIVIEW
*
wv
;
TRACE
(
"%p %d %p %p
\n
"
,
uv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
uv
,
n
,
name
,
type
,
temporary
);
wv
=
uv
->
wv
;
wv
=
uv
->
wv
;
if
(
!
wv
)
if
(
!
wv
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
return
wv
->
ops
->
get_column_info
(
wv
,
n
,
name
,
type
);
return
wv
->
ops
->
get_column_info
(
wv
,
n
,
name
,
type
,
temporary
);
}
}
static
UINT
UPDATE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
static
UINT
UPDATE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
...
...
dlls/msi/where.c
View file @
c9b3bc11
...
@@ -490,16 +490,17 @@ static UINT WHERE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *col
...
@@ -490,16 +490,17 @@ static UINT WHERE_get_dimensions( struct tagMSIVIEW *view, UINT *rows, UINT *col
}
}
static
UINT
WHERE_get_column_info
(
struct
tagMSIVIEW
*
view
,
static
UINT
WHERE_get_column_info
(
struct
tagMSIVIEW
*
view
,
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
)
UINT
n
,
LPWSTR
*
name
,
UINT
*
type
,
BOOL
*
temporary
)
{
{
MSIWHEREVIEW
*
wv
=
(
MSIWHEREVIEW
*
)
view
;
MSIWHEREVIEW
*
wv
=
(
MSIWHEREVIEW
*
)
view
;
TRACE
(
"%p %d %p %p
\n
"
,
wv
,
n
,
name
,
type
);
TRACE
(
"%p %d %p %p
%p
\n
"
,
wv
,
n
,
name
,
type
,
temporary
);
if
(
!
wv
->
table
)
if
(
!
wv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
ERROR_FUNCTION_FAILED
;
return
wv
->
table
->
ops
->
get_column_info
(
wv
->
table
,
n
,
name
,
type
);
return
wv
->
table
->
ops
->
get_column_info
(
wv
->
table
,
n
,
name
,
type
,
temporary
);
}
}
static
UINT
WHERE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
static
UINT
WHERE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
...
@@ -600,7 +601,7 @@ static UINT WHERE_VerifyCondition( MSIDATABASE *db, MSIVIEW *table, struct expr
...
@@ -600,7 +601,7 @@ static UINT WHERE_VerifyCondition( MSIDATABASE *db, MSIVIEW *table, struct expr
if
(
r
==
ERROR_SUCCESS
)
if
(
r
==
ERROR_SUCCESS
)
{
{
UINT
type
=
0
;
UINT
type
=
0
;
r
=
table
->
ops
->
get_column_info
(
table
,
val
,
NULL
,
&
type
);
r
=
table
->
ops
->
get_column_info
(
table
,
val
,
NULL
,
&
type
,
NULL
);
if
(
r
==
ERROR_SUCCESS
)
if
(
r
==
ERROR_SUCCESS
)
{
{
if
(
type
&
MSITYPE_STRING
)
if
(
type
&
MSITYPE_STRING
)
...
...
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