#include "wx/msw/private/hiddenwin.h"
+// FIXME-VC6: These are not defined in VC6 SDK headers.
+#ifndef BELOW_NORMAL_PRIORITY_CLASS
+ #define BELOW_NORMAL_PRIORITY_CLASS 0x4000
+#endif
+
+#ifndef ABOVE_NORMAL_PRIORITY_CLASS
+ #define ABOVE_NORMAL_PRIORITY_CLASS 0x8000
+#endif
+
// ----------------------------------------------------------------------------
// constants
// ----------------------------------------------------------------------------
}
// Translate wxWidgets priority to Windows conventions.
- unsigned prio = handler->GetPriority();
- if ( prio <= 20 )
- dwFlags |= IDLE_PRIORITY_CLASS;
- else if ( prio <= 40 )
- dwFlags |= BELOW_NORMAL_PRIORITY_CLASS;
- else if ( prio <= 60 )
- dwFlags |= NORMAL_PRIORITY_CLASS;
- else if ( prio <= 80 )
- dwFlags |= ABOVE_NORMAL_PRIORITY_CLASS;
- else if ( prio <= 99 )
- dwFlags |= HIGH_PRIORITY_CLASS;
- else if ( prio <= 100 )
- dwFlags |= REALTIME_PRIORITY_CLASS;
- else
+ if ( handler )
{
- wxFAIL_MSG(wxT("invalid value of thread priority parameter"));
- dwFlags |= THREAD_PRIORITY_NORMAL;
+ unsigned prio = handler->GetPriority();
+ if ( prio <= 20 )
+ dwFlags |= IDLE_PRIORITY_CLASS;
+ else if ( prio <= 40 )
+ dwFlags |= BELOW_NORMAL_PRIORITY_CLASS;
+ else if ( prio <= 60 )
+ dwFlags |= NORMAL_PRIORITY_CLASS;
+ else if ( prio <= 80 )
+ dwFlags |= ABOVE_NORMAL_PRIORITY_CLASS;
+ else if ( prio <= 99 )
+ dwFlags |= HIGH_PRIORITY_CLASS;
+ else if ( prio <= 100 )
+ dwFlags |= REALTIME_PRIORITY_CLASS;
+ else
+ {
+ wxFAIL_MSG(wxT("invalid value of thread priority parameter"));
+ dwFlags |= NORMAL_PRIORITY_CLASS;
+ }
}
bool ok = ::CreateProcess