亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? scidisp.c

?? 計算器源代碼c。和windows自帶的功能差不多。很多科學(xué)計算還沒有加入。
?? C
字號:
/****************************Module*Header***********************************\
* Module Name: SCIDISP.C
*
* Module Descripton:
*
* Warnings:
*
* Created:
*
* Author:
\****************************************************************************/

#include "scicalc.h"
#include "unifunc.h"
#include "input.h"


extern HNUMOBJ      ghnoNum;
extern eNUMOBJ_FMT  nFE;
extern TCHAR        szDec[5];
extern TCHAR        gszSep[5];
extern LPTSTR       gpszNum;
extern BOOL         gbRecord;
extern BOOL         gbUseSep;
extern CALCINPUTOBJ gcio;


/****************************************************************************\
* void DisplayNum(void)
*
* Convert ghnoNum to a string in the current radix.
*
* Updates the following globals:
*   ghnoNum, gpszNum
\****************************************************************************/
//
// State of calc last time DisplayNum was called
//
typedef struct {
    HNUMOBJ     hnoNum;
    LONG        nPrecision;
    LONG        nRadix;
    INT         nFE;
    INT         nCalc;
    INT         nHexMode;
    BOOL        fIntMath;
    BOOL        bRecord;
    BOOL        bUseSep;
} LASTDISP;

LASTDISP gldPrevious = { NULL, -1, -1, -1, -1, -1, FALSE, FALSE, FALSE };

#define InvalidLastDisp( pglp ) ((pglp)->hnoNum == NULL )


void AddNumSeparator(TCHAR sep, int sepLen, PTSTR szDisplay,
                     PTSTR szSepDisplay);


void DisplayNum(void)
{
    SetWaitCursor( TRUE );

    //
    // Only change the display if
    //  we are in record mode                               -OR-
    //  this is the first time DisplayNum has been called,  -OR-
    //  something important has changed since the last time DisplayNum was
    //  called.
    //
    if ( gbRecord || InvalidLastDisp( &gldPrevious ) ||
            !NumObjIsEq( gldPrevious.hnoNum,      ghnoNum     ) ||
            gldPrevious.nPrecision  != nPrecision   ||
            gldPrevious.nRadix      != nRadix       ||
            gldPrevious.nFE         != (int)nFE     ||
            gldPrevious.nCalc       != nCalc        ||
            gldPrevious.bUseSep     != gbUseSep     ||
            gldPrevious.nHexMode    != nHexMode     ||
            gldPrevious.fIntMath    != F_INTMATH()  ||
            gldPrevious.bRecord     != gbRecord )
    {
        // Assign is an expensive operation, only do when really needed
        if ( ghnoNum )
            NumObjAssign( &gldPrevious.hnoNum, ghnoNum );

        gldPrevious.nPrecision = nPrecision;
        gldPrevious.nRadix     = nRadix;
        gldPrevious.nFE        = (int)nFE;
        gldPrevious.nCalc      = nCalc;
        gldPrevious.nHexMode   = nHexMode;

        gldPrevious.fIntMath   = F_INTMATH();
        gldPrevious.bRecord    = gbRecord;
        gldPrevious.bUseSep    = gbUseSep;

        if (gbRecord)
        {
            // Display the string and return.

            CIO_vConvertToString(&gpszNum, &gcio, nRadix);
        }
        else if (!F_INTMATH())
        {
            // Decimal conversion

            NumObjGetSzValue( &gpszNum, ghnoNum, nRadix, nFE );
        }
        else
        {
            // Non-decimal conversion
            int i;

            // Truncate to an integer.  Do not round here.
            intrat( &ghnoNum );

            // Check the range.
            if ( NumObjIsLess( ghnoNum, HNO_ZERO ) )
            {
                // if negative make positive by doing a twos complement
                NumObjNegate( &ghnoNum );
                subrat( &ghnoNum, HNO_ONE );
                NumObjNot( &ghnoNum );
            }

            andrat( &ghnoNum, g_ahnoChopNumbers[nHexMode] );

            NumObjGetSzValue( &gpszNum, ghnoNum, nRadix, FMT_FLOAT );

            // Clobber trailing decimal point
            i = lstrlen( gpszNum ) - 1;
            if ( i >= 0 && gpszNum[i] == szDec[0] )
                gpszNum[i] = TEXT('\0');
        }

        // Display the string and return.

        if (!gbUseSep)
        {
            TCHAR szTrailSpace[256];

            lstrcpy(szTrailSpace,gpszNum);
            lstrcat(szTrailSpace,TEXT(" "));
            SetDlgItemText(g_hwndDlg, IDC_DISPLAY, szTrailSpace);
        }
        else
        {
            switch(nRadix)
            {
                TCHAR szSepNum[256];

                case 10:
                    AddNumSeparator(gszSep[0], 3, gpszNum, szSepNum);
                    lstrcat(szSepNum,TEXT(" "));
                    SetDlgItemText(g_hwndDlg, IDC_DISPLAY, szSepNum);
                    break;

                case 2:
                case 16:
                    AddNumSeparator(TEXT(' '), 4, gpszNum, szSepNum);
                    lstrcat(szSepNum,TEXT(" "));
                    SetDlgItemText(g_hwndDlg, IDC_DISPLAY, szSepNum);
                    break;

                default:
                    lstrcpy(szSepNum,gpszNum);
                    lstrcat(szSepNum,TEXT(" "));
                    SetDlgItemText(g_hwndDlg, IDC_DISPLAY, szSepNum);
            }
        }
    }

    SetWaitCursor( FALSE );

    return;
}

