aboutsummaryrefslogtreecommitdiff
path: root/cmd
diff options
context:
space:
mode:
authorVidhu Kant Sharma <vidhukant@vidhukant.xyz>2022-10-02 20:46:50 +0530
committerVidhu Kant Sharma <vidhukant@vidhukant.xyz>2022-10-02 20:46:50 +0530
commit8fb49796e37d2bf955d8ffa521f6bcda4f36b766 (patch)
treee0728f19a33c2f8f71767472c10767548ce99e94 /cmd
parente0da6a5205169f34671addd533739b6242d5eff3 (diff)
Automatically select nth search result with --auto-select flag
Diffstat (limited to 'cmd')
-rw-r--r--cmd/1136
-rw-r--r--cmd/chapters.go2
-rw-r--r--cmd/episodes.go2
-rw-r--r--cmd/score.go2
-rw-r--r--cmd/search.go2
-rw-r--r--cmd/status.go2
-rw-r--r--cmd/volumes.go2
7 files changed, 12 insertions, 136 deletions
diff --git a/cmd/1 b/cmd/1
deleted file mode 100644
index 0961ffe..0000000
--- a/cmd/1
+++ /dev/null
@@ -1,136 +0,0 @@
-/*
-macli - Unofficial CLI-Based MyAnimeList Client
-Copyright © 2022 Vidhu Kant Sharma <vidhukant@vidhukant.xyz>
-
-This program is free software: you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program. If not, see <http://www.gnu.org/licenses/>.
-*/
-
-package cmd
-
-import (
- "fmt"
- "os"
- "strings"
-
- "github.com/MikunoNaka/macli/mal"
- "github.com/MikunoNaka/macli/ui"
- "github.com/MikunoNaka/macli/util"
- a "github.com/MikunoNaka/MAL2Go/v4/anime"
- m "github.com/MikunoNaka/MAL2Go/v4/manga"
- "github.com/spf13/cobra"
-)
-
-var searchCmd = &cobra.Command {
- Use: "search",
- Short: "Search for an anime/manga",
- Long: "Search for an anime or a manga on MyAnimeList\n" +
- "\n" +
- "Example Usage:\n" +
- "\t\x1b[33m`macli search <anime-name>`\x1b[0m searches for an anime\n" +
- "\t\x1b[33m`macli search -m <manga-name>`\x1b[0m searches for a manga\n" +
- "\t\x1b[33m`macli search`\x1b[0m interactively asks for an anime to search for (same for manga with -m/--manga flag)\n",
- Run: func(cmd *cobra.Command, args []string) {
- conf, err := util.BindSearchConfig(cmd.Flags())
- if err != nil {
- fmt.Println("Error while parsing flags.", err.Error())
- os.Exit(1)
- }
- mal.SearchLength = conf.SearchLength
- mal.SearchOffset = conf.SearchOffset
- mal.SearchNSFW = conf.SearchNSFW
- ui.PromptLength = conf.PromptLength
- mal.Init()
-
- // read searchInput from command
- searchInput := strings.Join(args, " ")
- mangaMode, err := cmd.Flags().GetBool("manga")
- if err != nil {
- fmt.Println("Error while reading \x1b[33m--manga\x1b[0m flag.", err.Error())
- os.Exit(1)
- }
-
- if mangaMode {
- searchManga(searchInput)
- } else {
- searchAnime(searchInput)
- }
- },
-}
-
-func searchManga(searchInput string) {
- var selectedManga m.Manga
- mangaId := entryId
- fields := []string{}
-
- if entryId < 1 {
- if searchInput == "" {
- searchInput = ui.TextInput("Search Manga: ", "Search can't be blank.")
- }
- manga := ui.MangaSearch("Select Manga:", searchInput)
- mangaId = manga.Id
- fields = []string{"my_list_status", "num_chapters"}
- }
-
- selectedManga = mal.GetMangaData(mangaId, fields)
-
- if queryOnlyMode {
- util.PrintManga(selectedManga)
- os.Exit(0)
- }
-
- if entryId > 1 {
- fmt.Println("Selected: \x1b[35m" + selectedManga.Title + "\x1b[0m")
- }
- ui.MangaActionMenu(selectedManga.MyListStatus.Status != "")(selectedManga)
-}
-
-func searchAnime(searchInput string) {
- var selectedAnime a.Anime
- animeId := entryId
- fields := []string{}
-
- if entryId < 1 {
- if searchInput == "" {
- searchInput = ui.TextInput("Search Anime: ", "Search can't be blank.")
- }
- anime := ui.AnimeSearch("Select Anime:", searchInput)
- animeId = anime.Id
- fields = []string{"my_list_status", "num_episodes"}
- }
-
- selectedAnime = mal.GetAnimeData(animeId, fields)
-
- if queryOnlyMode {
- util.PrintAnime(selectedAnime)
- os.Exit(0)
- }
-
- if entryId > 1 {
- fmt.Println("Selected: \x1b[35m" + selectedAnime.Title + "\x1b[0m")
- }
- ui.AnimeActionMenu(selectedAnime.MyListStatus.Status != "")(selectedAnime)
-}
-
-func init() {
- rootCmd.AddCommand(searchCmd)
- searchCmd.Flags().BoolVarP(&mangaMode, "manga", "m", false, "Use manga mode")
- searchCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)")
- searchCmd.Flags().BoolVarP(&queryOnlyMode, "query", "q", false, "Query only (don't update data)")
- searchCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
-
- searchCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
- searchCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
- searchCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")
- searchCmd.Flags().BoolP("search-nsfw", "", false, "Include NSFW-rated items in search results")
-}
diff --git a/cmd/chapters.go b/cmd/chapters.go
index f8c3414..15e2169 100644
--- a/cmd/chapters.go
+++ b/cmd/chapters.go
@@ -50,6 +50,7 @@ var chaptersCmd = &cobra.Command{
mal.SearchLength = conf.SearchLength
mal.SearchOffset = conf.SearchOffset
mal.SearchNSFW = conf.SearchNSFW
+ mal.AutoSel = conf.AutoSel
ui.PromptLength = conf.PromptLength
mal.Init()
@@ -104,6 +105,7 @@ func init() {
chaptersCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)")
chaptersCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
+ chaptersCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value")
chaptersCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
chaptersCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
chaptersCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")
diff --git a/cmd/episodes.go b/cmd/episodes.go
index fce4b2a..a2dbd4d 100644
--- a/cmd/episodes.go
+++ b/cmd/episodes.go
@@ -50,6 +50,7 @@ var episodesCmd = &cobra.Command{
mal.SearchLength = conf.SearchLength
mal.SearchOffset = conf.SearchOffset
mal.SearchNSFW = conf.SearchNSFW
+ mal.AutoSel = conf.AutoSel
ui.PromptLength = conf.PromptLength
mal.Init()
@@ -104,6 +105,7 @@ func init() {
episodesCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)")
episodesCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
+ episodesCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value")
episodesCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
episodesCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
episodesCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")
diff --git a/cmd/score.go b/cmd/score.go
index a7a5aaa..57442fe 100644
--- a/cmd/score.go
+++ b/cmd/score.go
@@ -51,6 +51,7 @@ var scoreCmd = &cobra.Command{
mal.SearchLength = conf.SearchLength
mal.SearchOffset = conf.SearchOffset
mal.SearchNSFW = conf.SearchNSFW
+ mal.AutoSel = conf.AutoSel
ui.PromptLength = conf.PromptLength
mal.Init()
@@ -174,6 +175,7 @@ func init() {
scoreCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)")
scoreCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
+ scoreCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value")
scoreCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
scoreCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
scoreCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")
diff --git a/cmd/search.go b/cmd/search.go
index 0961ffe..8413804 100644
--- a/cmd/search.go
+++ b/cmd/search.go
@@ -49,6 +49,7 @@ var searchCmd = &cobra.Command {
mal.SearchLength = conf.SearchLength
mal.SearchOffset = conf.SearchOffset
mal.SearchNSFW = conf.SearchNSFW
+ mal.AutoSel = conf.AutoSel
ui.PromptLength = conf.PromptLength
mal.Init()
@@ -129,6 +130,7 @@ func init() {
searchCmd.Flags().BoolVarP(&queryOnlyMode, "query", "q", false, "Query only (don't update data)")
searchCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
+ searchCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value")
searchCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
searchCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
searchCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")
diff --git a/cmd/status.go b/cmd/status.go
index 7c641e6..0c92249 100644
--- a/cmd/status.go
+++ b/cmd/status.go
@@ -48,6 +48,7 @@ var statusCmd = &cobra.Command{
}
mal.SearchLength = conf.SearchLength
mal.SearchOffset = conf.SearchOffset
+ mal.AutoSel = conf.AutoSel
mal.SearchNSFW = conf.SearchNSFW
ui.PromptLength = conf.PromptLength
mal.Init()
@@ -151,6 +152,7 @@ func init() {
statusCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of anime/manga (overrides search)")
statusCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
+ statusCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value")
statusCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
statusCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
statusCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")
diff --git a/cmd/volumes.go b/cmd/volumes.go
index 6df1b69..f1cc108 100644
--- a/cmd/volumes.go
+++ b/cmd/volumes.go
@@ -49,6 +49,7 @@ var volumesCmd = &cobra.Command{
}
mal.SearchLength = conf.SearchLength
mal.SearchOffset = conf.SearchOffset
+ mal.AutoSel = conf.AutoSel
mal.SearchNSFW = conf.SearchNSFW
ui.PromptLength = conf.PromptLength
mal.Init()
@@ -104,6 +105,7 @@ func init() {
volumesCmd.Flags().IntVarP(&entryId, "id", "i", -1, "Manually specify the ID of manga (overrides search)")
volumesCmd.Flags().StringVarP(&mal.Secret, "authentication-token", "t", "", "MyAnimeList authentication token to use (overrides system keyring if any)")
+ volumesCmd.Flags().IntP("auto-select", "S", 0, "Automatically select nth value")
volumesCmd.Flags().IntP("prompt-length", "l", 5, "Length of select prompt")
volumesCmd.Flags().IntP("search-length", "n", 10, "Amount of search results to load")
volumesCmd.Flags().IntP("search-offset", "o", 0, "Offset for the search results")