X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=common%2FclitkCommon.h;h=52264cd0258d8f1131a17e3b247b707f624e52d2;hb=880e33e1299652f7a55ff47b8d65eb89f5578e5e;hp=1c5f9a09bf4d6241046e19481b2b267ae644b1df;hpb=931a42358442f4ee4f314613c991c838d4b4e3b7;p=clitk.git diff --git a/common/clitkCommon.h b/common/clitkCommon.h index 1c5f9a0..52264cd 100644 --- a/common/clitkCommon.h +++ b/common/clitkCommon.h @@ -1,67 +1,67 @@ -#ifndef CLITKCOMMON_H -#define CLITKCOMMON_H +/*========================================================================= + Program: vv http://www.creatis.insa-lyon.fr/rio/vv -/** - ------------------------------------------------------------------- - * @file clitkCommon.h - * @author David Sarrut - * @date 17 May 2006 07:57:56 + Authors belong to: + - University of LYON http://www.universite-lyon.fr/ + - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr + - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr - * @brief + This software is distributed WITHOUT ANY WARRANTY; without even + the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR + PURPOSE. See the copyright notices for more information. - -------------------------------------------------------------------*/ + It is distributed under dual licence -// std include -#include -#include -#include -#include -#include -#include -#include -#include -#include + - BSD See included LICENSE.txt file + - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html +======================================================================-====*/ + +#ifndef CLITKCOMMON_H +#define CLITKCOMMON_H -#include "itkMacro.h" +// clitk include +//#include "clitkConfiguration.h" +#include "clitkPortability.h" +#include "clitkExceptionObject.h" + +// itk include (include std) #include +#include +#include +#include + +#include //-------------------------------------------------------------------- namespace clitk { - -#if defined(WIN32) -#define lrint(x) (floor(x+(x>0) ? 0.5 : -0.5)) -#endif - + typedef unsigned char uchar; typedef unsigned short ushort; typedef unsigned int uint; //-------------------------------------------------------------------- // display -#define DD(a) std::cout << #a " = [ " << a << " ]" << std::endl; -#define DDV(a,n) { std::cout << #a " = [ "; for(unsigned int _i_=0; _i_ +void _print_container(T const& a) + { for(typename T::const_iterator i=a.begin();i!=a.end();++i) { std::cout << *i << " "; };} +#define DDS(a) { std::cout << #a " = [ "; _print_container(a) ; std::cout << " ]" << std::endl;std::cout.flush():} //-------------------------------------------------------------------- - // GGO with modified struct name -#define GGO(ggo_filename, args_info) \ - gengetopt_args_info_##ggo_filename args_info; \ - cmdline_parser2(argc, argv, &args_info, 1, 1, 0); \ - if (args_info.config_given) \ - cmdline_parser_configfile (args_info.config_arg, &args_info, 0, 0, 1); \ - else cmdline_parser(argc, argv, &args_info); + // when everything goes wrong +#define WHEREAMI "[ " << __FILE__ << " ] line " << __LINE__ +#define FATAL(a) std::cerr << "ERROR in " << WHEREAMI << ": " << a; exit(0); - - /* //-------------------------------------------------------------------- - // GGO default + //-------------------------------------------------------------------- + // GGO with modified struct name #define GGO(ggo_filename, args_info) \ - gengetopt_args_info_##ggo_filename args_info; \ - cmdline_parser2(argc, argv, &args_info, 1, 1, 0); \ + args_info_##ggo_filename args_info; \ + cmdline_parser_##ggo_filename##2(argc, argv, &args_info, 1, 1, 0); \ if (args_info.config_given) \ - cmdline_parser_configfile (args_info.config_arg, &args_info, 0, 0, 1); \ - else cmdline_parser(argc, argv, &args_info); - - //-------------------------------------------------------------------- - */ + cmdline_parser_##ggo_filename##_configfile (args_info.config_arg, &args_info, 0, 0, 1); \ + else cmdline_parser_##ggo_filename(argc, argv, &args_info); + //-------------------------------------------------------------------- // skip line with # void skipComment(std::istream & is); @@ -187,6 +187,9 @@ namespace clitk { void openFileForReading(std::ifstream & is, const std::string & filename); void openFileForWriting(std::ofstream & os, const std::string & filename); + //-------------------------------------------------------------------- + void readDoubleFromFile(const std::string & filename, std::vector & list); + //-------------------------------------------------------------------- double cotan(double i); double invcotan(double i); @@ -194,7 +197,11 @@ namespace clitk { //-------------------------------------------------------------------- void disableStdCerr(); void enableStdCerr(); - + + //-------------------------------------------------------------------- + template + void CloneImage(const typename ImageType::Pointer & input, typename ImageType::Pointer & output); + #include "clitkCommon.txx" } // end namespace