FUNCTION mvn_sta_get_d8,time,START=st,EN=en,ADVANCE=adv,RETREAT=ret,index=ind,calib=calib,times=times
common mvn_d8,get_ind,all_dat
if n_elements(get_ind) eq 0 then begin
if keyword_set(times) then return,0
dat = {project_name:'MAVEN',valid:0}
print,' ERROR - mvn d8 data not loaded'
return,dat
endif else if get_ind eq -1 then begin
dat = {project_name:'MAVEN',valid:0}
print,' ERROR - mvn d8 data not loaded'
return,dat
endif else if keyword_set(times) then begin
dat=(all_dat.time+all_dat.end_time)/2.
endif else begin
if (n_elements(time) eq 0) and (not keyword_set(st)) and (not keyword_set(en)) $
and (not keyword_set(adv)) and (not keyword_set(ret)) and (n_elements(ind) eq 0) $
then ctime,time,npoints=1
if keyword_set(st) then ind=0l $
else if keyword_set(en) then ind=n_elements(all_dat.time)-1 $
else if keyword_set(adv) then ind=get_ind+1 $
else if keyword_set(ret) then ind=get_ind-1 $
else if n_elements(ind) ne 0 then ind=ind $
else tmpmin = min(abs(all_dat.time-time),ind)
if ind lt 0 or ind ge n_elements(all_dat.time) then begin
dat = {project_name: all_dat.project_name, $
spacecraft: all_dat.spacecraft, $
data_name: all_dat.data_name, $
apid: all_dat.apid, $
valid: 0}
endif else begin
while (all_dat.valid[ind] eq 0 and ind+1 lt n_elements(all_dat.time)) do ind=ind+1
mode = all_dat.mode[ind]
rate = all_dat.rate[ind]
md = all_dat.md[ind]
swp_ind = all_dat.swp_ind[ind]
nrg = reform(all_dat.energy[swp_ind,*])
dat = {project_name: all_dat.project_name, $
spacecraft: all_dat.spacecraft, $
data_name: all_dat.data_name, $
apid: all_dat.apid, $
valid: all_dat.valid[ind], $
quality_flag: all_dat.quality_flag[ind], $
time: all_dat.time[ind], $
end_time: all_dat.end_time[ind], $
integ_t: all_dat.integ_t[ind], $
md: md, $
mode: mode, $
rate: rate, $
swp_ind: swp_ind, $
energy: nrg, $
nrate: all_dat.nrate, $
rate_labels: all_dat.rate_labels, $
rates: reform(all_dat.rates[ind,*])}
get_ind=ind
endelse
endelse
return,dat
end