Ayuda con DLL

Post Reply
Jorge Jaurena
Posts: 155
Joined: Fri Oct 21, 2005 6:35 pm

Ayuda con DLL

Post by Jorge Jaurena »

Buen dia.
Estoy usando una dll que se registra en windows y me provee varias funciones para realizar una comunicacion con un dispositivo externo.
El problema que tengo es que las funciones que deberian traerme info en algun parametro no lo hacen, la var que paso por referencia siempre vuelve vacia, las demas funciones si me andan bien.
Ya comprobe que no sea problema de la dll, creo que el problema lo tengo en mi codigo.
Esto es lo que hago:

Ret := .f.
Type := "S"
Pid := "217"
Message := ""

Ret := Controlador:PeriodSalesByGrade(Type, Pid, "", @Message)

En Message deberia venir la info y siempre vuelve vacio, ya probe inicializarla de todas las formas posibles y siempre igual.
Tambien consulte con el soporte de la dll y estoy haciendo lo correcto, quizas algo me falte en mi prg.

Muchas gracias
Jorge Jaurena
User avatar
Antonio Linares
Site Admin
Posts: 42259
Joined: Thu Oct 06, 2005 5:47 pm
Location: Spain
Contact:

Re: Ayuda con DLL

Post by Antonio Linares »

Estimado Jorge,

Copia aqui tu código para que podamos ayudarte, gracias
regards, saludos

Antonio Linares
www.fivetechsoft.com
Jorge Jaurena
Posts: 155
Joined: Fri Oct 21, 2005 6:35 pm

Re: Ayuda con DLL

Post by Jorge Jaurena »

Ok, va completo, las unicas funciones que no me andan son las que tienen que devolver algo en algun parametro, son:

PeriodSalesByGrade(Type, Pid, "", @Message)
PeriodSalesByPaymentType(Type, Pid, @Message)
GetMPPaymentObject(vSaleNr, @c_PaymentObject)
ShiftClose(Type, @St, @Message, @ErrorCode, @Pid, @PeriodType)

Estas funciones estan en VerTareas()
De las 4 que no me funcionan estoy probando con las 2 primeras.

#include "FiveWin.ch"
#include "Tsbutton.ch"
#include "WinApi.ch"
#include "ADS.ch"


// DEFINICION DE COLORES
#Define Negro 0
#Define Azul 8388608
#Define AzulB 16711680
#Define Verde 32768
#Define VerdeB 65280
#Define Celeste 8421376
#Define CelesteB 16776960
#Define Rojo 128
#Define RojoB 255
#Define Magenta 8388736
#Define MagentaB 16711935
#Define Marron 32896
#Define Gris 8421504
#Define GrisB 12632256
#Define Amarillo 65535
#Define Blanco 16777215
//


#define GHW_HWNDFIRST 0
#define GHW_HWNDNEXT 2


Static oApp,oTray,oIcon,oFondo1,oTimer,Controlador,LaIP,SerRemoto,RutaDat,SalgoSN
Static MaxSurt,MaxIsla,MaxTanq,MaxProd,VecPico[128],VecEst[20]
Static Type,St,Message,ErrorCode,Pid,PeriodType,Pte,PeriodInfo
Static Status,SubStatus,ModCem


******************** VENTANA PRINCIPAL DEL SISTEMA ***************************
Function Main()
Local oDbf,Vec1,Q,Titulo,MsgFooter,IPCem
Private DBF1,CDX1

DBF1:=CurDrive()+":\"+Curdir()+"\CONFPIPE.DBF"

USE &DBF1 NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()
RutaDat :=ALLTRIM(oDbf:RUTADATOS)
SerRemoto:=oDbf:REMOTO
DBCLOSEALL()

// PARA UTILIZAR INDICES CDX
REQUEST DBFCDX
RddSetDefault("DBFCDX")
//

RddRegister("ADS",1)
RddSetDefault("ADS")
IF !SerRemoto
SET SERVER LOCAL
ELSE
SET SERVER REMOTE
ENDIF
SET FILETYPE TO CDX

SET 3DLOOK ON
SET CENTURY ON
SET DATE FREN
SET EXCLUSIVE OFF
SET DELETED ON
SET AUTOPEN ON
SET FIXED ON
SET AUTORDER TO 1
SET DEFAULT TO &RutaDat
SetHandleCount(200)

CDX1:=RutaDat+"\VENTAS44.CDX"
FERASE("&CDX1")

IF !FILE("VTAFUS.DBF")
Vec1:={}
AADD(Vec1, {"FECHA ", "D", 8, 0})
AADD(Vec1, {"HORA ", "C", 8, 0})
AADD(Vec1, {"TURNO ", "N", 8, 0})
AADD(Vec1, {"PICO ", "N", 3, 0})
AADD(Vec1, {"PRODUC ", "N", 2, 0})
AADD(Vec1, {"PRECIO ", "N", 12, 3})
AADD(Vec1, {"AFOINI ", "N", 20, 3})
AADD(Vec1, {"AFOFIN ", "N", 20, 3})
AADD(Vec1, {"VTAVOL ", "N", 12, 3})
AADD(Vec1, {"VTAIMP ", "N", 12, 3})

DBCREATE("VTAFUS.DBF", Vec1)
DBCLOSEALL()

USE VTAFUS NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()
FOR Q=1 TO 128
oDbf:Append()
oDbf:FECHA :=DATE()
oDbf:HORA :=TIME()
oDbf:TURNO :=0
oDbf:PICO :=Q
oDbf:PRODUC:=0
oDbf:PRECIO:=0
oDbf:AFOINI:=0
oDbf:AFOFIN:=0
oDbf:VTAVOL:=0
oDbf:VTAIMP:=0
oDbf:Save()
oDbf:Unlock()
NEXT
ENDIF
DBCLOSEALL()

USE CONFICEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()
IPCem :=ALLTRIM(oDbf:IPCEM44)
ModCem:=ALLTRIM(oDbf:MODOCEM)
DBCLOSEALL()

Titulo :="WEST POINT Software - Comunicacion con Fusion Controller - V.240603"
MsgFooter:="Conectado en:"+IPCem+" "+ModCem

DEFINE ICON oIcon RESOURCE "A_ICON_1"
DEFINE BRUSH oFondo1 RESOURCE "FONDO_1"

DEFINE WINDOW oApp FROM 3,6 TO 40,160 TITLE Titulo ICON oIcon BRUSH oFondo1

SET MESSAGE OF oApp TO MsgFooter TIME DATE KEYBOARD 2007

ACTIVATE WINDOW oApp ON INIT HacerAlInicio(oApp)
Return nil
******************************************************************************


****************************** HACER AL INICIO *******************************
Function HacerAlInicio(oApp)
Local oDbf,Tiempo,Reg,Q,L,Ret,SiRet,oDlg,oLbx,oDbf1,oDbf2
Local oGetT[13],VarT[13],oGetD[10],VecDes[10],oGetI[10],VecProImp[10]
Local oGetV[10,10],NroVta[10],FecVta[10],HorVta[10],SurVta[10],PicVta[10],ProVta[10],ImpVta[10],DtoVta[10],VolVta[10],PPUVta[10],oBtn1,oBtn2,oBtn3
Private IPCem

IF !VerSiExe()
DBCLOSEALL()
QUIT
ENDIF

SalgoSN:=.f.

FOR Q=1 TO 10
NroVta[Q]:=0
FecVta[Q]:=CTOD(" / / ")
HorVta[Q]:=" : : "
SurVta[Q]:=" "
PicVta[Q]:=0
ProVta[Q]:=SPACE(35)
ImpVta[Q]:=0
DtoVta[Q]:=0
VolVta[Q]:=0
PPUVta[Q]:=0
NEXT

USE CONFICEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoBottom()
Reg:=oDbf:RecNo()
IF Reg>1
L:=(Reg+1)
ELSE
L:=1
ENDIF
IF Reg<128
FOR Q=L TO 128
oDbf:Append()
oDbf:Save()
oDbf:Unlock()
NEXT
ENDIF
DBCLOSEALL()

USE VENTACEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoBottom()
Reg:=oDbf:RecNo()
IF Reg>1
L:=(Reg+1)
ELSE
L:=1
ENDIF
IF Reg<128
FOR Q=L TO 128
oDbf:Append()
oDbf:Save()
oDbf:Unlock()
NEXT
ENDIF
DBCLOSEALL()

