LINUX.ORG.RU

Отправить баг репорт

 


0

2

Написал случайно примерно такое:

#include <iostream>

class Curses_table {
public:
	void draw_row() {std::cout << "draw_row fn" << std::endl;};
	void draw_table();
	int dir = 0;
};

void Curses_table::draw_table() {
	auto Curses_table::*draw_fn = &Curses_table::draw_row; //  line 14
	(this->*draw_fn)();
}

int main() {
	Curses_table t;
	t.draw_table();
}
$ g++ 1.cc -Wall
$ ./a.out
draw_row fn
$ g++ 1.cc -Wall -fsanitize=address
$ ./a.out
'draw_fn' (line 14) <== Memory access at offset 40 overflows this variable

$ gcc -v
Using built-in specs.
COLLECT_GCC=gcc
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-pc-linux-gnu/10.2.0/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: /build/gcc/src/gcc/configure --prefix=/usr --libdir=/usr/lib --libexecdir=/usr/lib --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=https://bugs.archlinux.org/ --enable-languages=c,c++,ada,fortran,go,lto,objc,obj-c++,d --with-isl --with-linker-hash-style=gnu --with-system-zlib --enable-__cxa_atexit --enable-cet=auto --enable-checking=release --enable-clocale=gnu --enable-default-pie --enable-default-ssp --enable-gnu-indirect-function --enable-gnu-unique-object --enable-install-libiberty --enable-linker-build-id --enable-lto --enable-multilib --enable-plugin --enable-shared --enable-threads=posix --disable-libssp --disable-libstdcxx-pch --disable-libunwind-exceptions --disable-werror gdc_include_dir=/usr/include/dlang/gdc
Thread model: posix
Supported LTO compression algorithms: zlib zstd
gcc version 10.2.0 (GCC)

Компилируется без ошибок. На 14 строке каким-то лютым синтаксисом создаю указатель на член-функцию. Программа отрабатывает норм. Потом компилирую с сантайзером, запускаю, он жалуется на «Memory access at offset 40 overflows this variable». С clang всё аналогично.

Я, собственно, чего пишу - меня на баг трекере gcc забанили, в общем проблемы у меня там с регистрацией. Сделайте доброе дело - отправьте. Сначала отписаться - «я отправлю», чтобы не было повтора.

★★

Ответ на: комментарий от bhfq

Объяснишь? Просто учти, что любой может написать такую муть, надо какую-то ошибку здесь выдавать.

pavlick ★★
() автор топика
Ответ на: комментарий от pavlick

Не за что.

Что-то написал, надеюсь поймут :)

https://gcc.gnu.org/bugzilla/show_bug.cgi?id=99801

Хотя если использовать просто auto, то тоже всё норм: https://gcc.godbolt.org/z/xnxn5E8EK

fsb4000 ★★★★★
()
Последнее исправление: fsb4000 (всего исправлений: 1)

В Visual Studio санитайзер ничего не находит.

И IntelliSense показывает одинаковый тип у всех 3 вариантов:

auto draw_fn = &Curses_table::draw_row;
auto Curses_table::*draw_fn = &Curses_table::draw_row;
void (Curses_table::*draw_fn)() = &Curses_table::draw_row;

Так что да, баг gcc.

А workaround простой, просто использовать 2 варианта которые работают :)

fsb4000 ★★★★★
()
Вы не можете добавлять комментарии в эту тему. Тема перемещена в архив.