2025-01-02 22:17:56 +01:00
< ? php
2025-01-05 07:40:30 +01:00
/*
* Node.php
* Copyright (c) 2025 https://github.com/Sobuno
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* 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 https://www.gnu.org/licenses/.
*/
2025-01-02 22:17:56 +01:00
declare ( strict_types = 1 );
namespace FireflyIII\Support\Search\QueryParser ;
2025-01-05 09:18:03 +01:00
use Illuminate\Support\Facades\Log ;
2025-01-02 22:17:56 +01:00
/**
* Base class for all nodes
*/
abstract class Node
{
protected bool $prohibited ;
2025-01-03 00:07:57 +01:00
/**
* Returns the prohibited status of the node, optionally inverted based on flipFlag
*
2025-01-05 07:45:29 +01:00
* Flipping is used when a node is inside a NodeGroup that has a prohibited status itself, causing inversion of the
* query parts inside
2025-01-03 00:07:57 +01:00
*
* @param bool $flipFlag When true, inverts the prohibited status
2025-01-05 07:45:29 +01:00
*
2025-01-03 00:07:57 +01:00
* @return bool The (potentially inverted) prohibited status
*/
public function isProhibited ( bool $flipFlag ) : bool
2025-01-02 22:17:56 +01:00
{
2025-01-05 07:45:29 +01:00
if ( $flipFlag ) {
2025-01-05 09:23:02 +01:00
// Log::debug(sprintf('This %s is (flipped) now prohibited: %s',get_class($this), var_export(!$this->prohibited, true)));
2025-01-03 00:07:57 +01:00
return ! $this -> prohibited ;
}
2025-01-05 09:23:02 +01:00
// Log::debug(sprintf('This %s is (not flipped) now prohibited: %s',get_class($this), var_export($this->prohibited, true)));
2025-01-05 07:45:29 +01:00
return $this -> prohibited ;
2025-01-03 00:07:57 +01:00
2025-01-02 22:17:56 +01:00
}
2025-02-06 08:56:58 +01:00
2025-02-08 08:18:18 +01:00
public function equals ( self $compare ) : bool
2025-02-06 08:56:58 +01:00
{
if ( $compare -> isProhibited ( false ) !== $this -> isProhibited ( false )) {
Log :: debug ( 'Return false because prohibited status is different' );
2025-02-08 08:18:18 +01:00
2025-02-06 08:56:58 +01:00
return false ;
}
2025-02-09 07:02:12 +01:00
if ( $compare instanceof NodeGroup && $this instanceof NodeGroup ) {
2025-02-06 08:56:58 +01:00
if ( count ( $compare -> getNodes ()) !== count ( $this -> getNodes ())) {
Log :: debug ( sprintf ( 'Return false because node count is different. Original is %d, compare is %d' , count ( $this -> getNodes ()), count ( $compare -> getNodes ())));
2025-02-09 07:10:05 +01:00
2025-02-06 08:56:58 +01:00
return false ;
}
2025-02-08 08:18:18 +01:00
2025-02-06 08:56:58 +01:00
/**
* @var int $index
* @var Node $node
*/
foreach ( $this -> getNodes () as $index => $node ) {
if ( false === $node -> equals ( $compare -> getNodes ()[ $index ])) {
Log :: debug ( 'Return false because nodes are different!' );
2025-02-09 07:10:05 +01:00
2025-02-06 08:56:58 +01:00
return false ;
}
}
2025-02-08 08:18:18 +01:00
2025-02-06 08:56:58 +01:00
return true ;
}
2025-02-08 08:18:18 +01:00
2025-02-06 08:56:58 +01:00
return true ;
}
2025-01-02 22:17:56 +01:00
}