USE CONFICEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()

Tiempo:=oDbf:TIEMPOPROM*1000
IF Tiempo<=0
Tiempo:=5000
ENDIF
IPCem :=ALLTRIM(oDbf:IPCEM44)
LaIP :=ALLTRIM(oDbf:IPCEM44)
DBCLOSEALL()

FOR Q=1 TO 20
Vecest[Q]:=" "
NEXT
Vecest[1 ]:="Disponible"
Vecest[2 ]:="En Solicitud"
Vecest[3 ]:="Despachando"
Vecest[4 ]:="Autorizado"
Vecest[8 ]:="Error"
Vecest[9 ]:="Anulado"
Vecest[10]:="No Instalado"
Vecest[11]:="Stop"

Ret:=ConecFusion("C")

IF !Ret
DBCLOSEALL()
QUIT
ENDIF

* Controlador:SetTimeout(3000)

MsgRun("Leyendo configuracion del Fusion Controller.","Un momento, por favor...",LeerConfi())

USE CONFICEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()

VecDes[1] :=oDbf:PRODUCTO1
VecDes[2] :=oDbf:PRODUCTO2
VecDes[3] :=oDbf:PRODUCTO3
VecDes[4] :=oDbf:PRODUCTO4
VecDes[5] :=oDbf:PRODUCTO5
VecDes[6] :=oDbf:PRODUCTO6
VecDes[7] :=oDbf:PRODUCTO7
VecDes[8] :=oDbf:PRODUCTO8
VecDes[9] :=oDbf:PRODUCTO9
VecDes[10] :=oDbf:PRODUCTO0
VecProImp[1] :=oDbf:PRECIO11
VecProImp[2] :=oDbf:PRECIO12
VecProImp[3] :=oDbf:PRECIO13
VecProImp[4] :=oDbf:PRECIO14
VecProImp[5] :=oDbf:PRECIO15
VecProImp[6] :=oDbf:PRECIO16
VecProImp[7] :=oDbf:PRECIO17
VecProImp[8] :=oDbf:PRECIO18
VecProImp[9] :=oDbf:PRECIO19
VecProImp[10]:=oDbf:PRECIO10
DBCLOSEALL()

USE VENTACEM NEW
DATABASE oDbf1
oDbf1:bEoF=nil
oDbf1:bBoF=nil
oDbf1:GoTop()

USE VENTAS44 NEW
DATABASE oDbf2
oDbf2:bEoF=nil
oDbf2:bBoF=nil
oDbf2:GoBottom()

Q:=1
DO WHILE !oDbf2:Bof() .AND. Q<=10
IF oDbf2:PRODUCTO>0
NroVta[Q]:=oDbf2:NUMEROVTA
FecVta[Q]:=oDbf2:FECHA
HorVta[Q]:=oDbf2:HORA
SurVta[Q]:=TRAN(oDbf2:SURTIDOR,"##")+" "+oDbf2:MANGUERA
PicVta[Q]:=oDbf2:PICO
ProVta[Q]:=TRAN(oDbf2:PRODUCTO,"##")+" "+VecDes[oDbf2:PRODUCTO]
ImpVta[Q]:=oDbf2:IMPORTE
DtoVta[Q]:=oDbf2:IMPODTO
VolVta[Q]:=oDbf2:LITROS
PPUVta[Q]:=oDbf2:PRECIO
ENDIF
Q++

oDbf2:Skip(-1)
ENDDO
oDbf2:GoBottom()

VarT[1] :="PRODUCTO"
VarT[2] :="PPU"
VarT[3] :="ULTIMAS 10 VENTAS"
VarT[4] :="Nro. Venta"
VarT[5] :="Fecha"
VarT[6] :="Hora"
VarT[7] :="Surt."
VarT[8] :="Pico"
VarT[9] :="Producto"
VarT[10]:="Importe"
VarT[11]:="Dto."
VarT[12]:="Volumen"
VarT[13]:="PPU"

DEFINE DIALOG oDlg RESOURCE "BROWSE_GENERAL" OF oApp TITLE ""

REDEFINE GET oGetT[1] VAR VarT[1] ID 4001 OF oDlg READONLY
REDEFINE GET oGetT[2] VAR VarT[2] ID 4002 OF oDlg READONLY
REDEFINE GET oGetT[3] VAR VarT[3] ID 4033 OF oDlg READONLY

REDEFINE GET oGetT[4] VAR VarT[4] ID 4034 OF oDlg READONLY
REDEFINE GET oGetT[5] VAR VarT[5] ID 4035 OF oDlg READONLY
REDEFINE GET oGetT[6] VAR VarT[6] ID 4036 OF oDlg READONLY
REDEFINE GET oGetT[7] VAR VarT[7] ID 4037 OF oDlg READONLY
REDEFINE GET oGetT[8] VAR VarT[8] ID 4038 OF oDlg READONLY
REDEFINE GET oGetT[9] VAR VarT[9] ID 4039 OF oDlg READONLY
REDEFINE GET oGetT[10] VAR VarT[10] ID 4040 OF oDlg READONLY
REDEFINE GET oGetT[11] VAR VarT[11] ID 4136 OF oDlg READONLY
REDEFINE GET oGetT[12] VAR VarT[12] ID 4041 OF oDlg READONLY
REDEFINE GET oGetT[13] VAR VarT[13] ID 4042 OF oDlg READONLY

