aboutsummaryrefslogtreecommitdiffstats
path: root/pkg/codesearch
diff options
context:
space:
mode:
authorDmitry Vyukov <dvyukov@google.com>2026-01-19 15:15:18 +0100
committerDmitry Vyukov <dvyukov@google.com>2026-01-20 21:12:57 +0000
commit8088ac4199a6e947c38db669c11d4441a9d59581 (patch)
treefe7d6a6f5c9a6de0be54a14b40cab448bb80aa59 /pkg/codesearch
parentfb714834adfb0e1e36c4cfc7ca288391cfc18986 (diff)
pkg/codesearch: add read-file command
Just provides full file contents as last resort.
Diffstat (limited to 'pkg/codesearch')
-rw-r--r--pkg/codesearch/codesearch.go28
-rw-r--r--pkg/codesearch/testdata/mm/slub.c2
-rw-r--r--pkg/codesearch/testdata/query-read-file-dir3
-rw-r--r--pkg/codesearch/testdata/query-read-file-escaping3
-rw-r--r--pkg/codesearch/testdata/query-read-file-existing4
-rw-r--r--pkg/codesearch/testdata/query-read-file-missing3
6 files changed, 43 insertions, 0 deletions
diff --git a/pkg/codesearch/codesearch.go b/pkg/codesearch/codesearch.go
index 8e0259af7..96ee1c696 100644
--- a/pkg/codesearch/codesearch.go
+++ b/pkg/codesearch/codesearch.go
@@ -45,6 +45,13 @@ var Commands = []Command{
}
return b.String(), nil
}},
+ {"read-file", 1, func(index *Index, args []string) (string, error) {
+ ok, contents, err := index.ReadFile(args[0])
+ if err != nil || !ok {
+ return notFound, err
+ }
+ return contents, nil
+ }},
{"file-index", 1, func(index *Index, args []string) (string, error) {
ok, entities, err := index.FileIndex(args[0])
if err != nil || !ok {
@@ -137,6 +144,27 @@ func (index *Index) DirIndex(dir string) (bool, []string, []string, error) {
return exists, subdirs, files, nil
}
+func (index *Index) ReadFile(file string) (bool, string, error) {
+ if err := escaping(file); err != nil {
+ return false, "", nil
+ }
+ for _, dir := range index.srcDirs {
+ data, err := os.ReadFile(filepath.Join(dir, file))
+ if err != nil {
+ if os.IsNotExist(err) {
+ continue
+ }
+ var errno syscall.Errno
+ if errors.As(err, &errno) && errno == syscall.EISDIR {
+ return false, "", nil
+ }
+ return false, "", err
+ }
+ return true, string(data), nil
+ }
+ return false, "", nil
+}
+
func (index *Index) FileIndex(file string) (bool, []Entity, error) {
var entities []Entity
for _, def := range index.db.Definitions {
diff --git a/pkg/codesearch/testdata/mm/slub.c b/pkg/codesearch/testdata/mm/slub.c
index e69de29bb..4b6741a7f 100644
--- a/pkg/codesearch/testdata/mm/slub.c
+++ b/pkg/codesearch/testdata/mm/slub.c
@@ -0,0 +1,2 @@
+// slub.c contents.
+// This file is used in read-file test.
diff --git a/pkg/codesearch/testdata/query-read-file-dir b/pkg/codesearch/testdata/query-read-file-dir
new file mode 100644
index 000000000..210a326cd
--- /dev/null
+++ b/pkg/codesearch/testdata/query-read-file-dir
@@ -0,0 +1,3 @@
+read-file mm
+
+not found
diff --git a/pkg/codesearch/testdata/query-read-file-escaping b/pkg/codesearch/testdata/query-read-file-escaping
new file mode 100644
index 000000000..fca2abf6a
--- /dev/null
+++ b/pkg/codesearch/testdata/query-read-file-escaping
@@ -0,0 +1,3 @@
+read-file mm/../../codesearch.go
+
+not found
diff --git a/pkg/codesearch/testdata/query-read-file-existing b/pkg/codesearch/testdata/query-read-file-existing
new file mode 100644
index 000000000..9fc30a164
--- /dev/null
+++ b/pkg/codesearch/testdata/query-read-file-existing
@@ -0,0 +1,4 @@
+read-file mm/slub.c
+
+// slub.c contents.
+// This file is used in read-file test.
diff --git a/pkg/codesearch/testdata/query-read-file-missing b/pkg/codesearch/testdata/query-read-file-missing
new file mode 100644
index 000000000..ac7bead8d
--- /dev/null
+++ b/pkg/codesearch/testdata/query-read-file-missing
@@ -0,0 +1,3 @@
+read-file file-that-does-not-exist.c
+
+not found