Mercurial > hg > rr-repo
diff sites/all/modules/rdfx/drush/rdfx.drush.inc @ 4:ce11bbd8f642
added modules
author | danieleb <danielebarchiesi@me.com> |
---|---|
date | Thu, 19 Sep 2013 10:38:44 +0100 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sites/all/modules/rdfx/drush/rdfx.drush.inc Thu Sep 19 10:38:44 2013 +0100 @@ -0,0 +1,115 @@ +<?php + +/** + * @file + * drush integration for rdfx. + */ + +/** + * Implementation of hook_drush_command(). + * + * In this hook, you specify which commands your + * drush module makes available, what it does and + * description. + * + * Notice how this structure closely resembles how + * you define menu hooks. + * + * @See drush_parse_command() for a list of recognized keys. + * + * @return + * An associative array describing your command(s). + */ +function rdfx_drush_command() { + $items = array(); + + $items['rdf-download'] = array( + 'callback' => 'rdfx_drush_arc2_download', + 'description' => dt('Downloads the required ARC2 library from http://github.com/semsol/arc2'), + 'aliases' => array('rdfdl'), + 'arguments' => array( + 'path' => dt('Optional. A path to the rdfx module. If omitted Drush will use the default location.'), + ), + ); + return $items; +} + +/** + * Implementation of hook_drush_help(). + * + * This function is called whenever a drush user calls + * 'drush help <name-of-your-command>' + * + * @param + * A string with the help section (prepend with 'drush:') + * + * @return + * A string with the help text for your command. + */ +function rdfx_drush_help($section) { + switch ($section) { + case 'drush:rdf-download': + return dt("Downloads the required ARC2 library from http://github.com/semsol/arc2. Include the optional path."); + } +} + +/** + * Example drush command callback. + * + * This is where the action takes place. + * + * In this function, all of Drupals API is (usually) available, including + * any functions you have added in your own modules/themes. + * + * To print something to the terminal window, use drush_print(). + * + */ +function rdfx_drush_arc2_download() { + $args = func_get_args(); + if ($args[0]) { + $path = $args[0]; + } + else { + $path = drush_get_context('DRUSH_DRUPAL_ROOT'); + if (module_exists('libraries')) { + $path .= '/' . libraries_get_path('ARC2'); + } + else { + $path .= '/' . drupal_get_path('module', 'rdfx') . '/vendor'; + } + } + + // Create the path if it does not exist yet. + if (!is_dir($path)) { + drush_mkdir($path); + } + + if (is_dir($path . '/arc')) { + drush_log('ARC2 already present. No download required.', 'ok'); + } + elseif (drush_op('chdir', $path) && + drush_shell_exec('wget --no-check-certificate -O arc.tar.gz http://github.com/semsol/arc2/tarball/master') && + drush_shell_exec('tar zxvf arc.tar.gz') && + drush_shell_exec('mv semsol-arc2-* arc') && + drush_shell_exec('rm arc.tar.gz')) { + drush_log(dt('The latest ARC2 library has been downloaded to @path', array('@path' => $path)), 'success'); + } + else { + drush_log(dt('Drush was unable to download the ARC2 library to @path', array('@path' => $path)), 'error'); + } +} + +/** + * Implements drush_MODULE_post_COMMAND(). + */ +function drush_rdfx_post_pm_enable() { + $extensions = func_get_args(); + // Deal with comma delimited extension list. + if (strpos($extensions[0], ',') !== FALSE) { + $extensions = explode(',', $extensions[0]); + } + + if (in_array('rdfx', $extensions) && !drush_get_option('skip')) { + rdfx_drush_arc2_download(); + } +}