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

📄 lzio.c

📁 一个2D电磁场FEM计算的VC++源程序
💻 C
字号:
/*** $Id: lzio.c,v 1.13 2000/06/12 13:52:05 roberto Exp $** a generic input stream interface** See Copyright Notice in lua.h*/#include <stdio.h>#include <string.h>#include "lua.h"#include "lzio.h"/* ----------------------------------------------------- memory buffers --- */static int zmfilbuf (ZIO* z) {  (void)z;  /* to avoid warnings */  return EOZ;}ZIO* zmopen (ZIO* z, const char* b, size_t size, const char *name) {  if (b==NULL) return NULL;  z->n = size;  z->p = (const unsigned char *)b;  z->filbuf = zmfilbuf;  z->u = NULL;  z->name = name;  return z;}/* ------------------------------------------------------------ strings --- */ZIO* zsopen (ZIO* z, const char* s, const char *name) {  if (s==NULL) return NULL;  return zmopen(z, s, strlen(s), name);}/* -------------------------------------------------------------- FILEs --- */static int zffilbuf (ZIO* z) {  size_t n;  if (feof((FILE *)z->u)) return EOZ;  n = fread(z->buffer, 1, ZBSIZE, (FILE *)z->u);  if (n==0) return EOZ;  z->n = n-1;  z->p = z->buffer;  return *(z->p++);}ZIO* zFopen (ZIO* z, FILE* f, const char *name) {  if (f==NULL) return NULL;  z->n = 0;  z->p = z->buffer;  z->filbuf = zffilbuf;  z->u = f;  z->name = name;  return z;}/* --------------------------------------------------------------- read --- */size_t zread (ZIO *z, void *b, size_t n) {  while (n) {    size_t m;    if (z->n == 0) {      if (z->filbuf(z) == EOZ)        return n;  /* return number of missing bytes */      zungetc(z);  /* put result from `filbuf' in the buffer */    }    m = (n <= z->n) ? n : z->n;  /* min. between n and z->n */    memcpy(b, z->p, m);    z->n -= m;    z->p += m;    b = (char *)b + m;    n -= m;  }  return 0;}

⌨️ 快捷键说明

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