// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab /* * Ceph - scalable distributed file system * * Copyright (C) 2014 Haomai Wang * * This is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software * Foundation. See file COPYING. * */ #include #include #include #include #include "CompressionPlugin.h" #include "Compressor.h" #include "include/random.h" #include "common/ceph_context.h" #include "common/debug.h" #include "common/dout.h" std::string Compressor::get_comp_alg_name(int a) { auto p = std::find_if(std::cbegin(compression_algorithms), std::cend(compression_algorithms), [a](const auto& kv) { return kv.second == a; }); if (std::cend(compression_algorithms) == p) return "???"; // It would be nice to revise this... return std::string { p->first }; } boost::optional Compressor::get_comp_alg_type(const std::string &s) { if (auto pos = compression_algorithms.find(s.c_str()); std::end(compression_algorithms) != pos) return pos->second; return boost::optional {}; } const char *Compressor::get_comp_mode_name(int m) { switch (m) { case COMP_NONE: return "none"; case COMP_PASSIVE: return "passive"; case COMP_AGGRESSIVE: return "aggressive"; case COMP_FORCE: return "force"; default: return "???"; } } boost::optional Compressor::get_comp_mode_type(const std::string &s) { if (s == "force") return COMP_FORCE; if (s == "aggressive") return COMP_AGGRESSIVE; if (s == "passive") return COMP_PASSIVE; if (s == "none") return COMP_NONE; return boost::optional(); } CompressorRef Compressor::create(CephContext *cct, const std::string &type) { // support "random" for teuthology testing if (type == "random") { int alg = ceph::util::generate_random_number(0, COMP_ALG_LAST - 1); if (alg == COMP_ALG_NONE) { return nullptr; } return create(cct, alg); } CompressorRef cs_impl = NULL; std::stringstream ss; PluginRegistry *reg = cct->get_plugin_registry(); CompressionPlugin *factory = dynamic_cast(reg->get_with_load("compressor", type)); if (factory == NULL) { lderr(cct) << __func__ << " cannot load compressor of type " << type << dendl; return NULL; } int err = factory->factory(&cs_impl, &ss); if (err) lderr(cct) << __func__ << " factory return error " << err << dendl; return cs_impl; } CompressorRef Compressor::create(CephContext *cct, int alg) { if (alg < 0 || alg >= COMP_ALG_LAST) { lderr(cct) << __func__ << " invalid algorithm value:" << alg << dendl; return CompressorRef(); } std::string type_name = get_comp_alg_name(alg); return create(cct, type_name); }