All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.netbeans.modules.php.api.PhpVersion Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.netbeans.modules.php.api;

import java.time.LocalDate;
import org.openide.util.NbBundle;

/**
 * Class representing a PHP version.
 * @since 2.28
 */
@NbBundle.Messages({
    "PhpVersion.PHP_5=PHP 5.2/5.1",
    "PhpVersion.PHP_53=PHP 5.3",
    "PhpVersion.PHP_54=PHP 5.4",
    "PhpVersion.PHP_55=PHP 5.5",
    "PhpVersion.PHP_56=PHP 5.6",
    "PhpVersion.PHP_70=PHP 7.0",
    "PhpVersion.PHP_71=PHP 7.1",
    "PhpVersion.PHP_72=PHP 7.2",
    "PhpVersion.PHP_73=PHP 7.3",
    "PhpVersion.PHP_74=PHP 7.4",
    "PhpVersion.PHP_80=PHP 8.0",
    "PhpVersion.PHP_81=PHP 8.1",
    "PhpVersion.PHP_82=PHP 8.2",
    "PhpVersion.PHP_83=PHP 8.3",
})
public enum PhpVersion {

    // order is important! from oldest to newest, see #getDefault()
    /**
     * PHP 5.2/5.1.
     */
    PHP_5(Bundle.PhpVersion_PHP_5(), false),
    /**
     * PHP 5.3.
     */
    PHP_53(Bundle.PhpVersion_PHP_53()),
    /**
     * PHP 5.4.
     */
    PHP_54(Bundle.PhpVersion_PHP_54()),
    /**
     * PHP 5.5.
     */
    PHP_55(Bundle.PhpVersion_PHP_55()),
    /**
     * PHP 5.6.
     */
    PHP_56(Bundle.PhpVersion_PHP_56()),
    /**
     * PHP 7.0.
     * @since 2.58
     */
    PHP_70(Bundle.PhpVersion_PHP_70()),
    /**
     * PHP 7.1.
     * @since 2.60
     */
    PHP_71(Bundle.PhpVersion_PHP_71()),
    /**
     * PHP 7.2.
     * @since 2.61
     */
    PHP_72(Bundle.PhpVersion_PHP_72()),
    /**
     * PHP 7.3.
     * @since 2.62
     */
    PHP_73(Bundle.PhpVersion_PHP_73()),
    /**
     * PHP 7.4.
     * @since 2.65
     */
    PHP_74(Bundle.PhpVersion_PHP_74()),
    /**
     * PHP 8.0.
     * @since 2.74
     */
    PHP_80(Bundle.PhpVersion_PHP_80()),
    /**
     * PHP 8.1.
     * @since 2.80
     */
    PHP_81(Bundle.PhpVersion_PHP_81()),
    /**
     * PHP 8.2.
     * @since 2.87
     */
    PHP_82(Bundle.PhpVersion_PHP_82()),
    /**
     * PHP 8.3.
     * @since 2.93
     */
    PHP_83(Bundle.PhpVersion_PHP_83()),
    ;

    private final String displayName;
    private final boolean namespaces;


    private PhpVersion(String displayName) {
        this(displayName, true);
    }

    private PhpVersion(String displayName, boolean namespaces) {
        assert displayName != null;
        this.displayName = displayName;
        this.namespaces = namespaces;
    }

    /**
     * Always return the latest PHP version.
     * @return the latest PHP version
     */
    public static PhpVersion getDefault() {
        PhpVersion[] phpVersions = PhpVersion.values();
        return phpVersions[phpVersions.length - 1];
    }