REDEFINE GET oGetD[1] VAR VecDes[1] ID 4003 OF oDlg READONLY
REDEFINE GET oGetI[1] VAR VecProImp[1] ID 4004 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[2] VAR VecDes[2] ID 4005 OF oDlg READONLY
REDEFINE GET oGetI[2] VAR VecProImp[2] ID 4006 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[3] VAR VecDes[3] ID 4007 OF oDlg READONLY
REDEFINE GET oGetI[3] VAR VecProImp[3] ID 4008 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[4] VAR VecDes[4] ID 4009 OF oDlg READONLY
REDEFINE GET oGetI[4] VAR VecProImp[4] ID 4010 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[5] VAR VecDes[5] ID 4011 OF oDlg READONLY
REDEFINE GET oGetI[5] VAR VecProImp[5] ID 4012 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[6] VAR VecDes[6] ID 4013 OF oDlg READONLY
REDEFINE GET oGetI[6] VAR VecProImp[6] ID 4014 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[7] VAR VecDes[7] ID 4015 OF oDlg READONLY
REDEFINE GET oGetI[7] VAR VecProImp[7] ID 4016 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[8] VAR VecDes[8] ID 4017 OF oDlg READONLY
REDEFINE GET oGetI[8] VAR VecProImp[8] ID 4018 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[9] VAR VecDes[9] ID 4019 OF oDlg READONLY
REDEFINE GET oGetI[9] VAR VecProImp[9] ID 4020 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetD[10] VAR VecDes[10] ID 4021 OF oDlg READONLY
REDEFINE GET oGetI[10] VAR VecProImp[10] ID 4022 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[1,1] VAR NroVta[1] ID 4043 OF oDlg READONLY
REDEFINE GET oGetV[1,2] VAR FecVta[1] ID 4044 OF oDlg READONLY
REDEFINE GET oGetV[1,3] VAR HorVta[1] ID 4045 OF oDlg READONLY
REDEFINE GET oGetV[1,4] VAR SurVta[1] ID 4046 OF oDlg READONLY
REDEFINE GET oGetV[1,5] VAR PicVta[1] ID 4047 OF oDlg READONLY
REDEFINE GET oGetV[1,6] VAR ProVta[1] ID 4048 OF oDlg READONLY
REDEFINE GET oGetV[1,7] VAR ImpVta[1] ID 4049 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[1,8] VAR DtoVta[1] ID 4137 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[1,9] VAR VolVta[1] ID 4050 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[1,10] VAR PPUVta[1] ID 4051 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[2,1] VAR NroVta[2] ID 4052 OF oDlg READONLY
REDEFINE GET oGetV[2,2] VAR FecVta[2] ID 4053 OF oDlg READONLY
REDEFINE GET oGetV[2,3] VAR HorVta[2] ID 4054 OF oDlg READONLY
REDEFINE GET oGetV[2,4] VAR SurVta[2] ID 4055 OF oDlg READONLY
REDEFINE GET oGetV[2,5] VAR PicVta[2] ID 4056 OF oDlg READONLY
REDEFINE GET oGetV[2,6] VAR ProVta[2] ID 4057 OF oDlg READONLY
REDEFINE GET oGetV[2,7] VAR ImpVta[2] ID 4058 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[2,8] VAR DtoVta[2] ID 4138 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[2,9] VAR VolVta[2] ID 4059 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[2,10] VAR PPUVta[2] ID 4060 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[3,1] VAR NroVta[3] ID 4061 OF oDlg READONLY
REDEFINE GET oGetV[3,2] VAR FecVta[3] ID 4062 OF oDlg READONLY
REDEFINE GET oGetV[3,3] VAR HorVta[3] ID 4063 OF oDlg READONLY
REDEFINE GET oGetV[3,4] VAR SurVta[3] ID 4064 OF oDlg READONLY
REDEFINE GET oGetV[3,5] VAR PicVta[3] ID 4065 OF oDlg READONLY
REDEFINE GET oGetV[3,6] VAR ProVta[3] ID 4066 OF oDlg READONLY
REDEFINE GET oGetV[3,7] VAR ImpVta[3] ID 4067 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[3,8] VAR DtoVta[3] ID 4139 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[3,9] VAR VolVta[3] ID 4068 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[3,10] VAR PPUVta[3] ID 4069 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[4,1] VAR NroVta[4] ID 4070 OF oDlg READONLY
REDEFINE GET oGetV[4,2] VAR FecVta[4] ID 4071 OF oDlg READONLY
REDEFINE GET oGetV[4,3] VAR HorVta[4] ID 4072 OF oDlg READONLY
REDEFINE GET oGetV[4,4] VAR SurVta[4] ID 4073 OF oDlg READONLY
REDEFINE GET oGetV[4,5] VAR PicVta[4] ID 4074 OF oDlg READONLY
REDEFINE GET oGetV[4,6] VAR ProVta[4] ID 4075 OF oDlg READONLY
REDEFINE GET oGetV[4,7] VAR ImpVta[4] ID 4076 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[4,8] VAR DtoVta[4] ID 4140 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[4,9] VAR VolVta[4] ID 4077 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[4,10] VAR PPUVta[4] ID 4078 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[5,1] VAR NroVta[5] ID 4079 OF oDlg READONLY
REDEFINE GET oGetV[5,2] VAR FecVta[5] ID 4080 OF oDlg READONLY
REDEFINE GET oGetV[5,3] VAR HorVta[5] ID 4081 OF oDlg READONLY
REDEFINE GET oGetV[5,4] VAR SurVta[5] ID 4082 OF oDlg READONLY
REDEFINE GET oGetV[5,5] VAR PicVta[5] ID 4083 OF oDlg READONLY
REDEFINE GET oGetV[5,6] VAR ProVta[5] ID 4084 OF oDlg READONLY
REDEFINE GET oGetV[5,7] VAR ImpVta[5] ID 4085 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[5,8] VAR DtoVta[5] ID 4141 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[5,9] VAR VolVta[5] ID 4086 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[5,10] VAR PPUVta[5] ID 4087 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[6,1] VAR NroVta[6] ID 4088 OF oDlg READONLY
REDEFINE GET oGetV[6,2] VAR FecVta[6] ID 4089 OF oDlg READONLY
REDEFINE GET oGetV[6,3] VAR HorVta[6] ID 4090 OF oDlg READONLY
REDEFINE GET oGetV[6,4] VAR SurVta[6] ID 4091 OF oDlg READONLY
REDEFINE GET oGetV[6,5] VAR PicVta[6] ID 4092 OF oDlg READONLY
REDEFINE GET oGetV[6,6] VAR ProVta[6] ID 4093 OF oDlg READONLY
REDEFINE GET oGetV[6,7] VAR ImpVta[6] ID 4094 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[6,8] VAR DtoVta[6] ID 4142 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[6,9] VAR VolVta[6] ID 4095 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[6,10] VAR PPUVta[6] ID 4096 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[7,1] VAR NroVta[7] ID 4097 OF oDlg READONLY
REDEFINE GET oGetV[7,2] VAR FecVta[7] ID 4098 OF oDlg READONLY
REDEFINE GET oGetV[7,3] VAR HorVta[7] ID 4099 OF oDlg READONLY
REDEFINE GET oGetV[7,4] VAR SurVta[7] ID 4100 OF oDlg READONLY
REDEFINE GET oGetV[7,5] VAR PicVta[7] ID 4101 OF oDlg READONLY
REDEFINE GET oGetV[7,6] VAR ProVta[7] ID 4102 OF oDlg READONLY
REDEFINE GET oGetV[7,7] VAR ImpVta[7] ID 4103 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[7,8] VAR DtoVta[7] ID 4143 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[7,9] VAR VolVta[7] ID 4104 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[7,10] VAR PPUVta[7] ID 4105 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[8,1] VAR NroVta[8] ID 4106 OF oDlg READONLY
REDEFINE GET oGetV[8,2] VAR FecVta[8] ID 4107 OF oDlg READONLY
REDEFINE GET oGetV[8,3] VAR HorVta[8] ID 4108 OF oDlg READONLY
REDEFINE GET oGetV[8,4] VAR SurVta[8] ID 4109 OF oDlg READONLY
REDEFINE GET oGetV[8,5] VAR PicVta[8] ID 4110 OF oDlg READONLY
REDEFINE GET oGetV[8,6] VAR ProVta[8] ID 4111 OF oDlg READONLY
REDEFINE GET oGetV[8,7] VAR ImpVta[8] ID 4112 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[8,8] VAR DtoVta[8] ID 4144 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[8,9] VAR VolVta[8] ID 4113 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[8,10] VAR PPUVta[8] ID 4114 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[9,1] VAR NroVta[9] ID 4115 OF oDlg READONLY
REDEFINE GET oGetV[9,2] VAR FecVta[9] ID 4116 OF oDlg READONLY
REDEFINE GET oGetV[9,3] VAR HorVta[9] ID 4117 OF oDlg READONLY
REDEFINE GET oGetV[9,4] VAR SurVta[9] ID 4118 OF oDlg READONLY
REDEFINE GET oGetV[9,5] VAR PicVta[9] ID 4119 OF oDlg READONLY
REDEFINE GET oGetV[9,6] VAR ProVta[9] ID 4120 OF oDlg READONLY
REDEFINE GET oGetV[9,7] VAR ImpVta[9] ID 4121 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[9,8] VAR DtoVta[9] ID 4145 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[9,9] VAR VolVta[9] ID 4122 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[9,10] VAR PPUVta[9] ID 4123 OF oDlg READONLY PICTURE "#####.##"

REDEFINE GET oGetV[10,1] VAR NroVta[10] ID 4124 OF oDlg READONLY
REDEFINE GET oGetV[10,2] VAR FecVta[10] ID 4125 OF oDlg READONLY
REDEFINE GET oGetV[10,3] VAR HorVta[10] ID 4126 OF oDlg READONLY
REDEFINE GET oGetV[10,4] VAR SurVta[10] ID 4127 OF oDlg READONLY
REDEFINE GET oGetV[10,5] VAR PicVta[10] ID 4128 OF oDlg READONLY
REDEFINE GET oGetV[10,6] VAR ProVta[10] ID 4129 OF oDlg READONLY
REDEFINE GET oGetV[10,7] VAR ImpVta[10] ID 4130 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[10,8] VAR DtoVta[10] ID 4146 OF oDlg READONLY PICTURE "#######.##"
REDEFINE GET oGetV[10,9] VAR VolVta[10] ID 4131 OF oDlg READONLY PICTURE "######.###"
REDEFINE GET oGetV[10,10] VAR PPUVta[10] ID 4132 OF oDlg READONLY PICTURE "#####.##"

REDEFINE SBUTTON oBtn1 ID 4133 OF oDlg PROMPT "LEER"+CHR(13)+"CONFIGURACION" TEXT 3 ACTION ""

REDEFINE SBUTTON oBtn2 ID 4134 OF oDlg PROMPT "MINIMIZAR" TEXT 3 ACTION oApp:Minimize()

REDEFINE SBUTTON oBtn3 ID 4135 OF oDlg PROMPT "SALIR" TEXT 3 ACTION oDlg:End()

