From 714aacf1ca410cf5e065bedf26e60f06ef5e5e13 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Moritz=20H=C3=B6lting?= <87192362+moritz-hoelting@users.noreply.github.com> Date: Wed, 3 Apr 2024 13:57:24 +0200 Subject: [PATCH] Add If/Else Statements and Logical Operators documentation --- src/content/docs/reference/conditionals.md | 49 ++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 src/content/docs/reference/conditionals.md diff --git a/src/content/docs/reference/conditionals.md b/src/content/docs/reference/conditionals.md new file mode 100644 index 0000000..51a42d9 --- /dev/null +++ b/src/content/docs/reference/conditionals.md @@ -0,0 +1,49 @@ +--- +title: If/Else Statements +description: Reference for Conditionals +--- + +If/Else statements are used to execute code based on a condition. If the condition is true, the code inside the `if` block is executed. If the condition is false, the code inside the `else` block is executed. + +```shulkerscript +if ("block ~ ~-1 ~ minecraft:grass_block") { + /say The block below is grass! +} else { + /say The block below is not grass! +} +``` + +The else block is optional. If it is not present, the code inside the if block will be executed if the condition is true, and nothing will be executed if the condition is false. + +```shulkerscript +if ("block ~ ~-1 ~ minecraft:grass_block") { + /say The block below is grass! +} +``` + +## Logical Operators + +Logical operators can be used to combine multiple conditions. The following logical operators are supported: +- `&&` (and): Returns true if both conditions are true. +- `||` (or): Returns true if at least one condition is true. +- `!` (not): Returns true if the condition is false. + +```shulkerscript +if ("block ~ ~-1 ~ minecraft:grass_block" && "block ~ ~-2 ~ minecraft:dirt") { + /say The block below is grass and the block below that is dirt! +} +if ("block ~ ~-1 ~ minecraft:grass_block" || "block ~ ~-1 ~ minecraft:dirt") { + /say The block below is grass or the block below is dirt! +} +if (!"block ~ ~-1 ~ minecraft:grass_block") { + /say The block below is not grass! +} +``` + +By default, the `!` operator has the highest precedence, followed by `&&`, and then `||`. Parentheses can be used to change the order of operations. + +```shulkerscript +if (!("block ~ ~-1 ~ minecraft:grass_block" && "block ~ ~-2 ~ minecraft:dirt")) { + /say This is not true: the block below is grass and the block below that is dirt! +} +``` \ No newline at end of file