Package org.esa.snap.core.util
Class SystemUtils
- java.lang.Object
- 
- org.esa.snap.core.util.SystemUtils
 
- 
 public class SystemUtils extends Object A collection of SNAP-system level functions.All functions have been implemented with extreme caution in order to provide a maximum performance. 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classSystemUtils.ImageSelectionThis class is used to hold an image while on the clipboard.
 - 
Field SummaryFields Modifier and Type Field Description static StringAUXDATA_DIR_NAMEName of SNAP's auxdata directory.static LoggerLOGThe SNAP system logger.static StringLSstatic StringSNAP_CACHE_DIR_PROPERTY_NAMEstatic StringSNAP_PARALLELISM_PROPERTY_NAME
 - 
Constructor SummaryConstructors Constructor Description SystemUtils()
 - 
Method SummaryAll Methods Static Methods Concrete Methods Modifier and Type Method Description static StringconvertToLocalPath(String urlPath)Replace the separator character '/' with the system-dependent path-separator character.static voidcopyToClipboard(Image image)Copies the given image to the system clipboard.static voidcopyToClipboard(String text)Copies the given text to the system clipboard.static StringcreateHumanReadableExceptionMessage(Exception e)Creates a (more) human readable exception message text for the given exception.static voidfreeAllMemory()Empty all tiles from cache and garbage collectstatic StringgetApplicationContextId()Gets the application context ID uses as prefix in a number of application configuration settings.static FilegetApplicationDataDir()Gets the current user's application data directory.static FilegetApplicationDataDir(boolean force)Optionally creates and returns the current user's application data directory.static FilegetApplicationHomeDir()Gets the application's home directory as set by the system property "${snap.context}.home".static StringgetApplicationHomepageUrl()Gets the application home page URL as set by the system property "${ceres.context}.homepage.url".static StringgetApplicationName()Gets the application name used in logger output and information messages.static StringgetApplicationRemoteVersionUrl()static PathgetAuxDataPath()Gets the auxdata directory which stores dems, orbits, rgb profiles, etc.static FilegetCacheDir()Gets the SNAP cache directory .static StringgetClassFileName(Class aClass)Retrieves the file name of a class.static File[]getClassPathFiles()Gets all files (class directory & JAR file pathes) given in the current class path of the Java runtime which loaded this class.static FilegetCurrentWorkingDir()Gets the current working directory, or the directory pointed to by '.' if the actual working directory cannot be determined.static FilegetDefaultCacheDir()Gets the default SNAP cache directory.static doublegetMemoryUsed()static StringgetReleaseVersion()Returns the version string.static FilegetUserHomeDir()Gets the current user's home directory, or the directory pointed to by '.' if the user's actual home directory cannot be determined.static StringgetUserName()Gets the current user's name, or the string"unknown"if the the user's name cannot be determined.static voidinit3rdPartyLibs(Class<?> cls)Initialize third party libraries of SNAP.static voidinit3rdPartyLibsByCl(ClassLoader cl)Initialize third party libraries of SNAP.static voidinitGeoTools()static voidinitJAI(Class<?> cls)static voidinitJAI(ClassLoader cl)static ModuleMetadataloadModuleMetadata(Class<?> aClass)Tries to load the metadata fromMETA-INF/MANIFEST.MFcontained in the module jar of the specified class.static <S> Iterable<S>loadServices(Class<S> serviceType)Loads services from allMETA-INF/services/resources.static <S> Iterable<S>loadServices(Class<S> serviceType, ClassLoader classLoader)Loads services from allMETA-INF/services/resources.static voidtileCacheFreeOldTiles()tell tileCache that some old tiles can be removed
 
- 
- 
- 
Field Detail- 
SNAP_PARALLELISM_PROPERTY_NAMEpublic static final String SNAP_PARALLELISM_PROPERTY_NAME 
 - 
SNAP_CACHE_DIR_PROPERTY_NAMEpublic static final String SNAP_CACHE_DIR_PROPERTY_NAME 
 - 
LOGpublic static final Logger LOG The SNAP system logger. Default name is "org.esa.snap" which may be overridden by system property "snap.logger.name".
 - 
LSpublic static final String LS 
 - 
AUXDATA_DIR_NAMEpublic static final String AUXDATA_DIR_NAME Name of SNAP's auxdata directory.- See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
getUserNamepublic static String getUserName() Gets the current user's name, or the string"unknown"if the the user's name cannot be determined.- Returns:
- the current user's name, never null
 
 - 
getUserHomeDirpublic static File getUserHomeDir() Gets the current user's home directory, or the directory pointed to by '.' if the user's actual home directory cannot be determined.- Returns:
- the current working directory, never null
 
 - 
getApplicationHomepageUrlpublic static String getApplicationHomepageUrl() Gets the application home page URL as set by the system property "${ceres.context}.homepage.url". Default is "http://sentinel.esa.int".- Returns:
- the application homepage url
- Since:
- BEAM 4.10
 
 - 
getApplicationDataDirpublic static File getApplicationDataDir() Gets the current user's application data directory.- Returns:
- the current user's application data directory
- Since:
- BEAM 4.2
 
 - 
getAuxDataPathpublic static Path getAuxDataPath() Gets the auxdata directory which stores dems, orbits, rgb profiles, etc.- Returns:
- the auxiliary data directory
- Since:
- SNAP 2.0
 
 - 
getCacheDirpublic static File getCacheDir() Gets the SNAP cache directory . This is the directory where SNAP stores cached & temporary data.The SNAP cache directory can be configured using the snap.cachedirconfiguration property (or Java system property).- Returns:
- the cache directory
- Since:
- SNAP 2
 
 - 
