]> git.saurik.com Git - wxWidgets.git/blobdiff - src/palmos/mslu.cpp
Final MSW/PalmOS split. Remove dump copies of MSW specific code.
[wxWidgets.git] / src / palmos / mslu.cpp
diff --git a/src/palmos/mslu.cpp b/src/palmos/mslu.cpp
deleted file mode 100644 (file)
index 5c207b4..0000000
+++ /dev/null
@@ -1,160 +0,0 @@
-/////////////////////////////////////////////////////////////////////////////
-// Name:        msw/mslu.cpp
-// Purpose:     Fixes for bugs in MSLU
-// Author:      Vaclav Slavik
-// Modified by:
-// Created:     2002/02/17
-// RCS-ID:      $Id$
-// Copyright:   (c) 2002 Vaclav Slavik
-// Licence:     wxWindows licence
-/////////////////////////////////////////////////////////////////////////////
-
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-#pragma implementation
-#endif
-
-// For compilers that support precompilation, includes "wx.h".
-#include "wx/wxprec.h"
-
-// This may or may not apply to Palm OS in the future, but for right now Unicode
-// is not supported.
-#ifndef __WXPALMOS__
-
-#ifdef __BORLANDC__
-#pragma hdrstop
-#include <dir.h>
-#endif
-
-#ifndef WX_PRECOMP
-    #include "wx/defs.h"
-#endif
-
-#if wxUSE_UNICODE_MSLU
-
-//------------------------------------------------------------------------
-//
-// NB: MSLU only covers Win32 API, it doesn't provide Unicode implementation of
-//     libc functions. Unfortunately, some of MSVCRT wchar_t functions
-//     (e.g. _wopen) don't work on Windows 9x, so we have to workaround it
-//     by calling the char version. We still want to use wchar_t version on
-//     NT/2000/XP, though, because they allow for Unicode file names.
-//
-//     Moreover, there are bugs in unicows.dll, of course. We have to
-//     workaround them, too.
-//
-//------------------------------------------------------------------------
-
-#include "wx/msw/private.h"
-#include "wx/msw/mslu.h"
-
-#include <stdio.h>
-#include <io.h>
-#include <sys/stat.h>
-
-#ifdef __VISUALC__
-    #include <direct.h>
-#endif
-
-// Undef redirection macros defined in wx/msw/mslu.h:
-#undef DrawStateW
-#undef GetOpenFileNameW
-#undef GetSaveFileNameW
-
-//------------------------------------------------------------------------
-// Wrongly implemented functions from unicows.dll
-//------------------------------------------------------------------------
-
-#if wxUSE_GUI
-
-WXDLLEXPORT int  wxMSLU_DrawStateW(WXHDC dc, WXHBRUSH br, WXFARPROC outputFunc,
-                                   WXLPARAM lData, WXWPARAM wData,
-                                   int x, int y, int cx, int cy,
-                                   unsigned int flags)
-{
-    // VS: There's yet another bug in MSLU: DrawStateW behaves like if it was
-    //     expecting char*, not wchar_t* input. We have to use DrawStateA
-    //     explicitly.
-
-    if ( wxUsingUnicowsDll() )
-    {
-        return DrawStateA((HDC)dc, (HBRUSH)br, (DRAWSTATEPROC)outputFunc,
-                          (LPARAM)(const char*)
-                                wxConvLocal.cWX2MB((const wxChar*)lData),
-                          wData, x, y, cx, cy, flags);
-    }
-    else
-    {
-        return DrawStateW((HDC)dc, (HBRUSH)br, (DRAWSTATEPROC)outputFunc,
-                          lData, wData, x, y, cx, cy, flags);
-    }
-}
-
-static void wxFixOPENFILENAME(LPOPENFILENAME ofn)
-{
-#ifdef OFN_EXPLORER
-    // VS: there's a bug in unicows.dll - when multiple files are selected,
-    //     of.nFileOffset doesn't point to the first filename but rather to
-    //     the last component of directory name. This bug is known to MSLU
-    //     developers, but they are not going to fix it: "this is a true
-    //     limitation, that we have decided to live with" and "working
-    //     harder on this case just did not seem worth the effort"...
-    //
-    //     Our only option is to try to fix it ourselves:
-
-    if ( (ofn->Flags & OFN_ALLOWMULTISELECT) &&
-         ofn->lpstrFile[ofn->nFileOffset-1] != wxT('\0') )
-    {
-        if ( wxDirExists(ofn->lpstrFile) )
-        {
-            // 1st component is dir => multiple files selected
-            ofn->nFileOffset = wxStrlen(ofn->lpstrFile)+1;
-        }
-    }
-#endif
-}
-
-WXDLLEXPORT int wxMSLU_GetOpenFileNameW(void *ofn)
-{
-    int ret = GetOpenFileName((LPOPENFILENAME)ofn);
-    if ( wxUsingUnicowsDll() && ret != 0 )
-        wxFixOPENFILENAME((LPOPENFILENAME)ofn);
-    return ret;
-}
-
-WXDLLEXPORT int wxMSLU_GetSaveFileNameW(void *ofn)
-{
-    int ret = GetSaveFileName((LPOPENFILENAME)ofn);
-    if ( wxUsingUnicowsDll() && ret != 0 )
-        wxFixOPENFILENAME((LPOPENFILENAME)ofn);
-    return ret;
-}
-
-#endif // wxUSE_GUI
-
-//------------------------------------------------------------------------
-// Missing libc file manipulation functions in Win9x
-//------------------------------------------------------------------------
-
-#if wxUSE_BASE
-
-WXDLLEXPORT int wxMSLU__trename(const wxChar *oldname, const wxChar *newname)
-{
-    if ( wxUsingUnicowsDll() )
-        return rename(wxConvFile.cWX2MB(oldname), wxConvFile.cWX2MB(newname));
-    else
-        return _trename(oldname, newname);
-}
-
-WXDLLEXPORT int wxMSLU__tremove(const wxChar *name)
-{
-    if ( wxUsingUnicowsDll() )
-        return remove(wxConvFile.cWX2MB(name));
-    else
-        return _tremove(name);
-}
-
-#endif // wxUSE_BASE
-
-#endif // wxUSE_UNICODE_MSLU
-
-#endif // __WXPALMOS__