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

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

?? transmit.c

?? 欣技8000 資料 很適用的資料
?? C
字號(hào):
/*
filename:	transmit.c
purpose:	deal with the things about transfer
author:		wx
date:		2003-3-20
*/

#include "..\\lib\\8000lib.h"
#include "..\\lib\\ucos.h"
#include "global.h"

static char *ACK = "ACK\r";
static char *NAK = "NAK\r";
int    beep1[4] = {16, 5, 0, 0};
int    beep2[8] = {30, 10, 0, 5, 30, 10, 0, 0};
BYTE   szData [512];
BYTE   szBuf  [512];
static BOOL ConnectingPage (void);

static BOOL ConnectingPage (void)
{
    clr_scr ();
    SetFont (2);
    DispString (0, 1, (char*)"Connecting. ", 0);
    DispString (0, 3, SpaceBar, 0);
    DispString (0, 5, (char*)"Press ESC to", 0);
    DispString (0, 7, (char*)"cancel      ", 0);
    return TRUE;
}

BOOL DownloadLookup (int nPort, int file)
{
    int    i, j, k, m, sum;
    BYTE   c;
	BYTE   szData [256];
	BYTE      szBuf[256];

    ConnectingPage ();

    if (nPort == 1)
        SetCommType (1, 0);	// direct 232
    else if (nPort == 2)
        SetCommType (1, 2);	// IR
    else
        SetCommType (1, 3);	// IrDA

 
        nPort = 1;			// must use COM1

    switch (SelectSpeed())
    {
        case 1:  c = 0x08;  break;	// 115200,N,8,1
        case 2:  c = 0x0a;  break;	// 57600
        case 3:  c = 0x0b;  break;	// 38400
        case 4:  c = 0x0c;  break;	// 19200
        case 5:  c = 0x0d;  break;	// 9600
    }
    open_com (nPort, c);

ReTry :
    i = 0;
    while (i < 10)
    {
        if (read_com (nPort, (char *)&c))
            szData [i++] = c;

        if (c == '\r')
            break;

        if ((c = getchar()) == KEY_ESC)
        {
            close_com (nPort);
            return TRUE;
        }
    }
    szData [i] = 0;

    if (!strcmp (szData, "CIPHER\r"))
    {
        DispString (0, 1, (char*)"Downloading", 0);
        write_com (nPort, ACK);
        while (!com_eot (nPort));
    }
    else
    {
        write_com (nPort, NAK);
        while (!com_eot (nPort));
        goto ReTry;
    }

    switch (file)
    {
    case 1:	
		remove ("PROV");
        prov_file = create_DBF ((char *)"PROV", 20);
        create_index (prov_file, 1, 0, 4);
        break;

    case 2:
        remove ("CUST");
        cust_file = create_DBF ((char *)"CUST", 20);
        create_index (cust_file, 1, 0, 4);
        break;

    case 3:
        remove ("OPER");
        oper_file = create_DBF ((char *)"OPER", 20);
        create_index (oper_file, 1, 0, 4);
        break;

	case 4:
		remove ("ISHEE");
        ishee_file = create_DBF ((char *)"ISHEE", 20);
        create_index (ishee_file, 1, 0, 4);
        break;

	case 5:
        remove ("OSHEE");
        oshee_file = create_DBF ((char *)"OSHEE", 20);
        create_index (oshee_file, 1, 0, 4);
        break;
    }//switch

    m = 0;
    while (1)	// download lookup file
    {
ReDo:
        i = 0;
        c = 0;
        while (c != '\r')
        {
            if (read_com (nPort, (char *)&c))
                *(szData+i++) = c;

            if (getchar() == KEY_ESC)
            {
                close_com (nPort);
                return FALSE;
            }
        }
        i--;
        *(szData+i) = 0;

        if (!strcmp (szData, "OVER"))
        {
            write_com (nPort, ACK);
            while (!com_eot (nPort));
            break;
        }

        sum = 0;
        for (j=0; j<i-2; j++)
            sum += szData [j];
        j = sum / 256;
        if (j == 13)
            j++;
        k = sum % 256;
        if (k == 13)
            k++;

        if (j != szData [i-2] || k != szData [i-1])  // checksum not correct
        {
            write_com (nPort, NAK);
            while (!com_eot (nPort));
            goto ReDo;
        }

        szData [i-2] = 0;
		switch (file)
		{
        case 1:
			add_member (prov_file, (char *)szData);
            break;

        case 2:
			add_member (cust_file, (char *)szData);  
            break;

        case 3:
			add_member (oper_file, (char *)szData);  
            break;

		case 4:
			add_member (ishee_file, (char *)szData);  
            break;
		case 5:
			add_member (oshee_file, (char *)szData);  
            break;
        }
        itoa (++m, szBuf, 10);
        DispString (1, 3, (char*)szBuf, 0);	// show data transfered

        write_com (nPort, ACK);
        while (!com_eot (nPort));
    }

    close_com (nPort);	// close COM
    clr_scr ();
    on_beeper (beep2);
    DispString (0, 1, (char*)"OK!", 0);
    DispString (0, 5, (char*)"Please wait", 0);
    OSTimeDly (200);
    return TRUE;
}

