MT440PROC
PE da geracao automatica de Nota Fiscal a partir do pedido liberado. Customiza campo, regra fiscal ou descricao adicional.
Assinatura: User Function MT440PROC()
// PARAMIXB[1] (RecNo): da SC9 (liberacao) que originou a NF
Return // NIL
Retorna: NIL
Modulo: SIGAFAT · Rotina: MATA440 · Momento: Durante geracao automatica de NF (botao "Gerar NF" em pedido liberado)
Parametros (PARAMIXB)
// PARAMIXB[1] = RecNo da SC9 (liberacao) que originou a NFRetorno esperado
NIL
Pegadinhas
- Pode alterar campos da SF2/SD2 em construcao via M-> antes do commit.
- Erro aqui geralmente nao reverte SC9 ja liberada — atencao.
- Em ambientes com TSS/SPED ativo, validar consistencia fiscal antes.
Quando usar
- Customizacao da rotina padrao Protheus
Exemplo (template)
User Function MT440PROC()
// Implementacao customizada do PE
Begin Sequence
// ...
Recover
FwLogger():Error("MT440PROC 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.
Veja tambem
Parâmetros
| Nome | Tipo | Obrigatório | Descrição |
|---|---|---|---|
PARAMIXB[1] (RecNo) | ? | sim | da SC9 (liberacao) que originou a NF |