Pular para o conteúdo principal

Postagem em destaque

BlackTDN :: LeetCode (17) :: Comparando Implementações do Desafio "Letter Combinations of a Phone Number" em Harbour e TOTVS TLPP

_Créditos das imagens: ChatGPT_ # LeetCode (17) :: Comparando Implementações do Desafio "Letter Combinations of a Phone Number" em Harbour e TOTVS TLPP O desafio [**"Letter Combinations of a Phone Number"**](https://leetcode.com/problems/letter-combinations-of-a-phone-number/description/) (Combinações de Letras de um Número de Telefone) é um problema clássico de programação que envolve a geração de todas as combinações possíveis de letras que um número de telefone pode representar, com base no mapeamento tradicional dos teclados de telefone. Abaixo, comparamos duas implementações desse desafio: uma em **Harbour** e outra em **TOTVS TLPP** (TOTVS Language Plus Plus). ## O Desafio Dada uma string contendo dígitos de 2 a 9, retorne todas as combinações possíveis de letras que esses dígitos podem representar. O mapeamento dos dígitos para as letras é o mesmo dos teclados de telefone tradicionais: - 2: "abc" - 3: "def" - 4: "ghi" - 5: ...

BlackTDN :: Gerenciamento de Erros e Avisos em Projetos AdvPL/TLPP: Um Desafio Frequente no Desenvolvimento TOTVS Protheus

_Créditos da imagem: Gerada com auxílio do ChatGPT_

---

**Gerenciamento de Erros e Avisos em Projetos AdvPL/TLPP: Um Desafio Frequente no Desenvolvimento TOTVS Protheus**

Ao trabalhar com projetos desenvolvidos na linguagem AdvPL/TLPP, especialmente em ambientes como o TOTVS Microsiga Protheus, desenvolvedores frequentemente se deparam com uma série de problemas e avisos de compilação. Recentemente, em uma análise de código de um dos nossos projetos, foram identificados mais de 700 problemas durante o processo de compilação, distribuídos entre erros críticos e avisos que podem afetar o desempenho e a manutenção da aplicação.

### Principais Problemas Encontrados

Entre os problemas destacados, podemos citar:

1. **Erros de Nomenclatura e Duplicação de Fontes**:
   - Um dos erros mais críticos que surgiram foi: "Not allowed more than one source with same name". Este erro é comum quando há múltiplos arquivos PRW com o mesmo nome em diferentes pastas do projeto, o que pode gerar confusão no processo de compilação e impactar diretamente o funcionamento do sistema.
   - Solução: Identificar os arquivos duplicados e renomeá-los adequadamente, garantindo que cada fonte possua um nome único dentro do projeto.

**Uso de Funções AdvPL/TLPP Personalizadas:**

Em algumas fontes, encontramos o aviso: "Functions are not allowed in code. Use USER FUNCTION or STATIC FUNCTION". No ambiente do Protheus, apenas os desenvolvedores internos da TOTVS podem utilizar a declaração `FUNCTION` sem prefixo especial. Em projetos customizados para clientes, é fundamental que os desenvolvedores sigam a convenção de criar suas funções públicas com o prefixo `U_`, utilizando `USER FUNCTION` (como `U_Funcao`). Isso evita conflitos com as funções padrão do sistema. Já para funções que não precisam ser acessíveis externamente, a recomendação é usar `STATIC FUNCTION`, garantindo que a função seja limitada ao escopo do arquivo onde foi declarada.

**Solução**: Substituir chamadas a funções não conformes pela convenção `U_` para `USER FUNCTION` e utilizar `STATIC FUNCTION` para funções internas, garantindo que o código customizado siga as melhores práticas de compatibilidade e integração com o ambiente Protheus.

3. **Variáveis Locais Não Utilizadas**:
   - Avisos do tipo "Local variable CPARAMX never used" indicam que algumas variáveis locais foram declaradas, mas não são utilizadas em nenhum ponto do código. Esse tipo de aviso, embora não interrompa a compilação, pode indicar trechos de código que necessitam de uma revisão, seja para eliminar variáveis desnecessárias ou para identificar lógicas não implementadas.
   - Solução: Revisar a lógica de uso das variáveis e, se possível, eliminar declarações desnecessárias para otimizar a manutenção e a legibilidade do código.
   
   etc...

### A Importância da Revisão de Código em Projetos AdvPL/TLPP

O acúmulo de problemas e avisos, como mostrado na imagem anexa, é um claro indicador de que a revisão de código é um passo crucial para o sucesso de um projeto. No ambiente AdvPL/TLPP, onde cada detalhe pode impactar na performance e estabilidade do sistema, adotar boas práticas de revisão e otimização pode significar a diferença entre um projeto eficiente e um projeto problemático.

Além disso, a revisão de código contribui para:

- **Redução de Custos de Manutenção**: Menos erros e um código mais limpo reduzem o tempo necessário para manutenção e futuras implementações.
- **Melhorias na Performance**: Ajustar problemas antes que eles cheguem ao ambiente de produção evita que o sistema tenha sua performance comprometida por pequenas falhas.
- **Qualidade do Produto Final**: Um código revisado e limpo reflete diretamente na qualidade do produto que chega ao cliente, resultando em uma melhor experiência de uso.

### Conclusão

Gerenciar os problemas e avisos de compilação em um projeto AdvPL/TLPP não é uma tarefa simples, mas é um investimento necessário para garantir a estabilidade e a qualidade do software. A análise detalhada dos erros, como os apresentados na imagem, e a implementação de soluções adequadas são passos importantes para um ciclo de desenvolvimento mais saudável e eficiente.

Se você está enfrentando desafios similares em seus projetos de desenvolvimento com AdvPL/TLPP, não hesite em compartilhar suas experiências e estratégias de resolução nos comentários!

---

Comentários

Postagens mais visitadas