Apache Mesos
utils.hpp
Go to the documentation of this file.
1 // Licensed to the Apache Software Foundation (ASF) under one
2 // or more contributor license agreements. See the NOTICE file
3 // distributed with this work for additional information
4 // regarding copyright ownership. The ASF licenses this file
5 // to you under the Apache License, Version 2.0 (the
6 // "License"); you may not use this file except in compliance
7 // with the License. You may obtain a copy of the License at
8 //
9 // http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing, software
12 // distributed under the License is distributed on an "AS IS" BASIS,
13 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 // See the License for the specific language governing permissions and
15 // limitations under the License.
16 
17 #ifndef __EXAMPLES_UTILS_HPP__
18 #define __EXAMPLES_UTILS_HPP__
19 
20 #include <string>
21 
22 #include <mesos/mesos.hpp>
23 
24 namespace mesos {
25 
26 inline double getScalarResource(const Offer& offer, const std::string& name)
27 {
28  double value = 0.0;
29 
30  for (int i = 0; i < offer.resources_size(); i++) {
31  const Resource& resource = offer.resources(i);
32  if (resource.name() == name &&
33  resource.type() == Value::SCALAR) {
34  value = resource.scalar().value();
35  }
36  }
37 
38  return value;
39 }
40 
41 } // namespace mesos {
42 
43 #endif // __EXAMPLES_UTILS_HPP__
double getScalarResource(const Offer &offer, const std::string &name)
Definition: utils.hpp:26
Definition: agent.hpp:25
constexpr const char * name
Definition: shell.hpp:41