Page 2 sur 26

Publié : dim. 07/déc./2008 12:44
par Backup
tu chaume pas dis donc :)

Publié : dim. 07/déc./2008 14:28
par Progi1984
Disons que l'organisation permet d'avancer facilement. Contrairement à Tailbite où l'organisation du code de celui ci est d'une horreur incompréhensible !

Publié : mar. 09/déc./2008 23:14
par Progi1984
Demain, release de la 0.4 :

Code : Tout sélectionner

    * ADDED : Global variables
    * ADDED : Used Userlibs
    * ADDED : End Function like the Init 

    * IMPROVED : Sample Total Interface 

    * DONE : Tests with all Samples
Et aprés (demain, lol) je m'attaque à la 0.5 :

Code : Tout sélectionner

    * TO ADD : Parameter with default value
    * TO ADD : Parameter with type : linked list
    * TO ADD : Parameter with type : tables 

    * TO IMPROVE : Deleting of content of directories (!now : Deleting recursively main directory)
    * TO IMPROVE : Clearing ASM Codes (a lot of newlines)
    * TO IMPROVE : Step 2 : in first function, moving asm detection code to second function 

    * TO DO : Tests with all Samples 

Publié : mer. 10/déc./2008 7:58
par Progi1984
Et voilà, vous pouvez la télécharger ici : http://code.google.com/p/moebius-pb/downloads/list

Publié : mer. 10/déc./2008 8:04
par Backup
Merci :)

Publié : mer. 10/déc./2008 10:34
par poshu
M'enfin! Arrête de bosser! Tu vas tous nous faire passer pour des gros glandeurs!

Merci et bravo ~

Publié : mer. 10/déc./2008 20:05
par Progi1984
Merci à tous les deux... Avec un peu de chance, peut etre la v 0.5 d'ici une semaine...

Publié : mer. 10/déc./2008 21:17
par Anonyme2
Je n'ai pas encore testé, peut-être demain.

Sinon, avec Tailbite j'ai un plantage du compilateur car j'utilise FreeImage et j'ai un message du compilateur qui me dit qu'il ne trouve pas la dll alors qu'elle est là.

Tu pourrais faire des tests avec un code qui utilise une dll pour voir.

A+

Publié : mer. 10/déc./2008 23:49
par Progi1984
Ajouté à la RoadMap pour la 0.9 : http://code.google.com/p/moebius-pb/wik ... estone_0.9

N'hésitez pas à poster vos idées !

Publié : jeu. 11/déc./2008 20:26
par Progi1984
Salut à tous, j'ai intégré la détection des listes chainées en paramètres. 30 minutes de coding et ca fonctionnait sur les deux systèmes...

Par contre, tite question, j'ai intégré la détection des tableaux en paramètre. Mais ca ne marche pas. Tite question aux codeurs ASM (et surtout à Denis), avez vous fait un peu de code de ce genre ?

Car là, ca plante mais sans pistes, j'ai cherché dans l'ASM mais sans résultat. Et comme Tailbite n'intègre pas les tableaux en paramètre, je n'y arrive pas :p

Publié : jeu. 11/déc./2008 21:01
par Anonyme2
Non je n'ai pas regardé le passage des tableaux en paramètre en asm.

Je ne sais pas si j'aurais le temps ces jours-ci mais je vais essayer de regarder .

Publié : jeu. 11/déc./2008 21:33
par Progi1984
Souhaites tu que je te fasse un package du code où j'en suis ?

Publié : jeu. 11/déc./2008 21:48
par Anonyme2
Oui pour le package.

J'ai fait un code PB avec un tableau à une dimension et j'ai regardé le code asm .

Je n'ai pas vu de difficulté particulière pour le code asm

Il y a la procedure comme d'habitude et PB réserve dans ce cas 2 long dans la datasection, je suppose que c'est la référence au pointeur de base et l'autre à la dimension du tableau

A partir du code PB suivant

Code : Tout sélectionner

 Procedure fill(A.l(1), longueur)  ; Le 1 représente le nombre de dimensions du tableau
      For i = 0 To longueur
           A(i) = i
      Next i
 EndProcedure
 
 Dim A.l(10)
 fill(A(), 10)  ; Le tableau A() est passé en paramètre
j'ai le code asm suivant

Code : Tout sélectionner

; 
; PureBasic 4.30 Beta 5 (Windows - x86) generated code
; 
; (c) 2008 Fantaisie Software
; 
; The header must remain intact for Re-Assembly
; 
; :System
; KERNEL32
; :Import
; 
format MS COFF
; 
extrn _ExitProcess@4
extrn _GetModuleHandleA@4
extrn _HeapCreate@12
extrn _HeapDestroy@4
; 
extrn _memset
extrn SYS_FreeArray
extrn SYS_AllocateArray
public _PB_Instance
public _PB_ExecutableType
public _PB_MemoryBase
public PB_Instance
public PB_MemoryBase
public _PB_EndFunctions

macro pb_public symbol
{
  public  _#symbol
  public symbol
_#symbol:
symbol:
}

macro    pb_align value { rb (value-1) - ($-_PB_DataSection + value-1) mod value }
macro pb_bssalign value { rb (value-1) - ($-_PB_BSSSection  + value-1) mod value }
public PureBasicStart
; 
section '.code' code readable executable
; 
; 
PureBasicStart:
; 
  PUSH   dword I_BSSEnd-I_BSSStart
  PUSH   dword 0
  PUSH   dword I_BSSStart
  CALL  _memset
  ADD    esp,12
  PUSH   dword 0
  CALL  _GetModuleHandleA@4
  MOV    [_PB_Instance],eax
  PUSH   dword 0
  PUSH   dword 4096
  PUSH   dword 0
  CALL  _HeapCreate@12
  MOV    [PB_MemoryBase],eax
; :
;  Dim MonTableau.l(41)
;   MonTableau(0) = 1
;   MonTableau(1) = 2 
; 
; 
; Procedure fill(A.l(1), longueur)  ; Le 1 représente le nombre de dimensions du tableau
macro MP0{
_Procedure0:
  PUSH   ebp
  PUSH   ebx
  PS0=20
  XOR    eax,eax
  PUSH   eax
  PUSH   eax                                                                                                                                                                                              
  MOV    eax,dword [esp+PS0+0]
  MOV    dword [esp+0],eax
; For i = 0 To longueur
  MOV    dword [esp+4],0
_For1:
  MOV    eax,dword [esp+PS0+4]
  CMP    eax,dword [esp+4]
  JL    _Next2
; A(i) = i
  PUSH   dword [esp+4]
  MOV    ebx,dword [esp+8]
  MOV    edx,[esp+4]
  MOV    ebp,dword [edx]
  SAL    ebx,2
  POP    eax
  MOV    dword [ebp+ebx],eax
; Next i
_NextContinue2:
  INC    dword [esp+4]
  JMP   _For1
_Next2:
; EndProcedure
  XOR    eax,eax
_EndProcedure1:
  ADD    esp,8
  POP    ebx
  POP    ebp
  RET    8
}
; 
; Dim A.l(10)
  PUSH   dword 5
  PUSH   dword a_A
  PUSH   dword 0
  MOV    edx,dword [a_A]
  CALL   SYS_FreeArray
  MOV    eax,11
  PUSH   dword 4
  CALL   SYS_AllocateArray
; fill(A(), 10)  ; Le tableau A() est passé en paramètre
  PUSH   dword 10
  PUSH   dword a_A
  CALL  _Procedure0
; 
; 
_PB_EOP_NoValue:
  PUSH   dword 0
_PB_EOP:
  CALL  _PB_EndFunctions
  PUSH   dword [PB_MemoryBase]
  CALL  _HeapDestroy@4
  CALL  _ExitProcess@4
_PB_EndFunctions:
  RET
; 
MP0
; 
section '.data' data readable writeable
; 
_PB_DataSection:
pb_public PB_DEBUGGER_LineNumber
  dd     -1
pb_public PB_DEBUGGER_IncludedFiles
  dd     0
pb_public PB_DEBUGGER_FileName
  db     0
_PB_ExecutableType: dd 0
align 4
align 4
s_s:
  dd     0
  dd     -1
align 4
; 
section '.bss' readable writeable
_PB_BSSSection:
align 4
; 
I_BSSStart:
_PB_MemoryBase:
PB_MemoryBase: rd 1
_PB_Instance:
PB_Instance: rd 1
; 
align 4
PB_DataPointer rd 1
align 4
align 4
align 4
align 4
a_A:
  rd     1
  rd     1
I_BSSEnd:
section '.data' data readable writeable
SYS_EndDataSection:

Les parties qui nous intéressent sont les suivantes :

La datasection avec la déclaration du tableau qui dans le code PB s'appelle A

PB ajoute un a_ avant le nom du tableau pour obtenir la ref au tableau
a_A. Normalement ton code récupère toute les sections et en fait un fichier asm, donc il ne doit pas y avoir de problème particulier

Code : Tout sélectionner

section '.bss' readable writeable
_PB_BSSSection:
align 4
; 
I_BSSStart:
_PB_MemoryBase:
PB_MemoryBase: rd 1
_PB_Instance:
PB_Instance: rd 1
; 
align 4
PB_DataPointer rd 1
align 4
align 4
align 4
align 4
a_A:          <-- c'est ici
  rd     1    <-- c'est ici
  rd     1    <-- c'est ici
I_BSSEnd:
section '.data' data readable writeable
SYS_EndDataSection:
Et la procedure sans tout le reste (ce qu'on a pas besoin) c'est

Code : Tout sélectionner

; Procedure fill(A.l(1), longueur)  ; Le 1 représente le nombre de dimensions du tableau
macro MP0{
_Procedure0:
  PUSH   ebp
  PUSH   ebx
  PS0=20
  XOR    eax,eax
  PUSH   eax
  PUSH   eax                                                                                                                                                                                              
  MOV    eax,dword [esp+PS0+0]
  MOV    dword [esp+0],eax
; For i = 0 To longueur
  MOV    dword [esp+4],0
_For1:
  MOV    eax,dword [esp+PS0+4]
  CMP    eax,dword [esp+4]
  JL    _Next2
; A(i) = i
  PUSH   dword [esp+4]
  MOV    ebx,dword [esp+8]
  MOV    edx,[esp+4]
  MOV    ebp,dword [edx]
  SAL    ebx,2
  POP    eax
  MOV    dword [ebp+ebx],eax
; Next i
_NextContinue2:
  INC    dword [esp+4]
  JMP   _For1
_Next2:
; EndProcedure
  XOR    eax,eax
_EndProcedure1:
  ADD    esp,8
  POP    ebx
  POP    ebp
  RET    8
}
Il y a aussi les déclarations suivantes propres au tableau qu'il faut inclure

extrn SYS_FreeArray
extrn SYS_AllocateArray




Je regarderais peut-être demain pour plusieurs dimensions, mais c'est surement la même chose avec plusieurs long en fonctions du nombre de dimensions.

A+

Publié : jeu. 11/déc./2008 21:55
par Progi1984
Tiens, ptite info :

a_ correspond aux tableaux (alias arrays)
_S correspond aux chaines (alias strings)
Y en a t il d'autres ? Où pourrais je avoir l'information ?

Publié : jeu. 11/déc./2008 21:59
par Anonyme2
Peut-être dans le fichier SDK de PB sur les librairies

Je pense qu'il faudrait faire un code avec les tableaux qui utilisent toutes les commandes pour voir si PB utilisent d'autres déclarations propres au tableau (comme extrn SYS_FreeArray, extrn SYS_AllocateArray)

Le fichier d'aide de PB dit ceci
- Il est possible de passer directement une ligne complète à l'assembleur sans aucune modification en utilisant le caractère '!' en début de ligne. Ceci permet d'avoir un accès total aux fonctionnalités de l'assembleur. Pour faciliter l'accès aux variables locales, une notation a été mise en place: 'p.v_NomVariable' pour une variable standard et 'p.p_NomPointeur' pour un pointeur.
Exemple:

Procedure Test(*Pointer, Variable)
! MOV dword [p.p_Pointer], 20
! MOV dword [p.v_Variable], 30
Debug *Pointer
Debug Variable
EndProcedure