org.autoplot.jythonsupport.Util

Utilities for Jython scripts in both the datasource and application contexts.

Util( )


fileCanRead

fileCanRead( String file ) → boolean

return true if the file can be read. This is introduced to avoid imports of java.io.File.

Parameters

file - the file or directory.

Returns:

true if the file can be read.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


fileExists

fileExists( String file ) → boolean

return true if the file exists. This is introduced to avoid imports of java.io.File.

Parameters

file - file or local file Autoplot URI

Returns:

true if the file exists.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


generateTimeRanges

generateTimeRanges( String spec, String srange ) → String[]

Given a spec to format timeranges and a range to contain each timerange, produce a list of all timeranges covering the range formatted with the spec. For example, generateTimeRanges( "%Y-%m-%d", "Jun 2009" ) would result in 2009-06-01, 2009-06-02, ..., 2009-06-30. This is limited to create no more than 100000 elements.

Parameters

spec - such as "%Y-%m". Note specs like "%Y%m" will not be parsable.
srange - range limiting the list, such as "2009"

Returns:

a string array of formatted time ranges, such as [ "2009-01", "2009-02", ..., "2009-12" ]

See Also:

DatumRangeUtil#parseTimeRangeValid(java.lang.String) to convert to DatumRange objects.


[search for examples] [view on GitHub] [view on old javadoc] [view source]


getAllCompletions

getAllCompletions( String file ) → String[]

return a list of all completions, even if they are not complete. This is useful in the IDL context as well as Jython scripts. This will perform the completion for where the carot is at the end of the string. All completions are returned, so for example http://autoplot.org/data/somedata.cdf?noDep is returned as well as http://autoplot.org/data/somedata.cdf?Magnitude.

Parameters

file - for example http://autoplot.org/data/somedata.cdf?

Returns:

list of completions, containing the entire URI.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getAutoplotScriptingVersion

getAutoplotScriptingVersion( ) → String

this returns a double indicating the current scripting version, found at the top of autoplot2023.py in AUTOPLOT_DATA/jython/autoplot2023.py. Do not parse this number and expect it to work in future versions!

Returns:

the version, such as v1.50.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getCompletions

getCompletions( String file ) → String[]

return a list of completions. This is useful in the IDL context as well as Jython scripts. This will perform the completion for where the carot is at the end of the string. Only completions where maybePlot indicates the URI is now valid are returned, so for example http://autoplot.org/data/somedata.cdf?noDep is not returned and http://autoplot.org/data/somedata.cdf?Magnitude is.

Parameters

file - for example http://autoplot.org/data/somedata.cdf?

Returns:

list of completions, containing the entire URI.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getDataSet

getDataSet( String suri, String stimeRange, ProgressMonitor mon ) → QDataSet

load the data specified by URI into Autoplot's internal data model. This will block until the load is complete, and a ProgressMonitor object can be used to monitor the load. This adds a timeRange parameter so that TimeSeriesBrowse-capable datasources can be used from AutoplotServer.

Parameters

suri - the URI of the dataset, such as "http://autoplot.org/data/2010_061_17_41_40.txt?column=field8"
stimeRange - a string representing the timerange to load, such as 2012-02-02/2012-02-03
mon - progress monitor object.

Returns:

QDataSet from the load.

[search for examples] [view on GitHub] [view on old javadoc] [view source]

getDataSet( String suri, DatumRange timeRange, ProgressMonitor monitor ) → QDataSet
getDataSet( String suri, ProgressMonitor mon ) → QDataSet
getDataSet( String suri ) → QDataSet
getDataSet( String suri, String stimerange ) → QDataSet
getDataSet( String suri, DatumRange timerange ) → QDataSet

getDataSetFromStream

getDataSetFromStream( String spec, java.io.InputStream in, ProgressMonitor mon ) → QDataSet

load data from the input stream into Autoplot internal data model. This will block until the load is complete. This works by creating a temporary file and then using the correct reader to read the data. When the data source is able to read directly from a stream, no temporary file is created. Currently this always loads to a file, and therefore does not support applets. This may have been introduced to support scripts, but it's not clear who uses it.

Parameters

spec - the extension and any parsing parameters, such as "vap+bin:?recLength=2000&rank2=1:"
in - the input stream
mon - a progress monitor.

Returns:

QDataSet the dataset or null.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getDataSets

getDataSets( java.util.List uris, ProgressMonitor mon ) → java.util.List

load multiple uris simultaneously. This will read all the data at once, returning all data or throwing one of the exceptions.

Parameters

uris - a list of URI strings.
mon - monitor for the aggregate load. TODO: Each uri should given equal shares of the task.

Returns:

list of loaded data

[search for examples] [view on GitHub] [view on old javadoc] [view source]

getDataSets( java.util.List uris, DatumRange timerange, ProgressMonitor mon ) → java.util.List

getDataSource

getDataSource( String suri ) → org.autoplot.datasource.DataSource

returns the dataSource for the given URI. This will include capabilities, like TimeSeriesBrowse.

Parameters

suri - the data address to load.

Returns:

the DataSource to load the URI.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getMetadata

getMetadata( String suri, ProgressMonitor mon ) → java.util.Map

load the metadata for the url. This can be called independently from getDataSet, and data sources should not assume that getDataSet is called before getMetaData. Some may, in which case a bug report should be submitted. The metadata is a tree of name/value pairs, for human consumption, and used when a particular metadata model is expects.

Parameters

suri - the data address to load.
mon - monitor, or null (None in Jython) for no feedback.

Returns:

metadata tree created by the data source.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getTimeRangesFor

getTimeRangesFor( String surl, String timeRange, String format ) → String[]

return an array of URLs that match the spec for the time range provided. For example,

  uri= 'https://cdaweb.gsfc.nasa.gov/istp_public/data/polar/hyd_h0/$Y/po_h0_hyd_$Y$m$d_v01.cdf?ELECTRON_DIFFERENTIAL_ENERGY_FLUX'
  xx= getTimeRangesFor( uri, '2000-jan', '$Y-$d-$m' )
  for x in xx:
    print x
 

Parameters

surl - an Autoplot uri with an aggregation specifier.
timeRange - a string that is parsed to a time range, such as "2001"
format - format for the result, such as "%Y-%m-%d"

Returns:

a list of URLs without the aggregation specifier.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


getTimeSeriesBrowse

getTimeSeriesBrowse( org.autoplot.datasource.DataSource ds ) → org.autoplot.datasource.capability.TimeSeriesBrowse

get the TimeSeriesBrowse capability, if available. Null (None) is returned if it is not found.

Parameters

ds - the data source.

Returns:

the TimeSeriesBrowse if available, or null (None)

[search for examples] [view on GitHub] [view on old javadoc] [view source]


guardedSplit

guardedSplit( String s, char delim, char exclude1, char exclude2 ) → String[]

only split on the delimiter when we are not within the exclude delimiters. For example, x=getDataSet("http://autoplot.org/data/autoplot.cdf?Magnitude&noDep=T")&y=getDataSet('http://autoplot.org/data/autoplot.cdf?BGSEc&slice1=2')&sqrt(x)

Parameters

s - the string to split.
delim - the delimiter to split on, for example the ampersand (&).
exclude1 - for example the single quote (')
exclude2 - for example the double quote (") Note URIs don't support these anyway.

Returns:

the split. This is a copy of another code.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


isLegacyImports

isLegacyImports( ) → boolean

return true if we should do the imports as before, where all of Autoplot is imported with each session. This is used to ease migration.

Returns:

true if the old behavior should be used.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


listDirectory

listDirectory( String suri ) → String[]

returns an array of the files in the local or remote filesystem pointed to by suri. The files are returned without the path, and directories are marked with a trailing slash character. Windows a forward slash is still used, even though a back slash is more conventional. When the suri ends in slash, all entries in the directory are listed, and when it ends in a file glob, all matching files are returned.

 print listDirectory( 'http://autoplot.org/data/pngwalk/' )
  --> 'product.vap', 'product_20080101.png', 'product_20080102.png', ...
 print listDirectory( 'http://autoplot.org/data/pngwalk/*.png' )
  --> 'product_20080101.png', 'product_20080102.png', ...
 

Parameters

suri - local or web directory.

Returns:

an array of the files pointed to by surl.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


main

main( String[] args ) → void

Parameters

args - a java.lang.String[]

Returns:

void (returns nothing)

[search for examples] [view on GitHub] [view on old javadoc] [view source]


popString

popString( String line ) → String

Parameters

line - a String

Returns:

java.lang.String

[search for examples] [view on GitHub] [view on old javadoc] [view source]


readConfiguration

readConfiguration( String suri ) → java.util.Map

read the preferences into a map. These are name=value pairs and anything following a pound symbol (#) is ignored. Anything before the equal sign is trimmed, so "x=2" and "x = 2" have the same interpretation. This has a number of TODOs, namely:

%{PWD} is replaced with the directory of the config file.

Parameters

suri - the location of files which are name value pairs.

Returns:

a map of string to object.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


requireAutoplotScriptingVersion

requireAutoplotScriptingVersion( String v ) → void

throw an exception if the scripting version cannot be supported. These versions are numeric--so note that v1.7 is newer than v1.50, and for this reason versions should always be vNNN.NN.

Parameters

v - a String

Returns:

void (returns nothing)

[search for examples] [view on GitHub] [view on old javadoc] [view source]


runInParallel

runInParallel( PyFunction job, java.util.List argument, ProgressMonitor mon ) → java.util.List

run the python jobs in parallel.

Parameters

job - a python function which takes one argument
argument - list of arguments to invoke.
mon - monitor for the group of processes

Returns:

list of results for each call of the function.

[search for examples] [view on GitHub] [view on old javadoc] [view source]


sleep

sleep( int millis ) → void

sleep for so many milliseconds. This is introduced to avoid the import, which makes running scripts securely non-trivial.

Parameters

millis - number of milliseconds to pause execution

Returns:

void (returns nothing)

[search for examples] [view on GitHub] [view on old javadoc] [view source]