/****************************************************************************\
*
* WatchDogThread
*
* Thread to look out for functions that take too long.  If it finds one, it
* prompts the user if he wants to abort the function, and asks RATPAK to
* abort if he does.
*
* History
*   26-Nov-1996 JonPa   Wrote it.
*
\****************************************************************************/
BOOL gfExiting = FALSE;
HANDLE ghCalcStart = NULL;
HANDLE ghCalcDone = NULL;
HANDLE ghDogThread = NULL;

INT_PTR TimeOutMessageBox( void );

DWORD WINAPI WatchDogThread( LPVOID pvParam ) {
    DWORD   cmsWait;
    INT_PTR iRet;

    while( !gfExiting ) {
        WaitForSingleObject( ghCalcStart, INFINITE );
        if (gfExiting)
            break;

        cmsWait = CMS_CALC_TIMEOUT;

        while( WaitForSingleObject( ghCalcDone, cmsWait ) == WAIT_TIMEOUT ) {

            // Put up the msg box
            MessageBeep( MB_ICONEXCLAMATION );
            iRet = TimeOutMessageBox();

            // if user wants to cancel, then stop
            if (gfExiting || iRet == IDYES || iRet == IDCANCEL) {
                NumObjAbortOperation(TRUE);
                break;
            } else {
                cmsWait *= 2;
                if (cmsWait > CMS_MAX_TIMEOUT) {
                    cmsWait = CMS_MAX_TIMEOUT;
                }
            }
        }
    }

    return 42;
}

/****************************************************************************\
*
* TimeCalc
*
*   Function to keep track of how long Calc is taking to do a calculation.
* If calc takes too long (about 10 sec's), then a popup is put up asking the
* user if he wants to abort the operation.
*
* Usage:
*   TimeCalc( TRUE );
*   do a lengthy operation
*   TimeCalc( FALSE );
*
* History
*   26-Nov-1996 JonPa   Wrote it.
*
\****************************************************************************/
HWND ghwndTimeOutDlg = NULL;

void TimeCalc( BOOL fStart ) {
    if (ghCalcStart == NULL) {
        ghCalcStart = CreateEvent( NULL, FALSE, FALSE, NULL );
    }

    if (ghCalcDone == NULL) {
        ghCalcDone = CreateEvent( NULL, TRUE, FALSE, NULL );
    }

    if (ghDogThread == NULL) {
        DWORD tid;
        ghDogThread = CreateThread( NULL, 0, WatchDogThread, NULL, 0, &tid );
    }

    if (fStart) {
        NumObjAbortOperation(FALSE);
        ResetEvent( ghCalcDone );
        SetEvent( ghCalcStart );
    } else {

        SetEvent( ghCalcDone );

        if( ghwndTimeOutDlg != NULL ) {
            SendMessage( ghwndTimeOutDlg, WM_COMMAND, IDRETRY, 0L );
        }

        if( NumObjWasAborted() ) {
            DisplayError(SCERR_ABORTED);
        }
    }
}


/****************************************************************************\
*
* KillTimeCalc
*
* Should be called only at the end of the program, just before exiting, to
* kill the background timer thread and free its resources.
*
* History
*   26-Nov-1996 JonPa   Wrote it.
*
\****************************************************************************/
void KillTimeCalc( void ) {
    gfExiting = TRUE;
    SetEvent( ghCalcStart );
    SetEvent( ghCalcDone );

    WaitForSingleObject( ghDogThread, CMS_MAX_TIMEOUT );

    CloseHandle( ghCalcStart );
    CloseHandle( ghCalcDone );
    CloseHandle( ghDogThread );
}


