定制 soloterm/solo 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

soloterm/solo

最新稳定版本:v0.5.0

Composer 安装命令:

composer require --dev soloterm/solo

包简介

A Laravel package to run multiple commands at once, to aid in local development.

README 文档

README

Solo for Laravel

Your all-in-one Laravel command to tame local development

Solo for Laravel

Important

This package requires ext-pcntl, so it will not work on Windows. Sorry about that. If you know how to fix that, let me know!

About

Solo for Laravel is a package to run multiple commands at once, to aid in local development. All the commands needed to run your application live behind a single artisan command:

php artisan solo

Each command runs in its own tab in Solo. Use the left/right arrow keys to navigate between tabs and enjoy a powerful, unified development environment.

Screenshot

Installation

  1. Require the package:
composer require soloterm/solo --dev
  1. Install the package:
php artisan solo:install

This will publish the configuration file to config/solo.php.

Configuration

Solo is entirely config-driven through config/solo.php. Here's a quick overview of what you can configure:

Commands

Define your commands in the commands array:

'commands' => [
    'About' => 'php artisan solo:about',
    'Logs' => EnhancedTailCommand::file(storage_path('logs/laravel.log')),
    'Vite' => 'npm run dev',
    'Make' => new MakeCommand,
    
    // Lazy commands don't start automatically
    'Dumps' => Command::from('php artisan solo:dumps')->lazy(),
    'Queue' => Command::from('php artisan queue:work')->lazy(),
    'Tests' => Command::from('php artisan test --colors=always')->lazy(),
],

You can define commands in several ways:

'commands' => [
    // A simple string
    'About' => 'php artisan solo:about',
    
    // A custom Command class
    'Logs' => EnhancedTailCommand::file(storage_path('logs/laravel.log')),
    'Make' => new MakeCommand,
    
    // Using the Command::from() static constructor
    'Dumps' => Command::from('php artisan solo:dumps')->lazy(),
],

A simple string command is the easiest way, but if you need more control you're free to create your own custom class. The EnhancedTailCommand is a good example of what you can do in a custom command.

Lazy Commands

If you want to define a command that does not start automatically, you can append lazy() to a Command instance:

// You might need Reverb, but maybe not always, so don't autostart it.
'Reverb' => Command::from('php artisan reverb')->lazy()

Themes

Solo ships with both light and dark themes. Configure your preference in config/solo.php:

'theme' => env('SOLO_THEME', 'dark'),

'themes' => [
    'light' => Themes\LightTheme::class,
    'dark' => Themes\DarkTheme::class,
],

You can define your own theme if you'd like. It's probably easiest to subclass one of the existing themes.

Keybindings

Choose between default and vim-style keybindings:

'keybinding' => env('SOLO_KEYBINDING', 'default'),

'keybindings' => [
    'default' => Hotkeys\DefaultHotkeys::class,
    'vim' => Hotkeys\VimHotkeys::class,
],

Again, you're welcome to define and register your own keybidings.

Usage

Start Solo with:

php artisan solo

Key Controls

Note these are the default bindings. They will be slightly different if you use the Vim bindings.

  • Navigation:

    • Left/Right arrows to switch between tabs
    • Up/Down arrows to scroll output
    • Shift + Up/Down to page scroll
    • g to quickly jump to any tab
  • Command Controls:

    • s to start/stop the current command
    • r to restart
    • c to clear output
    • p to pause output
    • f to resume (follow) output
  • Interactive Mode:

    • i to enter interactive mode
    • Ctrl+X to exit interactive mode
  • Global:

    • q or Ctrl+C to quit Solo

Special Commands

EnhancedTailCommand

The EnhancedTailCommand provides improved log viewing with features like:

  • Vendor frame collapsing
  • Stack trace formatting
  • Toggle vendor frames with v
  • File truncating
'Logs' => EnhancedTailCommand::file(storage_path('logs/laravel.log')),

MakeCommand

Solo ships with a special php artisan solo:make command that proxies to all of the underlying php artisan make:* commands. It serves as a universal entry point to Laravel's make commands.

It lives in a custom MakeCommand class.

'Make' => new MakeCommand,

solo:dumps

Solo also ships with a custom "Dump Server" that will intercept dump commands from your code and show them in Solo instead of inline. You can run this as a normal artisan command via php artisan solo:dumps.

FAQ

My command isn't working

Try these steps:

  1. Test if it works outside of Solo
  2. Check if it has an --ansi or --colors=always option
  3. Verify it's writing to STDOUT
  4. Look for options to force STDOUT output

Can I run Sail commands?

Yes! Use this format: vendor/bin/sail artisan schedule:work --ansi

Does Solo support Windows?

No, Solo requires ext-pcntl and other Unix-specific features. If you know how to fix that, please open a PR.

Can I use this in production?

I wouldn't! Use supervisor or similar tools for production environments.

Support

This is free! If you want to support me:

Credits

Solo was developed by Aaron Francis. If you like it, please let me know!

Special thanks to:

统计信息

  • 总下载量: 216.01k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1201
  • 点击次数: 1
  • 依赖项目数: 12
  • 推荐数: 0

GitHub 信息

  • Stars: 1200
  • Watchers: 7
  • Forks: 52
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-01-30