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

📄 ebcasc.c

📁 seismic software,very useful
💻 C
字号:
/* ebcdic/ascii conversions ** ascii to ebcdic*     call fascii (in, out, length, ibitof)  in fortran*          fascii_(in, out, length, ibitof)  in c* ebcdic to ascii*     call tascii (in, out, length, ibiton)  in fortran*          tascii_(in, out, length, ibiton)  in c** input arguments*     in     - beginning address of data to be converted to other code.**     out    - beginning address of area where converted data is to be*              stored.*     in and out are singly indirect, so any array or common block name*     will do; just count the length carefully!**     length - integer - number of bytes to be converted,**     ibitof - integer - 0 = normal conversion*                        1 = turn off high order bit before conversion *			 ibitof is meaningless in this context; the high*			 bit is always masked. ibitof is retained only*			 for backwards compatibility. the mvs version*			 produced garbage if 8 bit data was passed and*			 ibitof was not set.**     ibiton - integer - 0 = normal conversion*                        1 = turn on high order bit after conversion**/#include "wgc.h"#include "par.h"#include <stdio.h>/* convert ascii to ebcdic */int fascii_(unsigned char *in,unsigned char *out,int length,int ibitof){  int i;/* conversion table */  unsigned char astoeb_tbl[128] =		 { 			0x00,0x01,0x02,0x03,0x37,0x2d,0x2e,0x2f, 			0x16,0x05,0x25,0x0b,0x0c,0x0d,0x0e,0x0f,			0x10,0x11,0x12,0x13,0x3c,0x3d,0x32,0x26,			0x18,0x19,0x3f,0x27,0x1c,0x1d,0x1e,0x1f,			0x40,0x5a,0x7f,0x7b,0x5b,0x6c,0x50,0x7d,			0x4d,0x5d,0x5c,0x4e,0x6b,0x60,0x4b,0x61,			0xf0,0xf1,0xf2,0xf3,0xf4,0xf5,0xf6,0xf7,			0xf8,0xf9,0x7a,0x5e,0x4c,0x7e,0x6e,0x6f,			0x7c,0xc1,0xc2,0xc3,0xc4,0xc5,0xc6,0xc7,			0xc8,0xc9,0xd1,0xd2,0xd3,0xd4,0xd5,0xd6,			0xd7,0xd8,0xd9,0xe2,0xe3,0xe4,0xe5,0xe6,			0xe7,0xe8,0xe9,0xad,0xe0,0xbd,0x5f,0x6d,			0x79,0x81,0x82,0x83,0x84,0x85,0x86,0x87,			0x88,0x89,0x91,0x92,0x93,0x94,0x95,0x96,			0x97,0x98,0x99,0xa2,0xa3,0xa4,0xa5,0xa6,			0xa7,0xa8,0xa9,0xc0,0x6a,0xd0,0xa1,0x07		 };  for(i = 0; i <= length-1; i++)      out[i] = astoeb_tbl[(in[i] & 0x7f)];}/* convert ebcdic to ascii */int tascii_(unsigned char *in,unsigned char *out, int length, int ibiton){  int i;/* conversion table */  unsigned char ebtoas_tbl[256] =		 {			0x00,0x01,0x02,0x03,0x1a,0x09,0x1a,0x7f,			0x1a,0x1a,0x1a,0x0b,0x0c,0x0d,0x0e,0x0f,			0x10,0x11,0x12,0x13,0x1a,0x1a,0x08,0x1a,			0x18,0x19,0x1a,0x1a,0x1c,0x1d,0x1e,0x1f,			0x1a,0x1a,0x1a,0x1a,0x1a,0x0a,0x17,0x1b,			0x1a,0x1a,0x1a,0x1a,0x1a,0x05,0x06,0x07,			0x1a,0x1a,0x16,0x1a,0x1a,0x1a,0x1a,0x04,			0x1a,0x1a,0x1a,0x1a,0x14,0x15,0x1a,0x1a,			0x20,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x1a,0x5b,0x2e,0x3c,0x28,0x2b,0x7c,			0x26,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x1a,0x21,0x24,0x2a,0x29,0x3b,0x5e,			0x2d,0x2f,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x1a,0x7c,0x2c,0x25,0x5f,0x3e,0x3f,			0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x60,0x3a,0x23,0x40,0x27,0x3d,0x22,			0x1a,0x61,0x62,0x63,0x64,0x65,0x66,0x67,			0x68,0x69,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x6a,0x6b,0x6c,0x6d,0x6e,0x6f,0x70,			0x71,0x72,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x7e,0x73,0x74,0x75,0x76,0x77,0x78,			0x79,0x7a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x7b,0x41,0x42,0x43,0x44,0x45,0x46,0x47,			0x48,0x49,0x1a,0x1a,0x5b,0x1a,0x5d,0x1a,			0x7d,0x4a,0x4b,0x4c,0x4d,0x4e,0x4f,0x50,			0x51,0x52,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x5c,0x1a,0x53,0x54,0x55,0x56,0x57,0x58,			0x59,0x5a,0x1a,0x1a,0x1a,0x1a,0x1a,0x1a,			0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,			0x38,0x39,0x7c,0x1a,0x1a,0x1a,0x1a,0x1a		 };  if (ibiton == 0)      for(i = 0; i <= length-1; i++)          out[i] = ebtoas_tbl[(in[i])];  else if (ibiton == 1)      for(i = 0; i <= length-1; i++)          out[i] = ebtoas_tbl[(in[i])] & 0xff;}

⌨️ 快捷键说明

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