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
33856888
Commit
33856888
authored
Apr 23, 2007
by
Rob Shearman
Committed by
Alexandre Julliard
Apr 24, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Create the table directly in create_table instead of requiring it to be loaded after saving.
parent
ba0507a1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
44 additions
and
3 deletions
+44
-3
table.c
dlls/msi/table.c
+44
-3
No files found.
dlls/msi/table.c
View file @
33856888
...
@@ -102,6 +102,7 @@ static const MSICOLUMNINFO _Tables_cols[1] = {
...
@@ -102,6 +102,7 @@ static const MSICOLUMNINFO _Tables_cols[1] = {
static
UINT
table_get_column_info
(
MSIDATABASE
*
db
,
LPCWSTR
name
,
static
UINT
table_get_column_info
(
MSIDATABASE
*
db
,
LPCWSTR
name
,
MSICOLUMNINFO
**
pcols
,
UINT
*
pcount
);
MSICOLUMNINFO
**
pcols
,
UINT
*
pcount
);
static
void
table_calc_column_offsets
(
MSICOLUMNINFO
*
colinfo
,
DWORD
count
);
static
UINT
get_tablecolumns
(
MSIDATABASE
*
db
,
static
UINT
get_tablecolumns
(
MSIDATABASE
*
db
,
LPCWSTR
szTableName
,
MSICOLUMNINFO
*
colinfo
,
UINT
*
sz
);
LPCWSTR
szTableName
,
MSICOLUMNINFO
*
colinfo
,
UINT
*
sz
);
static
void
msi_free_colinfo
(
MSICOLUMNINFO
*
colinfo
,
UINT
count
);
static
void
msi_free_colinfo
(
MSICOLUMNINFO
*
colinfo
,
UINT
count
);
...
@@ -593,8 +594,6 @@ static UINT table_get_column_info( MSIDATABASE *db, LPCWSTR name, MSICOLUMNINFO
...
@@ -593,8 +594,6 @@ static UINT table_get_column_info( MSIDATABASE *db, LPCWSTR name, MSICOLUMNINFO
return
r
;
return
r
;
}
}
static
UINT
get_table
(
MSIDATABASE
*
db
,
LPCWSTR
name
,
MSITABLE
**
table_ret
);
UINT
msi_create_table
(
MSIDATABASE
*
db
,
LPCWSTR
name
,
column_info
*
col_info
,
UINT
msi_create_table
(
MSIDATABASE
*
db
,
LPCWSTR
name
,
column_info
*
col_info
,
BOOL
persistent
,
MSITABLE
**
table_ret
)
BOOL
persistent
,
MSITABLE
**
table_ret
)
{
{
...
@@ -602,15 +601,51 @@ UINT msi_create_table( MSIDATABASE *db, LPCWSTR name, column_info *col_info,
...
@@ -602,15 +601,51 @@ UINT msi_create_table( MSIDATABASE *db, LPCWSTR name, column_info *col_info,
MSIVIEW
*
tv
=
NULL
;
MSIVIEW
*
tv
=
NULL
;
MSIRECORD
*
rec
=
NULL
;
MSIRECORD
*
rec
=
NULL
;
column_info
*
col
;
column_info
*
col
;
MSITABLE
*
table
;
UINT
i
;
/* only add tables that don't exist already */
/* only add tables that don't exist already */
if
(
TABLE_Exists
(
db
,
name
)
)
if
(
TABLE_Exists
(
db
,
name
)
)
return
ERROR_BAD_QUERY_SYNTAX
;
return
ERROR_BAD_QUERY_SYNTAX
;
table
=
msi_alloc
(
sizeof
(
MSITABLE
)
+
lstrlenW
(
name
)
*
sizeof
(
WCHAR
)
);
if
(
!
table
)
return
ERROR_FUNCTION_FAILED
;
table
->
row_count
=
0
;
table
->
data
=
NULL
;
table
->
colinfo
=
NULL
;
table
->
col_count
=
0
;
lstrcpyW
(
table
->
name
,
name
);
for
(
col
=
col_info
;
col
;
col
=
col
->
next
)
table
->
col_count
++
;
table
->
colinfo
=
msi_alloc
(
table
->
col_count
*
sizeof
(
MSICOLUMNINFO
)
);
if
(
!
table
->
colinfo
)
{
free_table
(
table
);
return
ERROR_FUNCTION_FAILED
;
}
for
(
i
=
0
,
col
=
col_info
;
col
;
i
++
,
col
=
col
->
next
)
{
table
->
colinfo
[
i
].
tablename
=
strdupW
(
col
->
table
);
table
->
colinfo
[
i
].
number
=
i
+
1
;
table
->
colinfo
[
i
].
colname
=
strdupW
(
col
->
column
);
table
->
colinfo
[
i
].
type
=
col
->
type
;
table
->
colinfo
[
i
].
offset
=
0
;
table
->
colinfo
[
i
].
hash_table
=
NULL
;
}
table_calc_column_offsets
(
table
->
colinfo
,
table
->
col_count
);
r
=
TABLE_CreateView
(
db
,
szTables
,
&
tv
);
r
=
TABLE_CreateView
(
db
,
szTables
,
&
tv
);
TRACE
(
"CreateView returned %x
\n
"
,
r
);
TRACE
(
"CreateView returned %x
\n
"
,
r
);
if
(
r
)
if
(
r
)
{
free_table
(
table
);
return
r
;
return
r
;
}
r
=
tv
->
ops
->
execute
(
tv
,
0
);
r
=
tv
->
ops
->
execute
(
tv
,
0
);
TRACE
(
"tv execute returned %x
\n
"
,
r
);
TRACE
(
"tv execute returned %x
\n
"
,
r
);
...
@@ -689,7 +724,13 @@ err:
...
@@ -689,7 +724,13 @@ err:
tv
->
ops
->
delete
(
tv
);
tv
->
ops
->
delete
(
tv
);
if
(
r
==
ERROR_SUCCESS
)
if
(
r
==
ERROR_SUCCESS
)
r
=
get_table
(
db
,
name
,
table_ret
);
{
list_add_head
(
&
db
->
tables
,
&
table
->
entry
);
*
table_ret
=
table
;
}
else
free_table
(
table
);
return
r
;
return
r
;
}
}
...
...
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