lwscratch/readme.txt
2021-04-05 06:29:31 +10:00

433 lines
12 KiB
Plaintext

LWScratch
by loosewheel
Licence
=======
Code licence:
LGPL 2.1
Media licence:
CC-BY-SA 3.0
Version
=======
0.1.4
Minetest Version
================
This mod was developed on version 5.4.0
Dependencies
============
default
lwdrops
Optional Dependencies
=====================
intllib
Installation
============
Copy the 'lwscratch' folder to your mods folder.
Bug Report
==========
https://forum.minetest.net/viewtopic.php?f=9&t=26455
Description
===========
This mod provides scratch programmable robots.
The first time a robot is placed in the world a form opens asking the
player that placed it, if the machine is public or private. If private is
selected, the player becomes the owner and other players (except those
with protection_bypass privilege) cannot access it.
The persistence button toggles on and off. If persistence is on, the block
the robot is in remains loaded when out of range. This persistence is
retained across world startups. Robots retain their persistence state when
moved. The maximum force loaded blocks is limited to the
max_forceloaded_blocks setting (default is 16).
Each robot can be given a name, by entering the name in the Robot field and
clicking the Set button. The name will display when the robot is pointed
at or as the tool tip if it is in an inventory.
Each robot has a storage area (center right).
While a robot is running sneak + punch will open a form to stop it.
Robots are programmed graphically, by dragging a command from a pallet
(top right) to the program sheet (left). Items can be dragged from the
inventories. These are only markers, the item is not used. To remove an
item from the program sheet, drag it to an empty space in the command pallet.
To clear the whole program click the clear button. Commands are run in order,
left to right per line, then down the lines.
Block delimiting (for loop and if) is by indenting. When a following line
is indented to the same level or less, this marks the end of the block.
To run the program click the power button. If the program has an error a
red message below the program sheet details the error.
See lwscratch.pdf in docs folder.
Command items are color coded by type:
Orange - Statement, controls program flow.
Green - Value, represents a given value.
Yellow - Condition, results as true or false.
Blue - Action, performs an action of some kind.
White - Sheet action, used to edit the program sheet.
Working with variables:
All variable items, whether they are values, conditions or actions, must
be given a name. Set the name by placing it in the top slot, entering the
name in the Value field and clicking Set. All variable items with the same
name are the same variable value, whether being set with a value, testing
or using its value.
Statements:
Loop
Followed by a condition which evaluates to true or false. The following
lines of commands indented greater than the loop statement will run
repeatedly until the condition is false.
Each loop has an internal counter, which starts at zero and increments
by one every iteration.
If
Followed by a condition which evaluates to true or false. The following
lines of commands indented greater than the if statement will run once
if the condition is true.
Values:
Number
Can be set with a number value. To set the value, place it in the value
slot at the top, enter the desired value in the Value field and click
the Set button. Hovering over the number item, the tool tip displays its
current value.
Text
Can be set with a text value. To set the value, place it in the value
slot at the top, enter the desired value in the Value field and click
the Set button. Hovering over the text item, the tool tip displays its
current value.
Variable
Can be set with a name. To set the name, place it in the value slot at
the top, enter the desired name in the Value field and click the Set
button. Hovering over the variable item, the tool tip displays its
current name.
Name
Variants - up, down, forward, forward up, forward down, back, back up,
back down.
Is the name of the node in the relevant direction. If no node is there
it is blank text.
Conditions:
Counter
Variants - is equal to, is less than, is greater than.
Followed by a number or variable item, and results in true if the loop's
counter is equal to|less than|greater than the number.
*Outside of a loop the counter is always zero.
Counter is even
Results in true if the counter is currently an even number.
Counter is odd
Results in true if the counter is currently an odd number.
Variable is equal to
If followed by a number, text, variable or name item
Results in true if the variable is equal to than the following value.
If followed by inventory item
Results in true if the variables value equals the item's name.
*Must be set with a name in the top slot.
Variable is less than
Followed by a number or variable, and results in true if the variable
is less than than the following value.
*Must be set with a name in the top slot.
Variable is greater than
Followed by a number or variable, and results in true if the variable
is greater than the following value.
*Must be set with a name in the top slot.
Variable is even
Results in true if the variable is currently an even number.
*Must be set with a name in the top slot.
Variable is odd
Results in true if the variable is currently an odd number.
*Must be set with a name in the top slot.
Detect
Variants - up, down, forward, forward up, forward down, back, back up,
back down.
If followed by an inventory item
True if the node in the relevant direction match the inventory item.
If followed by a text or variable item
True if the node in the relevant direction match the text or
variable's value.
If followed by a blank space
True if there is any node in the relevant direction.
Contains item
If followed by an inventory item
True if the robot's storage contains at least one of the inventory item.
If followed by a text or variable item
True if robot's storage contains at least one of the inventory items
named in the text or variable's value.
If followed by a blank space
True if the robot's storage contains anything at all.
Item fits
If followed by an inventory item
True if one of the inventory item can fit in the robot's storage.
If followed by a text or variable item
True if one of the inventory item named in the text or variable's
value can fit in the robot's storage.
If followed by a blank space
True if the robot's storage has at least one empty slot (can fit
anything).
Not
Inverts the next condition result (true to false, or false to true).
And
Placed between two conditions and is true only if both the left and
right conditions are true.
Or
Placed between two conditions and is true if either the left or right
(or both) condition is true.
Actions:
Move
Variants - forward, backward, up, down.
Moves one node in the relevant direction, if nothing is there.
Turn
Variants - left, right.
Turns 90 degrees in the relevant direction.
Dig
Variants - up, down, forward, forward up, forward down, back, back up,
back down.
Digs the node in the relevant direction, if there is anything there.
If dug node is placed in the robot's storage if there is room, otherwise
it is dropped.
Place
Variants - up, down, forward, forward up, forward down, back, back up,
back down.
If followed by an inventory item
Places the given inventory item in the relevant direction if there
is nothing at that position.
If followed by a text or variable item
Places the inventory item named in the text or variable's value
in the relevant direction if there is nothing at that position.
*The item must be in the robot's storage.
Pull
If followed by an inventory item
Moves one of the given inventory items from an inventory (chest)
immediately in front of the robot, into the robot's storage if it
can fit.
If followed by a text or variable item
Moves one of the inventory items named in the text or variable's value
from an inventory (chest) immediately in front of the robot, into
the robot's storage if it can fit.
If followed by a blank space
Moves everything from an inventory (chest) immediately in front of
the robot, into the robot's storage or as much as can fit.
Put
If followed by an inventory item
Moves one of the given inventory items from the robot's storage into
an inventory (chest) immediately in front of the robot, if it can
fit.
If followed by a text or variable item
Moves one of the inventory items named in the text or variable's value
from the robot's storage into an inventory (chest) immediately in
front of the robot, if it can fit.
If followed by a blank space
Moves everything from the robot's storage into an inventory (chest)
immediately in front of the robot, or as much as can fit.
Drop
If followed by an inventory item
Drops one of the given inventory items from the robot's storage into
the world, if it contains one.
If followed by a text or variable item
Drops one of the inventory items named in the text or variable's value
from the robot's storage into the world, if it contains one.
If followed by a blank space
Drops everything from the robot's storage into the world.
Trash
If followed by an inventory item
Destroys (gone forever) one of the given inventory items in the
robot's storage, if it contains one.
If followed by a text or variable item
Destroys (gone forever) one of the inventory items named in the text
or variable's value in the robot's storage, if it contains one.
If followed by a blank space
Destroys (gone forever) everything in the robot's storage.
Craft
If followed by an inventory item
Crafts the given inventory item. The materials for the craft must
be in the robot's storage.
If followed by a text or variable item
Crafts the inventory item named in the text or variable's value.
The materials for the craft must be in the robot's storage.
Wait
Followed by a number or variable item. Pauses the robot's program by
the number value in tenths of a second (10 = 1 second pause).
Stop
Stops the robot's program.
Variable assign
If followed by a name
Assigns the node name in the given direction to this variable.
If followed by a number, text or variable
Assigns the value in the following number, text or variable to this
variable.
If followed by inventory item
Assigns the name of the inventory item to this variable.
*The variable must be named.
Variable plus
If followed by a name
Adds the node name in the given direction to the end of this variable's
current value.
If followed by a number, text or variable
If either of the values are text, adds the following value to the end
of this variable's current value. Otherwise adds, as numbers, the
two values and assigns the result to this variable.
*The variable must be named.
Variable minus
Followed by a number or variable. Subtracts the following value from
this variables value and assigns the result to this variable.
*The variable must be named.
Variable multiply
Followed by a number or variable. Multiplies the following value with
this variables value and assigns the result to this variable.
*The variable must be named.
Variable divide
Followed by a number or variable. Divides this variables value by the
following value and assigns the result to this variable.
*The variable must be named.
Sheet actions:
Insert line
Inserts a line in the program sheet where it is dropped. The last line
of the sheet is lost.
Remove line
Removes a line in the program sheet where it is dropped. The removed
line of the sheet is lost.
The mod supports the following settings:
Running interval seconds (float)
Seconds interval between running ticks.
Default: 0.1
Robot's action delay (float)
Delay (wait) in seconds for a robot's action. Enforced minimum of 0.1
seconds.
Default: 0.2
Robot's movement delay (float)
Delay (wait) in seconds for a robot's movement. Enforced minimum of 0.1
seconds.
Default: 0.5
* The file 'place_substitute.lua' in the mod folder contains a list of
item/node substitutes, useful for farming etc. Modify this file for
additional substitutes. The field name is the item/node to be
substituted. The value is what it is substituted with.
* The file 'crafting_mods.lua' in the mod folder contains a list of
crafting modifications. Modify this file as necessary. The field name
is the item being crafted. Each item in the add list is added to the
robot's storage. Each item in the remove list is removed from the
robot's storage.
------------------------------------------------------------------------