si_step_lampflats.c

00001 /* $Id: si_step_lampflats.c,v 1.10 2005/10/08 10:34:50 amodigli Exp $
00002  *
00003  * This file is part of the CPL (Common Pipeline Library)
00004  * Copyright (C) 2002 European Southern Observatory
00005  *
00006  * This library is free software; you can redistribute it and/or
00007  * modify it under the terms of the GNU Lesser General Public
00008  * License as published by the Free Software Foundation; either
00009  * version 2.1 of the License, or (at your option) any later version.
00010  *
00011  * This library is distributed in the hope that it will be useful,
00012  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00013  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00014  * Lesser General Public License for more details.
00015  *
00016  * You should have received a copy of the GNU Lesser General Public
00017  * License along with this library; if not, write to the Free Software
00018  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00019  */
00020 /*
00021  * $Author: amodigli $
00022  * $Date: 2005/10/08 10:34:50 $
00023  * $Revision: 1.10 $
00024  * $Name:  $
00025  */
00026 
00027  /****************************************************************
00028   *          Step_Lampflats Frames Data Reduction                          *
00029   ****************************************************************/
00030 #include <strings.h>
00031 #include <string.h>
00032 #include <stdio.h>
00033 
00034 
00035 #ifdef HAVE_CONFIG_H
00036 #include <config.h>          /* allows the program compilation */
00037 #endif
00038 #include <cxmacros.h>
00039 #include <cxtypes.h>
00040 #include <cxmessages.h>     /* defines message level types */
00041 #include <cpl_memory.h>       /* defines memory allocation functions */
00042 
00043 #include <cpl_parameterlist.h>    /* defines parlist structure */
00044 #include <cpl_msg.h>  /* defines different messaging functions */
00045 
00046 
00047 #include <cpl_recipe.h>     /* recipe plugin definitions */
00048 #include <cpl_plugin.h>     /* memory allocations functions */
00049 #include <cpl_pluginlist.h> /* memory allocations functions */
00050 #include <cpl_frameset.h>   /* defines operations on frames */
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   * Create the recipe instance, i.e. setup the parameter list for this
00067   * recipe and make it available to the application using the interface.
00068   *
00069   */
00070 
00071 
00072 cxint
00073 si_step_lampflats_create(cpl_plugin *plugin)
00074 {
00075 
00076   /*
00077    * We have to provide the option we accept to the application.
00078    * We need to setup our parameter list and hook it into the recipe
00079    * interface.
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    * Fill the parameter list.
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    * We just destroy what was created during the plugin initializzation phase
00120    * i.e. the parameter list. The frame set is managed by the application which
00121    * called us, so that we must not touch it.
00122    */
00123   /* cx_print("destroy\n"); */
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  * The actual recipe actually start here.
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 }

Generated on Wed Oct 26 13:08:54 2005 for SINFONI Pipeline Reference Manual by doxygen1.2.13.1 written by Dimitri van Heesch, © 1997-2001