ACTIVATE DIALOG oDlg ON INIT ActivoTimer(oDlg,Tiempo,oDbf1,oDbf2,oGetV,@NroVta,@FecVta,@HorVta,@SurVta,@PicVta,@ProVta,@ImpVta,@DtoVta,@VolVta,@PPUVta,VecDes) VALID VerSiSalgo()

IF SalgoSN
oTimer:DeActivate()
RELEASE TIMER oTimer
DBCLOSEALL()
oApp:End()
ENDIF
Return nil

// ACTIVAR EL TIMER
Function ActivoTimer(oDlg,Tiempo,oDbf1,oDbf2,oGetV,NroVta,FecVta,HorVta,SurVta,PicVta,ProVta,ImpVta,DtoVta,VolVta,PPUVta,VecDes)
DEFINE TIMER oTimer INTERVAL Tiempo ACTION VerTareas(oDbf1,oDbf2,oGetV,@NroVta,@FecVta,@HorVta,@SurVta,@PicVta,@ProVta,@ImpVta,@DtoVta,@VolVta,@PPUVta,VecDes) OF oDlg
ACTIVATE TIMER oTimer
Retur nil
//

// VERIFICO SI SALGO DEL SISTEMA
Function VerSiSalgo()
Local SiNo

IF SiNo:=MsgNoYes("Esta seguro que desea salir del sistema?","Por favor, seleccione")
SalgoSN:=.t.
Return .t.
ELSE
SalgoSN:=.f.
Return .f.
ENDIF
Return nil
//
******************************************************************************


**************************** LEER CONFIGURACION ******************************
Function LeerConfi()
Local oDbf,Q,L,N,cConfig,Surt,Pico,Grado,Desc,Li,Cont
Local Vec1[0],VecDes[10],VecSurt[32,6],VecTan[128], VecTanq[10],VecMan[128],VecPre[128]

MaxSurt:=0
MaxIsla:=0
MaxTanq:=0
MaxProd:=0

N:=1

FOR Q=1 TO 128
VecMan[Q] :=0
VecPre[Q] :=0
VecTan[Q] :=0
VecPico[Q]:=" "
NEXT

FOR Q=1 TO 10
VecDes[Q] :=SPACE(25)
VecTanq[Q]:=0
NEXT

FOR Q=1 TO 32
VecSurt[Q,1]:=" "
VecSurt[Q,2]:=" "
VecSurt[Q,3]:=" "
VecSurt[Q,4]:=" "
VecSurt[Q,5]:=" "
VecSurt[Q,6]:=" "
NEXT

cConfig:=CreateObject("FusionForecourt")
cConfig:=Controlador:GetConfig()

MaxSurt:=cConfig:m_iPumps

FOR Q=1 TO MaxSurt
Surt:=cConfig:GetPumpConfiguration(Q)
Li :="Surtidor:"+ALLTRIM(STR(Q))+";"+"Picos:"+ALLTRIM(STR(Surt:m_iHoses))+";"+"ID fisico:"+ALLTRIM(STR(Surt:m_iPhysicalID))+CHR(13)
AADD(Vec1,Li)

FOR L=1 TO Surt:m_iHoses
Pico:=Surt:GetHose(L)
Desc:=cConfig:GetGradeByID(Pico:m_iGradeNr)
IF Desc=nil
Desc:=" "
ENDIF
Li:="Pico:"+ALLTRIM(STR(N))+";"+"Grado:"+ALLTRIM(STR(Pico:m_iGradeNr))+";"+"Desc.:"+Desc+";"+"Precio:"+ALLTRIM(Pico:m_strPPU)+";"+"Tanque:"+ ALLTRIM(Pico:m_strTanks)+";"+;
"ID fisico:"+ALLTRIM(STR(Pico:m_iPhysicalID))+CHR(13)
AADD(Vec1,Li)

VecDes[Pico:m_iGradeNr]:=UPPER(Desc)
VecMan[N] :=Pico:m_iGradeNr
VecPre[N] :=VAL(Pico:m_strPPU)
VecTan[N] :=VAL(SUBSTR(Pico:m_strTanks,1,2))
VecTanq[VecTan[N]] :=1

IF L=1
VecSurt[Q,1]:="a"
ENDIF
IF L=2
VecSurt[Q,2]:="b"
ENDIF
IF L=3
VecSurt[Q,3]:="c"
ENDIF
IF L=4
VecSurt[Q,4]:="d"
ENDIF
IF L=5
VecSurt[Q,5]:="e"
ENDIF
IF L=6
VecSurt[Q,6]:="f"
ENDIF

N++
NEXT
NEXT

Li:=""
FOR Q=1 TO LEN(Vec1)
Li:=Li+Vec1[Q]
NEXT

MemoWrit( "ConfiFusion.TXT", cValToChar(Li) )

FOR Q=1 TO 10
IF !EMPTY(ALLTRIM(VecDes[Q]))
MaxProd++
ENDIF
NEXT

FOR Q=1 TO 10
IF VecTanq[Q]=1
MaxTanq++
ENDIF
NEXT

// GRABO LA CONFIGURACION
USE CONFICEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()

oDbf:Load()
oDbf:MAXSURTI :=MaxSurt
oDbf:MAXISLAS :=MaxIsla
oDbf:MAXTANQUES:=MaxTanq
oDbf:MAXPRODU :=MaxProd
oDbf:MAXMANGUE :=128

oDbf:PRODUCTO1:=VecDes[1]
oDbf:PRODUCTO2:=VecDes[2]
oDbf:PRODUCTO3:=VecDes[3]
oDbf:PRODUCTO4:=VecDes[4]
oDbf:PRODUCTO5:=VecDes[5]
oDbf:PRODUCTO6:=VecDes[6]
oDbf:PRODUCTO7:=VecDes[7]
oDbf:PRODUCTO8:=VecDes[8]
oDbf:PRODUCTO9:=VecDes[9]
oDbf:PRODUCTO0:=VecDes[10]

oDbf:CODIGO1 :=1
oDbf:CODIGO2 :=2
oDbf:CODIGO3 :=3
oDbf:CODIGO4 :=4
oDbf:CODIGO5 :=5
oDbf:CODIGO6 :=6
oDbf:CODIGO7 :=7
oDbf:CODIGO8 :=8
oDbf:CODIGO9 :=9
oDbf:CODIGO0 :=10

oDbf:FECHACONF:=DATE()
oDbf:HORACONF :=TIME()
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()

oDbf:GoTop()
Cont:=1
DO WHILE !oDbf:Eof()
oDbf:Load()
oDbf:NUMEROSURT:=0
oDbf:TIPOSURTI :=0
oDbf:NIVELPRECI:=1
oDbf:NUMEROMANG:=Cont
oDbf:TIPOPRODU :=VecMan[Cont]
oDbf:PRECPICO :=VecPre[Cont]
oDbf:TIPOTANQUE:=VecTan[Cont]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()

Cont++
oDbf:Skip()
ENDDO

oDbf:GoTop()
Cont:=1
DO WHILE Cont<=32
IF !EMPTY(VecSurt[Cont,1])
oDbf:Load()
oDbf:NUMEROSURT:=Cont
oDbf:PICO :=VecSurt[Cont,1]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()
oDbf:Skip()
ENDIF

IF !EMPTY(VecSurt[Cont,2])
oDbf:Load()
oDbf:NUMEROSURT:=Cont
oDbf:PICO :=VecSurt[Cont,2]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()
oDbf:Skip()
ENDIF

IF !EMPTY(VecSurt[Cont,3])
oDbf:Load()
oDbf:NUMEROSURT:=Cont
oDbf:PICO :=VecSurt[Cont,3]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()
oDbf:Skip()
ENDIF

IF !EMPTY(VecSurt[Cont,4])
oDbf:Load()
oDbf:NUMEROSURT:=Cont
oDbf:PICO :=VecSurt[Cont,4]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()
oDbf:Skip()
ENDIF

IF !EMPTY(VecSurt[Cont,5])
oDbf:Load()
oDbf:NUMEROSURT:=Cont
oDbf:PICO :=VecSurt[Cont,5]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()
oDbf:Skip()
ENDIF

IF !EMPTY(VecSurt[Cont,6])
oDbf:Load()
oDbf:NUMEROSURT:=Cont
oDbf:PICO :=VecSurt[Cont,6]
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()
oDbf:Skip()
ENDIF

Cont++
ENDDO

FOR Q=1 TO 128
VecPre[Q]:=0
NEXT

