Interface FileName

    • Field Summary

      Fields 
      Modifier and Type Field Description
      static java.lang.String ROOT_PATH
      The absolute path of the root of a file system.
      static java.lang.String SEPARATOR
      The separator used in file paths.
      static char SEPARATOR_CHAR
      The separator character used in file paths.
    • Method Summary

      All Methods Instance Methods Abstract Methods 
      Modifier and Type Method Description
      java.lang.String getBaseName()
      Returns the base name of this file.
      int getDepth()
      Returns the depth of this file name, within its file system.
      java.lang.String getExtension()
      Returns the extension of this file name.
      java.lang.String getFriendlyURI()
      Returns a "friendly path", this is a path without a password.
      FileName getParent()
      Returns the file name of the parent of this file.
      java.lang.String getPath()
      Returns the absolute path of this file, within its file system.
      java.lang.String getPathDecoded()
      Returns the absolute path of this file, within its file system.
      java.lang.String getRelativeName​(FileName name)
      Converts a file name to a relative name, relative to this file name.
      FileName getRoot()
      Finds the root of the file system.
      java.lang.String getRootURI()
      Returns the root URI of the file system this file belongs to.
      java.lang.String getScheme()
      Returns the URI scheme of this file.
      FileType getType()
      Returns the requested or current type of this name.
      java.lang.String getURI()
      Returns the absolute URI of this file.
      boolean isAncestor​(FileName ancestor)
      Determines if another file name is an ancestor of this file name.
      boolean isDescendent​(FileName descendent)
      Determines if another file name is a descendent of this file name.
      boolean isDescendent​(FileName descendent, NameScope nameScope)
      Determines if another file name is a descendent of this file name.
      boolean isFile()
      Checks if this file name is a name for a regular file.
      • Methods inherited from interface java.lang.Comparable

        compareTo
    • Method Detail

      • getBaseName

        java.lang.String getBaseName()
        Returns the base name of this file. The base name is the last element of the file name. For example the base name of /somefolder/somefile is somefile.

        The root file of a file system has an empty base name.

        Returns:
        The base name. Never returns null.
      • getPath

        java.lang.String getPath()
        Returns the absolute path of this file, within its file system. This path is normalized, so that . and .. elements have been removed. Also, the path only contains / as its separator character. The path always starts with /

        The root of a file system has / as its absolute path.

        Returns:
        The path. Never returns null.
      • getPathDecoded

        java.lang.String getPathDecoded()
                                 throws FileSystemException
        Returns the absolute path of this file, within its file system. This path is normalized, so that . and .. elements have been removed. Also, the path only contains / as its separator character. The path always starts with /

        The root of a file system has / as its absolute path.

        In contrast to getPath() the path is decoded i.e. all %nn stuff replaced by its character.

        Returns:
        The path. Never returns null.
        Throws:
        FileSystemException - if the path is not correctly encoded
      • getExtension

        java.lang.String getExtension()
        Returns the extension of this file name.
        Returns:
        The extension. Returns an empty string if the name has no extension.
      • getDepth

        int getDepth()
        Returns the depth of this file name, within its file system. The depth of the root of a file system is 0. The depth of any other file is 1 + the depth of its parent.
        Returns:
        The depth of this file name.
      • getScheme

        java.lang.String getScheme()
        Returns the URI scheme of this file.
        Returns:
        The URI scheme of this file.
      • getURI

        java.lang.String getURI()
        Returns the absolute URI of this file.
        Returns:
        the absolute URI of this file.
      • getRootURI

        java.lang.String getRootURI()
        Returns the root URI of the file system this file belongs to.
        Returns:
        the root URI.
      • getRoot

        FileName getRoot()
        Finds the root of the file system.
        Returns:
        the file system root.
      • getParent

        FileName getParent()
        Returns the file name of the parent of this file. The root of a file system has no parent.
        Returns:
        A FileName object representing the parent name. Returns null for the root of a file system.
      • isAncestor

        boolean isAncestor​(FileName ancestor)
        Determines if another file name is an ancestor of this file name.
        Parameters:
        ancestor - The FileName to check.
        Returns:
        true if another file name is an ancestor of this file name.
      • isDescendent

        boolean isDescendent​(FileName descendent)
        Determines if another file name is a descendent of this file name.
        Parameters:
        descendent - the FileName to check.
        Returns:
        true if the other FileName is a descendent of this file name.
      • isDescendent

        boolean isDescendent​(FileName descendent,
                             NameScope nameScope)
        Determines if another file name is a descendent of this file name.
        Parameters:
        descendent - the FileName to check.
        nameScope - the NameScope of the FileName.
        Returns:
        true if the other FileName is a descendent of this file name.
      • getType

        FileType getType()
        Returns the requested or current type of this name.

        The "requested" type is the one determined during resolving the name. In this case the name is a FileType.FOLDER if it ends with an "/" else it will be a FileType.FILE.

        Once attached it will be changed to reflect the real type of this resource.

        Returns:
        FileType.FOLDER or FileType.FILE
      • getFriendlyURI

        java.lang.String getFriendlyURI()
        Returns a "friendly path", this is a path without a password.

        This path can not be used to resolve the path again.

        Returns:
        the friendly URI as a String.