X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/90a77e64841dfcaf37103b6411987402739baa0b..d2e66707deb10dea6f92e3e4092f8a43ef942a5d:/src/palmos/utils.cpp?ds=inline diff --git a/src/palmos/utils.cpp b/src/palmos/utils.cpp index c8d8d84908..d52e90fb35 100644 --- a/src/palmos/utils.cpp +++ b/src/palmos/utils.cpp @@ -37,11 +37,18 @@ #include "wx/confbase.h" #include "wx/power.h" +#include #include #include #include +#include // SysDoze()... #include +#ifdef __WXPALMOS6__ +extern void SysReset (void); +extern UInt32 SysTaskID (void); +#endif + // ============================================================================ // implementation // ============================================================================ @@ -90,7 +97,7 @@ bool wxGetUserName(wxChar *buf, int maxSize) return false; } - wxStrncpy (buf, wxSafeConvertMB2WX(id), maxSize - 1); + wxStrlcpy(buf, wxSafeConvertMB2WX(id), maxSize); // free the buffer MemPtrUnlock(id); @@ -100,12 +107,15 @@ bool wxGetUserName(wxChar *buf, int maxSize) const wxChar* wxGetHomeDir(wxString *pstr) { - return NULL; + if (NULL != pstr) { + *pstr = "/palmos"; + } + return wxT("/palmos"); } -wxChar *wxGetUserHome(const wxString& WXUNUSED(user)) +wxString wxGetUserHome(const wxString& WXUNUSED(user)) { - return NULL; + return wxString("/palmos"); } bool wxGetDiskSpace(const wxString& path, wxDiskspaceSize_t *pTotal, wxDiskspaceSize_t *pFree) @@ -122,10 +132,12 @@ bool wxGetEnv(const wxString& var, wxString *value) return false; } +#if ! WXWIN_COMPATIBILITY_2_8 bool wxSetEnv(const wxString& var, const wxChar *value) { return false; } +#endif // ! WXWIN_COMPATIBILITY_2_8 bool wxUnsetEnv(const wxString& var) { @@ -150,6 +162,24 @@ bool wxShell(const wxString& command) // Shutdown or reboot the PC bool wxShutdown(wxShutdownFlags wFlags) { + switch (wFlags) { + case wxSHUTDOWN_POWEROFF: + // TODO: turn off lamps +#ifdef __WXPALMOS6__ + //extern void SysReset (void); + //extern UInt32 SysTaskID (void); + #define SysReset() + #define SysTaskID() (0) + SysSleep (); +#else + //SysSleep (false, false);// undocument API + SysDoze (true); +#endif + break; + case wxSHUTDOWN_REBOOT: + SysReset (); + break; + } return false; } @@ -159,13 +189,25 @@ bool wxShutdown(wxShutdownFlags wFlags) wxPowerType wxGetPowerType() { + //SysBatteryKind kind; + //POS_SysBatteryInfo (false, NULL, NULL, NULL, NULL, NULL, &kind, NULL); + //return wxPOWER_SOCKET; return wxPOWER_BATTERY; } wxBatteryState wxGetBatteryState() { - // TODO - return wxBATTERY_UNKNOWN_STATE; + //#include "SystemMgr.h" + UInt8 percent; + POS_SysBatteryInfo (false, NULL, NULL, NULL, NULL, NULL, NULL, &percent); + if (percent < 3) + return wxBATTERY_SHUTDOWN_STATE; + else if (percent < 5) + return wxBATTERY_CRITICAL_STATE; + else if (percent < 15) + return wxBATTERY_LOW_STATE; + //return wxBATTERY_UNKNOWN_STATE; + return wxBATTERY_NORMAL_STATE; } // ---------------------------------------------------------------------------- @@ -180,7 +222,7 @@ wxMemorySize wxGetFreeMemory() uint32_t freeChunk; // executed twice: for the dynamic heap, and for the non-secure RAM storage heap - for ( uint16_t i=0; i= 0x02000000) v20 = true; char *version = SysGetOSVersionString(); if(version) { @@ -228,8 +272,7 @@ wxString wxGetOsDescription() wxOperatingSystemId wxGetOsVersion(int *verMaj, int *verMin) { // TODO - - return wxOS_UNKNOWN; + return wxOS_PALM_OS; } // ---------------------------------------------------------------------------- @@ -238,14 +281,35 @@ wxOperatingSystemId wxGetOsVersion(int *verMaj, int *verMin) void wxMilliSleep(unsigned long milliseconds) { + UInt16 ticks_sec; + Int32 delay; + ticks_sec = SysTicksPerSecond (); + delay = milliseconds * ticks_sec / 1000; + if (delay > 0) { + SysTaskDelay (delay); + } } void wxMicroSleep(unsigned long microseconds) { + UInt16 ticks_sec; + Int32 delay; + ticks_sec = SysTicksPerSecond (); + delay = microseconds * ticks_sec / 1000000; + if (delay > 0) { + SysTaskDelay (delay); + } } void wxSleep(int nSecs) { + UInt16 ticks_sec; + Int32 delay; + ticks_sec = SysTicksPerSecond (); + delay = nSecs * ticks_sec; + if (delay > 0) { + SysTaskDelay (delay); + } } // ----------------------------------------------------------------------------