File: pyolecf_codepage.c

package info (click to toggle)
libolecf 20181231-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 12,508 kB
  • sloc: ansic: 182,255; sh: 6,096; makefile: 1,355; python: 325; sed: 16
file content (138 lines) | stat: -rw-r--r-- 3,292 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/*
 * Codepage functions
 *
 * Copyright (C) 2008-2018, Joachim Metz <joachim.metz@gmail.com>
 *
 * Refer to AUTHORS for acknowledgements.
 *
 * This software is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this software.  If not, see <http://www.gnu.org/licenses/>.
 */

#include <common.h>
#include <types.h>

#include "pyolecf_codepage.h"
#include "pyolecf_libolecf.h"

/* Returns a string representation of the codepage
 * Codecs and aliases are defined: http://docs.python.org/library/codecs.html#standard-encodings
 * Returns 1 if successful or NULL if codepage is not supported
 */
const char *pyolecf_codepage_to_string(
             int codepage )
{
	switch( codepage )
	{
		case LIBOLECF_CODEPAGE_ASCII:
			return( "ascii" );

		case LIBOLECF_CODEPAGE_ISO_8859_1:
			return( "iso-8859-1" );

		case LIBOLECF_CODEPAGE_ISO_8859_2:
			return( "iso-8859-2" );

		case LIBOLECF_CODEPAGE_ISO_8859_3:
			return( "iso-8859-3" );

		case LIBOLECF_CODEPAGE_ISO_8859_4:
			return( "iso-8859-4" );

		case LIBOLECF_CODEPAGE_ISO_8859_5:
			return( "iso-8859-5" );

		case LIBOLECF_CODEPAGE_ISO_8859_6:
			return( "iso-8859-6" );

		case LIBOLECF_CODEPAGE_ISO_8859_7:
			return( "iso-8859-7" );

		case LIBOLECF_CODEPAGE_ISO_8859_8:
			return( "iso-8859-8" );

		case LIBOLECF_CODEPAGE_ISO_8859_9:
			return( "iso-8859-9" );

		case LIBOLECF_CODEPAGE_ISO_8859_10:
			return( "iso-8859-10" );

		case LIBOLECF_CODEPAGE_ISO_8859_11:
			return( "iso-8859-11" );

		case LIBOLECF_CODEPAGE_ISO_8859_13:
			return( "iso-8859-13" );

		case LIBOLECF_CODEPAGE_ISO_8859_14:
			return( "iso-8859-14" );

		case LIBOLECF_CODEPAGE_ISO_8859_15:
			return( "iso-8859-15" );

		case LIBOLECF_CODEPAGE_ISO_8859_16:
			return( "iso-8859-16" );

		case LIBOLECF_CODEPAGE_KOI8_R:
			return( "koi8_r" );

		case LIBOLECF_CODEPAGE_KOI8_U:
			return( "koi8_u" );

		case LIBOLECF_CODEPAGE_WINDOWS_874:
			return( "cp874" );

		case LIBOLECF_CODEPAGE_WINDOWS_932:
			return( "cp932" );

		case LIBOLECF_CODEPAGE_WINDOWS_936:
			return( "cp936" );

		case LIBOLECF_CODEPAGE_WINDOWS_949:
			return( "cp949" );

		case LIBOLECF_CODEPAGE_WINDOWS_950:
			return( "cp950" );

		case LIBOLECF_CODEPAGE_WINDOWS_1250:
			return( "cp1250" );

		case LIBOLECF_CODEPAGE_WINDOWS_1251:
			return( "cp1251" );

		case LIBOLECF_CODEPAGE_WINDOWS_1252:
			return( "cp1252" );

		case LIBOLECF_CODEPAGE_WINDOWS_1253:
			return( "cp1253" );

		case LIBOLECF_CODEPAGE_WINDOWS_1254:
			return( "cp1254" );

		case LIBOLECF_CODEPAGE_WINDOWS_1255:
			return( "cp1255" );

		case LIBOLECF_CODEPAGE_WINDOWS_1256:
			return( "cp1256" );

		case LIBOLECF_CODEPAGE_WINDOWS_1257:
			return( "cp1257" );

		case LIBOLECF_CODEPAGE_WINDOWS_1258:
			return( "cp1258" );

		default:
			break;
	}
	return( NULL );
}