Skip to content

dunyakirkali/format_parser.ex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FormatParser

Code Quality Continuous Integration Coverage Status Hex.pm version Hex.pm downloads

FormatParser can be used to figure out the type and the format of a file. It also can extract some additional information.

Documentation can be found here.

Inspired heavily by format_parser.

Basic usage

# Image
{:ok, file} = File.read("myimage.png")
match = FormatParser.parse(file)
match.nature                      #=> :image
match.format                      #=> :gif
match.width_px                    #=> 256
match.height_px                   #=> 256
match.intrinsics[:filter_method]  #=> 0

# Video
{:ok, file} = File.read("myvideo.flv")
match = FormatParser.parse(file)
match.nature                      #=> :video
match.format                      #=> :flv

# Document
{:ok, file} = File.read("mydocument.rtf")
match = FormatParser.parse(file)
match.nature                      #=> :document
match.format                      #=> :rtf

# Audio
{:ok, file} = File.read("myaudio.wav")
match = FormatParser.parse(file)
match.nature                      #=> :audio
match.format                      #=> :wav
match.sample_rate_hz              #=> 44100
match.num_audio_channels          #=> 2

# Font
{:ok, file} = File.read("myfont.ttf")
match = FormatParser.parse(file)
match.nature                      #=> :font
match.format                      #=> :ttf

# Data
{:ok, file} = File.read("mydata.parquet")
match = FormatParser.parse(file)
match.nature                      #=> :data
match.format                      #=> :pqt

# Archive
{:ok, file} = File.read("myarchive.iso")
match = FormatParser.parse(file)
match.nature                      #=> :archive
match.format                      #=> :iso

Supported Formats

Data

Type Nature Format Intrinsics
pqt x x
sqlite3 x x
duckdb x x

Audio

Type Nature Format Sample Rate # of Channels Intrinsics
aiff x x x num_frames, bits_per_sample
wav x x x x byte_rate, block_align, bits_per_sample
vorbis x x x x vorbis_version
opus x x x x version, pre_skip, output_gain, mapping_family
flac x x x x
aac x x x x

Video

Type Nature Format
flv x x
mp4 x x
avi x x
wmv x x
mov x x
webm x x
mkv x x

Document

Type Nature Format Intrinsics
rtf x x
pdf x x page_count
docx x x
doc x x
odt x x

Image

Type Nature Format Width Height Intrinsics
jpg x x
gif x x x x
ico x x x x num_color_palette, color_planes, bits_per_pixel
cur x x x x num_color_palette, hotspot_horizontal_coords, hotspot_vertical_coords
cr2 x x x x date_time, model, preview_byte_count, preview_offset
nef x x x x date_time, model, preview_byte_count, preview_offset
tif x x x x
bmp x x x x
png x x x x bit_depth, color_type, compression_method, crc, filter_method, interlace_method
psd x x x x
jb2 x x
xcf x x
exr x x
webp x x
heic x x
svg x x

Font

Type Nature Format
ttf x x
otf x x
fon x x

Archive

Type Nature Format
iso x x

Installation

Add the following to your mix.exs file

def deps do
  [
    {:format_parser, "~> 2.6.0"}
  ]
end

And run mix deps.get

Contribute

Please feel free to fork and send us a PR or open up an issue.

About

The owls are not what they seem

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published

Contributors 5