-
Notifications
You must be signed in to change notification settings - Fork 12
Migrating configurations from INI files
Infinity versions 1.2 and higher have a new configuration syntax which does not use INI files. You may need to migrate custom configurations to the new syntax.
If you are a theme developer that is migrating an Infinity theme fork, or an Infinity child theme to be compatible with version 1.2 or higher, then yes.
If you edited the bundled INI configuration files, or added your own overriding INI files, you will need to convert only the specific options you changed or overrode to the new syntax. Don't worry, it's super easy.
Originally, INI files were chosen to make it easy for developers to add additional configurations and modify existing ones. Two things occurred that made INI files no longer a good choice for this:
-
Quite a few people complained that it wasn't possible to translate the strings in the INI files. We didn't think this would ever be an issue... but when developers started putting default string values for options which would appear on the front end, it became a real problem.
-
The WordPress theme-check plugin added the PHP functions which load and parse INI files to their black list of disallowed functions due to the fact that they open files directly from disk. This prevents any Infinity based themes from being accepted into the WordPress.org free theme directory.
The following is an overview which compares the old syntax to the new syntax. Each would give identical results.
This is example INI syntax for a Splash Image Position option:
#!ini
; The My Homepage feature is configured only once.
[infinity-myhomepage-images]
type = "default";
title = "My Homepage Images";
description = "My custom homepage images.";
options.section = "homepage";
; An image position option.
[infinity-myhomepage-images.splash-image-pos]
section = "homepage";
title = "Splash Image Position";
description = "Choose on which side you want to display the splash image.";
type = "radio";
default_value = "left";
field_options[] = "left=Left";
field_options[] = "right=Right";
The value of this options was previously retrieved with this API function call:
#!php
<?php
// Notice how the entire feature name had to be included (yuck)
$pos = infinity_option_get( 'infinity-myhomepage-images.splash-image-pos' );
?>
This is the PHP code which uses the ICE (Infinity Component Engine) for the Splash Image Position option:
#!php
<?php
// My Homepage group (configured only once)
// This creates the group (also a namespace) named "myhomepage" which allows features and options to share stored values easily.
ice_register_group( 'myhomepage' );
// My Homepage feature (configured only once)
// This creates the feature named "images" in the "myhomepage" group, which can then have options assigned to it.
ice_register_feature(
array(
'group' => 'myhomepage',
'name' => 'images',
'type' => 'default',
'title' => 'My Homepage Images',
'description' => 'My custom homepage options.'
)
);
// The Splash Image Position option
ice_register_option(
array(
'group' => 'myhomepage',
'required_feature' => 'images',
'name' => 'splash-image-pos',
'section' => 'homepage',
'title' => 'Splash Image Position',
'description' => 'Choose on which side you want to display the splash image.',
'type' => 'radio',
'default_value' => 'left',
'field_options' => array(
'left' => 'Left',
'right' => 'Right'
)
)
);
?>
The feature must be enabled using add_theme_support() as shown here:
#!php
<?php
// Notice the group name and the feature name.
// You can enable multiple features for the same group by adding additional arguments.
add_theme_support( 'infinity:myhomepage', 'images' );
?>
The value of the option can now be retrieved with this API function call:
#!php
<?php
// Notice how only the group and option name are used.
// It is no longer necessary or valid to include the feature name.
$pos = infinity_option_get( 'myhomepage.splash-image-pos' );
?>