Skip to main content
Drupal API
User account menu
  • Log in

Breadcrumb

  1. Drupal Core 11.1.x

Link.php

Same filename in this branch
  1. 11.1.x vendor/open-telemetry/sdk/Trace/Link.php
  2. 11.1.x vendor/open-telemetry/gen-otlp-protobuf/Opentelemetry/Proto/Trace/V1/Span/Link.php
  3. 11.1.x vendor/symfony/dom-crawler/Link.php
  4. 11.1.x vendor/phpdocumentor/reflection-docblock/src/DocBlock/Tags/Link.php
  5. 11.1.x core/lib/Drupal/Core/Link.php
  6. 11.1.x core/lib/Drupal/Core/Render/Element/Link.php
  7. 11.1.x core/modules/jsonapi/src/JsonApiResource/Link.php

Namespace

Composer\Package

File

vendor/composer/composer/src/Composer/Package/Link.php

View source
<?php

declare (strict_types=1);

/*
 * This file is part of Composer.
 *
 * (c) Nils Adermann <naderman@naderman.de>
 *     Jordi Boggiano <j.boggiano@seld.be>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */
namespace Composer\Package;

use Composer\Semver\Constraint\ConstraintInterface;

/**
 * Represents a link between two packages, represented by their names
 *
 * @author Nils Adermann <naderman@naderman.de>
 */
class Link {
    public const TYPE_REQUIRE = 'requires';
    public const TYPE_DEV_REQUIRE = 'devRequires';
    public const TYPE_PROVIDE = 'provides';
    public const TYPE_CONFLICT = 'conflicts';
    public const TYPE_REPLACE = 'replaces';
    
    /**
     * Special type
     * @internal
     */
    public const TYPE_DOES_NOT_REQUIRE = 'does not require';
    private const TYPE_UNKNOWN = 'relates to';
    
    /**
     * Will be converted into a constant once the min PHP version allows this
     *
     * @internal
     * @var string[]
     * @phpstan-var array<self::TYPE_REQUIRE|self::TYPE_DEV_REQUIRE|self::TYPE_PROVIDE|self::TYPE_CONFLICT|self::TYPE_REPLACE>
     */
    public static $TYPES = [
        self::TYPE_REQUIRE,
        self::TYPE_DEV_REQUIRE,
        self::TYPE_PROVIDE,
        self::TYPE_CONFLICT,
        self::TYPE_REPLACE,
    ];
    
    /**
     * @var string
     */
    protected $source;
    
    /**
     * @var string
     */
    protected $target;
    
    /**
     * @var ConstraintInterface
     */
    protected $constraint;
    
    /**
     * @var string
     * @phpstan-var string $description
     */
    protected $description;
    
    /**
     * @var ?string
     */
    protected $prettyConstraint;
    
    /**
     * Creates a new package link.
     *
     * @param ConstraintInterface $constraint       Constraint applying to the target of this link
     * @param self::TYPE_*        $description      Used to create a descriptive string representation
     */
    public function __construct(string $source, string $target, ConstraintInterface $constraint, $description = self::TYPE_UNKNOWN, ?string $prettyConstraint = null) {
        $this->source = strtolower($source);
        $this->target = strtolower($target);
        $this->constraint = $constraint;
        $this->description = self::TYPE_DEV_REQUIRE === $description ? 'requires (for development)' : $description;
        $this->prettyConstraint = $prettyConstraint;
    }
    public function getDescription() : string {
        return $this->description;
    }
    public function getSource() : string {
        return $this->source;
    }
    public function getTarget() : string {
        return $this->target;
    }
    public function getConstraint() : ConstraintInterface {
        return $this->constraint;
    }
    
    /**
     * @throws \UnexpectedValueException If no pretty constraint was provided
     */
    public function getPrettyConstraint() : string {
        if (null === $this->prettyConstraint) {
            throw new \UnexpectedValueException(sprintf('Link %s has been misconfigured and had no prettyConstraint given.', $this));
        }
        return $this->prettyConstraint;
    }
    public function __toString() : string {
        return $this->source . ' ' . $this->description . ' ' . $this->target . ' (' . $this->constraint . ')';
    }
    public function getPrettyString(PackageInterface $sourcePackage) : string {
        return $sourcePackage->getPrettyString() . ' ' . $this->description . ' ' . $this->target . ' ' . $this->constraint
            ->getPrettyString();
    }

}

Classes

Title Deprecated Summary
Link Represents a link between two packages, represented by their names

API Navigation

  • Drupal Core 11.1.x
  • Topics
  • Classes
  • Functions
  • Constants
  • Globals
  • Files
  • Namespaces
  • Deprecated
  • Services
RSS feed
Powered by Drupal