blob: f591415b121ba1f392b03d6d79238645772b8d3a [file] [log] [blame]
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you 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.
#include <mesos/mesos.hpp>
#include <mesos/module.hpp>
#include <mesos/allocator/allocator.hpp>
#include <mesos/module/allocator.hpp>
#include <stout/try.hpp>
#include "master/constants.hpp"
#include "master/allocator/mesos/hierarchical.hpp"
using namespace mesos;
using mesos::allocator::Allocator;
using mesos::internal::master::allocator::HierarchicalDRFAllocator;
static Allocator* createDRFAllocator(const Parameters& parameters)
{
Try<Allocator*> allocator = HierarchicalDRFAllocator::create();
if (allocator.isError()) {
return nullptr;
}
return allocator.get();
}
// Declares a DRFAllocator module named
// 'org_apache_mesos_TestDRFAllocator'.
mesos::modules::Module<Allocator> org_apache_mesos_TestDRFAllocator(
MESOS_MODULE_API_VERSION,
MESOS_VERSION,
"Apache Mesos",
"modules@mesos.apache.org",
"Test DRFAllocator module.",
nullptr,
createDRFAllocator);