source: palm/trunk/UTIL/chemistry/gasphase_preproc/kpp4palm/src/utils.h @ 4590

Last change on this file since 4590 was 3799, checked in by forkel, 6 years ago

editing in kpp4palm: add statements for avoiding unused variables, remove $Id

File size: 3.0 KB
Line 
1#ifndef UTIL
2#define UTIL 1
3
4// ############################################################################
5//
6//     create_mz_kpp_module
7//
8//     create scalar code from .f90 sources created by KPP to be used in MESSy
9//
10//     COPYRIGHT Klaus Ketelsen and MPI-CH   April 2007
11//
12// ############################################################################
13//
14//
15// Former revisions:
16// -----------------------
17// Deleted $Id since document_changes does not work for C and C++   (15.03.2019, forkel)
18//
19// initial version                                  (Nov. 2016, ketelsen)
20//
21
22#include <string>
23#include <list>
24#include <vector>
25
26#include <iostream>
27#include <string>
28
29using namespace std;
30
31extern void my_abort(string s);
32extern string my_to_upper(string sinp);
33
34class Vvar {
35 public:
36  string                name;
37  vector<string>        dim_var;
38
39  int nr_dim() {return dim_var.size(); };
40  void clear() {name.clear(); dim_var.clear(); return; };
41};
42
43class control_switches {
44 private:
45  bool   vector_mode;            // false     Generate scalar code
46                                 // true      Generate vector code
47
48  string vector_length;
49
50  int de_index_mode;              // 0: no de-indexing
51                                  // 1: normal de-indexing
52                                  // 2: 'fast' de-indexing  (LU)
53                                  // 3: 'old' de-indexing
54
55 public:
56
57  void   set_vector_mode()              {vector_mode = true; return;};
58  void   set_vector_length (string s)   {vector_length=s; return;};
59  void   set_de_index_mode(int i)       {de_index_mode = i; return;};
60
61
62  bool   is_vector()           {return vector_mode;};
63  string get_vector_length ()  {return vector_length;};
64  int de_indexing ()           {return de_index_mode;};
65
66  control_switches () {vector_mode = false; vector_length="1"; de_index_mode=0;} 
67};
68
69extern control_switches kpp_switches;
70
71class string_token {
72 private:
73  int                         size_val;
74  string                      seperator;
75  vector <string>             tokens;
76  vector <string>::iterator   is;
77  vector <int>                position;
78
79 public:
80    void set_separator (string s) {seperator.clear();seperator=s; return; };
81
82    void    fill_token (string s);
83    bool    get_next_token(string &s) { s=*is++; return (is == tokens.end()); };
84    string  get_token_by_index (int index) { if(index <= size_val-1) {
85                                               return tokens[index]; 
86                                             } else {
87                                               return " "; }; };
88    int     size()                         { return size_val; };
89    void    update (int i, string s)       { tokens[i].clear(); tokens[i] = s;return;};
90    int     get_position(int i)            { return position[i]; };
91    void    reset (string s)               { tokens.clear(); fill_token (s); return; };
92
93
94    string_token ()         {size_val=0;seperator=" ";};
95    string_token (string s) {size_val=0;seperator=s;};
96
97};
98
99#endif
Note: See TracBrowser for help on using the repository browser.