Pular para o conteúdo principal

Postagem em destaque

🚀 Oferecendo Serviços Remotos de Desenvolvedor AdvPL e Mais 🖥️

🚀 Oferecendo Serviços Remotos de Desenvolvedor AdvPL e Mais 🖥️ Olá pessoal, Espero que este post encontre todos vocês bem! É com grande entusiasmo que compartilho que estou expandindo meus serviços como Desenvolvedor AdvPL para novos desafios e colaborações. Com mais de duas décadas de experiência sólida, minha jornada profissional tem sido enriquecedora, com a oportunidade de participar de projetos empolgantes ao longo dos anos. Agora, estou ansioso para trazer minha experiência e habilidades para novas equipes e projetos, trabalhando de forma remota. Minha expertise abrange não apenas AdvPL, mas também outras tecnologias-chave, incluindo JS, SQL, Infraestrutura e Otimização de Processos. Acredito que essa combinação de conhecimentos me permite oferecer soluções abrangentes e eficazes para uma variedade de necessidades de desenvolvimento. Acredito que a tecnologia tem o poder de transformar negócios e impulsionar o sucesso, e estou comprometido em ajudar meus clientes a alcançar seu

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

  1. 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.

    Nã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!

    ResponderExcluir
  2. Vitor,

    Tem, 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

    ResponderExcluir
  3. Naldoidao, essa do expordic merece um post.

    ResponderExcluir
  4. Realmente este ExporDic foi bem elaborado e é de grande uso principalmente para quem não tem muito conhecimento de programação, pois é bem intuitivo.

    Copiei 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

    ResponderExcluir
  5. Rodrigo,

    Cadê 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...

    ResponderExcluir
  6. Eitaaaa... não precisava disso né brother!
    Ignorancia não é necessária, bastava dizer que esperava mais do exemplo.

    O site é nosso... e toda contribuição deve ser respeitada!

    {}'s

    ResponderExcluir
    Respostas
    1. eu mandava ele ir atrás e não esperar os outros darem o conhecimento assim de graça

      Excluir
  7. Naldo ,

    Gostei das ferramentas que você postou , mas tem algumas que não tem manual e nem exemplo
    teria como postar

    ResponderExcluir
  8. Ola Daniel

    Ainda 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

    ResponderExcluir
  9. Olá

    Eu coloquei a documentação das ferramentas no meu site. Por favor acessem:

    http://www.ernaniforastieri.com

    Espero que ajude.

    Obrigado.

    ResponderExcluir

Postar um comentário

Postagens mais visitadas deste blog

BlackTDN :: RLeg ~ Desvendando a Função ParamBox

Para quem precisar desenvolver uma interface de entrada de dados, coisa rápida, e não quer ter aquele trabalhão danado que todos já sabemos, o Protheus tem uma função que ajuda muito, é uma interface semelhante a função Pergunte, porém com muito mais opção de objeto de entrada de dados, alias até colocar o scrollbox desta interface com todos os objetos em outra MsDialog ou Wizard é simples. Vejam o exemplo abaixo, boa sorte! Rleg. //---------------------------------------------------------- // Função exemplo utilizando a função ParamBox() //---------------------------------------------------------- User Function xParamBox() Local aRet := {} Local aParamBox := {} Local aCombo := {"Janeiro","Fevereiro","Março","Abril","Maio","Junho","Julho","Agosto","Setembro","Outubro","Novembro","Dezembro"} Local i := 0 Private cCadastro := "xParambox" // ---------------

Protheus :: Chamando Funções do Menu Diretamente e sem a Necessidade de Login

Ferne$ perguntou: "...é possível abrir alguma rotina do sistema sem solicitar login ao usuário, como por exemplo a rotina MATA010..." Sim Ferne$, é possível sim. Abaixo um Exemplo para a Chamada à função MATA010 sem a necessidade de Login no sistema. #INCLUDE "PROTHEUS.CH" #INCLUDE "TBICONN.CH" /*/ Funcao: MATA010Ex Data: 30/04/2011 Autor: Marinaldo de Jesus Descricao: Executar a Funcao MATA010 diretamente sem a necessidade de LOGIN no Protheus Sintaxe: 1 ) U_MATA010Ex ( Chamada diretamente na Tela de Entrada do Sistema ) ; ou 2 ) totvsclient.exe -q -p=u_MATA010Ex -a=01;01 -c=rnp_local -e=rnp -m -l ( Chamada Via Linha de Comando ) /*/ User Function MATA010Ex( cEmpFil ) Local aEmpFil Local bWindowInit := { || __Execute( "MATA010()" , "xxxxxxxxxxxxxxxxxxxx" , "MATA010" , "SIGAFAT" , "SIGAFAT", 1 , .T. ) } Local cEmp Local cFil Local cMod Local cModName := "SIGAFAT" DEFA

BlackTDN :: Customizando a interface de Login no Protheus e by You

A publicação “ BlackTDN :: By You e sua nova tela de login ”  de nosso amigo OBona deu o que falar e, em função disso, esse que a muito não vos escreve resolveu criar uma versão onde será possível personalizar, “por completo”, a tela de login no Protheus/by You. Considerando que OBona já havia “mapeado, identificado e customizado” as imagens peguei-as emprestadas para o exemplo que se segue: O primeiro passo para a customização “total” da interface de login do Protheus/by You será implementar o “Ponto de Entrada” ChgPrDir (Diretório de impressão) . Usaremos esse PE juntamente como programa U_FindMsObject.prg (apresentado pela primeira vez em: Protheus :: ADVPL : The Container : Presents Pandora's box ). Diferente do exemplo proposto por OBona, que substitui, durante o processo de compilação, as imagens padrões do sistema (excluindo-as) por imagens customizadas (com o mesmo nome) este novo exemplo mantém, no RPO, as imagens padrões adicionando novas imagens customizadas que serã