diff options
author | Sean Whitton <spwhitton@spwhitton.name> | 2021-03-12 14:20:48 -0700 |
---|---|---|
committer | Sean Whitton <spwhitton@spwhitton.name> | 2021-03-15 17:18:39 -0700 |
commit | 7168d66878406fcebb2c2df0f41cddcbcc077861 (patch) | |
tree | cbb317b37303696783fedc7dd6e2abd066251958 /doc/connections.rst | |
parent | 06a3b2457bf1524a318b3fcaeb35e00bf510ee20 (diff) | |
download | consfigurator-7168d66878406fcebb2c2df0f41cddcbcc077861.tar.gz |
define connection chain specifications
Signed-off-by: Sean Whitton <spwhitton@spwhitton.name>
Diffstat (limited to 'doc/connections.rst')
-rw-r--r-- | doc/connections.rst | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/doc/connections.rst b/doc/connections.rst index 88674c9..e14aa82 100644 --- a/doc/connections.rst +++ b/doc/connections.rst @@ -1,6 +1,37 @@ Connections =========== +Connection chain specifications +------------------------------- + +The normalised form is a list of lists, where the car of each inner list is a +keyword symbol identifying a connection type, and the cdr of each inner list +is arguments to that connection, e.g.:: + + ((:ssh :foo foo :bar bar) (:sudo :baz baz :quux quux)) + +There are two notational simplifications permitted when passing connection +chain specifications to properties, functions and macros. Firstly, for each +inner list which contains only a single keyword identifying a connection type +and no arguments, this list may be replaced with only the keyword identifying +the connection type, e.g.:: + + (:ssh (:sudo :baz baz :quux quux)) + +Secondly, when there is exactly one connection and it takes no arguments, you +may specify just the keyword identifying the connection type, e.g. ``:ssh``. + +Note that if there is a single connection but it takes arguments, you will +need two sets of parentheses, i.e.:: + + ((:ssh :foo foo :bar bar)) + +rather than:: + + (:ssh :foo foo :bar bar) + +which is invalid. + Defining connection types ------------------------- |