Difference between revisions of "Directory Standards"

From GnuCash
Jump to: navigation, search
(Overlaps with Configuration Locations)
m (Appearence)
 
(4 intermediate revisions by 2 users not shown)
Line 9: Line 9:
 
The [https://en.wikipedia.org/wiki/Filesystem_Hierarchy_Standard Filesystem Hierarchy Standard] (FHS) defines the general directory layout of a '''computer system'''. It is currently maintained by [https://wiki.linuxfoundation.org/ The Linux Foundation] at https://wiki.linuxfoundation.org/lsb/fhs. Before it was at http://www.pathname.com/fhs/ maintained by  the ''Linux Standard Base'' (LSB) workgroup of freestandards.org.
 
The [https://en.wikipedia.org/wiki/Filesystem_Hierarchy_Standard Filesystem Hierarchy Standard] (FHS) defines the general directory layout of a '''computer system'''. It is currently maintained by [https://wiki.linuxfoundation.org/ The Linux Foundation] at https://wiki.linuxfoundation.org/lsb/fhs. Before it was at http://www.pathname.com/fhs/ maintained by  the ''Linux Standard Base'' (LSB) workgroup of freestandards.org.
 
The different BSD variants are no longer part. They use only <Syntaxhighlight lang="sh">man hier(7)</Syntaxhighlight>.
 
The different BSD variants are no longer part. They use only <Syntaxhighlight lang="sh">man hier(7)</Syntaxhighlight>.
 +
GnuCash tried ''always'' to conform this standard.
  
 
===XDG===
 
===XDG===
Line 26: Line 27:
 
| $XDG_CONFIG_DIRS
 
| $XDG_CONFIG_DIRS
 
| /etc/xdg
 
| /etc/xdg
| the colon ':' seperated preference-ordered set of base directories to search for configuration files ''in addition to $XDG_CONFIG_HOME''
+
| the colon <code>:</code> separated preference-ordered set of base directories to search for configuration files ''in addition to $XDG_CONFIG_HOME''
  
 
|- style="vertical-align:top;"
 
|- style="vertical-align:top;"
Line 36: Line 37:
 
| $XDG_DATA_DIRS
 
| $XDG_DATA_DIRS
 
| usr/local/share/:/usr/share/
 
| usr/local/share/:/usr/share/
| the colon ':' seperated preference-ordered set of base directories to search for data files ''in addition to $XDG_DATA_HOME''
+
| the colon <code>:</code> separated preference-ordered set of base directories to search for data files ''in addition to $XDG_DATA_HOME''
  
 
|- style="vertical-align:top;"
 
|- style="vertical-align:top;"
Line 49: Line 50:
 
|}
 
|}
 
Partly the home directory uses similar subdirectories as the system has, some with the same name like <code>/usr/share</code> vs. <code>~/.share</code>, others with a different name like <code>/etc</code> vs. <code>~/.config</code>. This will allow among others a ''fallback'': if no value is found in <tt>~/.config</tt> check <tt>/etc</tt> for the system wide default.
 
Partly the home directory uses similar subdirectories as the system has, some with the same name like <code>/usr/share</code> vs. <code>~/.share</code>, others with a different name like <code>/etc</code> vs. <code>~/.config</code>. This will allow among others a ''fallback'': if no value is found in <tt>~/.config</tt> check <tt>/etc</tt> for the system wide default.
 +
:With '''GnuCash 3.0''' this standard was adapted.
  
 
==MS-DOS based==
 
==MS-DOS based==
The [https://msdn.microsoft.com/en-us/library/windows/desktop/dd378457(v=vs.85).aspx KNOWNFOLDERID]s replaced in ''Vista'' the former [https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494(v=vs.85).aspx constant special item ID list] (CSIDL).
+
;Since Windows Vista:The [https://msdn.microsoft.com/en-us/library/windows/desktop/dd378457(v=vs.85).aspx KNOWNFOLDERID]s replaced the former [https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494(v=vs.85).aspx constant special item ID list] (CSIDL).
 
.
 
.

Latest revision as of 14:12, 3 July 2023

This is a short overview of standards for directories.

TODO: Overlaps with Configuration Locations.

Unix based

There are 2 important standards, which have their own scope:

FHS

The Filesystem Hierarchy Standard (FHS) defines the general directory layout of a computer system. It is currently maintained by The Linux Foundation at https://wiki.linuxfoundation.org/lsb/fhs. Before it was at http://www.pathname.com/fhs/ maintained by the Linux Standard Base (LSB) workgroup of freestandards.org.

The different BSD variants are no longer part. They use only
man hier(7)
.

GnuCash tried always to conform this standard.

XDG

The former X Desktop Group is today known as Freedesktop.org. Its XDG Base Directory Specification defines some rules for the home directory.

XDG variable Default Notes
$XDG_CONFIG_HOME $HOME/.config the base directory relative to which user specific configuration files should be stored.
$XDG_CONFIG_DIRS /etc/xdg the colon : separated preference-ordered set of base directories to search for configuration files in addition to $XDG_CONFIG_HOME
$XDG_DATA_HOME $HOME/.local/share the base directory relative to which user specific data files should be stored.
$XDG_DATA_DIRS usr/local/share/:/usr/share/ the colon : separated preference-ordered set of base directories to search for data files in addition to $XDG_DATA_HOME
$XDG_CACHE_HOME $HOME/.cache the base directory relative to which user specific non-essential data files should be stored.
$XDG_RUNTIME_DIR If it is not set applications should fall back to a replacement directory with similar capabilities and print a warning message. Applications should use this directory for communication and synchronization purposes and should not place larger files in it, since it might reside in runtime memory and cannot necessarily be swapped out to disk...

Partly the home directory uses similar subdirectories as the system has, some with the same name like /usr/share vs. ~/.share, others with a different name like /etc vs. ~/.config. This will allow among others a fallback: if no value is found in ~/.config check /etc for the system wide default.

With GnuCash 3.0 this standard was adapted.

MS-DOS based

Since Windows Vista
The KNOWNFOLDERIDs replaced the former constant special item ID list (CSIDL).

.