View source  
  <?php
class views_php_handler_sort extends views_handler_sort {
  protected $php_static_variable = NULL;
  
  function option_definition() {
    $options = parent::option_definition();
    $options['use_php_setup'] = array(
      'default' => FALSE,
    );
    $options['php_setup'] = array(
      'default' => '',
    );
    $options['php_sort'] = array(
      'default' => '',
    );
    $options['sql_sort'] = array(
      'default' => '',
    );
    return $options;
  }
  
  function options_form(&$form, &$form_state) {
    parent::options_form($form, $form_state);
    $form += views_php_form_element($this, FALSE, array(
      'sql_sort',
      t('SQL sort code'),
      t('Return a valid SQL ORDER BY clause.'),
      FALSE,
    ), array(
      '$view',
      '$handler',
      '$static',
    ));
    $form += views_php_form_element($this, array(
      'use_php_setup',
      t('Use setup code'),
      t('If checked, you can provide PHP code to be run once right before execution of the view. This may be useful to define functions to be re-used in the value and/or output code.'),
    ), array(
      'php_setup',
      t('Setup code'),
      t('Code to run right before execution of the view.'),
      FALSE,
    ), array(
      '$view',
      '$handler',
      '$static',
    ));
    $form += views_php_form_element($this, FALSE, array(
      'php_sort',
      t('Sort code'),
      t('The comparison code must return an integer less than, equal to, or greater than zero if the first row should respectively appear before, stay where it was compared to, or appear after the second row.'),
      FALSE,
    ), array(
      '$view',
      '$handler',
      '$static',
      '$row1' => t('Data of row.'),
      '$row2' => t('Data of row to compare against.'),
    ));
  }
  
  function query() {
    
    $this->view->views_php = TRUE;
    
    if (!empty($this->options['sql_sort'])) {
      $function = create_function('$view, $handler, &$static', $this->options['sql_sort'] . ';');
      ob_start();
      $clause = $function($this->view, $this, $this->php_static_variable);
      ob_end_clean();
      if (!empty($clause)) {
        $this->query
          ->add_orderby(NULL, NULL, '', $clause);
      }
    }
  }
  
  function php_pre_execute() {
    
    if (!empty($this->view->build_info['summary'])) {
      return;
    }
    
    if (!empty($this->options['php_setup'])) {
      $function = create_function('$view, $handler, &$static', $this->options['php_setup'] . ';');
      ob_start();
      $function($this->view, $this, $this->php_static_variable);
      ob_end_clean();
    }
    
    if (!empty($this->options['php_sort'])) {
      $this->view->use_php_pager = TRUE;
    }
  }
  
  function php_post_execute() {
    
    if (!empty($this->view->build_info['summary'])) {
      return;
    }
    if (!empty($this->options['php_sort']) && $this->view->style_plugin
      ->build_sort()) {
      $this->php_sort_function = create_function('$view, $handler, &$static, $row1, $row2', $this->options['php_sort'] . ';');
      ob_start();
      usort($this->view->result, array(
        $this,
        'php_sort',
      ));
      ob_end_clean();
    }
  }
  
  function php_sort($row1, $row2) {
    $factor = strtoupper($this->options['order']) == 'ASC' ? 1 : -1;
    $function = $this->php_sort_function;
    foreach (array(
      'row1' => 'normalized_row1',
      'row2' => 'normalized_row2',
    ) as $name => $normalized_name) {
      ${$normalized_name} = new stdClass();
      foreach ($this->view->display_handler
        ->get_handlers('field') as $field => $handler) {
        ${$normalized_name}->{$field} = isset(${$name}->{$handler->field_alias}) ? ${$name}->{$handler->field_alias} : NULL;
      }
      
      if (!empty($this->view->base_field) && isset(${$name}->{$this->view->base_field})) {
        ${$normalized_name}->{$this->view->base_field} = ${$name}->{$this->view->base_field};
      }
    }
    $result = (int) $function($this->view, $this, $this->php_static_variable, $normalized_row1, $normalized_row2);
    return $factor * $result;
  }
}