Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
bb529a49
Commit
bb529a49
authored
Nov 17, 2007
by
Rob Shearman
Committed by
Alexandre Julliard
Nov 19, 2007
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
credui: Split CredDialogProc out into separate functions.
parent
678d3965
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
85 additions
and
75 deletions
+85
-75
credui_main.c
dlls/credui/credui_main.c
+85
-75
No files found.
dlls/credui/credui_main.c
View file @
bb529a49
...
@@ -130,6 +130,89 @@ struct cred_dialog_params
...
@@ -130,6 +130,89 @@ struct cred_dialog_params
DWORD
dwFlags
;
DWORD
dwFlags
;
};
};
static
BOOL
CredDialogInit
(
HWND
hwndDlg
,
struct
cred_dialog_params
*
params
)
{
SetWindowLongPtrW
(
hwndDlg
,
DWLP_USER
,
(
LONG_PTR
)
params
);
if
(
params
->
pszMessageText
)
SetDlgItemTextW
(
hwndDlg
,
IDC_MESSAGE
,
params
->
pszMessageText
);
else
{
WCHAR
format
[
256
];
WCHAR
message
[
256
];
LoadStringW
(
hinstCredUI
,
IDS_MESSAGEFORMAT
,
format
,
sizeof
(
format
)
/
sizeof
(
format
[
0
]));
snprintfW
(
message
,
sizeof
(
message
)
/
sizeof
(
message
[
0
]),
format
,
params
->
pszTargetName
);
SetDlgItemTextW
(
hwndDlg
,
IDC_MESSAGE
,
message
);
}
SetDlgItemTextW
(
hwndDlg
,
IDC_USERNAME
,
params
->
pszUsername
);
SetDlgItemTextW
(
hwndDlg
,
IDC_PASSWORD
,
params
->
pszPassword
);
if
(
params
->
pszUsername
[
0
])
SetFocus
(
GetDlgItem
(
hwndDlg
,
IDC_PASSWORD
));
else
SetFocus
(
GetDlgItem
(
hwndDlg
,
IDC_USERNAME
));
if
(
params
->
pszCaptionText
)
SetWindowTextW
(
hwndDlg
,
params
->
pszCaptionText
);
else
{
WCHAR
format
[
256
];
WCHAR
title
[
256
];
LoadStringW
(
hinstCredUI
,
IDS_TITLEFORMAT
,
format
,
sizeof
(
format
)
/
sizeof
(
format
[
0
]));
snprintfW
(
title
,
sizeof
(
title
)
/
sizeof
(
title
[
0
]),
format
,
params
->
pszTargetName
);
SetWindowTextW
(
hwndDlg
,
title
);
}
if
(
params
->
dwFlags
&
(
CREDUI_FLAGS_DO_NOT_PERSIST
|
CREDUI_FLAGS_PERSIST
))
ShowWindow
(
GetDlgItem
(
hwndDlg
,
IDC_SAVE
),
SW_HIDE
);
else
if
(
params
->
fSave
)
CheckDlgButton
(
hwndDlg
,
IDC_SAVE
,
BST_CHECKED
);
return
FALSE
;
}
static
void
CredDialogCommandOk
(
HWND
hwndDlg
,
struct
cred_dialog_params
*
params
)
{
HWND
hwndUsername
=
GetDlgItem
(
hwndDlg
,
IDC_USERNAME
);
LPWSTR
user
;
INT
len
;
INT
len2
;
len
=
GetWindowTextLengthW
(
hwndUsername
);
user
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
len
+
1
)
*
sizeof
(
WCHAR
));
GetWindowTextW
(
hwndUsername
,
user
,
len
+
1
);
if
(
!
user
[
0
])
{
HeapFree
(
GetProcessHeap
(),
0
,
user
);
return
;
}
if
(
!
strchrW
(
user
,
'\\'
)
&&
!
strchrW
(
user
,
'@'
))
{
INT
len_target
=
strlenW
(
params
->
pszTargetName
);
memcpy
(
params
->
pszUsername
,
params
->
pszTargetName
,
min
(
len_target
,
params
->
ulUsernameMaxChars
)
*
sizeof
(
WCHAR
));
if
(
len_target
+
1
<
params
->
ulUsernameMaxChars
)
params
->
pszUsername
[
len_target
]
=
'\\'
;
if
(
len_target
+
2
<
params
->
ulUsernameMaxChars
)
params
->
pszUsername
[
len_target
+
1
]
=
'\0'
;
}
else
if
(
params
->
ulUsernameMaxChars
>
0
)
params
->
pszUsername
[
0
]
=
'\0'
;
len2
=
strlenW
(
params
->
pszUsername
);
memcpy
(
params
->
pszUsername
+
len2
,
user
,
min
(
len
,
params
->
ulUsernameMaxChars
-
len2
)
*
sizeof
(
WCHAR
));
if
(
params
->
ulUsernameMaxChars
)
params
->
pszUsername
[
len2
+
min
(
len
,
params
->
ulUsernameMaxChars
-
len2
-
1
)]
=
'\0'
;
HeapFree
(
GetProcessHeap
(),
0
,
user
);
GetDlgItemTextW
(
hwndDlg
,
IDC_PASSWORD
,
params
->
pszPassword
,
params
->
ulPasswordMaxChars
);
EndDialog
(
hwndDlg
,
IDOK
);
}
static
INT_PTR
CALLBACK
CredDialogProc
(
HWND
hwndDlg
,
UINT
uMsg
,
WPARAM
wParam
,
static
INT_PTR
CALLBACK
CredDialogProc
(
HWND
hwndDlg
,
UINT
uMsg
,
WPARAM
wParam
,
LPARAM
lParam
)
LPARAM
lParam
)
{
{
...
@@ -139,42 +222,7 @@ static INT_PTR CALLBACK CredDialogProc(HWND hwndDlg, UINT uMsg, WPARAM wParam,
...
@@ -139,42 +222,7 @@ static INT_PTR CALLBACK CredDialogProc(HWND hwndDlg, UINT uMsg, WPARAM wParam,
{
{
struct
cred_dialog_params
*
params
=
(
struct
cred_dialog_params
*
)
lParam
;
struct
cred_dialog_params
*
params
=
(
struct
cred_dialog_params
*
)
lParam
;
SetWindowLongPtrW
(
hwndDlg
,
DWLP_USER
,
(
LONG_PTR
)
params
);
return
CredDialogInit
(
hwndDlg
,
params
);
if
(
params
->
pszMessageText
)
SetDlgItemTextW
(
hwndDlg
,
IDC_MESSAGE
,
params
->
pszMessageText
);
else
{
WCHAR
format
[
256
];
WCHAR
message
[
256
];
LoadStringW
(
hinstCredUI
,
IDS_MESSAGEFORMAT
,
format
,
sizeof
(
format
)
/
sizeof
(
format
[
0
]));
snprintfW
(
message
,
sizeof
(
message
)
/
sizeof
(
message
[
0
]),
format
,
params
->
pszTargetName
);
SetDlgItemTextW
(
hwndDlg
,
IDC_MESSAGE
,
message
);
}
SetDlgItemTextW
(
hwndDlg
,
IDC_USERNAME
,
params
->
pszUsername
);
SetDlgItemTextW
(
hwndDlg
,
IDC_PASSWORD
,
params
->
pszPassword
);
if
(
params
->
pszUsername
[
0
])
SetFocus
(
GetDlgItem
(
hwndDlg
,
IDC_PASSWORD
));
else
SetFocus
(
GetDlgItem
(
hwndDlg
,
IDC_USERNAME
));
if
(
params
->
pszCaptionText
)
SetWindowTextW
(
hwndDlg
,
params
->
pszCaptionText
);
else
{
WCHAR
format
[
256
];
WCHAR
title
[
256
];
LoadStringW
(
hinstCredUI
,
IDS_TITLEFORMAT
,
format
,
sizeof
(
format
)
/
sizeof
(
format
[
0
]));
snprintfW
(
title
,
sizeof
(
title
)
/
sizeof
(
title
[
0
]),
format
,
params
->
pszTargetName
);
SetWindowTextW
(
hwndDlg
,
title
);
}
if
(
params
->
dwFlags
&
(
CREDUI_FLAGS_DO_NOT_PERSIST
|
CREDUI_FLAGS_PERSIST
))
ShowWindow
(
GetDlgItem
(
hwndDlg
,
IDC_SAVE
),
SW_HIDE
);
else
if
(
params
->
fSave
)
CheckDlgButton
(
hwndDlg
,
IDC_SAVE
,
BST_CHECKED
);
return
FALSE
;
}
}
case
WM_COMMAND
:
case
WM_COMMAND
:
switch
(
wParam
)
switch
(
wParam
)
...
@@ -183,45 +231,7 @@ static INT_PTR CALLBACK CredDialogProc(HWND hwndDlg, UINT uMsg, WPARAM wParam,
...
@@ -183,45 +231,7 @@ static INT_PTR CALLBACK CredDialogProc(HWND hwndDlg, UINT uMsg, WPARAM wParam,
{
{
struct
cred_dialog_params
*
params
=
struct
cred_dialog_params
*
params
=
(
struct
cred_dialog_params
*
)
GetWindowLongPtrW
(
hwndDlg
,
DWLP_USER
);
(
struct
cred_dialog_params
*
)
GetWindowLongPtrW
(
hwndDlg
,
DWLP_USER
);
HWND
hwndUsername
=
GetDlgItem
(
hwndDlg
,
IDC_USERNAME
);
CredDialogCommandOk
(
hwndDlg
,
params
);
LPWSTR
user
;
INT
len
;
INT
len2
;
len
=
GetWindowTextLengthW
(
hwndUsername
);
user
=
HeapAlloc
(
GetProcessHeap
(),
0
,
(
len
+
1
)
*
sizeof
(
WCHAR
));
GetWindowTextW
(
hwndUsername
,
user
,
len
+
1
);
if
(
!
user
[
0
])
{
HeapFree
(
GetProcessHeap
(),
0
,
user
);
return
TRUE
;
}
if
(
!
strchrW
(
user
,
'\\'
)
&&
!
strchrW
(
user
,
'@'
))
{
INT
len_target
=
strlenW
(
params
->
pszTargetName
);
memcpy
(
params
->
pszUsername
,
params
->
pszTargetName
,
min
(
len_target
,
params
->
ulUsernameMaxChars
)
*
sizeof
(
WCHAR
));
if
(
len_target
+
1
<
params
->
ulUsernameMaxChars
)
params
->
pszUsername
[
len_target
]
=
'\\'
;
if
(
len_target
+
2
<
params
->
ulUsernameMaxChars
)
params
->
pszUsername
[
len_target
+
1
]
=
'\0'
;
}
else
if
(
params
->
ulUsernameMaxChars
>
0
)
params
->
pszUsername
[
0
]
=
'\0'
;
len2
=
strlenW
(
params
->
pszUsername
);
memcpy
(
params
->
pszUsername
+
len2
,
user
,
min
(
len
,
params
->
ulUsernameMaxChars
-
len2
)
*
sizeof
(
WCHAR
));
if
(
params
->
ulUsernameMaxChars
)
params
->
pszUsername
[
len2
+
min
(
len
,
params
->
ulUsernameMaxChars
-
len2
-
1
)]
=
'\0'
;
HeapFree
(
GetProcessHeap
(),
0
,
user
);
GetDlgItemTextW
(
hwndDlg
,
IDC_PASSWORD
,
params
->
pszPassword
,
params
->
ulPasswordMaxChars
);
EndDialog
(
hwndDlg
,
IDOK
);
return
TRUE
;
return
TRUE
;
}
}
case
MAKELONG
(
IDCANCEL
,
BN_CLICKED
):
case
MAKELONG
(
IDCANCEL
,
BN_CLICKED
):
...
...
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