refactor: tighten LuaCATS annotations and canonicalize metadata fields (#141)
* refactor: tighten LuaCATS annotations across modules Problem: type annotations repeated inline unions with no aliases, used `table<string, any>` where structured types exist, and had loose `string` where union types should be used. Solution: add `pending.TaskStatus`, `pending.RecurMode`, `pending.TaskExtra`, `pending.ForgeType`, `pending.ForgeState`, `pending.ForgeAuthStatus` aliases and `pending.SyncBackend` interface. Replace inline unions and loose types with the new aliases in `store.lua`, `forge.lua`, `config.lua`, `diff.lua`, `views.lua`, `parse.lua`, `init.lua`, and `oauth.lua`. * refactor: canonicalize internal metadata field names Problem: `pending.Metadata` used shorthand field names (`cat`, `rec`, `rec_mode`) matching user-facing token syntax, coupling internal representation to config. `RecurSpec.from_completion` used a boolean where a `pending.RecurMode` alias exists. `category_syntax` was hardcoded to `'cat'` with no config option. Solution: rename `Metadata` fields to `category`/`recur`/`recur_mode`, add `category_syntax` config option (default `'cat'`), rename `ParsedEntry` fields to match, replace `RecurSpec.from_completion` with `mode: pending.RecurMode`, and restore `[string]` indexer on `pending.ForgeConfig` alongside explicit fields.
This commit is contained in:
parent
46b5d52b60
commit
939251f629
16 changed files with 144 additions and 80 deletions
|
|
@ -1,19 +1,31 @@
|
|||
local config = require('pending.config')
|
||||
|
||||
---@alias pending.TaskStatus 'pending'|'done'|'deleted'|'wip'|'blocked'
|
||||
---@alias pending.RecurMode 'scheduled'|'completion'
|
||||
|
||||
---@class pending.TaskExtra
|
||||
---@field _forge_ref? pending.ForgeRef
|
||||
---@field _forge_cache? pending.ForgeCache
|
||||
---@field _gtasks_task_id? string
|
||||
---@field _gtasks_list_id? string
|
||||
---@field _gcal_event_id? string
|
||||
---@field _gcal_calendar_id? string
|
||||
---@field [string] any
|
||||
|
||||
---@class pending.Task
|
||||
---@field id integer
|
||||
---@field description string
|
||||
---@field status 'pending'|'done'|'deleted'|'wip'|'blocked'
|
||||
---@field status pending.TaskStatus
|
||||
---@field category? string
|
||||
---@field priority integer
|
||||
---@field due? string
|
||||
---@field recur? string
|
||||
---@field recur_mode? 'scheduled'|'completion'
|
||||
---@field recur_mode? pending.RecurMode
|
||||
---@field entry string
|
||||
---@field modified string
|
||||
---@field end? string
|
||||
---@field order integer
|
||||
---@field _extra? table<string, any>
|
||||
---@field _extra? pending.TaskExtra
|
||||
|
||||
---@class pending.Data
|
||||
---@field version integer
|
||||
|
|
@ -24,14 +36,14 @@ local config = require('pending.config')
|
|||
|
||||
---@class pending.TaskFields
|
||||
---@field description string
|
||||
---@field status? string
|
||||
---@field status? pending.TaskStatus
|
||||
---@field category? string
|
||||
---@field priority? integer
|
||||
---@field due? string
|
||||
---@field recur? string
|
||||
---@field recur_mode? string
|
||||
---@field recur_mode? pending.RecurMode
|
||||
---@field order? integer
|
||||
---@field _extra? table
|
||||
---@field _extra? pending.TaskExtra
|
||||
|
||||
---@class pending.Store
|
||||
---@field path string
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue