Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php class Sort extends Handler { use ArrayAddressMode, UnaryOperator, Slow; protec..

Decoded Output download

<?php

class Sort extends Handler {

	use ArrayAddressMode, UnaryOperator, Slow;
	
	protected $direction = "ascending";

	public function getOperandType($i) {
		switch($i) {
			case 1: return "U32";
			case 2: return $this->operandType;
		}
	}
	
	public function getOperandAddressMode($i) {
		switch($i) {
			case 1: return "SCA";
			case 2: return "ARR";
		}
	}
	
	public function getFunctionType() {
		return "extern";
	}
	
	public function getOperandSize($i) {
		switch($i) {
			case 1: return 1;
			case 2: return "res_count";
		}
	}
	
	public function getHelperFunctions() {
		$type = $this->getOperandType(2);
		$cType = $this->getOperandCType(2);
		$dir = $this->direction;

		if($this->direction == 'ascending') {
			$a1 = "p1"; $a2 = "p2";
			$b1 = "p2"; $b2 = "p3";
		} else {
			// swap the parameters around when we want descending order
			$a1 = "p2"; $a2 = "p3";
			$b1 = "p1"; $b2 = "p2";
		}

		$scalar_f = array(
				"int qb_compare_{$dir}_{$type}(const void *p1, const void *p2) {",
					"if(*(($cType *) $a1) < *(($cType *) $b1)) {",
						"return -1;",
					"} else if(*(($cType *) $a1) > *(($cType *) $b1)) {",
						"return 1;",
					"} else {",
						"return 0;",
					"}",
				"}",
		);

		$vector_f = array(
			"int qb_compare_{$dir}_{$type}_array(const void *p1, const void *p2, const void *p3) {",
				"#if defined(BSD) || defined(__MACOSX__) || defined(_MSC_VER)",
				"uint32_t len = *((const uint32_t *) p1);",
				"return qb_compare_array_$type(($cType *) $a2, len, ($cType *) $b2, len);",
				"#else",
				"// the GNU version of qsort_r expects the extra parameter to come last",
				"uint32_t len = *((const uint32_t *) p3);",
				"return qb_compare_array_$type(($cType *) $a1, len, ($cType *) $b1, len);",
				"#endif",
			"}",
		);
		return array($scalar_f, $vector_f);
	}

	public function getActionOnUnitData() {
		$type = $this->getOperandType(2);
		$cType = $this->getOperandCType(2);
		$dir = $this->direction;
		$lines = array();

		$lines[] = "if(op1 == 1) {";
		$lines[] = 		"qsort(res_ptr, res_count, sizeof($cType) * 1, (void *) qb_compare_{$dir}_{$type});";
		$lines[] = "} else {";

		$lines[] = "#if defined(_MSC_VER)";
		$lines[] = "	qsort_s(res_ptr, res_count / op1, sizeof($cType) * op1, (void *) qb_compare_{$dir}_{$type}_array, &op1);";
		$lines[] = "#elif defined(BSD) || defined(__MACOSX__)";
		$lines[] = "	qsort_r(res_ptr, res_count / op1, sizeof($cType) * op1, &op1, (void *) qb_compare_{$dir}_{$type}_array);";
		$lines[] = "#else";
		$lines[] = "	qsort_r(res_ptr, res_count / op1, sizeof($cType) * op1, (void *) qb_compare_{$dir}_{$type}_array, &op1);";
		$lines[] = "#endif";
		$lines[] = "}";
		return $lines;
	}
}

?>

Did this file decode correctly?

Original Code

<?php

class Sort extends Handler {

	use ArrayAddressMode, UnaryOperator, Slow;
	
	protected $direction = "ascending";

	public function getOperandType($i) {
		switch($i) {
			case 1: return "U32";
			case 2: return $this->operandType;
		}
	}
	
	public function getOperandAddressMode($i) {
		switch($i) {
			case 1: return "SCA";
			case 2: return "ARR";
		}
	}
	
	public function getFunctionType() {
		return "extern";
	}
	
	public function getOperandSize($i) {
		switch($i) {
			case 1: return 1;
			case 2: return "res_count";
		}
	}
	
	public function getHelperFunctions() {
		$type = $this->getOperandType(2);
		$cType = $this->getOperandCType(2);
		$dir = $this->direction;

		if($this->direction == 'ascending') {
			$a1 = "p1"; $a2 = "p2";
			$b1 = "p2"; $b2 = "p3";
		} else {
			// swap the parameters around when we want descending order
			$a1 = "p2"; $a2 = "p3";
			$b1 = "p1"; $b2 = "p2";
		}

		$scalar_f = array(
				"int qb_compare_{$dir}_{$type}(const void *p1, const void *p2) {",
					"if(*(($cType *) $a1) < *(($cType *) $b1)) {",
						"return -1;",
					"} else if(*(($cType *) $a1) > *(($cType *) $b1)) {",
						"return 1;",
					"} else {",
						"return 0;",
					"}",
				"}",
		);

		$vector_f = array(
			"int qb_compare_{$dir}_{$type}_array(const void *p1, const void *p2, const void *p3) {",
				"#if defined(BSD) || defined(__MACOSX__) || defined(_MSC_VER)",
				"uint32_t len = *((const uint32_t *) p1);",
				"return qb_compare_array_$type(($cType *) $a2, len, ($cType *) $b2, len);",
				"#else",
				"// the GNU version of qsort_r expects the extra parameter to come last",
				"uint32_t len = *((const uint32_t *) p3);",
				"return qb_compare_array_$type(($cType *) $a1, len, ($cType *) $b1, len);",
				"#endif",
			"}",
		);
		return array($scalar_f, $vector_f);
	}

	public function getActionOnUnitData() {
		$type = $this->getOperandType(2);
		$cType = $this->getOperandCType(2);
		$dir = $this->direction;
		$lines = array();

		$lines[] = "if(op1 == 1) {";
		$lines[] = 		"qsort(res_ptr, res_count, sizeof($cType) * 1, (void *) qb_compare_{$dir}_{$type});";
		$lines[] = "} else {";

		$lines[] = "#if defined(_MSC_VER)";
		$lines[] = "	qsort_s(res_ptr, res_count / op1, sizeof($cType) * op1, (void *) qb_compare_{$dir}_{$type}_array, &op1);";
		$lines[] = "#elif defined(BSD) || defined(__MACOSX__)";
		$lines[] = "	qsort_r(res_ptr, res_count / op1, sizeof($cType) * op1, &op1, (void *) qb_compare_{$dir}_{$type}_array);";
		$lines[] = "#else";
		$lines[] = "	qsort_r(res_ptr, res_count / op1, sizeof($cType) * op1, (void *) qb_compare_{$dir}_{$type}_array, &op1);";
		$lines[] = "#endif";
		$lines[] = "}";
		return $lines;
	}
}

?>

Function Calls

None

Variables

None

Stats

MD5 06dbd104d21b6da0d31d1d840110bc5d
Eval Count 0
Decode Time 127 ms