oDbf:GoTop()
DO WHILE !oDbf:Eof()
IF oDbf:TIPOPRODU=1 .AND. VecPre[1]=0
VecPre[1]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=2 .AND. VecPre[2]=0
VecPre[2]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=3 .AND. VecPre[3]=0
VecPre[3]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=4 .AND. VecPre[4]=0
VecPre[4]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=5 .AND. VecPre[5]=0
VecPre[5]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=6 .AND. VecPre[6]=0
VecPre[6]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=7 .AND. VecPre[7]=0
VecPre[7]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=8 .AND. VecPre[8]=0
VecPre[8]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=9 .AND. VecPre[9]=0
VecPre[9]:=oDbf:PRECPICO
ENDIF
IF oDbf:TIPOPRODU=10 .AND. VecPre[10]=0
VecPre[10]:=oDbf:PRECPICO
ENDIF

oDbf:Skip()
ENDDO

oDbf:GoTop()
oDbf:Load()
oDbf:PRECIO11:=VecPre[1]
oDbf:PRECIO12:=VecPre[2]
oDbf:PRECIO13:=VecPre[3]
oDbf:PRECIO14:=VecPre[4]
oDbf:PRECIO15:=VecPre[5]
oDbf:PRECIO16:=VecPre[6]
oDbf:PRECIO17:=VecPre[7]
oDbf:PRECIO18:=VecPre[8]
oDbf:PRECIO19:=VecPre[9]
oDbf:PRECIO10:=VecPre[10]
oDbf:PRECIO21:=0
oDbf:PRECIO22:=0
oDbf:PRECIO23:=0
oDbf:PRECIO24:=0
oDbf:PRECIO25:=0
oDbf:PRECIO26:=0
oDbf:PRECIO27:=0
oDbf:PRECIO28:=0
oDbf:PRECIO29:=0
oDbf:PRECIO20:=0
oDbf:RecLock()
oDbf:Save()
oDbf:Unlock()

DBCLOSEALL()
//

// CARGO LA CONFIGURACION DE MANGUERAS
USE CONFICEM NEW
DATABASE oDbf
oDbf:bEoF=nil
oDbf:bBoF=nil
oDbf:GoTop()

DO WHILE !oDbf:Eof()
VecPico[oDbf:RecNo()]:=TRAN(oDbf:NUMEROSURT,"##")+oDbf:PICO
oDbf:Skip()
ENDDO
DBCLOSEALL()
//

cConfig:End()
Return nil
******************************************************************************


****************************** VERIFICAR TAREAS ******************************
Function VerTareas(oDbf1,oDbf2,oGetV,NroVta,FecVta,HorVta,SurVta,PicVta,ProVta,ImpVta,DtoVta,VolVta,PPUVta,VecDes)
Local Q,L,V,X,oDbf3,oDbf4,oDbf5,QueHora,Li,Ret,SiRet,RetInt,c_FusionSale,vAmount,vPPU,vPump,vSaleNr,vCierreNr,vVolume,vHose,vFin_Vol_Tot,vIni_Vol_Tot,vPay_Type,vPay_Info,vPay_InfoA,;
Vta,Mang,vProd,vPico,Fec,Hor,RetBol,ObjetoPago,RetMP,c_PaymentObject
Local pt,periodID,Di,Me,An,Fe,Ho
Local CieAfoF[128],CieAfoI[128],CieProd[128],CiePrec[128],VtaV[128],VtaI[128],VtaProV[10],VtaProI[10],VtaProP[10],TotV,TotI,NumCie,IniFOR,FinFOR,RetTxt,CieAct
Private NomArch,File1,File2,File3,File4

oTimer:DeActivate()

File1:=RutaDat+"\LEERCONF.MEM"

IF FILE("&File1")
FERASE("&File1")
LeerConfi()
ENDIF

File1:=RutaDat+"\CEMCLOSN.MEM"
File2:=RutaDat+"\CEMCLOSL.MEM"
File3:=RutaDat+"\LEEDESPA.TXT"
File4:=RutaDat+"\PRUEBAS.TXT"

IF (FILE("&File1") .AND. FILE("&File2")) .OR. FILE("&File3") && LECTURA DE DESPACHOS
IniFOR:=1
FinFOR:=MaxSurt
RetTxt:=" "

IF FILE("&File3")
RetTxt:=MemoRead("&File3")
RetTxt:=ALLTRIM(RetTxt)
IF VAL(RetTxt)>=1 .AND. VAL(RetTxt)<=32
IniFOR:=VAL(RetTxt)
FinFOR:=VAL(RetTxt)
ENDIF
ENDIF

/*
Pump NR 3
Hose 1
Shift ID 25
Payment Type SSF_TRANS_PAY_TYPE_AUTOMATIC
Amount 54.91
PPU 26.00000
Volume 2.11200
Sale NR 125243
Initial Volume 220757.18700
Final Volume 220759.29900
Payment Alarm
ATCVO 2.11200
AVGTM 0.00000
ATCIVO
ATCFVO
*/

c_FusionSale:=CreateObject("FusionSale")

FOR Q=IniFOR TO FinFOR
Inkey(1)

Status :=""
SubStatus:=""

*RetInt:=Controlador:PumpStatus(INT(Q), @Status, @SubStatus)

*IF RetInt=1 .AND. ALLTRIM(Status)="IDLE"

RetInt:=Controlador:GetLastSale(Q, c_FusionSale)

IF RetInt=1
vProd :=c_FusionSale:GetGradeNr() && Codigo de producto
vAmount :=c_FusionSale:GetAmount() && Monto total de la venta
vVolume :=c_FusionSale:GetVolume() && Volumen total de la venta
vPPU :=c_FusionSale:GetPPU() && Precio unitario de la venta
vPump :=c_FusionSale:GetPumpNr() && Numero de surtidor
vHose :=c_FusionSale:GetHoseNr() && Numero de pico
vSaleNr :=c_FusionSale:GetSaleID() && Numero de venta
vCierreNr :=c_FusionSale:GetShiftID() && Numero de cierre
vIni_Vol_Tot:=c_FusionSale:GetInitialVolume() && Aforador volumen inicial
vFin_Vol_Tot:=c_FusionSale:GetFinalVolume() && Aforador volumen final
vPay_Type :=c_FusionSale:GetPaymentType() && Tipo de pago
vPay_Info :=c_FusionSale:GetPaymentInfo() && Info del pago
vPay_InfoA :=c_FusionSale:GetPaymentInfoAttribute("1") && Info atrib del pago

Li :=ALLTRIM(STR(vSaleNr))+";"+vAmount+";"+vVolume+";"+vPPU+";"+ALLTRIM(STR(vProd))+";"+ALLTRIM(STR(vPump))+";"+ALLTRIM(STR(vHose))+";"+vIni_Vol_Tot+";"+vFin_Vol_Tot+";"+vPay_Type+";"+vPay_Info+";"+vPay_InfoA
NomArch:="UltVta_"+ALLTRIM(STR(Q))+".TXT"
MemoWrit( "&Nomarch", Li )

// PIDO DATOS DEL CIERRE RECIEN HECHO
IF FILE("&File4")
SiRet :=.f.
Type :="S"
Pid :="217"
Message:=SPACE(1024)

SiRet :=Controlador:PeriodSalesByGrade(Type, Pid, "", @Message)
IF SiRet
NomArch:="CierreProd_217"+".txt"
MemoWrit("&Nomarch", ALLTRIM(Message))
ENDIF

SiRet :=.f.
Type :="S"
Pid :="217"
Message:=SPACE(1024)

SiRet :=Controlador:PeriodSalesByPaymentType(Type, Pid, @Message)
IF SiRet
NomArch:="CierrePago_217"+".txt"
MemoWrit("&Nomarch", ALLTRIM(Message))
ENDIF
ENDIF
//
ELSE
Li :="No trajo ultima venta Surt. "+ALLTRIM(STR(Q))
NomArch:="NOUltVta_"+ALLTRIM(STR(Q))+".TXT"
MemoWrit( "&Nomarch", Li )
ENDIF

IF RetInt=1 .AND. VAL(vAmount)>0
vPico:=" "
IF vHose=1
vPico:="a"
ENDIF
IF vHose=2
vPico:="b"
ENDIF
IF vHose=3
vPico:="c"
ENDIF
IF vHose=4
vPico:="d"
ENDIF
IF vHose=5
vPico:="e"
ENDIF
IF vHose=6
vPico:="f"
ENDIF

