M460LIB
PE durante o processo de liberacao do pedido (MATA460). Permite logica custom antes do MaLibDoFat oficial.
Assinatura: User Function M460LIB() --> NIL
Retorna: NIL
Modulo: SIGAFAT · Rotina: MATA460 · Momento: Durante liberacao, antes do MaLibDoFat
Parametros (PARAMIXB)
Este PE nao recebe parametros via PARAMIXB. A tabela alvo ja esta posicionada quando o PE dispara — opere via (ALIAS)->CAMPO.
Retorno
NIL
Pegadinhas
- Dispara dentro do loop de liberacao — pode rodar N vezes por pedido.
- Cuidado com modificar SC6 — pode quebrar MaLibDoFat.
Quando usar
- Logica custom durante o processo de liberacao
- Gravar dados extras na SC9 ou tabela relacionada
- Aplicar regras de comissao customizada
Exemplo (template)
User Function M460LIB()
// Durante/apos liberacao — extender comportamento padrao
// Validar campos custom, gravar dados extras na SC9, etc
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
- SC9 — liberacao de pedido (geralmente posicionada quando PE dispara)
- Relacionadas: SF2, SD2, SE1