summaryrefslogtreecommitdiff
path: root/ui.go
diff options
context:
space:
mode:
authorDavid Schlachter <t480-debian-git@schlachter.ca>2026-01-09 01:53:19 -0500
committerDavid Schlachter <t480-debian-git@schlachter.ca>2026-01-09 01:53:19 -0500
commite5e4f420726cd67c89ee92498d9e5f20c64063ee (patch)
treec15f12795ff220fd2717a82fb163e4db4b16063e /ui.go
parentd49203deaaf1a52115ac6aeb1da15ec9f4c9081d (diff)
Show all senses for each word
Diffstat (limited to 'ui.go')
-rw-r--r--ui.go20
1 files changed, 16 insertions, 4 deletions
diff --git a/ui.go b/ui.go
index 3c4dbb7..c41d6f2 100644
--- a/ui.go
+++ b/ui.go
@@ -87,16 +87,28 @@ func (m model) Init() tea.Cmd {
func lookupWord(db *sql.DB, word string) tea.Cmd {
return func() tea.Msg {
word = strings.TrimSpace(word) // remove leading / trailing whitespace
- row := db.QueryRow(`select definition from words where word = ? limit 1`, word)
- var definition string
- err := row.Scan(&definition)
+ rows, err := db.Query(`select definition from words where word = ?`, word)
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return definitionMsg("")
}
return errMsg(fmt.Errorf("looking up '%s': %s", word, err))
}
- return definitionMsg(definition)
+ defer rows.Close()
+ var combinedDefinition []string
+ for rows.Next() {
+ var definition string
+ err = rows.Scan(&definition)
+ if err != nil {
+ return errMsg(fmt.Errorf("looking up '%s': %s", word, err))
+ }
+ combinedDefinition = append(combinedDefinition, definition)
+ }
+ if err := rows.Err(); err != nil {
+ return errMsg(fmt.Errorf("looking up '%s': %s", word, err))
+ }
+
+ return definitionMsg(strings.Join(combinedDefinition, "\n\n"))
}
}