source: branches/asap-3.x/src/python_asap.cpp@ 1965

Last change on this file since 1965 was 1715, checked in by Max Voronkov, 15 years ago

changed pressure to the mean sea level to match miriad, bugfix, C++ code is now exposed to python

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.6 KB
Line 
1//#---------------------------------------------------------------------------
2//# python_asap.cc: python module for single dish package asap
3//#---------------------------------------------------------------------------
4//# Copyright (C) 2004
5//# ATNF
6//#
7//# This program is free software; you can redistribute it and/or modify it
8//# under the terms of the GNU General Public License as published by the Free
9//# Software Foundation; either version 2 of the License, or (at your option)
10//# any later version.
11//#
12//# This program is distributed in the hope that it will be useful, but
13//# WITHOUT ANY WARRANTY; without even the implied warranty of
14//# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
15//# Public License for more details.
16//#
17//# You should have received a copy of the GNU General Public License along
18//# with this program; if not, write to the Free Software Foundation, Inc.,
19//# 675 Massachusetts Ave, Cambridge, MA 02139, USA.
20//#
21//# Correspondence concerning this software should be addressed as follows:
22//# Internet email: Malte.Marquarding@csiro.au
23//# Postal address: Malte Marquarding,
24//# Australia Telescope National Facility,
25//# P.O. Box 76,
26//# Epping, NSW, 2121,
27//# AUSTRALIA
28//#
29//# $Id: python_asap.cpp 1715 2010-03-17 11:03:25Z MaximVoronkov $
30//#---------------------------------------------------------------------------
31#include <string>
32#include <vector>
33
34#include <boost/python.hpp>
35#include <boost/python/exception_translator.hpp>
36
37#include <casa/aips.h>
38#include <casa/Exceptions/Error.h>
39#include "ScantableWrapper.h"
40
41#ifndef HAVE_LIBPYRAP
42 #include "pyconversions.h"
43#else
44 #include <pyrap/Converters/PycExcp.h>
45 #include <pyrap/Converters/PycBasicData.h>
46#endif
47
48#include "python_asap.h"
49
50#ifndef HAVE_LIBPYRAP
51namespace asap {
52 namespace python {
53
54void translate_ex(const casa::AipsError& e)
55{
56 // Use the Python 'C' API to set up an exception object
57 PyErr_SetString(PyExc_RuntimeError, e.what());
58}
59
60 }
61}
62#endif
63
64using namespace boost::python;
65
66BOOST_PYTHON_MODULE(_asap) {
67 asap::python::python_Scantable();
68 asap::python::python_STFiller();
69 asap::python::python_STSelector();
70 asap::python::python_STMath();
71 asap::python::python_Fitter();
72 asap::python::python_STLineFinder();
73 asap::python::python_STFitEntry();
74 asap::python::python_STWriter();
75 asap::python::python_LineCatalog();
76 asap::python::python_Logger();
77 asap::python::python_STCoordinate();
78 asap::python::python_STAtmosphere();
79
80#ifndef HAVE_LIBPYRAP
81 // Use built-in pyconversions.h
82 register_exception_translator<casa::AipsError>(&asap::python::translate_ex);
83 from_python_sequence < std::vector< asap::ScantableWrapper >,
84 variable_capacity_policy > ();
85 std_vector_to_tuple < int > ();
86 from_python_sequence < std::vector < int >,
87 variable_capacity_policy > ();
88 std_vector_to_tuple < uint > ();
89 from_python_sequence < std::vector < uint >,
90 variable_capacity_policy > ();
91 std_vector_to_tuple < float > ();
92 from_python_sequence < std::vector < float >,
93 variable_capacity_policy > ();
94 std_vector_to_tuple < double > ();
95 from_python_sequence < std::vector < double >,
96 variable_capacity_policy > ();
97 std_vector_to_tuple < std::string > ();
98 from_python_sequence < std::vector < std::string >,
99 variable_capacity_policy > ();
100 std_vector_to_tuple < bool> ();
101 from_python_sequence < std::vector < bool >,
102 variable_capacity_policy > ();
103#else
104 casa::pyrap::register_convert_excp();
105 casa::pyrap::register_convert_basicdata();
106 casa::pyrap::register_convert_std_vector<asap::ScantableWrapper>();
107#endif
108}
Note: See TracBrowser for help on using the repository browser.