StandardJavaFileManager (Java Platform SE 6) (original) (raw)



javax.tools

Interface StandardJavaFileManager

All Superinterfaces:

Closeable, Flushable, JavaFileManager, OptionChecker


public interface StandardJavaFileManager

extends JavaFileManager

File manager based on java.io.File. A common way to obtain an instance of this class is using [getStandardFileManager](../../javax/tools/JavaCompiler.html#getStandardFileManager%28javax.tools.DiagnosticListener, java.util.Locale, java.nio.charset.Charset%29), for example:

JavaCompiler compiler = ToolProvider.getSystemJavaCompiler(); DiagnosticCollector<JavaFileObject> diagnostics = new DiagnosticCollector<JavaFileObject>(); StandardJavaFileManager fm = compiler.getStandardFileManager(diagnostics, null, null);

This file manager creates file objects representing regularfiles,zip file entries, or entries in similar file system based containers. Any file object returned from a file manager implementing this interface must observe the following behavior:

Since:

1.6


Nested Class Summary
Nested classes/interfaces inherited from interface javax.tools.JavaFileManager
JavaFileManager.Location
Method Summary
Iterable<? extends JavaFileObject> getJavaFileObjects(File... files) Gets file objects representing the given files.
Iterable<? extends JavaFileObject> getJavaFileObjects(String... names) Gets file objects representing the given file names.
Iterable<? extends JavaFileObject> getJavaFileObjectsFromFiles(Iterable<? extends File> files) Gets file objects representing the given files.
Iterable<? extends JavaFileObject> getJavaFileObjectsFromStrings(Iterable<String> names) Gets file objects representing the given file names.
Iterable<? extends File> getLocation(JavaFileManager.Location location) Gets the path associated with the given location.
boolean [isSameFile](../../javax/tools/StandardJavaFileManager.html#isSameFile%28javax.tools.FileObject, javax.tools.FileObject%29)(FileObject a,FileObject b) Compares two file objects and return true if they represent the same canonical file, zip file entry, or entry in any file system based container.
void [setLocation](../../javax/tools/StandardJavaFileManager.html#setLocation%28javax.tools.JavaFileManager.Location, java.lang.Iterable%29)(JavaFileManager.Location location,Iterable<? extends File> path) Associates the given path with the given location.
Methods inherited from interface javax.tools.JavaFileManager
close, flush, getClassLoader, [getFileForInput](../../javax/tools/JavaFileManager.html#getFileForInput%28javax.tools.JavaFileManager.Location, java.lang.String, java.lang.String%29), [getFileForOutput](../../javax/tools/JavaFileManager.html#getFileForOutput%28javax.tools.JavaFileManager.Location, java.lang.String, java.lang.String, javax.tools.FileObject%29), [getJavaFileForInput](../../javax/tools/JavaFileManager.html#getJavaFileForInput%28javax.tools.JavaFileManager.Location, java.lang.String, javax.tools.JavaFileObject.Kind%29), [getJavaFileForOutput](../../javax/tools/JavaFileManager.html#getJavaFileForOutput%28javax.tools.JavaFileManager.Location, java.lang.String, javax.tools.JavaFileObject.Kind, javax.tools.FileObject%29), [handleOption](../../javax/tools/JavaFileManager.html#handleOption%28java.lang.String, java.util.Iterator%29), hasLocation, [inferBinaryName](../../javax/tools/JavaFileManager.html#inferBinaryName%28javax.tools.JavaFileManager.Location, javax.tools.JavaFileObject%29), [list](../../javax/tools/JavaFileManager.html#list%28javax.tools.JavaFileManager.Location, java.lang.String, java.util.Set, boolean%29)
Methods inherited from interface javax.tools.OptionChecker
isSupportedOption
Method Detail

isSameFile

boolean isSameFile(FileObject a, FileObject b)

Compares two file objects and return true if they represent the same canonical file, zip file entry, or entry in any file system based container.

Specified by:

[isSameFile](../../javax/tools/JavaFileManager.html#isSameFile%28javax.tools.FileObject, javax.tools.FileObject%29) in interface [JavaFileManager](../../javax/tools/JavaFileManager.html "interface in javax.tools")

Parameters:

a - a file object

b - a file object

Returns:

true if the given file objects represent the same canonical file or zip file entry; false otherwise

Throws:

[IllegalArgumentException](../../java/lang/IllegalArgumentException.html "class in java.lang") - if either of the arguments were created with another file manager implementation


getJavaFileObjectsFromFiles

Iterable<? extends JavaFileObject> getJavaFileObjectsFromFiles(Iterable<? extends File> files)

Gets file objects representing the given files.

Parameters:

files - a list of files

Returns:

a list of file objects

Throws:

[IllegalArgumentException](../../java/lang/IllegalArgumentException.html "class in java.lang") - if the list of files includes a directory


getJavaFileObjects

Iterable<? extends JavaFileObject> getJavaFileObjects(File... files)

Gets file objects representing the given files. Convenience method equivalent to:

 getJavaFileObjectsFromFiles([Arrays.asList](../../java/util/Arrays.html#asList%28T...%29)(files))

Parameters:

files - an array of files

Returns:

a list of file objects

Throws:

[IllegalArgumentException](../../java/lang/IllegalArgumentException.html "class in java.lang") - if the array of files includes a directory

[NullPointerException](../../java/lang/NullPointerException.html "class in java.lang") - if the given array contains null elements


getJavaFileObjectsFromStrings

Iterable<? extends JavaFileObject> getJavaFileObjectsFromStrings(Iterable<String> names)

Gets file objects representing the given file names.

Parameters:

names - a list of file names

Returns:

a list of file objects

Throws:

[IllegalArgumentException](../../java/lang/IllegalArgumentException.html "class in java.lang") - if the list of file names includes a directory


getJavaFileObjects

Iterable<? extends JavaFileObject> getJavaFileObjects(String... names)

Gets file objects representing the given file names. Convenience method equivalent to:

 getJavaFileObjectsFromStrings([Arrays.asList](../../java/util/Arrays.html#asList%28T...%29)(names))

Parameters:

names - a list of file names

Returns:

a list of file objects

Throws:

[IllegalArgumentException](../../java/lang/IllegalArgumentException.html "class in java.lang") - if the array of file names includes a directory

[NullPointerException](../../java/lang/NullPointerException.html "class in java.lang") - if the given array contains null elements


setLocation

void setLocation(JavaFileManager.Location location, Iterable<? extends File> path) throws IOException

Associates the given path with the given location. Any previous value will be discarded.

Parameters:

location - a location

path - a list of files, if null use the default path for this location

Throws:

[IllegalArgumentException](../../java/lang/IllegalArgumentException.html "class in java.lang") - if location is an output location and path does not contain exactly one element

[IOException](../../java/io/IOException.html "class in java.io") - if location is an output location and path does not represent an existing directory

See Also:

getLocation(javax.tools.JavaFileManager.Location)


getLocation

Iterable<? extends File> getLocation(JavaFileManager.Location location)

Gets the path associated with the given location.

Parameters:

location - a location

Returns:

a list of files or null if this location has no associated path

See Also:

[setLocation(javax.tools.JavaFileManager.Location, java.lang.Iterable)](../../javax/tools/StandardJavaFileManager.html#setLocation%28javax.tools.JavaFileManager.Location, java.lang.Iterable%29)



Submit a bug or feature
For further API reference and developer documentation, see Java SE Developer Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.

Copyright © 1993, 2015, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.

Scripting on this page tracks web page traffic, but does not change the content in any way.