abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 16:44 | Nová verze

    Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.

    Ladislav Hagara | Komentářů: 2
    včera 15:11 | IT novinky

    Miliardy korun na digitalizaci služeb státu nestačily. Stát do ní v letech 2020 až 2024 vložil víc než 50 miliard korun, ale původní cíl se nepodařilo splnit. Od loňského února měly být služby státu plně digitalizované a občané měli mít právo komunikovat se státem digitálně. Do tohoto data se povedlo plně digitalizovat 18 procent agendových služeb státu. Dnes to uvedl Nejvyšší kontrolní úřad (NKÚ) v souhrnné zprávě o stavu digitalizace v Česku. Zpráva vychází z výsledků víc než 50 kontrol, které NKÚ v posledních pěti letech v tomto oboru uskutečnil.

    Ladislav Hagara | Komentářů: 8
    včera 13:55 | IT novinky

    Nadace Wikimedia, která je provozovatelem internetové encyklopedie Wikipedia, oznámila u příležitosti 25. výročí vzniku encyklopedie nové licenční dohody s firmami vyvíjejícími umělou inteligenci (AI). Mezi partnery encyklopedie tak nově patří Microsoft, Amazon a Meta Platforms, ale také start-up Perplexity a francouzská společnost Mistral AI. Wikimedia má podobnou dohodu od roku 2022 také se společností Google ze skupiny

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Nová verze

    D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    včera 02:00 | Nová verze

    Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    15.1. 19:22 | Humor

    CreepyLink.com je nový zkracovač URL adres, 'díky kterému budou vaše odkazy vypadat tak podezřele, jak je to jen možné'. Například odkaz na abclinuxu.cz tento zkracovač převádí do podoby 'https://netflix.web-safe.link/logger_8oIlgs_free_money.php'. Dle prohlášení autora je CreepyLink alternativou ke zkracovači ShadyURL (repozitář na githubu), který dnes již bohužel není v provozu.

    NUKE GAZA! 🎆 | Komentářů: 3
    15.1. 12:33 | IT novinky

    Na blogu Raspberry Pi byla představena rozšiřující deska Raspberry Pi AI HAT+ 2 s akcelerátorem Hailo-10 a 8 GB RAM. Na rozdíl od předchozí Raspberry Pi AI HAT+ podporuje generativní AI. Cena desky je 130 dolarů.

    Ladislav Hagara | Komentářů: 3
    15.1. 12:11 | Komunita

    Wikipedie slaví 25. výročí svého založení. Vznikla 15. ledna 2001 jako doplňkový projekt k dnes již neexistující encyklopedii Nupedia. Doména wikipedia.org byla zaregistrována 12. ledna 2001. Zítra proběhne v Praze Večer svobodné kultury, který pořádá spolek Wikimedia ČR.

    Ladislav Hagara | Komentářů: 1
    15.1. 04:44 | Nová verze

    Po více než dvou letech od vydání předchozí verze 2.12 byla vydána nová stabilní verze 2.14 systémového zavaděče GNU GRUB (GRand Unified Bootloader, Wikipedie). Přehled novinek v souboru NEWS a v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    15.1. 02:22 | Nová verze

    Google Chrome 144 byl prohlášen za stabilní. Nejnovější stabilní verze 144.0.7559.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 10 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře (YouTube).

    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (5%)
     (0%)
     (9%)
     (19%)
     (3%)
     (6%)
     (3%)
     (11%)
     (42%)
    Celkem 464 hlasů
     Komentářů: 12, poslední 14.1. 21:12
    Rozcestník

    Dotaz: [C++] ANSI Colors a reset

    hermes avatar 4.11.2021 19:34 hermes | skóre: 7 | blog: Elektro | BA
    [C++] ANSI Colors a reset
    Přečteno: 501×
    Ahojte, robím na jednej konzolovej utilite. kôli zjednodušeniu orientácie tam používam farby.Tie volím cez ANSI escape sekvencie. Inšpiroval som týmto článkom (je to v pythone, ale pre inšpiráciu to stačí).

    Do tabuľky vypisujem rôzne hodnoty a veličiny a stringy, skladám cez std::stringstream.

    No a zaujímalo by ma, či neexistuje nejaká escape sekvencia, ktorá by dokázala vyresetovať farbu, ale nie na defaultnú farbu ako cez "\x1B[0m", ale na predchádzajúcu farbu. Viete o niečom takom? alebo ANSI nič také nepodporuje? Mohol by som si aktuálnu farbu niekam ukladať a potom sa k nej vrátiť, ale to by mi zbytočne skomplikovalo kód (ale ak to nepojde nejakou escape sekvenciou, tak to tak asi spravím)

    Řešení dotazu:


    Odpovědi

    Řešení 1× (Вherzet)
    4.11.2021 20:29 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: [C++] ANSI Colors a reset
    Ja som o tom nikdy nepočul, o takej feature. Escape sekvencie je LOW level interface, takže predpokladom, že priamo v ňom nie. Uvidí sa, čo iný.
    debian.plus@protonmail.com
    Řešení 1× (Andrej)
    11.11.2021 06:57 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: [C++] ANSI Colors a reset

    C++ má přesně k takovým účelům (udržování kontextu a návrat do původního stavu) své standardní mechanismy. Předchozí barva se dá jednoduše ukládat na zásobník a pak nechat obnovit destruktorem.

    Uvedený příklad není (kvůli statické proměnné) thread-safe, nicméně to by nemuselo vadit, protože terminál bývá jeden.

    Taky to podporuje jenom 256 barev místo 24-bitových, ale to se dá celkem triviálně doplnit.

    #include <cstdint>
    #include <ios>
    #include <iostream>
    #include <string>
    #include <string_view>
    #include <utility>
    
    using std::uint8_t;
    using std::size_t;
    
    class Color {
      class Value {
        const std::string code_;
       public:
        Value(std::string_view code);      // C++20: constexpr
        std::ostream& operator ()(std::ostream &out) const;
      };
    
      Color(std::ostream *out, const Value &previous,
            const Value &value, bool value_owned);
      std::ostream& operator ()(std::ostream &out);
      static const Value *_current;
      std::ostream *out_;
      const Value &previous_;
      const Value &value_;
      const bool value_owned_;
      friend std::ostream& operator <<(std::ostream& out, Color &&color);
    
     public:
      Color(Value &&value);
      Color(const Value &value);
      Color(std::ostream &out, Value &&value);
      Color(std::ostream &out, const Value &value);
      static Value custom(uint8_t color);  // C++20: constexpr
      ~Color();
    
      static const Value THICK;            // C++20: constexpr
      static const Value RESET;            // C++20: constexpr
      static const Value BLACK;            // C++20: constexpr
      static const Value RED;              // C++20: constexpr
      static const Value GREEN;            // C++20: constexpr
      static const Value YELLOW;           // C++20: constexpr
      static const Value BLUE;             // C++20: constexpr
      static const Value MAGENTA;          // C++20: constexpr
      static const Value CYAN;             // C++20: constexpr
      static const Value WHITE;            // C++20: constexpr
    };
    
    Color::Value::Value(std::string_view code) : code_{code} {}
    std::ostream& Color::Value::operator ()(std::ostream &out) const {
      return out << code_;
    }
    
    Color::Color(std::ostream *out, const Value &previous,
                 const Value &value, bool value_owned) :
        out_{out}, previous_{previous}, value_{value}, value_owned_(value_owned) {}
    std::ostream& Color::operator ()(std::ostream& out) {
      out_ = &out;
      _current = &value_;
      return value_(out);
    }
    Color::Color(Value &&value) :
        Color{nullptr, *_current, *new Value{std::move(value)}, true} {}
    Color::Color(const Value &value) :
        Color{nullptr, *_current, value, false} {}
    Color::Color(std::ostream &out, Value &&value) :
        Color{&out, *_current, *new Value{std::move(value)}, true} {
      _current = &value_;
      value(out);
    }
    Color::Color(std::ostream& out, const Value& value) :
        Color{&out, *_current, value, false} {
      _current = &value_;
      value(out);
    }
    
    Color::Value Color::custom(uint8_t color) {
      return Value("\u001B[38;5;" + std::to_string(color) + 'm');
    }
    
    Color::~Color() {
      if (out_) previous_(*out_);
      _current = &previous_;
      if (value_owned_) delete &value_;
    }
    
    std::ostream& operator <<(std::ostream& out, Color &&color) {
      return color(out);
    }
    
    const Color::Value Color::RESET{"\u001B[0m"};
    const Color::Value Color::THICK{"\u001B[0;1m"};
    const Color::Value Color::BLACK{"\u001B[30;1m"};
    const Color::Value Color::RED{"\u001B[31;1m"};
    const Color::Value Color::GREEN{"\u001B[32;1m"};
    const Color::Value Color::YELLOW{"\u001B[33;1m"};
    const Color::Value Color::BLUE{"\u001B[34;1m"};
    const Color::Value Color::MAGENTA{"\u001B[35;1m"};
    const Color::Value Color::CYAN{"\u001B[36;1m"};
    const Color::Value Color::WHITE{"\u001B[37;1m"};
    const Color::Value *Color::_current = &Color::RESET;
    
    void recursion(size_t base, size_t shift) {
      if (shift < 16) {
        Color next{std::cout, Color::custom(base + shift)};  // overflow intended
        std::cout << shift;
        recursion(base, shift + 1);
        std::cout << shift;
      } else {
        std::cout << " █ ";
        std::cout << Color{Color::BLACK} << 'K'
                  << Color{Color::RED} << 'R'
                  << Color{Color::GREEN} << 'G'
                  << Color{Color::YELLOW} << 'Y'
                  << Color{Color::BLUE} << 'B'
                  << Color{Color::MAGENTA} << 'M'
                  << Color{Color::CYAN} << 'C'
                  << Color{Color::WHITE} << 'W';
        std::cout << " █ ";
      }
    }
    
    int main() {
      std::cout << std::hex << '\n';
      std::cout << Color{Color::THICK} << '>'
                << Color{Color::BLACK} << "black"
                << Color{Color::THICK} << '<'
                << Color{Color::RED} << " red"
                << Color{Color::GREEN} << " green"
                << Color{Color::YELLOW} << " yellow"
                << Color{Color::BLUE} << " blue"
                << Color{Color::MAGENTA} << " magenta"
                << Color{Color::CYAN} << " cyan"
                << Color{Color::WHITE} << " white";
      std::cout << "\n\n";
      std::cout << "This is the default.\n";
      {
        Color red{std::cout, Color::RED};
        std::cout << "This is red.\n";
        {
          Color green{std::cout, Color::GREEN};
          std::cout << "This is green.\n";
          {
            Color blue{std::cout, Color::BLUE};
            std::cout << "This is blue.\n";
            std::cout << Color{Color::YELLOW} << "This is yellow.\n";
            std::cout << "This is blue.\n";
          }
          std::cout << "This is green.\n";
        }
        std::cout << "This is red.\n";
      }
      std::cout << "This is the default.\n\n";
      for (size_t color = 0; color < 256; ++color) {
        recursion(color, 0);
        std::cout << '\n';
      }
      std::cout << '\n';
      {
        Color thick{std::cout, Color::THICK};
        std::cout << "This is fucking thick!!!\n";
        std::cout << Color{Color::custom(77)} << "And this is almost green.\n";
        std::cout << "Thick again.\n";
        Color orange{std::cout, Color::custom(208)};
        std::cout << "This is an arbitrary orange color.\n";
      }
      std::cout << "And this is the default again!\n\n";
    }
    

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.