Source code for xbmcplugin

# This file is generated from Kodi source code and post-edited
# to correct code style and docstrings formatting.
# License: GPL v.3 <https://www.gnu.org/licenses/gpl-3.0.en.html>

"""
**Plugin functions on Kodi.**

Offers classes and functions that allow a developer to present information through Kodi's standard menu structure. While
plugins don't have the same flexibility as scripts, they boast significantly quicker development time and a more
consistent user experience.
"""

from __future__ import annotations
from typing import List, Optional, TYPE_CHECKING, Tuple

if TYPE_CHECKING:
    import xbmcgui

__kodistubs__ = True

SORT_METHOD_ALBUM = 14
SORT_METHOD_ALBUM_IGNORE_THE = 15
SORT_METHOD_ARTIST = 11
SORT_METHOD_ARTIST_IGNORE_THE = 13
SORT_METHOD_BITRATE = 43
SORT_METHOD_CHANNEL = 41
SORT_METHOD_COUNTRY = 17
SORT_METHOD_DATE = 3
SORT_METHOD_DATEADDED = 21
SORT_METHOD_DATE_TAKEN = 44
SORT_METHOD_DRIVE_TYPE = 6
SORT_METHOD_DURATION = 8
SORT_METHOD_EPISODE = 24
SORT_METHOD_FILE = 5
SORT_METHOD_FULLPATH = 35
SORT_METHOD_GENRE = 16
SORT_METHOD_LABEL = 1
SORT_METHOD_LABEL_IGNORE_FOLDERS = 36
SORT_METHOD_LABEL_IGNORE_THE = 2
SORT_METHOD_LASTPLAYED = 37
SORT_METHOD_LISTENERS = 39
SORT_METHOD_MPAA_RATING = 31
SORT_METHOD_NONE = 0
SORT_METHOD_PLAYCOUNT = 38
SORT_METHOD_PLAYLIST_ORDER = 23
SORT_METHOD_PRODUCTIONCODE = 28
SORT_METHOD_PROGRAM_COUNT = 22
SORT_METHOD_SIZE = 4
SORT_METHOD_SONG_RATING = 29
SORT_METHOD_SONG_USER_RATING = 30
SORT_METHOD_STUDIO = 33
SORT_METHOD_STUDIO_IGNORE_THE = 34
SORT_METHOD_TITLE = 9
SORT_METHOD_TITLE_IGNORE_THE = 10
SORT_METHOD_TRACKNUM = 7
SORT_METHOD_UNSORTED = 40
SORT_METHOD_VIDEO_ORIGINAL_TITLE = 49
SORT_METHOD_VIDEO_ORIGINAL_TITLE_IGNORE_THE = 50
SORT_METHOD_VIDEO_RATING = 19
SORT_METHOD_VIDEO_RUNTIME = 32
SORT_METHOD_VIDEO_SORT_TITLE = 26
SORT_METHOD_VIDEO_SORT_TITLE_IGNORE_THE = 27
SORT_METHOD_VIDEO_TITLE = 25
SORT_METHOD_VIDEO_USER_RATING = 20
SORT_METHOD_VIDEO_YEAR = 18


