midp_msgqueue_md.c
来自「This is a resource based on j2me embedde」· C语言 代码 · 共 168 行
C
168 行
/* * * * Copyright 1990-2007 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 only, as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License version 2 for more details (a copy is * included at /legal/license.txt). * * You should have received a copy of the GNU General Public License * version 2 along with this work; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 or visit www.sun.com if you need additional * information or have any questions. */#include <windows.h>#include <midp_mastermode_port.h>#include <winceapp_export.h>MidpReentryData* pSignalResult;MidpEvent* pMidpEventResult;int appManagerRequestWaiting = 0;int inMidpEventLoop = 0;int midpPaintAllowed = 1;int lastWmSettingChangeTick = 0;/* * This function is called by the VM periodically. It has to check if * system has sent a signal to MIDP and return the result in the * structs given. * * Values for the <timeout> paramater: * >0 = Block until a signal sent to MIDP, or until <timeout> milliseconds * has elapsed. * 0 = Check the system for a signal but do not block. Return to the * caller immediately regardless of the if a signal was sent. * -1 = Do not timeout. Block until a signal is sent to MIDP. */void checkForSystemSignal(MidpReentryData* pNewSignal, MidpEvent* pNewMidpEvent, jlong timeout) { MSG msg; unsigned long before; unsigned long after; inMidpEventLoop = 1; if (!midpPaintAllowed && timeout == 0) { /* Either the startmenu is pulled down, or we have switched * to another app. Since WinCE is not smart enough to dial down * our thread priority level, let's back off a bit to allow other * WinCE tasks to run. */ timeout = 30; } if (lastWmSettingChangeTick != 0) { int now = GetTickCount(); int diff = now - lastWmSettingChangeTick; if (diff < 0) { /* Clock wrapped */ lastWmSettingChangeTick = now; } else if (diff < 3000) { /* The user might have recently rotated the screen, or opened * the SIP keyboard. We need to back off a little to allow the * system to repaint the menus. */ if (timeout < 30) { timeout = 30; } } } if (timeout > 0) { before = (unsigned long)GetTickCount(); } /* * The only way to get output from the window procedure is to use * shared data. */ pSignalResult = pNewSignal; pMidpEventResult = pNewMidpEvent; do { if (!PeekMessage(&msg, NULL, 0, 0, PM_REMOVE)) { if (timeout == 0) { goto done; } /* * Unblock at the specified timeout even if not messages are * present. * A negative timeout value means to block until an event comes in. */ if (timeout > 0) { if (SetTimer(winceapp_get_window_handle(), EVENT_TIMER_ID, (UINT)timeout, NULL) == 0) { /* Timer already exists from last time. */ KillTimer(winceapp_get_window_handle(), EVENT_TIMER_ID); if (SetTimer(winceapp_get_window_handle(), EVENT_TIMER_ID, (UINT)timeout, NULL) == 0) { /* Can't set up the timer so do not block. */ goto done; } } } GetMessage(&msg, NULL, 0, 0); } /* Dispatching the message will call WndProc below. */ appManagerRequestWaiting = 0; TranslateMessage(&msg); DispatchMessage(&msg); if (appManagerRequestWaiting || pSignalResult->waitingFor != NO_SIGNAL) { /* We got signal to unblock a Java thread. */ goto done; } if (timeout < 0) { /* Wait until there is a signal for MIDP. */ continue; } if (timeout > 0) { after = (unsigned long)GetTickCount(); if (after > before) { timeout -= (jlong)(after - before); } else { /* The tick count has wrapped. (happens every 49.7 days) */ timeout -= (jlong)((unsigned long)0xFFFFFFFF - before + after); } } } while (timeout > 0);done: inMidpEventLoop = 0; return;}/** * Free the event result. Called when no waiting Java thread was found to * receive the result. This may be empty on some systems. * * @param waitingFor what signal the result is for * @param pResult the result set by checkForSystemSignal */void midpFreeEventResult(int waitingFor, void* pResult) { (void)waitingFor; (void)pResult;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?