forked from romanvm/Kodistubs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
xbmcplugin.py
210 lines (171 loc) · 6.85 KB
/
xbmcplugin.py
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
198
199
200
201
202
203
204
205
206
207
208
209
210
## @package xbmcplugin
# Functions for XBMC plugins.
#
SORT_METHOD_ALBUM = 13
SORT_METHOD_ALBUM_IGNORE_THE = 14
SORT_METHOD_ARTIST = 11
SORT_METHOD_ARTIST_IGNORE_THE = 12
SORT_METHOD_BITRATE = 39
SORT_METHOD_CHANNEL = 38
SORT_METHOD_COUNTRY = 16
SORT_METHOD_DATE = 3
SORT_METHOD_DATEADDED = 19
SORT_METHOD_DATE_TAKEN = 40
SORT_METHOD_DRIVE_TYPE = 6
SORT_METHOD_DURATION = 8
SORT_METHOD_EPISODE = 22
SORT_METHOD_FILE = 5
SORT_METHOD_FULLPATH = 32
SORT_METHOD_GENRE = 15
SORT_METHOD_LABEL = 1
SORT_METHOD_LABEL_IGNORE_FOLDERS = 33
SORT_METHOD_LABEL_IGNORE_THE = 2
SORT_METHOD_LASTPLAYED = 34
SORT_METHOD_LISTENERS = 36
SORT_METHOD_MPAA_RATING = 28
SORT_METHOD_NONE = 0
SORT_METHOD_PLAYCOUNT = 35
SORT_METHOD_PLAYLIST_ORDER = 21
SORT_METHOD_PRODUCTIONCODE = 26
SORT_METHOD_PROGRAM_COUNT = 20
SORT_METHOD_SIZE = 4
SORT_METHOD_SONG_RATING = 27
SORT_METHOD_STUDIO = 30
SORT_METHOD_STUDIO_IGNORE_THE = 31
SORT_METHOD_TITLE = 9
SORT_METHOD_TITLE_IGNORE_THE = 10
SORT_METHOD_TRACKNUM = 7
SORT_METHOD_UNSORTED = 37
SORT_METHOD_VIDEO_RATING = 18
SORT_METHOD_VIDEO_RUNTIME = 29
SORT_METHOD_VIDEO_SORT_TITLE = 24
SORT_METHOD_VIDEO_SORT_TITLE_IGNORE_THE = 25
SORT_METHOD_VIDEO_TITLE = 23
SORT_METHOD_VIDEO_YEAR = 17
#noinspection PyUnusedLocal
def addDirectoryItem(handle, url, listitem, isFolder=False, totalItems=0):
"""Callback function to pass directory contents back to XBMC.
Returns a bool for successful completion.
handle: integer - handle the plugin was started with.
url: string - url of the entry. would be plugin:// for another virtual directory.
listitem: ListItem - item to add.
isFolder: bool - True=folder / False=not a folder.
totalItems: integer - total number of items that will be passed. (used for progressbar)
Example:
if not xbmcplugin.addDirectoryItem(int(sys.argv[1]), 'F:\\Trailers\\300.mov', listitem, totalItems=50):
break
"""
return bool
#noinspection PyUnusedLocal
def addDirectoryItems(handle, items, totalItems=0):
"""Callback function to pass directory contents back to XBMC as a list.
Returns a bool for successful completion.
handle: integer - handle the plugin was started with.
items: List - list of (url, listitem[, isFolder]) as a tuple to add.
totalItems: integer - total number of items that will be passed. (used for progressbar)
Note:
Large lists benefit over using the standard addDirectoryItem().
You may call this more than once to add items in chunks.
Example:
if not xbmcplugin.addDirectoryItems(int(sys.argv[1]), [(url, listitem, False,)]:
raise
"""
return bool
#noinspection PyUnusedLocal
def endOfDirectory(handle, succeeded=True, updateListing=False, cacheToDisc=True):
"""Callback function to tell XBMC that the end of the directory listing in a virtualPythonFolder module is reached.
handle: integer - handle the plugin was started with.
succeeded: bool - True=script completed successfully/False=Script did not.
updateListing: bool - True=this folder should update the current listing/False=Folder is a subfolder.
cacheToDisc: bool - True=Folder will cache if extended time/False=this folder will never cache to disc.
Example:
xbmcplugin.endOfDirectory(int(sys.argv[1]), cacheToDisc=False)
"""
pass
#noinspection PyUnusedLocal
def setResolvedUrl(handle, succeeded, listitem):
"""Callback function to tell XBMC that the file plugin has been resolved to a url
handle: integer - handle the plugin was started with.
succeeded: bool - True=script completed successfully/False=Script did not.
listitem: ListItem - item the file plugin resolved to for playback.
Example:
xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, listitem)
"""
pass
#noinspection PyUnusedLocal
def addSortMethod(handle, sortMethod, label2="%D"):
"""Adds a sorting method for the media list.
handle: integer - handle the plugin was started with.
sortMethod: integer - number for sortmethod see FileItem.h.
label2Mask: string - the label mask to use for the second label. Defaults to '%D'
applies to: SORT_METHOD_NONE, SORT_METHOD_UNSORTED, SORT_METHOD_VIDEO_TITLE,
SORT_METHOD_TRACKNUM, SORT_METHOD_FILE, SORT_METHOD_TITLE
SORT_METHOD_TITLE_IGNORE_THE, SORT_METHOD_LABEL
SORT_METHOD_LABEL_IGNORE_THE
Example:
xbmcplugin.addSortMethod(int(sys.argv[1]), xbmcplugin.SORT_METHOD_TITLE)
"""
pass
#noinspection PyUnusedLocal
def getSetting(handle, id):
"""Returns the value of a setting as a string.
handle: integer - handle the plugin was started with.
id: string - id of the setting that the module needs to access.
Example:
apikey = xbmcplugin.getSetting(int(sys.argv[1]), 'apikey')
"""
return str
#noinspection PyUnusedLocal
def setSetting(handle, id, value):
"""Sets a plugin setting for the current running plugin.
handle: integer - handle the plugin was started with.
id: string - id of the setting that the module needs to access.
value: string or unicode - value of the setting.
Example:
xbmcplugin.setSetting(int(sys.argv[1]), id='username', value='teamxbmc')
"""
pass
#noinspection PyUnusedLocal
def setContent(handle, content):
"""Sets the plugins content.
handle: integer - handle the plugin was started with.
content: string - content type (eg. movies).
Note:
Possible values for content: files, songs, artists, albums, movies, tvshows, episodes, musicvideos
Example:
xbmcplugin.setContent(int(sys.argv[1]), 'movies')
"""
pass
#noinspection PyUnusedLocal
def setPluginCategory(handle, category):
"""Sets the plugins name for skins to display.
handle: integer - handle the plugin was started with.
category: string or unicode - plugins sub category.
Example:
xbmcplugin.setPluginCategory(int(sys.argv[1]), 'Comedy')
"""
pass
#noinspection PyUnusedLocal
def setPluginFanart(handle, image=None, color1=None, color2=None, color3=None):
"""Sets the plugins fanart and color for skins to display.
handle: integer - handle the plugin was started with.\n"
image: string - path to fanart image.
color1: hexstring - color1. (e.g. '0xFFFFFFFF')
color2: hexstring - color2. (e.g. '0xFFFF3300')
color3: hexstring - color3. (e.g. '0xFF000000')
Example:
xbmcplugin.setPluginFanart(int(sys.argv[1]), 'special://home/addons/plugins/video/Apple movie trailers II/fanart.png', color2='0xFFFF3300')
"""
pass
#noinspection PyUnusedLocal
def setProperty(handle, key, value):
"""Sets a container property for this plugin.
handle: integer - handle the plugin was started with.
key: string - property name.
value: string or unicode - value of property.
Note:
Key is NOT case sensitive.
Example:
xbmcplugin.setProperty(int(sys.argv[1]), 'Emulator', 'M.A.M.E.')
"""
pass