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

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

?? jdmarker.c

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? C
?? 第 1 頁 / 共 3 頁
字號:
     */    if (count > 256 || ((INT32) count) > length)      ERREXIT(cinfo, JERR_BAD_HUFF_TABLE);    for (i = 0; i < count; i++)      INPUT_BYTE(cinfo, huffval[i], return FALSE);    length -= count;    if (index & 0x10) {		/* AC table definition */      index -= 0x10;      htblptr = &cinfo->ac_huff_tbl_ptrs[index];    } else {			/* DC table definition */      htblptr = &cinfo->dc_huff_tbl_ptrs[index];    }    if (index < 0 || index >= NUM_HUFF_TBLS)      ERREXIT1(cinfo, JERR_DHT_INDEX, index);    if (*htblptr == NULL)      *htblptr = jpeg_alloc_huff_table((j_common_ptr) cinfo);      MEMCOPY((*htblptr)->bits, bits, SIZEOF((*htblptr)->bits));    MEMCOPY((*htblptr)->huffval, huffval, SIZEOF((*htblptr)->huffval));  }  if (length != 0)    ERREXIT(cinfo, JERR_BAD_LENGTH);  INPUT_SYNC(cinfo);  return TRUE;}LOCAL(boolean)get_dqt (j_decompress_ptr cinfo)/* Process a DQT marker */{  INT32 length;  int n, i, prec;  unsigned int tmp;  JQUANT_TBL *quant_ptr;  INPUT_VARS(cinfo);  INPUT_2BYTES(cinfo, length, return FALSE);  length -= 2;  while (length > 0) {    INPUT_BYTE(cinfo, n, return FALSE);    prec = n >> 4;    n &= 0x0F;    TRACEMS2(cinfo, 1, JTRC_DQT, n, prec);    if (n >= NUM_QUANT_TBLS)      ERREXIT1(cinfo, JERR_DQT_INDEX, n);          if (cinfo->quant_tbl_ptrs[n] == NULL)      cinfo->quant_tbl_ptrs[n] = jpeg_alloc_quant_table((j_common_ptr) cinfo);    quant_ptr = cinfo->quant_tbl_ptrs[n];    for (i = 0; i < DCTSIZE2; i++) {      if (prec)	INPUT_2BYTES(cinfo, tmp, return FALSE);      else	INPUT_BYTE(cinfo, tmp, return FALSE);      /* We convert the zigzag-order table to natural array order. */      quant_ptr->quantval[jpeg_natural_order[i]] = (UINT16) tmp;    }    if (cinfo->err->trace_level >= 2) {      for (i = 0; i < DCTSIZE2; i += 8) {	TRACEMS8(cinfo, 2, JTRC_QUANTVALS,		 quant_ptr->quantval[i],   quant_ptr->quantval[i+1],		 quant_ptr->quantval[i+2], quant_ptr->quantval[i+3],		 quant_ptr->quantval[i+4], quant_ptr->quantval[i+5],		 quant_ptr->quantval[i+6], quant_ptr->quantval[i+7]);      }    }    length -= DCTSIZE2+1;    if (prec) length -= DCTSIZE2;  }  if (length != 0)    ERREXIT(cinfo, JERR_BAD_LENGTH);  INPUT_SYNC(cinfo);  return TRUE;}LOCAL(boolean)get_dri (j_decompress_ptr cinfo)/* Process a DRI marker */{  INT32 length;  unsigned int tmp;  INPUT_VARS(cinfo);  INPUT_2BYTES(cinfo, length, return FALSE);    if (length != 4)    ERREXIT(cinfo, JERR_BAD_LENGTH);  INPUT_2BYTES(cinfo, tmp, return FALSE);  TRACEMS1(cinfo, 1, JTRC_DRI, tmp);  cinfo->restart_interval = tmp;  INPUT_SYNC(cinfo);  return TRUE;}/* * Routines for processing APPn and COM markers. * These are either saved in memory or discarded, per application request. * APP0 and APP14 are specially checked to see if they are * JFIF and Adobe markers, respectively. */#define APP0_DATA_LEN	14	/* Length of interesting data in APP0 */#define APP14_DATA_LEN	12	/* Length of interesting data in APP14 */#define APPN_DATA_LEN	14	/* Must be the largest of the above!! */LOCAL(void)examine_app0 (j_decompress_ptr cinfo, JOCTET FAR * data,	      unsigned int datalen, INT32 remaining)/* Examine first few bytes from an APP0. * Take appropriate action if it is a JFIF marker. * datalen is # of bytes at data[], remaining is length of rest of marker data. */{  INT32 totallen = (INT32) datalen + remaining;  if (datalen >= APP0_DATA_LEN &&      GETJOCTET(data[0]) == 0x4A &&      GETJOCTET(data[1]) == 0x46 &&      GETJOCTET(data[2]) == 0x49 &&      GETJOCTET(data[3]) == 0x46 &&      GETJOCTET(data[4]) == 0) {    /* Found JFIF APP0 marker: save info */    cinfo->saw_JFIF_marker = TRUE;    cinfo->JFIF_major_version = GETJOCTET(data[5]);    cinfo->JFIF_minor_version = GETJOCTET(data[6]);    cinfo->density_unit = GETJOCTET(data[7]);    cinfo->X_density = (GETJOCTET(data[8]) << 8) + GETJOCTET(data[9]);    cinfo->Y_density = (GETJOCTET(data[10]) << 8) + GETJOCTET(data[11]);    /* Check version.     * Major version must be 1, anything else signals an incompatible change.     * (We used to treat this as an error, but now it's a nonfatal warning,     * because some bozo at Hijaak couldn't read the spec.)     * Minor version should be 0..2, but process anyway if newer.     */    if (cinfo->JFIF_major_version != 1)      WARNMS2(cinfo, JWRN_JFIF_MAJOR,	      cinfo->JFIF_major_version, cinfo->JFIF_minor_version);    /* Generate trace messages */    TRACEMS5(cinfo, 1, JTRC_JFIF,	     cinfo->JFIF_major_version, cinfo->JFIF_minor_version,	     cinfo->X_density, cinfo->Y_density, cinfo->density_unit);    /* Validate thumbnail dimensions and issue appropriate messages */    if (GETJOCTET(data[12]) | GETJOCTET(data[13]))      TRACEMS2(cinfo, 1, JTRC_JFIF_THUMBNAIL,	       GETJOCTET(data[12]), GETJOCTET(data[13]));    totallen -= APP0_DATA_LEN;    if (totallen !=	((INT32)GETJOCTET(data[12]) * (INT32)GETJOCTET(data[13]) * (INT32) 3))      TRACEMS1(cinfo, 1, JTRC_JFIF_BADTHUMBNAILSIZE, (int) totallen);  } else if (datalen >= 6 &&      GETJOCTET(data[0]) == 0x4A &&      GETJOCTET(data[1]) == 0x46 &&      GETJOCTET(data[2]) == 0x58 &&      GETJOCTET(data[3]) == 0x58 &&      GETJOCTET(data[4]) == 0) {    /* Found JFIF "JFXX" extension APP0 marker */    /* The library doesn't actually do anything with these,     * but we try to produce a helpful trace message.     */    switch (GETJOCTET(data[5])) {    case 0x10:      TRACEMS1(cinfo, 1, JTRC_THUMB_JPEG, (int) totallen);      break;    case 0x11:      TRACEMS1(cinfo, 1, JTRC_THUMB_PALETTE, (int) totallen);      break;    case 0x13:      TRACEMS1(cinfo, 1, JTRC_THUMB_RGB, (int) totallen);      break;    default:      TRACEMS2(cinfo, 1, JTRC_JFIF_EXTENSION,	       GETJOCTET(data[5]), (int) totallen);      break;    }  } else {    /* Start of APP0 does not match "JFIF" or "JFXX", or too short */    TRACEMS1(cinfo, 1, JTRC_APP0, (int) totallen);  }}LOCAL(void)examine_app14 (j_decompress_ptr cinfo, JOCTET FAR * data,	       unsigned int datalen, INT32 remaining)/* Examine first few bytes from an APP14. * Take appropriate action if it is an Adobe marker. * datalen is # of bytes at data[], remaining is length of rest of marker data. */{  unsigned int version, flags0, flags1, transform;  if (datalen >= APP14_DATA_LEN &&      GETJOCTET(data[0]) == 0x41 &&      GETJOCTET(data[1]) == 0x64 &&      GETJOCTET(data[2]) == 0x6F &&      GETJOCTET(data[3]) == 0x62 &&      GETJOCTET(data[4]) == 0x65) {    /* Found Adobe APP14 marker */    version = (GETJOCTET(data[5]) << 8) + GETJOCTET(data[6]);    flags0 = (GETJOCTET(data[7]) << 8) + GETJOCTET(data[8]);    flags1 = (GETJOCTET(data[9]) << 8) + GETJOCTET(data[10]);    transform = GETJOCTET(data[11]);    TRACEMS4(cinfo, 1, JTRC_ADOBE, version, flags0, flags1, transform);    cinfo->saw_Adobe_marker = TRUE;    cinfo->Adobe_transform = (UINT8) transform;  } else {    /* Start of APP14 does not match "Adobe", or too short */    TRACEMS1(cinfo, 1, JTRC_APP14, (int) (datalen + remaining));  }}METHODDEF(boolean)get_interesting_appn (j_decompress_ptr cinfo)/* Process an APP0 or APP14 marker without saving it */{  INT32 length;  JOCTET b[APPN_DATA_LEN];  unsigned int i, numtoread;  INPUT_VARS(cinfo);  INPUT_2BYTES(cinfo, length, return FALSE);  length -= 2;  /* get the interesting part of the marker data */  if (length >= APPN_DATA_LEN)    numtoread = APPN_DATA_LEN;  else if (length > 0)    numtoread = (unsigned int) length;  else    numtoread = 0;  for (i = 0; i < numtoread; i++)    INPUT_BYTE(cinfo, b[i], return FALSE);  length -= numtoread;  /* process it */  switch (cinfo->unread_marker) {  case M_APP0:    examine_app0(cinfo, (JOCTET FAR *) b, numtoread, length);    break;  case M_APP14:    examine_app14(cinfo, (JOCTET FAR *) b, numtoread, length);    break;  default:    /* can't get here unless jpeg_save_markers chooses wrong processor */    ERREXIT1(cinfo, JERR_UNKNOWN_MARKER, cinfo->unread_marker);    break;  }  /* skip any remaining data -- could be lots */  INPUT_SYNC(cinfo);  if (length > 0)    (*cinfo->src->skip_input_data) (cinfo, (long) length);  return TRUE;}#ifdef SAVE_MARKERS_SUPPORTEDMETHODDEF(boolean)save_marker (j_decompress_ptr cinfo)/* Save an APPn or COM marker into the marker list */{  my_marker_ptr marker = (my_marker_ptr) cinfo->marker;  jpeg_saved_marker_ptr cur_marker = marker->cur_marker;  unsigned int bytes_read, data_length;  JOCTET FAR * data;  INT32 length = 0;  INPUT_VARS(cinfo);  if (cur_marker == NULL) {    /* begin reading a marker */    INPUT_2BYTES(cinfo, length, return FALSE);    length -= 2;    if (length >= 0) {		/* watch out for bogus length word */      /* figure out how much we want to save */      unsigned int limit;      if (cinfo->unread_marker == (int) M_COM)	limit = marker->length_limit_COM;      else	limit = marker->length_limit_APPn[cinfo->unread_marker - (int) M_APP0];      if ((unsigned int) length < limit)	limit = (unsigned int) length;      /* allocate and initialize the marker item */      cur_marker = (jpeg_saved_marker_ptr)	(*cinfo->mem->alloc_large) ((j_common_ptr) cinfo, JPOOL_IMAGE,				    SIZEOF(struct jpeg_marker_struct) + limit);      cur_marker->next = NULL;      cur_marker->marker = (UINT8) cinfo->unread_marker;      cur_marker->original_length = (unsigned int) length;      cur_marker->data_length = limit;      /* data area is just beyond the jpeg_marker_struct */      data = cur_marker->data = (JOCTET FAR *) (cur_marker + 1);      marker->cur_marker = cur_marker;      marker->bytes_read = 0;      bytes_read = 0;      data_length = limit;    } else {      /* deal with bogus length word */      bytes_read = data_length = 0;      data = NULL;    }  } else {    /* resume reading a marker */    bytes_read = marker->bytes_read;    data_length = cur_marker->data_length;    data = cur_marker->data + bytes_read;  }  while (bytes_read < data_length) {    INPUT_SYNC(cinfo);		/* move the restart point to here */    marker->bytes_read = bytes_read;    /* If there's not at least one byte in buffer, suspend */    MAKE_BYTE_AVAIL(cinfo, return FALSE);    /* Copy bytes with reasonable rapidity */    while (bytes_read < data_length && bytes_in_buffer > 0) {      *data++ = *next_input_byte++;      bytes_in_buffer--;      bytes_read++;    }  }  /* Done reading what we want to read */  if (cur_marker != NULL) {	/* will be NULL if bogus length word */    /* Add new marker to end of list */    if (cinfo->marker_list == NULL) {      cinfo->marker_list = cur_marker;    } else {      jpeg_saved_marker_ptr prev = cinfo->marker_list;      while (prev->next != NULL)	prev = prev->next;      prev->next = cur_marker;    }    /* Reset pointer & calc remaining data length */    data = cur_marker->data;    length = cur_marker->original_length - data_length;  }  /* Reset to initial state for next marker */  marker->cur_marker = NULL;  /* Process the marker if interesting; else just make a generic trace msg */  switch (cinfo->unread_marker) {  case M_APP0:    examine_app0(cinfo, data, data_length, length);    break;  case M_APP14:    examine_app14(cinfo, data, data_length, length);    break;  default:    TRACEMS2(cinfo, 1, JTRC_MISC_MARKER, cinfo->unread_marker,	     (int) (data_length + length));    break;  }  /* skip any remaining data -- could be lots */  INPUT_SYNC(cinfo);		/* do before skip_input_data */  if (length > 0)    (*cinfo->src->skip_input_data) (cinfo, (long) length);  return TRUE;}#endif /* SAVE_MARKERS_SUPPORTED */METHODDEF(boolean)skip_variable (j_decompress_ptr cinfo)/* Skip over an unknown or uninteresting variable-length marker */{  INT32 length;  INPUT_VARS(cinfo);  INPUT_2BYTES(cinfo, length, return FALSE);  length -= 2;    TRACEMS2(cinfo, 1, JTRC_MISC_MARKER, cinfo->unread_marker, (int) length);  INPUT_SYNC(cinfo);		/* do before skip_input_data */  if (length > 0)    (*cinfo->src->skip_input_data) (cinfo, (long) length);  return TRUE;}/* * Find the next JPEG marker, save it in cinfo->unread_marker. * Returns FALSE if had to suspend before reaching a marker; * in that case cinfo->unread_marker is unchanged. * * Note that the result might not be a valid marker code, * but it will never be 0 or FF. */LOCAL(boolean)next_marker (j_decompress_ptr cinfo){  int c;  INPUT_VARS(cinfo);  for (;;) {    INPUT_BYTE(cinfo, c, return FALSE);    /* Skip any non-FF bytes.     * This may look a bit inefficient, but it will not occur in a valid file.     * We sync after each discarded byte so that a suspending data source     * can discard the byte from its buffer.     */    while (c != 0xFF) {      cinfo->marker->discarded_bytes++;      INPUT_SYNC(cinfo);      INPUT_BYTE(cinfo, c, return FALSE);    }    /* This loop swallows any duplicate FF bytes.  Extra FFs are legal as     * pad bytes, so don't count them in discarded_bytes.  We assume there     * will not be so many consecutive FF bytes as to overflow a suspending     * data source's input buffer.     */    do {      INPUT_BYTE(cinfo, c, return FALSE);    } while (c == 0xFF);    if (c != 0)      break;			/* found a valid marker, exit loop */    /* Reach here if we found a stuffed-zero data sequence (FF/00).     * Discard it and loop back to try again.     */    cinfo->marker->discarded_bytes += 2;    INPUT_SYNC(cinfo);  }  if (cinfo->marker->discarded_bytes != 0) {

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产日韩欧美综合在线| 亚洲精品乱码久久久久久黑人 | 91色在线porny| 欧美精品一区二区三区在线| 国产成人亚洲综合a∨猫咪| 亚洲国产成人自拍| 精品国产制服丝袜高跟| 久久综合色播五月| 懂色av噜噜一区二区三区av| 中文字幕国产一区二区| 国产日韩欧美电影| 久久久久久久久久久黄色| www国产亚洲精品久久麻豆| 精品国产91九色蝌蚪| 久久日韩粉嫩一区二区三区| 精品国产91亚洲一区二区三区婷婷| 欧美一区二区三区精品| 日韩欧美电影在线| 久久久久久免费| 国产欧美日韩三区| 亚洲视频1区2区| 亚洲一区电影777| 一个色在线综合| 亚洲成人自拍一区| 免费观看在线色综合| 九九视频精品免费| 成人黄色一级视频| 91精品办公室少妇高潮对白| 欧美日韩国产首页| 精品国产91乱码一区二区三区| 久久久久久夜精品精品免费| 中文一区二区在线观看| 亚洲免费在线视频一区 二区| 亚洲伊人色欲综合网| 美女视频黄久久| 懂色av噜噜一区二区三区av| 色综合色狠狠综合色| 91福利在线观看| 日韩欧美中文一区二区| 久久精品人人做人人爽人人| 亚洲欧洲无码一区二区三区| 亚洲国产精品视频| 久久99在线观看| 一区二区在线观看不卡| 亚洲免费高清视频在线| 婷婷开心激情综合| 老司机免费视频一区二区| 国内久久精品视频| 色婷婷久久综合| 在线观看亚洲精品| 在线不卡免费av| 欧美日韩精品系列| 国产视频一区二区在线| 亚洲三级视频在线观看| 在线观看亚洲成人| 国产制服丝袜一区| 一区二区三区中文在线| 美腿丝袜亚洲综合| 一本到三区不卡视频| 欧美成va人片在线观看| 一区二区高清免费观看影视大全 | 亚洲男人的天堂在线aⅴ视频| 午夜精品久久久久久久蜜桃app| 国产成人av资源| 欧美一级理论片| 亚洲综合免费观看高清完整版| 国产一区二区三区观看| 欧美日韩午夜在线| 亚洲人吸女人奶水| 国产成人精品免费一区二区| 3d动漫精品啪啪1区2区免费 | 午夜影视日本亚洲欧洲精品| 大尺度一区二区| 欧美电视剧免费观看| 亚洲一级二级在线| 成人av网站在线观看| 日韩你懂的在线播放| 香蕉影视欧美成人| 日本电影亚洲天堂一区| 国产精品久久免费看| 国产精品18久久久久久久久久久久 | 成人免费观看男女羞羞视频| 精品国产乱码久久久久久免费| 香蕉乱码成人久久天堂爱免费| av在线免费不卡| 国产精品美女www爽爽爽| 精品一区二区国语对白| 日韩一区二区三区精品视频| 亚洲精品视频观看| 国产91精品一区二区麻豆亚洲| 欧美人与z0zoxxxx视频| 亚洲国产成人在线| 日韩一级完整毛片| 中文字幕亚洲不卡| 人禽交欧美网站| 制服丝袜亚洲精品中文字幕| 亚洲一区日韩精品中文字幕| 日韩欧美你懂的| 日韩精品91亚洲二区在线观看| 欧美色综合网站| 国产欧美日韩视频在线观看| 中文字幕不卡一区| 国产午夜精品一区二区三区视频 | 欧美日韩亚洲国产综合| 亚洲激情一二三区| 免费看日韩精品| 欧美中文字幕一二三区视频| 亚洲免费在线观看| 一区二区三区四区国产精品| 色94色欧美sute亚洲线路一ni | 中文子幕无线码一区tr| 亚洲另类春色国产| 国产成人精品影视| 国产精品久久毛片av大全日韩| 一区二区在线观看免费| 欧美日韩一二三| 蜜桃91丨九色丨蝌蚪91桃色| 色狠狠色噜噜噜综合网| 午夜日韩在线电影| 日韩一区国产二区欧美三区| 亚洲一级二级三级| 欧美一二区视频| 国产美女一区二区| 欧美老人xxxx18| 久久91精品国产91久久小草 | 日本丶国产丶欧美色综合| 日韩专区在线视频| 亚洲成人动漫精品| 久久综合九色综合欧美98| 99re亚洲国产精品| 亚洲va韩国va欧美va| 日韩午夜在线观看| 欧美精品丝袜中出| 成人晚上爱看视频| 中文字幕日本乱码精品影院| 欧美精品一区二区三区很污很色的| 精品一区在线看| 国产精品伊人色| 不卡在线视频中文字幕| 亚洲综合色噜噜狠狠| av在线播放不卡| 日日夜夜免费精品| 久久蜜臀精品av| 国精产品一区一区三区mba视频| 精品制服美女丁香| 国产精品国产精品国产专区不蜜| 欧美成人aa大片| 色悠久久久久综合欧美99| 国产精品乱码妇女bbbb| 欧美国产日韩亚洲一区| 欧美一区二区在线播放| 欧美一区二区视频免费观看| 粉嫩久久99精品久久久久久夜| 午夜免费欧美电影| 麻豆精品一区二区av白丝在线| 国产欧美日韩另类视频免费观看| 精品国精品自拍自在线| 91高清视频在线| www.性欧美| 欧美日韩色综合| 欧美视频在线一区| 5566中文字幕一区二区电影| 91色婷婷久久久久合中文| 日韩精品一卡二卡三卡四卡无卡| 一本色道久久综合亚洲aⅴ蜜桃| 国内不卡的二区三区中文字幕| 午夜久久久影院| 国产亚洲成aⅴ人片在线观看| 欧美主播一区二区三区| 日韩欧美亚洲另类制服综合在线| 精品国产免费久久| 亚洲成人久久影院| 欧美日韩国产一级| 欧美日韩美少妇| 日韩精品一级中文字幕精品视频免费观看| 中文字幕欧美国产| 日韩免费看的电影| 处破女av一区二区| 国内国产精品久久| 天堂久久久久va久久久久| 日韩精品影音先锋| 欧美精品tushy高清| 91欧美一区二区| 国产一区二区三区av电影| 日本黄色一区二区| 国产 欧美在线| 一本久久精品一区二区| 久久久久久亚洲综合影院红桃| 亚洲综合成人网| www.欧美.com| 91福利在线看| 亚洲丝袜精品丝袜在线| 亚洲精品国产一区二区三区四区在线 | 粉嫩aⅴ一区二区三区四区 | 亚洲欧洲美洲综合色网| 在线观看不卡一区| 99久久99久久精品免费观看 | 亚洲欧洲在线观看av| 6080亚洲精品一区二区| 欧美三级在线播放|