mirror of
https://github.com/Llewellynvdm/starship.git
synced 2025-02-09 23:48:36 +00:00
feat: Add PHP version module (#244)
This commit is contained in:
parent
78ca70a517
commit
46904e5045
5
.github/workflows/workflow.yml
vendored
5
.github/workflows/workflow.yml
vendored
@ -124,6 +124,11 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
dotnet-version: "2.2.402"
|
dotnet-version: "2.2.402"
|
||||||
|
|
||||||
|
# Install PHP at a fixed version
|
||||||
|
- uses: shivammathur/setup-php@master
|
||||||
|
with:
|
||||||
|
php-version: '7.3.8'
|
||||||
|
|
||||||
# Install Mercurial (pre-installed on linux, installed from pip on macos
|
# Install Mercurial (pre-installed on linux, installed from pip on macos
|
||||||
# and from choco on windows),
|
# and from choco on windows),
|
||||||
- name: Install Mercurial (macos)
|
- name: Install Mercurial (macos)
|
||||||
|
@ -88,6 +88,7 @@ The prompt shows information you need while you're working, while staying sleek
|
|||||||
- Current Rust version (`🦀`)
|
- Current Rust version (`🦀`)
|
||||||
- Current Ruby version (`💎`)
|
- Current Ruby version (`💎`)
|
||||||
- Current Python version (`🐍`)
|
- Current Python version (`🐍`)
|
||||||
|
- Current PHP version (`🐘`)
|
||||||
- Current Go version (`🐹`)
|
- Current Go version (`🐹`)
|
||||||
- Nix-shell environment detection
|
- Nix-shell environment detection
|
||||||
- Print an environment variable
|
- Print an environment variable
|
||||||
|
@ -841,6 +841,31 @@ and `poetry` packages.
|
|||||||
symbol = "🎁 "
|
symbol = "🎁 "
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## PHP
|
||||||
|
|
||||||
|
The `php` module shows the currently installed version of PHP.
|
||||||
|
The module will be shown if any of the following conditions are met:
|
||||||
|
|
||||||
|
- The current directory contains a `composer.json` file
|
||||||
|
- The current directory contains a `.php` file
|
||||||
|
|
||||||
|
### Options
|
||||||
|
|
||||||
|
| Variable | Default | Description |
|
||||||
|
| ---------- | ------------ | ------------------------------------------------------ |
|
||||||
|
| `symbol` | `"🐘 "` | The symbol used before displaying the version of PHP. |
|
||||||
|
| `style` | `"bold red"` | The style for the module. |
|
||||||
|
| `disabled` | `false` | Disables the `php` module. |
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
```toml
|
||||||
|
# ~/.config/starship.toml
|
||||||
|
|
||||||
|
[php]
|
||||||
|
symbol = "🔹 "
|
||||||
|
```
|
||||||
|
|
||||||
## Python
|
## Python
|
||||||
|
|
||||||
The `python` module shows the currently installed version of Python.
|
The `python` module shows the currently installed version of Python.
|
||||||
|
@ -19,6 +19,7 @@ pub mod memory_usage;
|
|||||||
pub mod nix_shell;
|
pub mod nix_shell;
|
||||||
pub mod nodejs;
|
pub mod nodejs;
|
||||||
pub mod package;
|
pub mod package;
|
||||||
|
pub mod php;
|
||||||
pub mod python;
|
pub mod python;
|
||||||
pub mod ruby;
|
pub mod ruby;
|
||||||
pub mod rust;
|
pub mod rust;
|
||||||
|
21
src/configs/php.rs
Normal file
21
src/configs/php.rs
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
use crate::config::{ModuleConfig, RootModuleConfig, SegmentConfig};
|
||||||
|
|
||||||
|
use ansi_term::{Color, Style};
|
||||||
|
use starship_module_config_derive::ModuleConfig;
|
||||||
|
|
||||||
|
#[derive(Clone, ModuleConfig)]
|
||||||
|
pub struct PhpConfig<'a> {
|
||||||
|
pub symbol: SegmentConfig<'a>,
|
||||||
|
pub style: Style,
|
||||||
|
pub disabled: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> RootModuleConfig<'a> for PhpConfig<'a> {
|
||||||
|
fn new() -> Self {
|
||||||
|
PhpConfig {
|
||||||
|
symbol: SegmentConfig::new("🐘 "),
|
||||||
|
style: Color::Red.bold(),
|
||||||
|
disabled: false,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -34,6 +34,7 @@ pub const ALL_MODULES: &[&str] = &[
|
|||||||
"python",
|
"python",
|
||||||
"ruby",
|
"ruby",
|
||||||
"rust",
|
"rust",
|
||||||
|
"php",
|
||||||
"time",
|
"time",
|
||||||
"username",
|
"username",
|
||||||
];
|
];
|
||||||
|
@ -20,6 +20,7 @@ mod memory_usage;
|
|||||||
mod nix_shell;
|
mod nix_shell;
|
||||||
mod nodejs;
|
mod nodejs;
|
||||||
mod package;
|
mod package;
|
||||||
|
mod php;
|
||||||
mod python;
|
mod python;
|
||||||
mod ruby;
|
mod ruby;
|
||||||
mod rust;
|
mod rust;
|
||||||
@ -61,6 +62,7 @@ pub fn handle<'a>(module: &str, context: &'a Context) -> Option<Module<'a>> {
|
|||||||
"nix_shell" => nix_shell::module(context),
|
"nix_shell" => nix_shell::module(context),
|
||||||
"nodejs" => nodejs::module(context),
|
"nodejs" => nodejs::module(context),
|
||||||
"package" => package::module(context),
|
"package" => package::module(context),
|
||||||
|
"php" => php::module(context),
|
||||||
"python" => python::module(context),
|
"python" => python::module(context),
|
||||||
"ruby" => ruby::module(context),
|
"ruby" => ruby::module(context),
|
||||||
"rust" => rust::module(context),
|
"rust" => rust::module(context),
|
||||||
|
67
src/modules/php.rs
Normal file
67
src/modules/php.rs
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
use std::process::Command;
|
||||||
|
|
||||||
|
use super::{Context, Module, RootModuleConfig, SegmentConfig};
|
||||||
|
|
||||||
|
use crate::configs::php::PhpConfig;
|
||||||
|
|
||||||
|
/// Creates a module with the current PHP version
|
||||||
|
///
|
||||||
|
/// Will display the PHP version if any of the following criteria are met:
|
||||||
|
/// - Current directory contains a `.php` file
|
||||||
|
/// - Current directory contains a `composer.json` file
|
||||||
|
pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
|
||||||
|
let is_php_project = context
|
||||||
|
.try_begin_scan()?
|
||||||
|
.set_files(&["composer.json"])
|
||||||
|
.set_extensions(&["php"])
|
||||||
|
.is_match();
|
||||||
|
|
||||||
|
if !is_php_project {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
|
||||||
|
match get_php_version() {
|
||||||
|
Some(php_version) => {
|
||||||
|
let mut module = context.new_module("php");
|
||||||
|
let config: PhpConfig = PhpConfig::try_load(module.config);
|
||||||
|
|
||||||
|
module.set_style(config.style);
|
||||||
|
|
||||||
|
let formatted_version = format_php_version(&php_version)?;
|
||||||
|
module.create_segment("symbol", &config.symbol);
|
||||||
|
module.create_segment("version", &SegmentConfig::new(&formatted_version));
|
||||||
|
|
||||||
|
Some(module)
|
||||||
|
}
|
||||||
|
None => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn get_php_version() -> Option<String> {
|
||||||
|
match Command::new("php")
|
||||||
|
.arg("-r")
|
||||||
|
.arg("echo PHP_MAJOR_VERSION.'.'.PHP_MINOR_VERSION.'.'.PHP_RELEASE_VERSION;")
|
||||||
|
.output()
|
||||||
|
{
|
||||||
|
Ok(output) => Some(String::from_utf8(output.stdout).unwrap()),
|
||||||
|
Err(_) => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn format_php_version(php_version: &str) -> Option<String> {
|
||||||
|
let mut formatted_version = String::with_capacity(php_version.len() + 1);
|
||||||
|
formatted_version.push('v');
|
||||||
|
formatted_version.push_str(php_version);
|
||||||
|
Some(formatted_version)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_format_php_version() {
|
||||||
|
let input = "7.3.8";
|
||||||
|
assert_eq!(format_php_version(input), Some("v7.3.8".to_string()));
|
||||||
|
}
|
||||||
|
}
|
@ -61,6 +61,18 @@ RUN mkdir -p "$DOTNET_HOME" \
|
|||||||
ENV PATH $DOTNET_HOME:$PATH
|
ENV PATH $DOTNET_HOME:$PATH
|
||||||
RUN dotnet help
|
RUN dotnet help
|
||||||
|
|
||||||
|
# Install PHP
|
||||||
|
ENV PHP_VERSION 7.3.8
|
||||||
|
ENV PHPENV_ROOT /home/nonroot/.phpenv
|
||||||
|
ENV PATH $PHPENV_ROOT/bin:$PHPENV_ROOT/shims:$PATH
|
||||||
|
ENV CONFIGURE_OPTS "--without-tidy --disable-zip"
|
||||||
|
RUN curl -L https://raw.githubusercontent.com/phpenv/phpenv-installer/master/bin/phpenv-installer | bash \
|
||||||
|
&& phpenv install $PHP_VERSION \
|
||||||
|
&& phpenv global $PHP_VERSION \
|
||||||
|
&& chmod -R a+x $PHPENV_ROOT
|
||||||
|
# Check that PHP was correctly installed
|
||||||
|
RUN php --version
|
||||||
|
|
||||||
# Install Mercurial
|
# Install Mercurial
|
||||||
RUN HGPYTHON3=1 pip install mercurial
|
RUN HGPYTHON3=1 pip install mercurial
|
||||||
# Check that Mercurial was correctly installed
|
# Check that Mercurial was correctly installed
|
||||||
|
56
tests/testsuite/php.rs
Normal file
56
tests/testsuite/php.rs
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
use std::fs::File;
|
||||||
|
use std::io;
|
||||||
|
|
||||||
|
use ansi_term::Color;
|
||||||
|
|
||||||
|
use crate::common;
|
||||||
|
use crate::common::TestCommand;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn folder_without_php_files() -> io::Result<()> {
|
||||||
|
let dir = common::new_tempdir()?;
|
||||||
|
|
||||||
|
let output = common::render_module("php")
|
||||||
|
.arg("--path")
|
||||||
|
.arg(dir.path())
|
||||||
|
.output()?;
|
||||||
|
let actual = String::from_utf8(output.stdout).unwrap();
|
||||||
|
|
||||||
|
let expected = "";
|
||||||
|
assert_eq!(expected, actual);
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[ignore]
|
||||||
|
fn folder_with_composer_file() -> io::Result<()> {
|
||||||
|
let dir = common::new_tempdir()?;
|
||||||
|
File::create(dir.path().join("composer.json"))?;
|
||||||
|
|
||||||
|
let output = common::render_module("php")
|
||||||
|
.arg("--path")
|
||||||
|
.arg(dir.path())
|
||||||
|
.output()?;
|
||||||
|
let actual = String::from_utf8(output.stdout).unwrap();
|
||||||
|
|
||||||
|
let expected = format!("via {} ", Color::Red.bold().paint("🐘 v7.3.8"));
|
||||||
|
assert_eq!(expected, actual);
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
#[ignore]
|
||||||
|
fn folder_with_php_file() -> io::Result<()> {
|
||||||
|
let dir = common::new_tempdir()?;
|
||||||
|
File::create(dir.path().join("any.php"))?;
|
||||||
|
|
||||||
|
let output = common::render_module("php")
|
||||||
|
.arg("--path")
|
||||||
|
.arg(dir.path())
|
||||||
|
.output()?;
|
||||||
|
let actual = String::from_utf8(output.stdout).unwrap();
|
||||||
|
|
||||||
|
let expected = format!("via {} ", Color::Red.bold().paint("🐘 v7.3.8"));
|
||||||
|
assert_eq!(expected, actual);
|
||||||
|
Ok(())
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user