Class Files
This class includes methods for retrieving JAR file paths, checking file usage, deleting files, retrieving file names, opening files in the file manager, validating file paths, and loading or saving key-value maps to files.
Key Features:
- Retrieve the absolute path or directory of a JAR file.
- Check if a file is currently in use by attempting a write lock.
- Delete files with optional debug output.
- Retrieve all file names or matching file names in a directory.
- Open files or directories in the system's default file manager.
- Validate file paths for different operating systems.
- Load and save key-value pairs from/to files in `key=value` format.
Note: This class cannot be instantiated as it is designed to be a utility class.
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidcopyDirectory(String source, String target) Copy a directory and its complete file tree to the target location.static voidcopyDirectory(Path source, Path target) Copy a directory and its complete file tree to the target location.static voiddeleteDirectory(String path) Delete a directory and all files within.static voiddeleteDirectory(String path, boolean debug) Delete a directory and all files within.static voiddeleteFile(String path) Deletes a file at the specified path.static voiddeleteFile(String path, boolean debug) Deletes a file at the specified path.getAllDirectoriesInDirectory(String inputDirectory) Retrieves a set of all directory names in a specified directory.getAllFilesInDirectory(String inputDirectory) Retrieves a set of all file names in a specified directory.static StringgetJarDirectory(Class<?> clazz) Retrieves the directory containing the JAR file of the specified class.static StringgetJarPath(Class<?> clazz) Retrieves the absolute path of the JAR file containing the specified class.getMatchingFiles(String inputDirectory, String contains) Retrieves a set of file names in a directory that contain a specific substring.static booleanisFileInUse(Path filePath) Checks if a file is currently in use by attempting to acquire a write lock on it.loadMapFromFile(String filePath) Loads a map from a file where each line represents a key-value pair in the format `key=value`.loadMapFromFile(Path filePath) Loads a map from a file where each line represents a key-value pair in the format `key=value`.static voidopenInFileManager(String path) Opens a directory in the default file manager and selects the specified file.static voidSaves a map to a file in the format `key=value` with each entry on a new line.static voidsaveMapToFile(Path filePath, Map<String, String> map, boolean overwrite) Saves a map to a file in the format `key=value` with each entry on a new line.static booleanvalidateFilePath(String path) Validates whether a given file path is valid and exists.
- 
Method Details- 
getJarPathRetrieves the absolute path of the JAR file containing the specified class.- Parameters:
- clazz- the class whose JAR file path is to be determined
- Returns:
- the absolute path of the JAR file as a string, or nullif the path cannot be determined
 
- 
getJarDirectoryRetrieves the directory containing the JAR file of the specified class.- Parameters:
- clazz- the class whose JAR file directory is to be determined
- Returns:
- the directory path of the JAR file as a string, or nullif the path cannot be determined
 
- 
isFileInUseChecks if a file is currently in use by attempting to acquire a write lock on it.- Parameters:
- filePath- the path of the file to check
- Returns:
- trueif the file is in use or an error occurs,- falseotherwise
 
- 
deleteFileDeletes a file at the specified path.- Parameters:
- path- the path of the file to delete
 
- 
deleteFileDeletes a file at the specified path.- Parameters:
- path- the path of the file to delete
- debug- if- true, prints debug information to System.out about the deletion process
 
- 
deleteDirectoryDelete a directory and all files within.- Parameters:
- path- path of the directory to delete
 
- 
deleteDirectoryDelete a directory and all files within.- Parameters:
- path- path of the directory to delete
- debug- whether to print debug information
 
- 
copyDirectoryCopy a directory and its complete file tree to the target location.- Parameters:
- source- source directory
- target- target directory
- Throws:
- IOException- if an IOException is thrown by a visitor method in walkFileTree()
 
- 
copyDirectoryCopy a directory and its complete file tree to the target location.- Parameters:
- source- source directory
- target- target directory
- Throws:
- IOException- if an IOException is thrown by a visitor method in walkFileTree()
 
- 
getMatchingFilesRetrieves a set of file names in a directory that contain a specific substring.- Parameters:
- inputDirectory- the directory to search for files
- contains- the substring to match in file names
- Returns:
- a set of matching file names, or nullif no matches are found
 
- 
getAllFilesInDirectoryRetrieves a set of all file names in a specified directory.- Parameters:
- inputDirectory- the directory to retrieve file names from
- Returns:
- a set of file names in the directory
 
- 
getAllDirectoriesInDirectoryRetrieves a set of all directory names in a specified directory.- Parameters:
- inputDirectory- the directory to retrieve directory names from
- Returns:
- a set of directory names in the directory
 
- 
openInFileManagerOpens a directory in the default file manager and selects the specified file.- Parameters:
- path- the path to the file or directory to open
 
- 
validateFilePathValidates whether a given file path is valid and exists.- Parameters:
- path- the file path to validate
- Returns:
- trueif the path is valid and exists,- falseotherwise
 
- 
loadMapFromFileLoads a map from a file where each line represents a key-value pair in the format `key=value`.If the file does not exist or is empty, an error message is printed to System.err, andnullis returned.- Parameters:
- filePath- the full path of the file to load the map from
- Returns:
- a Map<String, String>containing the key-value pairs from the file, ornullif the file does not exist or is empty
- Throws:
- RuntimeException- if an error occurs while reading the file- Example: - // File content: // key1=value1 // key2=value2 Map<String, String> map = Files.loadMapFromFile("/path/to/example.txt"); System.out.println(map); // {key1=value1, key2=value2}
 
- 
loadMapFromFileLoads a map from a file where each line represents a key-value pair in the format `key=value`.If the file does not exist or is empty, an error message is printed to System.err, andnullis returned.- Parameters:
- filePath- the full path of the file to load the map from
- Returns:
- a Map<String, String>containing the key-value pairs from the file, ornullif the file does not exist or is empty
- Throws:
- RuntimeException- if an error occurs while reading the file- Example: - // File content: // key1=value1 // key2=value2 Map<String, String> map = Files.loadMapFromFile("/path/to/example.txt"); System.out.println(map); // {key1=value1, key2=value2}
 
- 
saveMapToFileSaves a map to a file in the format `key=value` with each entry on a new line.If the file already exists and overwrite is disabled, the method stops and prints an error message to System.err. If overwrite is enabled, the existing file is deleted and replaced with the new content.- Parameters:
- filePath- the full filepath where the file will be saved (some/dir/filename.txt)
- map- the- Map<String, String>to save
- overwrite- whether to overwrite the file if it already exists
- Throws:
- RuntimeException- if an error occurs while writing to the file- Example: - Map<String, String> map = new HashMap<>(); map.put("key1", "value1"); map.put("key2", "value2"); Files.saveMapToFile("/path/to/directory/file.txt", map, true); // File content: // key1=value1 // key2=value2
- See Also:
 
- 
saveMapToFilepublic static void saveMapToFile(String path, String fileName, Map<String, String> map, boolean overwrite) Saves a map to a file in the format `key=value` with each entry on a new line.If the file already exists and overwrite is disabled, the method stops and prints an error message to System.err. If overwrite is enabled, the existing file is deleted and replaced with the new content.- Parameters:
- path- the directory path where the file will be saved
- fileName- the name of the file (without extension) to save the map to
- map- the- Map<String, String>to save
- overwrite- whether to overwrite the file if it already exists
- Throws:
- RuntimeException- if an error occurs while writing to the file- Example: - Map<String, String> map = new HashMap<>(); map.put("key1", "value1"); map.put("key2", "value2"); Files.saveMapToFile("/path/to/directory", "example", map, true); // File content: // key1=value1 // key2=value2
- See Also:
 
 
-