xaizek / uncov (License: AGPLv3+) (since 2018-12-07)
Uncov(er) is a tool that collects and processes code coverage reports.
<root> / src / ColorCane.hpp (369429e99db95911ff95a431faac8a54557a0130) (2,367B) (mode 100644) [raw]
// Copyright (C) 2018 xaizek <xaizek@posteo.net>
//
// This file is part of uncov.
//
// uncov is free software: you can redistribute it and/or modify
// it under the terms of version 3 of the GNU Affero General Public License as
// published by the Free Software Foundation.
//
// uncov is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with uncov.  If not, see <http://www.gnu.org/licenses/>.

#ifndef UNCOV_COLORCANE_HPP_
#define UNCOV_COLORCANE_HPP_

#include <boost/utility/string_ref.hpp>

#include <string>
#include <utility>
#include <vector>

enum class ColorGroup;

/**
 * @brief Single item of a ColorCane.
 */
struct ColorCanePiece
{
    /**
     * @brief Constructs the item.
     *
     * @param text Contents of the item (might be empty).
     * @param hi   Highlighting group of the item.
     */
    ColorCanePiece(std::string text, ColorGroup hi)
        : text(std::move(text)), hi(hi)
    { }

    std::string text; //!< Text of the item (can be empty).
    ColorGroup hi;    //!< Highlighting of the piece.
};

/**
 * @brief Allows constructing string consisting of multiple pieces each of which
 *        is associated with some metadata.
 */
class ColorCane
{
    /**
     * @brief Type of collection of pieces.
     */
    using Pieces = std::vector<ColorCanePiece>;

public:
    /**
     * @brief Appends a string.
     *
     * @param text Text to append.
     * @param hi   Highlighting group of the text.
     */
    void append(boost::string_ref text, ColorGroup hi = {});
    /**
     * @brief Appends single character.
     *
     * @param text Character to append.
     * @param hi   Highlighting group of the text.
     */
    void append(char text, ColorGroup hi = {});

    /**
     * @brief Retrieves beginning of the list of pieces.
     *
     * @returns The iterator.
     */
    Pieces::const_iterator begin() const;
    /**
     * @brief Retrieves end of the list of pieces.
     *
     * @returns The iterator.
     */
    Pieces::const_iterator end() const;

private:
    Pieces pieces; //!< Collection of pieces.
};

#endif // UNCOV_COLORCANE_HPP_
Hints

Before first commit, do not forget to setup your git environment:
git config --global user.name "your_name_here"
git config --global user.email "your@email_here"

Clone this repository using HTTP(S):
git clone https://code.reversed.top/user/xaizek/uncov

Clone this repository using ssh (do not forget to upload a key first):
git clone ssh://rocketgit@code.reversed.top/user/xaizek/uncov

You are allowed to anonymously push to this repository.
This means that your pushed commits will automatically be transformed into a pull request:
... clone the repository ...
... make some changes and some commits ...
git push origin master