Description

Shared MIME-info Database specification implementation

Package Information

Version0.4.2 (2016-Sep-26)
Repository https://github.com/FreeSlave/mime
LicenseBSL-1.0
CopyrightCopyright © 2015-2016, Roman Chistokhodov
AuthorsRoman Chistokhodov
Registered byRoman Chistokhodov
Sub packages
mime:database
A minimal D application.
mime:test
A minimal D application.
Dependencies

xdgpaths

Installation

To use this package, put the following dependency into your project's dependencies section:

dub.json
dub.sdl

Readme

Mime

Shared MIME-info database specification implementation in D programming language. Shared MIME-info database helps to determine media type of file by its name or contents.

Build Status Coverage Status

Online documentation

Features

Implemented features

  • Reading and using mime.cache files to match file names against glob patterns, match file contents against magic rules, resolve aliases and find mime type parents.
  • Reading various shared MIME-info database files in mime/ subfolder, e.g. globs2, magic and others.
  • treemagic support.

Missing features

  • Reading MIME types from mime/packages sources and mime/MEDIA folders (requires xml library).
  • Determining MIME type by XMLnamespace if document is xml (requires streaming xml library).

Examples

Mime Database

Run to detect mime types of files.

dub run :database -- detect README.md source .gitignore lib/libmime.a examples/database/bin/mime_database /var/run/acpid.socket dub.json /dev/sda

Automated mime path detection works only on Freedesktop platforms. On other systmes or for testing purposes it's possible to use mimepath option to set alternate path to mime/ subfolder. E.g. on Windows with KDE installed it would be:

dub run :database -- --mimepath=C:\ProgramData\KDE\share\mime detect README.md source .gitignore lib/mime.lib examples/mimedatabase/bin/mimedatabase.exe dub.json

Run to print info about MIME types:

dub run :database -- info application/pdf application/x-executable image/png text/plain text/html text/xml

Run to resolve aliases:

dub run :database -- resolve application/wwf application/x-pdf application/pgp text/rtf text/xml

Mime Test

Run to test if this library is capable of parsing your local shared MIME-info database:

dub run :test

As with mimedatabase example you may specify paths to mime folder(s) via command line:

dub run :test -- --mimepath=C:\ProgramData\KDE\share\mime

Available versions

0.4.2 0.4.1 0.4.0 0.3.3 0.3.2 0.3.1 0.3.0 0.2.1 0.2.0 0.1.3 0.1.2 0.1.1 ~master