FORUM DE DISCUSSION SUR LE LANGAGE PANORAMIC

Développement d'applications avec le langage Panoramic
 
AccueilAccueil  FAQFAQ  RechercherRechercher  S'enregistrerS'enregistrer  MembresMembres  GroupesGroupes  Connexion  
Derniers sujets
» Une autre façon de terminer une application.
par Francis-mr Aujourd'hui à 12:07

» Compilateur FBPano
par jean_debord Aujourd'hui à 10:09

» Copier / coller du texte à partir de la fenêtre de commandes
par jean_debord Aujourd'hui à 9:46

» COMPILATEUR V 0.9 beta 8 du 18 aout 2017
par papydall Aujourd'hui à 5:01

» Mettre en windows en veille
par papydall Aujourd'hui à 4:15

» Stretch_on ne stretch plus...
par papydall Hier à 15:22

» Pb 18 (en analyse): RESTORE_LABEL avec DATA à la fin
par Jack Hier à 13:21

» Problème de traitement des opérateurs avec le compilateur.
par Pedro Alvarez Sam 19 Aoû 2017 - 20:01

» Pb 17 (résolu): ITEM_SELECT ne fonctionne pas
par Jack Jeu 17 Aoû 2017 - 19:26

» un nouveau editeur panobasic
par Jean Claude Jeu 17 Aoû 2017 - 10:18

» Le compilateur.
par Pedro Alvarez Jeu 17 Aoû 2017 - 8:36

» Pb 16 (résolu): ON_CLOSE plante à l'exécution
par Jack Mer 16 Aoû 2017 - 20:00

» Pb 15 (résolu): TIMER_ON plante à l'exécution
par Jack Mer 16 Aoû 2017 - 19:58

» KGF_dll - nouvelles versions
par Yannick Dim 13 Aoû 2017 - 17:35

» probleme d'outil
par Yannick Dim 13 Aoû 2017 - 17:32

Navigation
 Portail
 Index
 Membres
 Profil
 FAQ
 Rechercher
Rechercher
 
 

Résultats par :
 
Rechercher Recherche avancée
Août 2017
LunMarMerJeuVenSamDim
 123456
78910111213
14151617181920
21222324252627
28293031   
CalendrierCalendrier

Partagez | 
 

 Mes aventures avec ISAM et Panoramic

Voir le sujet précédent Voir le sujet suivant Aller en bas 
AuteurMessage
Yannick

avatar

Nombre de messages : 7975
Age : 46
Localisation : Bretagne
Date d'inscription : 15/02/2010

MessageSujet: Mes aventures avec ISAM et Panoramic   Mer 12 Aoû 2015 - 19:22

Comme je voulais révolutionner l' appli pour le mag sur la base d' une base de données ISAM,
il m' a fallu faire une appli pour créer les fichiers database à utiliser avec PLM l' appli.
Le dossier est sur mon webdav mais voilà ce que cela donne en code :

Code:
Hide 0
Variables()
Labels()
Init()
Gui()
Show 0

Recherche_des_articles()
Creation_des_fichiers()
Creation_des_fiches()
Message "Base Créée !"
Quitter()

End

' +++ DECLARATION DES VARIABLES +++

SUB Variables()
   dim_local i%
'  adresses de dossiers

   dim Path$    : Path$    = dir_current$
   if right$(path$,1)="" : path$ = left$(path$,len(path$)-1) : end_if
   path$ = path$+""
  
   dim dir_Art$ : dir_Art$ = "C:\Users\Yannick\PLM_le_site\Articles"
   dim dir_dll$ : dir_dll$ = "C:\KGF"
'  adresses dll
   dim kgf$ : kgf$ = dir_dll$+"KGF.dll"
'  database
   dim support$
   dim ISAM_vers$
   dim ISAM_IdentSize%
   dim ISAM_id%
   dim ISAM_nam$
   dim ISAM_exist%
   dim ISAM_RecLen%
   dim ISAM_Record$
   dim ISAM_NbRec%
   dim inbase%
   dim keyinbase%
'  événements
   dim num_clic%
   dim num_dclic%
   dim num_change%
