mirror of
https://github.com/Myzel394/config-lsp.git
synced 2025-06-18 23:15:26 +02:00
Add more mount options to common-documentation/filesystems/mountoptions
Related to #3 Add mount options for `devpts`, `fat`, `hfs`, and `hpfs` filesystems. * **common-documentation/filesystems/mountoptions/devpts.go** - Implement mount options for `devpts` filesystem. - Export `DevptsDocumentationAssignable` and `DevptsDocumentationEnums` variables. * **common-documentation/filesystems/mountoptions/fat.go** - Implement mount options for `fat` filesystem. - Export `FatDocumentationAssignable` and `FatDocumentationEnums` variables. * **common-documentation/filesystems/mountoptions/hfs.go** - Implement mount options for `hfs` filesystem. - Export `HfsDocumentationAssignable` and `HfsDocumentationEnums` variables. * **common-documentation/filesystems/mountoptions/hpfs.go** - Implement mount options for `hpfs` filesystem. - Export `HpfsDocumentationAssignable` and `HpfsDocumentationEnums` variables. * **handlers/fstab/documentation/documentation-mountoptions.go** - Add entries for `devpts`, `fat`, `hfs`, and `hpfs` filesystems in `MountOptionsMapField`.
This commit is contained in:
parent
223428cf42
commit
131f80fe4c
33
common-documentation/filesystems/mountoptions/devpts.go
Normal file
33
common-documentation/filesystems/mountoptions/devpts.go
Normal file
@ -0,0 +1,33 @@
|
||||
package commondocumentation
|
||||
|
||||
import docvalues "config-lsp/doc-values"
|
||||
|
||||
var DevptsDocumentationAssignable = map[docvalues.EnumString]docvalues.Value{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"uid",
|
||||
"This sets the owner or the group of newly created pseudo terminals to the specified values. When nothing is specified, they will be set to the UID and GID of the creating process. For example, if there is a tty group with GID 5, then gid=5 will cause newly created pseudo terminals to belong to the tty group.",
|
||||
): docvalues.UIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"gid",
|
||||
"This sets the owner or the group of newly created pseudo terminals to the specified values. When nothing is specified, they will be set to the UID and GID of the creating process. For example, if there is a tty group with GID 5, then gid=5 will cause newly created pseudo terminals to belong to the tty group.",
|
||||
): docvalues.GIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"mode",
|
||||
"Set the mode of newly created pseudo terminals to the specified value. The default is 0600. A value of mode=620 and gid=5 makes \"mesg y\" the default on newly created pseudo terminals.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"ptmxmode",
|
||||
"Set the mode for the new ptmx device node in the devpts filesystem. With the support for multiple instances of devpts (see newinstance option above), each instance has a private ptmx node in the root of the devpts filesystem (typically /dev/pts/ptmx). For compatibility with older versions of the kernel, the default mode of the new ptmx node is 0000. ptmxmode=value specifies a more useful mode for the ptmx node and is highly recommended when the newinstance option is specified. This option is only implemented in Linux kernel versions starting with 2.6.29. Further, this option is valid only if CONFIG_DEVPTS_MULTIPLE_INSTANCES is enabled in the kernel configuration.",
|
||||
): docvalues.StringValue{},
|
||||
}
|
||||
|
||||
var DevptsDocumentationEnums = []docvalues.EnumString{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"newinstance",
|
||||
"Create a private instance of the devpts filesystem, such that indices of pseudo terminals allocated in this new instance are independent of indices created in other instances of devpts. All mounts of devpts without this newinstance option share the same set of pseudo terminal indices (i.e., legacy mode). Each mount of devpts with the newinstance option has a private set of pseudo terminal indices. This option is mainly used to support containers in the Linux kernel. It is implemented in Linux kernel versions starting with 2.6.29. Further, this mount option is valid only if CONFIG_DEVPTS_MULTIPLE_INSTANCES is enabled in the kernel configuration. To use this option effectively, /dev/ptmx must be a symbolic link to pts/ptmx. See Documentation/filesystems/devpts.txt in the Linux kernel source tree for details.",
|
||||
),
|
||||
}
|
150
common-documentation/filesystems/mountoptions/fat.go
Normal file
150
common-documentation/filesystems/mountoptions/fat.go
Normal file
@ -0,0 +1,150 @@
|
||||
package commondocumentation
|
||||
|
||||
import docvalues "config-lsp/doc-values"
|
||||
|
||||
var FatDocumentationAssignable = map[docvalues.EnumString]docvalues.Value{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"blocksize",
|
||||
"Set blocksize (default 512). This option is obsolete.",
|
||||
): docvalues.EnumValue{
|
||||
EnforceValues: true,
|
||||
Values: []docvalues.EnumString{
|
||||
// TODO: Check for other values too
|
||||
docvalues.CreateEnumString("512"),
|
||||
docvalues.CreateEnumString("1024"),
|
||||
docvalues.CreateEnumString("2048"),
|
||||
},
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"uid",
|
||||
"Set the owner and group of all files. (Default: the UID and GID of the current process.)",
|
||||
): docvalues.UIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"gid",
|
||||
"Set the owner and group of all files. (Default: the UID and GID of the current process.)",
|
||||
): docvalues.GIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"umask",
|
||||
"Set the umask (the bitmask of the permissions that are not present). The default is the umask of the current process. The value is given in octal.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"dmask",
|
||||
"Set the umask applied to directories only. The default is the umask of the current process. The value is given in octal.",
|
||||
// TODO: Add mask
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"fmask",
|
||||
"Set the umask applied to regular files only. The default is the umask of the current process. The value is given in octal.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"allow_utime",
|
||||
"This option controls the permission check of mtime/atime.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"check",
|
||||
"Three different levels of pickiness can be chosen: relaxed, normal, strict.",
|
||||
): docvalues.EnumValue{
|
||||
EnforceValues: true,
|
||||
Values: []docvalues.EnumString{
|
||||
docvalues.CreateEnumString("relaxed"),
|
||||
docvalues.CreateEnumString("normal"),
|
||||
docvalues.CreateEnumString("strict"),
|
||||
},
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"codepage",
|
||||
"Sets the codepage for converting to shortname characters on FAT and VFAT filesystems. By default, codepage 437 is used.",
|
||||
// TODO: Check if NumberValue fits here
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"iocharset",
|
||||
"Character set to use for converting between 8 bit characters and 16 bit Unicode characters. The default is iso8859-1. Long filenames are stored on disk in Unicode format.",
|
||||
// TODO: Use enum for charsets
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"time_offset",
|
||||
"Set offset for conversion of timestamps from local time used by FAT to UTC. I.e., minutes will be subtracted from each timestamp to convert it to UTC used internally by Linux. This is useful when the time zone set in the kernel via settimeofday(2) is not the time zone used by the filesystem. Note that this option still does not provide correct time stamps in all cases in presence of DST - time stamps in a different DST setting will be off by one hour.",
|
||||
// TODO: Probably NumberValeu
|
||||
): docvalues.NumberValue{},
|
||||
}
|
||||
|
||||
var FatDocumentationEnums = []docvalues.EnumString{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
// TODO: Show warning in analyzevalue when used
|
||||
"conv",
|
||||
"This option is obsolete and may fail or be ignored.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"cvf_format",
|
||||
"Forces the driver to use the CVF (Compressed Volume File) module cvf_module instead of auto-detection. If the kernel supports kmod, the cvf_format=xxx option also controls on-demand CVF module loading. This option is obsolete.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"cvf_option",
|
||||
"Option passed to the CVF module. This option is obsolete.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"debug",
|
||||
"Turn on the debug flag. A version string and a list of filesystem parameters will be printed (these data are also printed if the parameters appear to be inconsistent).",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"discard",
|
||||
"If set, causes discard/TRIM commands to be issued to the block device when blocks are freed. This is useful for SSD devices and sparse/thinly-provisioned LUNs.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"dos1xfloppy",
|
||||
"If set, use a fallback default BIOS Parameter Block configuration, determined by backing device size. These static parameters match defaults assumed by DOS 1.x for 160 kiB, 180 kiB, 320 kiB, and 360 kiB floppies and floppy images.",
|
||||
),
|
||||
// TODO: Should be in map
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"errors",
|
||||
"Specify FAT behavior on critical errors: panic, continue without doing anything, or remount the partition in read-only mode (default behavior).",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"fat",
|
||||
"Specify a 12, 16 or 32 bit fat. This overrides the automatic FAT type detection routine. Use with caution!",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"nfs",
|
||||
"Enable this only if you want to export the FAT filesystem over NFS.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"quiet",
|
||||
"Turn on the quiet flag. Attempts to chown or chmod files do not return errors, although they fail. Use with caution!",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"rodir",
|
||||
"FAT has the ATTR_RO (read-only) attribute. On Windows, the ATTR_RO of the directory will just be ignored, and is used only by applications as a flag (e.g. it’s set for the customized folder). If you want to use ATTR_RO as read-only flag even for the directory, set this option.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"showexec",
|
||||
"If set, the execute permission bits of the file will be allowed only if the extension part of the name is .EXE, .COM, or .BAT. Not set by default.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"sys_immutable",
|
||||
"If set, ATTR_SYS attribute on FAT is handled as IMMUTABLE flag on Linux. Not set by default.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"flush",
|
||||
"If set, the filesystem will try to flush to disk more early than normal. Not set by default.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"usefree",
|
||||
"Use the \"free clusters\" value stored on FSINFO. It’ll be used to determine number of free clusters without scanning disk. But it’s not used by default, because recent Windows don’t update it correctly in some case. If you are sure the \"free clusters\" on FSINFO is correct, by this option you can avoid scanning disk.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"dots",
|
||||
"Various misguided attempts to force Unix or DOS conventions onto a FAT filesystem.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"nodots",
|
||||
"Various misguided attempts to force Unix or DOS conventions onto a FAT filesystem.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"dotsOK",
|
||||
"Various misguided attempts to force Unix or DOS conventions onto a FAT filesystem.",
|
||||
),
|
||||
}
|
54
common-documentation/filesystems/mountoptions/hfs.go
Normal file
54
common-documentation/filesystems/mountoptions/hfs.go
Normal file
@ -0,0 +1,54 @@
|
||||
package commondocumentation
|
||||
|
||||
import docvalues "config-lsp/doc-values"
|
||||
|
||||
var HfsDocumentationAssignable = map[docvalues.EnumString]docvalues.Value{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"creator",
|
||||
"Set the creator/type values as shown by the MacOS finder used for creating new files. Default values: '????'.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"type",
|
||||
"Set the creator/type values as shown by the MacOS finder used for creating new files. Default values: '????'.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"uid",
|
||||
"Set the owner and group of all files. (Default: the UID and GID of the current process.)",
|
||||
): docvalues.UIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"gid",
|
||||
"Set the owner and group of all files. (Default: the UID and GID of the current process.)",
|
||||
): docvalues.GIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"dir_umask",
|
||||
"Set the umask used for all directories. Defaults to the umask of the current process.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"file_umask",
|
||||
"Set the umask used for all regular files. Defaults to the umask of the current process.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"umask",
|
||||
"Set the umask used for all files and directories. Defaults to the umask of the current process.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"session",
|
||||
"Select the CDROM session to mount. Defaults to leaving that decision to the CDROM driver. This option will fail with anything but a CDROM as underlying device.",
|
||||
): docvalues.StringValue{},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"part",
|
||||
"Select partition number n from the device. Only makes sense for CDROMs. Defaults to not parsing the partition table at all.",
|
||||
// TODO: Probably NumberValue
|
||||
): docvalues.StringValue{},
|
||||
}
|
||||
|
||||
var HfsDocumentationEnums = []docvalues.EnumString{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"quiet",
|
||||
"Don't complain about invalid mount options.",
|
||||
),
|
||||
}
|
38
common-documentation/filesystems/mountoptions/hpfs.go
Normal file
38
common-documentation/filesystems/mountoptions/hpfs.go
Normal file
@ -0,0 +1,38 @@
|
||||
package commondocumentation
|
||||
|
||||
import docvalues "config-lsp/doc-values"
|
||||
|
||||
var HpfsDocumentationAssignable = map[docvalues.EnumString]docvalues.Value{
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"uid",
|
||||
"Set the owner and group of all files. (Default: the UID and GID of the current process.)",
|
||||
): docvalues.UIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"gid",
|
||||
"Set the owner and group of all files. (Default: the UID and GID of the current process.)",
|
||||
): docvalues.GIDValue{
|
||||
EnforceUsingExisting: true,
|
||||
},
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"umask",
|
||||
"Set the umask (the bitmask of the permissions that are not present). The default is the umask of the current process. The value is given in octal.",
|
||||
): docvalues.StringValue{},
|
||||
}
|
||||
|
||||
var HpfsDocumentationEnums = []docvalues.EnumString{
|
||||
// Move up to map
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"case",
|
||||
"Convert all files names to lower case, or leave them. (Default: case=lower.)",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"conv",
|
||||
"This option is obsolete and may fail or being ignored.",
|
||||
),
|
||||
docvalues.CreateEnumStringWithDoc(
|
||||
"nocheck",
|
||||
"Do not abort mounting when certain consistency checks fail.",
|
||||
),
|
||||
}
|
@ -269,4 +269,20 @@ var MountOptionsMapField = map[string]docvalues.Value{
|
||||
append(append(commondocumentation.Ext2DocumentationEnums, commondocumentation.Ext3DocumentationEnums...), commondocumentation.Ext4DocumentationEnums...),
|
||||
docvalues.MergeKeyEnumAssignmentMaps(commondocumentation.Ext2DocumentationAssignable, docvalues.MergeKeyEnumAssignmentMaps(commondocumentation.Ext3DocumentationAssignable, commondocumentation.Ext4DocumentationAssignable)),
|
||||
),
|
||||
"devpts": createMountOptionField(
|
||||
commondocumentation.DevptsDocumentationEnums,
|
||||
commondocumentation.DevptsDocumentationAssignable,
|
||||
),
|
||||
"fat": createMountOptionField(
|
||||
commondocumentation.FatDocumentationEnums,
|
||||
commondocumentation.FatDocumentationAssignable,
|
||||
),
|
||||
"hfs": createMountOptionField(
|
||||
commondocumentation.HfsDocumentationEnums,
|
||||
commondocumentation.HfsDocumentationAssignable,
|
||||
),
|
||||
"hpfs": createMountOptionField(
|
||||
commondocumentation.HpfsDocumentationEnums,
|
||||
commondocumentation.HpfsDocumentationAssignable,
|
||||
),
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user