Tutorial de Desenvolvimento do Código‑Fonte do MeshCore
Pré-requisitos
Ferramenta necessária
Antes de começar, prepare as seguintes ferramentas:
Instalar o PlatformIO
Pesquise por PlatformIO no marketplace de Extensões do VS Code e instale-o.

Após a instalação, normalmente um ícone em forma de formiga aparece na barra de ferramentas à esquerda.

Preparação do projeto
Abra uma pasta onde você deseja ter o seu projeto. Abra a pasta no terminal. Clique aqui para clonar o projeto com git.
Abra o VSCode, depois clique no ícone do PlatformIO, escolha select a folder. Escolha a pasta onde você clonou o projeto.

O PlatformIO instalará automaticamente as dependências necessárias. Após a instalação ser concluída com sucesso, você verá Project has been successfully updated

Desenvolvimento de firmware
Tutorial de desenvolvimento
Encontre o ambiente para a sua placa alvo. Tome o L1 Pro companion como exemplo:

Então o PlatformIO irá preparar as dependências necessárias para a placa.
Altere o seu código. É recomendado alterar o arquivo variant.h para a sua placa.
Após completar a codificação, execute o seguinte comando para compilar o código e convertê-lo em um arquivo uf2.
pio run -e WioTrackerL1_companion_radio_ble
pio run -e WioTrackerL1_companion_radio_ble -t create_uf2
Em seguida, clique duas vezes no botão RST para entrar no modo DFU. Arraste o arquivo uf2 para o disco que aparecer. O arquivo uf2 deve ser encontrado em .pio\build\WioTrackerL1_companion_radio_ble
Exemplo
Controle de exibição do usuário
Este exemplo mostra como modificar a interface de exibição do L1 Pro. Ele exclui a exibição de mensagens na tela, mostrando "Test" constantemente.

Copie o código a seguir para /examples/companion_radio/ui-new/UITask.cpp
if (_page == HomePage::FIRST) {
display.setColor(DisplayDriver::YELLOW);
display.setTextSize(2);
display.drawTextCentered(display.width() / 2, 20, "Test");

Compile-o e grave o arquivo uf2 no seu L1 Pro.
(Avançado) Antes de enviar PR
Obrigado por considerar contribuir para o projeto MeshCore! Como você pode contribuir? 1. Reportar bugs
- Use o rastreador de Issues
- Use um título claro (por exemplo, "Crash when calling begin() with invalid pin")
- Descreva exatamente as etapas para reproduzir
- Inclua sua placa, versão da IDE, versão da biblioteca e trecho de código relevante
- Anexe um sketch de exemplo mínimo e completo, se possível
2. Sugerir melhorias / novos recursos
- Abra uma issue com o prefixo [Feature request]
- Explique o caso de uso → que problema isso resolveria?
- Descreva sua API / comportamento ideal (exemplos de código são muito úteis) 3. Enviar alterações de código (Pull Requests)
Pequenas correções
(erros de digitação, comentários, exemplos, pequenas correções de bugs) → Basta abrir um pull request — não é necessário criar issue antes
Alterações maiores / novos recursos
- Abra primeiro uma issue para discutir a ideia
- Obtenha um sinal positivo geral do(s) mantenedor(es)
- Faça um fork do repositório a partir da branch 'dev' e crie a sua branch (fix/xxx, feature/yyy, docs/whatever)
- Faça suas alterações
- Atualize ou adicione exemplos quando apropriado
- Adicione/atualize comentários no código
- Envie o pull request
Diretrizes para Pull Request
- Uma funcionalidade / correção = um pull request (PRs menores são mais fáceis e rápidos de revisar)
- Use mensagens de commit descritivas Bom: Fix I2C timeout handling on ESP32 Ruim: update
- Faça referência a qualquer issue relacionada (Fixes #123, Closes #89, etc.)
- Se você alterar a API pública, atualize README.md e library.properties
- Novos recursos devem incluir um sketch de exemplo em examples/
Estilo de código
Por favor, siga o estilo C++ existente (conforme o .clang-format)
- Recuo de 2 espaços (sem tabs)
- camelCase para funções e variáveis
- UpperCamelCase / PascalCase para nomes de classes
- Constantes
#defineem ALL_CAPS - Mantenha as linhas com < ~100 caracteres quando possível (Mas a consistência com o código existente é mais importante do que regras rígidas)