Skip to content

Commit

Permalink
Remove Stream Wrapper Functionality
Browse files Browse the repository at this point in the history
- Updates the path stack template resolver removing deprecated methods related to stream wrapper
- Removes the Stream wrapper class
- Updates psalm baseline

Signed-off-by: George Steel <[email protected]>
  • Loading branch information
gsteel committed Jan 31, 2022
1 parent 64f49b1 commit 6210995
Show file tree
Hide file tree
Showing 4 changed files with 6 additions and 383 deletions.
79 changes: 3 additions & 76 deletions psalm-baseline.xml
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
</ImplementedReturnTypeMismatch>
</file>
<file src="src/Helper/AbstractHtmlElement.php">
<MissingConstructor occurrences="13">
<MissingConstructor occurrences="11">
<code>$closingBracket</code>
<code>$closingBracket</code>
<code>$closingBracket</code>
Expand Down Expand Up @@ -631,26 +631,6 @@
<code>translate</code>
</PossiblyNullReference>
</file>
<file src="src/Helper/HtmlFlash.php">
<MixedAssignment occurrences="1">
<code>$htmlObject</code>
</MixedAssignment>
<MixedFunctionCall occurrences="1">
<code>$htmlObject($data, self::TYPE, $attribs, $params, $content)</code>
</MixedFunctionCall>
<MixedInferredReturnType occurrences="1">
<code>string</code>
</MixedInferredReturnType>
<MixedReturnStatement occurrences="1">
<code>$htmlObject($data, self::TYPE, $attribs, $params, $content)</code>
</MixedReturnStatement>
<PossiblyNullReference occurrences="1">
<code>plugin</code>
</PossiblyNullReference>
<UndefinedInterfaceMethod occurrences="1">
<code>plugin</code>
</UndefinedInterfaceMethod>
</file>
<file src="src/Helper/HtmlList.php">
<InvalidParamDefault occurrences="1">
<code>array</code>
Expand Down Expand Up @@ -705,26 +685,6 @@
<code>plugin</code>
</UndefinedInterfaceMethod>
</file>
<file src="src/Helper/HtmlQuicktime.php">
<MixedAssignment occurrences="1">
<code>$htmlObject</code>
</MixedAssignment>
<MixedFunctionCall occurrences="1">
<code>$htmlObject($data, self::TYPE, $attribs, $params, $content)</code>
</MixedFunctionCall>
<MixedInferredReturnType occurrences="1">
<code>string</code>
</MixedInferredReturnType>
<MixedReturnStatement occurrences="1">
<code>$htmlObject($data, self::TYPE, $attribs, $params, $content)</code>
</MixedReturnStatement>
<PossiblyNullReference occurrences="1">
<code>plugin</code>
</PossiblyNullReference>
<UndefinedInterfaceMethod occurrences="1">
<code>plugin</code>
</UndefinedInterfaceMethod>
</file>
<file src="src/Helper/HtmlTag.php">
<MixedArgument occurrences="1">
<code>$value</code>
Expand Down Expand Up @@ -2099,7 +2059,7 @@
<code>false</code>
<code>false</code>
</FalsableReturnStatement>
<MixedArgument occurrences="4">
<MixedArgument occurrences="3">
<code>$value</code>
<code>$value</code>
<code>$value</code>
Expand All @@ -2113,7 +2073,7 @@
<NullArgument occurrences="1">
<code>$this-&gt;paths</code>
</NullArgument>
<RedundantCastGivenDocblockType occurrences="3">
<RedundantCastGivenDocblockType occurrences="2">
<code>(bool) $flag</code>
<code>(bool) $flag</code>
<code>(string) $defaultSuffix</code>
Expand Down Expand Up @@ -2170,34 +2130,6 @@
<code>plugin</code>
</UndefinedInterfaceMethod>
</file>
<file src="src/Stream.php">
<MissingConstructor occurrences="2">
<code>$data</code>
<code>$stat</code>
</MissingConstructor>
<MissingParamType occurrences="5">
<code>$mode</code>
<code>$offset</code>
<code>$opened_path</code>
<code>$options</code>
<code>$whence</code>
</MissingParamType>
<MixedAssignment occurrences="3">
<code>$this-&gt;pos</code>
<code>$this-&gt;pos</code>
<code>$this-&gt;pos</code>
</MixedAssignment>
<MixedOperand occurrences="3">
<code>$offset</code>
<code>$offset</code>
<code>$offset</code>
</MixedOperand>
<UnevaluatedCode occurrences="3">
<code>break;</code>
<code>break;</code>
<code>break;</code>
</UnevaluatedCode>
</file>
<file src="src/Variables.php">
<ArgumentTypeCoercion occurrences="1">
<code>'ArrayIterator'</code>
Expand Down Expand Up @@ -2842,11 +2774,6 @@
<code>renderTitle</code>
</MixedMethodCall>
</file>
<file src="test/Helper/HtmlFlashTest.php">
<UndefinedThisPropertyAssignment occurrences="1">
<code>$this-&gt;view</code>
</UndefinedThisPropertyAssignment>
</file>
<file src="test/Helper/HtmlListTest.php">
<InvalidArgument occurrences="2">
<code>false</code>
Expand Down
61 changes: 1 addition & 60 deletions src/Resolver/TemplatePathStack.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,16 +7,13 @@
use Laminas\Stdlib\SplStack;
use Laminas\View\Exception;
use Laminas\View\Renderer\RendererInterface as Renderer;
use Laminas\View\Stream;
use SplFileInfo;
use Traversable;

