⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 crlf2nl.c

📁 Algorithms for Image Processing and Computer Vision Source Code
💻 C
字号:
/* This is file CRLF2NL.C */
/*
** Copyright (C) 1993 DJ Delorie, 24 Kirsten Ave, Rochester NH 03867-2954
**
** This file is distributed under the terms listed in the document
** "copying.dj", available from DJ Delorie at the address above.
** A copy of "copying.dj" should accompany this file; if not, a copy
** should be available from where this file was obtained.  This file
** may not be distributed without a verbatim copy of "copying.dj".
**
** This file is distributed WITHOUT ANY WARRANTY; without even the implied
** warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*/

#include <stdlib.h>

unsigned crlf2nl(char *buf, unsigned len)
{
  char *bp = buf;
  int i=0;
  while (len--)
  {
    if (*bp != 13)
    {
      *buf++ = *bp;
      i++;
    }
    bp++;
  }
  return i;
}

unsigned readcr(int fd, char *buf, unsigned len)
{
  unsigned i;
  i = read(fd, buf, len);
  if (i <= 0)
    return i;
  return crlf2nl(buf, i);
}

static char *sbuf = 0;
#define BUFSIZE 4096

unsigned writecr(int fd, char *buf, unsigned len)
{
  unsigned bufp=0, sbufp=0, crcnt=0, rlen=0;
  int rv;
  if (sbuf == 0)
    sbuf = (char *)malloc(BUFSIZE+1);
  while (len--)
  {
    if (buf[bufp] == 10)
    {
      crcnt++;
      sbuf[sbufp++] = 13;
    }
    sbuf[sbufp++] = buf[bufp++];
    if ((sbufp >= BUFSIZE) || (len == 0))
    {
      rv = write(fd, sbuf, sbufp);
      if (rv < 0)
        return rv;
      rlen += rv - crcnt;
      crcnt = 0;
      sbufp = 0;
    }
  }
  return rlen;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -