
Comparing changes: https://github.com/smarty-php/smarty/compare/v4.3.1...v4.4.1 It is noticeable that Smarty 4.3.1 does not officially support PHP 8.3. Is only supported with 4.4.0. Remark: During tests with Smarty 4.5.1, it was noticed that the following warning occurs: Deprecated: Using the unregistered function "function_exists" in a template is deprecated and will be removed in a future version. Use Smarty::registerPlugin to explicitly register a custom modifier. As of Smarty 5.X.X, templates must be revised again. The Smarty release 5.0.2 is already officially available. However, integration into FlatPress is not entirely trivial.
105 lines
4.2 KiB
Markdown
105 lines
4.2 KiB
Markdown
# Troubleshooting
|
|
|
|
## Smarty/PHP errors
|
|
|
|
Smarty can catch many errors such as missing tag attributes or malformed
|
|
variable names. If this happens, you will see an error similar to the
|
|
following:
|
|
|
|
```
|
|
Warning: Smarty: [in index.tpl line 4]: syntax error: unknown tag - '%blah'
|
|
in /path/to/smarty/Smarty.class.php on line 1041
|
|
|
|
Fatal error: Smarty: [in index.tpl line 28]: syntax error: missing section name
|
|
in /path/to/smarty/Smarty.class.php on line 1041
|
|
```
|
|
|
|
|
|
Smarty shows you the template name, the line number and the error. After
|
|
that, the error consists of the actual line number in the Smarty class
|
|
that the error occurred.
|
|
|
|
There are certain errors that Smarty cannot catch, such as missing close
|
|
tags. These types of errors usually end up in PHP compile-time parsing
|
|
errors.
|
|
|
|
`Parse error: parse error in /path/to/smarty/templates_c/index.tpl.php on line 75`
|
|
|
|
When you encounter a PHP parsing error, the error line number will
|
|
correspond to the compiled PHP script, NOT the template itself. Usually
|
|
you can look at the template and spot the syntax error. Here are some
|
|
common things to look for: missing close tags for
|
|
[`{if}{/if}`](../designers/language-builtin-functions/language-function-if.md) or
|
|
[`{section}{/section}`](../designers/language-builtin-functions/language-function-section.md),
|
|
or syntax of logic within an `{if}` tag. If you can\'t find the error, you might have to
|
|
open the compiled PHP file and go to the line number to figure out where
|
|
the corresponding error is in the template.
|
|
|
|
```
|
|
Warning: Smarty error: unable to read resource: "index.tpl" in...
|
|
```
|
|
or
|
|
```
|
|
Warning: Smarty error: unable to read resource: "site.conf" in...
|
|
```
|
|
|
|
- The [`$template_dir`](../programmers/api-variables/variable-template-dir.md) is incorrect, doesn't
|
|
exist or the file `index.tpl` is not in the `templates/` directory
|
|
|
|
- A [`{config_load}`](../designers/language-builtin-functions/language-function-config-load.md) function is
|
|
within a template (or [`configLoad()`](../programmers/api-functions/api-config-load.md) has been
|
|
called) and either [`$config_dir`](../programmers/api-variables/variable-config-dir.md) is
|
|
incorrect, does not exist or `site.conf` is not in the directory.
|
|
|
|
```
|
|
Fatal error: Smarty error: the $compile_dir 'templates_c' does not exist,
|
|
or is not a directory...
|
|
```
|
|
|
|
- Either the [`$compile_dir`](../programmers/api-variables/variable-compile-dir.md)is incorrectly
|
|
set, the directory does not exist, or `templates_c` is a file and
|
|
not a directory.
|
|
|
|
```
|
|
Fatal error: Smarty error: unable to write to $compile_dir '....
|
|
```
|
|
|
|
|
|
- The [`$compile_dir`](../programmers/api-variables/variable-compile-dir.md) is not writable by the
|
|
web server. See the bottom of the [installing
|
|
smarty](../getting-started.md#installation) page for more about permissions.
|
|
|
|
```
|
|
Fatal error: Smarty error: the $cache_dir 'cache' does not exist,
|
|
or is not a directory. in /..
|
|
```
|
|
|
|
- This means that [`$caching`](../programmers/api-variables/variable-caching.md) is enabled and
|
|
either; the [`$cache_dir`](../programmers/api-variables/variable-cache-dir.md) is incorrectly set,
|
|
the directory does not exist, or `cache/` is a file and not a
|
|
directory.
|
|
|
|
```
|
|
Fatal error: Smarty error: unable to write to $cache_dir '/...
|
|
```
|
|
|
|
- This means that [`$caching`](../programmers/api-variables/variable-caching.md) is enabled and the
|
|
[`$cache_dir`](../programmers/api-variables/variable-cache-dir.md) is not writable by the web
|
|
server. See the bottom of the [installing
|
|
smarty](../getting-started.md#installation) page for permissions.
|
|
|
|
```
|
|
Warning: filemtime(): stat failed for /path/to/smarty/cache/3ab50a623e65185c49bf17c63c90cc56070ea85c.one.tpl.php
|
|
in /path/to/smarty/libs/sysplugins/smarty_resource.php
|
|
```
|
|
|
|
- This means that your application registered a custom error handler
|
|
(using [set_error_handler()](https://www.php.net/set_error_handler))
|
|
which is not respecting the given `$errno` as it should. If, for
|
|
whatever reason, this is the desired behaviour of your custom error
|
|
handler, please call
|
|
[`muteExpectedErrors()`](../programmers/api-functions/api-mute-expected-errors.md) after you've
|
|
registered your custom error handler.
|
|
|
|
See also [debugging](../designers/chapter-debugging-console.md).
|