[RELEASE] Texture Cache Maintenance utility - Printable Version +- Kodi Community Forum (https://forum.kodi.tv) +-- Forum: Support (https://forum.kodi.tv/forumdisplay.php?fid=33) +--- Forum: Supplementary Tools for Kodi (https://forum.kodi.tv/forumdisplay.php?fid=116) +--- Thread: [RELEASE] Texture Cache Maintenance utility (/showthread.php?tid=158373) Pages:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
|
RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-23 (2013-11-23, 01:39)Enlightened Wrote: I know xbmc isn't caching the fanart I've added myself because when I go into the extrafanart folder and delete everything on my main machine That is odd, and I can't really explain it, as that isn't really how XBMC is meant to work. Check your xbmc.log for errors (enabling debug may help) - maybe XBMC can't write to your thumbnails folder. Can you paste the output from "jd movies <moviename>" where <moviename> is one of your movies that has this extrafanart? If it's your tv shows that have extrafanart, substitute "tvshows" for "movies" and upload the output to pastebin... (2013-11-23, 01:39)Enlightened Wrote: My music is a smb path. But when I added in fanart myself the browser doesn't give me the option of adding it with a smb path so I have to add the folder. Everything I have is on a flexraid D:/music/artist with full sharing enabled. Unless you have the Flexraid server mapped as the D:\ drive on all of your clients that D:\ path is simply not going to work. You need to find a way to add artwork that uses the smb path. Unfortunately I don't know why you can't select the smb path, that's maybe something to resolve first. Another option may be to try an addon such as Artwork Downloader which can find and use your local artwork, then set the correct smb path, but resolving your issue with smb browsing is probably the first step. RE: [RELEASE] Texture Cache Maintenance utility - Enlightened - 2013-11-23 Quote:Unless you have the Flexraid server mapped as the D:\ drive on all of your clients that D:\ path is simply not going to work. You need to find a way to add artwork that uses the smb path. Unfortunately I don't know why you can't select the smb path, that's maybe something to resolve first. Another option may be to try an addon such as Artwork Downloader which can find and use your local artwork, then set the correct smb path, but resolving your issue with smb browsing is probably the first step. artwork downloader works with music? Solved my problem. when adding in artwork myself i was going straight to the extrafanart folder and adding longstringoftext.jpg. And it was not caching it to the thumbnails. So I went back and copied longstringoftext.jpg to the artist folder and renamed to fanart.jpg then added that in xbmc and it finaly cached it to the thumbnails so now its adding it to my other machines. I only had to manually add about 10 artist out of 300. So everything was perfect except for thoes 10 which was annoying. thanks @Milhouse again for the awesome help. RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-23 (2013-11-23, 02:38)Enlightened Wrote: artwork downloader works with music? Ah, maybe not - it supports musicvideo, not entirely sure what that is as I don't use it. RE: [RELEASE] Texture Cache Maintenance utility - Enlightened - 2013-11-23 (2013-11-23, 02:40)MilhouseVH Wrote:(2013-11-23, 02:38)Enlightened Wrote: artwork downloader works with music? concerts and music videos which scrapers aren't good at because not a lot of people use it. So no one adds to scraper databases. RE: [RELEASE] Texture Cache Maintenance utility - Serak - 2013-11-23 Hey Milhouse, I'm running into an bug with the imdb function, which I think is caused by attempting to get the rating of a movie that doesn't yet have one (ie, has less than 5 votes on imdb) Code: C:\Tools\python33>python texturecache.py imdb movies francisco Where the movie it's trying to scrape from imdb is http://www.imdb.com/title/tt2294804 RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-23 (2013-11-23, 04:10)Serak Wrote: Where the movie it's trying to scrape from imdb is http://www.imdb.com/title/tt2294804 Many thanks, will add a fix to the next release. RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-23 (2013-11-23, 02:01)MilhouseVH Wrote:(2013-11-23, 01:39)Enlightened Wrote: I know xbmc isn't caching the fanart I've added myself because when I go into the extrafanart folder and delete everything on my main machine @Enlightened: Thanks for sending me your movie dumps and Textures13.db, it's starting to make a bit more sense. If I understand how extrafanart is working, it's artwork that is only available to skins. extrafanart doesn't appear in the media library, at least not as artwork assigned to any particular movie or tvshow. It exists within a special directory (/extrafanart, below the movie/tvshow) and the skin has to check for this directory and - if it exists - to then use (and display) whatever artwork files are present. This would explain why your extrafanart disappeared when you removed the extrafanart directory (or artwork) - the skin could no longer find anything to display. It is possible to cache extrafanart however, so I'll see about adding similar directory checks (though it might be disabled by default). This extrafanart behaviour also has a knock-on effect for the prune functionality, as none of your cached extrafanart artwork is present in your media library and thus a prime candidate for removal. There's also extrathumbs which will need to be handled in the same way as extrafanart. @Serak: I've just pushed v1.1.4 which fixes the N/A rating. RE: [RELEASE] Texture Cache Maintenance utility - Serak - 2013-11-23 (2013-11-23, 04:45)MilhouseVH Wrote: @Serak: I've just pushed v1.1.4 which fixes the N/A rating. That was quick! - Thanks for all your hard work RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-23 texturecache.py (Version 1.1.5):
@Enlightened: Please let me know how you get on. If there are any problems, a logfile would be most useful - add @logfile=c:\tc.log to your command line then email me the zipped tc.log file. Thanks. RE: [RELEASE] Texture Cache Maintenance utility - Enlightened - 2013-11-24 (2013-11-23, 15:27)MilhouseVH Wrote: texturecache.py (Version 1.1.5): Awesome trying it now. thanks. [edit] Not sure if I'm enabling it correctly. I'm putting c:\texturecache.py @cache.extrafanart=yes but a list of commands comes up. RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-24 (2013-11-24, 03:06)Enlightened Wrote: [edit] Not sure if I'm enabling it correctly. I'm putting c:\texturecache.py @cache.extrafanart=yes The @property=value notation is an alternative to adding properties to your configuration file (texturecache.cfg). You would specify these command line properties in addition to whatever action you are trying to perform, eg: Code: c:\texturecache.py @cache.extrafanart=yes c movies would pre-load the cache for your movies, with extrafanart support enabled. Obviously if you want to permanently enable extrafanart support, then add: Code: cache.extrafanart=yes RE: [RELEASE] Texture Cache Maintenance utility - Enlightened - 2013-11-24 Quote:Obviously if you want to permanently enable extrafanart support, then add: Got it. Running now looks like its going good. Thank you. RE: [RELEASE] Texture Cache Maintenance utility - redglory - 2013-11-24 Hi, First of all just the script I most miss in XBMC as it is quite hard to replace and re-cache fanart in every movie (doing it manually i PITA) I already have my desired fanart inside every movie folder locally. Would like to know the command to re-cache my movie and tvshow art replacing possible remote ones with my local art. Looking forward to also prune unused art to free some space. I scrape my fanart using EmberMM (using CPS post-processing script) and i also update XBMC library but sometimes like to change fanart and would like to reload it automatically (using your script) on XBMC. Great work! RE: [RELEASE] Texture Cache Maintenance utility - Milhouse - 2013-11-24 (2013-11-24, 16:22)redglory Wrote: Hi, If you want to replace your remote artwork with local artwork, you can use the mklocal.py script (which is in the tools folder on github. Download the source code and if using Linux, apply the correct permissions: chmod +x ./mklocal.py. This script exists to download remote artwork to your local filesystem, but it will only do so if local artwork doesn't already exist (ie. it won't overwrite) so in your case there should be nothing to download. Also, having determined the availability of the relevant local artwork, the script can generate "workitems" to be passed to "texturecache.py set" in order to update your media library with the new local urls. As your artwork is already available locally, you'll want to pass the --readonly switch so that mklocal.py won't download any of your current remote artwork and will only use whatever it finds locally. If you don't pass --readonly, it will download the remote artwork for artwork types that don't already exist locally, so you could leave it off and mklocal.py will then "fill in" any gaps in your local artwork collection by downloading whatever is missing. Probably best to specify --readonly to begin with though, at least until you feel comfortable with how it all works. The trickiest part is mapping your XBMC source to your OS mount point, which is done with the --prefix and --local switches. For instance my XBMC source is "nfs://192.168.0.3/mnt/share/media" and the equivalent OS mount point is "/freenas/media" so the relevant switches for me are "--prefix nfs://192.168.0.3/mnt/share/media --local /freenas/media". This means the script can map "nfs://192.168.0.3/mnt/share/media" to "/freenas/media" and vice versa. It only requires this mapping in order to gain read/write access to your local media, all XBMC urls will retain their current prefix (nfs:, smb:, whatever). I would suggest working with just a single movie until you get the hang of things. Then it's just a case of "feeding" mklocal.py a list of movies or tvshows to process, eg: Code: ./texturecache.py jd movies avatar | ./mklocal.py --readonly --prefix nfs://192.168.0.3/mnt/share/media --local /freenas/media --artwork poster fanart --output The above command would output "workitems" for the movie Avatar IF any changes are required. mklocal.py doesn't update your media library itself, it can only generate the "instructions" which must then be processed by "texturecache.py set". Example output from mklocal.py might be: Code: [ which is an instruction to set a new poster url on the movie. Add "--season" and/or "--episode" switches if you want to also process artwork for your tvshow seasons and episodes. Add additional artwork types (clearart, clearlogo, discart etc.) as you see fit. Add the "-v" switch to view debug output and whatever processing is taking place. See "./mklocal.py --help" for more details. Once you are happy with how mklocal.py is working, pass the output to "texturecache.py set" in order to apply the changes to your media library, eg.: Code: ./texturecache.py jd movies | ./mklocal.py --readonly --prefix nfs://192.168.0.3/mnt/share/media --local /freenas/media --artwork poster fanart --output | ./texturecache.py set though note that JSON support for the modification of season art isn't supported until JSON API v6.10.0, which means a recent Gotham nightly - any attempts to change season art pre-v6.10.0 will result in a warning from "texturecache.py set" and the season art request will be ignored. Updating movies via JSON can be quite a slow process and running workitems through "texturecache.py set" can take a while! Once you have made changes to your media library you'll want to pre-load the cache with the now local artwork ("./texturecache.py c movies"), and finally prune your cache to remove all trace of the old remote artwork ("./texturecache.py P"). So just to be clear: As long as you pass "--readonly" to mklocal.py, no modifications will be made to your local filesystem. And as long as you don't pass anything to "texturecache.py set" no changes will be applied to your media library. RE: [RELEASE] Texture Cache Maintenance utility - redglory - 2013-11-25 Thanks very much for your detailed info. I have my movies inside E:\Movies each with movie name folder, like this: Uploaded with ImageShack.us And have Frodo 12.2 installed. Tried to run your script like this: Code: ./texturecache.py jd movies | tools/mklocal.py --local E:/Movies --prefix E:/Movies --artwork fanart poster clearlogo clearart --output fixup.dat Code: ** SKIPPING ** - Bad Prefix - Zombieland am I looking into this in the wrong way?! tc.log |