aboutsummaryrefslogtreecommitdiffstats
path: root/fs/hfs/trans.c
blob: fb9720abbadd64ff572f58b4533302247347e50c (plain)
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
/*
 *  linux/fs/hfs/trans.c
 *
 * Copyright (C) 1995-1997  Paul H. Hargrove
 * This file may be distributed under the terms of the GNU General Public License.
 *
 * This file contains routines for converting between the Macintosh
 * character set and various other encodings.  This includes dealing
 * with ':' vs. '/' as the path-element separator.
 */

#include "hfs_fs.h"

/*================ Global functions ================*/

/*
 * hfs_mac2triv()
 *
 * Given a 'Pascal String' (a string preceded by a length byte) in
 * the Macintosh character set produce the corresponding filename using
 * the 'trivial' name-mangling scheme, returning the length of the
 * mangled filename.  Note that the output string is not NULL
 * terminated.
 *
 * The name-mangling works as follows:
 * The character '/', which is illegal in Linux filenames is replaced
 * by ':' which never appears in HFS filenames.	 All other characters
 * are passed unchanged from input to output.
 */
int hfs_mac2triv(char *out, const struct hfs_name *in)
{
	const char *p;
	char c;
	int i, len;

	len = in->len;
	p = in->name;
	for (i = 0; i < len; i++) {
		c = *p++;
		*out++ = c == '/' ? ':' : c;
	}
	return i;
}

/*
 * hfs_triv2mac()
 *
 * Given an ASCII string (not null-terminated) and its length,
 * generate the corresponding filename in the Macintosh character set
 * using the 'trivial' name-mangling scheme, returning the length of
 * the mangled filename.  Note that the output string is not NULL
 * terminated.
 *
 * This routine is a inverse to hfs_mac2triv().
 * A ':' is replaced by a '/'.
 */
void hfs_triv2mac(struct hfs_name *out, struct qstr *in)
{
	const char *src;
	char *dst, c;
	int i, len;

	out->len = len = min((unsigned int)HFS_NAMELEN, in->len);
	src = in->name;
	dst = out->name;
	for (i = 0; i < len; i++) {
		c = *src++;
		*dst++ = c == ':' ? '/' : c;
	}
	for (; i < HFS_NAMELEN; i++)
		*dst++ = 0;
}