Attention: Here be dragons
This is the latest
(unstable) version of this documentation, which may document features
not available in or compatible with released stable versions of Godot.
Checking the stable version of the documentation...
ConfigFile¶
Clase de ayuda para manejar los archivos de tipo INI.
Descripción¶
This helper class can be used to store Variant values on the filesystem using INI-style formatting. The stored values are identified by a section and a key:
[section]
some_key=42
string_example="Hello World!"
a_vector=Vector3( 1, 0, 2 )
The stored data can be saved to or parsed from a file, though ConfigFile objects can also be used directly without accessing the filesystem.
The following example shows how to create a simple ConfigFile
and save it on disk:
# Create new ConfigFile object.
var config = ConfigFile.new()
# Store some values.
config.set_value("Player1", "player_name", "Steve")
config.set_value("Player1", "best_score", 10)
config.set_value("Player2", "player_name", "V3geta")
config.set_value("Player2", "best_score", 9001)
# Save it to a file (overwrite if already exists).
config.save("user://scores.cfg")
This example shows how the above file could be loaded:
var score_data = {}
var config = ConfigFile.new()
# Load data from a file.
var err = config.load("user://scores.cfg")
# If the file didn't load, ignore it.
if err != OK:
return
# Iterate over all sections.
for player in config.get_sections():
# Fetch the data for each section.
var player_name = config.get_value(player, "player_name")
var player_score = config.get_value(player, "best_score")
score_data[player_name] = player_score
Any operation that mutates the ConfigFile such as set_value, clear, or erase_section, only changes what is loaded in memory. If you want to write the change to a file, you have to save the changes with save, save_encrypted, or save_encrypted_pass.
Keep in mind that section and property names can't contain spaces. Anything after a space will be ignored on save and on load.
ConfigFiles can also contain manually written comment lines starting with a semicolon (;
). Those lines will be ignored when parsing the file. Note that comments will be lost when saving the ConfigFile. This can still be useful for dedicated server configuration files, which are typically never overwritten without explicit user action.
Note: The file extension given to a ConfigFile does not have any impact on its formatting or behavior. By convention, the .cfg
extension is used here, but any other extension such as .ini
is also valid. Since neither .cfg
nor .ini
are standardized, Godot's ConfigFile formatting may differ from files written by other programs.
Métodos¶
void |
clear ( ) |
void |
erase_section ( String section ) |
void |
erase_section_key ( String section, String key ) |
get_section_keys ( String section ) const |
|
get_sections ( ) const |
|
get_value ( String section, String key, Variant default=null ) const |
|
has_section ( String section ) const |
|
has_section_key ( String section, String key ) const |
|
load_encrypted ( String path, PoolByteArray key ) |
|
load_encrypted_pass ( String path, String password ) |
|
save_encrypted ( String path, PoolByteArray key ) |
|
save_encrypted_pass ( String path, String password ) |
|
void |
Descripciones de Métodos¶
void clear ( )
Removes the entire contents of the config.
void erase_section ( String section )
Borra la sección especificada junto con todos los pares clave-valor que hay dentro. Provoca un error si la sección no existe.
Borra la clave especificada en una sección. Provoca un error si la sección o la clave no existen.
PoolStringArray get_section_keys ( String section ) const
Devuelve un array de todos los identificadores clave definidos en la sección especificada. Levanta un error y devuelve un array vacío si la sección no existe.
PoolStringArray get_sections ( ) const
Devuelve un array de todos los identificadores de sección definidos.
Devuelve el valor actual de la sección y la clave especificadas. Si la sección o la clave no existen, el método devuelve el valor de reserva default
. Si no se especifica default
o se establece en null
, también se produce un error.
Devuelve true
si existe la sección especificada.
Devuelve true
si existe el par de claves de lasección especificada.
Carga el archivo de configuración especificado como parámetro. El contenido del archivo es analizado y cargado en el objeto ConfigFile
al que se llamó el método.
Devuelve una de las constantes de código Error (OK
en caso de éxito).
Error load_encrypted ( String path, PoolByteArray key )
Carga el archivo de configuración cifrado especificado como parámetro, utilizando la clave
proporcionada para descifrarlo. El contenido del archivo es analizado y cargado en el objeto ConfigFile
al que el método fue llamado.
Devuelve una de las constantes de código Error (OK
en caso de éxito).
Carga el archivo de configuración cifrado especificado como parámetro, utilizando la password
proporcionado para descifrarlo. El contenido del archivo es analizado y cargado en el objeto ConfigFile
al que el método fue llamado.
Devuelve una de las constantes de código Error (OK
en caso de éxito).
Parses the passed string as the contents of a config file. The string is parsed and loaded in the ConfigFile object which the method was called on.
Returns one of the Error code constants (OK
on success).
Guarda el contenido del objeto ConfigFile
en el archivo especificado como parámetro. El archivo de salida utiliza una estructura tipo INI.
Devuelve una de las constantes de código Error (OK
en el éxito).
Error save_encrypted ( String path, PoolByteArray key )
Guarda el contenido del objeto ConfigFile
en el archivo cifrado AES-256 especificado como parámetro, utilizando la key
proporcionada para cifrarlo. El archivo de salida utiliza una estructura tipo INI.
Devuelve una de las constantes de código Error (OK
en caso de éxito).
Guarda el contenido del objeto ConfigFile
en el archivo encriptado AES-256 especificado como parámetro, utilizando la password
proporcionada para encriptarlo. El archivo de salida utiliza una estructura de tipo INI.
Devuelve una de las constantes de código Error (OK
en caso de éxito).
Asigna un valor a la clave especificada de la sección especificada. Si la sección o la clave no existen, se crean. Al pasar un valor null
se borra la clave especificada si existe, y se borra la sección si termina vacía una vez que se ha eliminado la clave.