    /**
     * Return legacy PHP version, the one before the latest one.
     * 

* This usually means the oldest yet supported PHP version. * @return the legacy PHP version * @since 2.41 */ public static PhpVersion getLegacy() { PhpVersion[] phpVersions = PhpVersion.values(); for (PhpVersion phpVersion : phpVersions) { if (phpVersion.isSupportedVersion()) { return phpVersion; } } return phpVersions[phpVersions.length - 2]; } /** * Get display name of this version. * @return display name of this version */ public String getDisplayName() { return displayName; } /** * Doec this version support namespaces? * @return {@code true} if this version supports namespaces, {@code false} otherwise */ public boolean hasNamespaces() { return namespaces; } /** * Check whether this version supports scalar and return type declarations. * * @return {@code true} if this version scalar and return type declarations, * {@code false} otherwise * @since 2.67 */ public boolean hasScalarAndReturnTypes() { return this.compareTo(PhpVersion.PHP_70) >= 0; } /** * Check whether this version supports nullable types. * * @return {@code true} if this version supports nullable types, * {@code false} otherwise * @since 2.67 */ public boolean hasNullableTypes() { return this.compareTo(PhpVersion.PHP_71) >= 0; } /** * Check whether this version supports a void return type. * * @return {@code true} if this version supports a void return type, * {@code false} otherwise * @since 2.68 */ public boolean hasVoidReturnType() { return this.compareTo(PhpVersion.PHP_71) >= 0; } /** * Check whether this version supports an object type. * * @return {@code true} if this version supports an object type, * {@code false} otherwise * @since 2.95 */ public boolean hasObjectType() { return this.compareTo(PhpVersion.PHP_72) >= 0; } /** * Check whether this version supports typed properties. * * @return {@code true} if this version supports typed properties, * {@code false} otherwise * @since 2.67 */ public boolean hasPropertyTypes() { return this.compareTo(PhpVersion.PHP_74) >= 0; } /** * Check whether this version supports the mixed type. * * @return {@code true} if this version supports mixed type, {@code false} * otherwise * @since 2.74 */ public boolean hasMixedType() { return this.compareTo(PhpVersion.PHP_80) >= 0; } /** * Check whether this version supports the never type. * * @return {@code true} if this version supports never type, {@code false} * otherwise * @since 2.81 */ public boolean hasNeverType() { return this.compareTo(PhpVersion.PHP_81) >= 0; } /** * Check whether this version supports the null, false, and true types. * * @return {@code true} if this version supports null, false, and true * types, {@code false} otherwise * @since 2.87 */ public boolean hasNullAndFalseAndTrueTypes() { return this.compareTo(PhpVersion.PHP_82) >= 0; } /** * Check whether this version supports constants in traits. * * @return {@code true} if this version supports constants in traits, * {@code false} otherwise * @since 2.92 */ public boolean hasConstantsInTraits() { return this.compareTo(PhpVersion.PHP_82) >= 0; } /** * Check whether this version supports [#\Override] attribute. * * @return {@code true} if this version supports [#\Override] attribute, * {@code false} otherwise * @since 2.94 */ public boolean hasOverrideAttribute() { return this.compareTo(PhpVersion.PHP_83) >= 0; } /** * Check whether this is supported version yet by PHP official. * * @return {@code true} if this is supported version, {@code false} * otherwise * @since 2.72 */ public boolean isSupportedVersion() { return Period.valueOf(name()).isSupportedVersion(); } @Override public String toString() { return getDisplayName(); } /** * Valid period for each php version. * https://www.php.net/supported-versions.php */ private enum Period { // Use the same name as PhpVersion PHP_5(LocalDate.of(2005, 11, 24), LocalDate.of(2011, 1, 6), LocalDate.of(2011, 1, 6)), PHP_53(LocalDate.of(2009, 6, 30), LocalDate.of(2014, 8, 14), LocalDate.of(2014, 8, 14)), PHP_54(LocalDate.of(2012, 3, 1), LocalDate.of(2014, 9, 14), LocalDate.of(2014, 9, 14)), PHP_55(LocalDate.of(2013, 6, 20), LocalDate.of(2015, 7, 10), LocalDate.of(2015, 7, 10)), PHP_56(LocalDate.of(2014, 8, 28), LocalDate.of(2017, 1, 19), LocalDate.of(2018, 12, 31)), PHP_70(LocalDate.of(2015, 12, 3), LocalDate.of(2017, 12, 3), LocalDate.of(2018, 12, 3)), PHP_71(LocalDate.of(2016, 12, 1), LocalDate.of(2018, 12, 1), LocalDate.of(2019, 12, 1)), PHP_72(LocalDate.of(2017, 11, 30), LocalDate.of(2019, 11, 30), LocalDate.of(2020, 11, 30)), PHP_73(LocalDate.of(2018, 12, 6), LocalDate.of(2020, 12, 6), LocalDate.of(2021, 12, 6)), PHP_74(LocalDate.of(2019, 11, 28), LocalDate.of(2021, 11, 28), LocalDate.of(2022, 11, 28)), PHP_80(LocalDate.of(2020, 11, 26), LocalDate.of(2022, 11, 26), LocalDate.of(2023, 11, 26)), PHP_81(LocalDate.of(2021, 11, 25), LocalDate.of(2023, 11, 25), LocalDate.of(2024, 11, 25)), PHP_82(LocalDate.of(2022, 12, 8), LocalDate.of(2024, 12, 8), LocalDate.of(2025, 12, 8)), PHP_83(LocalDate.of(2023, 11, 23), LocalDate.of(2025, 11, 23), LocalDate.of(2026, 11, 23)), ; private final LocalDate initialRelease; private final LocalDate activeSupport; private final LocalDate securitySupport; private Period(LocalDate initialRelease, LocalDate activeSupport, LocalDate securitySupport) { this.initialRelease = initialRelease; this.activeSupport = activeSupport; this.securitySupport = securitySupport; } public LocalDate getInitialRelease() { return initialRelease; } public LocalDate getActiveSupport() { return activeSupport; } public LocalDate getSecuritySupport() { return securitySupport; } public boolean isSupportedVersion() { return LocalDate.now().isBefore(securitySupport); } } };





© 2015 - 2025 Weber Informatics LLC | Privacy Policy