"pkgutil" --- Utilitário de extensão de pacote
**********************************************

**Código-fonte:** Lib/pkgutil.py

======================================================================

Este módulo fornece utilitários para o sistema de importação, em
particular suporte a pacotes.

class pkgutil.ModuleInfo(module_finder, name, ispkg)

   Um namedtuple que contém um breve resumo das informações de um
   módulo.

   Adicionado na versão 3.6.

pkgutil.extend_path(path, name)

   Estende o caminho de pesquisa para os módulos que compõem um
   pacote. O uso pretendido é colocar o seguinte código no
   "__init__.py" de um pacote:

      from pkgutil import extend_path
      __path__ = extend_path(__path__, __name__)

   Para cada diretório em "sys.path" que tenha um subdiretório que
   corresponda ao nome do pacote, adiciona o subdiretório ao
   "__path__" do pacote. Isto é útil se quisermos distribuir
   diferentes partes de um único pacote lógico como múltiplos
   diretórios.

   Também procura por arquivos "*.pkg" que começam onde "*"
   corresponde ao argumento *name*. Este recurso é semelhante aos
   arquivos "*.pth" (consulte o módulo "site" para mais informações),
   exceto que não considera casos especiais para linhas que começam
   com "import". Um arquivo "*.pkg" é confiável por natureza: além de
   pular linhas em branco e ignorar comentários, todas as entradas
   encontradas em um arquivo "*.pkg" são adicionadas ao caminho,
   independentemente de existirem ou não no sistema de arquivos (este
   é um recurso).

   Se o caminho de entrada não for uma lista (como é o caso de pacotes
   congelados), ele será retornado inalterado. O caminho de entrada
   não é modificado; uma cópia estendida é retornada. Os itens são
   anexados à cópia apenas no final.

   Presume-se que "sys.path" seja uma sequência. Itens de "sys.path"
   que não sejam strings referentes a diretórios existentes são
   ignorados. Itens Unicode em "sys.path" que causam erros quando
   usados como nomes de arquivo podem fazer com que esta função
   levante uma exceção (em linha com o comportamento de
   "os.path.isdir()").

pkgutil.get_importer(path_item)

   Recupera um *localizador* para o *path_item* fornecido.

   O localizador retornado é armazenado em cache em
   "sys.path_importer_cache" se ele foi criado recentemente por um
   gancho de caminho.

   O cache (ou parte dele) pode ser limpo manualmente se uma nova
   varredura de "sys.path_hooks" for necessária.

   Alterado na versão 3.3: Atualizado para ser baseado diretamente em
   "importlib" em vez de depender da emulação de importação interna do
   pacote da **PEP 302**.

pkgutil.iter_importers(fullname='')

   Produz objetos *localizador* para o nome do módulo fornecido.

   Se *fullname* contiver "'.'", os localizadores serão para o pacote
   que contém *fullname*, caso contrário, serão todos os localizadores
   de nível superior registrados (ou seja, aqueles em "sys.meta_path"
   e "sys.path_hooks").

   Se o módulo nomeado estiver em um pacote, esse pacote será
   importado como um efeito colateral da invocação desta função.

   Se nenhum nome de módulo for especificado, todos os localizadores
   de nível superior serão produzidos.

   Alterado na versão 3.3: Atualizado para ser baseado diretamente em
   "importlib" em vez de depender da emulação de importação interna do
   pacote da **PEP 302**.

pkgutil.iter_modules(path=None, prefix='')

   Levanta "ModuleInfo" para todos os submódulos em *path* ou, se
   *path* for "None", todos os módulos de nível superior em
   "sys.path".

   *path* deve ser "None" ou uma lista de caminhos para procurar
   módulos.

   *prefix* é uma string a ser exibida na frente de cada nome de
   módulo na saída.

   Nota:

     Funciona apenas para um *localizador* que define um método
     "iter_modules()". Esta interface não é padrão, portanto, o módulo
     também fornece implementações para
     "importlib.machinery.FileFinder" e "zipimport.zipimporter".

   Alterado na versão 3.3: Atualizado para ser baseado diretamente em
   "importlib" em vez de depender da emulação de importação interna do
   pacote da **PEP 302**.

pkgutil.walk_packages(path=None, prefix='', onerror=None)

   Levanta "ModuleInfo" para todos os módulos recursivamente em
   *path*, ou, se *path* for "None", todos os módulos acessíveis.

   *path* deve ser "None" ou uma lista de caminhos para procurar
   módulos.

   *prefix* é uma string a ser exibida na frente de cada nome de
   módulo na saída.

   Observe que esta função deve importar todos os *pacotes* (*não*
   todos os módulos!) no caminho *path* fornecido, para acessar o
   atributo "__path__" para encontrar submódulos.

   *onerror* é uma função que é chamada com um argumento (o nome do
   pacote que estava sendo importado) caso ocorra alguma exceção
   durante a tentativa de importação de um pacote. Se nenhuma função
   *onerror* for fornecida, "ImportError"s são capturadas e ignoradas,
   enquanto todas as outras exceções são propagadas, encerrando a
   busca.

   Exemplos:

      # lista todos os módulos que o python consegue acessars
      walk_packages()

      # lista todos os submódulos de ctypes
      walk_packages(ctypes.__path__, ctypes.__name__ + '.')

   Nota:

     Funciona apenas para um *localizador* que define um método
     "iter_modules()". Esta interface não é padrão, portanto, o módulo
     também fornece implementações para
     "importlib.machinery.FileFinder" e "zipimport.zipimporter".

   Alterado na versão 3.3: Atualizado para ser baseado diretamente em
   "importlib" em vez de depender da emulação de importação interna do
   pacote da **PEP 302**.

pkgutil.get_data(package, resource)

   Obtém um recurso de um pacote.

   Este é um invólucro para a API "get_data" do *carregador*. O
   argumento *package* deve ser o nome de um pacote, no formato de
   módulo padrão ("foo.bar"). O argumento *resource* deve estar no
   formato de um nome de arquivo relativo, usando "/" como separador
   de caminho. O nome do diretório pai ".." não é permitido, nem um
   nome raiz (começando com "/").

   A função retorna uma string binária que é o conteúdo do recurso
   especificado.

   Para pacotes localizados no sistema de arquivos, que já foram
   importados, isso é o equivalente aproximado de:

      d = os.path.dirname(sys.modules[package].__file__)
      data = open(os.path.join(d, resource), 'rb').read()

   Se o pacote não puder ser localizado ou carregado, ou se usar um
   *carregador* que não oferece suporte a "get_data", "None" será
   retornado. Em particular, o *carregador* para *pacotes de espaço de
   nomes* não oferece suporte a "get_data".

pkgutil.resolve_name(name)

   Resolve um nome a um objeto.

   Essa funcionalidade é usada em vários lugares na biblioteca padrão
   (veja bpo-12915) - e funcionalidades equivalentes também estão
   amplamente utilizadas em pacotes de terceiros, como setuptools,
   Django e Pyramid.

   Espera-se que *name* seja uma string em um dos seguintes formatos,
   onde W é uma abreviação para um identificador Python válido e ponto
   representa um ponto literal nessas pseudo-regexes:

   * "W(.W)*"

   * "W(.W)*:(W(.W)*)?"

   A primeira forma destina-se apenas à retrocompatibilidade. Ela
   presume que parte do nome pontilhado seja um pacote e o restante
   seja um objeto em algum lugar dentro desse pacote, possivelmente
   aninhado dentro de outros objetos. Como o ponto onde o pacote
   termina e a hierarquia de objetos começa não pode ser inferido por
   inspeção, tentativas repetidas de importação devem ser feitas com
   esta forma.

   Na segunda forma, o chamador deixa claro o ponto de divisão por
   meio de um caractere de dois pontos: o nome pontilhado à esquerda
   do caractere de dois pontos representa um pacote a ser importado, e
   o nome pontilhado à direita representa a hierarquia de objetos
   dentro desse pacote. Apenas uma importação é necessária nesta
   forma. Se terminar com caractere de dois pontos, um objeto de
   módulo será retornado.

   A função retornará um objeto (que pode ser um módulo) ou levantará
   uma das seguintes exceções:

   "ValueError" -- se *name* não estiver em um formato reconhecido.

   "ImportError" -- se uma importação falhou quando não deveria.

   "AttributeError" -- Se ocorrer uma falha ao percorrer a hierarquia
   de objetos dentro do pacote importado para chegar ao objeto
   desejado.

   Adicionado na versão 3.9.
