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
07ded6bb
Commit
07ded6bb
authored
Jan 06, 2014
by
Nikolay Sivov
Committed by
Alexandre Julliard
Jan 06, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
scrrun: Added IFileCollection stub.
parent
42d2b519
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
196 additions
and
3 deletions
+196
-3
filesystem.c
dlls/scrrun/filesystem.c
+167
-2
scrrun.c
dlls/scrrun/scrrun.c
+2
-1
scrrun_private.h
dlls/scrrun/scrrun_private.h
+1
-0
filesystem.c
dlls/scrrun/tests/filesystem.c
+26
-0
No files found.
dlls/scrrun/filesystem.c
View file @
07ded6bb
...
@@ -63,6 +63,11 @@ struct foldercollection {
...
@@ -63,6 +63,11 @@ struct foldercollection {
BSTR
path
;
BSTR
path
;
};
};
struct
filecollection
{
IFileCollection
IFileCollection_iface
;
LONG
ref
;
};
struct
folder
{
struct
folder
{
IFolder
IFolder_iface
;
IFolder
IFolder_iface
;
LONG
ref
;
LONG
ref
;
...
@@ -108,6 +113,11 @@ static inline struct foldercollection *impl_from_IFolderCollection(IFolderCollec
...
@@ -108,6 +113,11 @@ static inline struct foldercollection *impl_from_IFolderCollection(IFolderCollec
return
CONTAINING_RECORD
(
iface
,
struct
foldercollection
,
IFolderCollection_iface
);
return
CONTAINING_RECORD
(
iface
,
struct
foldercollection
,
IFolderCollection_iface
);
}
}
static
inline
struct
filecollection
*
impl_from_IFileCollection
(
IFileCollection
*
iface
)
{
return
CONTAINING_RECORD
(
iface
,
struct
filecollection
,
IFileCollection_iface
);
}
static
inline
struct
enumvariant
*
impl_from_IEnumVARIANT
(
IEnumVARIANT
*
iface
)
static
inline
struct
enumvariant
*
impl_from_IEnumVARIANT
(
IEnumVARIANT
*
iface
)
{
{
return
CONTAINING_RECORD
(
iface
,
struct
enumvariant
,
IEnumVARIANT_iface
);
return
CONTAINING_RECORD
(
iface
,
struct
enumvariant
,
IEnumVARIANT_iface
);
...
@@ -779,6 +789,156 @@ static HRESULT create_foldercoll(BSTR path, IFolderCollection **folders)
...
@@ -779,6 +789,156 @@ static HRESULT create_foldercoll(BSTR path, IFolderCollection **folders)
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
WINAPI
filecoll_QueryInterface
(
IFileCollection
*
iface
,
REFIID
riid
,
void
**
obj
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
TRACE
(
"(%p)->(%s %p)
\n
"
,
This
,
debugstr_guid
(
riid
),
obj
);
*
obj
=
NULL
;
if
(
IsEqualIID
(
riid
,
&
IID_IFileCollection
)
||
IsEqualIID
(
riid
,
&
IID_IDispatch
)
||
IsEqualIID
(
riid
,
&
IID_IUnknown
))
{
*
obj
=
iface
;
IFileCollection_AddRef
(
iface
);
}
else
return
E_NOINTERFACE
;
return
S_OK
;
}
static
ULONG
WINAPI
filecoll_AddRef
(
IFileCollection
*
iface
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
ULONG
ref
=
InterlockedIncrement
(
&
This
->
ref
);
TRACE
(
"(%p)->(%d)
\n
"
,
This
,
ref
);
return
ref
;
}
static
ULONG
WINAPI
filecoll_Release
(
IFileCollection
*
iface
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
ULONG
ref
=
InterlockedDecrement
(
&
This
->
ref
);
TRACE
(
"(%p)->(%d)
\n
"
,
This
,
ref
);
if
(
!
ref
)
heap_free
(
This
);
return
ref
;
}
static
HRESULT
WINAPI
filecoll_GetTypeInfoCount
(
IFileCollection
*
iface
,
UINT
*
pctinfo
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
TRACE
(
"(%p)->(%p)
\n
"
,
This
,
pctinfo
);
*
pctinfo
=
1
;
return
S_OK
;
}
static
HRESULT
WINAPI
filecoll_GetTypeInfo
(
IFileCollection
*
iface
,
UINT
iTInfo
,
LCID
lcid
,
ITypeInfo
**
ppTInfo
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
TRACE
(
"(%p)->(%u %u %p)
\n
"
,
This
,
iTInfo
,
lcid
,
ppTInfo
);
return
get_typeinfo
(
IFileCollection_tid
,
ppTInfo
);
}
static
HRESULT
WINAPI
filecoll_GetIDsOfNames
(
IFileCollection
*
iface
,
REFIID
riid
,
LPOLESTR
*
rgszNames
,
UINT
cNames
,
LCID
lcid
,
DISPID
*
rgDispId
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
ITypeInfo
*
typeinfo
;
HRESULT
hr
;
TRACE
(
"(%p)->(%s %p %u %u %p)
\n
"
,
This
,
debugstr_guid
(
riid
),
rgszNames
,
cNames
,
lcid
,
rgDispId
);
hr
=
get_typeinfo
(
IFileCollection_tid
,
&
typeinfo
);
if
(
SUCCEEDED
(
hr
))
{
hr
=
ITypeInfo_GetIDsOfNames
(
typeinfo
,
rgszNames
,
cNames
,
rgDispId
);
ITypeInfo_Release
(
typeinfo
);
}
return
hr
;
}
static
HRESULT
WINAPI
filecoll_Invoke
(
IFileCollection
*
iface
,
DISPID
dispIdMember
,
REFIID
riid
,
LCID
lcid
,
WORD
wFlags
,
DISPPARAMS
*
pDispParams
,
VARIANT
*
pVarResult
,
EXCEPINFO
*
pExcepInfo
,
UINT
*
puArgErr
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
ITypeInfo
*
typeinfo
;
HRESULT
hr
;
TRACE
(
"(%p)->(%d %s %d %d %p %p %p %p)
\n
"
,
This
,
dispIdMember
,
debugstr_guid
(
riid
),
lcid
,
wFlags
,
pDispParams
,
pVarResult
,
pExcepInfo
,
puArgErr
);
hr
=
get_typeinfo
(
IFileCollection_tid
,
&
typeinfo
);
if
(
SUCCEEDED
(
hr
))
{
hr
=
ITypeInfo_Invoke
(
typeinfo
,
iface
,
dispIdMember
,
wFlags
,
pDispParams
,
pVarResult
,
pExcepInfo
,
puArgErr
);
ITypeInfo_Release
(
typeinfo
);
}
return
hr
;
}
static
HRESULT
WINAPI
filecoll_get_Item
(
IFileCollection
*
iface
,
VARIANT
Key
,
IFile
**
file
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
FIXME
(
"(%p)->(%p)
\n
"
,
This
,
file
);
return
E_NOTIMPL
;
}
static
HRESULT
WINAPI
filecoll_get__NewEnum
(
IFileCollection
*
iface
,
IUnknown
**
ppenum
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
FIXME
(
"(%p)->(%p)
\n
"
,
This
,
ppenum
);
return
E_NOTIMPL
;
}
static
HRESULT
WINAPI
filecoll_get_Count
(
IFileCollection
*
iface
,
LONG
*
count
)
{
struct
filecollection
*
This
=
impl_from_IFileCollection
(
iface
);
FIXME
(
"(%p)->(%p)
\n
"
,
This
,
count
);
return
E_NOTIMPL
;
}
static
const
IFileCollectionVtbl
filecollectionvtbl
=
{
filecoll_QueryInterface
,
filecoll_AddRef
,
filecoll_Release
,
filecoll_GetTypeInfoCount
,
filecoll_GetTypeInfo
,
filecoll_GetIDsOfNames
,
filecoll_Invoke
,
filecoll_get_Item
,
filecoll_get__NewEnum
,
filecoll_get_Count
};
static
HRESULT
create_filecoll
(
IFileCollection
**
files
)
{
struct
filecollection
*
This
;
*
files
=
NULL
;
This
=
heap_alloc
(
sizeof
(
*
This
));
if
(
!
This
)
return
E_OUTOFMEMORY
;
This
->
IFileCollection_iface
.
lpVtbl
=
&
filecollectionvtbl
;
This
->
ref
=
1
;
*
files
=
&
This
->
IFileCollection_iface
;
return
S_OK
;
}
static
HRESULT
WINAPI
folder_QueryInterface
(
IFolder
*
iface
,
REFIID
riid
,
void
**
obj
)
static
HRESULT
WINAPI
folder_QueryInterface
(
IFolder
*
iface
,
REFIID
riid
,
void
**
obj
)
{
{
struct
folder
*
This
=
impl_from_IFolder
(
iface
);
struct
folder
*
This
=
impl_from_IFolder
(
iface
);
...
@@ -1041,8 +1201,13 @@ static HRESULT WINAPI folder_get_SubFolders(IFolder *iface, IFolderCollection **
...
@@ -1041,8 +1201,13 @@ static HRESULT WINAPI folder_get_SubFolders(IFolder *iface, IFolderCollection **
static
HRESULT
WINAPI
folder_get_Files
(
IFolder
*
iface
,
IFileCollection
**
files
)
static
HRESULT
WINAPI
folder_get_Files
(
IFolder
*
iface
,
IFileCollection
**
files
)
{
{
struct
folder
*
This
=
impl_from_IFolder
(
iface
);
struct
folder
*
This
=
impl_from_IFolder
(
iface
);
FIXME
(
"(%p)->(%p): stub
\n
"
,
This
,
files
);
return
E_NOTIMPL
;
TRACE
(
"(%p)->(%p)
\n
"
,
This
,
files
);
if
(
!
files
)
return
E_POINTER
;
return
create_filecoll
(
files
);
}
}
static
HRESULT
WINAPI
folder_CreateTextFile
(
IFolder
*
iface
,
BSTR
filename
,
VARIANT_BOOL
overwrite
,
static
HRESULT
WINAPI
folder_CreateTextFile
(
IFolder
*
iface
,
BSTR
filename
,
VARIANT_BOOL
overwrite
,
...
...
dlls/scrrun/scrrun.c
View file @
07ded6bb
...
@@ -107,7 +107,8 @@ static REFIID tid_ids[] = {
...
@@ -107,7 +107,8 @@ static REFIID tid_ids[] = {
&
IID_IFolder
,
&
IID_IFolder
,
&
IID_IFolderCollection
,
&
IID_IFolderCollection
,
&
IID_ITextStream
,
&
IID_ITextStream
,
&
IID_IFile
&
IID_IFile
,
&
IID_IFileCollection
};
};
static
HRESULT
load_typelib
(
void
)
static
HRESULT
load_typelib
(
void
)
...
...
dlls/scrrun/scrrun_private.h
View file @
07ded6bb
...
@@ -30,6 +30,7 @@ typedef enum tid_t
...
@@ -30,6 +30,7 @@ typedef enum tid_t
IFolderCollection_tid
,
IFolderCollection_tid
,
ITextStream_tid
,
ITextStream_tid
,
IFile_tid
,
IFile_tid
,
IFileCollection_tid
,
LAST_tid
LAST_tid
}
tid_t
;
}
tid_t
;
...
...
dlls/scrrun/tests/filesystem.c
View file @
07ded6bb
...
@@ -900,6 +900,31 @@ if (hr == S_OK) {
...
@@ -900,6 +900,31 @@ if (hr == S_OK) {
IFolderCollection_Release
(
folders
);
IFolderCollection_Release
(
folders
);
}
}
static
void
test_FileCollection
(
void
)
{
IFileCollection
*
files
;
WCHAR
buffW
[
MAX_PATH
];
IFolder
*
folder
;
HRESULT
hr
;
BSTR
str
;
GetWindowsDirectoryW
(
buffW
,
MAX_PATH
);
str
=
SysAllocString
(
buffW
);
hr
=
IFileSystem3_GetFolder
(
fs3
,
str
,
&
folder
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
SysFreeString
(
str
);
hr
=
IFolder_get_Files
(
folder
,
NULL
);
ok
(
hr
==
E_POINTER
,
"got 0x%08x
\n
"
,
hr
);
hr
=
IFolder_get_Files
(
folder
,
&
files
);
ok
(
hr
==
S_OK
,
"got 0x%08x
\n
"
,
hr
);
IFileCollection_Release
(
files
);
IFolder_Release
(
folder
);
}
START_TEST
(
filesystem
)
START_TEST
(
filesystem
)
{
{
HRESULT
hr
;
HRESULT
hr
;
...
@@ -926,6 +951,7 @@ START_TEST(filesystem)
...
@@ -926,6 +951,7 @@ START_TEST(filesystem)
test_BuildPath
();
test_BuildPath
();
test_GetFolder
();
test_GetFolder
();
test_FolderCollection
();
test_FolderCollection
();
test_FileCollection
();
IFileSystem3_Release
(
fs3
);
IFileSystem3_Release
(
fs3
);
...
...
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