123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- <?php
- /**
- * @file
- * drush integration for domwindow.
- */
- /**
- * The DOMWindow plugin URI.
- */
- define('DOMWINDOW_DOWNLOAD_URI', 'http://swip.codylindley.com/jquery.DOMWindow.js');
- /**
- * 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 topic docs-commands` for a list of recognized keys.
- *
- * @return
- * An associative array describing your command(s).
- */
- function domwindow_drush_command() {
- $items = array();
- // the key in the $items array is the name of the command.
- $items['domwindow-plugin'] = array(
- 'callback' => 'drush_domwindow_plugin',
- 'description' => dt("Downloads the DOMWindow plugin."),
- 'bootstrap' => DRUSH_BOOTSTRAP_DRUSH, // No bootstrap.
- 'arguments' => array(
- 'path' => dt('Optional. A path where to install the DOMWindow plugin. If omitted Drush will use the default location.'),
- ),
- 'aliases' => array('domwindowplugin'),
- );
- 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 domwindow_drush_help($section) {
- switch ($section) {
- case 'drush:domwindow-plugin':
- return dt("Downloads the DOMWindow plugin from http://swip.codylindley.com, default location is sites/all/libraries.");
- }
- }
- /**
- * Implements drush_MODULE_post_pm_enable().
- */
- // function drush_domwindow_post_pm_enable() {
- // $modules = func_get_args();
- // if (in_array('domwindow', $modules)) {
- // drush_domwindow_plugin();
- // }
- // }
- /**
- * Command to download the DOMWindow plugin.
- */
- function drush_domwindow_plugin() {
- $filename = basename(DOMWINDOW_DOWNLOAD_URI);
- $dirname = drupal_strtolower(basename(DOMWINDOW_DOWNLOAD_URI, '.js'));
-
- $args = func_get_args();
- if (!empty($args[0])) {
- $path = $args[0];
- }
- else {
- $path = 'sites/all/libraries';
- }
- // Create the path if it does not exist.
- if (!is_dir($path)) {
- drush_op('mkdir', $path);
- drush_log(dt('Directory @path was created', array('@path' => $path)), 'notice');
- }
- // Set the directory to the download location.
- $olddir = getcwd();
- chdir($path);
- // Remove any existing DOMWindow plugin directory
- if (is_dir($dirname)) {
- drush_log(dt('A existing DOMWindow plugin was overwritten at @path', array('@path' => $path)), 'notice');
- }
- else {
- drush_op('mkdir', $dirname);
- }
- chdir($dirname);
- // Remove any existing DOMWindow plugin zip archive
- if (is_file($filename)) {
- drush_op('unlink', $filename);
- }
- // Download the zip archive
- if (!drush_shell_exec('wget ' . DOMWINDOW_DOWNLOAD_URI)) {
- drush_shell_exec('curl -O ' . DOMWINDOW_DOWNLOAD_URI);
- }
- // Set working directory back to the previous working directory.
- chdir($olddir);
- if (is_dir($path)) {
- drush_log(dt('DOMWindow plugin has been downloaded to @path', array('@path' => $path)), 'success');
- }
- else {
- drush_log(dt('Drush was unable to download the DOMWindow plugin to @path', array('@path' => $path)), 'error');
- }
- }
|