Avoid assert when label is an empty string
authorJon Burgess <jburgess777@gmail.com>
Sun, 28 Oct 2018 14:49:09 +0000 (14:49 +0000)
committerJon Burgess <jburgess777@gmail.com>
Sun, 28 Oct 2018 14:57:04 +0000 (14:57 +0000)
Calling back() on an empty string is not allowed and triggers
an assert with recent gcc:

$ cd manual/PRESENTATION_Intro
$ ../../yosys counter.ys
...
/usr/include/c++/8/bits/basic_string.h:1136: std::__cxx11::basic_string<_CharT, _Traits, _Alloc>::reference std::__cxx11::basic_string<_CharT, _Traits, _Alloc>::back() [with _CharT = char; _Traits = std::char_traits<char>; _Alloc = std::allocator<char>; std::__cxx11::basic_string<_CharT, _Traits, _Alloc>::reference = char&]: Assertion '!empty()' failed.

802             if (label.back() == ':' && GetSize(label) > 1)
(gdb) p label
$1 = ""

kernel/yosys.cc

index 21eeadaaf0f09b4ca9895fb84dd6ed338f60b53a..f002955ad66be10e15af47bf0e36cc7421aa1933 100644 (file)
@@ -799,7 +799,7 @@ static void handle_label(std::string &command, bool &from_to_active, const std::
        while (pos < GetSize(command) && command[pos] != ' ' && command[pos] != '\t' && command[pos] != '\r' && command[pos] != '\n')
                label += command[pos++];
 
-       if (label.back() == ':' && GetSize(label) > 1)
+       if (GetSize(label) > 1 && label.back() == ':')
        {
                label = label.substr(0, GetSize(label)-1);
                command = command.substr(pos);