-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathdoc.lua
91 lines (79 loc) · 4.82 KB
/
doc.lua
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
castle_gates.doc = {}
if not minetest.get_modpath("doc") then
return
end
local S = minetest.get_translator("castle_gates")
castle_gates.doc.portcullis_bars_longdesc = S("Heavy wooden bars designed to prevent entry even to siege equipment.")
castle_gates.doc.portcullis_bars_usagehelp = S(
"Place these bars in a structure together and they will slide as a unified gate when clicked on."
)
castle_gates.doc.portcullis_bars_bottom_longdesc = S(
"The bottom edge of a portcullis gate, with knobs to lock securely into the floor."
)
castle_gates.doc.portcullis_bars_bottom_usagehelp = S(
"This block can be used to define the edge of a portcullius that meets up with another gate, should you have " ..
"an arrangement like that. Otherwise it's just decorative."
)
castle_gates.doc.gate_panel_longdesc = S("A basic gate panel.")
castle_gates.doc.gate_panel_usagehelp = S(
"This gate segment will move in unison with adjoining gate segments when right-clicked."
)
castle_gates.doc.gate_edge_longdesc = S("A gate panel with a defined edge.")
castle_gates.doc.gate_edge_usagehelp = S(
"The darkened edge of this panel marks the edge of the gate it's a part of. " ..
"You can use these when building double doors to ensure the two parts swing separately, " ..
"for example. Note that edges aren't strictly necessary for gates that stand alone."
)
castle_gates.doc.gate_edge_handle_longdesc = S("A gate edge with a handle.")
castle_gates.doc.gate_edge_handle_usagehelp = S(
"The handle is basically decorative, a door this size can be swung by clicking anywhere on it. " ..
"But the darkened edge of this panel is useful for defining the edge of a gate when it abuts a partner to the side."
)
castle_gates.doc.gate_hinge_longdesc = S("A hinged gate segment that allows a gate to swing.")
castle_gates.doc.gate_hinge_usagehelp = S(
"If you have more than one hinge in your gate, make sure the hinges line up correctly otherwise the gate will " ..
"not be able to swing. The hinge is the protruding block along the edge of the gate panel."
)
castle_gates.doc.gate_slot_longdesc = S("A block with a slot to allow an adjacent sliding gate through.")
castle_gates.doc.gate_slot_usagehelp = S(
"This block is designed to extend into a neighboring node that a sliding gate passes through, to provide a " ..
"tight seal for the gate to move through without allowing anything else to squeeze in."
)
castle_gates.doc.gate_slot_reverse_longdesc = S(
"A block that extends into an adjacent node to provide a tight seal for a large gate."
)
castle_gates.doc.gate_slot_reverse_usagehelp = S(
"Two nodes cannot occupy the same space, but this block extends into a neighboring node's space to allow " ..
"for gates to form a tight seal. It can be used with sliding gates or swinging gates."
)
doc.add_category("castle_gates",
{
name = S("Gates"),
description = S(
"Gates are large multi-node constructions that swing on hinges or slide out of the way when triggered."
),
build_formspec = doc.entry_builders.text_and_gallery,
})
doc.add_entry("castle_gates", "construction", {
name = S("Gate construction"),
data = {text = S(
"Gates are multi-node constructions, usually (though not always) consisting of multiple node types that fit " ..
"together into a unified whole. The orientation of gate nodes is significant, so a screwdriver will be a " ..
"helpful tool when constructing gates.\n\n" ..
"A gate's extent is determined by a \"flood fill\" operation. When you trigger a gate block, all compatible " ..
"neighboring blocks will be considered part of the same structure and will move in unison. Only gate blocks " ..
"that are aligned with each other will be considered part of the same gate. If you wish to build adjoining " ..
"gates (for example, a large pair of double doors that meet in the center) you'll need to make use of gate " ..
"edge blocks to prevent it all from being considered one big door. Note that if your gate does not abut any" ..
" other gates you don't actually need to define its edges this way - you don't have to use edge blocks in " ..
"this case.\n\n" ..
"If a gate has no hinge nodes it will be considered a sliding gate. When triggered, the gate code will " ..
"search for a direction that the gate can slide in and will move it in that direction at a rate of one " ..
"block-length per second. Once it reaches an obstruction it will stop, and when triggered again it will " ..
"try sliding in the opposite direction.\n\n" ..
"If a gate has hinge nodes then triggering it will cause the gate to try swinging around the hinge. " ..
"If the gate has multiple hinges and they don't line up properly the gate will be unable to move. " ..
"Note that the gate can only exist in 90-degree increments of orientation, but the gate still looks for " ..
"obstructions in the region it is swinging through and will not swing if there's something in the way."
)}
})