HEX
Server: Apache
System: Linux cpanelx.inxs.ro 4.18.0-477.27.2.lve.el8.x86_64 #1 SMP Wed Oct 11 12:32:56 UTC 2023 x86_64
User: crowdandsafety (1041)
PHP: 8.1.34
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/crowdandsafety/public_html/wp-content/plugins/cornerstone/includes/classes/Tss/Evaluator.php
<?php

namespace Themeco\Cornerstone\Tss;

use Themeco\Cornerstone\Util\Factory;
use Themeco\Cornerstone\Parsy\Util\Token;
use Themeco\Cornerstone\Tss\Operations\Validator;
use Themeco\Cornerstone\Tss\Traits\StackAccessor;
use Themeco\Cornerstone\Tss\Operations\GetVariable;
use Themeco\Cornerstone\Tss\Operations\DefineSplit;
use Themeco\Cornerstone\Tss\Operations\DefineList;
use Themeco\Cornerstone\Tss\Operations\DefineCommaList;
use Themeco\Cornerstone\Tss\Operations\FunctionCall;
use Themeco\Cornerstone\Tss\Operations\StringInterpolation;
use Themeco\Cornerstone\Tss\Operations\Unary;
use Themeco\Cornerstone\Tss\Operations\Binary;

use Themeco\Cornerstone\Tss\Typed\Typed;
use Themeco\Cornerstone\Tss\Typed\Primitive;
use Themeco\Cornerstone\Tss\Typed\Dimension;
use Themeco\Cornerstone\Tss\Typed\Number;
use Themeco\Cornerstone\Tss\Typed\ValueList;
use Themeco\Cornerstone\Tss\Typed\CommaList;
use Themeco\Cornerstone\Tss\Typed\Split;
use Themeco\Cornerstone\Tss\Typed\DoubleQuotedString;
use Themeco\Cornerstone\Tss\Typed\SingleQuotedString;

class Evaluator {

  use StackAccessor;

  // This should consistently take an input and resolve to
  // a single typed value
  // this could involve
  public function resolve($input) {

    if ( is_a( $input, Typed::class ) ) {
      return $input;
    }

    $token = is_a( $input, Token::class ) ? $input : new Token('primitive', $input);
    $type = $token->type();

    $operation = $this->identifyOperation( $type );
    if (!$operation) {
      return $this->makeTyped( $type, $token->content() );
    }

    return $operation::run( $this->stack, $token->content() );

  }

  public function identifyOperation( $type ) {
    switch ($type) {
      case 'interpolated':
        return StringInterpolation::class;
      case 'list':
        return DefineList::class;
      case 'list-comma':
        return DefineCommaList::class;
      case 'split':
        return DefineSplit::class;
      case 'unary':
        return Unary::class;
      case 'operation':
        return Binary::class;
      case 'call':
        return FunctionCall::class;
      case 'variable':
        return GetVariable::class;
      default:
        return false;
        throw new \Exception("unknown type: $type");
    }

  }

  public function identifyTyped( $type ) {
    switch ($type) {
      case 'primitive':
        return Factory::create(Primitive::class);
      case 'dimension':
        return Factory::create(Dimension::class);
      case 'number':
        return Factory::create(Number::class);
      case 'valueList':
        return Factory::create(ValueList::class);
      case 'commaList':
        return Factory::create(CommaList::class);
      case 'split':
        return Factory::create(Split::class);
      case 'doubleQuotedString':
        return Factory::create(DoubleQuotedString::class);
      case 'singleQuotedString':
        return Factory::create(SingleQuotedString::class);
      default:
        throw new \Exception("unknown type: $type");
    }

  }

  public function makeTyped( $type, $value ) {
    $typed = $this->identifyTyped( $type );
    if ( is_a( $value, Token::class ) && $value->is('interpolated') ) {
      $value = $this->resolve( $value );
    }
    $typed->setValue( $value );
    return $typed;
  }

  public function ensureType( $input ) {
    return is_a( $input, Typed::class ) ? $input : Factory::create(Primitive::class)->setValue($input);
  }

}