TkN 2.1
Toolkit for Nuclei
tkensdf_builder.h
1/********************************************************************************
2 * Copyright (c) : Université de Lyon 1, CNRS/IN2P3, UMR5822, *
3 * IP2I, F-69622 Villeurbanne Cedex, France *
4 * Normandie Université, ENSICAEN, UNICAEN, CNRS/IN2P3, *
5 * LPC Caen, F-14000 Caen, France *
6 * Contibutor(s) : *
7 * Jérémie Dudouet jeremie.dudouet@cnrs.fr [2020] *
8 * Diego Gruyer diego.gruyer@cnrs.fr [2020] *
9 * *
10 * This software is governed by the CeCILL-B license under French law and *
11 * abiding by the rules of distribution of free software. You can use, *
12 * modify and/ or redistribute the software under the terms of the *
13 * CeCILL-B license as circulated by CEA, CNRS and INRIA at the following *
14 * URL \"http://www.cecill.info\". *
15 * *
16 * As a counterpart to the access to the source code and rights to copy, *
17 * modify and redistribute granted by the license, users are provided *
18 * only with a limited warranty and the software's author, the holder of *
19 * the economic rights, and the successive licensors have only limited *
20 * liability. *
21 * *
22 * In this respect, the user's attention is drawn to the risks associated *
23 * with loading, using, modifying and/or developing or reproducing the *
24 * software by the user in light of its specific status of free software, *
25 * that may mean that it is complicated to manipulate, and that also *
26 * therefore means that it is reserved for developers and experienced *
27 * professionals having in-depth computer knowledge. Users are therefore *
28 * encouraged to load and test the software's suitability as regards *
29 * their requirements in conditions enabling the security of their *
30 * systems and/or data to be ensured and, more generally, to use and *
31 * operate it in the same conditions as regards security. *
32 * *
33 * The fact that you are presently reading this means that you have had *
34 * knowledge of the CeCILL-B license and that you accept its terms. *
35 ********************************************************************************/
36
37#ifndef tkensdf_builder_H
38#define tkensdf_builder_H
39
40#include "tkn_config.h"
41#include "tkdatabase.h"
42#include "tkensdf_reader.h"
43#include "tklevel_builder.h"
44#include "tkdecay_builder.h"
45
46#ifdef HAS_ROOT
47#include "TClass.h"
48#endif
49
50
51namespace tkn {
52
54
55private:
56 tkdatabase *fDataBase;
57
58 int fDatasetIndex = 0;
59 int fIsotopeIndex = 0;
60
61 tkensdf_reader fensdf_reader;
62
63 tklevel_builder *flevel_builder = nullptr;
64 tkdecay_builder *fdecay_builder = nullptr;
65
66public:
67 tkensdf_builder(tkdatabase *_database, const tkstring &_input_folder);
69
70protected:
71 bool read_dataset(tkensdf_ident_rec *_data_set, int _dataset_idx);
72
73public:
74
75 int fill_database();
76 int add_dataset(tkensdf_ident_rec &_dataset, const tkstring &_comment);
77
78 void set_level_builder(tklevel_builder* _lvl_builder) {flevel_builder = _lvl_builder;}
79 void set_decay_builder(tkdecay_builder* _trs_builder) {fdecay_builder = _trs_builder;}
80
81
82#ifdef HAS_ROOT
84 ClassDef(tkensdf_builder,0);
85#endif
86};
87
88}
89#endif
90
91
Interface to the sqlite database.
Definition: tkdatabase.h:57
Filling of the ENSDF decay properties.
Main class dedicated to the ENSDF records decoding.
virtual ~tkensdf_builder()
void set_decay_builder(tkdecay_builder *_trs_builder)
void set_level_builder(tklevel_builder *_lvl_builder)
tkensdf_builder(tkdatabase *_database, const tkstring &_input_folder)
int add_dataset(tkensdf_ident_rec &_dataset, const tkstring &_comment)
Decodding of the ENSDF identification record properties.
Main class dedicated to ENSDF ascii files reading.
Filling of the ENSDF level properties.
std::string with usefull tricks from TString (ROOT) and KVString (KaliVeda) and more....
Definition: tkstring.h:54
Definition: tklog.cpp:39