| 
<?phpnamespace eMacros\Runtime\Collection;
 
 use eMacros\Applicable;
 use eMacros\Scope;
 use eMacros\GenericList;
 use eMacros\Symbol;
 
 class ArrayMap implements Applicable {
 /**
 * Applies a callback to a given array
 * Usage: (Array::map "strtoupper" (array "a" "b" "c"))
 * Returns: array
 * (non-PHPdoc)
 * @see \eMacros\Applicable::apply()
 */
 public function apply(Scope $scope, GenericList $arguments) {
 $nargs = count($arguments);
 
 if ($nargs == 0) {
 throw new \BadFunctionCallException("ArrayMap: No callback specified.");
 }
 elseif ($nargs == 1) {
 throw new \BadFunctionCallException("ArrayMap: No target specified.");
 }
 
 $op = $arguments[0]->evaluate($scope);
 
 if (is_callable($op)) {
 $args = array();
 $it = $arguments->getIterator();
 $it->rewind();
 
 for ($it->next(); $it->valid(); $it->next()) {
 $el = $it->current()->evaluate($scope);
 
 if ($el instanceof \IteratorAggregate) {
 $eit = $el->getIterator();
 $eit->rewind();
 
 $el = array();
 
 for (;$eit->valid(); $eit->next()) {
 $el[] = $eit->current();
 }
 }
 
 $args[] = $el;
 }
 
 array_unshift($args, $op);
 
 return call_user_func_array('array_map', $args);
 }
 
 throw new \InvalidArgumentException("ArrayMap: Expected callable as first argument.");
 }
 }
 
 ?>
 |