feat: add --sort and --reverse flags to bd search command
Added sorting capability to the search command, matching the behavior already available in bd list. Supports sorting by: priority, created, updated, closed, status, id, title, type, and assignee. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -55,6 +55,8 @@ Examples:
|
|||||||
labels, _ := cmd.Flags().GetStringSlice("label")
|
labels, _ := cmd.Flags().GetStringSlice("label")
|
||||||
labelsAny, _ := cmd.Flags().GetStringSlice("label-any")
|
labelsAny, _ := cmd.Flags().GetStringSlice("label-any")
|
||||||
longFormat, _ := cmd.Flags().GetBool("long")
|
longFormat, _ := cmd.Flags().GetBool("long")
|
||||||
|
sortBy, _ := cmd.Flags().GetString("sort")
|
||||||
|
reverse, _ := cmd.Flags().GetBool("reverse")
|
||||||
|
|
||||||
// Date range flags
|
// Date range flags
|
||||||
createdAfter, _ := cmd.Flags().GetString("created-after")
|
createdAfter, _ := cmd.Flags().GetString("created-after")
|
||||||
@@ -241,6 +243,9 @@ Examples:
|
|||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Apply sorting
|
||||||
|
sortIssues(issues, sortBy, reverse)
|
||||||
|
|
||||||
outputSearchResults(issues, query, longFormat)
|
outputSearchResults(issues, query, longFormat)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@@ -265,6 +270,9 @@ Examples:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Apply sorting
|
||||||
|
sortIssues(issues, sortBy, reverse)
|
||||||
|
|
||||||
if jsonOutput {
|
if jsonOutput {
|
||||||
// Get labels and dependency counts
|
// Get labels and dependency counts
|
||||||
issueIDs := make([]string, len(issues))
|
issueIDs := make([]string, len(issues))
|
||||||
@@ -359,6 +367,8 @@ func init() {
|
|||||||
searchCmd.Flags().StringSlice("label-any", []string{}, "Filter by labels (OR: must have AT LEAST ONE)")
|
searchCmd.Flags().StringSlice("label-any", []string{}, "Filter by labels (OR: must have AT LEAST ONE)")
|
||||||
searchCmd.Flags().IntP("limit", "n", 50, "Limit results (default: 50)")
|
searchCmd.Flags().IntP("limit", "n", 50, "Limit results (default: 50)")
|
||||||
searchCmd.Flags().Bool("long", false, "Show detailed multi-line output for each issue")
|
searchCmd.Flags().Bool("long", false, "Show detailed multi-line output for each issue")
|
||||||
|
searchCmd.Flags().String("sort", "", "Sort by field: priority, created, updated, closed, status, id, title, type, assignee")
|
||||||
|
searchCmd.Flags().BoolP("reverse", "r", false, "Reverse sort order")
|
||||||
|
|
||||||
// Date range flags
|
// Date range flags
|
||||||
searchCmd.Flags().String("created-after", "", "Filter issues created after date (YYYY-MM-DD or RFC3339)")
|
searchCmd.Flags().String("created-after", "", "Filter issues created after date (YYYY-MM-DD or RFC3339)")
|
||||||
|
|||||||
@@ -33,6 +33,8 @@ Unlike `bd list`, which requires you to specify which field to search, `bd searc
|
|||||||
- **--label, -l**: Filter by labels (must have ALL specified labels)
|
- **--label, -l**: Filter by labels (must have ALL specified labels)
|
||||||
- **--label-any**: Filter by labels (must have AT LEAST ONE)
|
- **--label-any**: Filter by labels (must have AT LEAST ONE)
|
||||||
- **--limit, -n**: Limit number of results (default: 50)
|
- **--limit, -n**: Limit number of results (default: 50)
|
||||||
|
- **--sort**: Sort by field: priority, created, updated, closed, status, id, title, type, assignee
|
||||||
|
- **--reverse, -r**: Reverse sort order
|
||||||
- **--long**: Show detailed multi-line output for each issue
|
- **--long**: Show detailed multi-line output for each issue
|
||||||
- **--json**: Output results in JSON format
|
- **--json**: Output results in JSON format
|
||||||
|
|
||||||
@@ -62,6 +64,18 @@ bd search refactor --assignee alice --type task
|
|||||||
bd search bug --status open --limit 10
|
bd search bug --status open --limit 10
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Sorted Output
|
||||||
|
```bash
|
||||||
|
# Search bugs sorted by priority (P0 first)
|
||||||
|
bd search bug --sort priority
|
||||||
|
|
||||||
|
# Search features sorted by most recently updated
|
||||||
|
bd search feature --sort updated
|
||||||
|
|
||||||
|
# Search issues sorted by priority, lowest first
|
||||||
|
bd search refactor --sort priority --reverse
|
||||||
|
```
|
||||||
|
|
||||||
### JSON Output
|
### JSON Output
|
||||||
```bash
|
```bash
|
||||||
# Get JSON results for programmatic use
|
# Get JSON results for programmatic use
|
||||||
|
|||||||
Reference in New Issue
Block a user