/****************************************************************************\
*
* TimeOutMessageBox
*
*   Puts up a dialog that looks like a message box.  If the operation returns
* before the user has responded to the dialog, the dialog gets taken away.
*
* History
*   04-Dec-1996 JonPa   Wrote it.
*
\****************************************************************************/
INT_PTR
CALLBACK TimeOutDlgProc( HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam )
{
    RECT rc;
    int y;

    switch( uMsg ) {
    case WM_INITDIALOG:
        ghwndTimeOutDlg = hwndDlg;

        //
        // Move ourselves to be over the main calc window
        //

        // Find the display window so we don't cover it up.
        GetWindowRect(GetDlgItem(g_hwndDlg, IDC_DISPLAY), &rc );
        y = rc.bottom;

        // Get the main calc window pos
        GetWindowRect( g_hwndDlg, &rc );

        SetWindowPos( hwndDlg, 0, rc.left + 15, y + 40, 0, 0,
                      SWP_NOSIZE | SWP_NOZORDER | SWP_NOACTIVATE );
        break;

    case WM_COMMAND:
        EndDialog( hwndDlg, LOWORD(wParam) );
        break;

    default:
        return FALSE;
    }

    return TRUE;
}

INT_PTR TimeOutMessageBox( void ) {
    return (int)DialogBox( hInst, MAKEINTRESOURCE(IDD_TIMEOUT), NULL, TimeOutDlgProc );
}



