HFuse: HFuse is a binding for the Linux FUSE library.

[ bsd3, library, system ] [ Propose Tags ]
Versions 0.1, 0.2.1, 0.2.2, 0.2.3, 0.2.4,,,,,,
Change log CHANGELOG.md
Dependencies base (==4.*), bytestring, HFuse, unix [details]
License BSD-3-Clause
Author Jeremy Bobbio
Maintainer Montez Fitzpatrick <montezf@gmail.com>
Category System
Home page https://github.com/m15k/hfuse
Source repo head: git clone https://github.com/m15k/hfuse.git
Uploaded by M15K at Mon Jan 15 19:41:45 UTC 2018
Distributions Debian:, NixOS:
Executables HelloFS
Downloads 4670 total (44 in the last 30 days)
Rating (no votes yet) [estimated by rule of succession]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2018-01-15 [all 1 reports]
Hackage Matrix CI

Bindings for the FUSE library, compatible with Linux, OSXFUSE and FreeBSD.

[Skip to Readme]





Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info


Maintainer's Corner

For package maintainers and hackage trustees

Readme for HFuse-

[back to package description]

Haskell FUSE API

Filesystem in Userspace ("FUSE") makes it possible to implement a filesystem as a userspace program.

This library is the Haskell binding to this library.


BSD 3-Clause



All of the usual methods for installation will be supported. For Mac OS X, you must install OSXFuse first.

Installation via Hackage

cabal install hfuse

Installation for development

Can either be handled via Hackage

cabal unpack hfuse
cd HFuse-
cabal sandbox init
cabal install --only-dependencies
cabal install -fdeveloper

Or the library can be installed via Github repo

git clone git://github.com/m15k/hfuse
cd hfuse
cabal sandbox init
cabal install --only-dependencies
cabal install -fdeveloper


  • To use the sandboxes feature in Cabal your version must be higher than 1.18. highly recommended


To get a feel for HFuse, there are a number of example applications. They can be built by supplying the -fdeveloper configuration flag to Cabal.

git clone https://github.com/m15k/hfuse


HelloFS is as basic as you get. Haskell version of the canonical example from the FUSE project. Once compiled here is how you run HelloFS.

$ mkdir ~/fuseTest
$ ./HelloFS ~/fuseTest

This creates a file in the fuseTest directory. Now to test the application.

$ cat ~/fuseTest/hello
Hello World, HFuse!

To unmount issue the following command:

$ fusermount -u ~/fuseTest

Other Samples

There are other projects on hackage which use HFuse as a dependency. Check these out for a possibly richer experience than what is included with the examples folder.

If you lack for inspiration the FUSE Wiki have amassed quite the list of links to downstream projects.


Help is always welcome. Pull requests are appreciated.

If you run into any problems or bugs, please report the issue on Github


I would like to create the following examples:

  • MemoryFS.hs := In-memory file system
  • VBoxFS.hs := Mount VirtualBox disks as filesystem
  • SSHFS.hs := SSH file system