+++ /dev/null
-/////////////////////////////////////////////////////////////////////////////
-// Name: palmos/dialup.cpp
-// Purpose: Palm OS implementation of network/dialup classes and functions
-// Author: Vadim Zeitlin
-// Modified by:
-// Created: 07.07.99
-// RCS-ID: $Id$
-// Copyright: (c) Vadim Zeitlin
-// Licence: wxWindows licence
-/////////////////////////////////////////////////////////////////////////////
-
-// ============================================================================
-// declarations
-// ============================================================================
-
-// ----------------------------------------------------------------------------
-// headers
-// ----------------------------------------------------------------------------
-
-// for compilers that support precompilation, includes "wx.h".
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
- #pragma hdrstop
-#endif
-
-#if wxUSE_DIALUP_MANAGER
-
-#ifndef WX_PRECOMP
- #include "wx/log.h"
- #include "wx/intl.h"
- #include "wx/event.h"
-#endif
-
-#include "wx/timer.h"
-#include "wx/app.h"
-#include "wx/generic/choicdgg.h"
-
-#include "wx/dynlib.h"
-#include "wx/dialup.h"
-
-DEFINE_EVENT_TYPE(wxEVT_DIALUP_CONNECTED)
-DEFINE_EVENT_TYPE(wxEVT_DIALUP_DISCONNECTED)
-
-// This needs to be written using Palm OS Network API calls, but for now this
-// will do.
-#if (!defined(__WXPALMOS__)
-
-#include <ras.h>
-#include <raserror.h>
-
-#include <wininet.h>
-
-// Not in VC++ 5
-#ifndef INTERNET_CONNECTION_LAN
-#define INTERNET_CONNECTION_LAN 2
-#endif
-#ifndef INTERNET_CONNECTION_PROXY
-#define INTERNET_CONNECTION_PROXY 4
-#endif
-
-// ----------------------------------------------------------------------------
-// constants
-// ----------------------------------------------------------------------------
-
-// this message is sent by the secondary thread when RAS status changes
-#define wxWM_RAS_STATUS_CHANGED (WM_USER + 10010)
-#define wxWM_RAS_DIALING_PROGRESS (WM_USER + 10011)
-
-// ----------------------------------------------------------------------------
-// types
-// ----------------------------------------------------------------------------
-
-// the signatures of RAS functions: all this is quite heavy, but we must do it
-// to allow running wxWin programs on machine which don't have RAS installed
-// (this does exist) - if we link with rasapi32.lib, the program will fail on
-// startup because of the missing DLL...
-
-#ifndef UNICODE
- typedef DWORD (APIENTRY * RASDIAL)( LPRASDIALEXTENSIONS, LPCSTR, LPRASDIALPARAMSA, DWORD, LPVOID, LPHRASCONN );
- typedef DWORD (APIENTRY * RASENUMCONNECTIONS)( LPRASCONNA, LPDWORD, LPDWORD );
- typedef DWORD (APIENTRY * RASENUMENTRIES)( LPCSTR, LPCSTR, LPRASENTRYNAMEA, LPDWORD, LPDWORD );
- typedef DWORD (APIENTRY * RASGETCONNECTSTATUS)( HRASCONN, LPRASCONNSTATUSA );
- typedef DWORD (APIENTRY * RASGETERRORSTRING)( UINT, LPSTR, DWORD );
- typedef DWORD (APIENTRY * RASHANGUP)( HRASCONN );
- typedef DWORD (APIENTRY * RASGETPROJECTIONINFO)( HRASCONN, RASPROJECTION, LPVOID, LPDWORD );
- typedef DWORD (APIENTRY * RASCREATEPHONEBOOKENTRY)( HWND, LPCSTR );
- typedef DWORD (APIENTRY * RASEDITPHONEBOOKENTRY)( HWND, LPCSTR, LPCSTR );
- typedef DWORD (APIENTRY * RASSETENTRYDIALPARAMS)( LPCSTR, LPRASDIALPARAMSA, BOOL );
- typedef DWORD (APIENTRY * RASGETENTRYDIALPARAMS)( LPCSTR, LPRASDIALPARAMSA, LPBOOL );
- typedef DWORD (APIENTRY * RASENUMDEVICES)( LPRASDEVINFOA, LPDWORD, LPDWORD );
- typedef DWORD (APIENTRY * RASGETCOUNTRYINFO)( LPRASCTRYINFOA, LPDWORD );
- typedef DWORD (APIENTRY * RASGETENTRYPROPERTIES)( LPCSTR, LPCSTR, LPRASENTRYA, LPDWORD, LPBYTE, LPDWORD );
- typedef DWORD (APIENTRY * RASSETENTRYPROPERTIES)( LPCSTR, LPCSTR, LPRASENTRYA, DWORD, LPBYTE, DWORD );
- typedef DWORD (APIENTRY * RASRENAMEENTRY)( LPCSTR, LPCSTR, LPCSTR );
- typedef DWORD (APIENTRY * RASDELETEENTRY)( LPCSTR, LPCSTR );
- typedef DWORD (APIENTRY * RASVALIDATEENTRYNAME)( LPCSTR, LPCSTR );
- typedef DWORD (APIENTRY * RASCONNECTIONNOTIFICATION)( HRASCONN, HANDLE, DWORD );
-
- static const wxChar gs_funcSuffix = _T('A');
-#else // Unicode
- typedef DWORD (APIENTRY * RASDIAL)( LPRASDIALEXTENSIONS, LPCWSTR, LPRASDIALPARAMSW, DWORD, LPVOID, LPHRASCONN );
- typedef DWORD (APIENTRY * RASENUMCONNECTIONS)( LPRASCONNW, LPDWORD, LPDWORD );
- typedef DWORD (APIENTRY * RASENUMENTRIES)( LPCWSTR, LPCWSTR, LPRASENTRYNAMEW, LPDWORD, LPDWORD );
- typedef DWORD (APIENTRY * RASGETCONNECTSTATUS)( HRASCONN, LPRASCONNSTATUSW );
- typedef DWORD (APIENTRY * RASGETERRORSTRING)( UINT, LPWSTR, DWORD );
- typedef DWORD (APIENTRY * RASHANGUP)( HRASCONN );
- typedef DWORD (APIENTRY * RASGETPROJECTIONINFO)( HRASCONN, RASPROJECTION, LPVOID, LPDWORD );
- typedef DWORD (APIENTRY * RASCREATEPHONEBOOKENTRY)( HWND, LPCWSTR );
- typedef DWORD (APIENTRY * RASEDITPHONEBOOKENTRY)( HWND, LPCWSTR, LPCWSTR );
- typedef DWORD (APIENTRY * RASSETENTRYDIALPARAMS)( LPCWSTR, LPRASDIALPARAMSW, BOOL );
- typedef DWORD (APIENTRY * RASGETENTRYDIALPARAMS)( LPCWSTR, LPRASDIALPARAMSW, LPBOOL );
- typedef DWORD (APIENTRY * RASENUMDEVICES)( LPRASDEVINFOW, LPDWORD, LPDWORD );
- typedef DWORD (APIENTRY * RASGETCOUNTRYINFO)( LPRASCTRYINFOW, LPDWORD );
- typedef DWORD (APIENTRY * RASGETENTRYPROPERTIES)( LPCWSTR, LPCWSTR, LPRASENTRYW, LPDWORD, LPBYTE, LPDWORD );
- typedef DWORD (APIENTRY * RASSETENTRYPROPERTIES)( LPCWSTR, LPCWSTR, LPRASENTRYW, DWORD, LPBYTE, DWORD );
- typedef DWORD (APIENTRY * RASRENAMEENTRY)( LPCWSTR, LPCWSTR, LPCWSTR );
- typedef DWORD (APIENTRY * RASDELETEENTRY)( LPCWSTR, LPCWSTR );
- typedef DWORD (APIENTRY * RASVALIDATEENTRYNAME)( LPCWSTR, LPCWSTR );
- typedef DWORD (APIENTRY * RASCONNECTIONNOTIFICATION)( HRASCONN, HANDLE, DWORD );
-
- static const wxChar gs_funcSuffix = _T('W');
-#endif // ASCII/Unicode
-
-// structure passed to the secondary thread
-struct WXDLLEXPORT wxRasThreadData
-{
- wxRasThreadData()
- {
- hWnd = 0;
- hEventRas =
- hEventQuit = 0;
- dialUpManager = NULL;
- }
-
- ~wxRasThreadData()
- {
- if ( hWnd )
- DestroyWindow(hWnd);
-
- if ( hEventQuit )
- CloseHandle(hEventQuit);
-
- if ( hEventRas )
- CloseHandle(hEventRas);
- }
-
- HWND hWnd; // window to send notifications to
- HANDLE hEventRas, // automatic event which RAS signals when status changes
- hEventQuit; // manual event which we signal when we terminate
-
- class WXDLLEXPORT wxDialUpManagerMSW *dialUpManager; // the owner
-};
-
-// ----------------------------------------------------------------------------
-// wxDialUpManager class for MSW
-// ----------------------------------------------------------------------------
-
-class WXDLLEXPORT wxDialUpManagerMSW : public wxDialUpManager
-{
-public:
- // ctor & dtor
- wxDialUpManagerMSW();
- virtual ~wxDialUpManagerMSW();
-
- // implement base class pure virtuals
- virtual bool IsOk() const;
- virtual size_t GetISPNames(wxArrayString& names) const;
- virtual bool Dial(const wxString& nameOfISP,
- const wxString& username,
- const wxString& password,
- bool async);
- virtual bool IsDialing() const;
- virtual bool CancelDialing();
- virtual bool HangUp();
- virtual bool IsAlwaysOnline() const;
- virtual bool IsOnline() const;
- virtual void SetOnlineStatus(bool isOnline = true);
- virtual bool EnableAutoCheckOnlineStatus(size_t nSeconds);
- virtual void DisableAutoCheckOnlineStatus();
- virtual void SetWellKnownHost(const wxString& hostname, int port);
- virtual void SetConnectCommand(const wxString& commandDial,
- const wxString& commandHangup);
-
- // for RasTimer
- void CheckRasStatus();
-
- // for wxRasStatusWindowProc
- void OnConnectStatusChange();
- void OnDialProgress(RASCONNSTATE rasconnstate, DWORD dwError);
-
- // for wxRasDialFunc
- static HWND GetRasWindow() { return ms_hwndRas; }
- static wxDialUpManagerMSW *GetDialer() { return ms_dialer; }
-
-private:
- // return the error string for the given RAS error code
- static wxString GetErrorString(DWORD error);
-
- // find the (first) handle of the active connection
- static HRASCONN FindActiveConnection();
-
- // notify the application about status change
- void NotifyApp(bool connected, bool fromOurselves = false) const;
-
- // destroy the thread data and the thread itself
- void CleanUpThreadData();
-
- // number of times EnableAutoCheckOnlineStatus() had been called minus the
- // number of times DisableAutoCheckOnlineStatus() had been called
- int m_autoCheckLevel;
-
- // timer used for polling RAS status
- class WXDLLEXPORT RasTimer : public wxTimer
- {
- public:
- RasTimer(wxDialUpManagerMSW *dialUpManager)
- { m_dialUpManager = dialUpManager; }
-
- virtual void Notify() { m_dialUpManager->CheckRasStatus(); }
-
- private:
- wxDialUpManagerMSW *m_dialUpManager;
-
- DECLARE_NO_COPY_CLASS(RasTimer)
- } m_timerStatusPolling;
-
- // thread handle for the thread sitting on connection change event
- HANDLE m_hThread;
-
- // data used by this thread and our hidden window to send messages between
- // each other
- wxRasThreadData *m_data;
-
- // the handle of rasapi32.dll when it's loaded
- wxDynamicLibrary m_dllRas;
-
- // the hidden window we use for passing messages between threads
- static HWND ms_hwndRas;
-
- // the handle of the connection we initiated or 0 if none
- static HRASCONN ms_hRasConnection;
-
- // the pointers to RAS functions
- static RASDIAL ms_pfnRasDial;
- static RASENUMCONNECTIONS ms_pfnRasEnumConnections;
- static RASENUMENTRIES ms_pfnRasEnumEntries;
- static RASGETCONNECTSTATUS ms_pfnRasGetConnectStatus;
- static RASGETERRORSTRING ms_pfnRasGetErrorString;
- static RASHANGUP ms_pfnRasHangUp;
- static RASGETPROJECTIONINFO ms_pfnRasGetProjectionInfo;
- static RASCREATEPHONEBOOKENTRY ms_pfnRasCreatePhonebookEntry;
- static RASEDITPHONEBOOKENTRY ms_pfnRasEditPhonebookEntry;
- static RASSETENTRYDIALPARAMS ms_pfnRasSetEntryDialParams;
- static RASGETENTRYDIALPARAMS ms_pfnRasGetEntryDialParams;
- static RASENUMDEVICES ms_pfnRasEnumDevices;
- static RASGETCOUNTRYINFO ms_pfnRasGetCountryInfo;
- static RASGETENTRYPROPERTIES ms_pfnRasGetEntryProperties;
- static RASSETENTRYPROPERTIES ms_pfnRasSetEntryProperties;
- static RASRENAMEENTRY ms_pfnRasRenameEntry;
- static RASDELETEENTRY ms_pfnRasDeleteEntry;
- static RASVALIDATEENTRYNAME ms_pfnRasValidateEntryName;
-
- // this function is not supported by Win95
- static RASCONNECTIONNOTIFICATION ms_pfnRasConnectionNotification;
-
- // if this flag is different from -1, it overrides IsOnline()
- static int ms_userSpecifiedOnlineStatus;
-
- // this flag tells us if we're online
- static int ms_isConnected;
-
- // this flag tells us whether a call to RasDial() is in progress
- static wxDialUpManagerMSW *ms_dialer;
-
- DECLARE_NO_COPY_CLASS(wxDialUpManagerMSW)
-};
-
-// ----------------------------------------------------------------------------
-// private functions
-// ----------------------------------------------------------------------------
-
-static LRESULT WINAPI wxRasStatusWindowProc(HWND hWnd, UINT message,
- WPARAM wParam, LPARAM lParam);
-
-static DWORD wxRasMonitorThread(wxRasThreadData *data);
-
-static void WINAPI wxRasDialFunc(UINT unMsg,
- RASCONNSTATE rasconnstate,
- DWORD dwError);
-
-// ============================================================================
-// implementation
-// ============================================================================
-
-// ----------------------------------------------------------------------------
-// init the static variables
-// ----------------------------------------------------------------------------
-
-HRASCONN wxDialUpManagerMSW::ms_hRasConnection = 0;
-
-HWND wxDialUpManagerMSW::ms_hwndRas = 0;
-
-RASDIAL wxDialUpManagerMSW::ms_pfnRasDial = 0;
-RASENUMCONNECTIONS wxDialUpManagerMSW::ms_pfnRasEnumConnections = 0;
-RASENUMENTRIES wxDialUpManagerMSW::ms_pfnRasEnumEntries = 0;
-RASGETCONNECTSTATUS wxDialUpManagerMSW::ms_pfnRasGetConnectStatus = 0;
-RASGETERRORSTRING wxDialUpManagerMSW::ms_pfnRasGetErrorString = 0;
-RASHANGUP wxDialUpManagerMSW::ms_pfnRasHangUp = 0;
-RASGETPROJECTIONINFO wxDialUpManagerMSW::ms_pfnRasGetProjectionInfo = 0;
-RASCREATEPHONEBOOKENTRY wxDialUpManagerMSW::ms_pfnRasCreatePhonebookEntry = 0;
-RASEDITPHONEBOOKENTRY wxDialUpManagerMSW::ms_pfnRasEditPhonebookEntry = 0;
-RASSETENTRYDIALPARAMS wxDialUpManagerMSW::ms_pfnRasSetEntryDialParams = 0;
-RASGETENTRYDIALPARAMS wxDialUpManagerMSW::ms_pfnRasGetEntryDialParams = 0;
-RASENUMDEVICES wxDialUpManagerMSW::ms_pfnRasEnumDevices = 0;
-RASGETCOUNTRYINFO wxDialUpManagerMSW::ms_pfnRasGetCountryInfo = 0;
-RASGETENTRYPROPERTIES wxDialUpManagerMSW::ms_pfnRasGetEntryProperties = 0;
-RASSETENTRYPROPERTIES wxDialUpManagerMSW::ms_pfnRasSetEntryProperties = 0;
-RASRENAMEENTRY wxDialUpManagerMSW::ms_pfnRasRenameEntry = 0;
-RASDELETEENTRY wxDialUpManagerMSW::ms_pfnRasDeleteEntry = 0;
-RASVALIDATEENTRYNAME wxDialUpManagerMSW::ms_pfnRasValidateEntryName = 0;
-RASCONNECTIONNOTIFICATION wxDialUpManagerMSW::ms_pfnRasConnectionNotification = 0;
-
-int wxDialUpManagerMSW::ms_userSpecifiedOnlineStatus = -1;
-int wxDialUpManagerMSW::ms_isConnected = -1;
-wxDialUpManagerMSW *wxDialUpManagerMSW::ms_dialer = NULL;
-
-// ----------------------------------------------------------------------------
-// ctor and dtor: the dynamic linking happens here
-// ----------------------------------------------------------------------------
-
-// the static creator function is implemented here
-wxDialUpManager *wxDialUpManager::Create()
-{
- return new wxDialUpManagerMSW;
-}
-
-#ifdef __VISUALC__
- // warning about "'this' : used in base member initializer list" - so what?
- #pragma warning(disable:4355)
-#endif // VC++
-
-wxDialUpManagerMSW::wxDialUpManagerMSW()
- : m_timerStatusPolling(this),
- m_dllRas(_T("RASAPI32"))
-{
- // initialize our data
- m_autoCheckLevel = 0;
- m_hThread = 0;
- m_data = new wxRasThreadData;
-
- if ( !m_dllRas.IsLoaded() )
- {
- wxLogError(_("Dial up functions are unavailable because the remote access service (RAS) is not installed on this machine. Please install it."));
- }
- else if ( !ms_pfnRasDial )
- {
- // resolve the functions we need
-
- // this will contain the name of the function we failed to resolve
- // if any at the end
- const char *funcName = NULL;
-
- // get the function from rasapi32.dll and abort if it's not found
- #define RESOLVE_RAS_FUNCTION(type, name) \
- ms_pfn##name = (type)m_dllRas.GetSymbol( wxString(_T(#name)) \
- + gs_funcSuffix); \
- if ( !ms_pfn##name ) \
- { \
- funcName = #name; \
- goto exit; \
- }
-
- // a variant of above macro which doesn't abort if the function is
- // not found in the DLL
- #define RESOLVE_OPTIONAL_RAS_FUNCTION(type, name) \
- ms_pfn##name = (type)m_dllRas.GetSymbol( wxString(_T(#name)) \
- + gs_funcSuffix);
-
- RESOLVE_RAS_FUNCTION(RASDIAL, RasDial);
- RESOLVE_RAS_FUNCTION(RASENUMCONNECTIONS, RasEnumConnections);
- RESOLVE_RAS_FUNCTION(RASENUMENTRIES, RasEnumEntries);
- RESOLVE_RAS_FUNCTION(RASGETCONNECTSTATUS, RasGetConnectStatus);
- RESOLVE_RAS_FUNCTION(RASGETERRORSTRING, RasGetErrorString);
- RESOLVE_RAS_FUNCTION(RASHANGUP, RasHangUp);
- RESOLVE_RAS_FUNCTION(RASGETENTRYDIALPARAMS, RasGetEntryDialParams);
-
- // suppress error messages about missing (non essential) functions
- {
- wxLogNull noLog;
-
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASGETPROJECTIONINFO, RasGetProjectionInfo);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASCREATEPHONEBOOKENTRY, RasCreatePhonebookEntry);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASEDITPHONEBOOKENTRY, RasEditPhonebookEntry);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASSETENTRYDIALPARAMS, RasSetEntryDialParams);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASGETENTRYPROPERTIES, RasGetEntryProperties);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASSETENTRYPROPERTIES, RasSetEntryProperties);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASRENAMEENTRY, RasRenameEntry);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASDELETEENTRY, RasDeleteEntry);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASVALIDATEENTRYNAME, RasValidateEntryName);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASGETCOUNTRYINFO, RasGetCountryInfo);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASENUMDEVICES, RasEnumDevices);
- RESOLVE_OPTIONAL_RAS_FUNCTION(RASCONNECTIONNOTIFICATION, RasConnectionNotification);
- }
-
- // keep your preprocessor name space clean
- #undef RESOLVE_RAS_FUNCTION
- #undef RESOLVE_OPTIONAL_RAS_FUNCTION
-
-exit:
- if ( funcName )
- {
- static const wxChar *msg = wxTRANSLATE(
-"The version of remote access service (RAS) installed on this machine is too\
-old, please upgrade (the following required function is missing: %s)."
- );
-
- wxLogError(wxGetTranslation(msg), funcName);
- m_dllRas.Unload();
- return;
- }
- }
-
- // enable auto check by default
- EnableAutoCheckOnlineStatus(0);
-}
-
-wxDialUpManagerMSW::~wxDialUpManagerMSW()
-{
- CleanUpThreadData();
-}
-
-// ----------------------------------------------------------------------------
-// helper functions
-// ----------------------------------------------------------------------------
-
-wxString wxDialUpManagerMSW::GetErrorString(DWORD error)
-{
- wxChar buffer[512]; // this should be more than enough according to MS docs
- DWORD dwRet = ms_pfnRasGetErrorString(error, buffer, WXSIZEOF(buffer));
- switch ( dwRet )
- {
- case ERROR_INVALID_PARAMETER:
- // this was a standard Win32 error probably
- return wxString(wxSysErrorMsg(error));
-
- default:
- {
- wxLogSysError(dwRet,
- _("Failed to retrieve text of RAS error message"));
-
- wxString msg;
- msg.Printf(_("unknown error (error code %08x)."), error);
- return msg;
- }
-
- case 0:
- // we want the error message to start from a lower case letter
- buffer[0] = wxTolower(buffer[0]);
-
- return wxString(buffer);
- }
-}
-
-HRASCONN wxDialUpManagerMSW::FindActiveConnection()
-{
- // enumerate connections
- DWORD cbBuf = sizeof(RASCONN);
- LPRASCONN lpRasConn = (LPRASCONN)malloc(cbBuf);
- if ( !lpRasConn )
- {
- // out of memory
- return 0;
- }
-
- lpRasConn->dwSize = sizeof(RASCONN);
-
- DWORD nConnections = 0;
- DWORD dwRet = ERROR_BUFFER_TOO_SMALL;
-
- while ( dwRet == ERROR_BUFFER_TOO_SMALL )
- {
- dwRet = ms_pfnRasEnumConnections(lpRasConn, &cbBuf, &nConnections);
-
- if ( dwRet == ERROR_BUFFER_TOO_SMALL )
- {
- LPRASCONN lpRasConnOld = lpRasConn;
- lpRasConn = (LPRASCONN)realloc(lpRasConn, cbBuf);
- if ( !lpRasConn )
- {
- // out of memory
- free(lpRasConnOld);
-
- return 0;
- }
- }
- else if ( dwRet == 0 )
- {
- // ok, success
- break;
- }
- else
- {
- // an error occured
- wxLogError(_("Cannot find active dialup connection: %s"),
- GetErrorString(dwRet).c_str());
- return 0;
- }
- }
-
- HRASCONN hrasconn;
-
- switch ( nConnections )
- {
- case 0:
- // no connections
- hrasconn = 0;
- break;
-
- default:
- // more than 1 connection - we don't know what to do with this
- // case, so give a warning but continue (taking the first
- // connection) - the warning is really needed because this function
- // is used, for example, to select the connection to hang up and so
- // we may hang up the wrong connection here...
- wxLogWarning(_("Several active dialup connections found, choosing one randomly."));
- // fall through
-
- case 1:
- // exactly 1 connection, great
- hrasconn = lpRasConn->hrasconn;
- }
-
- free(lpRasConn);
-
- return hrasconn;
-}
-
-void wxDialUpManagerMSW::CleanUpThreadData()
-{
- if ( m_hThread )
- {
- if ( !SetEvent(m_data->hEventQuit) )
- {
- wxLogLastError(_T("SetEvent(RasThreadQuit)"));
- }
- else // sent quit request to the background thread
- {
- // the thread still needs m_data so we can't free it here, rather
- // let the thread do it itself
- m_data = NULL;
- }
-
- CloseHandle(m_hThread);
-
- m_hThread = 0;
- }
-
- if ( m_data )
- {
- delete m_data;
- m_data = NULL;
- }
-}
-
-// ----------------------------------------------------------------------------
-// connection status
-// ----------------------------------------------------------------------------
-
-void wxDialUpManagerMSW::CheckRasStatus()
-{
- // use int, not bool to compare with -1
- int isConnected = FindActiveConnection() != 0;
- if ( isConnected != ms_isConnected )
- {
- if ( ms_isConnected != -1 )
- {
- // notify the program
- NotifyApp(isConnected != 0);
- }
- // else: it's the first time we're called, just update the flag
-
- ms_isConnected = isConnected;
- }
-}
-
-void wxDialUpManagerMSW::NotifyApp(bool connected, bool fromOurselves) const
-{
- wxDialUpEvent event(connected, fromOurselves);
- (void)wxTheApp->ProcessEvent(event);
-}
-
-// this function is called whenever the status of any RAS connection on this
-// machine changes by RAS itself
-void wxDialUpManagerMSW::OnConnectStatusChange()
-{
- // we know that status changed, but we don't know whether we're connected
- // or not - so find it out
- CheckRasStatus();
-}
-
-// this function is called by our callback which we give to RasDial() when
-// calling it asynchronously
-void wxDialUpManagerMSW::OnDialProgress(RASCONNSTATE rasconnstate,
- DWORD dwError)
-{
- if ( !GetDialer() )
- {
- // this probably means that CancelDialing() was called and we get
- // "disconnected" notification
- return;
- }
-
- // we're only interested in 2 events: connected and disconnected
- if ( dwError )
- {
- wxLogError(_("Failed to establish dialup connection: %s"),
- GetErrorString(dwError).c_str());
-
- // we should still call RasHangUp() if we got a non 0 connection
- if ( ms_hRasConnection )
- {
- ms_pfnRasHangUp(ms_hRasConnection);
- ms_hRasConnection = 0;
- }
-
- ms_dialer = NULL;
-
- NotifyApp(false /* !connected */, true /* we dialed ourselves */);
- }
- else if ( rasconnstate == RASCS_Connected )
- {
- ms_isConnected = TRUE;
- ms_dialer = NULL;
-
- NotifyApp(true /* connected */, true /* we dialed ourselves */);
- }
-}
-
-// ----------------------------------------------------------------------------
-// implementation of wxDialUpManager functions
-// ----------------------------------------------------------------------------
-
-bool wxDialUpManagerMSW::IsOk() const
-{
- return m_dllRas.IsLoaded();
-}
-
-size_t wxDialUpManagerMSW::GetISPNames(wxArrayString& names) const
-{
- // fetch the entries
- DWORD size = sizeof(RASENTRYNAME);
- RASENTRYNAME *rasEntries = (RASENTRYNAME *)malloc(size);
- rasEntries->dwSize = sizeof(RASENTRYNAME);
-
- DWORD nEntries;
- DWORD dwRet;
- do
- {
- dwRet = ms_pfnRasEnumEntries
- (
- NULL, // reserved
- NULL, // default phone book (or all)
- rasEntries, // [out] buffer for the entries
- &size, // [in/out] size of the buffer
- &nEntries // [out] number of entries fetched
- );
-
- if ( dwRet == ERROR_BUFFER_TOO_SMALL )
- {
- // reallocate the buffer
- rasEntries = (RASENTRYNAME *)realloc(rasEntries, size);
- }
- else if ( dwRet != 0 )
- {
- // some other error - abort
- wxLogError(_("Failed to get ISP names: %s"),
- GetErrorString(dwRet).c_str());
-
- free(rasEntries);
-
- return 0u;
- }
- }
- while ( dwRet != 0 );
-
- // process them
- names.Empty();
- for ( size_t n = 0; n < (size_t)nEntries; n++ )
- {
- names.Add(rasEntries[n].szEntryName);
- }
-
- free(rasEntries);
-
- // return the number of entries
- return names.GetCount();
-}
-
-bool wxDialUpManagerMSW::Dial(const wxString& nameOfISP,
- const wxString& username,
- const wxString& password,
- bool async)
-{
- // check preconditions
- wxCHECK_MSG( IsOk(), false, wxT("using uninitialized wxDialUpManager") );
-
- if ( ms_hRasConnection )
- {
- wxFAIL_MSG(wxT("there is already an active connection"));
-
- return true;
- }
-
- // get the default ISP if none given
- wxString entryName(nameOfISP);
- if ( !entryName )
- {
- wxArrayString names;
- size_t count = GetISPNames(names);
- switch ( count )
- {
- case 0:
- // no known ISPs, abort
- wxLogError(_("Failed to connect: no ISP to dial."));
-
- return false;
-
- case 1:
- // only one ISP, choose it
- entryName = names[0u];
- break;
-
- default:
- // several ISPs, let the user choose
- {
- wxString *strings = new wxString[count];
- for ( size_t i = 0; i < count; i++ )
- {
- strings[i] = names[i];
- }
-
- entryName = wxGetSingleChoice
- (
- _("Choose ISP to dial"),
- _("Please choose which ISP do you want to connect to"),
- count,
- strings
- );
-
- delete [] strings;
-
- if ( !entryName )
- {
- // cancelled by user
- return false;
- }
- }
- }
- }
-
- RASDIALPARAMS rasDialParams;
- rasDialParams.dwSize = sizeof(rasDialParams);
- wxStrncpy(rasDialParams.szEntryName, entryName, RAS_MaxEntryName);
-
- // do we have the username and password?
- if ( !username || !password )
- {
- BOOL gotPassword;
- DWORD dwRet = ms_pfnRasGetEntryDialParams
- (
- NULL, // default phonebook
- &rasDialParams, // [in/out] the params of this entry
- &gotPassword // [out] did we get password?
- );
-
- if ( dwRet != 0 )
- {
- wxLogError(_("Failed to connect: missing username/password."));
-
- return false;
- }
- }
- else
- {
- wxStrncpy(rasDialParams.szUserName, username, UNLEN);
- wxStrncpy(rasDialParams.szPassword, password, PWLEN);
- }
-
- // default values for other fields
- rasDialParams.szPhoneNumber[0] = '\0';
- rasDialParams.szCallbackNumber[0] = '\0';
- rasDialParams.szCallbackNumber[0] = '\0';
-
- rasDialParams.szDomain[0] = '*';
- rasDialParams.szDomain[1] = '\0';
-
- // apparently, this is not really necessary - passing NULL instead of the
- // phone book has the same effect
-#if 0
- wxString phoneBook;
- if ( wxGetOsVersion() == wxWINDOWS_NT )
- {
- // first get the length
- UINT nLen = ::GetSystemDirectory(NULL, 0);
- nLen++;
-
- if ( !::GetSystemDirectory(phoneBook.GetWriteBuf(nLen), nLen) )
- {
- wxLogSysError(_("Cannot find the location of address book file"));
- }
-
- phoneBook.UngetWriteBuf();
-
- // this is the default phone book
- phoneBook << "\\ras\\rasphone.pbk";
- }
-#endif // 0
-
- // TODO may be we should disable auto check while async dialing is in
- // progress?
-
- ms_dialer = this;
-
- DWORD dwRet = ms_pfnRasDial
- (
- NULL, // no extended features
- NULL, // default phone book file (NT only)
- &rasDialParams,
- 0, // use callback for notifications
- async ? (void *)wxRasDialFunc // cast needed for gcc 3.1
- : 0, // no notifications, sync operation
- &ms_hRasConnection
- );
-
- if ( dwRet != 0 )
- {
- // can't pass a wxWCharBuffer through ( ... )
- wxLogError(_("Failed to %s dialup connection: %s"),
- wxString(async ? _("initiate") : _("establish")).c_str(),
- GetErrorString(dwRet).c_str());
-
- // we should still call RasHangUp() if we got a non 0 connection
- if ( ms_hRasConnection )
- {
- ms_pfnRasHangUp(ms_hRasConnection);
- ms_hRasConnection = 0;
- }
-
- ms_dialer = NULL;
-
- return false;
- }
-
- // for async dialing, we're not yet connected
- if ( !async )
- {
- ms_isConnected = TRUE;
- }
-
- return true;
-}
-
-bool wxDialUpManagerMSW::IsDialing() const
-{
- return GetDialer() != NULL;
-}
-
-bool wxDialUpManagerMSW::CancelDialing()
-{
- if ( !GetDialer() )
- {
- // silently ignore
- return false;
- }
-
- wxASSERT_MSG( ms_hRasConnection, wxT("dialing but no connection?") );
-
- ms_dialer = NULL;
-
- return HangUp();
-}
-
-bool wxDialUpManagerMSW::HangUp()
-{
- wxCHECK_MSG( IsOk(), false, wxT("using uninitialized wxDialUpManager") );
-
- // we may terminate either the connection we initiated or another one which
- // is active now
- HRASCONN hRasConn;
- if ( ms_hRasConnection )
- {
- hRasConn = ms_hRasConnection;
-
- ms_hRasConnection = 0;
- }
- else
- {
- hRasConn = FindActiveConnection();
- }
-
- if ( !hRasConn )
- {
- wxLogError(_("Cannot hang up - no active dialup connection."));
-
- return false;
- }
-
- DWORD dwRet = ms_pfnRasHangUp(hRasConn);
- if ( dwRet != 0 )
- {
- wxLogError(_("Failed to terminate the dialup connection: %s"),
- GetErrorString(dwRet).c_str());
- }
-
- ms_isConnected = FALSE;
-
- return true;
-}
-
-bool wxDialUpManagerMSW::IsAlwaysOnline() const
-{
- // assume no permanent connection by default
- bool isAlwaysOnline = false;
-
- // try to use WinInet functions
-
- // NB: we could probably use wxDynamicLibrary here just as well,
- // but we allow multiple instances of wxDialUpManagerMSW so
- // we might as well use the ref counted version here too.
-
- wxDynamicLibrary hDll(_T("WININET"));
- if ( hDll.IsLoaded() )
- {
- typedef BOOL (WINAPI *INTERNETGETCONNECTEDSTATE)(LPDWORD, DWORD);
- INTERNETGETCONNECTEDSTATE pfnInternetGetConnectedState;
-
- #define RESOLVE_FUNCTION(type, name) \
- pfn##name = (type)hDll.GetSymbol(_T(#name))
-
- RESOLVE_FUNCTION(INTERNETGETCONNECTEDSTATE, InternetGetConnectedState);
-
- if ( pfnInternetGetConnectedState )
- {
- DWORD flags = 0;
- if ( pfnInternetGetConnectedState(&flags, 0 /* reserved */) )
- {
- // there is some connection to the net, see of which type
- isAlwaysOnline = (flags & (INTERNET_CONNECTION_LAN |
- INTERNET_CONNECTION_PROXY)) != 0;
- }
- //else: no Internet connection at all
- }
- }
-
- return isAlwaysOnline;
-}
-
-bool wxDialUpManagerMSW::IsOnline() const
-{
- wxCHECK_MSG( IsOk(), false, wxT("using uninitialized wxDialUpManager") );
-
- if ( IsAlwaysOnline() )
- {
- // always => now
- return true;
- }
-
- if ( ms_userSpecifiedOnlineStatus != -1 )
- {
- // user specified flag overrides our logic
- return ms_userSpecifiedOnlineStatus != 0;
- }
- else
- {
- // return true if there is at least one active connection
- return FindActiveConnection() != 0;
- }
-}
-
-void wxDialUpManagerMSW::SetOnlineStatus(bool isOnline)
-{
- wxCHECK_RET( IsOk(), wxT("using uninitialized wxDialUpManager") );
-
- ms_userSpecifiedOnlineStatus = isOnline;
-}
-
-bool wxDialUpManagerMSW::EnableAutoCheckOnlineStatus(size_t nSeconds)
-{
- wxCHECK_MSG( IsOk(), false, wxT("using uninitialized wxDialUpManager") );
-
- if ( m_autoCheckLevel++ )
- {
- // already checking
- return true;
- }
-
- bool ok = ms_pfnRasConnectionNotification != 0;
-
- if ( ok )
- {
- // we're running under NT 4.0, Windows 98 or later and can use
- // RasConnectionNotification() to be notified by a secondary thread
-
- // first, see if we don't have this thread already running
- if ( m_hThread != 0 )
- {
- if ( ::ResumeThread(m_hThread) != (DWORD)-1 )
- return true;
-
- // we're leaving a zombie thread... but what else can we do?
- wxLogLastError(wxT("ResumeThread(RasThread)"));
-
- ok = false;
- }
- }
-
- // create all the stuff we need to be notified about RAS connection
- // status change
-
- if ( ok )
- {
- // first create an event to wait on
- m_data->hEventRas = CreateEvent
- (
- NULL, // security attribute (default)
- FALSE, // manual reset (no, it is automatic)
- FALSE, // initial state (not signaled)
- NULL // name (no)
- );
- if ( !m_data->hEventRas )
- {
- wxLogLastError(wxT("CreateEvent(RasStatus)"));
-
- ok = false;
- }
- }
-
- if ( ok )
- {
- // create the event we use to quit the thread: using a manual event
- // here avoids problems with missing the event if wxDialUpManagerMSW
- // is created and destroyed immediately, before wxRasStatusWindowProc
- // starts waiting on the event
- m_data->hEventQuit = CreateEvent
- (
- NULL, // default security
- TRUE, // manual event
- FALSE, // initially non signalled
- NULL // nameless
- );
- if ( !m_data->hEventQuit )
- {
- wxLogLastError(wxT("CreateEvent(RasThreadQuit)"));
-
- CleanUpThreadData();
-
- ok = false;
- }
- }
-
- if ( ok && !ms_hwndRas )
- {
- // create a hidden window to receive notification about connections
- // status change
- extern const wxChar *wxCanvasClassName;
- ms_hwndRas = ::CreateWindow(wxCanvasClassName, NULL,
- 0, 0, 0, 0,
- 0, NULL,
- (HMENU)NULL, wxGetInstance(), 0);
- if ( !ms_hwndRas )
- {
- wxLogLastError(wxT("CreateWindow(RasHiddenWindow)"));
-
- CleanUpThreadData();
-
- ok = false;
- }
-
- // and subclass it
- wxSetWindowProc(ms_hwndRas, wxRasStatusWindowProc);
- }
-
- m_data->hWnd = ms_hwndRas;
-
- if ( ok )
- {
- // start the secondary thread
- m_data->dialUpManager = this;
-
- DWORD tid;
- m_hThread = CreateThread
- (
- NULL,
- 0,
- (LPTHREAD_START_ROUTINE)wxRasMonitorThread,
- (void *)m_data,
- 0,
- &tid
- );
-
- if ( !m_hThread )
- {
- wxLogLastError(wxT("CreateThread(RasStatusThread)"));
-
- CleanUpThreadData();
- }
- }
-
- if ( ok )
- {
- // start receiving RAS notifications
- DWORD dwRet = ms_pfnRasConnectionNotification
- (
- (HRASCONN)INVALID_HANDLE_VALUE,
- m_data->hEventRas,
- 3 /* RASCN_Connection | RASCN_Disconnection */
- );
-
- if ( dwRet != 0 )
- {
- wxLogDebug(wxT("RasConnectionNotification() failed: %s"),
- GetErrorString(dwRet).c_str());
-
- CleanUpThreadData();
- }
- else
- {
- return true;
- }
- }
-
- // we're running under Windows 95 and have to poll ourselves
- // (or, alternatively, the code above for NT/98 failed)
- m_timerStatusPolling.Stop();
- if ( nSeconds == 0 )
- {
- // default value
- nSeconds = 60;
- }
- m_timerStatusPolling.Start(nSeconds * 1000);
-
- return true;
-}
-
-void wxDialUpManagerMSW::DisableAutoCheckOnlineStatus()
-{
- wxCHECK_RET( IsOk(), wxT("using uninitialized wxDialUpManager") );
-
- if ( --m_autoCheckLevel )
- {
- // still checking
- return;
- }
-
- if ( m_hThread )
- {
- // we have running secondary thread, it's just enough to suspend it
- if ( SuspendThread(m_hThread) == (DWORD)-1 )
- {
- wxLogLastError(wxT("SuspendThread(RasThread)"));
- }
- }
- else
- {
- // even simpler - just stop the timer
- m_timerStatusPolling.Stop();
- }
-}
-
-// ----------------------------------------------------------------------------
-// stubs which don't do anything in MSW version
-// ----------------------------------------------------------------------------
-
-void wxDialUpManagerMSW::SetWellKnownHost(const wxString& WXUNUSED(hostname),
- int WXUNUSED(port))
-{
- wxCHECK_RET( IsOk(), wxT("using uninitialized wxDialUpManager") );
-
- // nothing to do - we don't use this
-}
-
-void wxDialUpManagerMSW::SetConnectCommand(const wxString& WXUNUSED(dial),
- const wxString& WXUNUSED(hangup))
-{
- wxCHECK_RET( IsOk(), wxT("using uninitialized wxDialUpManager") );
-
- // nothing to do - we don't use this
-}
-
-// ----------------------------------------------------------------------------
-// callbacks
-// ----------------------------------------------------------------------------
-
-static DWORD wxRasMonitorThread(wxRasThreadData *data)
-{
- HANDLE handles[2];
- handles[0] = data->hEventRas;
- handles[1] = data->hEventQuit;
-
- bool cont = true;
- while ( cont )
- {
- DWORD dwRet = WaitForMultipleObjects(2, handles, FALSE, INFINITE);
-
- switch ( dwRet )
- {
- case WAIT_OBJECT_0:
- // RAS connection status changed
- SendMessage(data->hWnd, wxWM_RAS_STATUS_CHANGED,
- 0, (LPARAM)data);
- break;
-
- case WAIT_OBJECT_0 + 1:
- cont = false;
- break;
-
- default:
- wxFAIL_MSG( _T("unexpected return of WaitForMultipleObjects()") );
- // fall through
-
- case WAIT_FAILED:
-#ifdef __WXDEBUG__
- // using wxLogLastError() from here is dangerous: we risk to
- // deadlock the main thread if wxLog sends output to GUI
- DWORD err = GetLastError();
- wxMessageOutputDebug().Printf
- (
- wxT("WaitForMultipleObjects(RasMonitor) failed: 0x%08lx (%s)"),
- err,
- wxSysErrorMsg(err)
- );
-#endif // __WXDEBUG__
-
- // no sense in continuing, who knows if the handles we're
- // waiting for even exist yet...
- return (DWORD)-1;
- }
- }
-
- // we don't need it any more now and if this thread ran, it is our
- // responsability to free the data
- delete data;
-
- return 0;
-}
-
-static LRESULT APIENTRY wxRasStatusWindowProc(HWND hWnd, UINT message,
- WPARAM wParam, LPARAM lParam)
-{
- switch ( message )
- {
- case wxWM_RAS_STATUS_CHANGED:
- {
- wxRasThreadData *data = (wxRasThreadData *)lParam;
- data->dialUpManager->OnConnectStatusChange();
- }
- break;
-
- case wxWM_RAS_DIALING_PROGRESS:
- {
- wxDialUpManagerMSW *dialMan = wxDialUpManagerMSW::GetDialer();
-
- dialMan->OnDialProgress((RASCONNSTATE)wParam, lParam);
- }
- break;
-
- default:
- return ::DefWindowProc(hWnd, message, wParam, lParam);
- }
-
- return 0;
-}
-
-static void WINAPI wxRasDialFunc(UINT WXUNUSED(unMsg),
- RASCONNSTATE rasconnstate,
- DWORD dwError)
-{
- wxDialUpManagerMSW *dialUpManager = wxDialUpManagerMSW::GetDialer();
-
- wxCHECK_RET( dialUpManager, wxT("who started to dial then?") );
-
- SendMessage(dialUpManager->GetRasWindow(), wxWM_RAS_DIALING_PROGRESS,
- rasconnstate, dwError);
-}
-
-#endif // __WXPALMOS__
-
-#endif // wxUSE_DIALUP_MANAGER
-
+++ /dev/null
-/////////////////////////////////////////////////////////////////////////////
-// Name: palmos/mimetype.cpp
-// Purpose: classes and functions to manage MIME types
-// Author: Vadim Zeitlin
-// Modified by:
-// Created: 23.09.98
-// RCS-ID: $Id$
-// Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
-// Licence: wxWindows licence (part of wxExtra library)
-/////////////////////////////////////////////////////////////////////////////
-
-#ifdef __GNUG__
-#pragma implementation "mimetype.h"
-#endif
-
-// for compilers that support precompilation, includes "wx.h".
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
- #pragma hdrstop
-#endif
-
-// This really doesn't apply to Palm OS
-#ifdef __WXPALMOS__
-
-#if wxUSE_MIMETYPE
-
-#ifndef WX_PRECOMP
- #include "wx/string.h"
- #if wxUSE_GUI
- #include "wx/icon.h"
- #include "wx/msgdlg.h"
- #endif
-#endif //WX_PRECOMP
-
-#include "wx/log.h"
-#include "wx/file.h"
-#include "wx/iconloc.h"
-#include "wx/intl.h"
-#include "wx/dynarray.h"
-#include "wx/confbase.h"
-
-#include "wx/palmos/mimetype.h"
-
-// other standard headers
-#include <ctype.h>
-
-// in case we're compiling in non-GUI mode
-class WXDLLEXPORT wxIcon;
-
-// These classes use Windows registry to retrieve the required information.
-//
-// Keys used (not all of them are documented, so it might actually stop working
-// in future versions of Windows...):
-// 1. "HKCR\MIME\Database\Content Type" contains subkeys for all known MIME
-// types, each key has a string value "Extension" which gives (dot preceded)
-// extension for the files of this MIME type.
-//
-// 2. "HKCR\.ext" contains
-// a) unnamed value containing the "filetype"
-// b) value "Content Type" containing the MIME type
-//
-// 3. "HKCR\filetype" contains
-// a) unnamed value containing the description
-// b) subkey "DefaultIcon" with single unnamed value giving the icon index in
-// an icon file
-// c) shell\open\command and shell\open\print subkeys containing the commands
-// to open/print the file (the positional parameters are introduced by %1,
-// %2, ... in these strings, we change them to %s ourselves)
-
-// although I don't know of any official documentation which mentions this
-// location, uses it, so it isn't likely to change
-static const wxChar *MIME_DATABASE_KEY = wxT("MIME\\Database\\Content Type\\");
-
-// this function replaces Microsoft %1 with Unix-like %s
-static bool CanonicalizeParams(wxString& command)
-{
- // transform it from '%1' to '%s' style format string (now also test for %L
- // as apparently MS started using it as well for the same purpose)
-
- // NB: we don't make any attempt to verify that the string is valid, i.e.
- // doesn't contain %2, or second %1 or .... But we do make sure that we
- // return a string with _exactly_ one '%s'!
- bool foundFilename = false;
- size_t len = command.length();
- for ( size_t n = 0; (n < len) && !foundFilename; n++ )
- {
- if ( command[n] == wxT('%') &&
- (n + 1 < len) &&
- (command[n + 1] == wxT('1') || command[n + 1] == wxT('L')) )
- {
- // replace it with '%s'
- command[n + 1] = wxT('s');
-
- foundFilename = true;
- }
- }
-
- return foundFilename;
-}
-
-void wxFileTypeImpl::Init(const wxString& strFileType, const wxString& ext)
-{
- // VZ: does it? (FIXME)
- wxCHECK_RET( !ext.empty(), _T("needs an extension") );
-
- if ( ext[0u] != wxT('.') ) {
- m_ext = wxT('.');
- }
- m_ext << ext;
-
- m_strFileType = strFileType;
- if ( !strFileType ) {
- m_strFileType = m_ext.AfterFirst('.') + _T("_auto_file");
- }
-}
-
-wxString wxFileTypeImpl::GetVerbPath(const wxString& verb) const
-{
- wxString path;
- path << m_strFileType << _T("\\shell\\") << verb << _T("\\command");
- return path;
-}
-
-size_t wxFileTypeImpl::GetAllCommands(wxArrayString *verbs,
- wxArrayString *commands,
- const wxFileType::MessageParameters& params) const
-{
- wxCHECK_MSG( !m_ext.empty(), 0, _T("GetAllCommands() needs an extension") );
-
- if ( m_strFileType.empty() )
- {
- // get it from the registry
- wxFileTypeImpl *self = wxConstCast(this, wxFileTypeImpl);
- wxRegKey rkey(wxRegKey::HKCR, m_ext);
- if ( !rkey.Exists() || !rkey.QueryValue(wxEmptyString, self->m_strFileType) )
- {
- wxLogDebug(_T("Can't get the filetype for extension '%s'."),
- m_ext.c_str());
-
- return 0;
- }
- }
-
- // enum all subkeys of HKCR\filetype\shell
- size_t count = 0;
- wxRegKey rkey(wxRegKey::HKCR, m_strFileType + _T("\\shell"));
- long dummy;
- wxString verb;
- bool ok = rkey.GetFirstKey(verb, dummy);
- while ( ok )
- {
- wxString command = wxFileType::ExpandCommand(GetCommand(verb), params);
-
- // we want the open bverb to eb always the first
-
- if ( verb.CmpNoCase(_T("open")) == 0 )
- {
- if ( verbs )
- verbs->Insert(verb, 0);
- if ( commands )
- commands->Insert(command, 0);
- }
- else // anything else than "open"
- {
- if ( verbs )
- verbs->Add(verb);
- if ( commands )
- commands->Add(command);
- }
-
- count++;
-
- ok = rkey.GetNextKey(verb, dummy);
- }
-
- return count;
-}
-
-// ----------------------------------------------------------------------------
-// modify the registry database
-// ----------------------------------------------------------------------------
-
-bool wxFileTypeImpl::EnsureExtKeyExists()
-{
- wxRegKey rkey(wxRegKey::HKCR, m_ext);
- if ( !rkey.Exists() )
- {
- if ( !rkey.Create() || !rkey.SetValue(wxEmptyString, m_strFileType) )
- {
- wxLogError(_("Failed to create registry entry for '%s' files."),
- m_ext.c_str());
- return false;
- }
- }
-
- return true;
-}
-
-// ----------------------------------------------------------------------------
-// get the command to use
-// ----------------------------------------------------------------------------
-
-wxString wxFileTypeImpl::GetCommand(const wxChar *verb) const
-{
- // suppress possible error messages
- wxLogNull nolog;
- wxString strKey;
-
- if ( wxRegKey(wxRegKey::HKCR, m_ext + _T("\\shell")).Exists() )
- strKey = m_ext;
- if ( wxRegKey(wxRegKey::HKCR, m_strFileType + _T("\\shell")).Exists() )
- strKey = m_strFileType;
-
- if ( !strKey )
- {
- // no info
- return wxEmptyString;
- }
-
- strKey << wxT("\\shell\\") << verb;
- wxRegKey key(wxRegKey::HKCR, strKey + _T("\\command"));
- wxString command;
- if ( key.Open(wxRegKey::Read) ) {
- // it's the default value of the key
- if ( key.QueryValue(wxEmptyString, command) ) {
- bool foundFilename = CanonicalizeParams(command);
-
-#if wxUSE_IPC
- // look whether we must issue some DDE requests to the application
- // (and not just launch it)
- strKey += _T("\\DDEExec");
- wxRegKey keyDDE(wxRegKey::HKCR, strKey);
- if ( keyDDE.Open(wxRegKey::Read) ) {
- wxString ddeCommand, ddeServer, ddeTopic;
- keyDDE.QueryValue(wxEmptyString, ddeCommand);
- ddeCommand.Replace(_T("%1"), _T("%s"));
-
- wxRegKey(wxRegKey::HKCR, strKey + _T("\\Application")).
- QueryValue(wxEmptyString, ddeServer);
- wxRegKey(wxRegKey::HKCR, strKey + _T("\\Topic")).
- QueryValue(wxEmptyString, ddeTopic);
-
- if (ddeTopic.IsEmpty())
- ddeTopic = wxT("System");
-
- // HACK: we use a special feature of wxExecute which exists
- // just because we need it here: it will establish DDE
- // conversation with the program it just launched
- command.Prepend(_T("WX_DDE#"));
- command << _T('#') << ddeServer
- << _T('#') << ddeTopic
- << _T('#') << ddeCommand;
- }
- else
-#endif // wxUSE_IPC
- if ( !foundFilename )
- {
- // we didn't find any '%1' - the application doesn't know which
- // file to open (note that we only do it if there is no DDEExec
- // subkey)
- //
- // HACK: append the filename at the end, hope that it will do
- command << wxT(" %s");
- }
- }
- }
- //else: no such file type or no value, will return empty string
-
- return command;
-}
-
-bool
-wxFileTypeImpl::GetOpenCommand(wxString *openCmd,
- const wxFileType::MessageParameters& params)
- const
-{
- wxString cmd = GetCommand(wxT("open"));
-
- *openCmd = wxFileType::ExpandCommand(cmd, params);
-
- return !openCmd->empty();
-}
-
-bool
-wxFileTypeImpl::GetPrintCommand(wxString *printCmd,
- const wxFileType::MessageParameters& params)
- const
-{
- wxString cmd = GetCommand(wxT("print"));
-
- *printCmd = wxFileType::ExpandCommand(cmd, params);
-
- return !printCmd->empty();
-}
-
-// ----------------------------------------------------------------------------
-// getting other stuff
-// ----------------------------------------------------------------------------
-
-// TODO this function is half implemented
-bool wxFileTypeImpl::GetExtensions(wxArrayString& extensions)
-{
- if ( m_ext.empty() ) {
- // the only way to get the list of extensions from the file type is to
- // scan through all extensions in the registry - too slow...
- return false;
- }
- else {
- extensions.Empty();
- extensions.Add(m_ext);
-
- // it's a lie too, we don't return _all_ extensions...
- return true;
- }
-}
-
-bool wxFileTypeImpl::GetMimeType(wxString *mimeType) const
-{
- // suppress possible error messages
- wxLogNull nolog;
- wxRegKey key(wxRegKey::HKCR, m_ext);
-
- return key.Open(wxRegKey::Read) &&
- key.QueryValue(wxT("Content Type"), *mimeType);
-}
-
-bool wxFileTypeImpl::GetMimeTypes(wxArrayString& mimeTypes) const
-{
- wxString s;
-
- if ( !GetMimeType(&s) )
- {
- return false;
- }
-
- mimeTypes.Clear();
- mimeTypes.Add(s);
- return true;
-}
-
-
-bool wxFileTypeImpl::GetIcon(wxIconLocation *iconLoc) const
-{
- wxString strIconKey;
- strIconKey << m_strFileType << wxT("\\DefaultIcon");
-
- // suppress possible error messages
- wxLogNull nolog;
- wxRegKey key(wxRegKey::HKCR, strIconKey);
-
- if ( key.Open(wxRegKey::Read) ) {
- wxString strIcon;
- // it's the default value of the key
- if ( key.QueryValue(wxEmptyString, strIcon) ) {
- // the format is the following: <full path to file>, <icon index>
- // NB: icon index may be negative as well as positive and the full
- // path may contain the environment variables inside '%'
- wxString strFullPath = strIcon.BeforeLast(wxT(',')),
- strIndex = strIcon.AfterLast(wxT(','));
-
- // index may be omitted, in which case BeforeLast(',') is empty and
- // AfterLast(',') is the whole string
- if ( strFullPath.empty() ) {
- strFullPath = strIndex;
- strIndex = wxT("0");
- }
-
- if ( iconLoc )
- {
- iconLoc->SetFileName(wxExpandEnvVars(strFullPath));
-
- iconLoc->SetIndex(wxAtoi(strIndex));
- }
-
- return true;
- }
- }
-
- // no such file type or no value or incorrect icon entry
- return false;
-}
-
-bool wxFileTypeImpl::GetDescription(wxString *desc) const
-{
- // suppress possible error messages
- wxLogNull nolog;
- wxRegKey key(wxRegKey::HKCR, m_strFileType);
-
- if ( key.Open(wxRegKey::Read) ) {
- // it's the default value of the key
- if ( key.QueryValue(wxEmptyString, *desc) ) {
- return true;
- }
- }
-
- return false;
-}
-
-// helper function
-wxFileType *
-wxMimeTypesManagerImpl::CreateFileType(const wxString& filetype, const wxString& ext)
-{
- wxFileType *fileType = new wxFileType;
- fileType->m_impl->Init(filetype, ext);
- return fileType;
-}
-
-// extension -> file type
-wxFileType *
-wxMimeTypesManagerImpl::GetFileTypeFromExtension(const wxString& ext)
-{
- // add the leading point if necessary
- wxString str;
- if ( ext[0u] != wxT('.') ) {
- str = wxT('.');
- }
- str << ext;
-
- // suppress possible error messages
- wxLogNull nolog;
-
- bool knownExtension = false;
-
- wxString strFileType;
- wxRegKey key(wxRegKey::HKCR, str);
- if ( key.Open(wxRegKey::Read) ) {
- // it's the default value of the key
- if ( key.QueryValue(wxEmptyString, strFileType) ) {
- // create the new wxFileType object
- return CreateFileType(strFileType, ext);
- }
- else {
- // this extension doesn't have a filetype, but it's known to the
- // system and may be has some other useful keys (open command or
- // content-type), so still return a file type object for it
- knownExtension = true;
- }
- }
-
- if ( !knownExtension )
- {
- // unknown extension
- return NULL;
- }
-
- return CreateFileType(wxEmptyString, ext);
-}
-
-/*
-wxFileType *
-wxMimeTypesManagerImpl::GetOrAllocateFileTypeFromExtension(const wxString& ext)
-{
- wxFileType *fileType = GetFileTypeFromExtension(ext);
- if ( !fileType )
- {
- fileType = CreateFileType(wxEmptyString, ext);
- }
-
- return fileType;
-}
-*/
-
-// MIME type -> extension -> file type
-wxFileType *
-wxMimeTypesManagerImpl::GetFileTypeFromMimeType(const wxString& mimeType)
-{
- wxString strKey = MIME_DATABASE_KEY;
- strKey << mimeType;
-
- // suppress possible error messages
- wxLogNull nolog;
-
- wxString ext;
- wxRegKey key(wxRegKey::HKCR, strKey);
- if ( key.Open(wxRegKey::Read) ) {
- if ( key.QueryValue(wxT("Extension"), ext) ) {
- return GetFileTypeFromExtension(ext);
- }
- }
-
- // unknown MIME type
- return NULL;
-}
-
-size_t wxMimeTypesManagerImpl::EnumAllFileTypes(wxArrayString& mimetypes)
-{
- // enumerate all keys under MIME_DATABASE_KEY
- wxRegKey key(wxRegKey::HKCR, MIME_DATABASE_KEY);
-
- wxString type;
- long cookie;
- bool cont = key.GetFirstKey(type, cookie);
- while ( cont )
- {
- mimetypes.Add(type);
-
- cont = key.GetNextKey(type, cookie);
- }
-
- return mimetypes.GetCount();
-}
-
-// ----------------------------------------------------------------------------
-// create a new association
-// ----------------------------------------------------------------------------
-
-wxFileType *wxMimeTypesManagerImpl::Associate(const wxFileTypeInfo& ftInfo)
-{
- wxCHECK_MSG( !ftInfo.GetExtensions().IsEmpty(), NULL,
- _T("Associate() needs extension") );
-
- bool ok;
- int iExtCount = 0 ;
- wxString filetype;
- wxString extWithDot;
-
- wxString ext = ftInfo.GetExtensions()[iExtCount];
-
- wxCHECK_MSG( !ext.empty(), NULL,
- _T("Associate() needs non empty extension") );
-
- if ( ext[0u] != _T('.') )
- extWithDot = _T('.');
- extWithDot += ext;
-
- // start by setting the HKCR\\.ext entries
- // default is filetype; content type is mimetype
- const wxString& filetypeOrig = ftInfo.GetShortDesc();
-
- wxRegKey key(wxRegKey::HKCR, extWithDot);
- if ( !key.Exists() )
- {
- // create the mapping from the extension to the filetype
- ok = key.Create();
- if ( ok )
- {
-
- if ( filetypeOrig.empty() )
- {
- // make it up from the extension
- filetype << extWithDot.c_str() + 1 << _T("_file");
- }
- else
- {
- // just use the provided one
- filetype = filetypeOrig;
- }
-
- key.SetValue(wxEmptyString, filetype);
- }
- }
- else
- {
- // key already exists, maybe we want to change it ??
- if (!filetypeOrig.empty())
- {
- filetype = filetypeOrig;
- key.SetValue(wxEmptyString, filetype);
- }
- else
- {
- key.QueryValue(wxEmptyString, filetype);
- }
- }
- // now set a mimetypeif we have it, but ignore it if none
- const wxString& mimetype = ftInfo.GetMimeType();
- if ( !mimetype.empty() )
- {
- // set the MIME type
- ok = key.SetValue(_T("Content Type"), mimetype);
-
- if ( ok )
- {
- // create the MIME key
- wxString strKey = MIME_DATABASE_KEY;
- strKey << mimetype;
- wxRegKey keyMIME(wxRegKey::HKCR, strKey);
- ok = keyMIME.Create();
-
- if ( ok )
- {
- // and provide a back link to the extension
- keyMIME.SetValue(_T("Extension"), extWithDot);
- }
- }
- }
-
-
- // now make other extensions have the same filetype
-
- for (iExtCount=1; iExtCount < ftInfo.GetExtensionsCount(); iExtCount++ )
- {
- ext = ftInfo.GetExtensions()[iExtCount];
- if ( ext[0u] != _T('.') )
- extWithDot = _T('.');
- extWithDot += ext;
-
- wxRegKey key(wxRegKey::HKCR, extWithDot);
- if ( !key.Exists() ) key.Create();
- key.SetValue(wxEmptyString, filetype);
-
- // now set any mimetypes we may have, but ignore it if none
- const wxString& mimetype = ftInfo.GetMimeType();
- if ( !mimetype.empty() )
- {
- // set the MIME type
- ok = key.SetValue(_T("Content Type"), mimetype);
-
- if ( ok )
- {
- // create the MIME key
- wxString strKey = MIME_DATABASE_KEY;
- strKey << mimetype;
- wxRegKey keyMIME(wxRegKey::HKCR, strKey);
- ok = keyMIME.Create();
-
- if ( ok )
- {
- // and provide a back link to the extension
- keyMIME.SetValue(_T("Extension"), extWithDot);
- }
- }
- }
-
-
- } // end of for loop; all extensions now point to HKCR\.ext\Default
-
- // create the filetype key itself (it will be empty for now, but
- // SetCommand(), SetDefaultIcon() &c will use it later)
- wxRegKey keyFT(wxRegKey::HKCR, filetype);
- keyFT.Create();
-
- wxFileType *ft = CreateFileType(filetype, extWithDot);
-
- if (ft)
- {
- if (! ftInfo.GetOpenCommand ().IsEmpty() ) ft->SetCommand (ftInfo.GetOpenCommand (), wxT("open" ) );
- if (! ftInfo.GetPrintCommand().IsEmpty() ) ft->SetCommand (ftInfo.GetPrintCommand(), wxT("print" ) );
- // chris: I don't like the ->m_impl-> here FIX this ??
- if (! ftInfo.GetDescription ().IsEmpty() ) ft->m_impl->SetDescription (ftInfo.GetDescription ()) ;
- if (! ftInfo.GetIconFile().IsEmpty() ) ft->SetDefaultIcon (ftInfo.GetIconFile(), ftInfo.GetIconIndex() );
-
- }
- return ft;
-}
-
-bool wxFileTypeImpl::SetCommand(const wxString& cmd,
- const wxString& verb,
- bool WXUNUSED(overwriteprompt))
-{
- wxCHECK_MSG( !m_ext.empty() && !verb.empty(), false,
- _T("SetCommand() needs an extension and a verb") );
-
- if ( !EnsureExtKeyExists() )
- return false;
-
- wxRegKey rkey(wxRegKey::HKCR, GetVerbPath(verb));
-#if 0
- if ( rkey.Exists() && overwriteprompt )
- {
-#if wxUSE_GUI
- wxString old;
- rkey.QueryValue(wxEmptyString, old);
- if ( wxMessageBox
- (
- wxString::Format(
- _("Do you want to overwrite the command used to %s "
- "files with extension \"%s\" ?\nCurrent value is \n%s, "
- "\nNew value is \n%s %1"), // bug here FIX need %1 ??
- verb.c_str(),
- m_ext.c_str(),
- old.c_str(),
- cmd.c_str()),
- _("Confirm registry update"),
- wxYES_NO | wxICON_QUESTION
- ) != wxYES )
-#endif // wxUSE_GUI
- {
- // cancelled by user
- return false;
- }
- }
-#endif
- // TODO:
- // 1. translate '%s' to '%1' instead of always adding it
- // 2. create DDEExec value if needed (undo GetCommand)
- return rkey.Create() && rkey.SetValue(wxEmptyString, cmd + _T(" \"%1\"") );
-}
-
-/* // no longer used
-bool wxFileTypeImpl::SetMimeType(const wxString& mimeTypeOrig)
-{
- wxCHECK_MSG( !m_ext.empty(), false, _T("SetMimeType() needs extension") );
-
- if ( !EnsureExtKeyExists() )
- return false;
-
- // VZ: is this really useful? (FIXME)
- wxString mimeType;
- if ( !mimeTypeOrig )
- {
- // make up a default value for it
- wxString cmd;
- wxSplitPath(GetCommand(_T("open")), NULL, &cmd, NULL);
- mimeType << _T("application/x-") << cmd;
- }
- else
- {
- mimeType = mimeTypeOrig;
- }
-
- wxRegKey rkey(wxRegKey::HKCR, m_ext);
- return rkey.Create() && rkey.SetValue(_T("Content Type"), mimeType);
-}
-*/
-
-bool wxFileTypeImpl::SetDefaultIcon(const wxString& cmd, int index)
-{
- wxCHECK_MSG( !m_ext.empty(), false, _T("SetDefaultIcon() needs extension") );
- wxCHECK_MSG( !m_strFileType.empty(), false, _T("File key not found") );
-// the next line fails on a SMBshare, I think because it is case mangled
-// wxCHECK_MSG( !wxFileExists(cmd), false, _T("Icon file not found.") );
-
- if ( !EnsureExtKeyExists() )
- return false;
-
- wxRegKey rkey(wxRegKey::HKCR, m_strFileType + _T("\\DefaultIcon"));
-
- return rkey.Create() &&
- rkey.SetValue(wxEmptyString,
- wxString::Format(_T("%s,%d"), cmd.c_str(), index));
-}
-
-bool wxFileTypeImpl::SetDescription (const wxString& desc)
-{
- wxCHECK_MSG( !m_strFileType.empty(), false, _T("File key not found") );
- wxCHECK_MSG( !desc.empty(), false, _T("No file description supplied") );
-
- if ( !EnsureExtKeyExists() )
- return false;
-
- wxRegKey rkey(wxRegKey::HKCR, m_strFileType );
-
- return rkey.Create() &&
- rkey.SetValue(wxEmptyString, desc);
-}
-
-// ----------------------------------------------------------------------------
-// remove file association
-// ----------------------------------------------------------------------------
-
-bool wxFileTypeImpl::Unassociate()
-{
- bool result = true;
- if ( !RemoveOpenCommand() )
- result = false;
- if ( !RemoveDefaultIcon() )
- result = false;
- if ( !RemoveMimeType() )
- result = false;
- if ( !RemoveDescription() )
- result = false;
-
-/*
- //this might hold other keys, eg some have CSLID keys
- if ( result )
- {
- // delete the root key
- wxRegKey key(wxRegKey::HKCR, m_ext);
- if ( key.Exists() )
- result = key.DeleteSelf();
- }
-*/
- return result;
-}
-
-bool wxFileTypeImpl::RemoveOpenCommand()
-{
- return RemoveCommand(_T("open"));
-}
-
-bool wxFileTypeImpl::RemoveCommand(const wxString& verb)
-{
- wxCHECK_MSG( !m_ext.empty() && !verb.empty(), false,
- _T("RemoveCommand() needs an extension and a verb") );
-
- wxString sKey = m_strFileType;
- wxRegKey rkey(wxRegKey::HKCR, GetVerbPath(verb));
-
- // if the key already doesn't exist, it's a success
- return !rkey.Exists() || rkey.DeleteSelf();
-}
-
-bool wxFileTypeImpl::RemoveMimeType()
-{
- wxCHECK_MSG( !m_ext.empty(), false, _T("RemoveMimeType() needs extension") );
-
- wxRegKey rkey(wxRegKey::HKCR, m_ext);
- return !rkey.Exists() || rkey.DeleteSelf();
-}
-
-bool wxFileTypeImpl::RemoveDefaultIcon()
-{
- wxCHECK_MSG( !m_ext.empty(), false,
- _T("RemoveDefaultIcon() needs extension") );
-
- wxRegKey rkey (wxRegKey::HKCR, m_strFileType + _T("\\DefaultIcon"));
- return !rkey.Exists() || rkey.DeleteSelf();
-}
-
-bool wxFileTypeImpl::RemoveDescription()
-{
- wxCHECK_MSG( !m_ext.empty(), false,
- _T("RemoveDescription() needs extension") );
-
- wxRegKey rkey (wxRegKey::HKCR, m_strFileType );
- return !rkey.Exists() || rkey.DeleteSelf();
-}
-
-#endif // wxUSE_MIMETYPE
-#endif // __WXPALMOS__
+++ /dev/null
-/////////////////////////////////////////////////////////////////////////////
-// 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__
+++ /dev/null
-///////////////////////////////////////////////////////////////////////////////
-// Name: palmos/registry.cpp
-// Purpose: implementation of registry classes and functions
-// Author: Vadim Zeitlin
-// Modified by:
-// Created: 03.04.98
-// RCS-ID: $Id$
-// Copyright: (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
-// Licence: wxWindows licence
-// TODO: - parsing of registry key names
-// - support of other (than REG_SZ/REG_DWORD) registry types
-// - add high level functions (RegisterOleServer, ...)
-///////////////////////////////////////////////////////////////////////////////
-
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-#pragma implementation "registry.h"
-#endif
-
-// for compilers that support precompilation, includes "wx.h".
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
-#pragma hdrstop
-#endif
-
-// This really doesn't apply to the Palm OS platform. It would be better to
-// support the Palm OS preference database instead.
-#ifndef __WXPALMOS__
-
-// other wxWidgets headers
-#include "wx/string.h"
-#include "wx/intl.h"
-#include "wx/log.h"
-
-#include "wx/palmos/wrapwin.h"
-
-// other std headers
-#include <stdlib.h> // for _MAX_PATH
-
-#ifndef _MAX_PATH
- #define _MAX_PATH 512
-#endif
-
-// our header
-#define HKEY_DEFINED // already defined in windows.h
-#include "wx/palmos/registry.h"
-
-// some registry functions don't like signed chars
-typedef unsigned char *RegString;
-
-// ----------------------------------------------------------------------------
-// constants
-// ----------------------------------------------------------------------------
-
-// the registry name separator (perhaps one day MS will change it to '/' ;-)
-#define REG_SEPARATOR wxT('\\')
-
-// useful for Windows programmers: makes somewhat more clear all these zeroes
-// being passed to Windows APIs
-#define RESERVED (0)
-
-// ----------------------------------------------------------------------------
-// macros
-// ----------------------------------------------------------------------------
-
-// const_cast<> is not yet supported by all compilers
-#define CONST_CAST ((wxRegKey *)this)->
-
-// and neither is mutable which m_dwLastError should be
-#define m_dwLastError CONST_CAST m_dwLastError
-
-// ----------------------------------------------------------------------------
-// non member functions
-// ----------------------------------------------------------------------------
-
-// ============================================================================
-// implementation of wxRegKey class
-// ============================================================================
-
-// ----------------------------------------------------------------------------
-// static functions and variables
-// ----------------------------------------------------------------------------
-
-const size_t wxRegKey::nStdKeys = WXSIZEOF(aStdKeys);
-
-// @@ should take a `StdKey key', but as it's often going to be used in loops
-// it would require casts in user code.
-const wxChar *wxRegKey::GetStdKeyName(size_t key)
-{
- // return empty string if key is invalid
- wxCHECK_MSG( key < nStdKeys, wxEmptyString, wxT("invalid key in wxRegKey::GetStdKeyName") );
-
- return aStdKeys[key].szName;
-}
-
-const wxChar *wxRegKey::GetStdKeyShortName(size_t key)
-{
- // return empty string if key is invalid
- wxCHECK( key < nStdKeys, wxEmptyString );
-
- return aStdKeys[key].szShortName;
-}
-
-wxRegKey::StdKey wxRegKey::ExtractKeyName(wxString& strKey)
-{
- wxString strRoot = strKey.BeforeFirst(REG_SEPARATOR);
-
- HKEY hRootKey = 0;
- size_t ui;
- for ( ui = 0; ui < nStdKeys; ui++ ) {
- if ( strRoot.CmpNoCase(aStdKeys[ui].szName) == 0 ||
- strRoot.CmpNoCase(aStdKeys[ui].szShortName) == 0 ) {
- hRootKey = aStdKeys[ui].hkey;
- break;
- }
- }
-
- if ( ui == nStdKeys ) {
- wxFAIL_MSG(wxT("invalid key prefix in wxRegKey::ExtractKeyName."));
-
- hRootKey = HKEY_CLASSES_ROOT;
- }
- else {
- strKey = strKey.After(REG_SEPARATOR);
- if ( !strKey.empty() && strKey.Last() == REG_SEPARATOR )
- strKey.Truncate(strKey.Len() - 1);
- }
-
- return (wxRegKey::StdKey)(int)hRootKey;
-}
-
-wxRegKey::StdKey wxRegKey::GetStdKeyFromHkey(WXHKEY hkey)
-{
- for ( size_t ui = 0; ui < nStdKeys; ui++ ) {
- if ( (int) aStdKeys[ui].hkey == (int) hkey )
- return (StdKey)ui;
- }
-
- wxFAIL_MSG(wxT("non root hkey passed to wxRegKey::GetStdKeyFromHkey."));
-
- return HKCR;
-}
-
-// ----------------------------------------------------------------------------
-// ctors and dtor
-// ----------------------------------------------------------------------------
-
-wxRegKey::wxRegKey()
-{
- m_hRootKey = (WXHKEY) aStdKeys[HKCR].hkey;
-
- Init();
-}
-
-wxRegKey::wxRegKey(const wxString& strKey) : m_strKey(strKey)
-{
- m_hRootKey = (WXHKEY) aStdKeys[ExtractKeyName(m_strKey)].hkey;
-
- Init();
-}
-
-// parent is a predefined (and preopened) key
-wxRegKey::wxRegKey(StdKey keyParent, const wxString& strKey) : m_strKey(strKey)
-{
- RemoveTrailingSeparator(m_strKey);
- m_hRootKey = (WXHKEY) aStdKeys[keyParent].hkey;
-
- Init();
-}
-
-// parent is a normal regkey
-wxRegKey::wxRegKey(const wxRegKey& keyParent, const wxString& strKey)
- : m_strKey(keyParent.m_strKey)
-{
- // combine our name with parent's to get the full name
- if ( !m_strKey.empty() &&
- (strKey.empty() || strKey[0] != REG_SEPARATOR) ) {
- m_strKey += REG_SEPARATOR;
- }
-
- m_strKey += strKey;
- RemoveTrailingSeparator(m_strKey);
-
- m_hRootKey = keyParent.m_hRootKey;
-
- Init();
-}
-
-// dtor closes the key releasing system resource
-wxRegKey::~wxRegKey()
-{
- Close();
-}
-
-// ----------------------------------------------------------------------------
-// change the key name/hkey
-// ----------------------------------------------------------------------------
-
-// set the full key name
-void wxRegKey::SetName(const wxString& strKey)
-{
- Close();
-
- m_strKey = strKey;
- m_hRootKey = (WXHKEY) aStdKeys[ExtractKeyName(m_strKey)].hkey;
-}
-
-// the name is relative to the parent key
-void wxRegKey::SetName(StdKey keyParent, const wxString& strKey)
-{
- Close();
-
- m_strKey = strKey;
- RemoveTrailingSeparator(m_strKey);
- m_hRootKey = (WXHKEY) aStdKeys[keyParent].hkey;
-}
-
-// the name is relative to the parent key
-void wxRegKey::SetName(const wxRegKey& keyParent, const wxString& strKey)
-{
- Close();
-
- // combine our name with parent's to get the full name
-
- // NB: this method is called by wxRegConfig::SetPath() which is a performance
- // critical function and so it preallocates space for our m_strKey to
- // gain some speed - this is why we only use += here and not = which
- // would just free the prealloc'd buffer and would have to realloc it the
- // next line!
- m_strKey.clear();
- m_strKey += keyParent.m_strKey;
- if ( !strKey.empty() && strKey[0] != REG_SEPARATOR )
- m_strKey += REG_SEPARATOR;
- m_strKey += strKey;
-
- RemoveTrailingSeparator(m_strKey);
-
- m_hRootKey = keyParent.m_hRootKey;
-}
-
-// hKey should be opened and will be closed in wxRegKey dtor
-void wxRegKey::SetHkey(WXHKEY hKey)
-{
- Close();
-
- m_hKey = hKey;
-}
-
-// ----------------------------------------------------------------------------
-// info about the key
-// ----------------------------------------------------------------------------
-
-// returns true if the key exists
-bool wxRegKey::Exists() const
-{
- // opened key has to exist, try to open it if not done yet
- return IsOpened() ? true : KeyExists(m_hRootKey, m_strKey);
-}
-
-// returns the full name of the key (prefix is abbreviated if bShortPrefix)
-wxString wxRegKey::GetName(bool bShortPrefix) const
-{
- StdKey key = GetStdKeyFromHkey((WXHKEY) m_hRootKey);
- wxString str = bShortPrefix ? aStdKeys[key].szShortName
- : aStdKeys[key].szName;
- if ( !m_strKey.empty() )
- str << _T("\\") << m_strKey;
-
- return str;
-}
-
-bool wxRegKey::GetKeyInfo(size_t *pnSubKeys,
- size_t *pnMaxKeyLen,
- size_t *pnValues,
- size_t *pnMaxValueLen) const
-{
- // old gcc headers incorrectly prototype RegQueryInfoKey()
-#if defined(__GNUWIN32_OLD__) && !defined(__CYGWIN10__)
- #define REG_PARAM (size_t *)
-#else
- #define REG_PARAM (LPDWORD)
-#endif
-
- // it might be unexpected to some that this function doesn't open the key
- wxASSERT_MSG( IsOpened(), _T("key should be opened in GetKeyInfo") );
-
- m_dwLastError = ::RegQueryInfoKey
- (
- (HKEY) m_hKey,
- NULL, // class name
- NULL, // (ptr to) size of class name buffer
- RESERVED,
- REG_PARAM
- pnSubKeys, // [out] number of subkeys
- REG_PARAM
- pnMaxKeyLen, // [out] max length of a subkey name
- NULL, // longest subkey class name
- REG_PARAM
- pnValues, // [out] number of values
- REG_PARAM
- pnMaxValueLen, // [out] max length of a value name
- NULL, // longest value data
- NULL, // security descriptor
- NULL // time of last modification
- );
-
-#undef REG_PARAM
-
- if ( m_dwLastError != ERROR_SUCCESS ) {
- wxLogSysError(m_dwLastError, _("Can't get info about registry key '%s'"),
- GetName().c_str());
- return false;
- }
-
- return true;
-}
-
-// ----------------------------------------------------------------------------
-// operations
-// ----------------------------------------------------------------------------
-
-// opens key (it's not an error to call Open() on an already opened key)
-bool wxRegKey::Open(AccessMode mode)
-{
- if ( IsOpened() )
- return true;
-
- HKEY tmpKey;
- m_dwLastError = ::RegOpenKeyEx
- (
- (HKEY) m_hRootKey,
- m_strKey,
- RESERVED,
- mode == Read ? KEY_READ : KEY_ALL_ACCESS,
- &tmpKey
- );
-
- if ( m_dwLastError != ERROR_SUCCESS )
- {
- wxLogSysError(m_dwLastError, _("Can't open registry key '%s'"),
- GetName().c_str());
- return false;
- }
-
- m_hKey = (WXHKEY) tmpKey;
- return true;
-}
-
-// creates key, failing if it exists and !bOkIfExists
-bool wxRegKey::Create(bool bOkIfExists)
-{
- // check for existence only if asked (i.e. order is important!)
- if ( !bOkIfExists && Exists() )
- return false;
-
- if ( IsOpened() )
- return true;
-
- HKEY tmpKey;
-#ifdef __WXWINCE__
- DWORD disposition;
- m_dwLastError = RegCreateKeyEx((HKEY) m_hRootKey, m_strKey,
- NULL, // reserved
- NULL, // class string
- 0,
- 0,
- NULL,
- &tmpKey,
- &disposition);
-#else
- m_dwLastError = RegCreateKey((HKEY) m_hRootKey, m_strKey, &tmpKey);
-#endif
- if ( m_dwLastError != ERROR_SUCCESS ) {
- wxLogSysError(m_dwLastError, _("Can't create registry key '%s'"),
- GetName().c_str());
- return false;
- }
- else
- {
- m_hKey = (WXHKEY) tmpKey;
- return true;
- }
-}
-
-// close the key, it's not an error to call it when not opened
-bool wxRegKey::Close()
-{
- if ( IsOpened() ) {
- m_dwLastError = RegCloseKey((HKEY) m_hKey);
- m_hKey = 0;
-
- if ( m_dwLastError != ERROR_SUCCESS ) {
- wxLogSysError(m_dwLastError, _("Can't close registry key '%s'"),
- GetName().c_str());
-
- return false;
- }
- }
-
- return true;
-}
-
-bool wxRegKey::RenameValue(const wxChar *szValueOld, const wxChar *szValueNew)
-{
- bool ok = true;
- if ( HasValue(szValueNew) ) {
- wxLogError(_("Registry value '%s' already exists."), szValueNew);
-
- ok = false;
- }
-
- if ( !ok ||
- !CopyValue(szValueOld, *this, szValueNew) ||
- !DeleteValue(szValueOld) ) {
- wxLogError(_("Failed to rename registry value '%s' to '%s'."),
- szValueOld, szValueNew);
-
- return false;
- }
-
- return true;
-}
-
-bool wxRegKey::CopyValue(const wxChar *szValue,
- wxRegKey& keyDst,
- const wxChar *szValueNew)
-{
- if ( !szValueNew ) {
- // by default, use the same name
- szValueNew = szValue;
- }
-
- switch ( GetValueType(szValue) ) {
- case Type_String:
- {
- wxString strVal;
- return QueryValue(szValue, strVal) &&
- keyDst.SetValue(szValueNew, strVal);
- }
-
- case Type_Dword:
- /* case Type_Dword_little_endian: == Type_Dword */
- {
- long dwVal;
- return QueryValue(szValue, &dwVal) &&
- keyDst.SetValue(szValueNew, dwVal);
- }
-
- // these types are unsupported because I am not sure about how
- // exactly they should be copied and because they shouldn't
- // occur among the application keys (supposedly created with
- // this class)
- default:
- wxLogError(_("Can't copy values of unsupported type %d."),
- GetValueType(szValue));
- return false;
- }
-}
-
-bool wxRegKey::Rename(const wxChar *szNewName)
-{
- wxCHECK_MSG( !!m_strKey, false, _T("registry hives can't be renamed") );
-
- if ( !Exists() ) {
- wxLogError(_("Registry key '%s' does not exist, cannot rename it."),
- GetFullName(this));
-
- return false;
- }
-
- // do we stay in the same hive?
- bool inSameHive = !wxStrchr(szNewName, REG_SEPARATOR);
-
- // construct the full new name of the key
- wxRegKey keyDst;
-
- if ( inSameHive ) {
- // rename the key to the new name under the same parent
- wxString strKey = m_strKey.BeforeLast(REG_SEPARATOR);
- if ( !!strKey ) {
- // don't add '\\' in the start if strFullNewName is empty
- strKey += REG_SEPARATOR;
- }
-
- strKey += szNewName;
-
- keyDst.SetName(GetStdKeyFromHkey(m_hRootKey), strKey);
- }
- else {
- // this is the full name already
- keyDst.SetName(szNewName);
- }
-
- bool ok = keyDst.Create(false /* fail if alredy exists */);
- if ( !ok ) {
- wxLogError(_("Registry key '%s' already exists."),
- GetFullName(&keyDst));
- }
- else {
- ok = Copy(keyDst) && DeleteSelf();
- }
-
- if ( !ok ) {
- wxLogError(_("Failed to rename the registry key '%s' to '%s'."),
- GetFullName(this), GetFullName(&keyDst));
- }
- else {
- m_hRootKey = keyDst.m_hRootKey;
- m_strKey = keyDst.m_strKey;
- }
-
- return ok;
-}
-
-bool wxRegKey::Copy(const wxChar *szNewName)
-{
- // create the new key first
- wxRegKey keyDst(szNewName);
- bool ok = keyDst.Create(false /* fail if alredy exists */);
- if ( ok ) {
- ok = Copy(keyDst);
-
- // we created the dest key but copying to it failed - delete it
- if ( !ok ) {
- (void)keyDst.DeleteSelf();
- }
- }
-
- return ok;
-}
-
-bool wxRegKey::Copy(wxRegKey& keyDst)
-{
- bool ok = true;
-
- // copy all sub keys to the new location
- wxString strKey;
- long lIndex;
- bool bCont = GetFirstKey(strKey, lIndex);
- while ( ok && bCont ) {
- wxRegKey key(*this, strKey);
- wxString keyName;
- keyName << GetFullName(&keyDst) << REG_SEPARATOR << strKey;
- ok = key.Copy((const wxChar*) keyName);
-
- if ( ok )
- bCont = GetNextKey(strKey, lIndex);
- }
-
- // copy all values
- wxString strVal;
- bCont = GetFirstValue(strVal, lIndex);
- while ( ok && bCont ) {
- ok = CopyValue(strVal, keyDst);
-
- if ( !ok ) {
- wxLogSysError(m_dwLastError,
- _("Failed to copy registry value '%s'"),
- strVal.c_str());
- }
- else {
- bCont = GetNextValue(strVal, lIndex);
- }
- }
-
- if ( !ok ) {
- wxLogError(_("Failed to copy the contents of registry key '%s' to '%s'."), GetFullName(this), GetFullName(&keyDst));
- }
-
- return ok;
-}
-
-// ----------------------------------------------------------------------------
-// delete keys/values
-// ----------------------------------------------------------------------------
-bool wxRegKey::DeleteSelf()
-{
- {
- wxLogNull nolog;
- if ( !Open() ) {
- // it already doesn't exist - ok!
- return true;
- }
- }
-
- // prevent a buggy program from erasing one of the root registry keys or an
- // immediate subkey (i.e. one which doesn't have '\\' inside) of any other
- // key except HKCR (HKCR has some "deleteable" subkeys)
- if ( m_strKey.empty() ||
- ((m_hRootKey != (WXHKEY) aStdKeys[HKCR].hkey) &&
- (m_strKey.Find(REG_SEPARATOR) == wxNOT_FOUND)) ) {
- wxLogError(_("Registry key '%s' is needed for normal system operation,\ndeleting it will leave your system in unusable state:\noperation aborted."), GetFullName(this));
-
- return false;
- }
-
- // we can't delete keys while enumerating because it confuses GetNextKey, so
- // we first save the key names and then delete them all
- wxArrayString astrSubkeys;
-
- wxString strKey;
- long lIndex;
- bool bCont = GetFirstKey(strKey, lIndex);
- while ( bCont ) {
- astrSubkeys.Add(strKey);
-
- bCont = GetNextKey(strKey, lIndex);
- }
-
- size_t nKeyCount = astrSubkeys.Count();
- for ( size_t nKey = 0; nKey < nKeyCount; nKey++ ) {
- wxRegKey key(*this, astrSubkeys[nKey]);
- if ( !key.DeleteSelf() )
- return false;
- }
-
- // now delete this key itself
- Close();
-
- m_dwLastError = RegDeleteKey((HKEY) m_hRootKey, m_strKey);
- // deleting a key which doesn't exist is not considered an error
- if ( m_dwLastError != ERROR_SUCCESS &&
- m_dwLastError != ERROR_FILE_NOT_FOUND ) {
- wxLogSysError(m_dwLastError, _("Can't delete key '%s'"),
- GetName().c_str());
- return false;
- }
-
- return true;
-}
-
-bool wxRegKey::DeleteKey(const wxChar *szKey)
-{
- if ( !Open() )
- return false;
-
- wxRegKey key(*this, szKey);
- return key.DeleteSelf();
-}
-
-bool wxRegKey::DeleteValue(const wxChar *szValue)
-{
- if ( !Open() )
- return false;
-
- m_dwLastError = RegDeleteValue((HKEY) m_hKey, WXSTRINGCAST szValue);
-
- // deleting a value which doesn't exist is not considered an error
- if ( (m_dwLastError != ERROR_SUCCESS) &&
- (m_dwLastError != ERROR_FILE_NOT_FOUND) ) {
- wxLogSysError(m_dwLastError, _("Can't delete value '%s' from key '%s'"),
- szValue, GetName().c_str());
- return false;
- }
-
- return true;
-}
-
-// ----------------------------------------------------------------------------
-// access to values and subkeys
-// ----------------------------------------------------------------------------
-
-// return true if value exists
-bool wxRegKey::HasValue(const wxChar *szValue) const
-{
- // this function should be silent, so suppress possible messages from Open()
- wxLogNull nolog;
-
- if ( !CONST_CAST Open() )
- return false;
-
- LONG dwRet = ::RegQueryValueEx((HKEY) m_hKey,
- WXSTRINGCAST szValue,
- RESERVED,
- NULL, NULL, NULL);
- return dwRet == ERROR_SUCCESS;
-}
-
-// returns true if this key has any values
-bool wxRegKey::HasValues() const
-{
- // suppress possible messages from GetFirstValue()
- wxLogNull nolog;
-
- // just call GetFirstValue with dummy parameters
- wxString str;
- long l;
- return CONST_CAST GetFirstValue(str, l);
-}
-
-// returns true if this key has any subkeys
-bool wxRegKey::HasSubkeys() const
-{
- // suppress possible messages from GetFirstKey()
- wxLogNull nolog;
-
- // just call GetFirstKey with dummy parameters
- wxString str;
- long l;
- return CONST_CAST GetFirstKey(str, l);
-}
-
-// returns true if given subkey exists
-bool wxRegKey::HasSubKey(const wxChar *szKey) const
-{
- // this function should be silent, so suppress possible messages from Open()
- wxLogNull nolog;
-
- if ( !CONST_CAST Open() )
- return false;
-
- return KeyExists(m_hKey, szKey);
-}
-
-wxRegKey::ValueType wxRegKey::GetValueType(const wxChar *szValue) const
-{
- if ( ! CONST_CAST Open() )
- return Type_None;
-
- DWORD dwType;
- m_dwLastError = RegQueryValueEx((HKEY) m_hKey, WXSTRINGCAST szValue, RESERVED,
- &dwType, NULL, NULL);
- if ( m_dwLastError != ERROR_SUCCESS ) {
- wxLogSysError(m_dwLastError, _("Can't read value of key '%s'"),
- GetName().c_str());
- return Type_None;
- }
-
- return (ValueType)dwType;
-}
-
-bool wxRegKey::QueryValue(const wxChar *szValue,
- wxString& strValue,
- bool raw) const
-{
- if ( CONST_CAST Open() ) {
-
- // first get the type and size of the data
- DWORD dwType, dwSize;
- m_dwLastError = RegQueryValueEx((HKEY) m_hKey, WXSTRINGCAST szValue, RESERVED,
- &dwType, NULL, &dwSize);
- if ( m_dwLastError == ERROR_SUCCESS ) {
- if ( !dwSize ) {
- // must treat this case specially as GetWriteBuf() doesn't like
- // being called with 0 size
- strValue.Empty();
- }
- else {
- m_dwLastError = RegQueryValueEx((HKEY) m_hKey,
- WXSTRINGCAST szValue,
- RESERVED,
- &dwType,
- (RegString)(wxChar*)wxStringBuffer(strValue, dwSize),
- &dwSize);
-
- // expand the var expansions in the string unless disabled
-#ifndef __WXWINCE__
- if ( (dwType == REG_EXPAND_SZ) && !raw )
- {
- DWORD dwExpSize = ::ExpandEnvironmentStrings(strValue, NULL, 0);
- bool ok = dwExpSize != 0;
- if ( ok )
- {
- wxString strExpValue;
- ok = ::ExpandEnvironmentStrings
- (
- strValue,
- wxStringBuffer(strExpValue, dwExpSize),
- dwExpSize
- ) != 0;
- strValue = strExpValue;
- }
-
- if ( !ok )
- {
- wxLogLastError(_T("ExpandEnvironmentStrings"));
- }
- }
-#endif
- // __WXWINCE__
- }
-
- if ( m_dwLastError == ERROR_SUCCESS ) {
- // check that it was the right type
- wxASSERT_MSG( !IsNumericValue(szValue),
- wxT("Type mismatch in wxRegKey::QueryValue().") );
-
- return true;
- }
- }
- }
-
- wxLogSysError(m_dwLastError, _("Can't read value of '%s'"),
- GetFullName(this, szValue));
- return false;
-}
-
-bool wxRegKey::SetValue(const wxChar *szValue, const wxString& strValue)
-{
- if ( CONST_CAST Open() ) {
- m_dwLastError = RegSetValueEx((HKEY) m_hKey, szValue, (DWORD) RESERVED, REG_SZ,
- (RegString)strValue.c_str(),
- (strValue.Len() + 1)*sizeof(wxChar));
- if ( m_dwLastError == ERROR_SUCCESS )
- return true;
- }
-
- wxLogSysError(m_dwLastError, _("Can't set value of '%s'"),
- GetFullName(this, szValue));
- return false;
-}
-
-wxString wxRegKey::QueryDefaultValue() const
-{
- wxString str;
- QueryValue(NULL, str);
- return str;
-}
-
-// ----------------------------------------------------------------------------
-// enumeration
-// NB: all these functions require an index variable which allows to have
-// several concurrently running indexations on the same key
-// ----------------------------------------------------------------------------
-
-bool wxRegKey::GetFirstValue(wxString& strValueName, long& lIndex)
-{
- if ( !Open() )
- return false;
-
- lIndex = 0;
- return GetNextValue(strValueName, lIndex);
-}
-
-bool wxRegKey::GetNextValue(wxString& strValueName, long& lIndex) const
-{
- wxASSERT( IsOpened() );
-
- // are we already at the end of enumeration?
- if ( lIndex == -1 )
- return false;
-
- wxChar szValueName[1024]; // @@ use RegQueryInfoKey...
- DWORD dwValueLen = WXSIZEOF(szValueName);
-
- m_dwLastError = RegEnumValue((HKEY) m_hKey, lIndex++,
- szValueName, &dwValueLen,
- RESERVED,
- NULL, // [out] type
- NULL, // [out] buffer for value
- NULL); // [i/o] it's length
-
- if ( m_dwLastError != ERROR_SUCCESS ) {
- if ( m_dwLastError == ERROR_NO_MORE_ITEMS ) {
- m_dwLastError = ERROR_SUCCESS;
- lIndex = -1;
- }
- else {
- wxLogSysError(m_dwLastError, _("Can't enumerate values of key '%s'"),
- GetName().c_str());
- }
-
- return false;
- }
-
- strValueName = szValueName;
-
- return true;
-}
-
-bool wxRegKey::GetFirstKey(wxString& strKeyName, long& lIndex)
-{
- if ( !Open() )
- return false;
-
- lIndex = 0;
- return GetNextKey(strKeyName, lIndex);
-}
-
-bool wxRegKey::GetNextKey(wxString& strKeyName, long& lIndex) const
-{
- wxASSERT( IsOpened() );
-
- // are we already at the end of enumeration?
- if ( lIndex == -1 )
- return false;
-
- wxChar szKeyName[_MAX_PATH + 1];
-
-#ifdef __WXWINCE__
- DWORD sizeName = WXSIZEOF(szKeyName);
- m_dwLastError = RegEnumKeyEx((HKEY) m_hKey, lIndex++, szKeyName, & sizeName,
- 0, NULL, NULL, NULL);
-#else
- m_dwLastError = RegEnumKey((HKEY) m_hKey, lIndex++, szKeyName, WXSIZEOF(szKeyName));
-#endif
-
- if ( m_dwLastError != ERROR_SUCCESS ) {
- if ( m_dwLastError == ERROR_NO_MORE_ITEMS ) {
- m_dwLastError = ERROR_SUCCESS;
- lIndex = -1;
- }
- else {
- wxLogSysError(m_dwLastError, _("Can't enumerate subkeys of key '%s'"),
- GetName().c_str());
- }
-
- return false;
- }
-
- strKeyName = szKeyName;
- return true;
-}
-
-// returns true if the value contains a number (else it's some string)
-bool wxRegKey::IsNumericValue(const wxChar *szValue) const
-{
- ValueType type = GetValueType(szValue);
- switch ( type ) {
- case Type_Dword:
- /* case Type_Dword_little_endian: == Type_Dword */
- case Type_Dword_big_endian:
- return true;
-
- default:
- return false;
- }
-}
-
-// ============================================================================
-// implementation of global private functions
-// ============================================================================
-
-bool KeyExists(WXHKEY hRootKey, const wxChar *szKey)
-{
- // don't close this key itself for the case of empty szKey!
- if ( wxIsEmpty(szKey) )
- return true;
-
- HKEY hkeyDummy;
- if ( ::RegOpenKeyEx
- (
- (HKEY)hRootKey,
- szKey,
- RESERVED,
- KEY_READ, // we might not have enough rights for rw access
- &hkeyDummy
- ) == ERROR_SUCCESS )
- {
- ::RegCloseKey(hkeyDummy);
-
- return true;
- }
-
- return false;
-}
-
-const wxChar *GetFullName(const wxRegKey *pKey, const wxChar *szValue)
-{
- static wxString s_str;
- s_str = pKey->GetName();
- if ( !wxIsEmpty(szValue) )
- s_str << wxT("\\") << szValue;
-
- return s_str.c_str();
-}
-
-void RemoveTrailingSeparator(wxString& str)
-{
- if ( !str.empty() && str.Last() == REG_SEPARATOR )
- str.Truncate(str.Len() - 1);
-}
-
-#endif //Palm OS
-
+++ /dev/null
-///////////////////////////////////////////////////////////////////////////////
-// Name: palmos/renderer.cpp
-// Purpose: implementation of wxRendererNative for Palm OS
-// Author: Vadim Zeitlin
-// Modified by:
-// Created: 20.07.2003
-// RCS-ID: $Id$
-// Copyright: (c) 2003 Vadim Zeitlin <vadim@wxwindows.org>
-// License: wxWindows licence
-///////////////////////////////////////////////////////////////////////////////
-
-// ============================================================================
-// declarations
-// ============================================================================
-
-// ----------------------------------------------------------------------------
-// headers
-// ----------------------------------------------------------------------------
-
-// for compilers that support precompilation, includes "wx.h".
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
- #pragma hdrstop
-#endif
-
-// Palm OS doesn't really have a theme engine, so this is not needed.
-#ifndef __WXPALMOS__
-
-#ifndef WX_PRECOMP
- #include "wx/string.h"
- #include "wx/window.h"
- #include "wx/dc.h"
-#endif //WX_PRECOMP
-
-#include "wx/splitter.h"
-#include "wx/renderer.h"
-
-#include "wx/palmos/uxtheme.h"
-
-// ----------------------------------------------------------------------------
-// wxRendererMSW: wxRendererNative implementation for "old" Win32 systems
-// ----------------------------------------------------------------------------
-
-class WXDLLEXPORT wxRendererMSW : public wxDelegateRendererNative
-{
-public:
- wxRendererMSW() { }
-
- static wxRendererNative& Get();
-
-private:
- DECLARE_NO_COPY_CLASS(wxRendererMSW)
-};
-
-// ----------------------------------------------------------------------------
-// wxRendererXP: wxRendererNative implementation for Windows XP and later
-// ----------------------------------------------------------------------------
-
-class WXDLLEXPORT wxRendererXP : public wxDelegateRendererNative
-{
-public:
- wxRendererXP() : wxDelegateRendererNative(wxRendererMSW::Get()) { }
-
- static wxRendererNative& Get();
-
- virtual void DrawSplitterBorder(wxWindow *win,
- wxDC& dc,
- const wxRect& rect,
- int flags = 0);
- virtual void DrawSplitterSash(wxWindow *win,
- wxDC& dc,
- const wxSize& size,
- wxCoord position,
- wxOrientation orient,
- int flags = 0);
- virtual wxSplitterRenderParams GetSplitterParams(const wxWindow *win);
-
-private:
- DECLARE_NO_COPY_CLASS(wxRendererXP)
-};
-
-// ============================================================================
-// wxRendererNative and wxRendererMSW implementation
-// ============================================================================
-
-/* static */
-wxRendererNative& wxRendererNative::GetDefault()
-{
- wxUxThemeEngine *themeEngine = wxUxThemeEngine::Get();
- return themeEngine && themeEngine->IsAppThemed() ? wxRendererXP::Get()
- : wxRendererMSW::Get();
-}
-
-/* static */
-wxRendererNative& wxRendererMSW::Get()
-{
- static wxRendererMSW s_rendererMSW;
-
- return s_rendererMSW;
-}
-
-// ============================================================================
-// wxRendererXP implementation
-// ============================================================================
-
-/* static */
-wxRendererNative& wxRendererXP::Get()
-{
- static wxRendererXP s_rendererXP;
-
- return s_rendererXP;
-}
-
-// ----------------------------------------------------------------------------
-// splitter drawing
-// ----------------------------------------------------------------------------
-
-// the width of the sash: this is the same as used by Explorer...
-static const wxCoord SASH_WIDTH = 4;
-
-wxSplitterRenderParams
-wxRendererXP::GetSplitterParams(const wxWindow * win)
-{
- if (win->GetWindowStyle() & wxSP_NO_XP_THEME)
- return m_rendererNative.GetSplitterParams(win);
- else
- return wxSplitterRenderParams(SASH_WIDTH, 0, false);
-}
-
-void
-wxRendererXP::DrawSplitterBorder(wxWindow * win,
- wxDC& dc,
- const wxRect& rect,
- int flags)
-{
- if (win->GetWindowStyle() & wxSP_NO_XP_THEME)
- {
- m_rendererNative.DrawSplitterBorder(win, dc, rect, flags);
- }
-}
-
-void
-wxRendererXP::DrawSplitterSash(wxWindow *win,
- wxDC& dc,
- const wxSize& size,
- wxCoord position,
- wxOrientation orient,
- int flags)
-{
- if (win->GetWindowStyle() & wxSP_NO_XP_THEME)
- {
- m_rendererNative.DrawSplitterSash(
- win, dc, size, position, orient, flags);
- return;
- }
-
- // I don't know if it is correct to use the rebar background for the
- // splitter but it least this works ok in the default theme
- wxUxThemeHandle hTheme(win, L"REBAR");
- if ( hTheme )
- {
- RECT rect;
- if ( orient == wxVERTICAL )
- {
- rect.left = position;
- rect.right = position + SASH_WIDTH;
- rect.top = 0;
- rect.bottom = size.y;
- }
- else // wxHORIZONTAL
- {
- rect.left = 0;
- rect.right = size.x;
- rect.top = position;
- rect.bottom = position + SASH_WIDTH;
- }
-
- wxUxThemeEngine::Get()->DrawThemeBackground
- (
- (WXHTHEME)hTheme,
- dc.GetHDC(),
- 3 /* RP_BAND */,
- 0 /* no state */ ,
- &rect,
- NULL
- );
- }
-}
-
-#endif