Vta :=TRAN(vPump,"##")+vPico
Mang:=0
FOR L=1 TO 128
IF Vta=VecPico[L]
Mang:=L
ENDIF
NEXT

IF Mang>=1 .AND. Mang<=128
oDbf1:GoTo(Mang)
IF oDbf1:ULTIMANU<>vSaleNr
Fec:=DATE()
Hor:=TIME()

oDbf1:Load()
oDbf1:ANTERIORNU:=oDbf1:ULTIMANU
oDbf1:ANTERIORLI:=oDbf1:ULTIMALI
oDbf1:ANTERIORIM:=oDbf1:ULTIMAIM
oDbf1:ANTERIORFE:=oDbf1:ULTIMAFE
oDbf1:ANTERIORHO:=oDbf1:ULTIMAHO
oDbf1:ANTESURTI :=oDbf1:ULTISURTI
oDbf1:ANTERIORMA:=oDbf1:ULTIMAMA
oDbf1:ANTERIORPR:=oDbf1:ULTIMAPR
oDbf1:ANTEPPU :=oDbf1:ULTIPPU
oDbf1:ANTTOMADO :=.f.
oDbf1:ANTPAGTIP :=oDbf1:ULTPAGTIP
oDbf1:ANTPAGINF :=oDbf1:ULTPAGINF
oDbf1:ANTIMPDTO :=oDbf1:ULTIMPDTO
oDbf1:ULTIMANU :=vSaleNr
oDbf1:ULTIMALI :=VAL(vVolume)
oDbf1:ULTIMAIM :=VAL(vAmount)
oDbf1:ULTIMAFE :=Fec
oDbf1:ULTIMAHO :=Hor
oDbf1:ULTISURTI :=vPump
oDbf1:ULTIMAMA :=vPico
oDbf1:ULTIMAPR :=vProd
oDbf1:ULTIPPU :=VAL(vPPU)
oDbf1:ULTTOMADO :=.f.
oDbf1:ULTPAGTIP :=ALLTRIM(vPay_Type)
oDbf1:ULTPAGINF :=ALLTRIM(vPay_Info)
oDbf1:ULTIMPDTO :=0
oDbf1:RecLock()
oDbf1:Save()
oDbf1:Unlock()

oDbf2:Append()
oDbf2:FECHA :=Fec
oDbf2:HORA :=Hor
oDbf2:SURTIDOR :=vPump
oDbf2:MANGUERA :=vPico
oDbf2:PICO :=Mang
oDbf2:PRODUCTO :=vProd
oDbf2:LITROS :=VAL(vVolume)
oDbf2:IMPORTE :=VAL(vAmount)
oDbf2:PRECIO :=VAL(vPPU)
oDbf2:NUMEROVTA:=vSaleNr
oDbf2:AFORAINI :=VAL(vIni_Vol_Tot)
oDbf2:AFORAFIN :=VAL(vFin_Vol_Tot)
oDbf2:PAGOTIPO :=ALLTRIM(vPay_Type)
oDbf2:PAGOINFO :=ALLTRIM(vPay_Info)
oDbf2:IMPODTO :=0
oDbf2:NROCIERRE:=vCierreNr
oDbf2:Save()
oDbf2:Unlock()

FOR V=10 TO 2 STEP -1
NroVta[V]:=NroVta[V-1]
FecVta[V]:=FecVta[V-1]
HorVta[V]:=HorVta[V-1]
SurVta[V]:=SurVta[V-1]
PicVta[V]:=PicVta[V-1]
ProVta[V]:=ProVta[V-1]
ImpVta[V]:=ImpVta[V-1]
DtoVta[V]:=DtoVta[V-1]
VolVta[V]:=VolVta[V-1]
PPUVta[V]:=PPUVta[V-1]
NEXT

oDbf2:GoBottom()
NroVta[1]:=oDbf2:NUMEROVTA
FecVta[1]:=oDbf2:FECHA
HorVta[1]:=oDbf2:HORA
SurVta[1]:=TRAN(oDbf2:SURTIDOR,"##")+" "+oDbf2:MANGUERA
PicVta[1]:=oDbf2:PICO
ProVta[1]:=TRAN(oDbf2:PRODUCTO,"##")+" "+VecDes[oDbf2:PRODUCTO]
ImpVta[1]:=oDbf2:IMPORTE
DtoVta[1]:=oDbf2:IMPODTO
VolVta[1]:=oDbf2:LITROS
PPUVta[1]:=oDbf2:PRECIO

FOR V=1 TO 10
FOR X=1 TO 10
oGetV[V,X]:Refresh()
NEXT
NEXT
ELSE
IF oDbf1:ULTIMANU=vSaleNr .AND. !EMPTY(ALLTRIM(vPay_Type))
IF ModCem="PRIS" .AND. ALLTRIM(vPay_Type)="Puma App"
RetInt:=Controlador:GetSale(vSaleNr, c_FusionSale)
IF RetInt=1
RetBol :=.f.
*ObjetoPago:=" "
c_PaymentObject:=" "
RetBol :=Controlador:GetMPPaymentObject(vSaleNr, @c_PaymentObject)
IF RetBol
Li :=ALLTRIM(STR(vSaleNr))+";"+ALLTRIM(c_PaymentObject)
NomArch:="ObjPago_"+ALLTRIM(STR(vSaleNr))+".TXT"
MemoWrit( "&Nomarch", Li )
ENDIF
ENDIF
ENDIF

oDbf1:Load()
oDbf1:ULTPAGTIP :=ALLTRIM(vPay_Type)
oDbf1:ULTPAGINF :=ALLTRIM(vPay_Info)
oDbf1:RecLock()
oDbf1:Save()
oDbf1:Unlock()

V:=1
oDbf2:GoBottom()
DO WHILE !oDbf2:Eof() .AND. !oDbf2:Bof() .AND. V<=20
IF oDbf2:NUMEROVTA=vSaleNr
oDbf2:Load()
oDbf2:PAGOTIPO :=ALLTRIM(vPay_Type)
oDbf2:PAGOINFO :=ALLTRIM(vPay_Info)
oDbf2:RecLock()
oDbf2:Save()
oDbf2:Unlock()
V:=30
ENDIF
oDbf2:Skip(-1)
V++
ENDDO
ENDIF
ENDIF
ENDIF
ENDIF
*ENDIF
NEXT

c_FusionSale:End()
ENDIF
//


// CIERRE DE TURNO
IF FILE("&File1") .AND. FILE("&File2")
FERASE("&File1")
FERASE("&File2")

Type :="S"
St :=SPACE(100)
Message :=SPACE(100)
ErrorCode :=SPACE(100)
Pid :=SPACE(100)
PeriodType:=SPACE(100)

SiRet:=Controlador:ShiftClose(Type, @St, @Message, @ErrorCode, @Pid, @PeriodType)

IF !SiRet
NomArch:="NORecibioComandoCierre.txt"
MemoWrit( "&Nomarch", cValToChar("Error:"+ErrorCode) )
ENDIF

IF SiRet
// ACA HAGO EL CIERRE MANUAL TOMANDO LOS AFORADORES DE LOS DESPACHOS
USE CONFICEM NEW
DATABASE oDbf5
oDbf5:bEoF=nil
oDbf5:bBoF=nil
oDbf5:GoTop()

DO WHILE !oDbf5:Eof()
CieProd[oDbf5:RecNo()]:=oDbf5:TIPOPRODU
CiePrec[oDbf5:RecNo()]:=oDbf5:PRECPICO
oDbf5:Skip()
ENDDO
oDbf5:Close()

FOR Q=1 TO 128
CieAfoF[Q]:=0
CieAfoI[Q]:=0
VtaV[Q] :=0
VtaI[Q] :=0
NEXT

FOR Q=1 TO 10
VtaProV[Q]:=0
VtaProI[Q]:=0
VtaProP[Q]:=0
NEXT

TotV:=0
TotI:=0

USE VTAFUS NEW
DATABASE oDbf3
oDbf3:bEoF=nil
oDbf3:bBoF=nil
oDbf3:GoTop()

USE CEM44CIE NEW
DATABASE oDbf4
oDbf4:bEoF=nil
oDbf4:bBoF=nil
oDbf4:GoBottom()
NumCie:=oDbf4:NUMERO+1
oDbf4:GoTop()

