JakubMisek Since we're working with WordPress plugins, we keep our linting configs (ESLint, PHPCS, PHPStan, etc.) in the root of each plugin we maintain.

While phpstan.dist.neon / phpstan.neon.dist is the recommended file to check into VCS, we currently use phpstan.neon as the file as we haven't had a need for overriding a dist file.

To recap, we have our workspace root in VS Code as the webroot of a WordPress site which contains folders such as index.php, wp-content, wp-includes, etc.

Then, in wp-content/plugins, we have our plugins each containing their own configs.


Ideally whichever file you have open, it would try to find the closest phpstan.neon file, but this hasn't really been a pattern I've seen in VS Code outside of maybe ES Lint. For PHP_CodeSniffer, we just use a fairly loose config in the workspace root and let CI/CD catch more specific errors.

If that's the direction you have to go with the PHPStan config, I can understand. We'd still get a ton of value out of being able to plop a config in the workspace root containing a bunch of type aliases.

5 days later

JakubMisek Are there docs on how to use global type aliases with DevSense for VS Code?

I've put a phpstan.neon (tried phpstan.dist.neon as well) in a WordPress plugin directory as well as the project root, and it doesn't appear to be loading them.

Thank you!

claygriffiths We don't have docs yet. Most probably we fail to parse the .neon content due to some unexpected whitespace or indentation.

May I ask you to try simplifying the phpstan.neon file? Maybe the editor will load it then. I guess our reader needs some improvements.

    JakubMisek Sounds good!

    As an example, here's what we have in our phpstan.neon in one plugin.

    parameters:
        level: 9
        checkGenericClassInNonGenericObjectType: false
        paths:
            - gs-product-configurator.php
            - class-gs-product-configurator.php
            - includes/
        scanDirectories:
          - ../gravityforms
          - ../woocommerce
        excludePaths:
          analyse:
            - includes/third-party
        ignoreErrors:
          # gf_apply_filters only specifies two params.
          - '#Function gf_apply_filters invoked with \d+ parameters, 2 required.#'
        typeAliases:
          GFFeed: '''
            array{
              id: int,
              form_id: int,
              meta: array<string, mixed>,
              is_active: 0|1,
              addon_slug: string,
            }
          '''
          GSPCFeed: '''
            GFFeed & array{
              meta: array<string, mixed> & array{
                display_price: string,
                item_meta_display: string,
                item_meta_display_template: string,
              },
            }
          '''

      claygriffiths great! thank you very much for your patience, and all the feedback!

      If there will be anything to improve, please feel free to point it out.

        11 days later

        claygriffiths Thank you Clay!

        We should support "includes" already (but there might a be a bug of course). Let me check it.

          4 days later

          claygriffiths phpstan's includes should work, I've tested a few sample .neon files so far.

          (There is a minor issue with typedefs not being updated - this will be fixed in the next pre-release - workaround it to reload the vscode window)

          May I ask for your phpstan.neon file(s) so I can check we resolve them correctly?

          Thank you!

            Write a Reply...