Postagem em destaque
- Gerar link
- Outros aplicativos
Protheus :: Advpl :: TCInternal()
Fala ae Anonimo!
Em um dos posts anteriores.. comenterei sobre o uso de algumas funções para nao ocorrer o consumo de licenças no TOP / DBAccess… e logo na sequencia houve um pedido “anonimo”
para postar o uso da TCInternal() na atualização de campos / dicionario de dados…
Postado ao som de : Delinquent Habits – Here Come The Horns
Como prometido… segue abaixo o codigo contendo o uso:
#include "protheus.ch"
/*
Funcao: UPDGema
Autor: Rodrigo OverFail
Data: 21/12/2011
Funcionalidade: Exemplo para uso da TCInternal()
*/
User Function UpdGema()
cArqEmp := "SigaMat.Emp"
nModulo := 05
__cInterNet := Nil
PRIVATE cMessage
PRIVATE aArqUpd := {}
PRIVATE aREOPEN := {}
Private __lPyme := .F.
#IFDEF TOP
TCInternal(5,'*OFF') //-- Desliga Refresh no Lock do Top
#ENDIF
Set Dele On
GEMOpenSM0(.T.)
DbGoTop()
lHistorico := MsgYesNo("Atualização das tabelas e campos de exemplo UPDGema, Confirma?", "Update")
lEmpenho := .F.
lAtuMnu := .F.
DEFINE WINDOW oMainWnd FROM 0,0 TO 01,30 TITLE "Update"
ACTIVATE WINDOW oMainWnd ICONIZED ;
ON INIT (If(lHistorico ,Processa({||UpdTables()} ,"Atualização das tabelas") ,.F.), oMainWnd:End())
Return
Static Function GEMOpenSM0(lShared)
Local lOpen := .F.
Local i := 0
For i := 1 To 20
dbUseArea(.T., , "SIGAMAT.EMP", "SM0", lShared, .F.)
If !Empty(Select("SM0"))
lOpen := .T.
dbSetIndex("SIGAMAT.IND")
Exit
EndIf
Sleep(500)
Next
Return lOpen
Static Function UpdTables()
Local nRecno := 0
Local nRecAtu := 0
Local aAreaSM0 := {}
While SM0->(!Eof())
nRecAtu := SM0->(Recno())
aAreaSM0 := SM0->(GetArea())
RpcSetType(3)
RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)
RestArea(aAreaSM0)
SM0->(dbGoto(nRecAtu))
RpcClearEnv()
GEMOpenSM0(.F.)
SM0->(dbGoto(nRecAtu))
SM0->(dbSkip())
If SM0->(! Eof())
nRecno := SM0->(Recno())
SM0->(DbGoTo(nRecno))
EndIf
EndDo
dbSelectArea("SM0")
dbGotop()
While SM0->(!Eof())
nRecAtu := SM0->(Recno())
aAreaSM0 := SM0->(GetArea())
RpcSetType(3)
RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)
RestArea(aAreaSM0)
dbSelectArea("SM0")
dbGoto(nRecAtu)
If HasTemplate("LOT")
dbGoto(nRecAtu)
dbSelectArea("SX3")
dbSetOrder(2)
If SX3->(dbSeek("LJN_TPPRIC"))
RecLock("SX3",.F.)
SX3->X3_WHEN := "t_VerWhenLJN()"
MsUnlock()
EndIf
ENDIF
SM0->(dbGoto(nRecAtu))
SM0->(dbSkip())
If SM0->(! Eof())
nRecno := SM0->(Recno())
SM0->(DbGoTo(nRecno))
EndIf
EndDo
Alert("Fim da atualização")
Return(.T.)
User Function UpdGemSini()
cArqEmp := "SigaMat.Emp"
nModulo := 05
__cInterNet := Nil
PRIVATE cMessage
PRIVATE aArqUpd := {}
PRIVATE aREOPEN := {}
Private __lPyme := .F.
#IFDEF TOP
TCInternal(5,'*OFF') //-- Desliga Refresh no Lock do Top
#ENDIF
Set Dele On
GEMOpenSM0(.T.)
DbGoTop()
lHistorico := MsgYesNo("Atualização dos campos do template de exmplo com base SINIEF, Confirma?", "Update")
lEmpenho := .F.
lAtuMnu := .F.
DEFINE WINDOW oMainWnd FROM 0,0 TO 01,30 TITLE "Update"
ACTIVATE WINDOW oMainWnd ICONIZED ;
ON INIT (If(lHistorico ,Processa({||AuxGEMSINIEF()} ,"Atualização das tabelas") ,.F.), oMainWnd:End())
Return
Static Function AuxGEMSINIEF()
Local nRecno := 0
Local nCnt :=0
Local nRecAtu := 0
Local aAreaSM0 := {}
While SM0->(!Eof())
nRecAtu := SM0->(Recno())
aAreaSM0 := SM0->(GetArea())
RpcSetType(3)
RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)
RestArea(aAreaSM0)
SM0->(dbGoto(nRecAtu))
RpcClearEnv()
GEMOpenSM0(.F.)
SM0->(dbGoto(nRecAtu))
SM0->(dbSkip())
If SM0->(! Eof())
nRecno := SM0->(Recno())
SM0->(DbGoTo(nRecno))
EndIf
EndDo
dbSelectArea("SM0")
dbGotop()
While SM0->(!Eof())
nRecAtu := SM0->(Recno())
aAreaSM0 := SM0->(GetArea())
RpcSetType(3)
RpcSetEnv(SM0->M0_CODIGO, SM0->M0_CODFIL)
RestArea(aAreaSM0)
dbSelectArea("SM0")
dbGoto(nRecAtu)
If HasTemplate("LOT")
dbGoto(nRecAtu)
dbSelectArea("SXG")
dbSetOrder(1)
If dbSeek("018")
nSize := SXG->XG_SIZE
aSX2Alias := {}
aSX3Field := {}
aAdd( aSX3Field ,{"LIT" ,"LIT_DOC" })
aAdd( aSX3Field ,{"LIU" ,"LIU_DOC" })
aAdd( aSX3Field ,{"LIT" ,"LIT_DUPL"})
aAdd( aSX3Field ,{"LIW" ,"LIW_NUM" })
aAdd( aSX3Field ,{"LIY" ,"LIY_NUM" })
aAdd( aSX3Field ,{"LJA" ,"LJA_DOC" })
aAdd( aSX3Field ,{"LJA" ,"LJA_DUPL"})
aAdd( aSX3Field ,{"LJB" ,"LJB_DOC" })
aAdd( aSX3Field ,{"LJE" ,"LJE_NUM" })
aAdd( aSX3Field ,{"LJV" ,"LJV_NUM" })
aAdd( aSX3Field ,{"LJX" ,"LJX_NUM" })
aAdd( aSX3Field ,{"LJT" ,"LJT_NUM" })
aAdd( aSX3Field ,{"LIX" ,"LIX_NUM" })
aAdd( aSX3Field ,{"LK7" ,"LK7_NUM" })
ProcRegua(Len(aSX3Field))
For nCnt := 1 To Len(aSX3Field)
IncProc("Atualizando o dicionario de campos...")
dbSelectArea("SX3")
dbSetOrder(2)
If dbSeek(aSX3Field[nCnt ,02])
If SX3->X3_ARQUIVO == aSX3Field[nCnt ,01]
If aScan(aSX2Alias,{|x| x == SX3->X3_ARQUIVO })==0
aAdd(aSX2Alias ,SX3->X3_ARQUIVO)
EndIf
RecLock("SX3",.F.)
SX3->X3_TAMANHO := nSize
SX3->X3_GRPSXG := "018"
MsUnLock()
dbCommit()
EndIf
EndIf
Next nCnt
ProcRegua(Len(aSX2Alias))
__SetX31Mode(.F.)
For nCnt := 1 To Len(aSX2Alias)
IncProc("Atualizando a estrutura da tabela: " +aSX2Alias[nCnt])
If Select(aSX2Alias[nCnt])>0
dbSelecTArea(aSX2Alias[nCnt])
dbCloseArea()
EndIf
X31UpdTable(aSX2Alias[nCnt])
If __GetX31Error()
Alert(__GetX31Trace())
Aviso("Erro!!!", "Falha na atualizacao da tabela: " + aSX2Alias[nCnt] + ". ", {"OK"},2)
EndIf
Next nX
If Len(aSX2Alias) >0
Alert("Atenção!!!" +chr(13)+chr(10) +;
"Foram atualizados " + AllTrim(str(Len(aSX2Alias))) + " tabelas referentes ao SINIEF.")
EndIf
Else
Alert("Atenção!!!" +chr(13)+chr(10) +;
"O grupo de campo 018 - Documento de entrada/saida não existe. " +chr(13)+chr(10) +;
"Verifique se o atualizador do SINIEF foi executado anteriormente.")
EndIf
EndIf
dbSelectArea("SM0")
dbGoto(nRecAtu)
aAreaSM0 := SM0->(GetArea())
RpcClearEnv()
RestArea(aAreaSM0)
GEMOpenSM0(.F.)
dbSelectArea("SM0")
dbGoto(nRecAtu)
SM0->(dbSkip())
If SM0->(! Eof())
nRecno := SM0->(Recno())
SM0->(DbGoTo(nRecno))
EndIf
EndDo
Alert("Fim da atualização")
Return(.T.)
Rodrigo “OverFail”
Comentários
Postagens mais visitadas
BlackTDN :: RLeg ~ Desvendando a Função ParamBox
- Gerar link
- Outros aplicativos
Protheus :: Chamando Funções do Menu Diretamente e sem a Necessidade de Login
- Gerar link
- Outros aplicativos
Algo interessante que poucas pessoas conhecem é uma função automática (NGCRIAUPD) para criar updates, independente do módulo e alteração/inclusão de SX*, facilitando assim na manutenção e desenvolvimento de novos updates.
ResponderExcluirNão consegui postar neste comentário o código exemplo pois há limitação de nº de caracteres.
Se houver interesse de alguém me envie um e-mail: vitorebatista@gmail.com
Abraço!
Vitor,
ResponderExcluirTem, também, a função U_ExporDic.
BaseDic
http://dl.dropbox.com/u/1327330/Ferramentas/BaseDic/BaseDic.rar
CompaDic
http://dl.dropbox.com/u/1327330/Ferramentas/CompaDic/CompaDic.rar
ExporDic
http://dl.dropbox.com/u/1327330/Ferramentas/ExporDic/ExporDic.rar
FSBitMap
http://dl.dropbox.com/u/1327330/Ferramentas/FSBitMap/FSBitMap.rar
FSEnvMail
http://dl.dropbox.com/u/1327330/Ferramentas/FSEnvMail/FSEnvMail.rar
FSFontes
http://dl.dropbox.com/u/1327330/Ferramentas/FSFontes/FSFontes.rar
Todas as Ferramentas
http://dl.dropbox.com/u/1327330/Ferramentas/Ferramentas.rar
Naldoidao, essa do expordic merece um post.
ResponderExcluirRealmente este ExporDic foi bem elaborado e é de grande uso principalmente para quem não tem muito conhecimento de programação, pois é bem intuitivo.
ResponderExcluirCopiei sua ideia do dropbox e postei o fonte exemplo utilizando o NGCRIAUPD, fonte padrão desde a versão 8 R4. :D
O NGCRIAUPD tem por objetivo facilitar ao programador o desenvolvimento de novos updates, pois os updates que ainda são utilizados tem 1000 linhas e 90% do código dele é "inútil", ficando no CTRL + C / CTRL + V de um update para outro, certo?
http://dl.dropbox.com/u/8503472/NGCRIAUPD/UPDTESTE.PRW
abraço
Rodrigo,
ResponderExcluirCadê o Prometido sobre a TCInternal? Você disse que disse, prometeu que prometeu, escreveu um bucado de código inútil baseado em copy/past só para isso: "TCInternal(5,'*OFF') //-- Desliga Refresh no Lock do Top". Que LIXO.... Cadê TCInternal ??? Se quer participar de BlackTDN tem que escrever à ALTURA...
Eitaaaa... não precisava disso né brother!
ResponderExcluirIgnorancia não é necessária, bastava dizer que esperava mais do exemplo.
O site é nosso... e toda contribuição deve ser respeitada!
{}'s
eu mandava ele ir atrás e não esperar os outros darem o conhecimento assim de graça
ExcluirNaldo ,
ResponderExcluirGostei das ferramentas que você postou , mas tem algumas que não tem manual e nem exemplo
teria como postar
Ola Daniel
ResponderExcluirAinda não tive tempo para documentar todas as minhas ferramentas. Assim que puder vou fazer isso sim. Tambem estou elaborando outras novas.
Obrigado
Ernani Forastieri
Olá
ResponderExcluirEu coloquei a documentação das ferramentas no meu site. Por favor acessem:
http://www.ernaniforastieri.com
Espero que ajude.
Obrigado.