1Jimfs 2===== 3 4Jimfs is an in-memory file system for Java 7 and above, implementing the 5[java.nio.file](http://docs.oracle.com/javase/7/docs/api/java/nio/file/package-summary.html) 6abstract file system APIs. 7 8[](https://travis-ci.org/google/jimfs) 9[](https://maven-badges.herokuapp.com/maven-central/com.google.jimfs/jimfs) 10 11Getting started 12--------------- 13 14The latest release is [1.1](https://github.com/google/jimfs/releases/tag/v1.1). 15 16It is available in Maven Central as 17[com.google.jimfs:jimfs:1.1](http://search.maven.org/#artifactdetails%7Ccom.google.jimfs%7Cjimfs%7C1.1%7Cjar): 18 19```xml 20<dependency> 21 <groupId>com.google.jimfs</groupId> 22 <artifactId>jimfs</artifactId> 23 <version>1.1</version> 24</dependency> 25``` 26 27Basic use 28--------- 29 30The simplest way to use Jimfs is to just get a new `FileSystem` instance from the `Jimfs` class and 31start using it: 32 33```java 34import com.google.common.jimfs.Configuration; 35import com.google.common.jimfs.Jimfs; 36... 37 38// For a simple file system with Unix-style paths and behavior: 39FileSystem fs = Jimfs.newFileSystem(Configuration.unix()); 40Path foo = fs.getPath("/foo"); 41Files.createDirectory(foo); 42 43Path hello = foo.resolve("hello.txt"); // /foo/hello.txt 44Files.write(hello, ImmutableList.of("hello world"), StandardCharsets.UTF_8); 45``` 46 47What's supported? 48----------------- 49 50Jimfs supports almost all the APIs under `java.nio.file`. It supports: 51 52- Creating, deleting, moving and copying files and directories. 53- Reading and writing files with `FileChannel` or `SeekableByteChannel`, `InputStream`, 54 `OutputStream`, etc. 55- Symbolic links. 56- Hard links to regular files. 57- `SecureDirectoryStream`, for operations relative to an _open_ directory. 58- Glob and regex path filtering with `PathMatcher`. 59- Watching for changes to a directory with a `WatchService`. 60- File attributes. Built-in attribute views that can be supported include "basic", "owner", 61 "posix", "unix", "dos", "acl" and "user". Do note, however, that not all attribute views provide 62 _useful_ attributes. For example, while setting and reading POSIX file permissions is possible 63 with the "posix" view, those permissions will not actually affect the behavior of the file system. 64 65Jimfs also supports creating file systems that, for example, use Windows-style paths and (to an 66extent) behavior. In general, however, file system behavior is modeled after UNIX and may not 67exactly match any particular real file system or platform. 68 69License 70------- 71 72``` 73Copyright 2013 Google Inc. 74 75Licensed under the Apache License, Version 2.0 (the "License"); 76you may not use this file except in compliance with the License. 77You may obtain a copy of the License at 78 79 http://www.apache.org/licenses/LICENSE-2.0 80 81Unless required by applicable law or agreed to in writing, software 82distributed under the License is distributed on an "AS IS" BASIS, 83WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 84See the License for the specific language governing permissions and 85limitations under the License. 86``` 87