diff --git a/build/index.php b/build/index.php
index 77af1c5..14bc92a 100755
--- a/build/index.php
+++ b/build/index.php
@@ -25,7 +25,7 @@ $guiConfig = <<<'GUICONFIG'
"defaultpage": {"type": "text", "description": "The name of the page that will act as the home page for the wiki. This page will be served if you don't specify a page.", "default": "Main Page"},
"admindetails_name": {"type": "text", "description": "Your name as the wiki administrator.", "default": "Administrator"},
"admindetails_email": {"type": "email", "description": "Your email address as the wiki administrator. Will be displayed as a support contact address.", "default": "admin@localhost"},
- "favicon": {"type": "url", "description": "A url that points to the favicon you want to use for your wiki. By default this is set to a data: url of a Peppermint (Credit: by bluefrog23, source: https://openclipart.org/detail/19571/peppermint-candy-by-bluefrog23)", "default": ""},
+ "favicon": {"type": "url", "description": "A url that points to the favicon you want to use for your wiki. This image By default this is set to a data: url of a Peppermint (Credit: by bluefrog23, source: https://openclipart.org/detail/19571/peppermint-candy-by-bluefrog23)", "default": ""},
"logo_url": {"type": "url", "description": "A url that points to the site's logo. Leave blank to disable. When enabled the logo will be inserted next to the site name on every page.", "default": "//starbeamrainbowlabs.com/images/logos/peppermint.png"},
"logo_position": {"type": "text", "description": "The side of the site name at which the logo should be placed.", "default": "left"},
"show_subpages": {"type": "text", "description": "Whether to show a list of subpages at the bottom of the page.", "default": true},
@@ -430,6 +430,36 @@ if($env->is_logged_in)
///////////////////////////////////////////////////////////////////////////////
////////////////////////////////// Functions //////////////////////////////////
///////////////////////////////////////////////////////////////////////////////
+/**
+ * Get the actual absolute origin of the request sent by the user.
+ * @param array $s The $_SERVER variable contents. Defaults to $_SERVER.
+ * @param bool $use_forwarded_host Whether to utilise the X-Forwarded-Host header when calculating the actual origin.
+ * @return string The actual origin of the user's request.
+ */
+function url_origin( $s = false, $use_forwarded_host = false )
+{
+ if($s === false) $s = $_SERVER;
+ $ssl = ( ! empty( $s['HTTPS'] ) && $s['HTTPS'] == 'on' );
+ $sp = strtolower( $s['SERVER_PROTOCOL'] );
+ $protocol = substr( $sp, 0, strpos( $sp, '/' ) ) . ( ( $ssl ) ? 's' : '' );
+ $port = $s['SERVER_PORT'];
+ $port = ( ( ! $ssl && $port=='80' ) || ( $ssl && $port=='443' ) ) ? '' : ':'.$port;
+ $host = ( $use_forwarded_host && isset( $s['HTTP_X_FORWARDED_HOST'] ) ) ? $s['HTTP_X_FORWARDED_HOST'] : ( isset( $s['HTTP_HOST'] ) ? $s['HTTP_HOST'] : null );
+ $host = isset( $host ) ? $host : $s['SERVER_NAME'] . $port;
+ return $protocol . '://' . $host;
+}
+
+/**
+ * Get the full url, as requested by the client.
+ * @see http://stackoverflow.com/a/8891890/1460422 This Stackoverflow answer.
+ * @param array $s The $_SERVER variable. Defaults to $_SERVER.
+ * @param bool $use_forwarded_host Whether to take the X-Forwarded-Host header into account.
+ * @return string The full url, as requested by the client.
+ */
+function full_url( $s = false, $use_forwarded_host = false )
+{
+ return url_origin( $s, $use_forwarded_host ) . $s['REQUEST_URI'];
+}
/**
* Converts a filesize into a human-readable string.
@@ -735,7 +765,7 @@ function system_extension_mime_type($ext) {
/**
* Generates a stack trace.
- * @param bool $log_trace Whether to send the stack trace to the error log.
+ * @param bool $log_trace Whether to send the stack trace to the error log in addition to returning it.
* @return string A string prepresentation of a stack trace.
*/
function stack_trace($log_trace = true)
@@ -1159,11 +1189,6 @@ class page_renderer
$result = str_replace(array_keys($parts), array_values($parts), $result);
- $result = str_replace([
-
- ], [
- ], $result);
-
$result = str_replace("{generation-time-taken}", round((microtime(true) - $start_time)*1000, 2), $result);
return $result;
}
@@ -1181,6 +1206,9 @@ class page_renderer
global $settings;
$result = self::get_css_as_html();
+ if(module_exists("feature-search"))
+ $result .= "\t\t";
+
if(!empty($settings->enable_math_rendering))
$result .= "