summaryrefslogtreecommitdiffstats
path: root/docs-xml/smbdotconf/filename/manglednames.xml
blob: 1a6a57e6b66002db7412c093a7fcacd3ddb8901f (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
73
74
75
76
77
<samba:parameter name="mangled names"
                 type="enum"
                 enumlist="enum_mangled_names"
                 context="S"
                 parm="1"
                 xmlns:samba="http://www.samba.org/samba/DTD/samba-doc">
<description>
	<para>This controls whether non-DOS names under UNIX 
	should be mapped to DOS-compatible names (&quot;mangled&quot;) and made visible, 
	or whether non-DOS names should simply be ignored.</para>

	<para>See the section on <link linkend="NAMEMANGLINGSECT">name mangling</link> for
	details on how to control the mangling process.</para>

	<para>Possible option settings are</para>

	<itemizedlist>
		<listitem><para><emphasis>yes</emphasis> -
		enables name mangling for all not DOS 8.3 conforming
		names.</para></listitem>

		<listitem><para><emphasis>no</emphasis> - disables any
		name mangling.</para></listitem>

		<listitem><para><emphasis>illegal (default)</emphasis> - does
		mangling for names with illegal NTFS characters. This
		is the most sensible setting for modern clients that
		don't use the shortname anymore.</para></listitem>
	</itemizedlist>

	<para>If mangling is used then the mangling method is as follows:</para>

	<itemizedlist>
		<listitem>
			<para>The first (up to) five alphanumeric characters 
			before the rightmost dot of the filename are preserved, forced 
			to upper case, and appear as the first (up to) five characters 
			of the mangled name.</para>
		</listitem>
		
		<listitem>
			<para>A tilde &quot;~&quot; is appended to the first part of the mangled
			name, followed by a two-character unique sequence, based on the
			original root name (i.e., the original filename minus its final
			extension). The final extension is included in the hash calculation
			only if it contains any upper case characters or is longer than three
			characters.</para>

			<para>Note that the character to use may be specified using 
				the <smbconfoption name="mangling char"/>
			option, if you don't like '~'.</para>
		</listitem>

		<listitem>
			<para>Files whose UNIX name begins with a dot will be 
			presented as DOS hidden files. The mangled name will be created as 
			for other filenames, but with the leading dot removed and &quot;___&quot; as 
			its extension regardless of actual original extension (that's three 
			underscores).</para>
		</listitem>
	</itemizedlist>

	<para>The two-digit hash value consists of upper case alphanumeric characters.</para>

	<para>This algorithm can cause name collisions only if files 
	in a directory share the same first five alphanumeric characters. 
	The probability of such a clash is 1/1300.</para>

	<para>The name mangling (if enabled) allows a file to be 
	copied between UNIX directories from Windows/DOS while retaining 
	the long UNIX filename. UNIX files can be renamed to a new extension 
	from Windows/DOS and will retain the same basename. Mangled names 
	do not change between sessions.</para>
</description>
<value type="default">illegal</value>
<value type="example">no</value>
</samba:parameter>