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
b830fb0a
Commit
b830fb0a
authored
Jul 26, 2007
by
James Hawkins
Committed by
Alexandre Julliard
Jul 27, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Implement the MSIMODIFY_UPDATE command in the SELECT view.
parent
fb45206e
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
276 additions
and
95 deletions
+276
-95
alter.c
dlls/msi/alter.c
+11
-1
create.c
dlls/msi/create.c
+2
-1
delete.c
dlls/msi/delete.c
+2
-1
distinct.c
dlls/msi/distinct.c
+3
-2
insert.c
dlls/msi/insert.c
+2
-1
join.c
dlls/msi/join.c
+29
-1
msipriv.h
dlls/msi/msipriv.h
+8
-2
msiquery.c
dlls/msi/msiquery.c
+66
-54
order.c
dlls/msi/order.c
+17
-2
select.c
dlls/msi/select.c
+78
-3
streams.c
dlls/msi/streams.c
+11
-1
table.c
dlls/msi/table.c
+21
-7
db.c
dlls/msi/tests/db.c
+4
-16
update.c
dlls/msi/update.c
+2
-1
where.c
dlls/msi/where.c
+20
-2
No files found.
dlls/msi/alter.c
View file @
b830fb0a
...
...
@@ -61,6 +61,15 @@ static UINT ALTER_fetch_stream( struct tagMSIVIEW *view, UINT row, UINT col, ISt
return
ERROR_FUNCTION_FAILED
;
}
static
UINT
ALTER_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSIALTERVIEW
*
av
=
(
MSIALTERVIEW
*
)
view
;
TRACE
(
"%p %d %p
\n
"
,
av
,
row
,
rec
);
return
av
->
table
->
ops
->
get_row
(
av
->
table
,
row
,
rec
);
}
static
UINT
ITERATE_columns
(
MSIRECORD
*
row
,
LPVOID
param
)
{
(
*
(
UINT
*
)
param
)
++
;
...
...
@@ -179,7 +188,7 @@ static UINT ALTER_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
ALTER_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIALTERVIEW
*
av
=
(
MSIALTERVIEW
*
)
view
;
...
...
@@ -211,6 +220,7 @@ static const MSIVIEWOPS alter_ops =
{
ALTER_fetch_int
,
ALTER_fetch_stream
,
ALTER_get_row
,
NULL
,
NULL
,
NULL
,
...
...
dlls/msi/create.c
View file @
b830fb0a
...
...
@@ -96,7 +96,7 @@ static UINT CREATE_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
CREATE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSICREATEVIEW
*
cv
=
(
MSICREATEVIEW
*
)
view
;
...
...
@@ -124,6 +124,7 @@ static const MSIVIEWOPS create_ops =
NULL
,
NULL
,
NULL
,
NULL
,
CREATE_execute
,
CREATE_close
,
CREATE_get_dimensions
,
...
...
dlls/msi/delete.c
View file @
b830fb0a
...
...
@@ -147,7 +147,7 @@ static UINT DELETE_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
DELETE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIDELETEVIEW
*
dv
=
(
MSIDELETEVIEW
*
)
view
;
...
...
@@ -186,6 +186,7 @@ static const MSIVIEWOPS delete_ops =
NULL
,
NULL
,
NULL
,
NULL
,
DELETE_execute
,
DELETE_close
,
DELETE_get_dimensions
,
...
...
dlls/msi/distinct.c
View file @
b830fb0a
...
...
@@ -218,7 +218,7 @@ static UINT DISTINCT_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
DISTINCT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIDISTINCTVIEW
*
dv
=
(
MSIDISTINCTVIEW
*
)
view
;
...
...
@@ -227,7 +227,7 @@ static UINT DISTINCT_modify( struct tagMSIVIEW *view, MSIMODIFY eModifyMode,
if
(
!
dv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
dv
->
table
->
ops
->
modify
(
dv
->
table
,
eModifyMode
,
rec
);
return
dv
->
table
->
ops
->
modify
(
dv
->
table
,
eModifyMode
,
rec
,
row
);
}
static
UINT
DISTINCT_delete
(
struct
tagMSIVIEW
*
view
)
...
...
@@ -275,6 +275,7 @@ static const MSIVIEWOPS distinct_ops =
NULL
,
NULL
,
NULL
,
NULL
,
DISTINCT_execute
,
DISTINCT_close
,
DISTINCT_get_dimensions
,
...
...
dlls/msi/insert.c
View file @
b830fb0a
...
...
@@ -185,7 +185,7 @@ static UINT INSERT_get_column_info( struct tagMSIVIEW *view,
return
sv
->
ops
->
get_column_info
(
sv
,
n
,
name
,
type
);
}
static
UINT
INSERT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
static
UINT
INSERT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
,
UINT
row
)
{
MSIINSERTVIEW
*
iv
=
(
MSIINSERTVIEW
*
)
view
;
...
...
@@ -226,6 +226,7 @@ static const MSIVIEWOPS insert_ops =
NULL
,
NULL
,
NULL
,
NULL
,
INSERT_execute
,
INSERT_close
,
INSERT_get_dimensions
,
...
...
dlls/msi/join.c
View file @
b830fb0a
...
...
@@ -104,6 +104,33 @@ static UINT JOIN_fetch_stream( struct tagMSIVIEW *view, UINT row, UINT col, IStr
return
table
->
ops
->
fetch_stream
(
table
,
row
,
col
,
stm
);
}
static
UINT
JOIN_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSIJOINVIEW
*
jv
=
(
MSIJOINVIEW
*
)
view
;
MSIVIEW
*
table
;
TRACE
(
"%p %d %p
\n
"
,
jv
,
row
,
rec
);
if
(
!
jv
->
left
||
!
jv
->
right
)
return
ERROR_FUNCTION_FAILED
;
if
(
row
>=
jv
->
left_rows
*
jv
->
right_rows
)
return
ERROR_FUNCTION_FAILED
;
if
(
row
<=
jv
->
left_count
)
{
table
=
jv
->
left
;
row
=
(
row
/
jv
->
right_rows
);
}
else
{
table
=
jv
->
right
;
row
=
(
row
%
jv
->
right_rows
);
}
return
table
->
ops
->
get_row
(
table
,
row
,
rec
);
}
static
UINT
JOIN_execute
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
record
)
{
MSIJOINVIEW
*
jv
=
(
MSIJOINVIEW
*
)
view
;
...
...
@@ -201,7 +228,7 @@ static UINT JOIN_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
JOIN_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIJOINVIEW
*
jv
=
(
MSIJOINVIEW
*
)
view
;
...
...
@@ -243,6 +270,7 @@ static const MSIVIEWOPS join_ops =
{
JOIN_fetch_int
,
JOIN_fetch_stream
,
JOIN_get_row
,
NULL
,
NULL
,
NULL
,
...
...
dlls/msi/msipriv.h
View file @
b830fb0a
...
...
@@ -157,6 +157,12 @@ typedef struct tagMSIVIEWOPS
UINT
(
*
fetch_stream
)(
struct
tagMSIVIEW
*
view
,
UINT
row
,
UINT
col
,
IStream
**
stm
);
/*
* get_row - gets values from a row
*
*/
UINT
(
*
get_row
)(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
);
/*
* set_row - sets values in a row as specified by mask
*
* Similar semantics to fetch_int
...
...
@@ -203,7 +209,7 @@ typedef struct tagMSIVIEWOPS
/*
* modify - not yet implemented properly
*/
UINT
(
*
modify
)(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
record
);
UINT
(
*
modify
)(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
record
,
UINT
row
);
/*
* delete - destroys the structure completely
...
...
@@ -690,7 +696,7 @@ extern UINT MSI_ViewClose( MSIQUERY* );
extern
UINT
MSI_ViewGetColumnInfo
(
MSIQUERY
*
,
MSICOLINFO
,
MSIRECORD
**
);
extern
UINT
MSI_ViewModify
(
MSIQUERY
*
,
MSIMODIFY
,
MSIRECORD
*
);
extern
UINT
VIEW_find_column
(
MSIVIEW
*
,
LPCWSTR
,
UINT
*
);
extern
UINT
msi_view_get_row
(
MSIDATABASE
*
,
MSIVIEW
*
,
UINT
,
MSIRECORD
**
);
/* install internals */
extern
UINT
MSI_SetInstallLevel
(
MSIPACKAGE
*
package
,
int
iInstallLevel
);
...
...
dlls/msi/msiquery.c
View file @
b830fb0a
...
...
@@ -265,90 +265,102 @@ UINT WINAPI MsiDatabaseOpenViewW(MSIHANDLE hdb,
return
ret
;
}
UINT
MSI_ViewFetch
(
MSIQUERY
*
query
,
MSIRECORD
**
p
rec
)
UINT
msi_view_get_row
(
MSIDATABASE
*
db
,
MSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSIVIEW
*
view
;
MSIRECORD
*
rec
;
UINT
row_count
=
0
,
col_count
=
0
,
i
,
ival
,
ret
,
type
;
TRACE
(
"%p %p
\n
"
,
query
,
prec
);
view
=
query
->
view
;
if
(
!
view
)
return
ERROR_FUNCTION_FAILED
;
TRACE
(
"%p %p %d %p
\n
"
,
db
,
view
,
row
,
rec
);
ret
=
view
->
ops
->
get_dimensions
(
view
,
&
row_count
,
&
col_count
);
if
(
ret
)
ret
=
view
->
ops
->
get_dimensions
(
view
,
&
row_count
,
&
col_count
);
if
(
ret
)
return
ret
;
if
(
!
col_count
)
if
(
!
col_count
)
return
ERROR_INVALID_PARAMETER
;
if
(
query
->
row
>=
row_count
)
if
(
row
>=
row_count
)
return
ERROR_NO_MORE_ITEMS
;
rec
=
MSI_CreateRecord
(
col_count
);
if
(
!
rec
)
*
rec
=
MSI_CreateRecord
(
col_count
);
if
(
!*
rec
)
return
ERROR_FUNCTION_FAILED
;
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
for
(
i
=
1
;
i
<=
col_count
;
i
++
)
{
ret
=
view
->
ops
->
get_column_info
(
view
,
i
,
NULL
,
&
type
);
if
(
ret
)
ret
=
view
->
ops
->
get_column_info
(
view
,
i
,
NULL
,
&
type
);
if
(
ret
)
{
ERR
(
"Error getting column type for %d
\n
"
,
i
);
ERR
(
"Error getting column type for %d
\n
"
,
i
);
continue
;
}
if
(
!
MSITYPE_IS_BINARY
(
type
))
if
(
MSITYPE_IS_BINARY
(
type
))
{
ret
=
view
->
ops
->
fetch_int
(
view
,
query
->
row
,
i
,
&
ival
);
if
(
ret
)
IStream
*
stm
=
NULL
;
ret
=
view
->
ops
->
fetch_stream
(
view
,
row
,
i
,
&
stm
);
if
((
ret
==
ERROR_SUCCESS
)
&&
stm
)
{
ERR
(
"Error fetching data for %d
\n
"
,
i
);
continue
;
MSI_RecordSetIStream
(
*
rec
,
i
,
stm
);
IStream_Release
(
stm
)
;
}
if
(
!
(
type
&
MSITYPE_VALID
)
)
ERR
(
"
Invalid type!
\n
"
);
else
ERR
(
"
failed to get stream
\n
"
);
/* check if it's nul (0) - if so, don't set anything */
if
(
!
ival
)
continue
;
continue
;
}
if
(
type
&
MSITYPE_STRING
)
{
LPCWSTR
sval
;
ret
=
view
->
ops
->
fetch_int
(
view
,
row
,
i
,
&
ival
);
if
(
ret
)
{
ERR
(
"Error fetching data for %d
\n
"
,
i
);
continue
;
}
sval
=
msi_string_lookup_id
(
query
->
db
->
strings
,
ival
);
MSI_RecordSetStringW
(
rec
,
i
,
sval
);
}
else
{
if
(
(
type
&
MSI_DATASIZEMASK
)
==
2
)
MSI_RecordSetInteger
(
rec
,
i
,
ival
-
(
1
<<
15
)
);
else
MSI_RecordSetInteger
(
rec
,
i
,
ival
-
(
1
<<
31
)
);
}
if
(
!
(
type
&
MSITYPE_VALID
))
ERR
(
"Invalid type!
\n
"
);
/* check if it's nul (0) - if so, don't set anything */
if
(
!
ival
)
continue
;
if
(
type
&
MSITYPE_STRING
)
{
LPCWSTR
sval
;
sval
=
msi_string_lookup_id
(
db
->
strings
,
ival
);
MSI_RecordSetStringW
(
*
rec
,
i
,
sval
);
}
else
{
IStream
*
stm
=
NULL
;
ret
=
view
->
ops
->
fetch_stream
(
view
,
query
->
row
,
i
,
&
stm
);
if
(
(
ret
==
ERROR_SUCCESS
)
&&
stm
)
{
MSI_RecordSetIStream
(
rec
,
i
,
stm
);
IStream_Release
(
stm
);
}
if
((
type
&
MSI_DATASIZEMASK
)
==
2
)
MSI_RecordSetInteger
(
*
rec
,
i
,
ival
-
(
1
<<
15
));
else
ERR
(
"failed to get stream
\n
"
);
MSI_RecordSetInteger
(
*
rec
,
i
,
ival
-
(
1
<<
31
)
);
}
}
query
->
row
++
;
*
prec
=
rec
;
return
ERROR_SUCCESS
;
}
UINT
MSI_ViewFetch
(
MSIQUERY
*
query
,
MSIRECORD
**
prec
)
{
MSIVIEW
*
view
;
UINT
r
;
TRACE
(
"%p %p
\n
"
,
query
,
prec
);
view
=
query
->
view
;
if
(
!
view
)
return
ERROR_FUNCTION_FAILED
;
r
=
msi_view_get_row
(
query
->
db
,
view
,
query
->
row
,
prec
);
if
(
r
==
ERROR_SUCCESS
)
query
->
row
++
;
return
r
;
}
UINT
WINAPI
MsiViewFetch
(
MSIHANDLE
hView
,
MSIHANDLE
*
record
)
{
MSIQUERY
*
query
;
...
...
@@ -563,7 +575,7 @@ UINT MSI_ViewModify( MSIQUERY *query, MSIMODIFY mode, MSIRECORD *rec )
if
(
!
view
||
!
view
->
ops
->
modify
)
return
ERROR_FUNCTION_FAILED
;
return
view
->
ops
->
modify
(
view
,
mode
,
rec
);
return
view
->
ops
->
modify
(
view
,
mode
,
rec
,
query
->
row
);
}
UINT
WINAPI
MsiViewModify
(
MSIHANDLE
hView
,
MSIMODIFY
eModifyMode
,
...
...
dlls/msi/order.c
View file @
b830fb0a
...
...
@@ -142,6 +142,20 @@ static UINT ORDER_fetch_int( struct tagMSIVIEW *view, UINT row, UINT col, UINT *
return
ov
->
table
->
ops
->
fetch_int
(
ov
->
table
,
row
,
col
,
val
);
}
static
UINT
ORDER_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSIORDERVIEW
*
ov
=
(
MSIORDERVIEW
*
)
view
;
TRACE
(
"%p %d %p
\n
"
,
ov
,
row
,
rec
);
if
(
!
ov
->
table
)
return
ERROR_FUNCTION_FAILED
;
row
=
ov
->
reorder
[
row
];
return
ov
->
table
->
ops
->
get_row
(
ov
->
table
,
row
,
rec
);
}
static
UINT
ORDER_execute
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
record
)
{
MSIORDERVIEW
*
ov
=
(
MSIORDERVIEW
*
)
view
;
...
...
@@ -219,7 +233,7 @@ static UINT ORDER_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
ORDER_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIORDERVIEW
*
ov
=
(
MSIORDERVIEW
*
)
view
;
...
...
@@ -228,7 +242,7 @@ static UINT ORDER_modify( struct tagMSIVIEW *view, MSIMODIFY eModifyMode,
if
(
!
ov
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
ov
->
table
->
ops
->
modify
(
ov
->
table
,
eModifyMode
,
rec
);
return
ov
->
table
->
ops
->
modify
(
ov
->
table
,
eModifyMode
,
rec
,
row
);
}
static
UINT
ORDER_delete
(
struct
tagMSIVIEW
*
view
)
...
...
@@ -272,6 +286,7 @@ static const MSIVIEWOPS order_ops =
{
ORDER_fetch_int
,
NULL
,
ORDER_get_row
,
NULL
,
NULL
,
NULL
,
...
...
dlls/msi/select.c
View file @
b830fb0a
...
...
@@ -82,6 +82,18 @@ static UINT SELECT_fetch_stream( struct tagMSIVIEW *view, UINT row, UINT col, IS
return
sv
->
table
->
ops
->
fetch_stream
(
sv
->
table
,
row
,
col
,
stm
);
}
static
UINT
SELECT_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSISELECTVIEW
*
sv
=
(
MSISELECTVIEW
*
)
view
;
TRACE
(
"%p %d %p
\n
"
,
sv
,
row
,
rec
);
if
(
!
sv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
msi_view_get_row
(
sv
->
db
,
view
,
row
,
rec
);
}
static
UINT
SELECT_set_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
*
rec
,
UINT
mask
)
{
MSISELECTVIEW
*
sv
=
(
MSISELECTVIEW
*
)
view
;
...
...
@@ -214,17 +226,79 @@ static UINT SELECT_get_column_info( struct tagMSIVIEW *view,
return
sv
->
table
->
ops
->
get_column_info
(
sv
->
table
,
n
,
name
,
type
);
}
static
UINT
msi_select_update
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
rec
,
UINT
row
)
{
MSISELECTVIEW
*
sv
=
(
MSISELECTVIEW
*
)
view
;
UINT
r
,
i
,
num_columns
,
col
,
type
,
val
;
LPWSTR
name
;
LPCWSTR
str
;
MSIRECORD
*
mod
;
r
=
SELECT_get_dimensions
(
view
,
NULL
,
&
num_columns
);
if
(
r
!=
ERROR_SUCCESS
)
return
r
;
r
=
sv
->
table
->
ops
->
get_row
(
sv
->
table
,
row
-
1
,
&
mod
);
if
(
r
!=
ERROR_SUCCESS
)
return
r
;
for
(
i
=
0
;
i
<
num_columns
;
i
++
)
{
col
=
sv
->
cols
[
i
];
r
=
SELECT_get_column_info
(
view
,
i
+
1
,
&
name
,
&
type
);
msi_free
(
name
);
if
(
r
!=
ERROR_SUCCESS
)
{
ERR
(
"Failed to get column information: %d
\n
"
,
r
);
goto
done
;
}
if
(
MSITYPE_IS_BINARY
(
type
))
{
ERR
(
"Cannot modify binary data!
\n
"
);
r
=
ERROR_FUNCTION_FAILED
;
goto
done
;
}
else
if
(
type
&
MSITYPE_STRING
)
{
str
=
MSI_RecordGetString
(
rec
,
i
+
1
);
r
=
MSI_RecordSetStringW
(
mod
,
col
,
str
);
}
else
{
val
=
MSI_RecordGetInteger
(
rec
,
i
+
1
);
r
=
MSI_RecordSetInteger
(
mod
,
col
,
val
);
}
if
(
r
!=
ERROR_SUCCESS
)
{
ERR
(
"Failed to modify record: %d
\n
"
,
r
);
goto
done
;
}
}
r
=
sv
->
table
->
ops
->
modify
(
sv
->
table
,
MSIMODIFY_UPDATE
,
mod
,
row
);
done:
msiobj_release
(
&
mod
->
hdr
);
return
r
;
}
static
UINT
SELECT_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSISELECTVIEW
*
sv
=
(
MSISELECTVIEW
*
)
view
;
TRACE
(
"%p %d %p
\n
"
,
sv
,
eModifyMode
,
rec
);
TRACE
(
"%p %d %p
%d
\n
"
,
sv
,
eModifyMode
,
rec
,
row
);
if
(
!
sv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
sv
->
table
->
ops
->
modify
(
sv
->
table
,
eModifyMode
,
rec
);
if
(
eModifyMode
==
MSIMODIFY_UPDATE
)
return
msi_select_update
(
view
,
rec
,
row
);
return
sv
->
table
->
ops
->
modify
(
sv
->
table
,
eModifyMode
,
rec
,
row
);
}
static
UINT
SELECT_delete
(
struct
tagMSIVIEW
*
view
)
...
...
@@ -265,6 +339,7 @@ static const MSIVIEWOPS select_ops =
{
SELECT_fetch_int
,
SELECT_fetch_stream
,
SELECT_get_row
,
SELECT_set_row
,
SELECT_insert_row
,
NULL
,
...
...
dlls/msi/streams.c
View file @
b830fb0a
...
...
@@ -129,6 +129,15 @@ static UINT STREAMS_fetch_stream(struct tagMSIVIEW *view, UINT row, UINT col, IS
return
ERROR_SUCCESS
;
}
static
UINT
STREAMS_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSISTREAMSVIEW
*
sv
=
(
MSISTREAMSVIEW
*
)
view
;
FIXME
(
"%p %d %p
\n
"
,
sv
,
row
,
rec
);
return
ERROR_CALL_NOT_IMPLEMENTED
;
}
static
UINT
STREAMS_set_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
*
rec
,
UINT
mask
)
{
FIXME
(
"(%p, %d, %p, %d): stub!
\n
"
,
view
,
row
,
rec
,
mask
);
...
...
@@ -269,7 +278,7 @@ static UINT STREAMS_get_column_info(struct tagMSIVIEW *view,
return
ERROR_SUCCESS
;
}
static
UINT
STREAMS_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
static
UINT
STREAMS_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
,
UINT
row
)
{
FIXME
(
"(%p, %d, %p): stub!
\n
"
,
view
,
eModifyMode
,
rec
);
return
ERROR_SUCCESS
;
...
...
@@ -327,6 +336,7 @@ static const MSIVIEWOPS streams_ops =
{
STREAMS_fetch_int
,
STREAMS_fetch_stream
,
STREAMS_get_row
,
STREAMS_set_row
,
STREAMS_insert_row
,
STREAMS_delete_row
,
...
...
dlls/msi/table.c
View file @
b830fb0a
...
...
@@ -1277,6 +1277,16 @@ static UINT TABLE_set_int( MSITABLEVIEW *tv, UINT row, UINT col, UINT val )
return
ERROR_SUCCESS
;
}
static
UINT
TABLE_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSITABLEVIEW
*
tv
=
(
MSITABLEVIEW
*
)
view
;
if
(
!
tv
->
table
)
return
ERROR_INVALID_PARAMETER
;
return
msi_view_get_row
(
tv
->
db
,
view
,
row
,
rec
);
}
static
UINT
TABLE_set_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
*
rec
,
UINT
mask
)
{
MSITABLEVIEW
*
tv
=
(
MSITABLEVIEW
*
)
view
;
...
...
@@ -1532,10 +1542,10 @@ static UINT TABLE_delete_row( struct tagMSIVIEW *view, UINT row )
return
ERROR_SUCCESS
;
}
static
UINT
msi_table_update
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
rec
)
static
UINT
msi_table_update
(
struct
tagMSIVIEW
*
view
,
MSIRECORD
*
rec
,
UINT
row
)
{
MSITABLEVIEW
*
tv
=
(
MSITABLEVIEW
*
)
view
;
UINT
r
,
row
;
UINT
r
,
new_
row
;
/* FIXME: MsiViewFetch should set rec index 0 to some ID that
* sets the fetched record apart from other records
...
...
@@ -1544,19 +1554,22 @@ static UINT msi_table_update(struct tagMSIVIEW *view, MSIRECORD *rec)
if
(
!
tv
->
table
)
return
ERROR_INVALID_PARAMETER
;
r
=
msi_table_find_row
(
tv
,
rec
,
&
row
);
r
=
msi_table_find_row
(
tv
,
rec
,
&
new_
row
);
if
(
r
!=
ERROR_SUCCESS
)
{
ERR
(
"can't find row to modify
\n
"
);
return
ERROR_SUCCESS
;
}
/* the row cannot be changed */
if
(
row
!=
0
)
if
(
row
!=
new_row
+
1
)
return
ERROR_FUNCTION_FAILED
;
return
TABLE_set_row
(
view
,
row
,
rec
,
(
1
<<
tv
->
num_cols
)
-
1
);
return
TABLE_set_row
(
view
,
new_
row
,
rec
,
(
1
<<
tv
->
num_cols
)
-
1
);
}
static
UINT
TABLE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSITABLEVIEW
*
tv
=
(
MSITABLEVIEW
*
)
view
;
UINT
r
;
...
...
@@ -1577,7 +1590,7 @@ static UINT TABLE_modify( struct tagMSIVIEW *view, MSIMODIFY eModifyMode,
break
;
case
MSIMODIFY_UPDATE
:
r
=
msi_table_update
(
view
,
rec
);
r
=
msi_table_update
(
view
,
rec
,
row
);
break
;
case
MSIMODIFY_REFRESH
:
...
...
@@ -1826,6 +1839,7 @@ static const MSIVIEWOPS table_ops =
{
TABLE_fetch_int
,
TABLE_fetch_stream
,
TABLE_get_row
,
TABLE_set_row
,
TABLE_insert_row
,
TABLE_delete_row
,
...
...
dlls/msi/tests/db.c
View file @
b830fb0a
...
...
@@ -3841,10 +3841,7 @@ static void test_viewmodify_update(void)
r
=
MsiRecordGetInteger
(
hrec
,
1
);
ok
(
r
==
1
,
"Expected 1, got %d
\n
"
,
r
);
r
=
MsiRecordGetInteger
(
hrec
,
2
);
todo_wine
{
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
}
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
r
=
MsiCloseHandle
(
hrec
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to close record
\n
"
);
...
...
@@ -3918,10 +3915,7 @@ static void test_viewmodify_update(void)
r
=
MsiRecordGetInteger
(
hrec
,
1
);
ok
(
r
==
1
,
"Expected 1, got %d
\n
"
,
r
);
r
=
MsiRecordGetInteger
(
hrec
,
2
);
todo_wine
{
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
}
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
r
=
MsiCloseHandle
(
hrec
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to close record
\n
"
);
...
...
@@ -3932,10 +3926,7 @@ static void test_viewmodify_update(void)
r
=
MsiRecordGetInteger
(
hrec
,
1
);
ok
(
r
==
3
,
"Expected 3, got %d
\n
"
,
r
);
r
=
MsiRecordGetInteger
(
hrec
,
2
);
todo_wine
{
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
}
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
r
=
MsiCloseHandle
(
hrec
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to close record
\n
"
);
...
...
@@ -3946,10 +3937,7 @@ static void test_viewmodify_update(void)
r
=
MsiRecordGetInteger
(
hrec
,
1
);
ok
(
r
==
5
,
"Expected 5, got %d
\n
"
,
r
);
r
=
MsiRecordGetInteger
(
hrec
,
2
);
todo_wine
{
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
}
ok
(
r
==
0
,
"Expected 0, got %d
\n
"
,
r
);
r
=
MsiCloseHandle
(
hrec
);
ok
(
r
==
ERROR_SUCCESS
,
"failed to close record
\n
"
);
...
...
dlls/msi/update.c
View file @
b830fb0a
...
...
@@ -138,7 +138,7 @@ static UINT UPDATE_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
UPDATE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIUPDATEVIEW
*
uv
=
(
MSIUPDATEVIEW
*
)
view
;
...
...
@@ -178,6 +178,7 @@ static const MSIVIEWOPS update_ops =
NULL
,
NULL
,
NULL
,
NULL
,
UPDATE_execute
,
UPDATE_close
,
UPDATE_get_dimensions
,
...
...
dlls/msi/where.c
View file @
b830fb0a
...
...
@@ -82,6 +82,23 @@ static UINT WHERE_fetch_stream( struct tagMSIVIEW *view, UINT row, UINT col, ISt
return
wv
->
table
->
ops
->
fetch_stream
(
wv
->
table
,
row
,
col
,
stm
);
}
static
UINT
WHERE_get_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
**
rec
)
{
MSIWHEREVIEW
*
wv
=
(
MSIWHEREVIEW
*
)
view
;
TRACE
(
"%p %d %p
\n
"
,
wv
,
row
,
rec
);
if
(
!
wv
->
table
)
return
ERROR_FUNCTION_FAILED
;
if
(
row
>
wv
->
row_count
)
return
ERROR_NO_MORE_ITEMS
;
row
=
wv
->
reorder
[
row
];
return
wv
->
table
->
ops
->
get_row
(
view
,
row
,
rec
);
}
static
UINT
WHERE_set_row
(
struct
tagMSIVIEW
*
view
,
UINT
row
,
MSIRECORD
*
rec
,
UINT
mask
)
{
MSIWHEREVIEW
*
wv
=
(
MSIWHEREVIEW
*
)
view
;
...
...
@@ -379,7 +396,7 @@ static UINT WHERE_get_column_info( struct tagMSIVIEW *view,
}
static
UINT
WHERE_modify
(
struct
tagMSIVIEW
*
view
,
MSIMODIFY
eModifyMode
,
MSIRECORD
*
rec
)
MSIRECORD
*
rec
,
UINT
row
)
{
MSIWHEREVIEW
*
wv
=
(
MSIWHEREVIEW
*
)
view
;
...
...
@@ -388,7 +405,7 @@ static UINT WHERE_modify( struct tagMSIVIEW *view, MSIMODIFY eModifyMode,
if
(
!
wv
->
table
)
return
ERROR_FUNCTION_FAILED
;
return
wv
->
table
->
ops
->
modify
(
wv
->
table
,
eModifyMode
,
rec
);
return
wv
->
table
->
ops
->
modify
(
wv
->
table
,
eModifyMode
,
rec
,
row
);
}
static
UINT
WHERE_delete
(
struct
tagMSIVIEW
*
view
)
...
...
@@ -437,6 +454,7 @@ static const MSIVIEWOPS where_ops =
{
WHERE_fetch_int
,
WHERE_fetch_stream
,
WHERE_get_row
,
WHERE_set_row
,
NULL
,
NULL
,
...
...
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