Set focus to the dialog in EndDialog.

diff --git a/windows/defdlg.c b/windows/defdlg.c
index 05f234c..133dd09 100644
--- a/windows/defdlg.c
+++ b/windows/defdlg.c
@@ -53,7 +53,11 @@
 {
     if (!infoPtr->hwndFocus || IsIconic(hwnd)) return FALSE;
     if (!IsWindow( infoPtr->hwndFocus )) return FALSE;
-    DEFDLG_SetFocus( hwnd, infoPtr->hwndFocus );
+
+    /* Don't set the focus back to controls if EndDialog is already called.*/
+    if (!(infoPtr->flags & DF_END))
+       DEFDLG_SetFocus( hwnd, infoPtr->hwndFocus );
+
     /* This used to set infoPtr->hwndFocus to NULL for no apparent reason,
        sometimes losing focus when receiving WM_SETFOCUS messages. */
     return TRUE;
diff --git a/windows/dialog.c b/windows/dialog.c
index c5e4c79..a5d422e 100644
--- a/windows/dialog.c
+++ b/windows/dialog.c
@@ -1073,6 +1073,11 @@
         dlgInfo->flags |= DF_END;
     }
 
+    /* Windows sets the focus to the dialog itself first in EndDialog */
+
+    if (IsChild(hwnd, GetFocus()))
+       SetFocus(wndPtr->hwndSelf);
+
     /* Paint Shop Pro 4.14 calls EndDialog for a CreateDialog* dialog,
      * which isn't "normal". Only DialogBox* dialogs may be EndDialog()ed.
      * Just hide the window 
@@ -1163,6 +1168,7 @@
                             SendMessageA( hwndControl, WM_LBUTTONUP, 0, 0);
                         }
                         RetVal = TRUE;
+			WIN_ReleaseWndPtr(wndPtr);
                         break;
                     }
                 }
@@ -1182,6 +1188,10 @@
 		hwndControl = GetParent( hwndControl );
 		if (hwndControl == hwndDlg)
 		{
+		    if(hwnd==hwndDlg){  /* prevent endless loop */
+		        hwndNext=hwnd;
+			break;
+		    }
 		    hwndNext = GetWindow( hwndDlg, GW_CHILD );
 		}
 		else