BOOL UploadData (int nPort, int DataFile)
{
    int       i, j, k;
    unsigned  sum;
    BYTE      Header [2];
    BYTE      c;

    ConnectingPage ();

    if (nPort == 1)
        SetCommType (1, 0);                   // direct 232
    else if (nPort == 2)
        SetCommType (1, 2);                   // IR
    else if (nPort == 3)
        SetCommType (1, 3);                   // IrDA

        nPort = 1;                            // must use COM1

    switch (SelectSpeed())
    {
    case 1:  c = 0x08;  break;            // 115200,N,8,1
    case 2:  c = 0x0a;  break;            // 57600
    case 3:  c = 0x0b;  break;            // 38400
    case 4:  c = 0x0c;  break;            // 19200
    case 5:  c = 0x0d;  break;            // 9600
    }
    open_com (nPort, c);

ReTry:

    i = 0;
    while (i < 10)
    {
        if (read_com (nPort, (char *)&c))	// if successful reading
            szData [i++] = c;

        if (c == '\r')
            break;

        if ((c = getchar()) == KEY_ESC)
        {
            close_com (nPort);
            clr_scr ();
            return FALSE;
        }
    }
    szData [i] = 0;

    if (!strcmp (szData, "READ\r"))
    {
        write_com (nPort, ACK);
        while (!com_eot (nPort));
        DispString (0, 1, (char*)"Sending ...", 0);  // Sending data...
        DispString (0, 3, (char*)"Transfered:", 0);      // Transfered:
    }
    else
    {
        write_com (nPort, NAK);
        while (!com_eot (nPort));
        goto ReTry;
    }

    k = 0;
    lseek (DataFile, 0L, 1);            // move to file beginning
    while ((j = readln (DataFile, (char *)szData, 400)) > 1)
    {
        //j--;                            // deduct the flag byte
        /*if (szData [j-1] == 0x30)       /// do nothing if it's delete flag 
            continue;*/

        sum = Header [0] = k++ % 10;    // rotate from 0 to 9

        for (i=0; i<j-1; i++)
            sum += szData [i];
        szData [j-1] = sum & 0xFF;
        if (szData [j-1] == '\r')       // make sure the checksum isn't '\r'
            szData [j-1]++;
        szData [j] = sum >> 8;
        if (szData [j] == '\r')         // make sure the checksum isn't '\r'
            szData [j]++;
        szData [j+1] = '\r';
        szData [j+2] = 0;

        itoa (k, szBuf, 10);
        DispString (11, 3, (char*)szBuf, 0);   // show data transfered

ReSend:
        nwrite_com (nPort, (char *)Header, 1);
        while (com_eot(nPort)==0x00);
        nwrite_com (nPort, (char *)szData, j+2);
        while (!com_eot (nPort));
ReDo:
        i = 0;
        while (i < 10)
        {
            if (read_com (nPort, (char *)&c))
                szBuf [i++] = c;
            if (c == '\r')
                break;
            if ((c = getchar()) == KEY_ESC)
            {
                lseek (DataFile, 0L, -1);   // move file pointer to the end
                close_com (nPort);
                clr_scr ();
                return FALSE;
            }
        }
        szBuf [i] = 0;

        if (!strcmp (szBuf, NAK))
            goto ReSend;
        else if (strcmp (szBuf, ACK))
            goto ReDo;
    }

    write_com (nPort, "OVER\r");
    while (!com_eot (nPort));
    write_com (nPort, "OVER\r");
    while (!com_eot (nPort));
    lseek (DataFile, 0L, -1);               // move file pointer to the end
    on_beeper (beep2);
    DispString (11, 3, (char*)"Done", 0);    // Done
    DispString (0, 5, SpaceBar, 0);
    DispString (0, 7, SpaceBar, 0);
    close_com (nPort);
    OSTimeDly (200);
    return TRUE;
}


