Page MenuHomePhabricator

Add a linter rule for detecting empty files
ClosedPublic

Authored by joshuaspence on Aug 13 2015, 10:08 AM.
Tags
None
Referenced Files
F18821472: D13881.diff
Wed, Oct 22, 11:29 PM
F18752920: D13881.id33875.diff
Sat, Oct 4, 4:48 PM
F18737145: D13881.id33517.diff
Wed, Oct 1, 9:13 AM
F18712688: D13881.id.diff
Mon, Sep 29, 5:30 AM
F18626786: D13881.diff
Sep 16 2025, 2:19 AM
F18498908: D13881.diff
Sep 4 2025, 7:09 PM
F18224451: D13881.id.diff
Aug 19 2025, 11:59 PM
F18220908: D13881.id33517.diff
Aug 19 2025, 4:32 PM

Details

Summary

Adds two different linter rules (one general purpose and another PHP specific) to prevent empty files from being added to a repository. For some unknown reason, people seem to like to do this.

Test Plan

Added test cases.

Diff Detail

Repository
rARC Arcanist
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

joshuaspence retitled this revision from to Add a linter rule for detecting empty files.
joshuaspence updated this object.
joshuaspence edited the test plan for this revision. (Show Details)
joshuaspence added a reviewer: epriestley.
epriestley edited edge metadata.
This revision is now accepted and ready to land.Aug 13 2015, 2:37 PM

FWIW Creating an hidden empty file in a directoy seems to be the convention for making git create a directory in the working copy on checkout.

It's also practically required with python (To specify a package directory with __init__.py).
Sometimes people put stuff in it, which makes it even worse, IMO.

Maybe default this to advice?

Ah, good points.

You can put some text in .keep files to explain what the directory is used for, and they're normally fairly few and far between. This probably isn't a bad practice, but this isn't terribly obvious and is a little cumbersome. And this is pretty unreasonable to expect of __init__.py files.

We could try excluding .dotfiles and __init__.py by default. I'm not sure if this gets us 50% or 99% coverage of exceptions.

We could toss the generic version of the rule or disable it by default.

This is also tricky because there's no way to selectively disable it on-site via some eventual syntax added by T1549.

joshuaspence edited edge metadata.

Exclude __init__.py and filename beginning with .

This revision was automatically updated to reflect the committed changes.