Toggle menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

PZZ (Gotcha Force): Difference between revisions

No edit summary
No edit summary
Line 14: Line 14:
Le premier champs du header est un uint32 big endian contenant le nombre de fichiers total de l'archive. On retrouve après une suite de taille variable de descripteurs de fichiers au format uint32 big endian. Chaque fichier est paddé avec des "\x00" pour avoir une taille multiple de 0x800.
Le premier champs du header est un uint32 big endian contenant le nombre de fichiers total de l'archive. On retrouve après une suite de taille variable de descripteurs de fichiers au format uint32 big endian. Chaque fichier est paddé avec des "\x00" pour avoir une taille multiple de 0x800.


==== Format descripteur de fichier ====  
==== Format descripteur de fichier ====


Si on numérote les bits d'un descripteur de fichier de 0 (poids faible) à 31 (poids fort) :
Si on numérote les bits d'un descripteur de fichier de 0 (poids faible) à 31 (poids fort) :
Line 21: Line 21:
* bit 30 - Flag de compression : est à 1 si le fichier est compressé, 0 sinon,
* bit 30 - Flag de compression : est à 1 si le fichier est compressé, 0 sinon,
* bit 0 à 29 (30 bits) - taille du fichier divisée par 2048 (0x800),
* bit 0 à 29 (30 bits) - taille du fichier divisée par 2048 (0x800),
taille_fichier (octets) = (descripteur_fichier & 0x3FFFFFFF) * 0x800<br>
taille_fichier (octets) = (descripteur_fichier & 0x3FFFFFFF) * 0x800<br>
bCompression = descripteur_fichier & 0x40000000
bCompression = descripteur_fichier & 0x40000000
Line 31: Line 30:
Le descripteur de fichier peut décrire un fichier vide. Il correspondra alors à "00 00 00 00" mais sera compté dans le nombre de fichier au début du header.
Le descripteur de fichier peut décrire un fichier vide. Il correspondra alors à "00 00 00 00" mais sera compté dans le nombre de fichier au début du header.


Padding des fichiers
<span style="color: rgb(241, 196, 15);" >La question, c'est de savoir s'il faut enlever le padding des fichiers avec un flag de compression = 0, lorsqu'on les extrait du pzz.</span>
=== Algorithme de compression ===
=== Algorithme de compression ===
=== Observations ===
=== Observations ===
Line 36: Line 38:
Les fichiers PZZ contiennent entre autres des fichiers [[TPL (Format de fichier)|TPL]] affichant le nom des borgs dans différentes langues (version PAL), ou encore le nom des borgs en japonais (version JAP) ou en anglais (version NTSC).
Les fichiers PZZ contiennent entre autres des fichiers [[TPL (Format de fichier)|TPL]] affichant le nom des borgs dans différentes langues (version PAL), ou encore le nom des borgs en japonais (version JAP) ou en anglais (version NTSC).


<span style="color: olive;">Certains fichiers extraits des PZZ contiennent des indices sur un potentiel format d'animation 3D. <span style="color: #e03e2d;">&lt;- Attention, il faut citer les dits fichiers</span></span>
<span style="color: olive;"><span style="color: rgb(241, 196, 15);" >Certains fichiers extraits des PZZ contiennent des indices sur un potentiel format d'animation 3D.</span> <span style="color: #e03e2d;">&lt;- Attention, il faut citer les dits fichiers</span></span>


<span style="color: olive;">Dans le header des PZZ, on retrouve parfois des file_descriptor=NULL. On peut notamment citer "'''pl0f07.pzz'''" qui a un header se terminant par plusieurs descripteurs de fichiers NULL :</span>
<span style="color: rgb(241, 196, 15);" >Dans le header des PZZ, on retrouve parfois des file_descriptor=NULL. On peut notamment citer "'''pl0f07.pzz'''" qui a un header se terminant par plusieurs descripteurs de fichiers NULL :</span>
*<span style="color: olive;">Théorie 1 : On a une librairie parsant les PZZ qui utilise des pointeurs de fichiers et on initialise ces pointeurs à NULL quand les fichiers n'existent pas.<br></span>
*<span style="color: rgb(241, 196, 15);" >Théorie 1 : On a une librairie parsant les PZZ qui utilise des pointeurs de fichiers et on initialise ces pointeurs à NULL quand les fichiers n'existent pas.<br></span>
*<span style="color: olive;">Théorie 2 : On aurait des pointeurs sur des adresses absolues dans le DVD et les mises à jour auraient supprimé certains fichiers pour garder les mêmes adresses en augmentant la taille d'autres.</span>
*<span style="color: rgb(241, 196, 15);" >Théorie 2 : On aurait des pointeurs sur des adresses absolues dans le DVD et les mises à jour auraient supprimé certains fichiers pour garder les mêmes adresses en augmentant la taille d'autres.</span>
*<span style="color: olive;">Théorie 3 : Erreur de programmation des devs / ou reste de développements qui n'ont pas été implémentés / ou supprimés / cela peut résulter d'anciens fichiers en rapport avec la version bêta du jeu.</span>
*<span style="color: rgb(241, 196, 15);" >Théorie 3 : Erreur de programmation des devs / ou reste de développements qui n'ont pas été implémentés / ou supprimés / cela peut résulter d'anciens fichiers en rapport avec la version bêta du jeu.</span>


== Logiciel ==
== Logiciel ==

Revision as of 09:39, 16 November 2021

← Gotcha Force

Cet article est pour les format de fichiers PZZ de Gotcha Force. Voir PZZ (Format de fichier) pour les autres versions de ce fichier.

Les fichiers PZZ sont des dossiers d'archive.

Format

Les PZZ se composent d'un header de 2048 octets, soit 0x800 octets. A la suite de ce header se trouvent les fichiers inscrit les uns à la suite des autres. Ces fichiers peuvent être compressés ou non.

Header

Le premier champs du header est un uint32 big endian contenant le nombre de fichiers total de l'archive. On retrouve après une suite de taille variable de descripteurs de fichiers au format uint32 big endian. Chaque fichier est paddé avec des "\x00" pour avoir une taille multiple de 0x800.

Format descripteur de fichier

Si on numérote les bits d'un descripteur de fichier de 0 (poids faible) à 31 (poids fort) :

  • bit 31 - inutilisé,
  • bit 30 - Flag de compression : est à 1 si le fichier est compressé, 0 sinon,
  • bit 0 à 29 (30 bits) - taille du fichier divisée par 2048 (0x800),

taille_fichier (octets) = (descripteur_fichier & 0x3FFFFFFF) * 0x800
bCompression = descripteur_fichier & 0x40000000

Pour mieux comprendre le format du descripteur de fichier, voici un exemple :

Le premier fichier de l'archive fait 12288 octets et il est compressé, son descripteur est alors (12288/0x800)+0x40000000 = 0x40000006. On le stockera dans l'entête en big endian (40 00 00 06) juste à la suite du nombre de fichiers.

Le descripteur de fichier peut décrire un fichier vide. Il correspondra alors à "00 00 00 00" mais sera compté dans le nombre de fichier au début du header.

Padding des fichiers

La question, c'est de savoir s'il faut enlever le padding des fichiers avec un flag de compression = 0, lorsqu'on les extrait du pzz.

Algorithme de compression

Observations

Les fichiers PZZ contiennent entre autres des fichiers TPL affichant le nom des borgs dans différentes langues (version PAL), ou encore le nom des borgs en japonais (version JAP) ou en anglais (version NTSC).

Certains fichiers extraits des PZZ contiennent des indices sur un potentiel format d'animation 3D. <- Attention, il faut citer les dits fichiers

Dans le header des PZZ, on retrouve parfois des file_descriptor=NULL. On peut notamment citer "pl0f07.pzz" qui a un header se terminant par plusieurs descripteurs de fichiers NULL :

  • Théorie 1 : On a une librairie parsant les PZZ qui utilise des pointeurs de fichiers et on initialise ces pointeurs à NULL quand les fichiers n'existent pas.
  • Théorie 2 : On aurait des pointeurs sur des adresses absolues dans le DVD et les mises à jour auraient supprimé certains fichiers pour garder les mêmes adresses en augmentant la taille d'autres.
  • Théorie 3 : Erreur de programmation des devs / ou reste de développements qui n'ont pas été implémentés / ou supprimés / cela peut résulter d'anciens fichiers en rapport avec la version bêta du jeu.

Logiciel

Virtual World RE a développé le script python pzztool.py permettant de manipuler les archives PZZ et leurs fichiers internes, en s'inspirant d'un script de manipulation pzz de PS2.

Catégorie:Format de fichier Catégorie:Gotcha Force