Contiki 3.x
petsciiconv.c
1 /*
2  * Copyright (c) 2002, Adam Dunkels.
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above
11  * copyright notice, this list of conditions and the following
12  * disclaimer in the documentation and/or other materials provided
13  * with the distribution.
14  * 3. The name of the author may not be used to endorse or promote
15  * products derived from this software without specific prior
16  * written permission.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
19  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
20  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
22  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
24  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
26  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29  *
30  * This file is part of the Contiki desktop environment for the C64.
31  *
32  *
33  */
34 
35 /*
36 static unsigned char petscii2ascii[128] = {
37  0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
38  0x14,0x09,0x0d,0x11,0x93,0x0a,0x0e,0x0f,
39  0x10,0x0b,0x12,0x13,0x08,0x15,0x16,0x17,
40  0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f,
41  0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27,
42  0x28,0x29,0x2a,0x2b,0x2c,0x2d,0x2e,0x2f,
43  0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,
44  0x38,0x39,0x3a,0x3b,0x3c,0x3d,0x3e,0x3f,
45  0x40,0x61,0x62,0x63,0x64,0x65,0x66,0x67,
46  0x68,0x69,0x6a,0x6b,0x6c,0x6d,0x6e,0x6f,
47  0x70,0x71,0x72,0x73,0x74,0x75,0x76,0x77,
48  0x78,0x79,0x7a,0x5b,0x5c,0x5d,0x7e,0x5f,
49  0xc0,0xc1,0xc2,0xc3,0xc4,0xc5,0xc6,0xc7,
50  0xc8,0xc9,0xca,0xcb,0xcc,0xcd,0xce,0xcf,
51  0xd0,0xd1,0xd2,0xd3,0xd4,0xd5,0xd6,0xd7,
52  0xd8,0xd9,0xda,0xdb,0xdc,0xdd,0x7e,0xdf
53 };
54 */
55 
56 static unsigned char ascii2petscii[128] = {
57  0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,
58  0x14,0x09,0x0d,0x11,0x93,0x0a,0x0e,0x0f,
59  0x10,0x0b,0x12,0x13,0x08,0x15,0x16,0x17,
60  0x18,0x19,0x1a,0x1b,0x1c,0x1d,0x1e,0x1f,
61  0x20,0x21,0x22,0x23,0x24,0x25,0x26,0x27,
62  0x28,0x29,0x2a,0x2b,0x2c,0x2d,0x2e,0x2f,
63  0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,
64  0x38,0x39,0x3a,0x3b,0x3c,0x3d,0x3e,0x3f,
65  0x40,0xc1,0xc2,0xc3,0xc4,0xc5,0xc6,0xc7,
66  0xc8,0xc9,0xca,0xcb,0xcc,0xcd,0xce,0xcf,
67  0xd0,0xd1,0xd2,0xd3,0xd4,0xd5,0xd6,0xd7,
68  0xd8,0xd9,0xda,0x5b,0x5c,0x5d,0x5e,0x5f,
69  0xc0,0x41,0x42,0x43,0x44,0x45,0x46,0x47,
70  0x48,0x49,0x4a,0x4b,0x4c,0x4d,0x4e,0x4f,
71  0x50,0x51,0x52,0x53,0x54,0x55,0x56,0x57,
72  0x58,0x59,0x5a,0xdb,0xdd,0xdd,0x5e,0xdf,
73 };
74 
75 static unsigned int i;
76 static unsigned char *ptr;
77 
78 /*-----------------------------------------------------------------------------------*/
79 void
80 petsciiconv_toascii(char *buf, unsigned int len)
81 {
82  static char c;
83 
84  ptr = buf;
85  for(i = len; i > 0; --i) {
86  c = *ptr;
87  if(c == 0x0a) {
88  c = 0x0d;
89  } else if(c == 0x0d) {
90  c = 0x0a;
91  }
92  if(c != 0x40) {
93  switch (c & 0xe0) {
94  case 0x40:
95  case 0x60:
96  c ^= 0x20;
97  break;
98  case 0xc0:
99  c ^= 0x80;
100  break;
101  }
102  }
103  *ptr = c & 0x7f;
104  ++ptr;
105  }
106 }
107 /*-----------------------------------------------------------------------------------*/
108 void
109 petsciiconv_topetscii(char *buf, unsigned int len)
110 {
111  ptr = buf;
112  for(i = len; i > 0; --i) {
113  *ptr = ascii2petscii[*ptr & 0x7f];
114  ++ptr;
115  }
116 }
117 /*-----------------------------------------------------------------------------------*/