Skip to content
forked from puniverse/javafs

🗂️ javafs Java Fuse SPI delegatee

License

Notifications You must be signed in to change notification settings

umjammer/javafs

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Release Java CI with Maven CodeQL Java Parent

JavaFS

Java filesystems as FUSE

Requirements

Java 8 and up.

Your OS must support FUSE or have it installed.

Usage

The API consists of a single class with two methods:

  • JavaFS.mount, which mounts a Java FileSystem as FUSE filesystem, and
  • JavaFS.unmount, which unmounts a FUSE filesystem

Test

$ java -cp ... co.paralleluniverse.javafs.Main [-r] <mountpoint> [<zipfile>]

Compatibility

  • OS X with MacFUSE/fuse4x/OSXFUSE on Intel architectures
  • Linux with FUSE on Intel, PowerPC and ARM architectures
  • FreeBSD with FUSE on Intel architectures

Project Information

This is essentially a port of fuse-jna, by Etienne Perot, from JNA to JNR, with some code copied from jnr-fuse, by Sergey Tselovalnikov, made to work with the standard JDK FileSystem API.

  • Differences from fuse-jna: this project uses JNR rather than JNA.
  • Differences from jnr-fuse: this project supports Java 7 (jnr-fuse supports only Java 8), and more platforms (like Mac).
  • Differences from both: rather than exposing a new, specific, Java FUSE API, this project uses the standard FileSystem API.

License

Copyright (c) 2015 Parallel Universe
Copyright (c) 2012-2015 Etienne Perot
Copyright (c) 2015 Sergey Tselovalnikov

Redistribution and use in source and binary forms, with or without modification, are
permitted provided that the following conditions are met:

   1. Redistributions of source code must retain the above copyright notice, this list of
      conditions and the following disclaimer.

   2. Redistributions in binary form must reproduce the above copyright notice, this list
      of conditions and the following disclaimer in the documentation and/or other materials
      provided with the distribution.

THIS SOFTWARE IS PROVIDED THE COPYRIGHT HOLDERS AND CONTRIBUTORS ''AS IS'' AND ANY EXPRESS OR IMPLIED
WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

This is the 2-clause BSD license.

fuse-jna is licensed under the BSD 2-Clause License.

jnr-fuse is licensed under the MIT License.