This commit is contained in:
pablo rodriguez 2024-12-12 16:35:25 +01:00
parent 87adb0f4d8
commit a9e1f41e67
77 changed files with 550 additions and 204 deletions

File diff suppressed because one or more lines are too long

4
bin/.gitignore vendored
View File

@ -7,3 +7,7 @@
/resources/
/evaluer/
/outils/
/calc/
/baseEvaluation/
/baseListesEtudiants/
/calcul/

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

72
src/calc/Student.java Normal file
View File

@ -0,0 +1,72 @@
package calc;
import xml.EnsembleFichiers;
import xml.LecturesDossiers;
import xml.node;
public class Student {
/**
* Lecture du fichier Student pour vérification des historiques.<br>
* <br>
* @param nod node
* @param i
* @return
*/
public static node LectureFichierEtudiantPourVerification(node nod, node nodHisto, Integer i) {
node fichier = new node();
fichier.setNameNode("fichier");
fichier.getAttributs().put("filename", EnsembleFichiers.getListeFichierods().get(i));
fichier.getAttributs().put("dossier", EnsembleFichiers.getListeNomDossier().get(i));
node nodmeta = nod.retourneFirstEnfant("office:meta");
System.out.println(i);
if(nodmeta==null) return null;
LecturesDossiers.getEC();
System.out.println(EnsembleFichiers.getListeNomDossier().get(i));
if(!nodmeta.retourneFirstEnfant("meta:generator").getContenu().isEmpty()) {
fichier.getAttributs().put("producteur", nodmeta.retourneFirstEnfant("meta:generator").getContenu().get(0));
}else {
fichier.getAttributs().put("producteur", "nobody");
}
if(!nodmeta.retourneFirstEnfant("meta:generator").getContenu().isEmpty()) {
fichier.getAttributs().put("producteur", nodmeta.retourneFirstEnfant("meta:generator").getContenu().get(0));
}else {
fichier.getAttributs().put("producteur", "unknow");
}
if(!nodmeta.retourneFirstEnfant("dc:date").getContenu().isEmpty()) {
fichier.getAttributs().put("dateModification", nodmeta.retourneFirstEnfant("dc:date").getContenu().get(0));
}else {
fichier.getAttributs().put("dateModification", "unknow");
}
if(!nodmeta.retourneFirstEnfant("meta:editing-duration").getContenu().isEmpty()) {
fichier.getAttributs().put("dureeEdition", nodmeta.retourneFirstEnfant("meta:editing-duration").getContenu().get(0));
}else {
fichier.getAttributs().put("dureeEdition", "unknow");
}
fichier.getEnfants().add(nodmeta);
node nodhistorique = new node();
nodhistorique.setNameNode("historique");
int nbrModif =0;
if(nodHisto.retourneFirstEnfant("table:tracked-changes")!=null) {
nodHisto = nodHisto.retourneFirstEnfant("table:tracked-changes");
nodHisto.setParent(null);
nbrModif = nodHisto.retourneFirstEnfant("table:tracked-changes").getEnfants().size();
nodhistorique.addEnfant(nodHisto);
}else {
node tableTrackedVide= new node("table:tracked-changes");
nodhistorique.addEnfant(tableTrackedVide);
}
nodhistorique.getAttributs().put("nbrModif", String.valueOf(nbrModif));
// nodhistorique.getEnfants().addAll( nod.retourneAllEnfants("office:spreadsheet")); //a.retourneNames(nod, "office:text"));
fichier.getEnfants().add(nodhistorique);
return fichier;
}
}

View File

