00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030 #include <strings.h>
00031 #include <string.h>
00032 #include <stdio.h>
00033
00034
00035 #ifdef HAVE_CONFIG_H
00036 #include <config.h>
00037 #endif
00038 #include <cxmacros.h>
00039 #include <cxtypes.h>
00040 #include <cxmessages.h>
00041 #include <cpl_memory.h>
00042
00043 #include <cpl_parameterlist.h>
00044 #include <cpl_msg.h>
00045
00046
00047 #include <cpl_recipe.h>
00048 #include <cpl_plugin.h>
00049 #include <cpl_pluginlist.h>
00050 #include <cpl_frameset.h>
00051 #include <cpl_error.h>
00052
00053 #include <sinfoni_general_config.h>
00054 #include <sinfoni_lamp_flats_config.h>
00055 #include <lamp_flats.h>
00056 #include <sinfoni_memory.h>
00057
00058 static cxint si_step_lampflats(cpl_parameterlist *, cpl_frameset *);
00059 const char * sinfoni_get_licence(void)
00060 {
00061 return "bla bla";
00062
00063 }
00064
00065
00066
00067
00068
00069
00070
00071
00072 cxint
00073 si_step_lampflats_create(cpl_plugin *plugin)
00074 {
00075
00076
00077
00078
00079
00080
00081 cpl_recipe *recipe = (cpl_recipe *)plugin;
00082 recipe->parameters = cpl_parameterlist_new();
00083 if(recipe->parameters == NULL) {
00084 return 1;
00085 }
00086
00087
00088
00089
00090 sinfoni_general_config_add(recipe->parameters);
00091 sinfoni_lamp_flats_config_add(recipe->parameters);
00092
00093 return 0;
00094
00095 }
00096
00097 cxint
00098 si_step_lampflats_exec(cpl_plugin *plugin)
00099 {
00100
00101 cpl_recipe *recipe = (cpl_recipe *) plugin;
00102 if(recipe->parameters == NULL) {
00103 return 1;
00104 }
00105 if(recipe->frames == NULL) {
00106 return 1;
00107 }
00108 cpl_error_reset();
00109 return si_step_lampflats(recipe->parameters, recipe->frames);
00110
00111 }
00112
00113 cxint
00114 si_step_lampflats_destroy(cpl_plugin *plugin)
00115 {
00116
00117 cpl_recipe *recipe = (cpl_recipe *) plugin;
00118
00119
00120
00121
00122
00123
00124 cpl_parameterlist_delete(recipe->parameters);
00125
00126 return 0;
00127
00128 }
00129
00130
00131 int
00132 cpl_plugin_get_info(cpl_pluginlist *list)
00133 {
00134
00135 cpl_recipe *recipe = cpl_calloc(1, sizeof *recipe);
00136 cpl_plugin *plugin = &recipe->interface;
00137
00138
00139 cpl_plugin_init(plugin,
00140 CPL_PLUGIN_API,
00141 SINFONI_BINARY_VERSION,
00142 CPL_PLUGIN_TYPE_RECIPE,
00143 "si_step_lampflats",
00144 "Lamp Flats data reduction",
00145 "TBD",
00146 "A. Modigliani",
00147 "amodigli@eso.org",
00148 "No license",
00149 si_step_lampflats_create,
00150 si_step_lampflats_exec,
00151 si_step_lampflats_destroy);
00152
00153 cpl_pluginlist_append(list, plugin);
00154
00155 return 0;
00156
00157 }
00158
00159
00160
00161
00162
00163
00164
00165 static cxint
00166 si_step_lampflats(cpl_parameterlist *config, cpl_frameset *set)
00167 {
00168
00169 const char *_id = "si_step_lampflats";
00170 int ind =0;
00171
00172 if(sinfoni_dfs_set_groups(set)) {
00173
00174 cpl_msg_error(_id, "Cannot indentify RAW and CALIB frames") ;
00175 return -1;
00176
00177 }
00178
00179 {
00180 cpl_msg_info (_id,"Running") ;
00181 if ( -1 == (ind = lamp_flats(config, set ) ) )
00182 {
00183 cpl_msg_error(_id,"no: %d\n", ind) ;
00184 return -1 ;
00185 }
00186
00187 cpl_msg_info (_id,"success") ;
00188 }
00189 return 0 ;
00190 }