Mercurial > minori
annotate src/services/services.cc @ 392:a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
eventually, we can cancel any outgoing requests, but it's kind of
unnecessary
| author | Paper <paper@tflc.us> |
|---|---|
| date | Fri, 07 Nov 2025 07:10:32 -0500 |
| parents | 47c9f8502269 |
| children | 963047512d34 |
| rev | line source |
|---|---|
| 15 | 1 #include "services/services.h" |
| 10 | 2 #include "core/session.h" |
|
334
948955c3ba81
services: use fmt for setting the status bar
Paper <paper@paper.us.eu.org>
parents:
327
diff
changeset
|
3 #include "core/strings.h" |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
4 #include "gui/translate/anime.h" |
| 10 | 5 #include "services/anilist.h" |
|
317
b1f4d1867ab1
services: VERY initial Kitsu support
Paper <paper@paper.us.eu.org>
parents:
304
diff
changeset
|
6 #include "services/kitsu.h" |
| 10 | 7 |
|
334
948955c3ba81
services: use fmt for setting the status bar
Paper <paper@paper.us.eu.org>
parents:
327
diff
changeset
|
8 #include <fmt/core.h> |
|
948955c3ba81
services: use fmt for setting the status bar
Paper <paper@paper.us.eu.org>
parents:
327
diff
changeset
|
9 |
| 10 | 10 namespace Services { |
| 11 | |
| 369 | 12 void Synchronize() |
| 13 { | |
| 14 session.SetStatusBar( | |
| 15 fmt::format(Strings::Translate("{}: Retrieving anime list..."), Translate::ToString(session.config.service))); | |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
16 |
| 10 | 17 switch (session.config.service) { |
| 279 | 18 case Anime::Service::AniList: AniList::GetAnimeList(); break; |
|
317
b1f4d1867ab1
services: VERY initial Kitsu support
Paper <paper@paper.us.eu.org>
parents:
304
diff
changeset
|
19 case Anime::Service::Kitsu: Kitsu::GetAnimeList(); break; |
|
112
80f49f623d30
locale: allow switching locales without restarting
Paper <mrpapersonic@gmail.com>
parents:
81
diff
changeset
|
20 default: break; |
| 10 | 21 } |
| 22 } | |
| 23 | |
|
392
a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
Paper <paper@tflc.us>
parents:
369
diff
changeset
|
24 /* This is specific to Kitsu; by default they don't provide genre |
|
a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
Paper <paper@tflc.us>
parents:
369
diff
changeset
|
25 * nor producer info so we grab it only when we need it (i.e. when |
|
a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
Paper <paper@tflc.us>
parents:
369
diff
changeset
|
26 * the anime info list is open). |
|
a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
Paper <paper@tflc.us>
parents:
369
diff
changeset
|
27 * |
|
a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
Paper <paper@tflc.us>
parents:
369
diff
changeset
|
28 * The backend should automatically detect whether this is unnecessary |
|
a72d6d7b3568
anime_info: don't need to wait on the thread, just disconnect
Paper <paper@tflc.us>
parents:
369
diff
changeset
|
29 * and simply return false if it is. */ |
| 369 | 30 bool RetrieveAnimeMetadata(int id) |
| 31 { | |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
32 switch (session.config.service) { |
| 369 | 33 case Anime::Service::Kitsu: return Kitsu::RetrieveAnimeMetadata(id); |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
34 default: return false; |
|
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
35 } |
|
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
36 } |
|
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
37 |
| 369 | 38 std::vector<int> Search(const std::string &search) |
| 39 { | |
| 40 session.SetStatusBar( | |
| 41 fmt::format(Strings::Translate("{}: Requesting search query..."), Translate::ToString(session.config.service))); | |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
42 |
| 250 | 43 switch (session.config.service) { |
| 279 | 44 case Anime::Service::AniList: return AniList::Search(search); |
|
317
b1f4d1867ab1
services: VERY initial Kitsu support
Paper <paper@paper.us.eu.org>
parents:
304
diff
changeset
|
45 case Anime::Service::Kitsu: return Kitsu::Search(search); |
| 250 | 46 default: return {}; |
| 47 } | |
| 48 } | |
| 49 | |
| 369 | 50 bool GetSeason(Anime::Season season) |
| 51 { | |
| 52 session.SetStatusBar(fmt::format(Strings::Translate("{}: Retrieving anime season data..."), | |
| 53 Translate::ToString(session.config.service))); | |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
54 |
|
304
2115488eb302
*: add very early season searcher
Paper <paper@paper.us.eu.org>
parents:
279
diff
changeset
|
55 switch (session.config.service) { |
|
327
b5d6c27c308f
anime: refactor Anime::SeriesSeason to Season class
Paper <paper@paper.us.eu.org>
parents:
325
diff
changeset
|
56 case Anime::Service::AniList: return AniList::GetSeason(season); |
|
b5d6c27c308f
anime: refactor Anime::SeriesSeason to Season class
Paper <paper@paper.us.eu.org>
parents:
325
diff
changeset
|
57 case Anime::Service::Kitsu: return Kitsu::GetSeason(season); |
|
304
2115488eb302
*: add very early season searcher
Paper <paper@paper.us.eu.org>
parents:
279
diff
changeset
|
58 default: return {}; |
|
2115488eb302
*: add very early season searcher
Paper <paper@paper.us.eu.org>
parents:
279
diff
changeset
|
59 } |
|
2115488eb302
*: add very early season searcher
Paper <paper@paper.us.eu.org>
parents:
279
diff
changeset
|
60 } |
|
2115488eb302
*: add very early season searcher
Paper <paper@paper.us.eu.org>
parents:
279
diff
changeset
|
61 |
| 369 | 62 void UpdateAnimeEntry(int id) |
| 63 { | |
| 64 session.SetStatusBar(fmt::format(Strings::Translate("{}: Updating remote anime entry..."), | |
| 65 Translate::ToString(session.config.service))); | |
|
320
1b5c04268d6a
services/kitsu: ACTUALLY finish GetAnimeList
Paper <paper@paper.us.eu.org>
parents:
317
diff
changeset
|
66 |
|
52
0c4138de2ea7
anime list: we are finally read-write
Paper <mrpapersonic@gmail.com>
parents:
47
diff
changeset
|
67 switch (session.config.service) { |
| 279 | 68 case Anime::Service::AniList: AniList::UpdateAnimeEntry(id); break; |
|
317
b1f4d1867ab1
services: VERY initial Kitsu support
Paper <paper@paper.us.eu.org>
parents:
304
diff
changeset
|
69 case Anime::Service::Kitsu: Kitsu::UpdateAnimeEntry(id); break; |
|
52
0c4138de2ea7
anime list: we are finally read-write
Paper <mrpapersonic@gmail.com>
parents:
47
diff
changeset
|
70 default: break; |
|
0c4138de2ea7
anime list: we are finally read-write
Paper <mrpapersonic@gmail.com>
parents:
47
diff
changeset
|
71 } |
|
0c4138de2ea7
anime list: we are finally read-write
Paper <mrpapersonic@gmail.com>
parents:
47
diff
changeset
|
72 } |
|
0c4138de2ea7
anime list: we are finally read-write
Paper <mrpapersonic@gmail.com>
parents:
47
diff
changeset
|
73 |
|
44
619cbd6e69f9
filesystem: fix CreateDirectories function
Paper <mrpapersonic@gmail.com>
parents:
15
diff
changeset
|
74 }; // namespace Services |
