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
5e125e7d
Commit
5e125e7d
authored
Jul 25, 2007
by
Eric Pouech
Committed by
Alexandre Julliard
Jul 26, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Implemented ActivationContextDetailedInformation option in…
ntdll: Implemented ActivationContextDetailedInformation option in RtlQueryInformationActivationContext.
parent
3a71513d
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
53 additions
and
0 deletions
+53
-0
actctx.c
dlls/ntdll/actctx.c
+53
-0
No files found.
dlls/ntdll/actctx.c
View file @
5e125e7d
...
...
@@ -2192,6 +2192,7 @@ NTSTATUS WINAPI RtlQueryInformationActivationContext( ULONG flags, HANDLE handle
ULONG
class
,
PVOID
buffer
,
SIZE_T
bufsize
,
SIZE_T
*
retlen
)
{
ACTIVATION_CONTEXT
*
actctx
;
NTSTATUS
status
;
TRACE
(
"%08x %p %p %u %p %ld %p
\n
"
,
flags
,
handle
,
...
...
@@ -2215,6 +2216,58 @@ NTSTATUS WINAPI RtlQueryInformationActivationContext( ULONG flags, HANDLE handle
break
;
case
ActivationContextDetailedInformation
:
{
ACTIVATION_CONTEXT_DETAILED_INFORMATION
*
acdi
=
buffer
;
struct
assembly
*
assembly
=
NULL
;
SIZE_T
len
,
manifest_len
=
0
,
config_len
=
0
,
appdir_len
=
0
;
LPWSTR
ptr
;
if
(
!
(
actctx
=
check_actctx
(
handle
)))
return
STATUS_INVALID_PARAMETER
;
if
(
actctx
->
num_assemblies
)
assembly
=
actctx
->
assemblies
;
if
(
assembly
&&
assembly
->
manifest
.
info
)
manifest_len
=
strlenW
(
assembly
->
manifest
.
info
)
+
1
;
if
(
actctx
->
config
.
info
)
config_len
=
strlenW
(
actctx
->
config
.
info
)
+
1
;
if
(
actctx
->
appdir
.
info
)
appdir_len
=
strlenW
(
actctx
->
appdir
.
info
)
+
1
;
len
=
sizeof
(
*
acdi
)
+
(
manifest_len
+
config_len
+
appdir_len
)
*
sizeof
(
WCHAR
);
if
(
retlen
)
*
retlen
=
len
;
if
(
!
buffer
||
bufsize
<
len
)
return
STATUS_BUFFER_TOO_SMALL
;
acdi
->
dwFlags
=
0
;
acdi
->
ulFormatVersion
=
assembly
?
1
:
0
;
/* FIXME */
acdi
->
ulAssemblyCount
=
actctx
->
num_assemblies
;
acdi
->
ulRootManifestPathType
=
assembly
?
assembly
->
manifest
.
type
:
0
/* FIXME */
;
acdi
->
ulRootManifestPathChars
=
assembly
&&
assembly
->
manifest
.
info
?
manifest_len
-
1
:
0
;
acdi
->
ulRootConfigurationPathType
=
actctx
->
config
.
type
;
acdi
->
ulRootConfigurationPathChars
=
actctx
->
config
.
info
?
config_len
-
1
:
0
;
acdi
->
ulAppDirPathType
=
actctx
->
appdir
.
type
;
acdi
->
ulAppDirPathChars
=
actctx
->
appdir
.
info
?
appdir_len
-
1
:
0
;
ptr
=
(
LPWSTR
)(
acdi
+
1
);
if
(
manifest_len
)
{
acdi
->
lpRootManifestPath
=
ptr
;
memcpy
(
ptr
,
assembly
->
manifest
.
info
,
manifest_len
*
sizeof
(
WCHAR
));
ptr
+=
manifest_len
;
}
else
acdi
->
lpRootManifestPath
=
NULL
;
if
(
config_len
)
{
acdi
->
lpRootConfigurationPath
=
ptr
;
memcpy
(
ptr
,
actctx
->
config
.
info
,
config_len
*
sizeof
(
WCHAR
));
ptr
+=
config_len
;
}
else
acdi
->
lpRootConfigurationPath
=
NULL
;
if
(
appdir_len
)
{
acdi
->
lpAppDirPath
=
ptr
;
memcpy
(
ptr
,
actctx
->
appdir
.
info
,
appdir_len
*
sizeof
(
WCHAR
));
}
else
acdi
->
lpAppDirPath
=
NULL
;
}
break
;
case
AssemblyDetailedInformationInActivationContext
:
case
FileInformationInAssemblyOfAssemblyInActivationContext
:
default:
...
...
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