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
cad837c9
Commit
cad837c9
authored
May 26, 2009
by
Hib Eris
Committed by
Alexandre Julliard
May 27, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msi: Add support for importing binary OBJECTS.
parent
9ccc9bd6
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
57 additions
and
11 deletions
+57
-11
database.c
dlls/msi/database.c
+49
-4
msipriv.h
dlls/msi/msipriv.h
+1
-0
record.c
dlls/msi/record.c
+1
-1
db.c
dlls/msi/tests/db.c
+6
-6
No files found.
dlls/msi/database.c
View file @
cad837c9
...
@@ -377,6 +377,7 @@ static LPWSTR msi_build_createsql_columns(LPWSTR *columns_data, LPWSTR *types, D
...
@@ -377,6 +377,7 @@ static LPWSTR msi_build_createsql_columns(LPWSTR *columns_data, LPWSTR *types, D
static
const
WCHAR
type_char
[]
=
{
'C'
,
'H'
,
'A'
,
'R'
,
0
};
static
const
WCHAR
type_char
[]
=
{
'C'
,
'H'
,
'A'
,
'R'
,
0
};
static
const
WCHAR
type_int
[]
=
{
'I'
,
'N'
,
'T'
,
0
};
static
const
WCHAR
type_int
[]
=
{
'I'
,
'N'
,
'T'
,
0
};
static
const
WCHAR
type_long
[]
=
{
'L'
,
'O'
,
'N'
,
'G'
,
0
};
static
const
WCHAR
type_long
[]
=
{
'L'
,
'O'
,
'N'
,
'G'
,
0
};
static
const
WCHAR
type_object
[]
=
{
'O'
,
'B'
,
'J'
,
'E'
,
'C'
,
'T'
,
0
};
static
const
WCHAR
type_notnull
[]
=
{
' '
,
'N'
,
'O'
,
'T'
,
' '
,
'N'
,
'U'
,
'L'
,
'L'
,
0
};
static
const
WCHAR
type_notnull
[]
=
{
' '
,
'N'
,
'O'
,
'T'
,
' '
,
'N'
,
'U'
,
'L'
,
'L'
,
0
};
static
const
WCHAR
localizable
[]
=
{
' '
,
'L'
,
'O'
,
'C'
,
'A'
,
'L'
,
'I'
,
'Z'
,
'A'
,
'B'
,
'L'
,
'E'
,
0
};
static
const
WCHAR
localizable
[]
=
{
' '
,
'L'
,
'O'
,
'C'
,
'A'
,
'L'
,
'I'
,
'Z'
,
'A'
,
'B'
,
'L'
,
'E'
,
0
};
...
@@ -421,6 +422,11 @@ static LPWSTR msi_build_createsql_columns(LPWSTR *columns_data, LPWSTR *types, D
...
@@ -421,6 +422,11 @@ static LPWSTR msi_build_createsql_columns(LPWSTR *columns_data, LPWSTR *types, D
else
else
type
=
type_long
;
type
=
type_long
;
break
;
break
;
case
'v'
:
lstrcpyW
(
extra
,
type_notnull
);
case
'V'
:
type
=
type_object
;
break
;
default:
default:
ERR
(
"Unknown type: %c
\n
"
,
types
[
i
][
0
]);
ERR
(
"Unknown type: %c
\n
"
,
types
[
i
][
0
]);
msi_free
(
columns
);
msi_free
(
columns
);
...
@@ -522,8 +528,32 @@ static UINT msi_add_table_to_db(MSIDATABASE *db, LPWSTR *columns, LPWSTR *types,
...
@@ -522,8 +528,32 @@ static UINT msi_add_table_to_db(MSIDATABASE *db, LPWSTR *columns, LPWSTR *types,
return
r
;
return
r
;
}
}
static
LPWSTR
msi_import_stream_filename
(
LPCWSTR
path
,
LPCWSTR
name
)
{
DWORD
len
;
LPWSTR
fullname
,
ptr
;
len
=
lstrlenW
(
path
)
+
lstrlenW
(
name
)
+
1
;
fullname
=
msi_alloc
(
len
*
sizeof
(
WCHAR
));
if
(
!
fullname
)
return
NULL
;
lstrcpyW
(
fullname
,
path
);
/* chop off extension from path */
ptr
=
strrchrW
(
fullname
,
'.'
);
if
(
!
ptr
)
{
msi_free
(
fullname
);
return
NULL
;
}
*
ptr
++
=
'\\'
;
lstrcpyW
(
ptr
,
name
);
return
fullname
;
}
static
UINT
construct_record
(
DWORD
num_columns
,
LPWSTR
*
types
,
static
UINT
construct_record
(
DWORD
num_columns
,
LPWSTR
*
types
,
LPWSTR
*
data
,
MSIRECORD
**
rec
)
LPWSTR
*
data
,
LPWSTR
path
,
MSIRECORD
**
rec
)
{
{
UINT
i
;
UINT
i
;
...
@@ -542,6 +572,20 @@ static UINT construct_record(DWORD num_columns, LPWSTR *types,
...
@@ -542,6 +572,20 @@ static UINT construct_record(DWORD num_columns, LPWSTR *types,
if
(
*
data
[
i
])
if
(
*
data
[
i
])
MSI_RecordSetInteger
(
*
rec
,
i
+
1
,
atoiW
(
data
[
i
]));
MSI_RecordSetInteger
(
*
rec
,
i
+
1
,
atoiW
(
data
[
i
]));
break
;
break
;
case
'V'
:
case
'v'
:
if
(
*
data
[
i
])
{
UINT
r
;
LPWSTR
file
=
msi_import_stream_filename
(
path
,
data
[
i
]);
if
(
!
file
)
return
ERROR_FUNCTION_FAILED
;
r
=
MSI_RecordSetStreamFromFileW
(
*
rec
,
i
+
1
,
file
);
msi_free
(
file
);
if
(
r
!=
ERROR_SUCCESS
)
return
ERROR_FUNCTION_FAILED
;
}
break
;
default:
default:
ERR
(
"Unhandled column type: %c
\n
"
,
types
[
i
][
0
]);
ERR
(
"Unhandled column type: %c
\n
"
,
types
[
i
][
0
]);
msiobj_release
(
&
(
*
rec
)
->
hdr
);
msiobj_release
(
&
(
*
rec
)
->
hdr
);
...
@@ -554,7 +598,8 @@ static UINT construct_record(DWORD num_columns, LPWSTR *types,
...
@@ -554,7 +598,8 @@ static UINT construct_record(DWORD num_columns, LPWSTR *types,
static
UINT
msi_add_records_to_table
(
MSIDATABASE
*
db
,
LPWSTR
*
columns
,
LPWSTR
*
types
,
static
UINT
msi_add_records_to_table
(
MSIDATABASE
*
db
,
LPWSTR
*
columns
,
LPWSTR
*
types
,
LPWSTR
*
labels
,
LPWSTR
**
records
,
LPWSTR
*
labels
,
LPWSTR
**
records
,
int
num_columns
,
int
num_records
)
int
num_columns
,
int
num_records
,
LPWSTR
path
)
{
{
UINT
r
;
UINT
r
;
int
i
;
int
i
;
...
@@ -579,7 +624,7 @@ static UINT msi_add_records_to_table(MSIDATABASE *db, LPWSTR *columns, LPWSTR *t
...
@@ -579,7 +624,7 @@ static UINT msi_add_records_to_table(MSIDATABASE *db, LPWSTR *columns, LPWSTR *t
for
(
i
=
0
;
i
<
num_records
;
i
++
)
for
(
i
=
0
;
i
<
num_records
;
i
++
)
{
{
r
=
construct_record
(
num_columns
,
types
,
records
[
i
],
&
rec
);
r
=
construct_record
(
num_columns
,
types
,
records
[
i
],
path
,
&
rec
);
if
(
r
!=
ERROR_SUCCESS
)
if
(
r
!=
ERROR_SUCCESS
)
goto
done
;
goto
done
;
...
@@ -683,7 +728,7 @@ static UINT MSI_DatabaseImport(MSIDATABASE *db, LPCWSTR folder, LPCWSTR file)
...
@@ -683,7 +728,7 @@ static UINT MSI_DatabaseImport(MSIDATABASE *db, LPCWSTR folder, LPCWSTR file)
}
}
}
}
r
=
msi_add_records_to_table
(
db
,
columns
,
types
,
labels
,
records
,
num_columns
,
num_records
);
r
=
msi_add_records_to_table
(
db
,
columns
,
types
,
labels
,
records
,
num_columns
,
num_records
,
path
);
}
}
done:
done:
...
...
dlls/msi/msipriv.h
View file @
cad837c9
...
@@ -704,6 +704,7 @@ extern UINT MSI_RecordReadStream( MSIRECORD *, UINT, char *, LPDWORD);
...
@@ -704,6 +704,7 @@ extern UINT MSI_RecordReadStream( MSIRECORD *, UINT, char *, LPDWORD);
extern
UINT
MSI_RecordSetStream
(
MSIRECORD
*
,
UINT
,
IStream
*
);
extern
UINT
MSI_RecordSetStream
(
MSIRECORD
*
,
UINT
,
IStream
*
);
extern
UINT
MSI_RecordGetFieldCount
(
const
MSIRECORD
*
rec
);
extern
UINT
MSI_RecordGetFieldCount
(
const
MSIRECORD
*
rec
);
extern
UINT
MSI_RecordStreamToFile
(
MSIRECORD
*
,
UINT
,
LPCWSTR
);
extern
UINT
MSI_RecordStreamToFile
(
MSIRECORD
*
,
UINT
,
LPCWSTR
);
extern
UINT
MSI_RecordSetStreamFromFileW
(
MSIRECORD
*
,
UINT
,
LPCWSTR
);
extern
UINT
MSI_RecordCopyField
(
MSIRECORD
*
,
UINT
,
MSIRECORD
*
,
UINT
);
extern
UINT
MSI_RecordCopyField
(
MSIRECORD
*
,
UINT
,
MSIRECORD
*
,
UINT
);
extern
MSIRECORD
*
MSI_CloneRecord
(
MSIRECORD
*
);
extern
MSIRECORD
*
MSI_CloneRecord
(
MSIRECORD
*
);
extern
BOOL
MSI_RecordsAreEqual
(
MSIRECORD
*
,
MSIRECORD
*
);
extern
BOOL
MSI_RecordsAreEqual
(
MSIRECORD
*
,
MSIRECORD
*
);
...
...
dlls/msi/record.c
View file @
cad837c9
...
@@ -673,7 +673,7 @@ UINT MSI_RecordSetStream(MSIRECORD *rec, UINT iField, IStream *stream)
...
@@ -673,7 +673,7 @@ UINT MSI_RecordSetStream(MSIRECORD *rec, UINT iField, IStream *stream)
return
ERROR_SUCCESS
;
return
ERROR_SUCCESS
;
}
}
static
UINT
MSI_RecordSetStreamFromFileW
(
MSIRECORD
*
rec
,
UINT
iField
,
LPCWSTR
szFilename
)
UINT
MSI_RecordSetStreamFromFileW
(
MSIRECORD
*
rec
,
UINT
iField
,
LPCWSTR
szFilename
)
{
{
IStream
*
stm
=
NULL
;
IStream
*
stm
=
NULL
;
HRESULT
r
;
HRESULT
r
;
...
...
dlls/msi/tests/db.c
View file @
cad837c9
...
@@ -1966,23 +1966,23 @@ static void test_binary_import(void)
...
@@ -1966,23 +1966,23 @@ static void test_binary_import(void)
GetCurrentDirectory
(
MAX_PATH
,
path
);
GetCurrentDirectory
(
MAX_PATH
,
path
);
r
=
MsiDatabaseImport
(
hdb
,
path
,
"bin_import.idt"
);
r
=
MsiDatabaseImport
(
hdb
,
path
,
"bin_import.idt"
);
todo_wine
ok
(
r
==
ERROR_SUCCESS
,
"Failed to import Binary table
\n
"
);
ok
(
r
==
ERROR_SUCCESS
,
"Failed to import Binary table
\n
"
);
/* read file from the Binary table */
/* read file from the Binary table */
query
=
"SELECT * FROM `Binary`"
;
query
=
"SELECT * FROM `Binary`"
;
r
=
do_query
(
hdb
,
query
,
&
rec
);
r
=
do_query
(
hdb
,
query
,
&
rec
);
todo_wine
ok
(
r
==
ERROR_SUCCESS
,
"SELECT query failed: %d
\n
"
,
r
);
ok
(
r
==
ERROR_SUCCESS
,
"SELECT query failed: %d
\n
"
,
r
);
size
=
MAX_PATH
;
size
=
MAX_PATH
;
r
=
MsiRecordGetString
(
rec
,
1
,
file
,
&
size
);
r
=
MsiRecordGetString
(
rec
,
1
,
file
,
&
size
);
todo_wine
ok
(
r
==
ERROR_SUCCESS
,
"Failed to get string: %d
\n
"
,
r
);
ok
(
r
==
ERROR_SUCCESS
,
"Failed to get string: %d
\n
"
,
r
);
todo_wine
ok
(
!
lstrcmp
(
file
,
"filename1"
),
"Expected 'filename1', got %s
\n
"
,
file
);
ok
(
!
lstrcmp
(
file
,
"filename1"
),
"Expected 'filename1', got %s
\n
"
,
file
);
size
=
MAX_PATH
;
size
=
MAX_PATH
;
memset
(
buf
,
0
,
MAX_PATH
);
memset
(
buf
,
0
,
MAX_PATH
);
r
=
MsiRecordReadStream
(
rec
,
2
,
buf
,
&
size
);
r
=
MsiRecordReadStream
(
rec
,
2
,
buf
,
&
size
);
todo_wine
ok
(
r
==
ERROR_SUCCESS
,
"Failed to get stream: %d
\n
"
,
r
);
ok
(
r
==
ERROR_SUCCESS
,
"Failed to get stream: %d
\n
"
,
r
);
todo_wine
ok
(
!
lstrcmp
(
buf
,
"just some words"
),
ok
(
!
lstrcmp
(
buf
,
"just some words"
),
"Expected 'just some words', got %s
\n
"
,
buf
);
"Expected 'just some words', got %s
\n
"
,
buf
);
r
=
MsiCloseHandle
(
rec
);
r
=
MsiCloseHandle
(
rec
);
...
...
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