/****************************************************************************\
*
* AddNumSeparator
*
*   Inserts the specified separator into the number string at the sepLen
* interval.   This is from the left of the decimal.  The right of the
* decimal (ie fractional part) is copied as is.
*
* History
*   08-Sept-1998 KPeery   Wrote it.
*
\****************************************************************************/
void
AddNumSeparator(TCHAR sep, int sepLen, PTSTR szDisplay, PTSTR szSepDisplay)
{
    PTSTR src,dest, dec;
    int   len, count;

    if ((sep == TEXT('\0')) || (sepLen < 1))
    {
        lstrcpy(szSepDisplay,szDisplay);
        return;
    }

    // find decimal point

    for(dec=szDisplay; (*dec != szDec[0]) && (*dec != TEXT('\0')); dec++)
        ; // do nothing

    // at this point dec should point to '\0' or '.' we will add the left
    // side of the number to the final string

    // num of digits
    len=(int)(dec-szDisplay);

    // plus num of commas
    len+=(len-(*szDisplay == TEXT('-') ? 2 : 1))/sepLen;

    // account for decimal
    count=-1;

    for(src=dec, dest=szSepDisplay+len; src >= szDisplay; src--, dest--)
    {
        if ((count > 0) && ((count % sepLen) == 0))
        {
            *dest=sep;
            dest--;

            // if neg num sign then we didn't want that last comma
            if (*src == TEXT('-'))
               dest++;
        }

        *dest=*src;
        count++;
    }

    //
    // ok, now add the right (fractional) part of the number to the final
    // string.
    //
    dest=szSepDisplay+len;

    lstrcpy(dest,dec);

}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91啪在线观看| 欧美这里有精品| 亚洲成av人**亚洲成av**| 久久久亚洲国产美女国产盗摄| jizz一区二区| 紧缚奴在线一区二区三区| 一区二区在线观看不卡| 久久久综合九色合综国产精品| 欧美综合在线视频| 不卡电影一区二区三区| 久久精品国产99国产精品| 一区二区三区中文字幕在线观看| 国产亚洲成年网址在线观看| 欧美一区二区女人| 色噜噜狠狠一区二区三区果冻| 国产成人综合网| 久久精品国产99| 亚洲国产精品久久一线不卡| 国产精品成人在线观看| 精品国精品国产尤物美女| 欧美精品国产精品| 日本韩国欧美三级| 国产91丝袜在线播放0| 精品一区二区三区av| 婷婷六月综合亚洲| 亚洲无人区一区| 亚洲美女淫视频| 日韩毛片精品高清免费| 日本一区二区电影| 欧美国产精品中文字幕| 国产日本一区二区| 国产日本亚洲高清| 国产午夜精品久久久久久免费视| 精品国产91亚洲一区二区三区婷婷| 91精品国产麻豆国产自产在线| 欧美综合在线视频| 欧美日韩一区二区三区四区| 一本久道久久综合中文字幕| 99久久99久久精品免费看蜜桃| 国产91精品欧美| 成人黄色a**站在线观看| 高清beeg欧美| av在线综合网| 91麻豆国产香蕉久久精品| 91啪亚洲精品| 欧美色电影在线| 欧美精品在线视频| 91精品午夜视频| 日韩女优毛片在线| 2020国产精品久久精品美国| 久久久久国产精品麻豆| 国产欧美一区二区精品忘忧草| 国产日韩欧美精品电影三级在线| 国产精品另类一区| 亚洲另类色综合网站| 亚洲电影一级黄| 日韩激情一二三区| 狠狠狠色丁香婷婷综合激情| 岛国精品在线观看| 91高清视频在线| 91精品国产麻豆国产自产在线 | 日韩一区中文字幕| 悠悠色在线精品| 肉色丝袜一区二区| 国内成+人亚洲+欧美+综合在线| 成人一区在线看| 在线精品视频一区二区三四| 51精品久久久久久久蜜臀| 精品99一区二区三区| 国产精品久久99| 天天综合日日夜夜精品| 久久99精品一区二区三区三区| 成人黄色小视频在线观看| 在线精品视频小说1| 亚洲精品在线免费播放| 一区二区在线观看视频| 老鸭窝一区二区久久精品| 成人久久18免费网站麻豆 | 欧美高清视频不卡网| 精品国产一二三| 亚洲欧美日韩在线| 日本成人在线网站| 成人网男人的天堂| 3d成人h动漫网站入口| 中文久久乱码一区二区| 五月激情综合婷婷| 成人激情小说乱人伦| 欧美高清视频一二三区| 国产精品国产三级国产普通话三级| 亚洲一区二区三区四区五区中文 | av成人动漫在线观看| 欧美日韩一区视频| 欧美激情资源网| 日韩高清不卡一区| 91免费看片在线观看| 精品国产污污免费网站入口 | av电影一区二区| 日韩精品一区二区三区swag| 亚洲综合成人在线视频| 国产精品亚洲一区二区三区妖精| 欧美日韩中文精品| 1000精品久久久久久久久| 久久精品国产第一区二区三区| 色婷婷av久久久久久久| 久久久综合九色合综国产精品| 亚洲1区2区3区4区| 91免费视频网址| 国产天堂亚洲国产碰碰| 免费观看久久久4p| 色狠狠av一区二区三区| 中文字幕免费在线观看视频一区| 男女男精品视频| 欧美日韩亚洲综合在线 | 亚洲欧美影音先锋| 国产高清在线精品| 日韩欧美久久久| 日韩国产在线一| 欧亚洲嫩模精品一区三区| 亚洲另类春色校园小说| 成人av网站大全| 国产日韩欧美精品电影三级在线| 久久99久久久久久久久久久| 欧美疯狂做受xxxx富婆| 一区二区三区免费看视频| 99re8在线精品视频免费播放| 国产肉丝袜一区二区| 国产福利不卡视频| 久久久午夜精品| 国产精品综合久久| 久久综合久久综合亚洲| 另类调教123区| 精品少妇一区二区三区在线视频 | 视频在线观看一区| 欧美精品久久一区| 日韩成人免费看| 日韩精品综合一本久道在线视频| 日韩成人精品在线观看| 日韩亚洲欧美在线| 毛片一区二区三区| 日韩精品一区二区三区老鸭窝| 蜜桃精品在线观看| 精品国产伦一区二区三区免费| 久久69国产一区二区蜜臀| 欧美va天堂va视频va在线| 国产一区二区三区免费播放 | 久久日韩精品一区二区五区| 韩国午夜理伦三级不卡影院| 久久久综合精品| 成人午夜精品在线| 亚洲欧美国产三级| 欧美日韩在线播放一区| 日韩电影一区二区三区四区| www国产精品av| 成人午夜视频网站| 亚洲一区二区三区在线| 777xxx欧美| 国产一区二区免费视频| 国产精品理伦片| 欧美自拍偷拍一区| 日本不卡一区二区三区| 久久奇米777| 色先锋资源久久综合| 日韩精品亚洲专区| 精品美女一区二区三区| 成人在线视频一区| 亚洲福利电影网| 欧美mv和日韩mv国产网站| 不卡的看片网站| 午夜电影一区二区三区| 2021久久国产精品不只是精品 | 一区免费观看视频| 欧洲另类一二三四区| 久久国产精品72免费观看| 中文字幕av一区二区三区免费看| 色拍拍在线精品视频8848| 日本人妖一区二区| 国产精品美女久久久久aⅴ| 欧美日韩国产电影| 国产成人aaa| 亚洲成人激情自拍| 亚洲国产精品av| 欧美疯狂性受xxxxx喷水图片| 国产成人av电影在线| 天堂精品中文字幕在线| 国产欧美在线观看一区| 欧美中文字幕一二三区视频| 国产精品伊人色| 无码av免费一区二区三区试看| 欧美激情在线一区二区| 91精品国产麻豆| 色悠悠亚洲一区二区| 国产综合久久久久久鬼色| 一区二区三区中文字幕| 久久久不卡影院| 欧美一区二区在线不卡| a美女胸又www黄视频久久| 久草精品在线观看| 亚洲成人av在线电影| 国产精品沙发午睡系列990531| 精品日本一线二线三线不卡|