在 PHP 7.4 中,基于语义化版本的目录名称,从低到高逐一执行目录中的脚本文件(当目录名称不符合规范时)
1、参考:在 PHP 7.4 中,基于语义化版本的目录名称,从低到高逐一执行目录中的脚本文件
2、现在有需求不再使用语义化版本做为目录名称。当目录名称不可控时,可能会出现目录列表如下:custom_mobile_layout_2、p333、v1_33、v2.0.20、v2.0.21、v2.0.28、v2.1.1、v2.1.2、v2.1.3、v2.1.30、v2.1.65、v2.1.70、v2.1.90、v12.4.iuu、v324、wu_us6、zus.4m_m4bile_l4ut_2。如图1
3、筛选出小于等于 v2.1.66,最终排序后的目录结果,期望将不符合规范的目录的给排除掉,仅保留 vx.x.x 格式(符合语义化版本规范)的,不符合预期。
[2023-07-05 10:37:19] local.INFO: availableVersions [ { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "custom_mobile_layout_2" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "wu_us6" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v1_33" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.0.20" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.0.21" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.0.28" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.1.1" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.1.2" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.1.3" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.1.30" } }, { "Modules\\ThemeStoreDb\\ThemeSetting\\ThemeVersion": { "version": "v2.1.65" } } ]
4、最终决定目录名称即使不使用语义化版本,也仍然需要有一定的规则来确定其先后大小顺序。参考 Laravel 的 数据库迁移的设计。目录名称调整为如下格式:{YY_mm_dd_H}_{特性名称}。目录列表如下:v2.0.20、v2.0.21、v2.0.28、v2.1.1、v2.1.2、v2.1.3、v2.1.30、v2.1.65、v2.1.70、v2.1.90、2023_07_05_16_feature1、2023_07_05_17_feature2、2023_07_06_17_feature3。判断顺序时,基于是否存在前缀 v 来处理(最后发现不需要,因为 {YY_mm_dd_H}_ 开头的版本号始终大于 以 v 开头的版本号)。
近期评论