@semacode/cli 1.1.0 → 1.2.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,196 +1,196 @@
1
- # Instalacao e Primeiro Uso
2
-
3
- Este guia mostra o caminho mais curto para testar a Sema do jeito certo, sem misturar fluxo de usuario com gambiarra de contribuinte.
4
-
5
- ## Requisitos
6
-
7
- - Node.js instalado
8
- - npm funcionando
9
- - Python 3 e `pytest` se voce quiser rodar o fluxo completo de testes Python gerados
10
-
11
- O repositorio so e necessario se voce quiser contribuir na Sema, rodar o showcase oficial localmente ou empacotar release.
12
-
13
- ## Caminho oficial
14
-
15
- Instalacao via npm:
16
-
17
- ```bash
18
- npm install -g @semacode/cli
19
- sema --help
20
- sema doctor
21
- ```
22
-
23
- Se preferir o tarball oficial da GitHub Release:
24
-
25
- ```bash
26
- npm install -g https://github.com/gerlanss/Sema/releases/latest/download/sema-cli-latest.tgz
27
- sema --help
28
- sema doctor
29
- ```
30
-
31
- Instalacao local ao projeto:
32
-
33
- ```bash
34
- npm install @semacode/cli
35
- npx sema --help
36
- ```
37
-
38
- Instaladores auxiliares para a linha publica atual:
39
-
40
- - Linux/macOS: `curl -fsSL https://raw.githubusercontent.com/gerlanss/Sema/v1.0.0/install-sema.sh | bash`
41
- - Windows PowerShell: `irm https://raw.githubusercontent.com/gerlanss/Sema/v1.0.0/install-sema.ps1 | iex`
42
-
43
- Se voce quiser reproducao estrita, prefira o npm registry ou o tarball da GitHub Release.
44
-
45
- ## Primeiro teste sem clonar o repo
46
-
47
- ```bash
48
- mkdir sema-demo
49
- cd sema-demo
50
- sema iniciar
51
- sema validar contratos/pedidos.sema --json
52
- ```
53
-
54
- ## Primeiro fluxo util
55
-
56
- ```bash
57
- sema validar contratos/pedidos.sema --json
58
- sema ast contratos/pedidos.sema --json
59
- sema ir contratos/pedidos.sema --json
60
- sema formatar contratos/pedidos.sema
61
- sema verificar contratos --saida ./.tmp/verificacao
62
- ```
63
-
64
- ## Primeiro fluxo de IA real
65
-
66
- Sem clonar o repo, o fluxo que mais mostra a proposta da Sema hoje e:
67
-
68
- ```bash
69
- sema inspecionar . --json
70
- sema resumo contratos/pedidos.sema --micro --para mudanca
71
- sema drift contratos/pedidos.sema --json
72
- sema contexto-ia contratos/pedidos.sema --saida ./.tmp/contexto-pedidos --json
73
- ```
74
-
75
- Esse fluxo mostra:
76
-
77
- - base de projeto resolvida
78
- - cartao semantico curto para IA pequena ou gratuita
79
- - codigo vivo detectado
80
- - `impl` e `vinculos` resolvidos
81
- - score, confianca e lacunas do `drift`
82
- - `briefing.min.json` e `briefing.json` para IA antes da edicao
83
-
84
- ## `sema.config.json`
85
-
86
- Exemplo de configuracao para projeto real:
87
-
88
- ```json
89
- {
90
- "origens": ["./contratos"],
91
- "saida": "./generated",
92
- "alvos": ["typescript", "python"],
93
- "alvoPadrao": "typescript",
94
- "estruturaSaida": "backend",
95
- "framework": "nestjs",
96
- "modoEstrito": true,
97
- "diretoriosSaidaPorAlvo": {
98
- "typescript": "./generated/nestjs",
99
- "python": "./generated/fastapi"
100
- },
101
- "convencoesGeracaoPorProjeto": "backend"
102
- }
103
- ```
104
-
105
- ## Gerar codigo
106
-
107
- Scaffold base:
108
-
109
- ```bash
110
- sema compilar contratos/pedidos.sema --alvo typescript --saida ./saida/typescript
111
- sema compilar contratos/pedidos.sema --alvo python --saida ./saida/python
112
- sema compilar contratos/pedidos.sema --alvo dart --saida ./saida/dart
113
- ```
114
-
115
- Scaffold backend:
116
-
117
- ```bash
118
- sema compilar contratos/pedidos.sema --alvo typescript --framework nestjs --estrutura backend --saida ./generated/nestjs
119
- sema compilar contratos/pedidos.sema --alvo python --framework fastapi --estrutura backend --saida ./generated/fastapi
120
- ```
121
-
122
- ## Extensao VS Code
123
-
124
- Via GitHub Release:
125
-
126
- ```bash
127
- curl -L -o sema-language-tools.vsix https://github.com/gerlanss/Sema/releases/latest/download/sema-language-tools-latest.vsix
128
- code --install-extension ./sema-language-tools.vsix --force
129
- ```
130
-
131
- Windows PowerShell:
132
-
133
- ```powershell
134
- Invoke-WebRequest -Uri https://github.com/gerlanss/Sema/releases/latest/download/sema-language-tools-latest.vsix -OutFile sema-language-tools.vsix
135
- code --install-extension .\sema-language-tools.vsix --force
136
- ```
137
-
138
- Pagina oficial:
139
-
140
- - [https://github.com/gerlanss/Sema/releases/latest](https://github.com/gerlanss/Sema/releases/latest)
141
-
142
- Se voce estiver desenvolvendo a propria extensao localmente, ai sim entra a trilha de contribuinte:
143
-
144
- ```bash
145
- npm run extensao:empacotar
146
- npm run extensao:instalar-local
147
- ```
148
-
149
- ## Caminho de contribuinte
150
-
151
- Se o objetivo for desenvolver a propria Sema:
152
-
153
- ```bash
154
- npm install
155
- npm run build
156
- npm run cli:instalar-local
157
- sema validar exemplos/calculadora.sema
158
- ```
159
-
160
- Se quiser validar tudo de cara:
161
-
162
- ```bash
163
- npm run project:check
164
- ```
165
-
166
- ## `npm link` continua existindo
167
-
168
- Esse fluxo continua util, mas e trilha de contribuinte:
169
-
170
- ```powershell
171
- npm run cli:instalar-local
172
- ```
173
-
174
- Serve para:
175
-
176
- - testar a experiencia de terminal no proprio ambiente
177
- - desenvolver a CLI
178
- - usar `sema` como interface principal mesmo durante o desenvolvimento local
179
-
180
- Para remover:
181
-
182
- ```powershell
183
- npm run cli:desinstalar-local
184
- ```
185
-
186
- ## Resumo honesto
187
-
188
- Hoje o jeito certo de testar a Sema e:
189
-
190
- 1. instalar a CLI pelo npm ou pela GitHub Release
191
- 2. rodar `sema iniciar`
192
- 3. validar `contratos/pedidos.sema`
193
- 4. usar `inspecionar -> resumo -> drift -> contexto-ia` quando o projeto for vivo
194
- 5. ler `briefing.min.json` ou `briefing.json` antes de mandar a IA sair cavando arquivo
195
-
196
- Clone + build + `npm link` continua bom para oficina, nao para landing page publica.
1
+ # Instalacao e Primeiro Uso
2
+
3
+ Este guia mostra o caminho mais curto para testar a Sema do jeito certo, sem misturar fluxo de usuario com gambiarra de contribuinte.
4
+
5
+ ## Requisitos
6
+
7
+ - Node.js instalado
8
+ - npm funcionando
9
+ - Python 3 e `pytest` se voce quiser rodar o fluxo completo de testes Python gerados
10
+
11
+ O repositorio so e necessario se voce quiser contribuir na Sema, rodar o showcase oficial localmente ou empacotar release.
12
+
13
+ ## Caminho oficial
14
+
15
+ Instalacao via npm:
16
+
17
+ ```bash
18
+ npm install -g @semacode/cli
19
+ sema --help
20
+ sema doctor
21
+ ```
22
+
23
+ Se preferir o tarball oficial da GitHub Release:
24
+
25
+ ```bash
26
+ npm install -g https://github.com/gerlanss/Sema/releases/latest/download/sema-cli-latest.tgz
27
+ sema --help
28
+ sema doctor
29
+ ```
30
+
31
+ Instalacao local ao projeto:
32
+
33
+ ```bash
34
+ npm install @semacode/cli
35
+ npx sema --help
36
+ ```
37
+
38
+ Instaladores auxiliares para a linha publica atual:
39
+
40
+ - Linux/macOS: `curl -fsSL https://raw.githubusercontent.com/gerlanss/Sema/v1.0.0/install-sema.sh | bash`
41
+ - Windows PowerShell: `irm https://raw.githubusercontent.com/gerlanss/Sema/v1.0.0/install-sema.ps1 | iex`
42
+
43
+ Se voce quiser reproducao estrita, prefira o npm registry ou o tarball da GitHub Release.
44
+
45
+ ## Primeiro teste sem clonar o repo
46
+
47
+ ```bash
48
+ mkdir sema-demo
49
+ cd sema-demo
50
+ sema iniciar
51
+ sema validar contratos/pedidos.sema --json
52
+ ```
53
+
54
+ ## Primeiro fluxo util
55
+
56
+ ```bash
57
+ sema validar contratos/pedidos.sema --json
58
+ sema ast contratos/pedidos.sema --json
59
+ sema ir contratos/pedidos.sema --json
60
+ sema formatar contratos/pedidos.sema
61
+ sema verificar contratos --saida ./.tmp/verificacao
62
+ ```
63
+
64
+ ## Primeiro fluxo de IA real
65
+
66
+ Sem clonar o repo, o fluxo que mais mostra a proposta da Sema hoje e:
67
+
68
+ ```bash
69
+ sema inspecionar . --json
70
+ sema resumo contratos/pedidos.sema --micro --para mudanca
71
+ sema drift contratos/pedidos.sema --json
72
+ sema contexto-ia contratos/pedidos.sema --saida ./.tmp/contexto-pedidos --json
73
+ ```
74
+
75
+ Esse fluxo mostra:
76
+
77
+ - base de projeto resolvida
78
+ - cartao semantico curto para IA pequena ou gratuita
79
+ - codigo vivo detectado
80
+ - `impl` e `vinculos` resolvidos
81
+ - score, confianca e lacunas do `drift`
82
+ - `briefing.min.json` e `briefing.json` para IA antes da edicao
83
+
84
+ ## `sema.config.json`
85
+
86
+ Exemplo de configuracao para projeto real:
87
+
88
+ ```json
89
+ {
90
+ "origens": ["./contratos"],
91
+ "saida": "./generated",
92
+ "alvos": ["typescript", "python"],
93
+ "alvoPadrao": "typescript",
94
+ "estruturaSaida": "backend",
95
+ "framework": "nestjs",
96
+ "modoEstrito": true,
97
+ "diretoriosSaidaPorAlvo": {
98
+ "typescript": "./generated/nestjs",
99
+ "python": "./generated/fastapi"
100
+ },
101
+ "convencoesGeracaoPorProjeto": "backend"
102
+ }
103
+ ```
104
+
105
+ ## Gerar codigo
106
+
107
+ Scaffold base:
108
+
109
+ ```bash
110
+ sema compilar contratos/pedidos.sema --alvo typescript --saida ./saida/typescript
111
+ sema compilar contratos/pedidos.sema --alvo python --saida ./saida/python
112
+ sema compilar contratos/pedidos.sema --alvo dart --saida ./saida/dart
113
+ ```
114
+
115
+ Scaffold backend:
116
+
117
+ ```bash
118
+ sema compilar contratos/pedidos.sema --alvo typescript --framework nestjs --estrutura backend --saida ./generated/nestjs
119
+ sema compilar contratos/pedidos.sema --alvo python --framework fastapi --estrutura backend --saida ./generated/fastapi
120
+ ```
121
+
122
+ ## Extensao VS Code
123
+
124
+ Via GitHub Release:
125
+
126
+ ```bash
127
+ curl -L -o sema-language-tools.vsix https://github.com/gerlanss/Sema/releases/latest/download/sema-language-tools-latest.vsix
128
+ code --install-extension ./sema-language-tools.vsix --force
129
+ ```
130
+
131
+ Windows PowerShell:
132
+
133
+ ```powershell
134
+ Invoke-WebRequest -Uri https://github.com/gerlanss/Sema/releases/latest/download/sema-language-tools-latest.vsix -OutFile sema-language-tools.vsix
135
+ code --install-extension .\sema-language-tools.vsix --force
136
+ ```
137
+
138
+ Pagina oficial:
139
+
140
+ - [https://github.com/gerlanss/Sema/releases/latest](https://github.com/gerlanss/Sema/releases/latest)
141
+
142
+ Se voce estiver desenvolvendo a propria extensao localmente, ai sim entra a trilha de contribuinte:
143
+
144
+ ```bash
145
+ npm run extensao:empacotar
146
+ npm run extensao:instalar-local
147
+ ```
148
+
149
+ ## Caminho de contribuinte
150
+
151
+ Se o objetivo for desenvolver a propria Sema:
152
+
153
+ ```bash
154
+ npm install
155
+ npm run build
156
+ npm run cli:instalar-local
157
+ sema validar exemplos/calculadora.sema
158
+ ```
159
+
160
+ Se quiser validar tudo de cara:
161
+
162
+ ```bash
163
+ npm run project:check
164
+ ```
165
+
166
+ ## `npm link` continua existindo
167
+
168
+ Esse fluxo continua util, mas e trilha de contribuinte:
169
+
170
+ ```powershell
171
+ npm run cli:instalar-local
172
+ ```
173
+
174
+ Serve para:
175
+
176
+ - testar a experiencia de terminal no proprio ambiente
177
+ - desenvolver a CLI
178
+ - usar `sema` como interface principal mesmo durante o desenvolvimento local
179
+
180
+ Para remover:
181
+
182
+ ```powershell
183
+ npm run cli:desinstalar-local
184
+ ```
185
+
186
+ ## Resumo honesto
187
+
188
+ Hoje o jeito certo de testar a Sema e:
189
+
190
+ 1. instalar a CLI pelo npm ou pela GitHub Release
191
+ 2. rodar `sema iniciar`
192
+ 3. validar `contratos/pedidos.sema`
193
+ 4. usar `inspecionar -> resumo -> drift -> contexto-ia` quando o projeto for vivo
194
+ 5. ler `briefing.min.json` ou `briefing.json` antes de mandar a IA sair cavando arquivo
195
+
196
+ Clone + build + `npm link` continua bom para oficina, nao para landing page publica.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sema/gerador-dart",
3
- "version": "1.1.0",
3
+ "version": "1.2.9",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts"
@@ -0,0 +1,3 @@
1
+ import type { IrModulo } from "@sema/nucleo";
2
+ import { type ArquivoGerado } from "@sema/padroes";
3
+ export declare function gerarLua(modulo: IrModulo): ArquivoGerado[];