Na verdade, as rotinas de miniaturas do Nautilus vêm da biblioteca libgnome-desktop
, portanto, é possível executar os mesmos miniaturizadores fora do gerenciador de arquivos.
A API é um pouco complexa, mas o seguinte script Python deve ajudar:
#!/usr/bin/python
import os
import sys
from gi.repository import Gio, GnomeDesktop
def make_thumbnail(factory, filename):
mtime = os.path.getmtime(filename)
# Use Gio to determine the URI and mime type
f = Gio.file_new_for_path(filename)
uri = f.get_uri()
info = f.query_info(
'standard::content-type', Gio.FileQueryInfoFlags.NONE, None)
mime_type = info.get_content_type()
if factory.lookup(uri, mtime) is not None:
print "FRESH %s" % uri
return False
if not factory.can_thumbnail(uri, mime_type, mtime):
print "UNSUPPORTED %s" % uri
return False
thumbnail = factory.generate_thumbnail(uri, mime_type)
if thumbnail is None:
print "ERROR %s" % uri
return False
print "OK %s" % uri
factory.save_thumbnail(thumbnail, uri, mtime)
return True
def thumbnail_folder(factory, folder):
for dirpath, dirnames, filenames in os.walk(folder):
for filename in filenames:
make_thumbnail(factory, os.path.join(dirpath, filename))
def main(argv):
factory = GnomeDesktop.DesktopThumbnailFactory()
for filename in argv[1:]:
if os.path.isdir(filename):
thumbnail_folder(factory, filename)
else:
make_thumbnail(factory, filename)
if __name__ == '__main__':
sys.exit(main(sys.argv))
Salve isso em um arquivo e marque-o como executável. Você também pode precisar instalar o pacote gir1.2-gnomedesktop-3.0
se ainda não estiver instalado.
Depois disso, basta invocar o script com os arquivos ou pastas que você deseja usar como argumentos. As miniaturas serão salvas em ~/.thumbnails
, onde aplicativos como o Nautilus esperam encontrá-los.