'  objets
   dim no%
   dim frame%     : no%=no%+1 : frame% =no%
   dim alph1%     : no%=no%+1 : alph1% =no%
   dim Pbar%      : no%=no%+1 : Pbar%  =no%
   dim liste%     : no%=no%+1 : liste% =no%
END_SUB

' +++ DECLARATION DES LABELS +++

SUB Labels()
   Label Clic
   Label DClic
   Label Change
END_SUB

' +++ INITIALISATIONS +++

SUB Init()
   dim_local version%,kgf_vers$,res%,i%,url$,fic$
  
'  activation de la dll
   if dir_exists(dir_dll$)=1
      dll_on kgf$
      kgf_vers$=string$(25," ")
      version% = DLL_call1("KGFdllVersion",adr(kgf_vers$))
      ' message trim$(kgf_vers$)
   else
      i% = Message_information_yes_no("Le dossier ''C:\KGF'' n' a pas été trouvé."+chr$(13)+"Voulez vous le télécharger maintenant ?...")
      if i%<>1
         dir_make dir_dll$
'        fonction à définir
      else
         res% = dll_call1("KillProcessByHandle",handle(0))
      end_if
   end_if
  
'  initialisation de l' environnement isam
   res% = dll_call0("InitIsam")
   ISAM_vers$ = string$(25," ")
   res% = dll_call1("GetIsamVersion",adr(ISAM_vers$))
   ' message trim$(ISAM_vers$)
END_SUB

' +++ INTERFACE UTILISATEUR +++

SUB Gui()

   height 0,100
   width 0,600
   top 0,(screen_y-height(0))/2
   left 0,(screen_x-width(0))/2
   font_name 0,"arial"
   font_size 0,8
   caption 0,""
  
   Panel frame%
   full_space frame%

   alpha alph1%
   parent alph1%,frame%
   top alph1%,15
   left alph1%,15
   font_color alph1%,0,0,200
  
   Progress_bar Pbar%
   hide Pbar%
   parent Pbar%,frame%
   width Pbar%,width(frame%)-30
   top Pbar%,30
   left Pbar%,15
  
   dlist liste%
  
END_SUB

' +++ MENUS +++

Clic:
   num_clic% = number_click
return

DClic:
   num_dclic% = number_double_click
return

Change:
   num_change% = number_change
return

' +++ FONCTIONS ET PROCEDURES +++

SUB Recherche_des_articles()
   dim_local i%,a$,fic$

   caption 0,"PLM Appli - Data Créator  [ Recherche des articles ]"
   caption alph1%,"0 Articles trouvés..."

   dir_change dir_Art$
   a$=file_find_first$
   a$=file_find_next$
   while a$<>"_"
      if upper$(file_extract_extension$(a$))=".PDF"
         fic$=file_extract_name$(a$)
         if left$(fic$,3)="art"
            item_add liste%,fic$
            i%=i%+1
            caption alph1%,str$(i%)+" Articles trouvés..."
         end_if
      end_if
      a$=file_find_next$
      wait 200
   end_while
   file_find_close
   dir_change Path$
END_SUB

' ------------------------------------------------------------------------------

SUB Creation_des_fichiers()
   dim_local i%,def$,res%,defkey$,court$

   caption 0,"PLM Appli - Data Créator  [ Création de la base données ]"
   caption alph1%,"Création des fichiers "+chr$(13)+"- PLM_appli.IX"+chr$(13)+"- PLM_appli.DAT"

'  création de l' identifiant isam
   ISAM_IdentSize% = dll_call0("GetIsamIdentifierSize")
   support$ = string$(ISAM_IdentSize%," ")
   ISAM_id% = dll_call1("CreateIsamIdentifier",adr(support$))

'  vérif de l' existence de la base ou pas
   ISAM_nam$ ="PLM_appli"
   ISAM_exist% = dll_call1("IsamFileExists",adr(ISAM_nam$))

   if ISAM_exist% =0
      file_delete Path$+"Fic\PLM_appli.IX"
      file_delete Path$+"Fic\PLM_appli.DAT"
   end_if

'  création des champs
   def$ ="6,6,4,20,20,60,110"
   res% = dll_call2("SetIsamFields",Isam_ID%,adr(def$))

