diff options
-rw-r--r-- | cmd/1 | 136 | ||||
-rw-r--r-- | cmd/chapters.go | 2 | ||||
-rw-r--r-- | cmd/episodes.go | 2 | ||||
-rw-r--r-- | cmd/score.go | 2 | ||||
-rw-r--r-- | cmd/search.go | 2 | ||||
-rw-r--r-- | cmd/status.go | 2 | ||||
-rw-r--r-- | cmd/volumes.go | 2 | ||||
-rw-r--r-- | macli.yaml | 39 | ||||
-rw-r--r-- | mal/mal.go | 1 | ||||
-rw-r--r-- | mal/search.go | 16 | ||||
-rw-r--r-- | ui/search.go | 18 | ||||
-rw-r--r-- | util/bind_config.go | 8 |
12 files changed, 53 insertions, 177 deletions
@@ -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") diff --git a/macli.yaml b/macli.yaml deleted file mode 100644 index 4578967..0000000 --- a/macli.yaml +++ /dev/null @@ -1,39 +0,0 @@ -# sample macli configuration file -# can be placed (and accessed in the same order) -# at ./macli.yaml, ~/.config/macli/macli.yaml or /etc/macli/macli.yaml -# -# https://vidhukant.xyz/docs/macli -# https://github.com/MikunoNaka/macli -# -# macli v1.12 onwards support reading this file but -# currently this file may cause unexpected behaviour -# so it is not currently recommended to use it - -# AUTHENTICAITON INFO -# macli defaults to the system keyring on windows or mac, -# or gnome-keyring (optional) on linux to store the login information -# if none are available it can be set here -# but it is not recommended unless it's the only option -# -# if you're using termux, this is probably the only option -auth: - # TODO: add option to ignore system keyring - # ~~can leave blank, macli will set this~~ TODO: make macli set this optionally - token: "" - # run `macli help` for instructions for creating one - client_id: "" - # save newly entered client id when logging in (yes/no) - save_client_id: "yes" - -# default settings (can be overridden by corresponding flags, `macli --help` for more details) -searching: - prompt_length: 5 # length of anime/manga selection prompt when searching (default: 5) - search_length: 10 # amount of search results to get (default: 10) - search_offset: 0 # offset for the search results (default is 0, changing it is here not recommended as it may cause confusion) - search_nsfw: false # include NSFW rated search results (true/false) - -lists: - # TODO: add default sort types, etc - list_length: 15 # amount of titles to show from user's list - list_offset: 0 # offset for the results (default is 0, changing it here is not recommended as it may cause confusion) - include_nsfw_results: false # show NSFW rated items @@ -39,6 +39,7 @@ var ( SearchLength, SearchOffset int SearchNSFW bool + AutoSel int ) // init() would kill the program prematurely on `macli login` command diff --git a/mal/search.go b/mal/search.go index 1bad114..e6e416a 100644 --- a/mal/search.go +++ b/mal/search.go @@ -28,7 +28,13 @@ import ( func SearchAnime(searchString string, fields []string) []a.Anime { fields = append([]string{"title", "id"}, fields...) - res, err := animeClient.SearchAnime(searchString, SearchLength, SearchOffset, SearchNSFW, fields) + searchLength, searchOffset := SearchLength, SearchOffset + if AutoSel > 0 { + searchLength = 1 + searchOffset = AutoSel - 1 + } + + res, err := animeClient.SearchAnime(searchString, searchLength, searchOffset, SearchNSFW, fields) if err != nil { fmt.Println("MyAnimeList reported error while searching:", err.Error()) os.Exit(1) @@ -40,7 +46,13 @@ func SearchAnime(searchString string, fields []string) []a.Anime { func SearchManga(searchString string, fields []string) []m.Manga { fields = append([]string{"title", "id"}, fields...) - res, err := mangaClient.SearchManga(searchString, SearchLength, SearchOffset, SearchNSFW, fields) + searchLength, searchOffset := SearchLength, SearchOffset + if AutoSel > 0 { + searchLength = 1 + searchOffset = AutoSel - 1 + } + + res, err := mangaClient.SearchManga(searchString, searchLength, searchOffset, SearchNSFW, fields) if err != nil { fmt.Println("MyAnimeList reported error while searching:", err.Error()) os.Exit(1) diff --git a/ui/search.go b/ui/search.go index 60089f3..a8e8f51 100644 --- a/ui/search.go +++ b/ui/search.go @@ -40,6 +40,15 @@ var AnimeSearchFields []string = []string { // only search animes probably only now func AnimeSearch(label, searchString string) a.Anime { animes := mal.SearchAnime(searchString, AnimeSearchFields) + // don't show selection prompt if --auto-select is passed + if mal.AutoSel > 0 { + if len(animes) > 0 { + return animes[0] + } else { + fmt.Println("Error: Empty response from MyAnimeList while searching for anime.") + os.Exit(1) + } + } for i, anime := range animes { animes[i].DurationSeconds = anime.DurationSeconds / 60 @@ -148,6 +157,15 @@ var MangaSearchFields []string = []string { func MangaSearch(label, searchString string) m.Manga { mangas := mal.SearchManga(searchString, MangaSearchFields) + // don't show selection prompt if --auto-select is passed + if mal.AutoSel > 0 { + if len(mangas) > 0 { + return mangas[0] + } else { + fmt.Println("Error: Empty response from MyAnimeList while searching for manga.") + os.Exit(1) + } + } for i, manga := range mangas { /* I cant find a way to add functions to the details template diff --git a/util/bind_config.go b/util/bind_config.go index 2ab6cc9..ece5c2e 100644 --- a/util/bind_config.go +++ b/util/bind_config.go @@ -33,6 +33,7 @@ type SearchConfig struct { PromptLength int SearchLength int SearchOffset int + AutoSel int SearchNSFW bool } @@ -49,6 +50,13 @@ func BindSearchConfig(flags *pflag.FlagSet) (SearchConfig, error) { err error ) + if flags.Lookup("auto-select").Changed { + conf.AutoSel, err = flags.GetInt("auto-select") + if err != nil {return conf, err} + } else { + conf.AutoSel = viper.GetInt("searching.auto_select_n") + } + if flags.Lookup("prompt-length").Changed { conf.PromptLength, err = flags.GetInt("prompt-length") if err != nil {return conf, err} |