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}  |