BOOL UploadDBF (int fDbf, int nPort)
    {
    int       i, j, k, n;
    unsigned  sum;
    BYTE      Header [2];
    BYTE      c;
	BYTE      szData [256];
	BYTE      szBuf[256];

    ConnectingPage ();

    if (nPort == 1)
        SetCommType (1, 0);                   // direct 232
    else if (nPort == 2)
        SetCommType (1, 2);                   // IR
    else if (nPort == 3)
        SetCommType (1, 3);                   // IrDA

        nPort = 1;                            // must use COM2

    switch (SelectSpeed())
    {      
	case 1:  c = 0x08;  break;            // 115200,N,8,1        
	case 2:  c = 0x0a;  break;            // 57600        
	case 3:  c = 0x0b;  break;            // 38400        
	case 4:  c = 0x0c;  break;            // 19200        
	case 5:  c = 0x0d;  break;            // 9600
    }
    open_com (nPort, c);

ReTry:
    i = 0;
    while (i < 10)
	{
        if (read_com (nPort, (char *)&c))     // if successful reading
            szData [i++] = c;

        if (c == '\r')
            break;

        if ((c = getchar()) == KEY_ESC)
		{
            close_com (nPort);
            clr_scr ();
            return FALSE;
		}
	}
    szData [i] = 0;

    if (!strcmp (szData, "READ\r"))
	{
        write_com (nPort, ACK);
        while (!com_eot (nPort));
        DispString (0, 1, (char*)"Sending ...", 0);      // Sending data...
        DispString (0, 3, (char*)"Transfered:", 0);      // Transfered:
	}
    else
	{
        write_com (nPort, NAK);
        while (!com_eot (nPort));
        goto ReTry;
	}

    n = member_in_DBF (fDbf);
    lseek_DBF (fDbf, 1, 0, SEEK_SET);
    k = 0;
    while (k < n)
	{
        get_member (fDbf, 1, (char *)szData);
        lseek_DBF (fDbf, 1, 1, SEEK_CUR);
        j = strlen (szData);
        if (j < 2)
		{
            k++;
            continue;
		}

        sum = Header [0] = k++ % 10;    // rotate from 0 to 9

        for (i=0; i<j; i++)
            sum += szData [i];
        szData [j] = sum & 0xFF;
        if (szData [j] == '\r')         // make sure the checksum isn't '\r'
            szData [j]++;
        j++;
        szData [j] = sum >> 8;
        if (szData [j] == '\r')         // make sure the checksum isn't '\r'
            szData [j]++;
        szData [++j] = '\r';
        szData [++j] = 0;

        itoa (k, szBuf, 10);
        DispString (11, 3, (char*)szBuf, 0);   // show data transfered

ReSend:
        nwrite_com (nPort, (char *)Header, 1);
        while (com_eot(nPort) == 0x00);
        nwrite_com (nPort, (char *)szData, j);
        while (!com_eot (nPort));
ReDo:
        i = 0;
        while (i < 10)
		{
            if (read_com (nPort, (char *)&c))
                szBuf [i++] = c;
            if (c == '\r')
                break;
            if ((c = getchar()) == KEY_ESC)
			{
                close_com (nPort);
                clr_scr ();
                return FALSE;
			}
		}
        szBuf [i] = 0;

        if (!strcmp (szBuf, NAK))
            goto ReSend;
        else if (strcmp (szBuf, ACK))
            goto ReDo;
	}

    write_com (nPort, "OVER\r");
    while (!com_eot (nPort));
    write_com (nPort, "OVER\r");
    while (!com_eot (nPort));
    on_beeper (beep2);
    DispString (11, 3, (char*)"Done", 0);    // Done
    DispString (0, 5, SpaceBar, 0);
    DispString (0, 7, SpaceBar, 0);
    close_com (nPort);
    OSTimeDly (200);
    return TRUE;
    }

