1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190
| /**
* 16:13:29 berthier 2007
* (c) Copyright BERRTHIER rodolphe
* BEDOURET thierry
*/
package lpd2i.midp.motscroises;
import java.io.IOException;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
import org.xml.sax.helpers.DefaultHandler;
/**
* @author berthier TODO Description du type et son importance
*/
public class AnalyseXML extends DefaultHandler {
private FileIOListener fl= new FileIOListener();
private FileIO fic = new FileIO(fl);
private String FILENAME = "/root1/Test/file.xml";
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser;
/**
* Le mot qu'on relève dans le
*/
private Mot unMot = new Mot();
/**
* Fabrication de la grille
*/
private Grille uneGrille = new Grille();
/**
* Description d'un mot parcouru
*/
private String desc;
/* (non-Javadoc)
* Créer un simple handler de fichier
* @see org.xml.sax.ext.DeclHandler#attributeDecl(java.lang.String, java.lang.String, java.lang.String, java.lang.String, java.lang.String)
*/
public AnalyseXML(){
super();
}
/**
* Constructeur chargeant un analyseur directement en analysant un fichier
* @param nomFichier Fichier à partir duquel les données XML devront être extraites
*/
public void doAnalyse (String nomFichier) {
if ( fic.exists(FILENAME) == 0 ) {
//Si le fichier existe, alors on le lit
fic.read(FILENAME);
//Et on démarre l'analyse du fichier XML
fic.run();
} else {
//Si le fichier n'existe pas, on créé le do
fic.mkdir("/root1/Test/");
fic.create(FILENAME);
}
//Dossier créé dans D:\java\WTK25-Beta2\appdb\MediaControlSkin\filesystem\root1
try {
//on lance l'analyseur avec le fichier XML en parametre
saxParser = factory.newSAXParser();
System.out.println("Passage avant saxParser.parse");
saxParser.parse(fic.is, this);
fic.close();
System.out.println("Passage après saxParser.parse");
} catch (SAXParseException t) {
//Si on a une erreur pendant l'analyse
System.out.println("Erreur => " + t.toString());
System.out.println("Erreur => " + t.getPublicId());
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
* Cette méthode se lance lors de l'ouverture du fichier
*/
public void startDocument () throws SAXException {
System.out.println("début du document");
}
/**
* Cette commande se lance lors de la fermeture du fichier (EOF)
*/
public void endDocument () throws SAXException {
System.out.println("fin du document");
}
/**
* Commande lancée lors de l'ouverture d'une balise
*/
public void startElement (String namespaceURI, String simpleName, String qualifiedName, Attributes attrs) throws SAXException {
System.out.println("Entrée dans startElement");
if (simpleName.equals("")){
if (qualifiedName.equals("grille")){
System.out.println(attrs.getValue("difficulte"));
uneGrille.setDif(attrs.getValue("difficulte"));
System.out.println(attrs.getValue("taille"));
uneGrille.setTaille(attrs.getValue("taille"));
} else if (qualifiedName.equals("mot")) {
System.out.println("//////////");
System.out.println("x="+attrs.getValue("x")+" y="+attrs.getValue("y"));
unMot.setPositionX(Integer.parseInt(attrs.getValue("x").trim()));
unMot.setPositionY(Integer.parseInt(attrs.getValue("y").trim()));
//unMot.setPosition(new Point(sx.nextInt(),sy.nextInt()));
} else {
unMot.setPositionX(0);
unMot.setPositionY(0);
}
} else {
desc=qualifiedName;
}
}
/**
* Méthode éxecutée lors de la fermeture d'une balise
*/
public void endElement (String namespaceURI, String simpleName, String qualifiedName) throws SAXException {
System.out.println("sortie de Element");
if (simpleName.equals("")){
if (qualifiedName.equals("mot")){
System.out.println("sauvegarde "+unMot);
//uneGrille.add(unMot.getSens(), unMot.getPosition(), unMot.getElement(), unMot.getDescription());
uneGrille.add(unMot);
}
}
}
/**
* Méthode éxecutée lorsque les données interne a un élement sont lues
*/
public void characters (char buf [], int offset, int len) throws SAXException {
System.out.println("Entrée dans char");
String s = new String(buf, offset,len);
if (desc=="sens") {
System.out.println("entree => sens : "+s);
unMot.setSens(s);
} else if(desc=="element") {
System.out.println("entree => element : "+s);
unMot.setElement(s);
} else if(desc=="description") {
System.out.println("entree => descr : "+s);
unMot.setDescription(s);
}
//ici, il faut réinitialisé la variable temporaire de balise
//sinon l'entrée est vérifiée deux fois (balise ouvrante + balise fermante)
desc = null;
}
/**
* Renvoi la grille créée à partir du document xml
* @return uneGrille Grille créée à partir des données XML
* @uml.property name="uneGrille"
*/
public Grille getUneGrille() {
return uneGrille;
}
} |
Partager