getDefaultCacheDirpublic static File getDefaultCacheDir() Gets the default SNAP cache directory.- Returns:
- the default cache directory
- See Also:
- getCacheDir()
 
 - 
getApplicationDataDirpublic static File getApplicationDataDir(boolean force) Optionally creates and returns the current user's application data directory.- Parameters:
- force- if true, the directory will be created if it didn't exist before
- Returns:
- the current user's application data directory
- Since:
- BEAM 4.2
 
 - 
getApplicationContextIdpublic static String getApplicationContextId() Gets the application context ID uses as prefix in a number of application configuration settings. The context ID is configured using the system property "snap.context". If this property is not set, the string "snap" is used.- Returns:
- The application context ID.
- Since:
- BEAM 4.10
 
 - 
getApplicationNamepublic static String getApplicationName() Gets the application name used in logger output and information messages. The context ID is configured using the system property "${ceres.context}.application.name". If this property is not set, the string "SNAP" is used.- Returns:
- The application name.
- Since:
- BEAM 4.10
- See Also:
- getApplicationContextId()
 
 - 
getCurrentWorkingDirpublic static File getCurrentWorkingDir() Gets the current working directory, or the directory pointed to by '.' if the actual working directory cannot be determined.- Returns:
- the current working directory, never null
 
 - 
getClassPathFilespublic static File[] getClassPathFiles() Gets all files (class directory & JAR file pathes) given in the current class path of the Java runtime which loaded this class.The files pathes returned are either relative or absolute, just as they where defined for the runtime's class path. - Returns:
- all files in the current class path, never null
 
 - 
getApplicationHomeDirpublic static File getApplicationHomeDir() Gets the application's home directory as set by the system property "${snap.context}.home".- Returns:
- an assumption of an application's home directory, never null
 
 - 
getClassFileNamepublic static String getClassFileName(Class aClass) Retrieves the file name of a class. For example, the string"Date.class"is returned for the classjava.util.Date.- Parameters:
- aClass- The class.
- Returns:
- the file name of the given class
- Throws:
- IllegalArgumentException- if the given parameter is- null.
 
 - 
convertToLocalPathpublic static String convertToLocalPath(String urlPath) Replace the separator character '/' with the system-dependent path-separator character.- Parameters:
- urlPath- an URL path or any other string containing the forward slash '/' as directory separator.
- Returns:
- a path string with all occurrences of '/'
- Throws:
- IllegalArgumentException- if the given parameter is- null.
 
 - 
createHumanReadableExceptionMessagepublic static String createHumanReadableExceptionMessage(Exception e) Creates a (more) human readable exception message text for the given exception. This method should be used when exception messages are to be presented to the user in a GUI.Currently the only modifications are 
 1. the first letter is turned into upper case
 2. the message is suffixed with a dot ('.') character.- Parameters:
- e- the exception
- Returns:
- a modified message text, or nullifewas null.
 
 - 
copyToClipboardpublic static void copyToClipboard(String text) Copies the given text to the system clipboard.- Parameters:
- text- the text to copy
 
 - 
copyToClipboardpublic static void copyToClipboard(Image image) Copies the given image to the system clipboard.- Parameters:
- image- the image to copy
 
 - 
loadServicespublic static <S> Iterable<S> loadServices(Class<S> serviceType) Loads services from allMETA-INF/services/resources.- Parameters:
- serviceType- the type of the service to be loaded.
- Returns:
- the services of type serviceTypefound.
 
 - 
loadServicespublic static <S> Iterable<S> loadServices(Class<S> serviceType, ClassLoader classLoader) Loads services from allMETA-INF/services/resources.- Parameters:
- serviceType- the type of the service to be loaded.
- classLoader- the class loader.
- Returns:
- the services of type serviceTypefound.
 
 - 
init3rdPartyLibspublic static void init3rdPartyLibs(Class<?> cls) Initialize third party libraries of SNAP.- Parameters:
- cls- The most useful class.
- Since:
- BEAM 4.8
 
 - 
init3rdPartyLibsByClpublic static void init3rdPartyLibsByCl(ClassLoader cl) Initialize third party libraries of SNAP.- Parameters:
- cl- The most useful class loader.
- Since:
- SNAP 8.0
 
 - 
initGeoToolspublic static void initGeoTools() 
 - 
initJAIpublic static void initJAI(Class<?> cls) 
 - 
initJAIpublic static void initJAI(ClassLoader cl) 
 - 
getApplicationRemoteVersionUrlpublic static String getApplicationRemoteVersionUrl() 
 - 
loadModuleMetadatapublic static ModuleMetadata loadModuleMetadata(Class<?> aClass) Tries to load the metadata fromMETA-INF/MANIFEST.MFcontained in the module jar of the specified class.- Parameters:
- aClass- The module jar which contains this specified class will be used to look-up the- META-INF/MANIFEST.MF
- Returns:
- the module metadata, or nullif aMETA-INF/MANIFEST.MFcould not be found.
 
 - 
getReleaseVersionpublic static String getReleaseVersion() Returns the version string. It'S the version uf the last major release.- Returns:
- the version string
 
 - 
freeAllMemorypublic static void freeAllMemory() Empty all tiles from cache and garbage collect
 - 
getMemoryUsedpublic static double getMemoryUsed() 
 - 
tileCacheFreeOldTilespublic static void tileCacheFreeOldTiles() tell tileCache that some old tiles can be removed
 
- 
 
-