GFE070
PE pra customizar calculo de frete (GFE070). Substitui regra padrao de tarifacao por logica do cliente.
Assinatura: User Function GFE070() --> Numerico — valor do frete calculado
Retorna: Numerico — valor do frete calculado
Modulo: SIGATMS · Rotina: GFE070 · Momento: Calculo de frete
Parametros (PARAMIXB)
Este PE nao recebe parametros via PARAMIXB. A tabela alvo ja esta posicionada quando o PE dispara — opere via (ALIAS)->CAMPO.
Retorno
Numerico — valor do frete calculado
Pegadinhas
- Override completo da regra — perde regra padrao TOTVS.
- Use somente quando tabela de frete nao consegue expressar a regra.
Quando usar
- Customizacao da rotina padrao Protheus
Exemplo (template)
User Function GFE070()
// Implementacao customizada do PE
Begin Sequence
// ...
Recover
FwLogger():Error("GFE070 falhou: " + ErrorBlock())
End Sequence
ReturnCuidados gerais
- Idempotencia: PEs podem disparar mais de uma vez em retry ou reprocessamento — codigo deve ser seguro pra rodar varias vezes sem efeito colateral.
- Performance critica: PE roda em fluxo do usuario. Operacoes pesadas (loop sobre milhares de registros, chamada HTTP sincrona) podem travar a tela. Use
StartJobpra background. - Em JOB sem AppServer ativo: PE chamado via RPC pode ter
cFilAnt/cEmpAntvazios — sempre garantaRpcSetEnv. - Begin Sequence + Recover: erros nao tratados em PE podem deixar transacao Protheus em estado inconsistente. Sempre envolver em
Begin Sequence ... End Sequence. - Logging com contexto: use
FwLoggercom identificacao do PE no log — facilita troubleshooting.
Tabelas afetadas
- GW4 — calculo de frete (geralmente posicionada quando PE dispara)