#include "drawtypes/label.hpp" POLYBAR_NS namespace drawtypes { string label::get() const { return m_tokenized; } label::operator bool() { return !m_text.empty(); } label_t label::clone() { return label_t{new label(m_text, m_foreground, m_background, m_underline, m_overline, m_font, m_padding, m_margin, m_maxlen, m_ellipsis, m_token_bounds)}; } void label::reset_tokens() { m_tokenized = m_text; m_token_iterator = m_token_bounds.begin(); } bool label::has_token(string token) { return m_text.find(token) != string::npos; } void label::replace_token(string token, string replacement) { if (m_text.find(token) == string::npos) return; m_tokenized = string_util::replace_all_bounded(m_tokenized, token, replacement, m_token_iterator->min, m_token_iterator->max); m_token_iterator++; } void label::replace_defined_values(const label_t& label) { if (!label->m_foreground.empty()) m_foreground = label->m_foreground; if (!label->m_background.empty()) m_background = label->m_background; if (!label->m_underline.empty()) m_underline = label->m_underline; if (!label->m_overline.empty()) m_overline = label->m_overline; } void label::copy_undefined(const label_t& label) { if (m_foreground.empty() && !label->m_foreground.empty()) m_foreground = label->m_foreground; if (m_background.empty() && !label->m_background.empty()) m_background = label->m_background; if (m_underline.empty() && !label->m_underline.empty()) m_underline = label->m_underline; if (m_overline.empty() && !label->m_overline.empty()) m_overline = label->m_overline; if (m_font == 0 && label->m_font != 0) m_font = label->m_font; if (m_padding == 0 && label->m_padding != 0) m_padding = label->m_padding; if (m_margin == 0 && label->m_margin != 0) m_margin = label->m_margin; if (m_maxlen == 0 && label->m_maxlen != 0) { m_maxlen = label->m_maxlen; m_ellipsis = label->m_ellipsis; } } /** * Create a label by loading values from the configuration */ label_t load_label(const config& conf, string section, string name, bool required, string def) { vector bound; name = string_util::ltrim(string_util::rtrim(name, '>'), '<'); string text; if (required) text = conf.get(section, name); else text = conf.get(section, name, def); vector text_split = string_util::split(text, '%'); // get rid of false positives (lemonbar-style declarations) for (size_t i = 0; i < text_split.size(); i++) { if (!text_split[i].empty() && text_split[i].at(0) == '{') text_split.erase(text_split.begin() + i--); } for (size_t i = 1; i < text_split.size(); i += 2) { struct bounds bound_vals = {0, 0}; size_t delim_min = text_split[i].find(':'), delim_max = text_split[i].find(':', delim_min + 1); if (delim_min != string::npos) { if (delim_max != string::npos) { bound_vals.min = stoul(text_split[i].substr(delim_min + 1, delim_max - delim_min - 1)); bound_vals.max = stoul(text_split[i].substr(delim_max + 1)); } else bound_vals.min = stoul(text_split[i].substr(delim_min + 1)); } bound.push_back(bound_vals); text = string_util::replace_all(text, text_split[i], text_split[i].substr(0, delim_min)); } // clang-format off return label_t{new label_t::element_type(text, conf.get(section, name + "-foreground", ""), conf.get(section, name + "-background", ""), conf.get(section, name + "-underline", ""), conf.get(section, name + "-overline", ""), conf.get(section, name + "-font", 0), conf.get(section, name + "-padding", 0), conf.get(section, name + "-margin", 0), conf.get(section, name + "-maxlen", 0), conf.get(section, name + "-ellipsis", true), bound)}; // clang-format on } /** * Create a label by loading optional values from the configuration */ label_t load_optional_label(const config& conf, string section, string name, string def) { return load_label(conf, section, name, false, def); } /** * Create an icon by loading values from the configuration */ icon_t load_icon(const config& conf, string section, string name, bool required, string def) { return load_label(conf, section, name, required, def); } /** * Create an icon by loading optional values from the configuration */ icon_t load_optional_icon(const config& conf, string section, string name, string def) { return load_icon(conf, section, name, false, def); } } POLYBAR_NS_END