use function count;
use function file_exists;
use function get_class;
use function gettype;
use function in_array;
use function ini_get;
use function is_array;
use function is_object;
use function is_string;
Expand All @@ -25,8 +22,6 @@
use function preg_match;
use function rtrim;
use function sprintf;
use function stream_get_wrappers;
use function stream_wrapper_register;
use function strpos;
use function strtolower;

Expand Down Expand Up @@ -69,15 +64,6 @@ class TemplatePathStack implements ResolverInterface
*/
protected $lfiProtectionOn = true;

/**@+
* Flags used to determine if a stream wrapper should be used for enabling short tags
*/

/** @var bool */
protected $useViewStream = false;
/** @var bool */
protected $useStreamWrapper = false;

/**@-*/

/**
Expand All @@ -87,14 +73,6 @@ class TemplatePathStack implements ResolverInterface
*/
public function __construct($options = null)
{
$this->useViewStream = (bool) ini_get('short_open_tag');
if ($this->useViewStream) {
if (! in_array('laminas.view', stream_get_wrappers())) {
/** @psalm-suppress DeprecatedClass */
stream_wrapper_register('laminas.view', Stream::class);
}
}

/** @psalm-var PathStack $paths */
$paths = new SplStack();
$this->paths = $paths;
Expand Down Expand Up @@ -128,10 +106,6 @@ public function setOptions($options)
case 'script_paths':
$this->addPaths($value);
break;
case 'use_stream_wrapper':
/** @psalm-suppress DeprecatedMethod */
$this->setUseStreamWrapper($value);
break;
case 'default_suffix':
$this->setDefaultSuffix($value);
break;
Expand Down Expand Up @@ -283,35 +257,6 @@ public function isLfiProtectionOn()
return $this->lfiProtectionOn;
}

/**
* Set flag indicating if stream wrapper should be used if short_open_tag is off
*
* @deprecated will be removed in version 3
*
* @param bool $flag
* @return TemplatePathStack
*/
public function setUseStreamWrapper($flag)
{
$this->useStreamWrapper = (bool) $flag;
return $this;
}

/**
* Should the stream wrapper be used if short_open_tag is off?
*
* Returns true if the use_stream_wrapper flag is set, and if short_open_tag
* is disabled.
*
* @deprecated will be removed in version 3
*
* @return bool
*/
public function useStreamWrapper()
{
return $this->useViewStream && $this->useStreamWrapper;
}

/**
* Retrieve the filesystem path to a view script
*
Expand Down Expand Up @@ -351,11 +296,7 @@ public function resolve($name, ?Renderer $renderer = null)
break;
}
}
/** @psalm-suppress DeprecatedMethod */
if ($this->useStreamWrapper()) {
// If using a stream wrapper, prepend the spec to the path
$filePath = 'laminas.view://' . $filePath;
}

return $filePath;
}
}
Expand Down
Loading

0 comments on commit 6210995

Please sign in to comment.