@ -22,6 +22,7 @@ public class commandes {
public static node sujetSauvegarde = new node();
public static JTree tree = new JTree();
public static node nodeACCSV = null;
public static String pathApp = Paths.get("").toAbsolutePath().toString();
//*************************
//** version **

View File

@ -8,11 +8,15 @@ import javax.xml.parsers.ParserConfigurationException;
import org.xml.sax.SAXException;
import calc.Student;
import calc.commandes;
import calcul.calculIntervalleBaremeABCDE;
import fenetres.baliseStyle;
import net.lingala.zip4j.exception.ZipException;
import xml.EnsembleFichiers;
import xml.LecturesDossiers;
import xml.ecritureFileXML;
import xml.node;
import xml.transformeXLMtoNode;
public class evaluerLesFichiersEtudiants implements Runnable{
@ -58,28 +62,45 @@ public class evaluerLesFichiersEtudiants implements Runnable{
commandes.message.append("<hr>");
Run a = null;
if(commandes.fichierStudentMoodle) {
try {
a = new Run(commandes.path,commandes.Profil, commandes.fichierStudentMoodle);
} catch (ParserConfigurationException e2) {
e2.printStackTrace();
} catch (SAXException e2) {
e2.printStackTrace();
} catch (IOException e2) {
e2.printStackTrace();
new LecturesDossiers(ecritureFileXML.LocationFile.UniquementFichier, commandes.path);
} 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();
}
}else {
try {
new LecturesDossiers(ecritureFileXML.LocationFile.DansDossier, commandes.path);
} 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();
}
}
LecturesDossiers.getEC();
//*****************************************
//** Nombre de fichier writer à analyser **
//*****************************************
int nbFichierWriter = a.getLectDossiers().getEC().getListeContentWriter().size();
String NbFichiers = String.valueOf(nbFichierWriter);
commandes.analyse_Nbre_Fichier_Student = nbFichierWriter;
int nbClasseur = EnsembleFichiers.getListeContentTableur().size();
String NbFichiers = String.valueOf(nbClasseur);
commandes.analyse_Nbre_Fichier_Student = nbClasseur;
commandes.message.append("<br>");
commandes.message.append("<p>Nombre de fichier à analyser et évaluer : " + NbFichiers + "</p>");
commandes.message.append("<p>Nombre de fichier à analyser et à évaluer : " + NbFichiers + "</p>");
commandes.message.append("<br>");
commandes.message.append("<hr>");
@ -89,25 +110,35 @@ public class evaluerLesFichiersEtudiants implements Runnable{
node verif = new node();
if(commandes.verifHisto || commandes.verifHisto2) {
node verification = new node();
verification.setNomElt("verification");
verification.getAttributs().put("nombre_fichier", String.valueOf(a.getLectDossiers().getEC().getListeFichierodt().size()));
for(int i = 0 ; i < nbFichierWriter ; i++) {
txt.setText("\nChargement de l'historique du fichier n° " + String.valueOf(i) +" par comparaison avec les "+ String.valueOf(nbFichierWriter-1) + " autres fichiers");
node nod = Run.XMLContent(a.getLectDossiers().getEC().getListeContentWriter().get(i));
node nodStudent = meptl.LectureFichierEtudiantPourVerification(nod,a,i);
verification.getNodes().add(nodStudent);
verification.setNameNode("verification");
LecturesDossiers.getEC();
verification.getAttributs().put("nombre_fichier", String.valueOf(EnsembleFichiers.getListeFichierods().size()));
for(int i = 0 ; i < nbClasseur ; i++) {
txt.setText("\nChargement de l'historique du fichier n° " + String.valueOf(i) +" par comparaison avec les "+ String.valueOf(nbClasseur-1) + " autres fichiers");
new transformeXLMtoNode(EnsembleFichiers.getListeContentTableur().get(i),false,null);//Run.XMLContent(a.getLectDossiers().getEC().getListeContentWriter().get(i));
node nod = transformeXLMtoNode.getNodeRoot();
new transformeXLMtoNode(EnsembleFichiers.getListeHistoriqueTableur().get(i),false,null);//Run.XMLContent(a.getLectDossiers().getEC().getListeContentWriter().get(i));
node nodHisto = transformeXLMtoNode.getNodeRoot();
node nodStudent = Student.LectureFichierEtudiantPourVerification(nod,nodHisto,i);
verification.getEnfants().add(nodStudent);
}
verification.saveNodeEnXMLinNewFile("histo", commandes.pathApp);
//a.ecritureNodeEnXML(verification, "VerificationHistorique","",false); //écriture du node de l'étudiant
txt.setText("\nRecherche des concordances temporelles et d'auteur dans l'historique des modifications des " + nbFichierWriter + " fichiers."
txt.setText("\nRecherche des concordances temporelles et d'auteur dans l'historique des modifications des " + nbClasseur + " fichiers."
+ "\nPatientez, cela peut prendre quelques secondes ou minutes.");
//********************************
//** Ecriture du node verif.xml **
//********************************
try {
verif = VerificationHistorique.verificationHistorique(verification, a,txt);
Run.ecritureNodeEnXML(verif, "Verif",commandes.path, Run.TypeFile.Verif );
} catch (IOException | ParseException | CloneNotSupportedException e) {
verif = new verificationHistorique(verification,txt).getVerif();
verif.saveNodeEnXMLinNewFile("Verif", commandes.pathApp);
} catch (ParseException | CloneNotSupportedException e) {
e.printStackTrace();
} //écriture du node de vérification
commandes.message.append("<br>");
@ -123,172 +154,171 @@ public class evaluerLesFichiersEtudiants implements Runnable{
//** Node contenant l'ensemble des analyses des étudiants **
//*********************************************************
node ensembleanalyse = new node();
ensembleanalyse.setNomElt("analyses");
ensembleanalyse.setNameNode("analyses");
//*****************************************************
//** Parcours l'ensemble des fichiers des étudiants ***
//*****************************************************
for(int i = 0 ; i < nbFichierWriter ; i++) {
String texteAfficher = "\nEvaluation du fichier n° " + String.valueOf(i+1) + "/" + String.valueOf(nbFichierWriter) + " fichier(s)";
for(int i = 0 ; i < nbClasseur ; i++) {
String texteAfficher = txt.getText() + "\nEvaluation du fichier n° " + String.valueOf(i+1) + "/" + String.valueOf(nbClasseur) + " fichier(s)";
txt.setText(texteAfficher);
//index de l'étudiant
commandes.analyse_index_Fichier_Student = i;
//** Ne prends pas en compte le dossier destination créé par la commande -dest
//** Si pas d'analyse alors le nom doit contenir le caractère $ dans le nom du dossier.
if(commandes.fourniDossierDestination) if(a.getLectDossiers().getEC().getListeNomDossier().get(i).equals(commandes.pathDestination)) continue;
//***********************************************************
//** Lecture et transformation en node du fichier étudiant **
//***********************************************************
node nod = Run.XMLContent(a.getLectDossiers().getEC().getListeContentWriter().get(i));
new transformeXLMtoNode(EnsembleFichiers.getListeContentTableur().get(i),false,null);
node nod = transformeXLMtoNode.getNodeRoot();
node nodStudent=null;
try {
System.gc(); // Demande de nettoyage du GC
//Création du node de l'étudiant.
//Permet aussi d'avoir l'historique des modifications du fichier de l'étudiant.
nodStudent = meptl.LectureFichierEtudiantSousFormeDeNode(nod,a,i);
//Supprime l'historique des modifications
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:tracked-changes");
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:change");
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:change-start");
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:change-end");
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:deletion");
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:bookmark-start");
nodStudent.supprimeTousLesNodesEnfantWithThisName("text:bookmark-end");
} catch (IOException e1) {
e1.printStackTrace();
}
//Ecriture du node fichier de l'étudiant
// try {
// Run.ecritureNodeEnXML(nodStudent, a.getLectDossiers().getEC().getListeNomDossier().get(i),commandes.path,"Sujet");
//
//
// //Création du node de l'étudiant.
// //Permet aussi d'avoir l'historique des modifications du fichier de l'étudiant.
// nodStudent = meptl.LectureFichierEtudiantSousFormeDeNode(nod,a,i);
//
// //Supprime l'historique des modifications
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:tracked-changes");
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:change");
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:change-start");
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:change-end");
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:deletion");
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:bookmark-start");
// nodStudent.supprimeTousLesNodesEnfantWithThisName("text:bookmark-end");
//
//
// } catch (IOException e1) {
// // TODO Auto-generated catch block
// e1.printStackTrace();
// }
//**********************************
//** Analyse des fichiers student **
//**********************************
if(commandes.analyse||commandes.ecritNodeAnalyse) {
// Run.ecritureNodeEnXML(nodStudent, "fichier student","",false,""); //écriture du node nodStudent de l'étudiant
node ana = analyseFichier.analyse(nodStudent, commandes.sujet, i, a, txt,texteAfficher);
//
// //Ecriture du node fichier de l'étudiant
//// try {
//// Run.ecritureNodeEnXML(nodStudent, a.getLectDossiers().getEC().getListeNomDossier().get(i),commandes.path,"Sujet");
//// } catch (IOException e1) {
//// // TODO Auto-generated catch block
//// e1.printStackTrace();
//// }
//
//
// //**********************************
// //** Analyse des fichiers student **
// //**********************************
// if(commandes.analyse||commandes.ecritNodeAnalyse) {
//
//// Run.ecritureNodeEnXML(nodStudent, "fichier student","",false,""); //écriture du node nodStudent de l'étudiant
// node ana = analyseFichier.analyse(nodStudent, commandes.sujet, i, a, txt,texteAfficher);
//// try {
//// Run.ecritureNodeEnXML(ana, "analyse", commandes.path, Run.TypeFile.Verif);
//// } catch (IOException e1) {
//// // TODO Auto-generated catch block
//// e1.printStackTrace();
//// }
// //**************************************************
// //** Ecriture des fichiers d'analyse des students **
// //**************************************************
// if(commandes.ecritNodeAnalyse) {
// try {
// Run.ecritureNodeEnXML(ana, "analyse", commandes.path, Run.TypeFile.Verif);
// } catch (IOException e1) {
// // TODO Auto-generated catch block
// e1.printStackTrace();
// Run.ecritureNodeEnXML(ana, "nodana"+ana.retourneFirstEnfantsByName("ouverture").getAttributs().get("dossier"),commandes.path,Run.TypeFile.Analyse);
// } catch (IOException e) {
// e.printStackTrace();
// }
// }
//
// //****************************
// //** Création des feedbacks **
// //****************************
// if(!commandes.sansFeeback&&!commandes.ecritNodeAnalyse) {
// if(!commandes.zipfeedback) {
// //feedback(ana, verif); //classique directement dans le répertoire
// try {
// feedbacks.feedback(ana,verif, false,false);
// } catch (IOException e) {
// e.printStackTrace();
// } catch (ParseException e) {
// e.printStackTrace();
// }
// }
// if(commandes.zipfeedback) { // Dans une archive pour Moodle
// try {
//// a.AddStreamToZip(feedbacks.feedback(ana, verif, true,false), meptl.retourneLeNomDuFeedback(a.getLectDossiers().getEC().getListeNomFichierFeedBack().get(i),ana, verif),commandes.analyse_size,commandes.analyse_nameZip);
// // Modification imposé par Moodle 4
// if(commandes.fichierStudentMoodle) {
// a.AddStreamToZip(feedbacks.feedback(ana, verif, true,false), meptl.retourneLeNomDuFeedbackMoodle4(a.getLectDossiers().getEC().getListeFichierodt().get(i),ana, verif),commandes.analyse_size,commandes.analyse_nameZip);
// }else {
// String nomFichiermoodle4 = a.getLectDossiers().getEC().getListeNomFichierFeedBack().get(i)+"_"+a.getLectDossiers().getEC().getListeFichierodt().get(i);
// a.AddStreamToZip(feedbacks.feedback(ana, verif, true,false), meptl.retourneLeNomDuFeedbackMoodle4(nomFichiermoodle4,ana, verif),commandes.analyse_size,commandes.analyse_nameZip);
// }
//
// } catch (ZipException e) {
// e.printStackTrace();
// } catch (IOException e) {
// e.printStackTrace();
// } catch (ParseException e) {
// e.printStackTrace();
// }
// }
// }
//
// //********************************************************************************
// //** Ajoute au node ensembleanalyse lorsque -csv file.csv ou -verifcsv file.scv **
// //********************************************************************************
// if(commandes.ecritNoteCSV) ensembleanalyse.addNode(ana);
//
// //*********************************************************
// //** Message dans la console sur l'analyse de l'étudiant **
// //*********************************************************
// commandes.message.append(meptl.messageSystem(ana).toString());
// }
//**************************************************
//** Ecriture des fichiers d'analyse des students **
//**************************************************
if(commandes.ecritNodeAnalyse) {
try {
Run.ecritureNodeEnXML(ana, "nodana"+ana.retourneFirstEnfantsByName("ouverture").getAttributs().get("dossier"),commandes.path,Run.TypeFile.Analyse);
} catch (IOException e) {
e.printStackTrace();
}
}
//****************************
//** Création des feedbacks **
//****************************
if(!commandes.sansFeeback&&!commandes.ecritNodeAnalyse) {
if(!commandes.zipfeedback) {
//feedback(ana, verif); //classique directement dans le répertoire
try {
feedbacks.feedback(ana,verif, false,false);
} catch (IOException e) {
e.printStackTrace();
} catch (ParseException e) {
e.printStackTrace();
}
}
if(commandes.zipfeedback) { // Dans une archive pour Moodle
try {
// a.AddStreamToZip(feedbacks.feedback(ana, verif, true,false), meptl.retourneLeNomDuFeedback(a.getLectDossiers().getEC().getListeNomFichierFeedBack().get(i),ana, verif),commandes.analyse_size,commandes.analyse_nameZip);
// Modification imposé par Moodle 4
if(commandes.fichierStudentMoodle) {
a.AddStreamToZip(feedbacks.feedback(ana, verif, true,false), meptl.retourneLeNomDuFeedbackMoodle4(a.getLectDossiers().getEC().getListeFichierodt().get(i),ana, verif),commandes.analyse_size,commandes.analyse_nameZip);
}else {
String nomFichiermoodle4 = a.getLectDossiers().getEC().getListeNomFichierFeedBack().get(i)+"_"+a.getLectDossiers().getEC().getListeFichierodt().get(i);
a.AddStreamToZip(feedbacks.feedback(ana, verif, true,false), meptl.retourneLeNomDuFeedbackMoodle4(nomFichiermoodle4,ana, verif),commandes.analyse_size,commandes.analyse_nameZip);
}
} catch (ZipException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (ParseException e) {
e.printStackTrace();
}
}
}
//********************************************************************************
//** Ajoute au node ensembleanalyse lorsque -csv file.csv ou -verifcsv file.scv **
//********************************************************************************
if(commandes.ecritNoteCSV) ensembleanalyse.addNode(ana);
//*********************************************************
//** Message dans la console sur l'analyse de l'étudiant **
//*********************************************************
commandes.message.append(meptl.messageSystem(ana).toString());
}
}
//*****************************************************
//** Exportation au format CSV si -csv ou -verifcsv **
//*****************************************************
if(commandes.ecritNoteCSV && !commandes.fourniCSV) {
if(!commandes.verifHisto2)
try {
meptl.ecritureCSV(ensembleanalyse);
} catch (IOException e) {
e.printStackTrace();
}
if(commandes.verifHisto2)
try {
meptl.ecritureCSV(ensembleanalyse,verif,a,commandes.sujet.retourneFirstEnfantsByName("setting"));
} catch (IOException e) {
e.printStackTrace();
}
}
//***********************************************************************
//** Exportation au format CSV si -csv file.csv ou -verifcsv file.csv **
//***********************************************************************
if(commandes.ecritNoteCSV && commandes.fourniCSV) {
try {
meptl.ecritureCSV(ensembleanalyse,verif,a,commandes.nodeCSV, commandes.sujet.retourneFirstEnfantsByName("setting"));
} catch (IOException e) {
e.printStackTrace();
}
//a.ecritureNodeEnXML(ensembleanalyse, "ensembleAnalyse"); //écriture du node de l'étudiant
}
//**************************************
//** Mise à jour du fichier d'analyse **
//**************************************
if(commandes.MAJFichierAnalyse||commandes.MAJnameAnalysisFile) {
try {
verificationFichierAnalyse_node_commandesSujet.MiseAJourFichierAnalyse();
} catch (CloneNotSupportedException | IOException e) {
e.printStackTrace();
}
verificationFichierAnalyse_node_commandesSujet.messagMiseAJourFichierAnalyseAprèsAnalyse();
}
//
//
//
// //*****************************************************
// //** Exportation au format CSV si -csv ou -verifcsv **
// //*****************************************************
// if(commandes.ecritNoteCSV && !commandes.fourniCSV) {
// if(!commandes.verifHisto2)
// try {
// meptl.ecritureCSV(ensembleanalyse);
// } catch (IOException e) {
// e.printStackTrace();
// }
// if(commandes.verifHisto2)
// try {
// meptl.ecritureCSV(ensembleanalyse,verif,a,commandes.sujet.retourneFirstEnfantsByName("setting"));
// } catch (IOException e) {
// e.printStackTrace();
// }
// }
//
// //***********************************************************************
// //** Exportation au format CSV si -csv file.csv ou -verifcsv file.csv **
// //***********************************************************************
// if(commandes.ecritNoteCSV && commandes.fourniCSV) {
// try {
// meptl.ecritureCSV(ensembleanalyse,verif,a,commandes.nodeCSV, commandes.sujet.retourneFirstEnfantsByName("setting"));
// } catch (IOException e) {
// e.printStackTrace();
// }
// //a.ecritureNodeEnXML(ensembleanalyse, "ensembleAnalyse"); //écriture du node de l'étudiant
// }
//
// //**************************************
// //** Mise à jour du fichier d'analyse **
// //**************************************
// if(commandes.MAJFichierAnalyse||commandes.MAJnameAnalysisFile) {
// try {
// verificationFichierAnalyse_node_commandesSujet.MiseAJourFichierAnalyse();
// } catch (CloneNotSupportedException | IOException e) {
// e.printStackTrace();
// }
// verificationFichierAnalyse_node_commandesSujet.messagMiseAJourFichierAnalyseAprèsAnalyse();
// }
//
txt.setContentType("text/html");
txt.setText(commandes.message.toString());

View File

@ -0,0 +1,124 @@
package evaluer;
import java.text.ParseException;
import java.util.ArrayList;
import javax.swing.JEditorPane;
import calc.commandes;
import xml.node;
public class verificationHistorique {
node verif = new node();
/**
* Vérirication des historiques
* @param verification
* @param a
* @return le node verif
* @throws ParseException
* @throws CloneNotSupportedException
*/
public verificationHistorique(node verification, JEditorPane txt) throws ParseException, CloneNotSupportedException {
boolean trouveCorrespondances = false;
verif.setNameNode("verification");
verif.addAttributs(verification.getAttributs());
verif.getAttributs().put("number_match", String.valueOf(commandes.number_match));
verif.getAttributs().put("mini_number_modification", String.valueOf(commandes.mini_number_modification));
verif.getAttributs().put("nombres_modifications_simultané_maxi", String.valueOf(commandes.nombres_modifications_simultané_maxi));
ArrayList<node> LesFichiers = verification.retourneAllEnfants("fichier");
System.out.println();
System.out.println("***** DEBUT VERIFICATION DES HISTORIQUES DES MODIFICATION ****");
System.out.println();
commandes.message.append("\n\n***** DEBUT VERIFICATION DES HISTORIQUES DES MODIFICATION ****\n");
int nbFichier = LesFichiers.size();
for(int i = 0 ; i < LesFichiers.size() ; i++) {
node nodStudent = new node();
nodStudent.setNameNode("fichier");
nodStudent.addAttributs(LesFichiers.get(i).getAttributs());
ArrayList<node> HitoriqueDuFichier = LesFichiers.get(i).retourneAllEnfants("table:cell-content-change");
int nombreModifications = HitoriqueDuFichier.size();
nodStudent.getAttributs().put("nombre_modification", String.valueOf(nombreModifications));
// Affichage message
String nameStudent1 = LesFichiers.get(i).getAttributs().get("dossier");
String AffichageMessageEcran = "Analyse du fichier " + i + " / " + nbFichier +"\n" + LesFichiers.get(i).getAttributs().get("dossier") + " - number of modifications : " + nombreModifications;
txt.setText(AffichageMessageEcran);
@SuppressWarnings("unchecked")
ArrayList<node> LesFichiers2 = (ArrayList<node>) LesFichiers.clone();
LesFichiers2.remove(i);
// Parcours toutes les modifications dans l'historique du fichier de l'étudiants
// pour les comparer à tous les autres.
for(int j = 0 ; j < HitoriqueDuFichier.size(); j++) {
for(int i2 = 0 ; i2 < LesFichiers2.size(); i2++) {
String nameStudent2 = LesFichiers2.get(i2).getAttributs().get("dossier");
String AffichageMessageEcran2 = AffichageMessageEcran + "\n" + "Recherche correspondance avec " + nameStudent2;
txt.setText(AffichageMessageEcran2);
int compteurnombreCorrespondance=0;
boolean correspondance = false;
node Tempo = new node("liste_comparer");
ArrayList<node> HitoriqueDuFichier2 = LesFichiers2.get(i2).retourneAllEnfants("table:cell-content-change");
for(int j2 = 0 ; j2 <HitoriqueDuFichier2.size(); j2++ ) {
if(HitoriqueDuFichier.get(j).enfantsTousIdentique(HitoriqueDuFichier2.get(j2))) {
txt.setText(AffichageMessageEcran2 + "\n" + "TROUVE CORRESPONDANCE");
compteurnombreCorrespondance++;
correspondance=true;
node A = new node("C"+String.valueOf(compteurnombreCorrespondance));
node B = new node("student1");
B.addAttribut("id", nameStudent1);
B.addEnfant(HitoriqueDuFichier.get(j));
node C = new node("student2");
C.addAttribut("id", nameStudent2);
C.addEnfant(HitoriqueDuFichier2.get(j2));
A.addEnfant(B);
A.addEnfant(C);
Tempo.addEnfant(A);
}
}
if(correspondance) {
node NodeCorrespondance = new node("correspondance");
NodeCorrespondance.addAttribut("student1", nameStudent1);
NodeCorrespondance.addAttribut("student2", nameStudent2);
NodeCorrespondance.addAttribut("nombreCorrespondance", String.valueOf(compteurnombreCorrespondance));
NodeCorrespondance.addEnfant(Tempo);
verif.addEnfant(NodeCorrespondance);
trouveCorrespondances=true;
}
}
}
}
if(trouveCorrespondances) {
String AffichageMessageEcran =
"┌─────────────────────────────────────────────────┐\n"+
"│ TROUVE DES CORREPONDNACES │\n"+
"│ ENTRE DES FICHIERS │\n"+
"└─────────────────────────────────────────────────┘\n\n"+
"Le fichier Verif.xml se trouve dans le dossier de l'application."+
commandes.pathApp;
txt.setText(AffichageMessageEcran);
}
System.gc(); // Demande de nettoyage du GC
}
public node getVerif() {
return verif;
}
}

View File

@ -42,6 +42,7 @@ import actions.actOpenBaseListesEtudiants;
import actions.actSaveEvaluation;
import actions.actTutoriels;
import calc.commandes;
import evaluer.evaluerLesFichiersEtudiants;
import net.miginfocom.swing.MigLayout;
/**

View File

@ -1,6 +1,8 @@
package xml;
import java.util.ArrayList;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class EnsembleFichiers {
private static ArrayList<String> ListeContentTableur = new ArrayList<String>();
@ -8,6 +10,9 @@ public class EnsembleFichiers {
private static ArrayList<String> ListeNomFichierFeedBack = new ArrayList<String>();
private static ArrayList<String> ListeFichierods = new ArrayList<String>();
private static ArrayList<String> ListeObjetGraphicTableur = new ArrayList<String>();
private static ArrayList<String> ListeHistoriqueTableur = new ArrayList<String>();
public static int size=0;
public EnsembleFichiers() {
@ -38,7 +43,26 @@ public class EnsembleFichiers {
*/
public void AjouteEnsembleAnalyse(String NomDossier, String contentT,String fichierods,
String fichierObjectgraphicTableur, String fichierFeedBack) {
String historiques="";
// Regex pour capturer tout le contenu entre <table:tracked-changes> et </table:tracked-changes>
String regex = "<table:tracked-changes>(.*?)</table:tracked-changes>";
// Compilation du pattern avec le flag DOTALL pour inclure les sauts de ligne
Pattern pattern = Pattern.compile(regex, Pattern.DOTALL);
Matcher matcher = pattern.matcher(contentT);
if (matcher.find()) {
// Capture du texte compris entre les balises
String capturedText = matcher.group(1);
historiques = historiques + capturedText;
System.out.println("Texte capturé : " + capturedText);
}
historiques = "<table:tracked-changes>"+historiques+"</table:tracked-changes>";
contentT = contentT.replaceAll(Pattern.quote(historiques), "");
ListeContentTableur.add(contentT);
ListeHistoriqueTableur.add(historiques);
ListeNomDossier.add(NomDossier);
ListeObjetGraphicTableur.add(fichierObjectgraphicTableur);
ListeFichierods.add(fichierods);
@ -47,16 +71,16 @@ public class EnsembleFichiers {
}
public ArrayList<String> getListeNomDossier() {
public static ArrayList<String> getListeNomDossier() {
return ListeNomDossier;
}
public ArrayList<String> getListeFichierods() {
public static ArrayList<String> getListeFichierods() {
return ListeFichierods;
}
public int getSize() {
public static int getSize() {
return EnsembleFichiers.size;
}
@ -74,7 +98,7 @@ public class EnsembleFichiers {
EnsembleFichiers.size = size;
}
public ArrayList<String> getListeObjetGraphicTableur() {
public static ArrayList<String> getListeObjetGraphicTableur() {
return ListeObjetGraphicTableur;
}
@ -82,7 +106,7 @@ public class EnsembleFichiers {
ListeObjetGraphicTableur = listeObjetGraphicTableur;
}
public ArrayList<String> getListeNomFichierFeedBack() {
public static ArrayList<String> getListeNomFichierFeedBack() {
return ListeNomFichierFeedBack;
}
@ -90,9 +114,12 @@ public class EnsembleFichiers {
ListeNomFichierFeedBack = listeNomFichierFeedBack;
}
public ArrayList<String> getListeContentTableur() {
public static ArrayList<String> getListeContentTableur() {
return ListeContentTableur;
}
public static ArrayList<String> getListeHistoriqueTableur() {
return ListeHistoriqueTableur;
}
}

View File

@ -69,11 +69,12 @@ public class LecturesDossiers {
ContentT = ContenuContent(fichiers2[j]);
fichierAnalyseods = fichiers2[j].getName();
ContentObjectGraphicTableur = ContenuContentObject(fichiers2[j]);
fichierAnalyseods = fichiers2[j].getName(); }
}
}
}
if(NomDossier==null) {NomDossier="inconnu"; filename="inconnu";}
if(fichierAnalyseods==null) fichierAnalyseods="pas de fichier calc déposé.";
if(ContentT==null) fichierAnalyseods="pas de fichier calc déposé.";
if(fichierAnalyseods!=null) {
@ -81,13 +82,17 @@ public class LecturesDossiers {
node nod = transformeXLMtoNode.getNodeRoot();
fichierAnalyseods = nod.ecritureXML().toString();
if(ContentObjectGraphicTableur!=null) {
// ContentObjectGraphicTableur="<Object num=\"0\" vide=\"true\"</Object>";
new transformeXLMtoNode(ContentObjectGraphicTableur,false,null);
nod = transformeXLMtoNode.getNodeRoot();
ContentObjectGraphicTableur = nod.ecritureXML().toString();
}
}
EC.AjouteEnsembleAnalyse(NomDossier, ContentT, fichierAnalyseods,ContentObjectGraphicTableur,filename );
System.out.print(".");
System.out.println(fichierAnalyseods);
}
}

View File

@ -1,6 +1,5 @@
package xml;
import java.io.BufferedWriter;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
@ -8,11 +7,11 @@ import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map.Entry;
import java.util.Objects;
import java.util.Set;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
@ -47,7 +46,6 @@ private boolean nodeClose = false;
parent.addEnfant(this);
}
public boolean isNodeClose() {
return nodeClose;
}
@ -104,19 +102,24 @@ private boolean nodeClose = false;
public void addNewEnfant(String nameNewEnfant) {
node newEnfant = new node(nameNewEnfant);
newEnfant.setParent(this);
newEnfant.setLevel(this.level+1);
this.enfants.add(newEnfant);
this.recalculLevel();
//this.recalculLevel();
}
public void addEnfant(node enfant) {
enfant.setParent(this);
enfant.setLevel(this.level+1);
this.enfants.add(enfant);
this.recalculLevel();
// this.recalculLevel();
}
public void addAllEnfants(ArrayList<node> enfants) {
for(int i = 0 ; i < enfants.size();i++) {
enfants.get(i).setLevel(this.level+1);
}
this.enfants.addAll(enfants);
this.recalculLevel();
// this.recalculLevel();
}
public void removeEnfant(node enfant) {
@ -304,7 +307,7 @@ private boolean nodeClose = false;
return attributs.size();
}
public HashMap<String, String> getAttributs() {
public LinkedHashMap<String, String> getAttributs() {
return attributs;
}
@ -660,6 +663,7 @@ private boolean nodeClose = false;
if(this.enfants.size()>0) {
for(int i = 0 ; i < this.enfants.size(); i++) {
if(this.enfants.get(i)==null) continue;
sb.append(this.enfants.get(i).ecritureXML());
if((indexMaxContenu-indexContenu)>0) {
if(this.contenu.size()>indexContenu) {
@ -766,6 +770,55 @@ private boolean nodeClose = false;
}
}
/**
* Cette méthode permet de vérifier si deux nodes sont identiques.<br>
* Retourne TRUE s'ils sont identiques, dans le cas contraire retourne FALSE.
* @param nodAVerifier
* @return
*/
public boolean identique(node nodAComparer) {
if(!this.nameNode.equals(nodAComparer.getNameNode())) return false;
if(this.getNbrEnfants()!=nodAComparer.getNbrEnfants()) return false;
if(this.getNbrAttributs()!=nodAComparer.getNbrAttributs()) return false;
if(!this.getContenu().equals(nodAComparer.getContenu())) return false;
Set<String> keys = this.getAttributs().keySet();
for (String key : keys) {
String valeur1 = this.getAttributs().get(key);
String valeur2 = nodAComparer.getAttributs().get(key);
if(!valeur1.equals(valeur2)) return false;
}
for(int i = 0 ; i <this.getEnfants().size();i++) {
if(!this.getEnfant(i).identique(nodAComparer.getEnfant(i))) return false;
}
return true;
}
/**
* Compare tous les nodes enfants. Cette méthode doit être utilisée pour comparer les historique de modifications.<br>
* Le node <table:previous> n'est pas comparé.<br>
* Retourne TRUE si tous les nodes enfants sont identiques.<br>
* Retourne FALSE dans le cas ou un seul n'est pas identique.
* @param nodAComparer
* @return
*/
public boolean enfantsTousIdentique(node nodAComparer) {
if(this.getNbrEnfants()!=nodAComparer.getNbrEnfants()) return false;
for (int i = 0 ; i < this.enfants.size();i++) {
if(this.getEnfant(i).getNameNode().equals("table:previous")) continue;
if(!this.getEnfant(i).identique(nodAComparer.getEnfant(i))) {
return false;
}
}
return true;
}
/**
* Insère l'attribut saut.
* @param value : valeur logique du saut.
@ -824,6 +877,7 @@ private boolean nodeClose = false;
/**
* Ecriture d'un node dans un fichier au format XML.<br>
* Le fichier doit existé.
*
* @param nod Le node à écrire dans un fichier.
* @param filename Le nom du fichier.
@ -854,6 +908,34 @@ private boolean nodeClose = false;
return true;
}
/**
* Ecriture d'un node dans un fichier au format XML.<br>
* Dans un nouveau fichier.
*
* @param filenameWithExtension
* @param pathDestination
* @return
*/
public boolean saveNodeEnXMLinNewFile(String filenameWithExtension, String pathDestination) {
if(filenameWithExtension.contains(".xml")) {
filenameWithExtension = filenameWithExtension.substring(0,filenameWithExtension.lastIndexOf(".xml"));
}
Path outputFilePath = Paths.get(pathDestination +"/"+ filenameWithExtension + ".xml");
try {
BufferedWriter fichier = Files.newBufferedWriter(outputFilePath, StandardCharsets.UTF_8);
fichier.write(this.ecritureXML().toString());
fichier.close();
} catch (IOException e) {
e.printStackTrace();
return false;
}
return true;
}
/**
* Insère l'attribut addmenu avec la valeur logique.
* @param value : valeur logique.