2015-09-25 19:38:44 +03:00
|
|
|
---
|
|
|
|
title: Node Metadata
|
|
|
|
layout: default
|
2018-07-15 21:36:35 +03:00
|
|
|
root: ../..
|
2018-07-15 17:28:10 +03:00
|
|
|
idx: 3.3
|
|
|
|
description: Using get_meta to obtain a NodeMetaRef.
|
2018-07-15 21:13:16 +03:00
|
|
|
redirect_from: /en/chapters/node_metadata.html
|
2015-09-25 19:38:44 +03:00
|
|
|
---
|
|
|
|
|
|
|
|
## Introduction
|
|
|
|
|
|
|
|
In this chapter you will learn how to manipulate a node's metadata.
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
* [What is Node Metadata?](#what-is-node-medadata)
|
|
|
|
* [Getting a Metadata Object](#getting-a-metadata-object)
|
|
|
|
* [Reading Metadata](#reading-metadata)
|
|
|
|
* [Setting Metadata](#setting-metadata)
|
|
|
|
* [Lua Tables](#lua-tables)
|
|
|
|
* [Infotext](#infotext)
|
|
|
|
* [Your Turn](#your-turn)
|
2015-09-25 19:38:44 +03:00
|
|
|
|
|
|
|
## What is Node Metadata?
|
|
|
|
|
|
|
|
Metadata is data about data. So Node Metadata is **data about a node**.
|
|
|
|
|
|
|
|
You may use metadata to store:
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
* A node's inventory (such as in a chest).
|
|
|
|
* Progress on crafting (such as in a furnace).
|
|
|
|
* Who owns the node (such as the owner of a locked chest).
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
The node's type, light levels, and orientation are not stored in the metadata.
|
|
|
|
These are part of the data itself.
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
Metadata is stored in a key value relationship. For example:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
|
|
|
| Key | Value |
|
|
|
|
|---------|---------|
|
|
|
|
| foo | bar |
|
|
|
|
| owner | player1 |
|
|
|
|
| counter | 5 |
|
|
|
|
|
|
|
|
## Getting a Metadata Object
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
If you know the position of a node, you can retrieve its metadata:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2015-09-25 19:38:44 +03:00
|
|
|
local meta = minetest.get_meta(pos)
|
|
|
|
-- where pos = { x = 1, y = 5, z = 7 }
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2015-09-25 19:38:44 +03:00
|
|
|
|
|
|
|
## Reading Metadata
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
After retrieving the metadata, you can read its values:
|
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2015-09-25 19:38:44 +03:00
|
|
|
local value = meta:get_string("key")
|
|
|
|
|
|
|
|
if value then
|
2017-08-26 21:01:51 +03:00
|
|
|
print(value)
|
2015-09-25 19:38:44 +03:00
|
|
|
else
|
2017-08-26 21:01:51 +03:00
|
|
|
-- value == nil
|
|
|
|
-- metadata of key "key" does not exist
|
|
|
|
print(value)
|
2015-09-25 19:38:44 +03:00
|
|
|
end
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
The functions available include:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
|
|
|
* get_string
|
|
|
|
* get_int
|
|
|
|
* get_float
|
|
|
|
* get_inventory
|
|
|
|
|
2018-07-16 01:04:55 +03:00
|
|
|
To get a Boolean, you should use `get_string` and `minetest.is_yes`:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2015-09-25 19:38:44 +03:00
|
|
|
local value = minetest.is_yes(meta:get_string("key"))
|
|
|
|
|
|
|
|
if value then
|
2017-08-26 21:01:51 +03:00
|
|
|
print("is yes")
|
2015-09-25 19:38:44 +03:00
|
|
|
else
|
2017-08-26 21:01:51 +03:00
|
|
|
print("is no")
|
2015-09-25 19:38:44 +03:00
|
|
|
end
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2015-09-25 19:38:44 +03:00
|
|
|
|
|
|
|
## Setting Metadata
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
You can set node metadata. For example:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2015-09-25 19:38:44 +03:00
|
|
|
local value = "one"
|
|
|
|
meta:set_string("key", value)
|
|
|
|
|
|
|
|
meta:set_string("foo", "bar")
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
This can be done using the following functions:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
|
|
|
* set_string
|
|
|
|
* set_int
|
|
|
|
* set_float
|
|
|
|
|
|
|
|
## Lua Tables
|
|
|
|
|
2018-07-16 01:04:55 +03:00
|
|
|
You can convert to and from Lua tables using `to_table` and `from_table`:
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2015-09-25 19:38:44 +03:00
|
|
|
local tmp = meta:to_table()
|
|
|
|
tmp.foo = "bar"
|
|
|
|
meta:from_table(tmp)
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2015-09-25 19:38:44 +03:00
|
|
|
|
2015-09-25 19:42:46 +03:00
|
|
|
## Infotext
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
The Minetest engine reads the field `infotext` to make text
|
|
|
|
appear on mouse-over. This is used by furnaces to show progress and by signs
|
|
|
|
to show their text. For example:
|
2015-09-25 19:42:46 +03:00
|
|
|
|
2018-09-19 14:04:51 +03:00
|
|
|
```lua
|
2017-09-18 17:42:13 +03:00
|
|
|
meta:set_string("infotext", "Here is some text that will appear on mouse-over!")
|
2018-09-19 14:04:51 +03:00
|
|
|
```
|
2015-09-25 19:42:46 +03:00
|
|
|
|
2015-09-25 19:38:44 +03:00
|
|
|
## Your Turn
|
|
|
|
|
2017-09-18 17:42:13 +03:00
|
|
|
* Make a node which disappears after it has been punched five times.
|
|
|
|
(Use `on_punch` in the node definition and `minetest.set_node`.)
|