int SelectSpeed()
{
return 1;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品亲子伦对白| 亚洲一区二区偷拍精品| 欧美丝袜丝交足nylons图片| 国产在线播精品第三| 亚洲第一搞黄网站| 中文字幕在线播放不卡一区| 日韩精品一区二区三区视频| 欧美伊人久久大香线蕉综合69| 国产传媒一区在线| 日韩精品1区2区3区| 国产精品成人免费在线| 久久综合久久99| 欧美日本乱大交xxxxx| www.欧美.com| 国产精品一区久久久久| 麻豆精品精品国产自在97香蕉| 亚洲综合一二区| 亚洲天堂免费看| 国产精品久久久一本精品| 日韩欧美不卡一区| 制服丝袜中文字幕一区| 色狠狠av一区二区三区| 99视频一区二区三区| 国产传媒欧美日韩成人| 久久精品999| 日韩精品91亚洲二区在线观看 | 91精品国产91热久久久做人人| a4yy欧美一区二区三区| 国产成人午夜视频| 精品亚洲porn| 老色鬼精品视频在线观看播放| 日韩高清欧美激情| 五月婷婷综合激情| 亚洲成人av一区二区三区| 亚洲国产美女搞黄色| 亚洲一区二区av电影| 亚洲高清免费一级二级三级| 亚洲曰韩产成在线| 亚洲国产精品久久久久婷婷884 | 韩国女主播一区二区三区| 久久精品国产色蜜蜜麻豆| 美国毛片一区二区| 精品午夜久久福利影院| 久久99国产精品久久99| 国产最新精品免费| 国产99精品视频| 成人三级伦理片| 成人午夜av影视| 色综合久久中文字幕综合网| 日本精品裸体写真集在线观看| 欧美在线视频不卡| 宅男在线国产精品| 精品国产电影一区二区| 国产网站一区二区| 亚洲欧洲成人av每日更新| 一区二区在线观看免费视频播放| 一区二区三区免费在线观看| 亚洲午夜激情网页| 免费欧美日韩国产三级电影| 国产一区91精品张津瑜| 不卡av免费在线观看| 欧美亚洲尤物久久| 日韩精品在线看片z| 国产欧美精品日韩区二区麻豆天美| 国产精品每日更新在线播放网址| 中文字幕一区二区三区在线不卡 | 午夜日韩在线电影| 精品一区二区三区在线观看 | 亚洲精品在线观| 国产精品免费视频一区| 亚洲欧美日韩系列| 免费精品视频在线| 国产白丝精品91爽爽久久| 日本精品一区二区三区高清 | 成人免费小视频| 亚洲国产视频直播| 国产一区二区免费看| 91免费观看在线| 欧美一级在线免费| 国产精品久久久久久久久搜平片| 亚洲自拍偷拍图区| 韩国精品久久久| 91久久线看在观草草青青| 日韩欧美在线网站| 中文字幕在线不卡一区 | 国产乱码精品一区二区三| 91麻豆国产在线观看| 精品三级在线看| 亚洲女女做受ⅹxx高潮| 精品一区二区三区av| 欧美性感一区二区三区| 国产欧美日韩在线观看| 日韩高清电影一区| 91在线无精精品入口| 久久影院视频免费| 亚洲一线二线三线视频| 成人三级在线视频| 日韩精品一区在线| 亚洲国产另类av| 不卡的av电影| 久久综合视频网| 性久久久久久久久| 97国产精品videossex| 久久嫩草精品久久久精品一| 日欧美一区二区| 在线观看日韩一区| 国产精品久久久久久久久免费桃花| 美腿丝袜亚洲综合| 欧美日韩视频第一区| 17c精品麻豆一区二区免费| 国产一区不卡在线| 日韩免费一区二区| 日韩二区在线观看| 欧洲av在线精品| 亚洲日本va在线观看| 国产成人在线视频免费播放| 日韩欧美一级精品久久| 亚洲chinese男男1069| 91久久奴性调教| 亚洲丝袜制服诱惑| 成人激情视频网站| 国产日韩欧美不卡在线| 国产一区二区福利| 精品国产一二三| 六月婷婷色综合| 日韩午夜激情av| 美女视频网站久久| 日韩欧美国产综合| 久久国产尿小便嘘嘘| 欧美一区二区三区在| 一区二区欧美国产| 欧美性猛片xxxx免费看久爱| 国产精品久久三| 99久久精品国产导航| 综合分类小说区另类春色亚洲小说欧美| 国产亚洲一区二区三区| 韩国女主播一区| 久久久久久电影| 国产aⅴ综合色| 国产精品久久久久婷婷二区次 | 69堂国产成人免费视频| 日韩中文字幕一区二区三区| 欧美精品1区2区| 亚洲mv大片欧洲mv大片精品| 欧美高清视频不卡网| 麻豆专区一区二区三区四区五区| 欧美一区二区在线免费播放| 久久精品国产一区二区三 | 欧美xfplay| 国产91综合一区在线观看| 国产精品午夜电影| 99re亚洲国产精品| 亚洲一区二区三区四区中文字幕| 欧美日韩国产系列| 日韩影院精彩在线| 久久综合九色欧美综合狠狠| 国产福利一区二区三区视频在线| 国产精品入口麻豆九色| 日本韩国精品在线| 日本美女视频一区二区| 亚洲精品一区二区三区福利| 国产91精品免费| 一区二区成人在线| 欧美一区二区三区啪啪| 国产精品一区二区视频| 中文字幕一区二区三区四区 | 久久久不卡影院| 色综合咪咪久久| 日韩精品一二三四| 欧美国产日韩精品免费观看| 99久久精品国产毛片| 日韩影院在线观看| 久久久国际精品| 欧美亚男人的天堂| 加勒比av一区二区| 尤物视频一区二区| 精品国产亚洲在线| 欧洲中文字幕精品| 国产呦精品一区二区三区网站 | 狠狠色丁香久久婷婷综| 综合中文字幕亚洲| 日韩精品一区二区在线| 91免费看片在线观看| 久久成人精品无人区| 亚洲精品国久久99热| 日韩精品在线一区二区| 一本色道久久综合亚洲aⅴ蜜桃| 蜜桃视频一区二区| 亚洲免费观看高清完整版在线观看熊 | 免费成人美女在线观看.| 国产日韩欧美精品综合| 99精品一区二区| 久久成人精品无人区| 亚洲国产欧美另类丝袜| 欧美极品xxx| 欧美一级欧美一级在线播放| 99re这里都是精品| 国产精品资源网| 日本视频一区二区三区| 一级女性全黄久久生活片免费|