Как я могу проанализировать вывод gcc по регулярному выражению, чтобы получить пути по умолчанию для включения? - PullRequest
0 голосов
/ 27 декабря 2018

Я знаю, что gcc -xc -E -v - Печать по умолчанию включает пути в конце.

[patryk@patryk-asus-manjaro ~]$ gcc -xc -E -v -  
Using built-in specs.
COLLECT_GCC=gcc
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++ --enable-shared --enable-threads=posix --enable-libmpx --with-system-zlib --with-isl --enable-__cxa_atexit --disable-libunwind-exceptions --enable-clocale=gnu --disable-libstdcxx-pch --disable-libssp --enable-gnu-unique-object --enable-linker-build-id --enable-lto --enable-plugin --enable-install-libiberty --with-linker-hash-style=gnu --enable-gnu-indirect-function --enable-multilib --disable-werror --enable-checking=release --enable-default-pie --enable-default-ssp --enable-cet=auto
Thread model: posix
gcc version 8.2.1 20181127 (GCC) 
COLLECT_GCC_OPTIONS='-E' '-v' '-mtune=generic' '-march=x86-64'
 /usr/lib/gcc/x86_64-pc-linux-gnu/8.2.1/cc1 -E -quiet -v - -mtune=generic -march=x86-64
ignoring nonexistent directory "/usr/lib/gcc/x86_64-pc-linux-gnu/8.2.1/../../../../x86_64-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
 /usr/lib/gcc/x86_64-pc-linux-gnu/8.2.1/include
 /usr/local/include
 /usr/lib/gcc/x86_64-pc-linux-gnu/8.2.1/include-fixed
 /usr/include
End of search list.
^C
[patryk@patryk-asus-manjaro ~]$

Я создал регулярное выражение

#include <\.\.\.> search starts here:$
(^.+$)*
^End of search list\.$

Но он не работает должным образом.Другая проблема заключается в том, что gcc для этих параметров не заканчивается.Я должен позвонить SIGINT Ctrl + C в Linux.Я использую Python 3 и subprocess.run.

Ответы [ 2 ]

0 голосов
/ 30 декабря 2018

Решение, использующее только оболочку:

gcc -x c -E -v /dev/null 2>&1 | sed -n '/include.*search starts here/,/End of search list/{s/^ //p}'

Если это уместно, обязательно обработайте следующие случаи:

  • каталог включает следующие символические ссылки
  • есть дубликаты каталогов
  • каталог не существует
  • возможно, установлено более одного двоичного файла gcc (разные версии, разные арки и т. д.), каждый с разными путями
  • даже для одного двоичного файла gcc флаги компилятора (такие как -m32) могут влиять на путь включения
0 голосов
/ 30 декабря 2018

Я написал спагети

def find_re_it_in_list(pattern, input, start=0, stop=-1, flags=0):
    length = len(input)

    if length == 0:
        return None

    end_it = max(0, length - 1)

    if start >= end_it:
        return None

    if stop<0:
        stop = length

    if stop <= start:
        return None

    for it in range(max(0, start), min(stop, length)):
        elem = input[it]
        match = re.match(pattern, elem, flags)
        if match:
            return it

def get_includes(self):
    args = [self.conf['gcc_path'], '-xc', '-E', '-v', os.devnull]
    args.extend(self.env.get('flags', []))

    incl_start_regex = r' *#include <\.\.\.> search starts here: *'
    incl_end_regex = r' *End of search list\. *'

    proc = subprocess.run(args, stdout=subprocess.PIPE, stderr=subprocess.STDOUT , text=True)
    lines = proc.stdout.splitlines()

    start_it = find_re_it_in_list(incl_start_regex, lines)
    if start_it == None:
        return []

    end_it = find_re_it_in_list(incl_end_regex, lines, start_it)
    if end_it == None:
        return []

    # theres no paths between them
    if (end_it - start_it) == 1:
        return []

    return lines[start_it+1 : end_it]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...