[docs] def addDirectoryItem( handle: int, url: str, listitem: xbmcgui.ListItem, isFolder: bool = False, totalItems: int = 0, ) -> bool: """ Callback function to pass directory contents back to Kodi. :param handle: integer - handle the plugin was started with. :param url: string - url of the entry. would be ``plugin://`` for another virtual directory :param listitem: ListItem - item to add. :param isFolder: [opt] bool - True=folder / False=not a folder(default). :param totalItems: [opt] integer - total number of items that will be passed.(used for progressbar) :return: Returns a bool for successful completion. .. note:: You can use the above as keywords for arguments and skip certain optional arguments. Once you use a keyword, all following arguments require the keyword. Example:: .. if not xbmcplugin.addDirectoryItem(int(sys.argv[1]), 'F:\\\\Trailers\\\\300.mov', listitem, totalItems=50): break .. """ return True
[docs] def addDirectoryItems(handle: int, items: List[Tuple[str, xbmcgui.ListItem, bool]], totalItems: int = 0) -> bool: """ Callback function to pass directory contents back to Kodi as a list. :param handle: integer - handle the plugin was started with. :param items: List - list of (url, listitem[, isFolder]) as a tuple to add. :param totalItems: [opt] integer - total number of items that will be passed.(used for progressbar) :return: Returns a bool for successful completion. 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 True
[docs] def endOfDirectory(handle: int, succeeded: bool = True, updateListing: bool = False, cacheToDisc: bool = True) -> None: """ Callback function to tell Kodi that the end of the directory listing in a virtualPythonFolder module is reached. :param handle: integer - handle the plugin was started with. :param succeeded: [opt] bool - True=script completed successfully(Default)/False=Script did not. :param updateListing: [opt] bool - True=this folder should update the current listing/False=Folder is a subfolder(Default). :param cacheToDisc: [opt] bool - True=Folder will cache if extended time(default)/False=this folder will never cache to disc. Example:: .. xbmcplugin.endOfDirectory(int(sys.argv[1]), cacheToDisc=False) .. """ pass
[docs] def setResolvedUrl(handle: int, succeeded: bool, listitem: xbmcgui.ListItem) -> None: """ Callback function to tell Kodi that the file plugin has been resolved to a url :param handle: integer - handle the plugin was started with. :param succeeded: bool - True=script completed successfully/False=Script did not. :param listitem: ListItem - item the file plugin resolved to for playback. Example:: .. xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, listitem) .. """ pass
[docs] def addSortMethod(handle: int, sortMethod: int, labelMask: str = "", label2Mask: str = "") -> None: """ Adds a sorting method for the media list. :param handle: integer - handle the plugin was started with. :param sortMethod: integer - see available sort methods at the bottom (or see SortUtils). :param labelMask: [opt] string - the label mask to use for the first label. :param label2Mask: [opt] string - the label mask to use for the second label. Defaults to ``%D`` +-----------------------------------------------------+------------------------------------------------------+ | Value | Description | +=====================================================+======================================================+ | xbmcplugin.SORT_METHOD_NONE | Do not sort | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_LABEL | Sort by label | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_LABEL_IGNORE_THE | Sort by the label and ignore "The" before | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_DATE | Sort by the date | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_SIZE | Sort by the size | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_FILE | Sort by the file | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_DRIVE_TYPE | Sort by the drive type | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_TRACKNUM | Sort by the track number | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_DURATION | Sort by the duration | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_TITLE | Sort by the title | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_TITLE_IGNORE_THE | Sort by the title and ignore "The" before | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_ARTIST | Sort by the artist | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_ARTIST_IGNORE_THE | Sort by the artist and ignore "The" before | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_ALBUM | Sort by the album | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_ALBUM_IGNORE_THE | Sort by the album and ignore "The" before | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_GENRE | Sort by the genre | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_SORT_METHOD_VIDEO_YEAR, | Sort by the year | | xbmcplugin.SORT_METHOD_YEAR | | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_VIDEO_RATING | Sort by the video rating | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_PROGRAM_COUNT | Sort by the program count | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_PLAYLIST_ORDER | Sort by the playlist order | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_EPISODE | Sort by the episode | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_VIDEO_TITLE | Sort by the video title | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_VIDEO_SORT_TITLE | Sort by the video sort title | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_VIDEO_SORT_TITLE_IGNORE_THE | Sort by the video sort title and ignore "The" before | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_PRODUCTIONCODE | Sort by the production code | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_SONG_RATING | Sort by the song rating | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_MPAA_RATING | Sort by the mpaa rating | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_VIDEO_RUNTIME | Sort by video runtime | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_STUDIO | Sort by the studio | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_STUDIO_IGNORE_THE | Sort by the studio and ignore "The" before | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_UNSORTED | Use list not sorted | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_BITRATE | Sort by the bitrate | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_LISTENERS | Sort by the listeners | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_COUNTRY | Sort by the country | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_DATEADDED | Sort by the added date | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_FULLPATH | Sort by the full path name | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_LABEL_IGNORE_FOLDERS | Sort by the label names and ignore related folder | | | names | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_LASTPLAYED | Sort by last played date | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_PLAYCOUNT | Sort by the play count | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_CHANNEL | Sort by the channel | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_DATE_TAKEN | Sort by the taken date | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_VIDEO_USER_RATING | Sort by the rating of the user of video | +-----------------------------------------------------+------------------------------------------------------+ | xbmcplugin.SORT_METHOD_SONG_USER_RATING | Sort by the rating of the user of song | +-----------------------------------------------------+------------------------------------------------------+ .. note:: to add multiple sort methods just call the method multiple times. .. note:: see LabelFormatter.cpp for list of available metadata masks @python_v13 Added new sort **SORT_METHOD_DATE_TAKEN**, **SORT_METHOD_COUNTRY**, **SORT_METHOD_DATEADDED**, **SORT_METHOD_FULLPATH**, **SORT_METHOD_LABEL_IGNORE_FOLDERS**, **SORT_METHOD_LASTPLAYED**, **SORT_METHOD_PLAYCOUNT**, **SORT_METHOD_CHANNEL**. @python_v17 Added new sort **SORT_METHOD_VIDEO_USER_RATING**. @python_v19 Added new option **labelMask**. Example:: .. xbmcplugin.addSortMethod(int(sys.argv[1]), xbmcplugin.SORTMETHOD_DATEADDED) .. """ pass
[docs] def getSetting(handle: int, id: str) -> str: """ Returns the value of a setting as a string. :param handle: integer - handle the plugin was started with. :param id: string - id of the setting that the module needs to access. :return: Setting value as string .. note:: You can use the above as a keyword. Example:: .. apikey = xbmcplugin.getSetting(int(sys.argv[1]), 'apikey') .. """ return ""
[docs] def setSetting(handle: int, id: str, value: str) -> None: """ Sets a plugin setting for the current running plugin. :param handle: integer - handle the plugin was started with. :param id: string - id of the setting that the module needs to access. :param value: string or unicode - value of the setting. Example:: .. xbmcplugin.setSetting(int(sys.argv[1]), id='username', value='teamxbmc') .. """ pass
[docs] def setContent(handle: int, content: str) -> None: """ Sets the plugins content. :param handle: integer - handle the plugin was started with. :param content: string - content type (eg. movies) Use **videos** for all videos which do not apply to the more specific mentioned ones like "movies", "episodes" etc. A good example is youtube. @python_v18 Added new **games** content Example:: .. xbmcplugin.setContent(int(sys.argv[1]), 'movies') .. """ pass
[docs] def setPluginCategory(handle: int, category: str) -> None: """ Sets the plugins name for skins to display. :param handle: integer - handle the plugin was started with. :param category: string or unicode - plugins sub category. Example:: .. xbmcplugin.setPluginCategory(int(sys.argv[1]), 'Comedy') .. """ pass
[docs] def setPluginFanart( handle: int, image: Optional[str] = None, color1: Optional[str] = None, color2: Optional[str] = None, color3: Optional[str] = None, ) -> None: """ Sets the plugins fanart and color for skins to display. :param handle: integer - handle the plugin was started with. :param image: [opt] string - path to fanart image. :param color1: [opt] hexstring - color1. (e.g. '0xFFFFFFFF') :param color2: [opt] hexstring - color2. (e.g. '0xFFFF3300') :param color3: [opt] 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
[docs] def setProperty(handle: int, key: str, value: str) -> None: """ Sets a container property for this plugin. :param handle: integer - handle the plugin was started with. :param key: string - property name. :param 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