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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pdf417_prep.c

?? PDF417編碼的算法的源程序
?? C
字號:
//////////////////////////////////////////////////////////////////////////////// File name    :pdf417_prep.c// Derived from :// Author       :M.A. Brand// Reviewer     ://// Description : Converts an arbitrary file into form usable by pdf417_encode//               by applying the Annex P algorithm of the ISO pdf417 specification.//// Copyright (c) 2004, 2005 N200.com B.V.// Marifoonweg 1// 1042 AV Amsterdam, The Netherlands///*    This file is part of pdf417_prep.    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    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 for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*///// History // ---------------------------------------------------------------------------// Date       | Who           |Action// ---------------------------------------------------------------------------// 2004-07-22 | M.A. Brand     |Created// 2004-08-02 | M.A. Brand     |Fixed a bug that could make pdf417_prep loop forever// 2004-08-02 | Niels Duineveld|Fixed bug in algorithm that would cause byte compaction //            |                |where text compaction would be the optimal choice// 2004-08-02 | M.A. Brand     |Replaced isdigit() with is_nc(). isdigit failed//            |                |failed to return the expected result for extended//            |                |characters in release builds. This was hard to find.// 2004-12-20 | M.A. Brand     |Increased PDF417_RECORD_LEN// 2005-01-05 | M.A. Brand     |Fixed is_tc() to give correct result for NULL.// 2005-01-06 | M.A. Brand     |Fixed processing when short numeric string appears//            |                |at end of buffer////////////////////////////////////////////////////////////////////////////////#include <stdio.h>#include <stdlib.h>#include <string.h>#include "pdf417_prep.h"//Line buffer size. Not sure how long lines in input//for pdf417_encode can be.#define PDF417_RECORD_LEN (512)//These functions output a sequence of bytes to a file in the format that //pdf417_enc understands. Each compaction type has an output function.static void output_bc(const char* buf, int len, FILE* fp);static void output_nc(const char* buf, int len, FILE* fp);static void output_tc(const char* buf, int len, FILE* fp);//These functions test a byte. They return true if the byte is a candidate for numeric compaction//or text compaction, respectively. The compaction mode that actually ends up being used is //context dependentstatic int is_nc(char c);static int is_tc(char c);/* Very literal implementation of Annex P algorithm */int pdf417_prep(const char* buffer, int len, FILE* fp){    const char* p; //ptr to current sequence of bytes    int n, t, b;  //counters for numeric, text, and byte compaction candidates             p = buffer;        while(p < buffer + len)    {        //STEP3: test for sequence for numeric compaction            n = 0;            while(p + n < buffer + len)        {            if (!is_nc(p[n]))            {                break;            }            n++;        }                if (n >= 13)        {            /* Use numeric compaction */            output_nc(p, n, fp);            p += n;            continue;        }                //STEP10: test for sequence for text compaction                t = n = 0;            while(p + n + t  < buffer + len)        {            if (is_nc(p[n + t]))            {                n++;            }            else if (is_tc(p[n + t]))            {                t++;                t += n;                n = 0;            }            else            {                break;            }            if (n == 13)            {                break;            }        }        if (n < 13)        {            //encountered BC byte or end of buffer reached. convert remaining n to t            t += n;            n = 0;        }                if (t >= 5)        {            /* Use text compaction */            output_tc(p, t, fp);            p += t;            continue;        }                //STEP17: test for sequence for byte compaction                b = t = n = 0;            while(p + n + t + b < buffer + len)        {            if (is_nc(p[n + t + b]))            {                n++;            }            else if (is_tc(p[n + t + b]))            {                t++;                t += n;                n = 0;            }            else            {                b++;                b += n + t;                n = 0;                t = 0;            }            if (n == 13)            {                b += t;                t = 0;                break;            }            if (t >= 5)            {                b += n;                n = 0;                break;            }        }                if (n < 13)        {            //end of buffer reached. convert remaining n to t            t += n;            n = 0;        }        if (t < 5)        {            //end of buffer reached. convert remaining t to b            b += t;            t = 0;        }        if (b >= 1)        {            // Use byte compaction            // Annex P Step 18 recommends:            // If b == 1 and current mode is text,            // then we should SHIFT into Byte Compaction Mode;            // otherwise, we should LATCH into Byte Compaction Mode.            // pdf417_encode should make this distinction since            // we cannot do it here.                        output_bc(p, b, fp);            p += b;        }    }    return 1;}void output_bc(const char* buf, int len, FILE* fp){    int i;    if (!buf || !len || !fp)    {        return;    }        for (i = 0; i < len; i++)    {        if (i % PDF417_RECORD_LEN == 0)        {            fputs("BC \"", fp);        }                fprintf(fp, "%02X", (unsigned char)buf[i]);                if ((i + 1) % PDF417_RECORD_LEN == 0 || i == len - 1)        {            fputs("\"\n", fp);        }            }}void output_nc(const char* buf, int len, FILE* fp){    int i;    if (!buf || !len || !fp)    {        return;    }    for (i = 0; i < len; i++)    {        if (i % PDF417_RECORD_LEN == 0)        {            fputs("NC \"", fp);        }                fputc(buf[i], fp);                if ((i + 1) % PDF417_RECORD_LEN == 0 || i == len - 1)        {            fputs("\"\n", fp);        }    }}void output_tc(const char* buf, int len, FILE* fp){    int i ;    if (!buf || !len || !fp)    {        return;    }        for (i = 0; i < len; i++)    {        if (i % PDF417_RECORD_LEN == 0)        {            fputs("TC \"", fp);        }                switch(buf[i])        {        case '\"':            fputs("\\DQ", fp);            break;        case '\n':            fputs("\\LF", fp);            break;        case '\r':            fputs("\\CR", fp);            break;        case '\\':            fputs("\\BS", fp);            break;                default:            fputc(buf[i], fp);            break;        }                if ((i + 1) % PDF417_RECORD_LEN == 0 || i == len - 1)        {            fputs("\"\n", fp);        }    }}int is_tc(char c){    if (c >= 32 && c <= 126)    {        return 1;    }    else if (c && strchr("\t\n\r", c))    {        return 1;    }        return 0;}int is_nc(char c){    return (c >= '0' && c <= '9');}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人8x视频一区二区| 欧美吻胸吃奶大尺度电影| 六月丁香综合在线视频| 亚洲高清免费在线| 一区二区三区免费| 精品一区二区三区视频在线观看 | 欧美国产乱子伦| 国产三级精品在线| 国产精品久久三| 亚洲色图视频网站| 夜夜嗨av一区二区三区网页| 洋洋av久久久久久久一区| 一区二区三区波多野结衣在线观看| 亚洲裸体在线观看| 亚洲午夜在线电影| 青青草一区二区三区| 美女一区二区三区| 国产99久久久国产精品| av电影天堂一区二区在线| 91欧美激情一区二区三区成人| 在线免费亚洲电影| 欧美精品18+| 久久日韩精品一区二区五区| 中文av一区特黄| 亚洲精品免费看| 麻豆久久久久久久| 高清不卡在线观看| 色又黄又爽网站www久久| 欧美日韩一区二区三区在线看| 欧美一区二区三区在线观看视频 | 一区二区三区免费观看| 日日骚欧美日韩| 国产一区二区不卡| 91麻豆福利精品推荐| 欧美一区二区三区在线视频 | 黑人巨大精品欧美一区| 丁香啪啪综合成人亚洲小说| 色吧成人激情小说| 欧美日韩电影一区| 国产亚洲欧美一区在线观看| 亚洲丝袜自拍清纯另类| 日av在线不卡| 丁香婷婷综合色啪| 欧美妇女性影城| 国产精品你懂的在线| 亚洲一区二区综合| 国产精品一品二品| 久久久www免费人成精品| 捆绑变态av一区二区三区| 欧美一级二级在线观看| 国产91精品欧美| 99久久免费精品高清特色大片| 国产精品久久久久久久久快鸭| 国产夫妻精品视频| 亚洲男人电影天堂| 最新不卡av在线| 免费观看在线综合色| av午夜一区麻豆| 日韩欧美一区二区视频| 亚洲免费观看高清| 国产在线不卡一区| 在线观看av不卡| 欧美激情综合五月色丁香小说| 无码av免费一区二区三区试看| 国产成人久久精品77777最新版本| 欧美精品在线观看一区二区| 国产精品理论片在线观看| 免费人成在线不卡| 色综合久久九月婷婷色综合| 国产日韩亚洲欧美综合| 日本成人在线电影网| 色综合久久天天| 久久九九久精品国产免费直播| 国产高清精品在线| 欧美日韩亚洲不卡| 日韩久久一区二区| 成人一区二区视频| 欧美不卡一二三| 日韩综合在线视频| 在线精品视频小说1| 国产精品福利电影一区二区三区四区| 久久精品久久综合| 欧美精品免费视频| 亚洲自拍偷拍图区| 一本到高清视频免费精品| 亚洲国产精品精华液ab| 精品午夜久久福利影院| 91精品国产91久久久久久最新毛片| 亚洲精品久久嫩草网站秘色| 成人国产精品免费网站| 国产欧美日韩麻豆91| 激情综合一区二区三区| 日韩免费视频一区二区| 丝袜亚洲精品中文字幕一区| 欧美亚洲图片小说| 亚洲国产中文字幕| 欧美亚洲日本国产| 亚洲综合色在线| 欧美日韩五月天| 亚洲第一精品在线| 欧美日韩国产美女| 婷婷六月综合亚洲| 91麻豆精品国产91久久久| 天天亚洲美女在线视频| 欧美二区在线观看| 日韩精品电影在线| 欧美一级二级三级乱码| 看片网站欧美日韩| 久久久久一区二区三区四区| 国产精品一二三区在线| 久久精品日产第一区二区三区高清版 | 精品噜噜噜噜久久久久久久久试看| 蜜桃传媒麻豆第一区在线观看| 欧美va日韩va| 国产在线播放一区| 中文字幕亚洲一区二区va在线| 99久久精品免费看| 亚洲欧美色图小说| 欧美日韩一区二区三区高清| 亚洲成人av一区二区三区| 欧美二区在线观看| 国产一区二区在线视频| 久久精品人人做| 成人小视频免费在线观看| 亚洲色图欧美激情| 欧美日韩成人综合在线一区二区| 日韩国产成人精品| 日韩视频免费观看高清在线视频| 国产综合色精品一区二区三区| 亚洲国产成人在线| 在线观看一区二区视频| 丝袜国产日韩另类美女| 精品福利在线导航| kk眼镜猥琐国模调教系列一区二区| 亚洲精品高清在线观看| 91精品福利在线一区二区三区 | 色妞www精品视频| 麻豆一区二区三区| 中文字幕一区二区三中文字幕| 欧美探花视频资源| 久久99精品一区二区三区三区| 欧美国产乱子伦| 欧美区在线观看| 国产乱码字幕精品高清av| 亚洲精品欧美专区| 91精品福利在线一区二区三区 | 懂色中文一区二区在线播放| 一区二区免费视频| 欧美xxx久久| 色呦呦一区二区三区| 久久国产精品无码网站| 国产精品久久久久久久第一福利| 欧美日本免费一区二区三区| 国产一区二区美女| 亚洲电影激情视频网站| 久久综合视频网| 欧美天堂亚洲电影院在线播放| 91在线观看免费视频| 蜜桃久久久久久久| 夜夜嗨av一区二区三区中文字幕| 久久精品人人做人人综合| 欧美剧情片在线观看| 成人18视频在线播放| 日本亚洲免费观看| 一区二区三区在线视频播放| 久久这里只精品最新地址| 欧美午夜在线观看| 成人av第一页| 精品一区二区久久久| 亚洲成人自拍一区| 中文字幕一区二区三| 精品国产区一区| 欧美日本在线看| 在线精品国精品国产尤物884a| 国产99精品在线观看| 久久丁香综合五月国产三级网站| 一区二区欧美精品| 国产精品人成在线观看免费| 欧美v日韩v国产v| 69av一区二区三区| 在线看不卡av| 91美女在线看| 成人99免费视频| 国产凹凸在线观看一区二区| 久久精品99久久久| 日韩和的一区二区| 亚洲国产成人91porn| 亚洲欧美激情视频在线观看一区二区三区 | 五月综合激情婷婷六月色窝| 中文字幕av一区二区三区| 久久夜色精品国产欧美乱极品| 91精品国产美女浴室洗澡无遮挡| 91国模大尺度私拍在线视频| bt欧美亚洲午夜电影天堂| 国产风韵犹存在线视精品| 国产精品一区免费视频| 韩国成人福利片在线播放| 青青草97国产精品免费观看| 午夜精品久久久久久久 | 91黄视频在线|