'  création des cles
'  par ID / numero d article
   defkey$ ="1,1,1"
   res% = dll_call2("SetIsamKeyFields",Isam_ID%,adr(defkey$))
   res% = dll_call0("GetIsamOk")
   if res%<0 : MessageErreur(res%) : end_if
'  Par Mag
   defkey$ ="2,0,2"
   res% = dll_call2("SetIsamKeyFields",Isam_ID%,adr(defkey$))
   res% = dll_call0("GetIsamOk")
   if res%<0 : MessageErreur(res%) : end_if
'  Par Sujet
   defkey$ ="3,0,3"
   res% = dll_call2("SetIsamKeyFields",Isam_ID%,adr(defkey$))
   res% = dll_call0("GetIsamOk")
   if res%<0 : MessageErreur(res%) : end_if
'  Par Auteur
   defkey$ ="4,0,4"
   res% = dll_call2("SetIsamKeyFields",Isam_ID%,adr(defkey$))
   res% = dll_call0("GetIsamOk")
   if res%<0 : MessageErreur(res%) : end_if

'  Création des fichiers ISAM
   dir_change Path$+"\Fic"
   res% = dll_call2("CreateIsamFile",Isam_ID%,adr(ISAM_nam$))
'   message str$(res%)

'  recup de la longueur d' un enregistrement
   ISAM_RecLen% = dll_call1("GetIsamRecordLength",Isam_ID%)
   ISAM_record$ = string$(ISAM_RecLen%," ")

'  recup du nombre d' enregistrements dans la base
   inbase% = dll_call1("GetIsamRecordCount",Isam_ID%)

'  recup du nombre de clés
   keyinbase% = dll_call1("GetIsamKeyCount",Isam_ID%)

END_SUB

' ------------------------------------------------------------------------------

SUB Creation_des_fiches()
   dim_local i%,a$,id$,mag$,rub$,aut$,art$,res%,url$,sf$,err%

   show Pbar%
   min Pbar%,0
   max Pbar%,count(liste%)
   position Pbar%,0
   caption 0,"PLM Appli - Data Créator  [ Création des fiches ]"

   res% = dll_call1("IsamFileIsOpen",Isam_ID%)
   if res%<0
       message "Le fichier ISAM est fermé !"
       exit_sub
   end_if

   for i% = 1 to count(liste%)
      position Pbar%,Position(Pbar%)+1
      caption alph1%,"Création de la fiche : "+str$(inbase%+1)+" / "+str$(count(liste%))
      display
      a$=item_read$(liste%,i%)
      id$=left$(a$,6)
      mag$=mid$(a$,7,4)
      rub$=mid$(a$,11,20) : remplace_caractere(rub$,"_"," ") : rub$=retour$ : rub$=trim$(rub$)
      aut$=mid$(a$,31,20) : remplace_caractere(aut$,"_"," ") : aut$=retour$ : aut$=trim$(aut$)
      art$=mid$(a$,51,60) : remplace_caractere(art$,"_"," ") : art$=retour$ : art$=trim$(art$)
      url$=a$
      ISAM_record$ = string$(ISAM_RecLen%," ")
      sf$ =" "
      res% = dll_call6("FillIsamField",Isam_ID%,1,1,adr(ISAM_Record$),adr(id$),adr(sf$))
      res% = dll_call6("FillIsamField",Isam_ID%,2,0,adr(ISAM_Record$),adr(mag$),adr(sf$))
      res% = dll_call6("FillIsamField",Isam_ID%,3,0,adr(ISAM_Record$),adr(rub$),adr(sf$))
      res% = dll_call6("FillIsamField",Isam_ID%,4,0,adr(ISAM_Record$),adr(aut$),adr(sf$))
      res% = dll_call6("FillIsamField",Isam_ID%,5,0,adr(ISAM_Record$),adr(art$),adr(sf$))
      res% = dll_call6("FillIsamField",Isam_ID%,6,0,adr(ISAM_Record$),adr(url$),adr(sf$))
      pause 100
      res% = dll_call2("AddIsamRecord",Isam_ID%,adr(ISAM_Record$))
      if res%<0
          err% = dll_call0("GetIsamError")
          message "Erreur en création "+str$(res%)+": "+str$(err%)
          exit_sub
      else
          inbase% = dll_call1("GetIsamRecordCount",Isam_ID%)
      end_if
   next i%
END_SUB

' ------------------------------------------------------------------------------

SUB Quitter()
  dim_local fin%
  fin% = dll_call1("CloseIsamFile",Isam_ID%)
  wait 100
  fin% = dll_call0("FreeIsam")
  wait 100
  fin% = dll_call1("KillProcessByHandle",handle(0))
END_SUB

' ------------------------------------------------------------------------------

SUB MessageErreur(e%)
  dim_local a$,i%
  i%=e%*-1
  select i%
  case 1 : a$="[1] La chaîne de définition es incohérente"
  case 2 : a$="[2] Le numéro de la clé est non numérique"
  case 3 : a$="[3] Le nombre de clés est invalide (<1 ou >(nombre de clés)+1))"
  case 4 : a$="[4] Le flag ''pas de doublons'' est non numérique"
  case 5 : a$="[5] Un numéro de champ est non numérique"
  case 6 : a$="[6] Un numéro de champ est invalide (<1 ou >(nombre de champ))"
  case 7 : a$="[7] Clé > 30 caractères"
  end_select
  message str$(res%)+chr$(13)+a$
END_SUB

' ------------------------------------------------------------------------------

SUB remplace_caractere(texte$,char_indesirable$,char_subsitution$)
    dim_local l% : l% = len(texte$)
    dim_local chaine$(l%),i%
    if variable ("retour$") = 0 then dim retour$
    retour$ = ""
    for i% = 1 to l%
       chaine$(i%)= mid$(texte$,i%,1)
       if chaine$(i%) = char_indesirable$  then  chaine$(i%) = char_subsitution$
    next i%
    for i% = 1 to l%
       retour$ = retour$+chaine$(i%)
    next i%
END_SUB

La suite, c' est "PLM l' appli" dans le prochain post...soyez patient. Laughing
Revenir en haut Aller en bas
Voir le profil de l'utilisateur
Yannick

avatar

Nombre de messages : 7975
Age : 46
Localisation : Bretagne
Date d'inscription : 15/02/2010

MessageSujet: re   Mar 18 Aoû 2015 - 4:57

J' ai revu, encore une fois Rolling Eyes , mon outils.
j' ai mis sur mon webdav le dossier "PLM DataBase.zip".
Revenir en haut Aller en bas
Voir le profil de l'utilisateur
Yannick

avatar

Nombre de messages : 7975
Age : 46
Localisation : Bretagne
Date d'inscription : 15/02/2010

MessageSujet: re   Mer 19 Aoû 2015 - 0:00

J' ai actualisé le zip sur mon webdav "Projet PLM DataBase.zip".
Est ce qu' un utilisateur d' une autre version de windows que la 10
pourrait me dire si le curseur change sur la toolbar ?
Revenir en haut Aller en bas
Voir le profil de l'utilisateur
Jicehel

avatar

Nombre de messages : 5849
Age : 45
Localisation : 77500
Date d'inscription : 19/04/2011

MessageSujet: Re: Mes aventures avec ISAM et Panoramic   Mer 19 Aoû 2015 - 0:47

ici la connexion est trop lente... j'évite les téléchargement jusqu'à mon retour sur Paris ... Désolé
Revenir en haut Aller en bas
Voir le profil de l'utilisateur
Contenu sponsorisé




MessageSujet: Re: Mes aventures avec ISAM et Panoramic   

Revenir en haut Aller en bas
 
Mes aventures avec ISAM et Panoramic
Voir le sujet précédent Voir le sujet suivant Revenir en haut 
Page 1 sur 1
 Sujets similaires
-
» Liste des mots-clé de Panoramic avec leur classification
» Problème avec ASC(a$)
» Programmes Panoramic en ligne de commande
» Un exemple de gestion d'un sprite vaisseau avec panoramic
» j ai des souci , je debute depuis ce jour avec linux fedora

Permission de ce forum:Vous ne pouvez pas répondre aux sujets dans ce forum
FORUM DE DISCUSSION SUR LE LANGAGE PANORAMIC :: PANORAMIC 32 bits :: Vos sources, vos utilitaires à partager-
Sauter vers: