Avoid use of assignments bare inside statements
Either use them in a subroutine call or put parentheses around the assignment.
This commit is contained in:
		| @@ -1,36 +1,31 @@ | ||||
| <?php | ||||
| // This file is part of GNU social - https://www.gnu.org/software/social | ||||
| // | ||||
| // GNU social is free software: you can redistribute it and/or modify | ||||
| // it under the terms of the GNU Affero General Public License as published by | ||||
| // the Free Software Foundation, either version 3 of the License, or | ||||
| // (at your option) any later version. | ||||
| // | ||||
| // GNU social is distributed in the hope that it will be useful, | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| // GNU Affero General Public License for more details. | ||||
| // | ||||
| // You should have received a copy of the GNU Affero General Public License | ||||
| // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  | ||||
| /** | ||||
|  * StatusNet, the distributed open-source microblogging tool | ||||
|  * | ||||
|  * An activity | ||||
|  * | ||||
|  * PHP version 5 | ||||
|  * | ||||
|  * LICENCE: This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Affero General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Affero General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Affero General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  * | ||||
|  * @category  Feed | ||||
|  * @package   StatusNet | ||||
|  * @package   GNUsocial | ||||
|  * @author    Evan Prodromou <evan@status.net> | ||||
|  * @author    Zach Copley <zach@status.net> | ||||
|  * @copyright 2010 StatusNet, Inc. | ||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPLv3 | ||||
|  * @link      http://status.net/ | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
|  | ||||
| if (!defined('STATUSNET')) { | ||||
|     exit(1); | ||||
| } | ||||
| defined('GNUSOCIAL') || die(); | ||||
|  | ||||
| /** | ||||
|  * An activity in the ActivityStrea.ms world | ||||
| @@ -42,11 +37,10 @@ if (!defined('STATUSNET')) { | ||||
|  * 'something else' is the object. | ||||
|  * | ||||
|  * @category  OStatus | ||||
|  * @package   StatusNet | ||||
|  * @package   GNUsocial | ||||
|  * @author    Evan Prodromou <evan@status.net> | ||||
|  * @copyright 2010 StatusNet, Inc. | ||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPLv3 | ||||
|  * @link      http://status.net/ | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
| class Activity | ||||
| { | ||||
| @@ -113,7 +107,7 @@ class Activity | ||||
|      * @param DOMElement $entry Atom entry to poke at | ||||
|      * @param DOMElement $feed  Atom feed, for context | ||||
|      */ | ||||
|     function __construct($entry = null, $feed = null) | ||||
|     public function __construct($entry = null, $feed = null) | ||||
|     { | ||||
|         if (is_null($entry)) { | ||||
|             return; | ||||
| @@ -130,14 +124,20 @@ class Activity | ||||
|         $this->entry = $entry; | ||||
|         $this->feed  = $feed; | ||||
|  | ||||
|         if ($entry->namespaceURI == Activity::ATOM && | ||||
|             $entry->localName == 'entry') { | ||||
|         if ( | ||||
|             $entry->namespaceURI === Activity::ATOM | ||||
|             && $entry->localName === 'entry' | ||||
|         ) { | ||||
|             $this->_fromAtomEntry($entry, $feed); | ||||
|         } else if ($entry->namespaceURI == Activity::RSS && | ||||
|                    $entry->localName == 'item') { | ||||
|         } elseif ( | ||||
|             $entry->namespaceURI === Activity::RSS | ||||
|             && $entry->localName === 'item' | ||||
|         ) { | ||||
|             $this->_fromRssItem($entry, $feed); | ||||
|         } else if ($entry->namespaceURI == Activity::SPEC && | ||||
|                    $entry->localName == 'object') { | ||||
|         } elseif ( | ||||
|             $entry->namespaceURI === Activity::SPEC | ||||
|             && $entry->localName === 'object' | ||||
|         ) { | ||||
|             $this->_fromAtomEntry($entry, $feed); | ||||
|         } else { | ||||
|             // Low level exception. No need for i18n. | ||||
| @@ -145,7 +145,7 @@ class Activity | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     function _fromAtomEntry($entry, $feed) | ||||
|     public function _fromAtomEntry($entry, $feed) | ||||
|     { | ||||
|         $pubEl = $this->_child($entry, self::PUBLISHED, self::ATOM); | ||||
|  | ||||
| @@ -191,9 +191,7 @@ class Activity | ||||
|             $this->objects[] = new ActivityObject($entry); | ||||
|         } | ||||
|  | ||||
|         $actorEl = $this->_child($entry, self::ACTOR); | ||||
|  | ||||
|         if (!empty($actorEl)) { | ||||
|         if (!empty($actorEl = $this->_child($entry, self::ACTOR))) { | ||||
|             // Standalone <activity:actor> elements are a holdover from older | ||||
|             // versions of ActivityStreams. Newer feeds should have this data | ||||
|             // integrated straight into <atom:author>. | ||||
| @@ -211,22 +209,25 @@ class Activity | ||||
|                     $this->actor->id = $authorObj->id; | ||||
|                 } | ||||
|             } | ||||
|         } else if ($authorEl = $this->_child($entry, self::AUTHOR, self::ATOM)) { | ||||
|  | ||||
|         } elseif (!empty($authorEl = $this->_child( | ||||
|             $entry, | ||||
|             self::AUTHOR, | ||||
|             self::ATOM | ||||
|         ))) { | ||||
|             // An <atom:author> in the entry overrides any author info on | ||||
|             // the surrounding feed. | ||||
|             $this->actor = new ActivityObject($authorEl); | ||||
|  | ||||
|         } else if (!empty($feed) && | ||||
|                    $subjectEl = $this->_child($feed, self::SUBJECT)) { | ||||
|  | ||||
|         } elseif ( | ||||
|             !empty($feed) | ||||
|             && !empty($subjectEl = $this->_child($feed, self::SUBJECT)) | ||||
|         ) { | ||||
|             // Feed subject is used for things like groups. | ||||
|             // Should actually possibly not be interpreted as an actor...? | ||||
|             $this->actor = new ActivityObject($subjectEl); | ||||
|  | ||||
|         } else if (!empty($feed) && $authorEl = $this->_child($feed, self::AUTHOR, | ||||
|                                                               self::ATOM)) { | ||||
|  | ||||
|         } elseif ( | ||||
|             !empty($feed) | ||||
|             && !empty($authorEl = $this->_child($feed, self::AUTHOR, self::ATOM)) | ||||
|         ) { | ||||
|             // If there's no <atom:author> on the entry, it's safe to assume | ||||
|             // the containing feed's authorship info applies. | ||||
|             $this->actor = new ActivityObject($authorEl); | ||||
| @@ -271,7 +272,7 @@ class Activity | ||||
|         $this->editLink = ActivityUtils::getLink($entry, 'edit', 'application/atom+xml'); | ||||
|     } | ||||
|  | ||||
|     function _fromRssItem($item, $channel) | ||||
|     public function _fromRssItem($item, $channel) | ||||
|     { | ||||
|         $verbEl = $this->_child($item, self::VERB); | ||||
|  | ||||
| @@ -288,14 +289,26 @@ class Activity | ||||
|             $this->time = strtotime($pubDateEl->textContent); | ||||
|         } | ||||
|  | ||||
|         if ($authorEl = $this->_child($item, self::AUTHOR, self::RSS)) { | ||||
|         if (!empty($authorEl = $this->_child( | ||||
|             $item, | ||||
|             self::AUTHOR, | ||||
|             self::RSS | ||||
|         ))) { | ||||
|             $this->actor = ActivityObject::fromRssAuthor($authorEl); | ||||
|         } else if ($dcCreatorEl = $this->_child($item, self::CREATOR, self::DC)) { | ||||
|         } elseif (!empty($dcCreatorEl = $this->_child( | ||||
|             $item, | ||||
|             self::CREATOR, | ||||
|             self::DC | ||||
|         ))) { | ||||
|             $this->actor = ActivityObject::fromDcCreator($dcCreatorEl); | ||||
|         } else if ($posterousEl = $this->_child($item, ActivityObject::AUTHOR, ActivityObject::POSTEROUS)) { | ||||
|         } elseif (!empty($posterousEl = $this->_child( | ||||
|             $item, | ||||
|             ActivityObject::AUTHOR, | ||||
|             ActivityObject::POSTEROUS | ||||
|         ))) { | ||||
|             // Special case for Posterous.com | ||||
|             $this->actor = ActivityObject::fromPosterousAuthor($posterousEl); | ||||
|         } else if (!empty($channel)) { | ||||
|         } elseif (!empty($channel)) { | ||||
|             $this->actor = ActivityObject::fromRssChannel($channel); | ||||
|         } else { | ||||
|             // No actor! | ||||
| @@ -347,7 +360,7 @@ class Activity | ||||
|      * @return DOMElement Atom entry | ||||
|      */ | ||||
|  | ||||
|     function toAtomEntry() | ||||
|     public function toAtomEntry() | ||||
|     { | ||||
|         return null; | ||||
|     } | ||||
| @@ -359,7 +372,7 @@ class Activity | ||||
|      * @return array $activity | ||||
|      */ | ||||
|  | ||||
|     function asArray() | ||||
|     public function asArray() | ||||
|     { | ||||
|         $activity = array(); | ||||
|  | ||||
| @@ -416,7 +429,6 @@ class Activity | ||||
|         // Context stuff. | ||||
|  | ||||
|         if (!empty($this->context)) { | ||||
|  | ||||
|             if (!empty($this->context->location)) { | ||||
|                 $loc = $this->context->location; | ||||
|  | ||||
| @@ -528,15 +540,23 @@ class Activity | ||||
|         return array_filter($activity); | ||||
|     } | ||||
|  | ||||
|     function asString($namespace=false, $author=true, $source=false) | ||||
|     { | ||||
|     public function asString( | ||||
|         $namespace = false, | ||||
|         $author    = true, | ||||
|         $source    = false | ||||
|     ) { | ||||
|         $xs = new XMLStringer(true); | ||||
|         $this->outputTo($xs, $namespace, $author, $source); | ||||
|         return $xs->getString(); | ||||
|     } | ||||
|  | ||||
|     function outputTo($xs, $namespace=false, $author=true, $source=false, $tag='entry') | ||||
|     { | ||||
|     public function outputTo( | ||||
|         $xs, | ||||
|         $namespace = false, | ||||
|         $author    = true, | ||||
|         $source    = false, | ||||
|         $tag       = 'entry' | ||||
|     ) { | ||||
|         if ($namespace) { | ||||
|             $attrs = array('xmlns' => 'http://www.w3.org/2005/Atom', | ||||
|                            'xmlns:thr' => 'http://purl.org/syndication/thread/1.0', | ||||
| @@ -557,10 +577,8 @@ class Activity | ||||
|         } | ||||
|  | ||||
|         if ($this->verb == ActivityVerb::POST && count($this->objects) == 1 && $tag == 'entry') { | ||||
|  | ||||
|             $obj = $this->objects[0]; | ||||
| 			$obj->outputTo($xs, null); | ||||
|  | ||||
|             $obj->outputTo($xs, null); | ||||
|         } else { | ||||
|             $xs->element('id', null, $this->id); | ||||
|  | ||||
| @@ -582,7 +600,6 @@ class Activity | ||||
|                                            'type' => 'text/html', | ||||
|                                            'href' => $this->link)); | ||||
|             } | ||||
|  | ||||
|         } | ||||
|  | ||||
|         $xs->element('activity:verb', null, $this->verb); | ||||
| @@ -597,7 +614,7 @@ class Activity | ||||
|         } | ||||
|  | ||||
|         if ($this->verb != ActivityVerb::POST || count($this->objects) != 1 || $tag != 'entry') { | ||||
|             foreach($this->objects as $object) { | ||||
|             foreach ($this->objects as $object) { | ||||
|                 if ($object instanceof Activity) { | ||||
|                     $object->outputTo($xs, false, true, true, 'activity:object'); | ||||
|                 } else { | ||||
| @@ -607,21 +624,24 @@ class Activity | ||||
|         } | ||||
|  | ||||
|         if (!empty($this->context)) { | ||||
|  | ||||
|             if (!empty($this->context->replyToID)) { | ||||
|                 if (!empty($this->context->replyToUrl)) { | ||||
|                     $xs->element('thr:in-reply-to', | ||||
|                                  array('ref' => $this->context->replyToID, | ||||
|                                        'href' => $this->context->replyToUrl)); | ||||
|                     $xs->element('thr:in-reply-to', [ | ||||
|                         'ref'  => $this->context->replyToID, | ||||
|                         'href' => $this->context->replyToUrl, | ||||
|                     ]); | ||||
|                 } else { | ||||
|                     $xs->element('thr:in-reply-to', | ||||
|                                  array('ref' => $this->context->replyToID)); | ||||
|                     $xs->element('thr:in-reply-to', [ | ||||
|                         'ref' => $this->context->replyToID, | ||||
|                     ]); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             if (!empty($this->context->replyToUrl)) { | ||||
|                 $xs->element('link', array('rel' => 'related', | ||||
|                                            'href' => $this->context->replyToUrl)); | ||||
|                 $xs->element('link', [ | ||||
|                     'rel'  => 'related', | ||||
|                     'href' => $this->context->replyToUrl, | ||||
|                 ]); | ||||
|             } | ||||
|  | ||||
|             if (!empty($this->context->conversation)) { | ||||
| @@ -631,14 +651,18 @@ class Activity | ||||
|                     $convattr['href'] = $conv->getUrl(); | ||||
|                     $convattr['local_id'] = $conv->getID(); | ||||
|                     $convattr['ref'] = $conv->getUri(); | ||||
|                     $xs->element('link', array('rel' => 'ostatus:'.ActivityContext::CONVERSATION, | ||||
|                                                 'href' => $convattr['href'])); | ||||
|                     $xs->element('link', [ | ||||
|                         'rel'  => 'ostatus:' . ActivityContext::CONVERSATION, | ||||
|                         'href' => $convattr['href'], | ||||
|                     ]); | ||||
|                 } else { | ||||
|                     $convattr['ref'] = $this->context->conversation; | ||||
|                 } | ||||
|                 $xs->element('ostatus:'.ActivityContext::CONVERSATION, | ||||
|                                 $convattr, | ||||
|                                 $this->context->conversation); | ||||
|                 $xs->element( | ||||
|                     'ostatus:' . ActivityContext::CONVERSATION, | ||||
|                     $convattr, | ||||
|                     $this->context->conversation | ||||
|                 ); | ||||
|                 /* Since we use XMLWriter we just use the previously hardcoded prefix for ostatus, | ||||
|                     otherwise we should use something like this: | ||||
|                 $xs->elementNS(array(ActivityContext::OSTATUS => 'ostatus'),    // namespace | ||||
| @@ -649,9 +673,11 @@ class Activity | ||||
|             } | ||||
|  | ||||
|             foreach ($this->context->attention as $attnURI=>$type) { | ||||
|                 $xs->element('link', array('rel' => ActivityContext::MENTIONED, | ||||
|                                            ActivityContext::OBJECTTYPE => $type,  // FIXME: undocumented  | ||||
|                                            'href' => $attnURI)); | ||||
|                 $xs->element('link', [ | ||||
|                     'rel'  => ActivityContext::MENTIONED, | ||||
|                     ActivityContext::OBJECTTYPE => $type,  // @fixme undocumented | ||||
|                     'href' => $attnURI, | ||||
|                 ]); | ||||
|             } | ||||
|  | ||||
|             if (!empty($this->context->location)) { | ||||
| @@ -759,7 +785,7 @@ class Activity | ||||
|      * @param int $tm Unix timestamp | ||||
|      * @return string | ||||
|      */ | ||||
|     static function iso8601Date($tm) | ||||
|     public static function iso8601Date($tm) | ||||
|     { | ||||
|         $dateStr = date('d F Y H:i:s', $tm); | ||||
|         $d = new DateTime($dateStr, new DateTimeZone('UTC')); | ||||
|   | ||||
							
								
								
									
										109
									
								
								lib/ui/theme.php
									
									
									
									
									
								
							
							
						
						
									
										109
									
								
								lib/ui/theme.php
									
									
									
									
									
								
							| @@ -1,36 +1,31 @@ | ||||
| <?php | ||||
| // This file is part of GNU social - https://www.gnu.org/software/social | ||||
| // | ||||
| // GNU social is free software: you can redistribute it and/or modify | ||||
| // it under the terms of the GNU Affero General Public License as published by | ||||
| // the Free Software Foundation, either version 3 of the License, or | ||||
| // (at your option) any later version. | ||||
| // | ||||
| // GNU social is distributed in the hope that it will be useful, | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| // GNU Affero General Public License for more details. | ||||
| // | ||||
| // You should have received a copy of the GNU Affero General Public License | ||||
| // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  | ||||
| /** | ||||
|  * StatusNet, the distributed open-source microblogging tool | ||||
|  * | ||||
|  * Utilities for theme files and paths | ||||
|  * | ||||
|  * PHP version 5 | ||||
|  * | ||||
|  * LICENCE: This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Affero General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Affero General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Affero General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  * | ||||
|  * @category  Paths | ||||
|  * @package   StatusNet | ||||
|  * @package   GNUsocial | ||||
|  * @author    Evan Prodromou <evan@status.net> | ||||
|  * @author    Sarven Capadisli <csarven@status.net> | ||||
|  * @copyright 2008-2009 StatusNet, Inc. | ||||
|  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | ||||
|  * @link      http://status.net/ | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
|  | ||||
| if (!defined('STATUSNET') && !defined('LACONICA')) { | ||||
|     exit(1); | ||||
| } | ||||
| defined('GNUSOCIAL') || die(); | ||||
|  | ||||
| /** | ||||
|  * Class for querying and manipulating a theme | ||||
| @@ -45,19 +40,18 @@ if (!defined('STATUSNET') && !defined('LACONICA')) { | ||||
|  * This used to be a couple of functions, but for various reasons it's nice | ||||
|  * to have a class instead. | ||||
|  * | ||||
|  * @category Output | ||||
|  * @package  StatusNet | ||||
|  * @author   Evan Prodromou <evan@status.net> | ||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | ||||
|  * @link     http://status.net/ | ||||
|  * @category  Output | ||||
|  * @package   GNUsocial | ||||
|  * @author    Evan Prodromou <evan@status.net> | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
| class Theme | ||||
| { | ||||
|     const FALLBACK = 'neo'; | ||||
|  | ||||
|     var $name = null; | ||||
|     var $dir  = null; | ||||
|     var $path = null; | ||||
|     public $name = null; | ||||
|     public $dir  = null; | ||||
|     public $path = null; | ||||
|     protected $metadata = null; // access via getMetadata() lazy-loader | ||||
|     protected $externals = null; | ||||
|     protected $deps = null; | ||||
| @@ -70,7 +64,7 @@ class Theme | ||||
|      * @param string $name Name of the theme; defaults to config value | ||||
|      * @throws ServerException | ||||
|      */ | ||||
|     function __construct($name = null) | ||||
|     public function __construct($name = null) | ||||
|     { | ||||
|         if (empty($name)) { | ||||
|             $name = common_config('site', 'theme'); | ||||
| @@ -107,14 +101,15 @@ class Theme | ||||
|  | ||||
|         // Ruh roh. Fall back to default, then. | ||||
|  | ||||
|         common_log(LOG_WARNING, sprintf("Unable to find theme '%s', falling back to default theme '%s'", | ||||
|                                         $name, | ||||
|                                         Theme::FALLBACK)); | ||||
|         common_log(LOG_WARNING, sprintf( | ||||
|             'Unable to find theme \'%s\', falling back to default theme \'%s\'', | ||||
|             $name, | ||||
|             Theme::FALLBACK | ||||
|         )); | ||||
|  | ||||
|         $this->name = Theme::FALLBACK; | ||||
|         $this->dir  = $instroot.'/'.Theme::FALLBACK; | ||||
|         $this->path = $this->relativeThemePath('theme', 'theme', Theme::FALLBACK); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -135,13 +130,13 @@ class Theme | ||||
|             $sslserver = common_config($group, 'sslserver'); | ||||
|  | ||||
|             if (empty($sslserver)) { | ||||
|                 if (is_string(common_config('site', 'sslserver')) && | ||||
|                     mb_strlen(common_config('site', 'sslserver')) > 0) { | ||||
|                     $server = common_config('site', 'sslserver'); | ||||
|                 } else if (common_config('site', 'server')) { | ||||
|                 $sslserver = common_config('site', 'sslserver'); | ||||
|                 if (is_string($sslserver) && strlen($sslserver) > 0) { | ||||
|                     $server = $sslserver; | ||||
|                 } elseif (!empty(common_config('site', 'server'))) { | ||||
|                     $server = common_config('site', 'server'); | ||||
|                 } | ||||
|                 $path   = common_config('site', 'path') . '/'; | ||||
|                 $path = common_config('site', 'path') . '/'; | ||||
|                 if ($fallbackSubdir) { | ||||
|                     $path .= $fallbackSubdir . '/'; | ||||
|                 } | ||||
| @@ -191,7 +186,7 @@ class Theme | ||||
|      * | ||||
|      * @return string full pathname, like /var/www/mublog/theme/default/logo.png | ||||
|      */ | ||||
|     function getFile($relative) | ||||
|     public function getFile($relative) | ||||
|     { | ||||
|         return $this->dir.'/'.$relative; | ||||
|     } | ||||
| @@ -203,7 +198,7 @@ class Theme | ||||
|      * | ||||
|      * @return string full URL, like 'http://example.com/theme/default/logo.png' | ||||
|      */ | ||||
|     function getPath($relative) | ||||
|     public function getPath($relative) | ||||
|     { | ||||
|         return $this->path.'/'.$relative; | ||||
|     } | ||||
| @@ -215,7 +210,7 @@ class Theme | ||||
|      * | ||||
|      * @return array of strings with theme names | ||||
|      */ | ||||
|     function getDeps() | ||||
|     public function getDeps() | ||||
|     { | ||||
|         if ($this->deps === null) { | ||||
|             $chain = $this->doGetDeps(array($this->name)); | ||||
| @@ -238,9 +233,11 @@ class Theme | ||||
|                     array_unshift($chain, $include); | ||||
|                     return $theme->doGetDeps($chain); | ||||
|                 } catch (Exception $e) { | ||||
|                     common_log(LOG_ERR, | ||||
|                             "Exception while fetching theme dependencies " . | ||||
|                             "for $this->name: " . $e->getMessage()); | ||||
|                     common_log( | ||||
|                         LOG_ERR, | ||||
|                         'Exception while fetching theme dependencies ' | ||||
|                         . "for {$this->name}: {$e->getMessage()}" | ||||
|                     ); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| @@ -253,9 +250,9 @@ class Theme | ||||
|      * | ||||
|      * @return array associative of strings | ||||
|      */ | ||||
|     function getMetadata() | ||||
|     public function getMetadata() | ||||
|     { | ||||
|         if ($this->metadata == null) { | ||||
|         if (is_null($this->metadata)) { | ||||
|             $this->metadata = $this->doGetMetadata(); | ||||
|         } | ||||
|         return $this->metadata; | ||||
| @@ -284,9 +281,9 @@ class Theme | ||||
|      * @return array of URL strings | ||||
|      * @throws ServerException | ||||
|      */ | ||||
|     function getExternals() | ||||
|     public function getExternals() | ||||
|     { | ||||
|         if ($this->externals == null) { | ||||
|         if (is_null($this->externals)) { | ||||
|             $data = $this->getMetadata(); | ||||
|             if (!empty($data['external'])) { | ||||
|                 $ext = (array)$data['external']; | ||||
| @@ -313,7 +310,7 @@ class Theme | ||||
|      * @return string File path to the theme file | ||||
|      * @throws ServerException | ||||
|      */ | ||||
|     static function file($relative, $name=null) | ||||
|     public static function file($relative, $name = null) | ||||
|     { | ||||
|         $theme = new Theme($name); | ||||
|         return $theme->getFile($relative); | ||||
| @@ -328,7 +325,7 @@ class Theme | ||||
|      * @return string URL of the file | ||||
|      * @throws ServerException | ||||
|      */ | ||||
|     static function path($relative, $name=null) | ||||
|     public static function path($relative, $name = null) | ||||
|     { | ||||
|         $theme = new Theme($name); | ||||
|         return $theme->getPath($relative); | ||||
| @@ -339,7 +336,7 @@ class Theme | ||||
|      * | ||||
|      * @return array list of available theme names | ||||
|      */ | ||||
|     static function listAvailable() | ||||
|     public static function listAvailable() | ||||
|     { | ||||
|         $local   = self::subdirsOf(self::localRoot()); | ||||
|         $install = self::subdirsOf(self::installRoot()); | ||||
| @@ -363,7 +360,7 @@ class Theme | ||||
|         $subdirs = array(); | ||||
|  | ||||
|         if (is_dir($dir)) { | ||||
|             if ($dh = opendir($dir)) { | ||||
|             if (($dh = opendir($dir)) !== false) { | ||||
|                 while (($filename = readdir($dh)) !== false) { | ||||
|                     if ($filename != '..' && $filename !== '.' && | ||||
|                         is_dir($dir.'/'.$filename)) { | ||||
| @@ -409,7 +406,7 @@ class Theme | ||||
|         return $instroot; | ||||
|     } | ||||
|  | ||||
|     static function validName($name) | ||||
|     public static function validName($name) | ||||
|     { | ||||
|         return preg_match('/^[a-z0-9][a-z0-9_-]*$/i', $name); | ||||
|     } | ||||
|   | ||||
| @@ -1,43 +1,40 @@ | ||||
| <?php | ||||
| // This file is part of GNU social - https://www.gnu.org/software/social | ||||
| // | ||||
| // GNU social is free software: you can redistribute it and/or modify | ||||
| // it under the terms of the GNU Affero General Public License as published by | ||||
| // the Free Software Foundation, either version 3 of the License, or | ||||
| // (at your option) any later version. | ||||
| // | ||||
| // GNU social is distributed in the hope that it will be useful, | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| // GNU Affero General Public License for more details. | ||||
| // | ||||
| // You should have received a copy of the GNU Affero General Public License | ||||
| // along with GNU social.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  | ||||
| /** | ||||
|  * Form action extendable class. | ||||
|  * | ||||
|  * PHP version 5 | ||||
|  * | ||||
|  * @category Action | ||||
|  * @package  StatusNet | ||||
|  * @author   Evan Prodromou <evan@status.net> | ||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 | ||||
|  * @link     http://status.net/ | ||||
|  * | ||||
|  * StatusNet - the distributed open-source microblogging tool | ||||
|  * Copyright (C) 2008, 2009, StatusNet, Inc. | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU Affero General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU Affero General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Affero General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  * @category  Action | ||||
|  * @package   GNUsocial | ||||
|  * @author    Evan Prodromou <evan@status.net> | ||||
|  * @copyright 2008, 2009 StatusNet, Inc. | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
|  | ||||
| if (!defined('GNUSOCIAL')) { exit(1); } | ||||
| defined('GNUSOCIAL') || die(); | ||||
|  | ||||
| /** | ||||
|  * Form action extendable class | ||||
|  * | ||||
|  * @category Action | ||||
|  * @package  StatusNet | ||||
|  * @author   Evan Prodromou <evan@status.net> | ||||
|  * @author   Mikael Nordfeldth <evan@status.net> | ||||
|  * @license  http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 | ||||
|  * @link     http://status.net/ | ||||
|  * @category  Action | ||||
|  * @package   GNUsocial | ||||
|  * @author    Evan Prodromou <evan@status.net> | ||||
|  * @author    Mikael Nordfeldth <evan@status.net> | ||||
|  * @copyright 2008, 2009 StatusNet, Inc. | ||||
|  * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later | ||||
|  */ | ||||
| class FormAction extends ManagedAction | ||||
| { | ||||
| @@ -47,7 +44,8 @@ class FormAction extends ManagedAction | ||||
|     protected $needLogin = true; | ||||
|     protected $canPost = true; | ||||
|  | ||||
|     protected function prepare(array $args = []) { | ||||
|     protected function prepare(array $args = []) | ||||
|     { | ||||
|         parent::prepare($args); | ||||
|  | ||||
|         $this->form = $this->form ?: ucfirst($this->action); | ||||
| @@ -63,17 +61,18 @@ class FormAction extends ManagedAction | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     public function isReadOnly($args) { | ||||
|     public function isReadOnly($args) | ||||
|     { | ||||
|         return !$this->isPost(); | ||||
|     } | ||||
|  | ||||
|     public function showPageNotice() | ||||
|     { | ||||
|         $this->showInstructions(); | ||||
|         if ($msg = $this->getError()) { | ||||
|         if (!empty($msg = $this->getError())) { | ||||
|             $this->element('div', 'error', $msg); | ||||
|         } | ||||
|         if ($msg = $this->getInfo()) { | ||||
|         if (!empty($msg = $this->getInfo())) { | ||||
|             $this->element('div', 'info', $msg); | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -2097,7 +2097,7 @@ function common_get_mime_media($type) | ||||
| function common_bare_mime($mimetype) | ||||
| { | ||||
|     $mimetype = mb_strtolower($mimetype); | ||||
|     if ($semicolon = mb_strpos($mimetype, ';')) { | ||||
|     if (($semicolon = mb_strpos($mimetype, ';')) !== false) { | ||||
|         $mimetype = mb_substr($mimetype, 0, $semicolon); | ||||
|     } | ||||
|     return trim($mimetype); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user