source: trunk/environments/g4py/source/materials/pyG4Isotope.cc @ 1337

Last change on this file since 1337 was 1337, checked in by garnier, 14 years ago

tag geant4.9.4 beta 1 + modifs locales

File size: 4.0 KB
Line 
1//
2// ********************************************************************
3// * License and Disclaimer                                           *
4// *                                                                  *
5// * The  Geant4 software  is  copyright of the Copyright Holders  of *
6// * the Geant4 Collaboration.  It is provided  under  the terms  and *
7// * conditions of the Geant4 Software License,  included in the file *
8// * LICENSE and available at  http://cern.ch/geant4/license .  These *
9// * include a list of copyright holders.                             *
10// *                                                                  *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work  make  any representation or  warranty, express or implied, *
14// * regarding  this  software system or assume any liability for its *
15// * use.  Please see the license in the file  LICENSE  and URL above *
16// * for the full disclaimer and the limitation of liability.         *
17// *                                                                  *
18// * This  code  implementation is the result of  the  scientific and *
19// * technical work of the GEANT4 collaboration.                      *
20// * By using,  copying,  modifying or  distributing the software (or *
21// * any work based  on the software)  you  agree  to acknowledge its *
22// * use  in  resulting  scientific  publications,  and indicate your *
23// * acceptance of all terms of the Geant4 Software license.          *
24// ********************************************************************
25//
26// $Id: pyG4Isotope.cc,v 1.1 2008/12/04 08:55:25 kmura Exp $
27// $Name: geant4-09-04-beta-01 $
28// ====================================================================
29//   pyG4Isotope.cc
30//
31//                                         2005 Q
32// ====================================================================
33#include <boost/python.hpp>
34#include "G4Version.hh"
35#include "pyG4indexing.hh"
36#include "G4Isotope.hh"
37
38using namespace boost::python;
39
40// ====================================================================
41// thin wrappers
42// ====================================================================
43namespace pyG4Isotope {
44
45BOOST_PYTHON_FUNCTION_OVERLOADS(f_GetIsotope, G4Isotope::GetIsotope, 1, 2);
46
47// copy constructor is private, so ...
48void Print(G4Isotope& iso)
49{
50  G4cout << iso;
51}
52
53};
54
55using namespace pyG4Isotope;
56
57// ====================================================================
58// module definition
59// ====================================================================
60void export_G4Isotope()
61{
62  class_<G4Isotope, G4Isotope*, boost::noncopyable>
63    ("G4Isotope", "isotope class", no_init)
64    // constructors
65    .def(init<const G4String&, G4int, G4int>())
66    .def(init<const G4String&, G4int, G4int, G4double>())
67    // ---
68#if G4VERSION_NUMBER >= 920
69    .def("GetName",             &G4Isotope::GetName,
70         return_value_policy<reference_existing_object>())
71    .def("SetName",             &G4Isotope::SetName)
72#else
73    .def("GetName",             &G4Isotope::GetName)
74#endif
75    .def("GetZ",                &G4Isotope::GetZ)
76    .def("GetN",                &G4Isotope::GetN)
77    .def("GetA",                &G4Isotope::GetA)
78    .def("GetCountUse",         &G4Isotope::GetCountUse)
79    .def("GetIsotope",          &G4Isotope::GetIsotope,
80         f_GetIsotope()
81         [return_value_policy<reference_existing_object>()])
82    .staticmethod("GetIsotope")
83    .def("GetIsotopeTable",     &G4Isotope::GetIsotopeTable,
84         return_value_policy<reference_existing_object>())
85    .staticmethod("GetIsotopeTable")
86    .def("GetNumberOfIsotopes", &G4Isotope::GetNumberOfIsotopes)
87    .staticmethod("GetNumberOfIsotopes")
88
89    .def("GetIndex",            &G4Isotope::GetIndex)
90    // ---
91    .def("Print", Print)
92    .def(self == self)
93    .def(self != self)
94    ;
95
96  // G4IsotopeTable
97  class_<G4IsotopeTable> ("G4IsotopeTable", "isotope table")
98    .def(vector_indexing_suite<G4IsotopeTable>())
99    .def(self_ns::str(self))
100    ;
101}
102
Note: See TracBrowser for help on using the repository browser.