Git Product home page Git Product logo

composer-repl's Introduction

ramsey/composer-repl

A REPL for PHP built into Composer.

Source Code Download Package PHP Programming Language Read License Build Status Codecov Code Coverage Psalm Type Coverage

About

This Composer plugin provides the composer repl command.

REPL stands for read-eval-print loop. It's a language shell that reads user input, evaluates the input using a programming language (in this case, PHP), and prints the output to the screen. Then, it returns to the read state (that's the loop part).

PsySH is the REPL providing the magic behind ramsey/composer-repl. PsySH is a language shell for PHP. It's similar to irb for Ruby, IPython for Python, and JShell for Java. In addition to acting as a language shell, PsySH can also function as an interactive debugger and development console. Laravel Tinker, Drush for Drupal, WP-CLI shell for WordPress, CakePHP console, and Yii shell are a few of the projects using PsySH.

๐Ÿ’ก You may use this REPL without the Composer plugin functionality by requiring ramsey/composer-repl-lib instead.

This project adheres to a code of conduct. By participating in this project and its community, you are expected to uphold this code.

Installation

Install this package as a development dependency using Composer.

composer require --dev ramsey/composer-repl

Usage

Open your terminal and type composer repl. You may also type composer shell, if you prefer.

You'll see something similar to this:

Psy Shell v0.11.1 (PHP 8.1.1 โ€” cli) by Justin Hileman
------------------------------------------------------------------------
Welcome to the development console (REPL).
To learn more about what you can do in PsySH, type `help`.
------------------------------------------------------------------------
>>>

While in the dev console, you can do cool things like this:

>>> $hello = 'Hello, world'
=> "Hello, world"

>>> echo $hello
Hello, world

>>> foreach ([1, 2, 3] as $x) echo $x . "\n"
1
2
3

>>> $date = new DateTimeImmutable();
=> DateTimeImmutable @1598393282 {#6953
     date: 2020-08-25 22:08:02.643076 UTC (+00:00),
   }

>>> $getDate = fn (DateTimeInterface $dt): DateTimeInterface => $dt;
=> Closure(DateTimeInterface $dt): DateTimeInterface {#6964 โ€ฆ3}

>>> t assertInstanceOf(DateTimeInterface::class, $date);
Test passed!

>>> t assertSame($date, $getDate($date))
Test passed!

>>> phpunit

PHPUnit 9.5.11 by Sebastian Bergmann and contributors.

Runtime:       PHP 8.1.1
Configuration: /path/to/ramsey/conventional-commits/phpunit.xml.dist

...............................................................  63 / 221 ( 28%)
............................................................... 126 / 221 ( 57%)
............................................................... 189 / 221 ( 85%)
................................                                221 / 221 (100%)

Time: 00:00.064, Memory: 12.00 MB

OK (221 tests, 484 assertions)

โœจ๐Ÿ˜ This implementation of PsySH has Super ElePHPant Powers. ๐Ÿ˜โœจ

Environment Bootstrapping

The power of this REPL comes in its ability to act as a tool in your local development environment. So, you might want to load parts of your environment (i.e., configuration, objects, etc.), so you can access these from within the REPL.

You can do this by specifying any number of PHP scripts to include in composer.json, like this:

{
    "extra": {
        "ramsey/composer-repl": {
            "includes": [
                "repl.php",
                "tests/bootstrap.php"
            ]
        }
    }
}

Any variables set or configuration loaded from these scripts is available to use from within the REPL.

For example, if repl.php contains:

<?php
$foo = 'bar';

And we use composer.json to load it with the REPL:

{
    "extra": {
        "ramsey/composer-repl": {
            "includes": [ "repl.php" ]
        }
    }
}

Then, when we're in the REPL, we'll see $foo defined:

>>> ls
Variables: $env, $foo, $phpunit

>>> $foo
=> "bar"

Contributing

Contributions are welcome! To contribute, please familiarize yourself with CONTRIBUTING.md.

Coordinated Disclosure

Keeping user information safe and secure is a top priority, and we welcome the contribution of external security researchers. If you believe you've found a security issue in software that is maintained in this repository, please read SECURITY.md for instructions on submitting a vulnerability report.

Copyright and License

The ramsey/composer-repl plugin is copyright ยฉ Ben Ramsey and licensed for use under the terms of the MIT License (MIT). Please see LICENSE for more information.

composer-repl's People

Contributors

ramsey avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

composer-repl's Issues

Composer Dependency Hell

OK I had a look at the repro case from https://github.com/ramsey/composer-plugin-issue

The root cause of the problem really is

require $vendorDir . '/autoload.php';
which prepends the application's autoloader to Composer's, which mean that some of the files get loaded from the Composer phar and then whatever is loaded after this line runs is loaded from the local vendor dir.

A workaround is to make sure everything which may clash gets loaded beforehand, e.g this appears to resolve it:

        class_exists('Symfony\Component\Console\Input\ArrayInput');

        /** @psalm-suppress UnresolvableInclude */
        require $vendorDir . '/autoload.php';

The only proper and definitive fix however would be to stop sharing the process space between the project deps and Composer.. And for that having a binary like vendor/bin/composer-repl or whatever you wanna call it which does locate the vendor dir, include autoloader, do whatever is needed, then start psysh, would be more appropriate.

You could even run vendor/bin/composer-repl as a new process (make sure to run with TTY enabled) from within the ReplCommand so that you retain BC and retain a way to call this via composer repl. But people could also add "scripts": {"repl": "@php vendor/bin/composer-repl"} and be able to call composer repl then which would run the composer-repl binary.. and that would not require a composer plugin or command integration here.

If any of the above is unclear please ask I'm happy to explain in more details.

Add Support for Symfony Process 6.x

The upstream Psysh project has implemented support for version 6.x of Symfony Console, so it would be advantageous to have support for version 6.x of Symfony Process in this project.

In my experience thus far with the 6.x upgrade, this should only represent a change in explicitly providing function argument types and return types, though that may also result in a change in the minimum supported PHP version.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.