Web Analytics

igcc

⭐ 209 stars Portuguese by alexandru-dinu

🌐 Idioma

GCC Interativo

tests contrib Code style: black

[!NOTA]
O repositório original de Andy Balaam está aqui: https://codeberg.org/andybalaam/igcc.

Neste fork, fiz algumas refatorações e tentei torná-lo mais fácil de usar.

[!AVISO]
Este projeto é uma tentativa improvisada de obter um ciclo de feedback mais curto ao trabalhar com C/C++ em alguns casos e obviamente não é destinado a nada sério.

O GCC Interativo (igcc) é um loop de leitura-avaliação-impressão (REPL) para C/C++. Ele funciona manipulando um arquivo fonte base com comandos do usuário, compila o fonte após cada modificação, depois executa o binário resultante e coleta sua saída stdout & stderr. A entrada multilinha (em bloco) é suportada, então você pode adicionar múltiplas linhas de uma vez e invocar o compilador apenas uma vez (exemplos abaixo).

Você pode incluir vários arquivos de cabeçalho. Para conveniência, um cabeçalho padrão é incluído: boilerplate.h. Além disso, using namespace std; não está disponível por padrão, mas você pode adicioná-lo explicitamente (exemplo abaixo).

Vários aspectos do igcc podem ser configurados, veja config.yaml.

Primeiros passos

A maneira mais fácil de começar é usando o pipx:
pipx install git+https://github.com/alexandru-dinu/igcc.git
Alternativamente, você também pode usar o uv:
uv tool run git+https://github.com/alexandru-dinu/igcc
E para desenvolvimento:
git clone https://github.com/alexandru-dinu/igcc.git
cd igcc
uv sync

Argumentos disponíveis:

usage: igcc [-h] [-I INCLUDE [INCLUDE ...]] [-L LIBDIR [LIBDIR ...]]
            [-l LIB [LIB ...]]

options: -h, --help show this help message and exit -I INCLUDE [INCLUDE ...] Add INCLUDE to the list of directories to be searched for header files. -L LIBDIR [LIBDIR ...] Add LIBDIR to the list of directories to be searched for library files. -l LIB [LIB ...] Search the library LIB when linking.

O código será compilado com GCC (g++) e os resultados (se houver) serão exibidos. Digite .h para ajuda:

$ igcc
[1]> .h
.h  Show this help message
.e  Show the last compile errors/warnings
.l  List the code you have entered
.L  List the whole program as given to the compiler
.r  Redo undone command
.u  Undo previous command
.q  Quit

Exemplos

$ igcc
[1]> int a = 5;
[2]> a += 2;
[3]> using namespace std;
[4]> cout << a << endl;
7

[5]> int b = 17; [6]> a *= b; [7]> cout << a << ", " << b << endl; 119, 17

[8]> .L #include "boilerplate.h" using namespace std;

int main(void) { int a = 5; a += 2; cout << a << endl; int b = 17; a *= b; cout << a << ", " << b << endl;

return 0; }

Entrada multilinha é suportada (verifique multiline_marker na configuração). O benefício é evitar múltiplas chamadas ao compilador.

$ igcc
[1]> .m
... for (int i = 0; i < 10; i++) {
...   std::cout << i << " ";
... }
... std::cout << "\n";
... .m
0 1 2 3 4 5 6 7 8 9
Você pode incluir cabeçalhos:

$ igcc
[1]> #include 
[2]> std::vector xs{1,2,3};
[3]> xs.push_back(17);
[4]> .m
... for (auto x : xs) {
...   std::cout << x << " ";
... }
... .m
1 2 3 17
Bibliotecas podem ser vinculadas:

$ igcc -lpthread
[  1]> #include 
[  2]> pthread_t thr;
[  3]> const char* msg = "Hello, World!";
[  4]> // assuming print_msg is defined somewhere
[  5]> int ret = pthread_create(&thr, NULL, print_msg, (void*) msg); pthread_join(thr, NULL);
Hello, World!
Você também pode desfazer comandos:

$ igcc
[1]> int x = 2
 Compile error - type .e to see it

[2]> .e : In function ‘int main()’: :7:5: error: expected ‘,’ or ‘;’ before ‘return’ :5:9: warning: unused variable ‘x’ [-Wunused-variable]

[2]> .u Undone int x = 2 [1]> int x = 2; [2]> .L #include "boilerplate.h"

int main(void) { int x = 2;

return 0; }

... ou refazer comandos previamente desfeitos:

$ igcc
[1]> int x = 2;
[2]> std::cout << x;
2
[3]> .u
Undone std::cout << x;
[2]> .L
#include "boilerplate.h"

int main(void) { int x = 2;

return 0; } [2]> .r Redone std::cout << x; 2 [3]> .L #include "boilerplate.h"

int main(void) { int x = 2; std::cout << x;

return 0; }

Trabalhos futuros

Veja https://github.com/alexandru-dinu/igcc/issues

Projetos similares

Créditos

--- Tranlated By Open Ai Tx | Last indexed: 2025-12-11 ---