summaryrefslogtreecommitdiffstats
path: root/meta-oem-production-readiness/meta-agl-basesystem/classes/bsmake.bbclass
blob: c1079e217e1bdfcd35656122b1df804e80825eda (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# poky's base.bbclass must be named Makefile, makefile, or GNUmakefile to be processed.
# The names of the basesystem Makefile are Makefile.client and Makefile.server,so you
# need to define a do_compile to process the Makefile.
bsmake_do_compile (){
    oe_runmake -f ${BSMAKE_FILE}
}

# base_do_install under poky's base.bbclass is empty so definition is needed.
bsmake_do_install (){
    oe_runmake  -f ${BSMAKE_FILE} DESTDIR=${D} install
}

#BaseSystem's .so does not have multiple versions. Therefore, overwrite these variables.
SOLIBS = ".so"
FILES_SOLIBSDEV = ""

EXPORT_FUNCTIONS do_compile do_install
/* Literal.String.Backtick */ .highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */ .highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */ .highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */ .highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */ .highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */ .highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */ .highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */ .highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */ .highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */ .highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */ .highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */ .highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */ .highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */ .highlight .vc { color: #336699 } /* Name.Variable.Class */ .highlight .vg { color: #dd7700 } /* Name.Variable.Global */ .highlight .vi { color: #3333bb } /* Name.Variable.Instance */ .highlight .vm { color: #336699 } /* Name.Variable.Magic */ .highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */ }
/*
 * Copyright (c) 2017 TOYOTA MOTOR CORPORATION
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef TMCAGLWM_RESULT_HPP
#define TMCAGLWM_RESULT_HPP

#include <experimental/optional>
#include <functional>

namespace wm {

using std::experimental::optional;
using std::experimental::nullopt;

// We only ever return a string as an error - so just parametrize
// this over result type T
template <typename T>
struct result {
   char const *e;
   optional<T> t;

   bool is_ok() const { return this->t != nullopt; }
   bool is_err() const { return this->e != nullptr; }

   T unwrap() {
      if (this->e != nullptr) {
         throw std::logic_error(this->e);
      }
      return this->t.value();
   }

   operator T() { return this->unwrap(); }

   char const *unwrap_err() { return this->e; }

   optional<T> const &ok() const { return this->t; }
   optional<char const *> err() const {
      return this->e ? optional<char const *>(this->e) : nullopt;
   }

   result<T> map_err(std::function<char const *(char const *)> f);
};

template <typename T>
struct result<T> Err(char const *e) {
   return result<T>{e, nullopt};
}

template <typename T>
struct result<T> Ok(T t) {
   return result<T>{nullptr, t};
}

template <typename T>
result<T> result<T>::map_err(std::function<char const *(char const *)> f) {
   if (this->is_err()) {
      return Err<T>(f(this->e));
   }
   return *this;
}

}  // namespace wm

#endif  // TMCAGLWM_RESULT_HPP