summaryrefslogtreecommitdiff
path: root/solutions/21_macros
diff options
context:
space:
mode:
authormo8it <mo8it@proton.me>2024-07-05 13:39:50 +0200
committermo8it <mo8it@proton.me>2024-07-05 13:39:50 +0200
commit7123c7ae3a9605fbe962e4ef0a0f1424cd16fef8 (patch)
treec67f7e62bb9a179ae4fdbab492501cb6847e64c7 /solutions/21_macros
parent77b687d501771c24bd83294d97b8e6f9ffa92d6b (diff)
parent4d9c346a173bb722b929f3ea3c00f84954483e24 (diff)
Merge remote-tracking branch 'upstream/main' into fix-enum-variant-inconsistency
Diffstat (limited to 'solutions/21_macros')
-rw-r--r--solutions/21_macros/macros1.rs10
-rw-r--r--solutions/21_macros/macros2.rs10
-rw-r--r--solutions/21_macros/macros3.rs13
-rw-r--r--solutions/21_macros/macros4.rs15
4 files changed, 48 insertions, 0 deletions
diff --git a/solutions/21_macros/macros1.rs b/solutions/21_macros/macros1.rs
new file mode 100644
index 0000000..1b86156
--- /dev/null
+++ b/solutions/21_macros/macros1.rs
@@ -0,0 +1,10 @@
+macro_rules! my_macro {
+ () => {
+ println!("Check out my macro!");
+ };
+}
+
+fn main() {
+ my_macro!();
+ // ^
+}
diff --git a/solutions/21_macros/macros2.rs b/solutions/21_macros/macros2.rs
new file mode 100644
index 0000000..b6fd5d2
--- /dev/null
+++ b/solutions/21_macros/macros2.rs
@@ -0,0 +1,10 @@
+// Moved the macro definition to be before its call.
+macro_rules! my_macro {
+ () => {
+ println!("Check out my macro!");
+ };
+}
+
+fn main() {
+ my_macro!();
+}
diff --git a/solutions/21_macros/macros3.rs b/solutions/21_macros/macros3.rs
new file mode 100644
index 0000000..df35be4
--- /dev/null
+++ b/solutions/21_macros/macros3.rs
@@ -0,0 +1,13 @@
+// Added the attribute `macro_use` attribute.
+#[macro_use]
+mod macros {
+ macro_rules! my_macro {
+ () => {
+ println!("Check out my macro!");
+ };
+ }
+}
+
+fn main() {
+ my_macro!();
+}
diff --git a/solutions/21_macros/macros4.rs b/solutions/21_macros/macros4.rs
new file mode 100644
index 0000000..41bcad1
--- /dev/null
+++ b/solutions/21_macros/macros4.rs
@@ -0,0 +1,15 @@
+// Added semicolons to separate the macro arms.
+#[rustfmt::skip]
+macro_rules! my_macro {
+ () => {
+ println!("Check out my macro!");
+ };
+ ($val:expr) => {
+ println!("Look at this other macro: {}", $val);
+ };
+}
+
+fn main() {
+ my_macro!();
+ my_macro!(7777);
+}