;
; NOSA HEADER START
;
; The contents of this file are subject to the terms of the NASA Open
; Source Agreement (NOSA), Version 1.3 only (the "Agreement"). You may
; not use this file except in compliance with the Agreement.
;
; You can obtain a copy of the agreement at
; docs/NASA_Open_Source_Agreement_1.3.txt
; or
; https://cdaweb.gsfc.nasa.gov/WebServices/NASA_Open_Source_Agreement_1.3.txt.
;
; See the Agreement for the specific language governing permissions
; and limitations under the Agreement.
;
; When distributing Covered Code, include this NOSA HEADER in each
; file and include the Agreement file at
; docs/NASA_Open_Source_Agreement_1.3.txt. If applicable, add the
; following below this NOSA HEADER, with the fields enclosed by
; brackets "[]" replaced with your own identifying information:
; Portions Copyright [yyyy] [name of copyright owner]
;
; NOSA HEADER END
;
; Copyright (c) 2010-2018 United States Government as represented by the
; National Aeronautics and Space Administration. No copyright is claimed
; in the United States under Title 17, U.S.Code. All Other Rights Reserved.
;
;
;+
; This class is an IDL representation of the GraphRequest element from
; the
; <a href="https://cdaweb.gsfc.nasa.gov/">Coordinated Data Analysis System</a>
; (CDAS) XML schema.
;
; @copyright Copyright (c) 2010-2018 United States Government as represented
; by the National Aeronautics and Space Administration. No
; copyright is claimed in the United States under Title 17,
; U.S.Code. All Other Rights Reserved.
;
; @author B. Harris
;-
;+
; Creates an SpdfGraphRequest object.
;
; @param timeInterval {in} {type=SpdfTimeInterval}
; time interval that the requested graph is to contain data
; for.
; @param datasetRequests {in} {type=objarr of SpdfDatasetRequests}
; specifies the dataset information.
; @keyword graphOptions {in} {type=int} {default=0}
; graph option bit-mask value.
; @keyword imageFormats {in} {type=strarr} {default=PNG}
; format of graph file.
; @keyword binData {in} {optional} {type=SpdfBinData}
; data binning parameters to apply to result file.
; @returns reference to an SpdfGraphRequest object.
;-
function SpdfGraphRequest::init, $
timeInterval, datasetRequests, $
graphOptions = graphOptions, imageFormats = imageFormats, $
binData = binData
compile_opt idl2
self.timeInterval = ptr_new(timeInterval)
self.datasetRequests = ptr_new(datasetRequests)
if keyword_set(graphOptions) then begin
self.graphOptions = ptr_new(graphOptions)
end
if keyword_set(imageFormats) then begin
self.imageFormats = ptr_new(imageFormats)
end
if keyword_set(binData) then begin
self.binData = ptr_new(binData)
end
return, self
end
;+
; Performs cleanup operations when this object is destroyed.
;-
pro SpdfGraphRequest::cleanup
compile_opt idl2
if ptr_valid(self.timeInterval) then ptr_free, self.timeInterval
if ptr_valid(self.datasetRequests) then ptr_free, self.datasetRequests
if ptr_valid(self.graphOptions) then ptr_free, self.graphOptions
if ptr_valid(self.imageFormats) then ptr_free, self.imageFormats
if ptr_valid(self.binData) then ptr_free, self.binData
end
;+
; Gets the time interval of this request.
;
; @returns time interval of this request.
;-
function SpdfGraphRequest::getTimeInterval
compile_opt idl2
return, *self.timeInterval
end
;+
; Gets the dataset information of this request.
;
; @returns reference to objarr of SpdfDatasetRequest's.
;-
function SpdfGraphRequest::getDatasetRequests
compile_opt idl2
return, *self.datasetRequests
end
;+
; Gets the graph options of this request.
;
; @returns graph options of this request.
;-
function SpdfGraphRequest::getGraphOptions
compile_opt idl2
return, *self.graphOptions
end
;+
; Gets the image formats of this request.
;
; @returns reference to strarr of image formats.
;-
function SpdfGraphRequest::getImageFormats
compile_opt idl2
return, *self.imageFormats
end
;+
; Gets the binData parameters.
;
; @returns binData parameters.
;-
function SpdfGraphRequest::getBinData
compile_opt idl2
return, *self.binData
end
;+
; Creates a GraphRequest element using the given XML DOM document with
; the values of this object.
;
; @param doc {in} {type=IDLffXMLDOMDocument}
; document in which to create the GraphRequest element.
; @returns a reference to a new IDLffXMLDOMElement representation of
; this object.
;-
function SpdfGraphRequest::createDomElement, $
doc
compile_opt idl2
graphRequestElement = doc->createElement('GraphRequest')
timeIntervalElement = (*self.timeInterval)->createDomElement(doc)
ovoid = graphRequestElement->appendChild(timeIntervalElement)
for i = 0, n_elements(*self.datasetRequests) - 1 do begin
datasetRequestElement = $
(*self.datasetRequests)[i]->createDomElement(doc)
ovoid = graphRequestElement->appendChild(datasetRequestElement)
endfor
if ptr_valid(self.graphOptions) then begin
for i = 0, n_elements(*self.graphOptions) - 1 do begin
graphOptionElement = doc->createElement('GraphOption')
ovoid = graphRequestElement->appendChild(graphOptionElement)
graphOptionText = doc->createTextNode((*self.graphOptions)[i])
ovoid = graphOptionElement->appendChild(graphOptionText)
endfor
end
if ptr_valid(self.imageFormats) then begin
for i = 0, n_elements(*self.imageFormats) - 1 do begin
imageFormatElement = doc->createElement('ImageFormat')
ovoid = graphRequestElement->appendChild(imageFormatElement)
imageFormatText = doc->createTextNode((*self.imageFormats)[i])
ovoid = imageFormatElement->appendChild(imageFormatText)
endfor
end
if ptr_valid(self.binData) then begin
binDataElement = (*self.binData)->createDomElement(doc)
ovoid = graphRequestElement->appendChild(binDataElement)
end
return, graphRequestElement
end
;+
; Defines the SpdfGraphRequest class.
;
; @field timeInterval time interval of this request.
; @field datasetRequests identifies the datasets for this request.
; @field graphOptions graph options for this request.
; @field imageFormats format options for this request.
; @field binData data binning parameters.
;-
pro SpdfGraphRequest__define
compile_opt idl2
struct = { SpdfGraphRequest, $
timeInterval:ptr_new(), $
datasetRequests:ptr_new(), $
graphOptions:ptr_new(), $
imageFormats:ptr_new(), $
binData:ptr_new() $
}
end