2020-05-31 23:31:18 +03:00
--[[
Minecart
========
2021-05-14 19:50:16 +03:00
Copyright ( C ) 2019 - 2021 Joachim Stolberg
2020-05-31 23:31:18 +03:00
MIT
See license.txt for more information
] ] --
minecart.doc = { }
if not minetest.get_modpath ( " doc " ) then
return
end
local S = minecart.S
local summary_doc = table.concat ( {
S ( " Summary " ) ,
" ------------ " ,
" " ,
S ( " 1. Place your rails and build a route with two endpoints. Junctions are allowed as long as each route has its own start and endpoint. " ) ,
S ( " 2. Place a Railway Buffer at both endpoints (buffers are always needed, they store the route and timing information). " ) ,
S ( " 3. Give both Railway Buffers unique station names, like Oxford and Cambridge. " ) ,
2020-06-19 00:23:53 +03:00
S ( " 4. Place a Minecart at a buffer and give it a cart number (1..999) " ) ,
S ( " 5. Drive from buffer to buffer in both directions using the Minecart(!) to record the routes (use 'right-left' keys to control the Minecart). " ) ,
S ( " 6. Punch the buffers to check the connection data (e.g. 'Oxford: connected to Cambridge'). " ) ,
2021-05-14 19:50:16 +03:00
S ( " 7. Optional: Configure the Minecart waiting time in both buffers. The Minecart will then start automatically after the configured time. " ) ,
2020-06-19 00:23:53 +03:00
S ( " 8. Optional: Protect your rail network with the Protection Landmarks (one Landmark at least every 16 nodes/meters). " ) ,
S ( " 9. Place a Minecart in front of the buffer and check whether it starts after the configured time. " ) ,
S ( " 10. Check the cart state via the chat command: /mycart <num> \n '<num>' is the cart number " ) ,
2021-05-14 19:50:16 +03:00
S ( " 11. Drop items into the Minecart and punch the cart to start it. " ) ,
S ( " 12. Dig the cart with 'sneak+click' (as usual). The items will be drop down. " ) ,
2020-05-31 23:31:18 +03:00
} , " \n " )
2021-05-14 19:50:16 +03:00
local cart_doc = S ( " Primary used to transport items. You can drop items into the Minecart and punch the cart to get started. Sneak+click the cart to get cart and items back " )
2020-05-31 23:31:18 +03:00
local buffer_doc = S ( " Used as buffer on both rail ends. Needed to be able to record the cart routes " )
local landmark_doc = S ( " Protect your rails with the Landmarks (one Landmark at least every 16 blocks near the rail) " )
local hopper_doc = S ( " Used to load/unload Minecart. The Hopper can push/pull items to/from chests and drop/pickup items to/from Minecarts. To unload a Minecart place the hopper below the rail. To load the Minecart, place the hopper right next to the Minecart. " )
2021-05-14 19:50:16 +03:00
local pusher_doc = S ( [ [ If several carts are running on one route ,
it can happen that a buffer position is already occupied and one cart therefore stops earlier .
In this case , the cart pusher is used to push the cart towards the buffer again .
This block must be placed under the rail at a distance of 2 m in front of the buffer . ] ] )
local speed_doc = S ( [ [ Limit the cart speed with speed limit signs .
As before , the speed of the carts is also influenced by power rails .
Brake rails are irrelevant , the cart does not brake here .
The maximum speed is 8 m / s . This assumes a ratio of power rails
to normal rails of 1 to 4 on a flat section of rail . A rail section is a
series of rail nodes without a change of direction . After every curve / kink ,
the speed for the next section of the route is newly determined ,
taking into account the swing of the cart . This means that a cart can
roll over short rail sections without power rails .
In order to additionally brake the cart at certain points
( at switches or in front of a buffer ) , speed limit signs can be placed
on the track . With these signs the speed can be reduced to 4 , 2 , or 1 m / s .
The " No speed limit " sign can be used to remove the speed limit .
The speed limit signs must be placed next to the track so that they can
be read from the cart . This allows different speeds in each direction of travel . ] ] )
2020-05-31 23:31:18 +03:00
local function formspec ( data )
if data.image then
local image = " image[ " .. ( doc.FORMSPEC . ENTRY_WIDTH - 3 ) .. " ,0;3,2; " .. data.image .. " ] "
local formstring = doc.widgets . text ( data.text , doc.FORMSPEC . ENTRY_START_X , doc.FORMSPEC . ENTRY_START_Y + 1.6 , doc.FORMSPEC . ENTRY_WIDTH , doc.FORMSPEC . ENTRY_HEIGHT - 1.6 )
return image .. formstring
elseif data.item then
local box = " box[ " .. ( doc.FORMSPEC . ENTRY_WIDTH - 1.6 ) .. " ,0;1,1.1;#BBBBBB] "
local image = " item_image[ " .. ( doc.FORMSPEC . ENTRY_WIDTH - 1.5 ) .. " ,0.1;1,1; " .. data.item .. " ] "
local formstring = doc.widgets . text ( data.text , doc.FORMSPEC . ENTRY_START_X , doc.FORMSPEC . ENTRY_START_Y + 0.8 , doc.FORMSPEC . ENTRY_WIDTH , doc.FORMSPEC . ENTRY_HEIGHT - 0.8 )
return box .. image .. formstring
else
return doc.entry_builders . text ( data.text )
end
end
doc.add_category ( " minecart " ,
{
name = S ( " Minecart " ) ,
description = S ( " Minecart, the lean railway transportation automation system " ) ,
sorting = " custom " ,
sorting_data = { " summary " , " cart " } ,
build_formspec = formspec ,
} )
doc.add_entry ( " minecart " , " summary " , {
name = S ( " Summary " ) ,
data = { text = summary_doc , image = " minecart_doc_image.png " } ,
} )
doc.add_entry ( " minecart " , " cart " , {
name = S ( " Minecart Cart " ) ,
data = { text = cart_doc , item = " minecart:cart " } ,
} )
doc.add_entry ( " minecart " , " buffer " , {
name = S ( " Minecart Railway Buffer " ) ,
data = { text = buffer_doc , item = " minecart:buffer " } ,
} )
doc.add_entry ( " minecart " , " landmark " , {
name = S ( " Minecart Landmark " ) ,
data = { text = landmark_doc , item = " minecart:landmark " } ,
} )
2021-05-14 19:50:16 +03:00
doc.add_entry ( " minecart " , " speed signs " , {
name = S ( " Minecart Speed Signs " ) ,
data = { text = speed_doc , item = " minecart:speed4 " } ,
} )
doc.add_entry ( " minecart " , " cart pusher " , {
name = S ( " Cart Pusher " ) ,
data = { text = pusher_doc , item = " minecart:cart_pusher " } ,
} )
2020-05-31 23:31:18 +03:00
if minecart.hopper_enabled then
doc.add_entry ( " minecart " , " hopper " , {
name = S ( " Minecart Hopper " ) ,
data = { text = hopper_doc , item = " minecart:hopper " } ,
} )
end