SELECT VTAFUS
oDbf3:GoTop()
DO WHILE !oDbf3:Eof()
CieAfoI[oDbf3:PICO]:=oDbf3:AFOFIN
oDbf3:Skip()
ENDDO

SELECT VENTAS44
oDbf2:GoBottom()
CieAct:=oDbf2:NROCIERRE
DO WHILE !oDbf2:Bof() .AND. (oDbf2:FECHA=DATE() .OR. oDbf2:FECHA=(DATE()-1))
IF oDbf2:PICO>0
IF CieAfoF[oDbf2:PICO]=0
CieAfoF[oDbf2:PICO]:=oDbf2:AFORAFIN
IF CieAfoI[oDbf2:PICO]=0
CieAfoI[oDbf2:PICO]:=oDbf2:AFORAFIN
ENDIF
ENDIF
ENDIF
oDbf2:Skip(-1)
ENDDO

FOR Q=1 TO 128
IF CieAfoI[Q]>0 .AND. CieAfoF[Q]=0
CieAfoF[Q]:=CieAfoI[Q]
ENDIF
NEXT

SELECT VTAFUS
oDbf3:GoTop()
FOR Q=1 TO 128
VtaV[Q]:=ROUND((CieAfoF[Q]-CieAfoI[Q]),2)
VtaI[Q]:=ROUND((VtaV[Q]*CiePrec[Q]),2)

oDbf3:RecLock()
oDbf3:FECHA :=DATE()
oDbf3:HORA :=TIME()
oDbf3:TURNO :=NumCie
oDbf3:PICO :=Q
oDbf3:PRODUC:=CieProd[Q]
oDbf3:PRECIO:=CiePrec[Q]
oDbf3:AFOINI:=CieAfoI[Q]
oDbf3:AFOFIN:=CieAfoF[Q]
oDbf3:VTAVOL:=VtaV[Q]
oDbf3:VTAIMP:=VtaI[Q]
oDbf3:Save()
oDbf3:Unlock()

oDbf3:Skip()
NEXT

oDbf3:GoTop()
DO WHILE !oDbf3:Eof()
IF oDbf3:PRODUC>0 .AND. oDbf3:VTAVOL>0
VtaProV[oDbf3:PRODUC]:=VtaProV[oDbf3:PRODUC]+oDbf3:VTAVOL
VtaProI[oDbf3:PRODUC]:=VtaProI[oDbf3:PRODUC]+oDbf3:VTAIMP
ENDIF
oDbf3:Skip()
ENDDO

FOR Q=1 TO 10
TotV:=TotV+VtaProV[Q]
TotI:=TotI+VtaProI[Q]
NEXT

FOR Q=1 TO 10
IF VtaProV[Q]>0
VtaProP[Q]:=ROUND(((VtaProV[Q]*100)/TotV),2)
ENDIF
NEXT

SELECT CEM44CIE
FOR Q=1 TO 128
IF VtaV[Q]>0
oDbf4:Append()
oDbf4:NUMERO :=NumCie
oDbf4:FECHA :=DATE()
oDbf4:HORA :=TIME()
oDbf4:TOTPESOS :=TotI
oDbf4:TOTLITROS :=TotV
oDbf4:TOTSINIMP :=0
oDbf4:TOTSINLIT :=0
oDbf4:TOTPRUIMP :=0
oDbf4:TOTPRULIT :=0
oDbf4:TOTYERIMP :=0
oDbf4:TOTYERLIT :=0
oDbf4:PRODUCTO1I:=VtaProI[1]
oDbf4:PRODUCTO1L:=VtaProV[1]
oDbf4:PRODUCTO1P:=VtaProP[1]
oDbf4:PRODUCTO2I:=VtaProI[2]
oDbf4:PRODUCTO2L:=VtaProV[2]
oDbf4:PRODUCTO2P:=VtaProP[2]
oDbf4:PRODUCTO3I:=VtaProI[3]
oDbf4:PRODUCTO3L:=VtaProV[3]
oDbf4:PRODUCTO3P:=VtaProP[3]
oDbf4:PRODUCTO4I:=VtaProI[4]
oDbf4:PRODUCTO4L:=VtaProV[4]
oDbf4:PRODUCTO4P:=VtaProP[4]
oDbf4:PRODUCTO5I:=VtaProI[5]
oDbf4:PRODUCTO5L:=VtaProV[5]
oDbf4:PRODUCTO5P:=VtaProP[5]
oDbf4:PRODUCTO6I:=VtaProI[6]
oDbf4:PRODUCTO6L:=VtaProV[6]
oDbf4:PRODUCTO6P:=VtaProP[6]
oDbf4:PRODUCTO7I:=VtaProI[7]
oDbf4:PRODUCTO7L:=VtaProV[7]
oDbf4:PRODUCTO7P:=VtaProP[7]
oDbf4:PRODUCTO8I:=VtaProI[8]
oDbf4:PRODUCTO8L:=VtaProV[8]
oDbf4:PRODUCTO8P:=VtaProP[8]
oDbf4:PRODUCTO9I:=VtaProI[9]
oDbf4:PRODUCTO9L:=VtaProV[9]
oDbf4:PRODUCTO9P:=VtaProP[9]
oDbf4:PRODUCTO0I:=VtaProI[10]
oDbf4:PRODUCTO0L:=VtaProV[10]
oDbf4:PRODUCTO0P:=VtaProP[10]
oDbf4:SURTILIT :=VtaV[Q]
oDbf4:SURTIIMP :=VtaI[Q]
oDbf4:CERRADO :=" "
oDbf4:CERRADON :=" "
oDbf4:CERRADOL :=" "
oDbf4:Save()
oDbf4:Unlock()
ENDIF
NEXT

SELECT VENTACEM
oDbf1:GoTop()

DO WHILE !oDbf1:Eof()
oDbf1:Load()
oDbf1:ANTERIORNU:=0
oDbf1:ANTERIORLI:=0
oDbf1:ANTERIORIM:=0
oDbf1:ANTERIORFE:=CTOD(" / / ")
oDbf1:ANTERIORHO:=" "
oDbf1:ANTESURTI :=0
oDbf1:ANTERIORMA:=" "
oDbf1:ANTERIORPR:=0
oDbf1:ANTEPPU :=0
oDbf1:ANTTOMADO :=.f.
oDbf1:ULTIMANU :=0
oDbf1:ULTIMALI :=0
oDbf1:ULTIMAIM :=0
oDbf1:ULTIMAFE :=CTOD(" / / ")
oDbf1:ULTIMAHO :=" "
oDbf1:ULTISURTI :=0
oDbf1:ULTIMAMA :=" "
oDbf1:ULTIMAPR :=0
oDbf1:ULTIPPU :=0
oDbf1:ULTTOMADO :=.f.
oDbf1:RecLock()
oDbf1:Save()
oDbf1:Unlock()
oDbf1:Skip()
ENDDO

SELECT VENTAS44
oDbf2:GoTop()

oDbf2:Append()
oDbf2:FECHA :=DATE()
oDbf2:HORA :=TIME()
oDbf2:SURTIDOR :=0
oDbf2:MANGUERA :=" "
oDbf2:PICO :=0
oDbf2:PRODUCTO :=0
oDbf2:LITROS :=0
oDbf2:IMPORTE :=0
oDbf2:PRECIO :=0
oDbf2:NUMEROVTA:=0
oDbf2:AFORAINI :=0
oDbf2:AFORAFIN :=0
oDbf2:Save()
oDbf2:Unlock()

oDbf3:Close()
oDbf4:Close()

// RESULTADO DEL CIERRE
NomArch:="ResultadoCierre.txt"
MemoWrit( "&Nomarch", cValToChar("ST:"+St+CHR(13)+"MESSAGE:"+Message+CHR(13)+"ERRORCODE:"+ErrorCode+CHR(13)+"PID:"+Pid+CHR(13)+"PERIODTYPE:"+PeriodType) )
//
///////////////////////////////////////////////////////////////////
ENDIF
ENDIF

oTimer:Activate()
//
Return nil
******************************************************************************


********************** CONECTAR O DESCONECTAR DEL FUSION *********************
Function ConecFusion(Par)
Local SiRet,Q
Private _IPCem

_IPCem:=LaIP

