Sindbad~EG File Manager
<!--
+---------------------------------------------------------------------------------------+
� 2002-2005 PMB Services / www.sigb.net pmb@sigb.net et contributeurs (voir www.sigb.net)
+---------------------------------------------------------------------------------------+
$Id: iso2709_class.html,v 1.5 2017/11/07 15:24:11 ngantier Exp $
-->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="fr">
<head>
<meta name="generator" content="HTML Tidy, see www.w3.org">
<title>
Classe ISO2709 pour le PHP
</title>
</head>
<body leftmargin='120' rightmargin='30'>
<h1>
Une classe PHP pour manipuler des enregistrements au format ISO2709
</h1>
<small>classe iso2709_record (public release 0.0.6)</small><br />
<i>par François Lemarchand. 2003</i> <a href="mailto:balno@users.sourceforge.net">balno@users.sourceforge.net</a>
<hr />
<p>
En préambule, je voudrais dédier ce travail à Hervé Le Crosnier. Au début des années 90, j'ai eu la chance de suivre un stage d'initiation à HTML assuré par lui. Il est plus que probable qu'il ne s'en souvienne pas, mais depuis ce stage, quand je mesure le chemin parcouru, je ne peux que dire merci Hervé, un grand MERCI.
</p>
<p>
La classe PHP dont il est question ici se pose deux objectifs : Dans un premier temps, il s'agit de lire des enregistrements ISO2709 afin de récupérer des informations. Dans un second temps, et pour être complétement efficiente, la classe devrait idéalement nous permettre de constituer de nouveaux enregistrements respectant ce format.
</p>
<h2>
Rappel sur le format ISO2709
</h2>
<p>
Le format d'échange ISO 2709 fournit une norme pour l'échange de données bibliographiques. Il offre une interface unifiée permettant la description d'enregistrements organisés en champs et sous-champs.
</p>
Ce format définit pour un enregistrement 3 zones :
<ul>
<li>
le <strong>guide</strong>
</li>
<li>
le <strong>répertoire</strong>
</li>
<li>
la <strong>zone des données</strong>
</li>
</ul>
<ul>
<li>
Le <strong>guide</strong> contient des informations sur la nature de l'enregistrement : le type de notice, le genre de document décrit, le statut de la notice, etc. Il contient aussi diverses informations sur la structure ISO 2709 de l'enregistrement : la longueur de l'enregistrement, la position dans l'enregistrement où se trouvent les données, etc. Ce guide est constitué d'une série de 24 caractères qui se décomposent ainsi
<ol>
<li>
caractères 0 à 4 : la longueur de l'enregistrement
</li>
<li>
caractère 5 : le statut de la notice bibliographique
</li>
<li>
caractère 6 : le type de document
</li>
<li>
caractère 7 : le type de la notice
</li>
<li>
caractère 8 : le niveau hiérarchique de la notice
</li>
<li>
caractère 9 : non-défini
</li>
<li>
caractère 10 : la longueur des indicateurs (2 en UNIMARC)
</li>
<li>
caractère 11 : la longueur du code de sous-zone (2 en UNIMARC)
</li>
<li>
caractères 12 à 16 : position dans l'enregistrement du début de la zone de données
</li>
<li>
caractère 17 : le niveau de catalogage
</li>
<li>
caractère 18 : la forme du catalogage descriptif
</li>
<li>
caractère 19 : non-défini
</li>
<li>
caractère 20 : le nombre de caractères du répertoire indiquant la longueur d'un champ (4 en UNIMARC)
</li>
<li>
caractère 21 : le nombre de caractères du répertoire indiquant la position d'un champ (5 en UNIMARC)
</li>
<li>
caractère 22 : le "nombre de caractères de la partie relative à l'application de chaque article du répertoire" (Je ne sais pas trop à quoi cela sert, c'est toujours 0 en UNIMARC)
</li>
<li>
caractère 23 : non-défini
</li>
</ol>
</li>
<li>
Le <strong>répertoire</strong> est une sorte de table des matières de l'enregistrement. Il contient pour chacun des champs de celui-ci le label du champ (sur 3 caractères), le nombre de caractères du champ (sur le nombre de caractères défini par la position 20 du guide) et la position du début du champ dans la zone de données (sur le nombre de caractères défini par la position 21 du guide). Prenons un exemple qui sera peut-être plus parlant. Pour le champ 001 d'un enregistrement qui compte 12 caractères on aura la mention suivante dans le répertoire : 001001200000. On peut décomposer cette mention ainsi : le label est sur trois caractères, c'est 001. La longueur du champ est sur 4 caractères : 0012. Enfin l'adresse du champ est sur 5 caractères : 00000. Celle-ci est fixée à 0 car c'est l'"offset", la position en nombre de caractères par rapport au début de la zone des données (le début de cette zone est défini dans les positions 12 à 16 du label). Pour accéder au contenu de ce champ, nous avons donc toutes les informations requises : sa longueur (second élément de son entrée dans la "table des matières"), son label, et l'endroit où il débute dans l'enregistrement (obtenu par l'addition de la position du début des données indiquée dans le guide et du troisième élément trouvé dans le répertoire).
</li>
<li>
La <strong>zone des données</strong> contient donc l'ensemble des champs de l'enregistrement mis bout à bout suivant l'ordre défini dans le <strong>répertoire</strong>. Dans ces champs, des caractères spéciaux sont utilisés pour marquer le début des sous-champs et la fin du champ (ces caractères sont inclus dans la longueur indiquée par le répertoire). Certains champs commencent par des indicateurs définis dans la norme UNIMARC ou autre. La fin de l'enregistrement lui-même est marquée par un caractère spécial.
</li>
</ul>
<p>
Comme on peut le voir, la structure d'un enregistrement au format ISO 2709 est assez simple une fois que l'on en a compris le principe. La manipulation de tels enregistrements se résume à des opérations élémentaires (décomposition de l'enregistrement, consultation de la "table des matières" pour accéder à un champ, etc.) La difficulté principale reste de maintenir la synchronisation entre les trois zones de l'enregistrement lors de l'insertion ou de la suppression de champs. La classe présentée ici à pour but d'accomplir ces accès et cette synchronisation de manière relativement transparente pour le programmeur.
</p>
<h2>
Propriétés
</h2>
<p>
Comme toute classe PHP, la classe iso2709_record comprend des propriétés qui peuvent être accédées par votre code. Certaines de ces propriétés sont utilisées pour la gestion interne de l'objet défini dans la classe.
</p>
<table border='1' cellpadding='3'>
<tr>
<th>
</th>
<th>
propriété
</th>
<th>
type
</th>
<th>
description
</th>
</tr>
<tr>
<td rowspan='4' style='vertical-align:middle'>
enregistrement ISO2709
</td>
<td>
full_record
</td>
<td>
string
</td>
<td>
enregistrement complet
</td>
</tr>
<tr>
<td>
guide
</td>
<td>
chaîne
</td>
<td>
portion 'guide'
</td>
</tr>
<tr>
<td>
directory
</td>
<td>
chaîne
</td>
<td>
portion 'répertoire'
</td>
</tr>
<tr>
<td>
data
</td>
<td>
chaîne
</td>
<td>
portion 'zone de données'
</td>
</tr>
<tr>
<td rowspan='3' style='vertical-align:middle'>
tableaux internes
</td>
<td>
inner_guide
</td>
<td>
tableau associatif
</td>
<td nowrap>
guide sous forme de tableau associatif
<br />
structure:
<br />
<code>$this->inner_guide = array(
<br />
rl => 'longueur de l'enregistrement (int)',
<br />
rs => 'état de la notice (1 car.)',
<br />
dt => 'type de document (1 car.)',
<br />
bl => 'type de la notice (1 car.)',
<br />
hl => 'niveau hiérarchique (1 car.)',
<br />
pos9 => 'indéfini. contient un espace',
<br />
il => 'longueur indicateurs (int)',
<br />
sl => 'longueur code sous-champ (int)',
<br />
ba => 'adresse de base des données (int)',
<br />
el => 'niveau de catalogage (1 car.)',
<br />
ru => 'forme du catal. descriptif (1 car.)',
<br />
pos19 => 'indéfini. contient un espace',
<br />
dm1 => 'infos pour le répertoires (toujours 4)',
<br />
dm2 => 'infos pour le répertoires (toujours 5)',
<br />
dm3 => 'infos pour le répertoires (toujours 0)',
<br />
pos23 => 'indéfini. contient un espace'
<br />
);</code>
</td>
</tr>
<tr>
<td>
inner_directory
</td>
<td>
tableau multi-dimensionnel
</td>
<td>
tableau correspondant au répertoire de l'enregistrement
<br />
structure:
<br />
<code>$this->inner_guide[x] = array(
<br />
label => 'label du champ de rang x (string)',
<br />
length => 'longueur du champ de rang x',
<br />
adress => 'offset du champ dans l'enregistrement'
<br />
);</code>
</td>
</tr>
<tr>
<td>
inner_data
</td>
<td>
tableau multi-dimensionnel
</td>
<td>
tableau correspondant au répertoire de l'enregistrement
<br />
structure:
<br />
<code>$this->inner_data[x] = array(
<br />
label => 'label du champ de rang x (string)',
<br />
content => 'contenu du champ'
<br />
);</code>
</td>
</tr>
<tr>
<td rowspan='6' style='vertical-align:middle'>
caractères spéciaux
</td>
<td>
record_end
</td>
<td>
chaîne
</td>
<td>
caractère de fin de notice (IS3 de l'ISO 6630)
</td>
</tr>
<tr>
<td>
field_end
</td>
<td>
chaîne
</td>
<td>
caractère de fin de champ (IS2 de l'ISO 6630)
</td>
</tr>
<tr>
<td>
subfield_begin
</td>
<td>
chaîne
</td>
<td>
caractère de début de sous-champ (IS1 de l'ISO 6630)
</td>
</tr>
<tr>
<td>
NSB_begin
</td>
<td>
chaîne
</td>
<td>
caractère débutant un NSB (Non Sorting Block)
</td>
</tr>
<tr>
<td>
NSB_end
</td>
<td>
chaîne
</td>
<td>
caractère de fin NSB (Non Sorting Block)
</td>
</tr>
<tr>
<td colspan='3'>
<u>note</u> Les propriétés décrivant des caractères spéciaux ont toutes dans cette classe un équivalent préfixé par <strong>rgx_</strong> contenant les mêmes caractères sous une forme utilisable dans des <i>expressions régulières compatibles PERL</i>.
</td>
</tr>
<tr>
<td rowspan='2' style='vertical-align:middle'>
divers
</td>
<td>
update_mode
</td>
<td>
entier
</td>
<td>
mode de mise à jour de l'enregistrement
</td>
</tr>
<tr>
<td>
errors
</td>
<td>
tableau
</td>
<td>
tableau contenant les messages d'erreurs liés au format de l'enregistrement (méthode <i>valid()</i>) ou aux modifications effectuées sur celui-ci.
</td>
</tr>
</table>
<br />
<br />
<p>
Dans l'état actuel des choses, la gestion des objets de PHP ne comprend aucune notion de propriétes ou méthodes publiques ou privées. Les propriétés de la classe sont donc toutes accessibles depuis n'importe quel endroit de votre code. Cependant, je ne recommande pas de modifier les propriétés préfixées par <strong>inner_</strong> sans bien réfléchir avant. Ces variables sont en effet utilisées de manière interne dans la classe pour la gestion de l'enregistrement. On peut donc les modifier, mais sans garantie quant à la synchronisation de l'ensemble.
</p>
<h2>
Méthodes
</h2>
<h3>
Le constructeur : iso2709_record
</h3>
<p>
<u>prototype</u> : <code>iso2709_record([<i>string</i> record], [<i>flag</i> update_mode])</code>
</p>
<p>
Le constructeur est appelé lors de la création de la classe. Il admet deux paramètres :
</p>
<ul>
<li>
Un enregistrement ISO2709 sous la forme d'une chaîne. La chaîne passée en paramètre peut être vide, auquel cas un nouvel enregistrement sera créé.
</li>
<li>
Un drapeau indiquant le mode de mise à jour de l'enregistrement. Ce drapeau peut prendre les valeurs <strong>AUTO_UPDATE</strong> ou <strong>USER_UPDATE</strong>, la valeur par défaut étant <strong>AUTO_UPDATE</strong>. Ce drapeau permet de régler le comportement de la classe lors de l'insertion ou de l'effacement de champs dans l'enregsitrement. Avec la valeur <strong>AUTO_UPDATE</strong>, les tableaux internes et le contenu des variables de l'enregistrement sont remis à jour à <u>chaque</u> insertion ou suppression, ce qui ralentit celles-ci. A contrario, avec la valeur fixée à <strong>USER_UPDATE</strong>, le script appelant doit gérer ces mises à jour par l'intermédiaire de la méthode <i>update()</i>. Pour clarifier ceci, on peut considérer que s'il s'agit de lire ou d'ajouter juste quelques champs, on peut laisser la valeur de ce paramètre à <strong>AUTO_UPDATE</strong>. Par contre, pour la création d'un enregistrement ou de nombreuses modifications, il est grandement préférable de retenir <strong>USER_UPDATE</strong>. Si cela est le cas, il ne faudra pas omettre l'appel de la méthode <i>update()</i> après les modifications, la gestion des mises à jour internes à la classe étant de la responsabilité du programmeur et non plus de celle-çi.
</li>
</ul>
<h3>
Obtenir le contenu d'un sous-champ ou d'un champ : get_field
</h3>
<p>
<u>prototype</u> : <code>get_subfield(<i>string</i> label [, <i>mixed</i> refs])</code>
</p>
<p>
La fonction <i>get_subfield</i> retourne le contenu du champ spécifié par le paramètres qui lui sont passés. L'appel de la méthode peut être effectué de différentes manières. Le paramètre <i>label</i> est l'étiquette du champ. Ce peut être une expression régulière (le point est alors un caractère "joker". <u>ex</u> : 7.0 indique les champs 700 <u>et</u> 710).
</p>
<p>
La valeur retournée par la fonction est un tableau dont la structure est définie par les paramètres passés (<i>ref</i>).
</p>
<ol>
<li>
Si le seul paramètre fourni est <i>label</i>, la méthode retourne un tableau dont les éléments sont constitués par les contenus entiers des champs correspondant à <i>label</i>.
</li>
<li>
Si seule une étiquette de sous-champ est fournie en plus du <i>label</i>, le tableau retourné sera comme précédemment un tableau dont les éléments sont constitués par les contenus entiers des champs correspondant à <i>label</i> et à l'étiquette fournie.
</li>
<li>
Si plusieurs étiquettes de sous-champs sont fournies, le tableau retourné sera un tableau multi-dimensionnel dont les éléments sont des tableaux associatifs contenant les valeurs des sous-champs spécifiés.
</li>
</ol>
<br />
<br />
<p>
<u>exemples d'appels valides de <strong>get_subfield</strong></u> :
</p>
<dl>
<dt>
<code>$isbn = $myRecord->get_subfield('010')</code>
</dt>
<dd>
retourne un tableau constitué par les contenus des champs 010 de l'enregistrement. Les indices de ce tableau sont numériques.
<br />
<u>ex.</u>
<pre>
$isbn[0] = 'contenu du premier champ 010'
$isbn[1] = 'contenu du second champ 010'
...
</pre>
</dd>
<dt>
<code>$nom_auteur = $myRecord->get_subfield('7..', a)</code>
</dt>
<dd>
retourne un tableau constitué par les contenus des sous-champs <b>$a</b> des champs commencant par 7 de l'enregistrement. Les indices de ce tableau sont numériques.
<br />
<u>ex.</u>
<pre>
$nom_auteur[0] = 'contenu du sous-champ 700$a'
$nom_auteur[1] = 'contenu du sous-champ 701$a'
...
$nom_auteur[x] = 'contenu du dernier sous-champ 712$a'
</pre>
</dd>
<dt>
<code>$nom_auteur = $myRecord->get_subfield('7..', a, b)</code>
</dt>
<dd>
retourne un tableau indexé dont les élements sont le contenu des sous-champs <b>$a</b> et <b>$b</b> des champs commencant par 7 de l'enregistrement. Les indices de ce tableau sont numériques et chacun de ses éléments est un tableau associatif.
<br />
<u>ex.</u>
<pre>
$nom_auteur[0][a] = 'contenu du sous-champ 700$a'
$nom_auteur[0][b] = 'contenu du sous-champ 700$b'
$nom_auteur[1][a] = 'contenu du sous-champ 701$a'
...
$nom_auteur[x][a] = 'contenu du dernier sous-champ 712$a'
$nom_auteur[x][b] = 'contenu du dernier sous-champ 712$b'
</pre>
</dd>
</dl>
<br />
<br />
<p>
Avec ceci, on doit en principe pouvoir accéder n'importe quel sous-champ de l'enregistrement. Si vous avez des besoins plus complexes, rien ne vous empêche de 'parser' directement les propriétes de la classe (cf. section <i>propriétés</i>).
</p>
<h3>
Ajout d'un champ : add_field
</h3>
<p>
<u>prototype</u> : <code>add_field(<i>string</i> label, <i>string</i> indicators, <i>mixed</i> field_content)</code>
</p>
<p>
Cette méthode permet l'ajout d'un champ à un enregistrement ISO2709. On peut l'appeler de différentes manières : le nombre de paramètres est variable. On doit fournir en premier lieu l'étiquette du champ et les éventuels indicateurs, ceux-çi pouvant être de longueur nulle si le champ n'a pas d'indicateurs.
</p>
<p>
Le passage du contenu du champ se fait par le paramètre <i>field_content</i> sous la forme d'un nombre variable de chaînes comprenant alternativement l'étiquette du sous-champ et le contenu du sous-champ. Si une seule chaîne est fournie, le champ est réputé n'avoir pas d'étiquette de sous-champ et contenir uniquement la chaîne fournie.
</p>
<p>
La seconde possibilité est de passer le contenu du champ sous la forme d'un tableau multi-dimensionnel dont chaque ligne est un array constitué par l'étiquette du sous-champ et le contenu du sous-champ.
</p>
<p>
<u>exemples d'appels valides de <strong>add_field</strong></u> :
</p>
<dl>
<dt>
<code>$myRecord->add_field('001', '', '01-0002977')</code>
</dt>
<dd>
ajoute un champ 001 ayant pour contenu 01-0002977 et ne comprenant pas d'indicateurs.
</dd>
<dt>
<code>$myRecord->add_field(200, '1 ', a, 'Minable le pingouin', f, 'Texte d'Helen Lester')</code>
</dt>
<dd>
ajoute un champ 200 ayant un champ $a, un champ $f et dont le premier indicateur est 1.
</dd>
<dt>
<code>$monChamp[0] = array( a => 'Lester');
<br />
$monChamp[1] = array( b => 'Helen');
<br />
$myRecord->add_field(700, ' 1', $monChamp);</code>
</dt>
<dd>
Passage des arguments par un tableau. On insére un champ 700 avec $a et $b avec un indicateur décrivant une entrée au nom de famille.
</dd>
</dl>
<br />
<br />
<p>
La méthode add_field() retourne <strong>TRUE</strong> en cas de succès et <strong>FALSE</strong> en cas d'échec (mauvais format pour les paramètres). Dans ce dernier cas, un message est ajouté au tableau des erreurs (cf. méthode <i>show_errors</i>).
</p>
<h3>
Suppression d'un champ : delete_field
</h3>
<p>
<u>prototype</u> : <code>delete_field(<i>string</i> label)</code>
</p>
<p>
La méthode <i>delete_field()</i> est à utiliser pour supprimer un champ de l'enregistrement ISO2709. Son fonctionnement est relativement simple : on passe comme paramètre l'étiquette du champ à supprimer. Il est possible de supprimer plusieurs champs en un seul appel dans la mesure où le paramètre <i>label</i> peut être une <u>expression régulière</u>. En pratique, on peut considérer que le point est un caractère "joker".
</p>
<p>
<u>exemples d'appels valides de <strong>delete_field</strong></u> :
</p>
<dl>
<dt>
<code>$myRecord->delete_field('001')</code>
</dt>
<dd>
supprime le ou les champs 001.
</dd>
<dt>
<code>$myRecord->delete_field('71.')</code>
</dt>
<dd>
supprime les champs de l'enregistrement dont les labels commencent par 71 (710, 711, 712...).
</dd>
<dt>
<code>$myRecord->delete_field('..2')</code>
</dt>
<dd>
supprime les champs de l'enregistrement dont les labels finissent par 2 (012, 022, etc.). (c'est idiot, mais sait-on jamais...)
</dd>
</dl>
<br />
<br />
<p>
La méthode delete_field() retourne <strong>TRUE</strong> en cas de succès et <strong>FALSE</strong> en cas d'échec (mauvais format pour le label). Dans ce dernier cas, un message est ajouté au tableau des erreurs (cf. méthode <i>show_errors</i>).
</p>
<h3>
Gestion du guide : set_rs, set_dt, set_bl, set_hl, set_el, set_ru
</h3>
<p>
<u>prototypes</u> :
<br />
<code>set_rs(<i>string/char</i> value)</code>
<br />
<code>set_dt(<i>string/char</i> value)</code>
<br />
<code>set_bl(<i>string/char</i> value)</code>
<br />
<code>set_hl(<i>string/char</i> value)</code>
<br />
<code>set_el(<i>string/char</i> value)</code>
<br />
<code>set_ru(<i>string/char</i> value)</code>
</p>
<p>
Cet ensemble de méthodes permet de positionner les valeurs non calculées du guide de l'enregistrement. Pour connaître le codage des valeurs concernées, je vous invite à vous reporter aux spécifications du format UNIMARC (ou autre).
</p>
<p>
Nomenclature des fonctions :
<br />
</p>
<table border='1'>
<tr>
<th>
fonction
</th>
<th>
position concernée
</th>
<th>
élément
</th>
<th>
description
</th>
</tr>
<tr>
<td>
set_rs()
</td>
<td>
5
</td>
<td>
record status
</td>
<td>
Etat de la notice
</td>
</tr>
<tr>
<td>
set_dt()
</td>
<td>
6
</td>
<td>
document type
</td>
<td>
Type de document
</td>
</tr>
<tr>
<td>
set_bl()
</td>
<td>
7
</td>
<td>
bibliographic level
</td>
<td>
Type de la notice
</td>
</tr>
<tr>
<td>
set_hl()
</td>
<td>
8
</td>
<td>
hierarchical level
</td>
<td>
Niveau hiérarchique
</td>
</tr>
<tr>
<td>
set_el()
</td>
<td>
17
</td>
<td>
encoding level
</td>
<td>
Niveau de catalogage
</td>
</tr>
<tr>
<td>
set_ru()
</td>
<td>
18
</td>
<td>
record update
</td>
<td>
Forme du catalogage descriptif
</td>
</tr>
</table>
<br />
<br />
<p>
L'appel de ces méthodes est on ne peut plus simple : on passe le code souhaité comme paramètre unique. Le guide (<i>inner_guide</i>) est modifié. Cependant, la mise à jour de l'enregistrement est toujours gérée suivant les modes <b>USER_UPDATE</b> et <b>AUTO_UPDATE</b>. Si la classe a été déclarée avec le mode <b>USER_UPDATE</b>, la modification ne sera effective qu'après l'appel de la méthode <i>update()</i>.
</p>
<h3>
Mise à jour de l'enregistrement : update
</h3>
<p>
<u>prototype</u> : <code>update(<i>void</i>)</code>
</p>
<p>
Cette méthode n'est à invoquer que si la classe a été créée avec le drapeau <strong>update_mode</strong> fixé à <strong>USER_UPDATE</strong>. Si ce n'est pas le cas, l'appel à cette méthode sera effectué à chaque opération d'insertion ou d'effacement effectuée sur l'enregistrement, ce qui rend superflue une mise à jour par le script appelant (cf. le constructeur : iso2709_record).
</p>
<p>
Le rôle de cette méthode est de synchroniser l'enregistrement courant avec sa représentation interne dans la classe. Les propriétés <i>full_record</i>, <i>guide</i> et <i>directory</i> sont mises à jour à partir du contenu des tableaux <i>inner_data</i>, <i>inner_guide</i>, <i>inner_directory</i>.
</p>
<p>
Cette méthode ne retourne rien.
</p>
<h3>
Vérification du format de l'enregistrement : valid
</h3>
<p>
<u>prototype</u> : <code>valid(<i>void</i>)</code>
</p>
<p>
Cette méthode vérifie le format ISO2709 de l'enregistrement. Elle retournera <strong>TRUE</strong> si l'enregistrement courant est valide et <strong>FALSE</strong> dans le cas contraire. <u>Attention</u> Cette méthode valide le format ISO2709 <u>uniquement</u>. Aucune erreur de sera générée si votre enregistrement contient, par exemple, 2 champs 700, ce qui est interdit par le standard UNIMARC.
</p>
<h3>
Gestion des caractères accentués et autres : ISO_encode et ISO_decode
</h3>
<p>
<u>prototypes</u> :
<br />
<code>ISO_encode(<i>string</i> chaine)</code>
<br />
<code>ISO_decode(<i>string</i> chaine)</code>
</p>
<p>
Ces deux méthodes assurent la conversion des caractères codés suivant le format ISO 5426 vers le format ISO 8859-1.
</p>
<p>
La fonction ISO_encode convertit le format ISO 8859-1 vers le format ISO 5426 et ISO_decode fait l'inverse.
</p>
<p>
Ces deux fonctions retournent la chaîne passée en paramètre mais convertie suivant le cas.
</p>
<p>
De mon point de vue, ces deux méthodes sont implémentées de manière 'partielle mais suffisante', ce qui veut dire que cette implémentation n'est pas complète dans la mesure où j'ai énormément de mal à trouver des informations suffisantes sur le format ISO 5426 et l'ISO 646. Pour l'anecdote, la fonction ISO_decode est adaptée d'un bout de code C posté sur le forum de l'application bien connue <strong>recode</strong> et la fonction ISO_encode en découle directement. Si des personnes avaient plus de documentation sur le sujet, je leur serais reconnaissant de m'en faire part. L'implémentation actuelle est a peu près satisfaisante pour les langues latines et romanes, mais incomplète pour l'allemand et les alphabets 'exotiques'.
</p>
<h2>
Un cas pratique
</h2>
<p>
Voici un exemple d'utilisation très simple destiné à clarifier un peu tout ça. Il illustre la création d'un enregistrement ISO 2709 minimal. Les commentaires sont dans le script.
</p>
<table border='0' class='center' bgcolor='mintcream' cellpadding='12'>
<tr>
<td>
<code><?
<br />
// inclusion du fichier de la classe
<br />
<br />
require('./iso2709.inc');
<br />
<br />
// on crée un nouvel objet vide
<br />
<br />
$record = new iso2709_record('', AUTO_UPDATE);
<br />
<br />
// on crée le champ 100 qui est obligatoire en UNIMARC
<br />
<br />
$champ = date('Ymd').'d||||||||||||uy0frea03||||ba';
<br />
<br />
// ce champ est inséré dans l'enregistrement
<br />
<br />
$record->add_field('100', '', a, champ);
<br />
<br />
// on ajoute un champ 200
<br />
<br />
$resp[0] = array(a, "Travailler, moi ? jamais !");
<br />
$resp[1] = array(e, "l'abolition du travail");
<br />
$resp[2] = array(f, "Bob Black");
<br />
$resp[3] = array(g, "traduit de l'anglais par Julius Van Daal");
<br />
<br />
<br />
$record->add_field('200', '1 ', $resp);
<br />
<br />
// on ajoute un champ 700
<br />
<br />
$record->add_field(700, ' 1', a, 'Black', b, 'Bob');
<br />
<br />
// champ 010 : l'ISBN
<br />
<br />
$record->add_field('010', '', a, '2-84405-000-X');
<br />
<br />
// champ 210 : adresse bibliographique
<br />
<br />
$record->add_field(210, '', a, '[s.l]', c, 'L'esprit frappeur', d, '1997');
<br />
<br />
// c'est fini, vous avez votre enregistrement.
<br />
// affichage de l'enregistrement ISO 2709 :
<br />
<br />
print $record->full_record;
<br />
<br />
?></code>
</td>
</tr>
</table>
<hr />
</div>
</body>
</html>
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists