SPACKER

From AtariForumWiki
Revision as of 07:39, 12 October 2011 by >Wongck
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search
                          S P A C K E R III                               |
               (c) octobre 1992 - A FIREHAWKS Utility                     |
                    FREEWARE !!! librement copiable                       |
                           Code by Spiral.                                |
								          |
							                  |
Date de sortie : le 30 octobre 1992            				  |
                          						  |
									  |
                          ~~~~~~~~~~~~~~~~~~				  |
									  |
   - Spacker 3 est un compacteur de fichier Exe et data		          |
									  |
   - C'est aussi un archiveur trÅ s rapide				  |
									  |
   - Existera aussi sur Amiga (en cours), Falcon (version DSP),		  |
   		        Mac et IBM PC					  |
									  |
		          ~~~~~~~~~~~~~~~~~				  |
															
*** ATTENTION ***												
Le fichier  AUTO_SP3.PRG  est  un programme RESIDENT qui permet …
tout fichier compr‚ss‚ avec SPACKER3  de  se d‚compresser,il doit
par cons‚quent se trouver en premiŠre place dans le dossier AUTO.
Lors  du  chargement  automatique  du  r‚sident,  on  peut ne pas
l'activer  en  maintenant  la  touche  CONTROL  enfonc‚e.
*****************

                          ~~~~~~~~~~~~~~~~~~

 Les diff‚rentes fonctions sont class‚es par menu...

  * Menu 'FILE'
  -------------
                      ____
        NEW  FOLDER       |
        FORMAT DISK       |
        DISK   INFO       |        Disponibles uniquement avec un selecteur
        FILE   INFO       |------  du type de S‚l‚tric (Shareware) qui vous
        MOVE   FILE       |        est offert avec le Spacker 3
        COPY   FILE       |
        RENAME FILE       |
        DELETE FILE   ____|


   *Skip or Copy    ... Permet  de  passer ou copier  les fichiers qui
                        ne  peuvent  etre  pack‚es sur la destination.
    utilis‚  lors du compressage  de  plusieurs fichiers, il assure la
    copie (option Copy) sur  le  disque destination pour  les fichiers
    ne pouvant Štre compr‚ss‚s (taille originale trop petite ou taille
    compr‚ss‚e sup‚rieure … la taille originale).

   *Src A Dst A     ... D‚finit le lecteur Source et le lecteur destination

   *save Config     ... sauvegarde la configuration
                        Patch SPACKER3 en sauvegardant
    l'unit‚ (de disquette/disque) source, l'unit‚ destination,
    l'indicateur FILE PREF dans le menu FICHIER(C ou autre),
    la prise ou non en compte du dossier dans le menu ARCHIVE (P ou autre),
    l'indicateur flash et la couleur de flash dans le menu PACK
    (F ou autre, RGB).
    La config est en ASCII et … l'offset 28(entete)+2 de SPACKER3.

   *Create Auto SP3 ... Cr‚e le r‚sident indispensable pour le decrunch
                        des executables et des datas

   *touch SP3 files Date ... Correction de la date des fichiers compact‚es
   permet de rattacher la longueur originale d'un fichier compress‚
   avec SPACKER3 directement en ‚crasant la date et l'heure de
   cr‚ation/modification du fichier: seule solution restante pour
   ‚viter le cycle lent ouverture/lecture/fermeture de fichiers
   lors d'une selection de fichiers. La taille originale est utile
   … connaitre car elle permet de r‚server une taille m‚moire
   ‚gale au celle du fichier une fois d‚compress‚.
   L'attribut ARCHIVE est aussi utilis‚ pour les fichiers compress‚s
   par SPACKER3, il se conserve lors d'une copie de fichier, la
   date par contre change, d'o— l'int‚ret de cette fonction...

 * MENU 'OFFSET'
 ---------------

    un simple ‚diteur de fichiers Offset...Hum Hum..

   Les offsets permettent d'ajuster la structure de compression
   … la structure de chargement d'un type de fichier: une image
   DEGAS compress‚e en un seul bloc et charg‚e en plusieurs fois
   par un programme de dessin ne sera pas d‚compress‚e ou plantera
   le programme.

   Le module ESPION de structure de chargement est inclus dans le
   r‚sident, il faut recharger le r‚sident via le Gem et choisir
   l'option SPY OFF pour indiquer l'extension des fichiers …
   surveiller: une sauvegarde de la structure de chargement sera
   automatiquement effectu‚e (extension r‚serv‚e SPn ou n varie de
   0 … 9) lors de la fermeture du fichier (ne pas oublier de
   d‚prot‚ger la disquette).

   Ce fichier offset g‚n‚r‚ peut Štre ‚dit‚ et adapt‚ … un type
   standard de fichier (images DEGAS, fontes CALAMUS...).
   Les premiers octets de ce fichier offset contiennent l'extension.
   Un commentaire peut Štre rajout‚ par l'usage d'une tabulation ou
   d'un ';' (les lignes blanches ou commen‡ant par un ';' sont
   ignor‚es par l'‚diteur int‚gr‚ d'offsets dans SPACKER3).
   3 types de blocs dans un fichier sont … distinguer: le type
   MOVE (cod‚ par -) indique que le bloc ne sera pas compress‚
   dans le fichier r‚sultat de la compression, le type PACK (cod‚ +)
   pour compresser le bloc et le type PGFX (cod‚ *) pour compresser
   le bloc par algorithme graphique 4 plans.

   Toutes les longueurs de bloc doivent Å tre paires, seul le dernier
   bloc fait exception s'il est assign‚ du type MOVE (pour les fichiers
   de taille originale impaire). La description d'une ligne bloc du
   fichier offset est la suivante (les espaces entre caractÅ res et
   les tabulations sont g‚r‚s): 'type de bloc' + 'longueur de bloc',
   longueur HEXA sur 5 caractÅ res max, le total des longueurs HEXA
   ne doit pas d‚passer F423F soit 999999 octets. Les blocs de
   longueur nulle sont expressement interdits.

   voici quelques exemples:
   - 80  ; 128 octets … ne pas compresser (entete NEO)
        ; ligne de commentaires ignor‚e
   *07D00   ; ‚cran basse r‚solution compress‚ par algo. graphique

   Il est possible de standardiser tous les fichiers offsets d'un
   type de fichier en un seul fichier offset en incluant un bloc
   et un seul de longueur paire et variable: au lieu de la taille
   il suffit de saisir le mot cl‚ 'dummy' ou 'DUMMY' (ou mŠme
   'DuMMy' si vous pr‚f‚rez). Le bloc connaitra sa longueur au
   moment de la compression (taille originale du fichier moins
   tailles des autres blocs). Les fontes Calamus sont des fichiers
   charg‚s en 13 fois, 1 seul bloc parmi ces 13 blocs est variable
   et contient les data de la fonte: un seul fichier offset, livr‚
   avec SPACKER3, permet de g‚rer toutes les fontes. Ce principe
   expos‚ par l'exemple des fontes Calamus peut Štre appliqu‚ sur
   d'autres fichiers charg‚s en plusieurs fois (utilisez l'espion
   dans le r‚sident pour connaitre la structure de chargement).

   L'‚diteur d'offset de SPACKER3 permet d'adapter un fichier
   offset sans quitter le compresseur.
   L'extension indiqu‚ est changeable … tout moment.

   Touche ESPACE change le type de bloc: MOVE/PACK/PGFX
   Tab: entr‚e valeurs HEX (ou <-) / entr‚e valeurs DEC (ou ->)
   Up:pr‚c‚dent,Down:suivant,Shift+Up:1er,Shift+Down:dernier bloc
   Ins:insÅ re un bloc juste aprÅ s le bloc courant
   Del:d‚truit le bloc courant

   Variable correspond … la d‚finition du bloc courant en bloc de
   longueur variable (mot cl‚ DUMMY) pour avoir un fichier offset
   s'alignant sur la taille originale du fichier … compresser de
   mÅ me extension.

   Encore un plus! Si le fichier offset comprend les conditions
   suivantes alors il est d‚clar‚ '‚x‚cutable':
   - le premier bloc est de type MOVE et de taille ‚gale … 28 octets
   - il ne doit pas y avoir de blocs de type PACK
   - il doit y avoir au moins un bloc de type PGFX
   En clair, cel… signifie qu'il est possible de regrouper des blocs
   graphiques (sprites, images...) basse r‚solutions (4 plans, alignement
   8 octets) … l'int‚rieur d'un programme ex‚cutable et de compresser
   l'ensemble tout en exer‡ant l'algo. graphique sur les blocs PGFX:
   optimisation des performances de compression...

* Menu ARCHIVE :
--------------

   On peut constituer des programmes SFX (SelF-eXtracting) avec des
   fichiers compress‚s avec SPACKER3 ou pas, toutefois, il faut
   noter que les fichiers compress‚s en ‚x‚cutable,ressource,offset
   ne seront pas d‚compress‚s lors du d‚sarchivage, seuls les fichiers
   compress‚s en type DAT seront d‚compress‚s.
   
   

   - ADD FILE
   Les fichiers (contenu et location) sont ajout‚s … la liste
   des fichiers … archiver: un fichier qui n'est pas compress‚ en
   type DAT (utilisation de l'option FORCE DATA TYPE dans le menu
   PACK) est sujet … une boite d'alerte pour d‚terminer la poursuite
   du traitement (arret,passe,ajoute).

   Une fois le fichier SFX cr‚e par la fonction SAVE SP3 SFX, ce
   programme proposera ces fonctionnalit‚s:
   - possibilit‚ de d‚truire le SFX charg‚ pour regagner la place
   sur une disquette avant sauvegarde des fichiers contenus
   - restauration des dossiers (si option PATH ON)
   - en cas de manque de place sur disquette, possibilit‚ de
   changer de disquette pour finir le d‚sarchivage.

   L'ordre de sauvegarde est conditionn‚ par la taille de chacun des
   blocs: du plus petit (un fichier de longueur nulle peut Å tre dans
   la liste des fichiers SFX (fichier identificateur de volume)) au
   plus grand (pour b‚n‚ficier de toute la m‚moire).

* Menu UNPACK :
-------------

   Les fichiers compress‚s par SPACKER3 ou SPACKER2 sont reconnus
   quelquesoit le type de fichier.

   - LOAD UNPACKER

   Cette fonction permet de charger un d‚compresseur externe … SPACKER3
   et de b‚n‚ficier du d‚compressage en s‚rie des fichiers d'un dossier.
   Elle ne remplace pas l'utilisation d'un 'multi-depacker' qui
   reconnait de lui-mÅ me le format de compression.

   Un fichier d‚compresseur pour Štre charg‚ et appel‚ par SPACKER3 doit
   respecter la structure (trŠs complexe, une partie est … r‚diger en
   68000!) suivante:

   - octets 0 … 3: constante 'SPup'
   - octets 4 … 15: libre pour nommer le d‚compresseur

   remarques:
   . le mot cl‚ REL sera utilis‚ pour dire que l'offset est
   … prendre par rapport au d‚but de fichier (d‚but+28 pour un
   ex‚cutable) si l'offset est positif et, par rapport … la fin de
   fichier (fin de code hors infos de relocation pour un ex‚cutable).
   . tous les offsets doivent Štre pairs 5align‚s sur un mot m‚moire).

   struc donn‚es type fichier ex‚cutable:

   - octets 16 … 19: constante '.EXE'
   - octets 20 … 21: offset d'un identificateur facultatif
    (… 0 si octets 22 … 25 … 0)
   - octets 22 … 25: valeur de l'identificateur (ex: 'Ice!')
    (… 0 si octets 20 … 21 … 0)
   - octets 26 … 27: offset =>0 d‚but de la liste checksum (borne sup)
   - octets 28 … 29: offset >0 fin de la liste checksum (borne inf)
   - octets 30 … 31: r‚sultat du checksum: somme des mots compris entre
     les 2 offsets d‚finis pr‚c‚demment moins les ‚ventuels mots longs des
     adresses d‚finies par leurs offsets dans les 5 mots octets 32 … 41.
     Le checksum permet d'identifier un d‚compresseur et sa version.
   - octets 32 … 41: max 5 offsets d'adresses … retrancher du checksum
     (par adresse, il faut entendre 2 mots cons‚cutifs),ils doivent
     Å tre strictement compris entre les deux bornes.
     … 0 si tous les mots entre les 2 bornes sont utilis‚s pour le
     checksum.

   Ex: soit le code d'un fichier ex‚cutable comprenant un d‚compresseur
       de longueur 512 octets, d‚butant relativement par rapport au
       d‚but du fichier ex‚cutable … l'offset 28+64, les adresses
       28+80 et 28+112 contiennent des mots longs issus de la relocation
       du programme, il ne faut donc pas les compter dans le checksum
       ou alors faire d‚marrer le checksum aprŠs (changement de d‚but de
       liste checksum), cel… donne:
       '.EXE' 0000 00000000 0040 0240 87D4
       0050 0070 0000 0000 0000
       le checksum 87D4 est obtenu en ajoutant tous les mots entre
       le d‚but du fichier ex‚cutable non relog‚+28(entete)+64 et le
       d‚but+28+64+512 puis en retranchant les mots des offsets
       d‚but+28+80,d‚but+28+82,d‚but+28+112,d‚but+28+114.

   - octets 42 … 43: offset REL du bloc longueurs originale/compress‚e
    (octet 44 = -1) ou longueurs compress‚e/originale (octet 44 = 0)
   - octet 44: 0 ou -1 selon ordre du bloc longueurs
   - octet 45: valeur d'ajustement=0 si la longueur compress‚e contient
     la taille du bloc total ((identificateur+)longueurs+donn‚es)
     sinon = taille du bloc longueurs (=8 ou 12 si identificateur pr‚sent),
     ou = -1 si la longueur compress‚e n'est pas indiqu‚e dans le bloc
     longueurs mais dans le code du d‚compresseur:
     dans ce dernier cas, la longueur compress‚e est recalcul‚e … partir
     de l'entete de l'ex‚cutable (section text+data-offset du bloc des
     donn‚es compress‚es (valeur octets 46 … 47).
   - octets 46 … 47: offset du bloc total ((identificateur+)longueurs+
     donn‚es), si les donn‚es se trouvent en d‚but du bloc total, cet
     offset correspond alors … l'offset des donn‚es.

   struc donn‚es type fichier data:
   - octets 48 … 51: constante '.DAT'
   - octets 52 … 53: offset d'un identificateur OBLIGATOIRE
     (pas de routine de d‚compression permettant d'identifier la
     m‚thode de compression), … 0 si 1er mot long du fichier data
   - octets 54 … 57: valeur de l'identificateur (octet 54 toujours non nul)
   - octets 58 … 59: offset REL du bloc longueurs originale/compress‚e
     (octet 60 = -1) ou longueurs compress‚e/originale (octet 60 = 0)
   - octet 60: 0 ou -1 selon ordre du bloc longueurs
   - octet 61: valeur d'ajustement=0 si la longueur compress‚e contient
     la taille du fichier compress‚ (identificateur+longueurs+donn‚es)
    sinon = taille du bloc longueurs (=8 ou 12 si identificateur pr‚sent),
     ou = -1 si la longueur compress‚e n'est pas indiqu‚e.
   - octets 62 … 63: offset du fichier compress‚: g‚n‚ralement … 0, sauf
     s'il contient d'autres informations en entete.

   code d'appel de la routine de d‚compression  :
   - octets 64 … 127: non utilis‚s (possibilit‚ de s'en servir pour
    stocker les valeurs d'entr‚e et de sortie de la routine de
    d‚compression)
   - octets 128 … 255: code d'appel (le mot en 128 doit Štre non nul)
    sont charg‚s les registres A0:adresse du bloc total
                               D0:type de struc fichier:0=dat/-1=exe
   - octets 256 … ...: extrait d'un programme compress‚ contenant
     le d‚compresseur.

   … titre d'exemple, le code d'appel utilis‚ pour ATOMIK35.SP9:

code  lea   code-128(pc),a6      ;relativement octet 0
   move.l   a0,120(a6)     ;sauve adresse pour reloger
   tst.w d0       ;test type
   bne.s exe
dat   addq  #4,a0       ;aprÅ s identificateur
   move.l   (a0)+,d0    ;lit longueur originale
   move.l   d0,124(a6)     ;et sauve pour reloger

   jsr   256+202        ;sous-routine de d‚comp ATM5

   lea   code-128(pc),a6      ;relativement octet 0
   move.l   a5,a0       ;adresse bloc d‚compress‚
   move.l   120(a6),a1     ;r‚cupŠre adresse destination
   move.l   124(a6),d0     ;et longueur originale
deplace move.b (a0)+,(a1)+
   dbf   d0,deplace
   subi.l   #$10000,d0     ;toute la longueur originale
   rts

   Les autres fichiers d‚compresseurs (extension SPn) donn‚ avec
   SPACKER3 peuvent aider … comprendre la structure complexe mais
   flexible d'un module de d‚compression externe … SPACKER3.

* Menu PACK :
-----------
   - Optimize SEQ 2 EXTEND
     Option permettant de compresser les s‚quences de 2 octets
     identiques sur une ‚tendue de recherche plus grande: gains
     souvent appr‚ciables sur les fichiers de type samples.

   - Optimize LOW RES BLK
     Option permettant de compresser des fichiers graphiques (sprites,
     ‚crans...) en un bloc et par algoritme graphique 4 plans (basse
     r‚solution). Pour les images, il est pr‚f‚rable d'utiliser
     la compression via un fichier offset (pour pouvoir recharger
     directement par le programme de dessin).

   - FORCE DATA TYPE
     Compresse un ex‚cutable, ressource en fichier compress‚ en
     un bloc (DAT ou BLK si l'optimisation LOW RES BLK est activ‚e).
     cel… permet de cr‚er des fichiers compress‚s simples qui pourront
     Štre int‚gr‚s dans une archive SFX.

Les autres fonctionnalit‚s ne devraient pas poser problŠmes.

Enfin, nous ne sommes pas responsables des pertes ou dommages qui pourraient
apparaitre lors de l'utilisation du Spacker 3 et des problÅ mes lors du
d‚compactage subsistent encore sous Multidesk et Neodesk III.
Faites donc attention !

Vous pouvez nous joindre sur 3614 code TEASER
                          ou 3615 code Rtel, Bal Daneel

Nous remer‡ions … l'avance les personnes qui diffuseront ce packer dans
le monde entier.

Un grand merci … STE59, STOF, DMVIOLATOR pour leurs encouragements.

Ceci est un produit certifi‚ 100 % FIREHAWKS,
vous pouvez consommez sans mod‚ration...


Back to Packer/Depacker