IF Par="C"
Controlador:=CreateObject("Fusion")
Controlador:Connection("&_IPCem")

FOR Q=1 TO 10
SiRet:=Controlador:ConnectionStatus()
IF !SiRet
Inkey(2)
Controlador:Connection("&_IPCem")
ELSE
Q:=100
ENDIF
NEXT

IF !SiRet
MsgWait("NO PUDO CONECTAR CON EL FUSION.","ATENCION",3)
Return .f.
ENDIF
ENDIF

IF Par="D"
SiRet:=Controlador:ConnectionStatus()

IF SiRet
Controlador:Close()
Controlador:End()
ENDIF
ENDIF
Return .t.
******************************************************************************


***********************************************************************************************
***************************** FUNCIONES GENERALES *********************************************
***********************************************************************************************
// VERIFICO SI YA ESTA CORRIENDO
Function VerSiExe()
Local Q,aTask,Flag:=0

aTask:=GetTask()
FOR Q=1 TO LEN(aTask)
IF aTask[Q]="WEST POINT Software - Comunicacion con Fusion Controller"
Flag++
ENDIF
NEXT

IF Flag>1
MsgWait("El servicio ya se esta ejecutando.","ERROR",3)
Return .f.
ELSE
Return .t.
ENDIF
Return nil
//


//
Function CargaArch(Ruta,Objeto)
Ruta :=cGetFile32()
Objeto:Refresh()
Return Ruta
//


// CORRE EL EXE COMO UN SERVICIO
Function ServiceProcess( mode )
Local nProcessId := 0

Default mode := 0

nProcessId := GCP( )

If Abs( nProcessId ) > 0
RSProcess( nProcessId, mode )
Endif
Return nil
//


// VER APLICACIONES CORRIENDO
Function GetTask()
local hWnd := GetWindow( GetActiveWindow(), GHW_HWNDFIRST )
local aTasks := {}
local cTask

while hWnd != 0
#ifdef __CLIPPER__
cTask = GetModuleFileName( GetWindowWord( hWnd, GWW_HINSTANCE ) )
#else
cTask = GetWindowText( hWnd ) // The above does now work :-(
#endif

AAdd( aTasks, cTask )
hWnd = GetWindow( hWnd, GHW_HWNDNEXT )
end
Return aTasks
//


DLL32 FUNCTION RSProcess(npID AS LONG, nMode AS LONG ) AS LONG FROM "RegisterServiceProcess" LIB "Kernel32.dll"

DLL32 FUNCTION GCP() AS LONG FROM "GetCurrentProcessId" LIB "Kernel32.dll"

DLL32 FUNCTION PeriodSalesByGrade( pt AS LPSTR, periodID AS LPSTR, pte AS LPSTR, @periodInfo AS LPSTR ) AS BOOL FROM "Fusion" LIB "FusionClass.dll"

DLL32 FUNCTION PeriodSalesByPaymentType( pt AS LPSTR, periodID AS LPSTR, @periodInfo AS LPSTR ) AS BOOL FROM "Fusion" LIB "FusionClass.dll"
***********************************************************************************************
***********************************************************************************************
***********************************************************************************************
User avatar
Antonio Linares
Site Admin
Posts: 42259
Joined: Thu Oct 06, 2005 5:47 pm
Location: Spain
Contact:

Re: Ayuda con DLL

Post by Antonio Linares »

Por qué lo usas como un mensaje a un objeto ?

SiRet :=Controlador:PeriodSalesByGrade(Type, Pid, "", @Message)
regards, saludos

Antonio Linares
www.fivetechsoft.com
Jorge Jaurena
Posts: 155
Joined: Fri Oct 21, 2005 6:35 pm

Re: Ayuda con DLL

Post by Jorge Jaurena »

Disculpa, no entiendo la pregunta.
Jorge Jaurena
Posts: 155
Joined: Fri Oct 21, 2005 6:35 pm

Re: Ayuda con DLL

Post by Jorge Jaurena »

Controlador es el objeto y PeriodSalesByGrade() es el metodo que estoy ejecutando con sus 4 parametros en cual en la var Meesage deberia venir la info.
Jorge Jaurena
Posts: 155
Joined: Fri Oct 21, 2005 6:35 pm

Re: Ayuda con DLL

Post by Jorge Jaurena »

No se si servira pero esto dice la documentacion de la clase.
Siempre me devuelve .t. por lo tanto asumo que la sintaxis al menos es correcta.

◆ Fusion::PeriodSalesByGrade() [2/2]
bool FusionClass::Fusion::Fusion::PeriodSalesByGrade ( String^ pt,
String^ periodID,
String^ pte,
String^ % periodInfo
)

Gets shift period information by grade.

Parameters
pt Period Type. The valid options are:
S -> Shift
D -> Day
M -> Month
Y -> Year
periodID Period ID
pte list of payment types excluded
periodInfo Sales information

Returns
True if operation is successful
User avatar
Antonio Linares
Site Admin
Posts: 42259
Joined: Thu Oct 06, 2005 5:47 pm
Location: Spain
Contact:

Re: Ayuda con DLL

Post by Antonio Linares »

Jorge Jaurena wrote:Disculpa, no entiendo la pregunta.
Aqui está la declaración de tu función:
DLL32 FUNCTION PeriodSalesByGrade( pt AS LPSTR, periodID AS LPSTR, pte AS LPSTR, @periodInfo AS LPSTR ) AS BOOL FROM "Fusion" LIB "FusionClass.dll"

sin embargo en tu código la usas como un mensaje a un objeto:
SiRet :=Controlador:PeriodSalesByGrade(Type, Pid, "", @Message)

luego debes tener una clase TControlador ó nombre similar, donde está ?
regards, saludos

Antonio Linares
www.fivetechsoft.com
Jorge Jaurena
Posts: 155
Joined: Fri Oct 21, 2005 6:35 pm

Re: Ayuda con DLL

Post by Jorge Jaurena »

Hola Antonio.

Esta declaracion:
DLL32 FUNCTION PeriodSalesByGrade( pt AS LPSTR, periodID AS LPSTR, pte AS LPSTR, @periodInfo AS LPSTR ) AS BOOL FROM "Fusion" LIB "FusionClass.dll"
La puse y tambien la saque para probar si era por esto o no, como esto probe de todo, no es que lo estoy usando porque estoy seguro que sea asi, probe de muchas formas.
Las otras funciones que si andan no necesite declarar nada solo las uso, las que no me funcionan son las que se debe pasar el parametro como referencia para que llegue con info.
La clase que uso y que esta dentro de la dll se llama FUSION y la defino asi en el prg que copie pero te lo resumo aca abajo

Static Controlador

Controlador := CreateObject("Fusion")
Controlador:Connection("&_IPCem") // ACA CONECTO CON EL CONTROLADOR FUSION, ESTO FUNCIONA BIEN
SiRet := Controlador:PeriodSalesByGrade(Type, Pid, "", @Message) // ACA ES DONDE LA VAR MESSAGE DEBERIA CARGARSE CON LA INFO DE RETORNO

Segun la documentacion, a mi entender, deberia usarse asi.

En la documentacion hay un ejemplo en VB de una de las tantas funciones que se pasa parametro por referencia, en principio probe eso mismo pero tampoco funciono, te copio el ejemplo porque quizas hay algo que no estoy viendo.

/// EJEMPLO EN VB ///
'PumpStatus()
Private Sub btn_PumpStatus_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btn_PumpStatus.Click
Dim c_Fusion As New FusionClass.Fusion()
c_Fusion.Connection(FusionIP.Text)
Dim Status As String
Dim SubStatus As String
Status = ""
SubStatus = ""
c_Fusion.PumpStatus(Int(c_PumpNr.Text), Status, SubStatus)
If (Status = "") Then
txt_CommandReturn.Text = "No status from pump " + c_PumpNr.Text
End If
End Sub
//////////////////////

/// LO QUE LA DOCUMENTACION INFORMA DE LA FUNCION PumpStatus() ///
◆ Fusion::PumpStatus()
int FusionClass::Fusion::Fusion::PumpStatus ( int p_iPump,
String^ % p_strStatus,
String^ % p_strSubStatus
)

Gets pump status.

Parameters
p_iPump Pump number
p_strStatus Pump status
p_strSubStatus Pump substatus

Returns
1 if operation is successful
/////////////////////////////////////////////////////////////////
Post Reply