media_soundcloud.variables.inc 3.88 KB
<?php

/**
 * @file media_soundcloud/includes/media_soundcloud.variables.inc
 * Variable defaults for Media: SoundCloud.
 */

/**
 * Define our constants.
 */

/**
 * This is the variable namespace, automatically prepended to module variables.
 */
define('MEDIA_SOUNDCLOUD_NAMESPACE', 'media_soundcloud__');

/**
 * Wrapper for variable_get() using the Media: SoundCloud variable registry.
 *
 * @param string $name
 *  The variable name to retrieve. Note that it will be namespaced by
 *  pre-pending MEDIA_SOUNDCLOUD_NAMESPACE, as to avoid variable collisions
 *  with other modules.
 * @param unknown $default
 *  An optional default variable to return if the variable hasn't been set
 *  yet. Note that within this module, all variables should already be set
 *  in the media_soundcloud_variable_default() function.
 * @return unknown
 *  Returns the stored variable or its default.
 *
 * @see media_soundcloud_variable_set()
 * @see media_soundcloud_variable_del()
 * @see media_soundcloud_variable_default()
 */
function media_soundcloud_variable_get($name, $default = NULL) {
  // Allow for an override of the default.
  // Useful when a variable is required (like $path), but namespacing is still
  // desired.
  if (!isset($default)) {
    $default = media_soundcloud_variable_default($name);
  }
  // Namespace all variables.
  $variable_name = MEDIA_SOUNDCLOUD_NAMESPACE . $name;
  return variable_get($variable_name, $default);
}

/**
 * Wrapper for variable_set() using the Media: SoundCloud variable registry.
 *
 * @param string $name
 *  The variable name to set. Note that it will be namespaced by
 *  pre-pending MEDIA_SOUNDCLOUD_NAMESPACE, as to avoid variable collisions with
 *  other modules.
 * @param unknown $value
 *  The value for which to set the variable.
 * @return unknown
 *  Returns the stored variable after setting.
 *
 * @see media_soundcloud_variable_get()
 * @see media_soundcloud_variable_del()
 * @see media_soundcloud_variable_default()
 */
function media_soundcloud_variable_set($name, $value) {
  $variable_name = MEDIA_SOUNDCLOUD_NAMESPACE . $name;
  return variable_set($variable_name, $value);
}

/**
 * Wrapper for variable_del() using the Media: SoundCloud variable registry.
 *
 * @param string $name
 *  The variable name to delete. Note that it will be namespaced by
 *  pre-pending MEDIA_SOUNDCLOUD_NAMESPACE, as to avoid variable collisions with
 *  other modules.
 *
 * @see media_soundcloud_variable_get()
 * @see media_soundcloud_variable_set()
 * @see media_soundcloud_variable_default()
 */
function media_soundcloud_variable_del($name) {
  $variable_name = MEDIA_SOUNDCLOUD_NAMESPACE . $name;
  variable_del($variable_name);
}

/**
 * The default variables within the Media: SoundCloud namespace.
 *
 * @param string $name
 *  Optional variable name to retrieve the default. Note that it has not yet
 *  been pre-pended with the MEDIA_SOUNDCLOUD_NAMESPACE namespace at this time.
 * @return unknown
 *  The default value of this variable, if it's been set, or NULL, unless
 *  $name is NULL, in which case we return an array of all default values.
 *
 * @see media_soundcloud_variable_get()
 * @see media_soundcloud_variable_set()
 * @see media_soundcloud_variable_del()
 */
function media_soundcloud_variable_default($name = NULL) {
  static $defaults;

  if (!isset($defaults)) {
    $defaults = array(
      'width' => "100%",
      'autoplay' => FALSE,
      'extra_params' => "",
      'preview_uri' => 'soundcloud://u/djandrewz/a/hope-one',
    );
  }

  if (!isset($name)) {
    return $defaults;
  }

  if (isset($defaults[$name])) {
    return $defaults[$name];
  }
}

/**
 * Return the fully namespace variable name.
 *
 * @param string $name
 *  The variable name to retrieve the namespaced name.
 * @return string
 *  The fully namespace variable name, prepended with
 *  MEDIA_SOUNDCLOUD_NAMESPACE.
 */
function media_soundcloud_variable_name($name) {
  return MEDIA_SOUNDCLOUD_NAMESPACE . $name;
}