ConfigFile

Inherits: Reference < Object

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 )

PoolStringArray

get_section_keys ( String section ) const

PoolStringArray

get_sections ( ) const

Variant

get_value ( String section, String key, Variant default=null ) const

bool

has_section ( String section ) const

bool

has_section_key ( String section, String key ) const

Error

load ( String path )

Error

load_encrypted ( String path, PoolByteArray key )

Error

load_encrypted_pass ( String path, String password )

Error

parse ( String data )

Error

save ( String path )

Error

save_encrypted ( String path, PoolByteArray key )

Error

save_encrypted_pass ( String path, String password )

void

set_value ( String section, String key, Variant value )

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.


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.


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).


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).


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.