SAGA C++ API
1.6
|
00001 #if defined(__WAVE__) 00002 #pragma wave option(preserve: 2, line: 1, output: "preprocessed/cpr_checkpoint.cpp") 00003 #endif 00004 // Copyright (c) 2005-2009 Hartmut Kaiser 00005 // Copyright (c) 2008 Andre Merzky (andre@merzky.net) 00006 // 00007 // Distributed under the Boost Software License, Version 1.0. (See accompanying 00008 // job LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) 00009 00010 #if defined(__WAVE__) 00011 #pragma wave option(output: null) 00012 #endif 00013 00014 // this is needed in every file including detail/attribute_impl.hpp and not 00015 // belonging to the engine 00016 #define SAGA_NO_IMPORT_ATTRIBUTE 00017 #define SAGA_EXPORT_ATTRIBUTE SAGA_CPR_PACKAGE_EXPORT 00018 00019 #include <saga/saga/task.hpp> 00020 00021 // include file API and implementation 00022 #include <saga/saga/cpr.hpp> 00023 #include <saga/impl/cpr.hpp> 00024 #include <saga/saga/detail/call.hpp> 00025 00026 #include <boost/assign/list_inserter.hpp> 00027 #include <boost/assign/std/vector.hpp> 00028 00029 #include <saga/saga/detail/attribute_impl.hpp> 00030 00031 #ifdef SAGA_DEBUG 00032 #include <saga/saga/packages/filesystem/preprocessed/cpr_checkpoint.cpp> 00033 #else 00034 00035 #if defined(__WAVE__) 00036 #pragma wave option(preserve: 2, line: 1, output: "preprocessed/cpr_checkpoint.cpp") 00037 #endif 00038 00039 namespace saga 00040 { 00041 namespace cpr 00042 { 00043 namespace metrics 00044 { 00046 saga::metrics::init_data const checkpoint_metric_data[] = 00047 { 00048 // cpr_checkpoint specific metrics 00049 { 00050 checkpoint_modified, 00051 "Metric fires on checkpoint changes, it carries the key of" 00052 "the modified checkpoint file.", 00053 saga::attributes::metric_mode_readonly, 00054 "1", 00055 saga::attributes::metric_type_string, 00056 "" 00057 }, 00058 { 00059 checkpoint_deleted, 00060 "Metric fires on checkpoint deletes, it carries the key of" 00061 "the deleted checkpoint file.", 00062 saga::attributes::metric_mode_readonly, 00063 "1", 00064 saga::attributes::metric_type_string, 00065 "" 00066 }, 00067 }; 00069 00070 } // namespace metrics 00071 00072 checkpoint::checkpoint (session const& s, saga::url url, int mode) 00073 : entry (new saga::impl::cpr_checkpoint (s, url, mode)) 00074 { 00075 // initialize attribute implementation 00076 this->attribute_base::init (true); // no constraints on attributes 00077 00078 // initialize implementation object 00079 this->saga::object::get_impl()->init(); 00080 00081 // initialize metrics 00082 std::vector<saga::metric> metrics; 00083 for (unsigned int i = 0; 00084 i < sizeof(saga::cpr::metrics::checkpoint_metric_data)/sizeof(saga::metrics::init_data); 00085 ++i) 00086 { 00087 saga::metrics::init_data const* p = &saga::cpr::metrics::checkpoint_metric_data[i]; 00088 saga::metric m(*this, p->name, p->description, p->mode, p->unit, 00089 p->type, p->value); 00090 metrics.push_back(m); 00091 } 00092 this->monitorable_base::init (metrics); 00093 00094 // initialize attributes 00095 using namespace boost::assign; 00096 std::vector<std::string> valid_keys; 00097 valid_keys += 00098 attributes::cpr_time, 00099 attributes::cpr_nfliles, 00100 attributes::cpr_mode, 00101 attributes::cpr_parent, 00102 attributes::cpr_children 00103 ; 00104 00105 // initialize list of valid keys 00106 this->init_keynames (valid_keys); 00107 00108 strmap_type attributes_scalar_rw; 00109 insert(attributes_scalar_rw) 00110 (attributes::cpr_time, "") 00111 (attributes::cpr_nfliles, "") 00112 (attributes::cpr_mode, "") 00113 (attributes::cpr_parent, "") 00114 (attributes::cpr_children, "") 00115 ; 00116 00117 // initialize attribute implementation 00118 this->attribute_base::init (strmap_type(), attributes_scalar_rw); 00119 this->attribute_base::init (false, true); // cache only implementation 00120 } 00121 00122 checkpoint::checkpoint (saga::url url, int mode) 00123 : entry (new saga::impl::cpr_checkpoint (detail::get_the_session (), url, mode)) 00124 { 00125 // initialize attribute implementation 00126 this->attribute_base::init (true); // no constraints on attributes 00127 00128 // initialize implementation object 00129 this->saga::object::get_impl()->init(); 00130 00131 // initialize metrics 00132 std::vector<saga::metric> metrics; 00133 for (unsigned int i = 0; 00134 i < sizeof(saga::cpr::metrics::checkpoint_metric_data)/sizeof(saga::metrics::init_data); 00135 ++i) 00136 { 00137 saga::metrics::init_data const* p = &saga::cpr::metrics::checkpoint_metric_data[i]; 00138 saga::metric m(*this, p->name, p->description, p->mode, p->unit, 00139 p->type, p->value); 00140 metrics.push_back(m); 00141 } 00142 00143 this->monitorable_base::init (metrics); 00144 00145 // initialize attributes 00146 using namespace boost::assign; 00147 std::vector<std::string> valid_keys; 00148 valid_keys += 00149 attributes::cpr_time, 00150 attributes::cpr_nfliles, 00151 attributes::cpr_mode, 00152 attributes::cpr_parent, 00153 attributes::cpr_children 00154 ; 00155 00156 // initialize list of valid keys 00157 this->init_keynames (valid_keys); 00158 00159 strmap_type attributes_scalar_rw; 00160 insert(attributes_scalar_rw) 00161 (attributes::cpr_time, "") 00162 (attributes::cpr_nfliles, "") 00163 (attributes::cpr_mode, "") 00164 (attributes::cpr_parent, "") 00165 (attributes::cpr_children, "") 00166 ; 00167 00168 // initialize attribute implementation 00169 this->attribute_base::init (strmap_type(), attributes_scalar_rw); 00170 this->attribute_base::init (false, true); // cache only implementation 00171 } 00172 00173 checkpoint::checkpoint(saga::object const& o) 00174 : entry(o) 00175 { 00176 if (this->get_type() != saga::object::CPRCheckpoint) 00177 { 00178 SAGA_THROW("Bad type conversion.", saga::BadParameter); 00179 } 00180 } 00181 00182 checkpoint::checkpoint (void) 00183 { 00184 } 00185 00186 checkpoint::checkpoint(saga::impl::cpr_checkpoint *impl) 00187 : entry (impl) 00188 { 00189 } 00190 00191 checkpoint::~checkpoint (void) 00192 { 00193 } 00194 00195 checkpoint &checkpoint::operator= (saga::object const& o) 00196 { 00197 return this->saga::name_space::entry::operator=(o), *this; 00198 } 00199 00200 saga::impl::cpr_checkpoint* checkpoint::get_impl() const 00201 { 00202 typedef saga::object base_type; 00203 return static_cast<saga::impl::cpr_checkpoint*>(this->base_type::get_impl()); 00204 } 00205 00206 TR1::shared_ptr <saga::impl::cpr_checkpoint> checkpoint::get_impl_sp(void) const 00207 { 00208 // FIXME: this needs documentation 00209 typedef saga::object base_type; 00210 return TR1::static_pointer_cast <saga::impl::cpr_checkpoint> ( 00211 this->base_type::get_impl_sp()); 00212 } 00213 00215 // factory 00216 SAGA_CALL_CREATE_IMP_3(checkpoint, impl::cpr_checkpoint, session const&, saga::url, int) 00217 00218 SAGA_CALL_IMP_2 (checkpoint, set_parent, saga::url, int); 00219 SAGA_CALL_IMP_1 (checkpoint, get_parent, int); 00220 SAGA_CALL_IMP_0 (checkpoint, get_file_num); 00221 SAGA_CALL_IMP_0 (checkpoint, list_files); 00222 SAGA_CALL_IMP_1 (checkpoint, add_file, saga::url); 00223 SAGA_CALL_IMP_1 (checkpoint, get_file, int); 00224 SAGA_CALL_IMP_2 (checkpoint, open_file, saga::url, int); 00225 SAGA_CALL_IMP_2_EX (checkpoint, open_file, open_file_idx, int, int); 00226 SAGA_CALL_IMP_1 (checkpoint, remove_file, saga::url); 00227 SAGA_CALL_IMP_1_EX (checkpoint, remove_file, remove_file_idx, int); 00228 SAGA_CALL_IMP_2 (checkpoint, update_file, saga::url, saga::url); 00229 SAGA_CALL_IMP_2_EX (checkpoint, update_file, update_file_idx, int, saga::url); 00230 SAGA_CALL_IMP_2 (checkpoint, stage_file, saga::url, saga::url); 00231 SAGA_CALL_IMP_2_EX (checkpoint, stage_file, stage_file_idx, int, saga::url); 00232 SAGA_CALL_IMP_1_EX (checkpoint, stage_file, stage_file_all, saga::url); 00234 00235 } // namespace cpr 00236 00237 namespace detail 00238 { 00240 // implement the attribute functions (we need to explicitly specialize 00241 // the template because the functions are not implemented inline) 00242 template struct SAGA_CPR_PACKAGE_EXPORT_REPEAT attribute<cpr::checkpoint>; 00243 00244 template struct SAGA_CPR_PACKAGE_EXPORT attribute_priv<cpr::checkpoint, task_base::Sync>; 00245 template struct SAGA_CPR_PACKAGE_EXPORT attribute_priv<cpr::checkpoint, task_base::Async>; 00246 template struct SAGA_CPR_PACKAGE_EXPORT attribute_priv<cpr::checkpoint, task_base::Task>; 00247 00248 template struct SAGA_CPR_PACKAGE_EXPORT attribute_sync<cpr::checkpoint>; 00249 } 00250 00252 } // namespace saga 00253 00254 #endif 00255