aboutsummaryrefslogtreecommitdiff
path: root/projectile.el
diff options
context:
space:
mode:
authorBozhidar Batsov <bozhidar@toptal.com>2026-04-25 19:00:09 +0100
committerBozhidar Batsov <bozhidar@toptal.com>2026-04-25 19:00:09 +0100
commit5e4471b10dc59274e7608489b28897a69c585cc8 (patch)
treea25ccb579536dcba4c35066fdfa74254e5cc288d /projectile.el
parent54387baa2e2bd7af9866abd27f5454da71cdbd22 (diff)
Warn when alien indexing bypasses a populated .projectile
Under alien indexing the dirconfig file is silently ignored, which is the most common confusion in the issue tracker (#1322, #1075, #1534, #1941). Show a one-shot display-warning the first time we index a project where alien mode meets a non-empty .projectile. The new projectile-warn-when-dirconfig-is-ignored option lets users who already understand the trade-off silence the warning.
Diffstat (limited to 'projectile.el')
-rw-r--r--projectile.el42
1 files changed, 41 insertions, 1 deletions
diff --git a/projectile.el b/projectile.el
index f0ec260..7d7d745 100644
--- a/projectile.el
+++ b/projectile.el
@@ -404,6 +404,17 @@ Similar to '#' in .gitignore files."
:type 'character
:package-version '(projectile . "2.2.0"))
+(defcustom projectile-warn-when-dirconfig-is-ignored t
+ "Whether to warn when a non-empty .projectile is bypassed by alien indexing.
+Under the `alien' indexing method, Projectile does not consult the
+project's dirconfig file at indexing time. When this option is
+non-nil, a one-time warning is shown for each project where a
+non-empty dirconfig is present alongside alien indexing, since the
+silent bypass is a frequent source of confusion."
+ :group 'projectile
+ :type 'boolean
+ :package-version '(projectile . "2.10.0"))
+
(defcustom projectile-globally-ignored-files
(list projectile-tags-file-name projectile-cache-file)
"A list of files globally ignored by projectile.
@@ -653,6 +664,9 @@ project."
"Cache for parsed dirconfig files, keyed by project root.
Each value is a cons of (MTIME . PARSED-RESULT).")
+(defvar projectile--alien-dirconfig-warned-projects (make-hash-table :test 'equal)
+ "Set of project roots already warned about alien indexing skipping the dirconfig.")
+
(defvar projectile-known-projects nil
"List of locations where we have previously seen projects.
The list of projects is ordered by the time they have been accessed.
@@ -2288,6 +2302,30 @@ project-root for every file."
(funcall action res)
res)))
+(defun projectile--dirconfig-non-empty-p ()
+ "Return non-nil if the current project's dirconfig file has any content."
+ (let* ((dirconfig (projectile-dirconfig-file))
+ (attrs (and (projectile-file-exists-p dirconfig)
+ (file-attributes dirconfig))))
+ (and attrs (> (file-attribute-size attrs) 0))))
+
+(defun projectile--maybe-warn-dirconfig-ignored (project-root)
+ "Warn once per session that PROJECT-ROOT's dirconfig is bypassed by alien mode."
+ (when (and projectile-warn-when-dirconfig-is-ignored
+ (eq projectile-indexing-method 'alien)
+ (not (gethash project-root
+ projectile--alien-dirconfig-warned-projects))
+ (projectile--dirconfig-non-empty-p))
+ (puthash project-root t projectile--alien-dirconfig-warned-projects)
+ (display-warning
+ 'projectile
+ (format "Project %s has a non-empty %s but `projectile-indexing-method' \
+is `alien', which bypasses dirconfig filtering. Switch to `hybrid' or \
+`native' if you need those rules to apply, or set \
+`projectile-warn-when-dirconfig-is-ignored' to nil to silence this warning."
+ project-root projectile-dirconfig-file)
+ :warning)))
+
(defun projectile-project-files (project-root)
"Return a list of files for the PROJECT-ROOT."
(let (files)
@@ -2317,7 +2355,9 @@ project-root for every file."
(if (eq projectile-indexing-method 'alien)
;; In alien mode we can just skip reading
;; .projectile and find all files in the root dir.
- (projectile-dir-files-alien project-root)
+ (progn
+ (projectile--maybe-warn-dirconfig-ignored project-root)
+ (projectile-dir-files-alien project-root))
;; If a project is defined as a list of subfolders
;; then we'll have the files returned for each subfolder,
;; so they are relative to the project root.