Bug fixes
This commit is contained in:
parent
f367068e74
commit
a1472c7b60
1
NGCC/config.txt
Normal file
1
NGCC/config.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Code : 8
|
@ -41,7 +41,7 @@ public class Exec implements Callable <Void> {
|
|||||||
public static void main(String[] args) throws InterruptedException {
|
public static void main(String[] args) throws InterruptedException {
|
||||||
|
|
||||||
// Système de subcommand semblable à celui de git permettant d'appeler les classes relatives
|
// Système de subcommand semblable à celui de git permettant d'appeler les classes relatives
|
||||||
//String[] t = {"-r","-v9","-d","pdf"};
|
String[] t = {"-r","-v9","-d","pdf","config.txt"};
|
||||||
CommandLine cmd = new CommandLine (new Exec())
|
CommandLine cmd = new CommandLine (new Exec())
|
||||||
.addSubcommand("-r", new Read(System.out)) // nom commande, objet commande
|
.addSubcommand("-r", new Read(System.out)) // nom commande, objet commande
|
||||||
.addSubcommand("-b", new Build(System.out))
|
.addSubcommand("-b", new Build(System.out))
|
||||||
@ -51,7 +51,7 @@ public class Exec implements Callable <Void> {
|
|||||||
.addSubcommand("-e", new Evaluate(System.out))
|
.addSubcommand("-e", new Evaluate(System.out))
|
||||||
.addSubcommand("help", new HelpCommand()); // Aide générée automatiquement par l'API
|
.addSubcommand("help", new HelpCommand()); // Aide générée automatiquement par l'API
|
||||||
|
|
||||||
cmd.execute(args); //t
|
cmd.execute(t); //t
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,10 +137,8 @@ public class Read implements Callable <Void> {
|
|||||||
Config config = new Config(source_path); //Initialise le fichier de configuration selon le chemin donné
|
Config config = new Config(source_path); //Initialise le fichier de configuration selon le chemin donné
|
||||||
config.readConfig();
|
config.readConfig();
|
||||||
|
|
||||||
|
|
||||||
GestionnaireCopies ocr = new GestionnaireCopies(directory_name); // Instantie l'ocr
|
GestionnaireCopies ocr = new GestionnaireCopies(directory_name); // Instantie l'ocr
|
||||||
GenerateCSV csv = new GenerateCSV(ocr.createHashMapforCSV(),config.getParam().get("Code"), result_name);
|
GenerateCSV csv = new GenerateCSV(ocr.createHashMapforCSV(),config.getParam().get("Code"), result_name, logger);
|
||||||
|
|
||||||
|
|
||||||
csv.createFile(); //Génère le fichier csv à partir de la HMap retournée par l'OCR
|
csv.createFile(); //Génère le fichier csv à partir de la HMap retournée par l'OCR
|
||||||
|
|
||||||
|
@ -30,38 +30,38 @@ public class Config {
|
|||||||
public Config(String s) {
|
public Config(String s) {
|
||||||
// Constructeur, prend en parametre le chemin vers le fichier source
|
// Constructeur, prend en parametre le chemin vers le fichier source
|
||||||
source = s;
|
source = s;
|
||||||
// Initialisation des parametres avec les valeurs par défaut.
|
// Initialisation des parametres avec les valeurs par d<EFBFBD>faut.
|
||||||
// Les élements avec des placeholders en valeur sont des élements qui ne servent
|
// Les <EFBFBD>lements avec des placeholders en valeur sont des <EFBFBD>lements qui ne servent
|
||||||
// pas pour le moment
|
// pas pour le moment
|
||||||
param.put("PaperSize", "A4"); // A3 A4 A5 letter
|
param.put("PaperSize", "A4"); // A3 A4 A5 letter
|
||||||
param.put("Title", "Placeholder"); // titre de l exam
|
param.put("Title", "Placeholder"); // titre de l exam
|
||||||
param.put("Presentation", "Placeholder"); // texte de consignes
|
param.put("Presentation", "Placeholder"); // texte de consignes
|
||||||
param.put("DocumentModel", "PlaceHolder"); // nom du fichier du modèle
|
param.put("DocumentModel", "PlaceHolder"); // nom du fichier du mod<EFBFBD>le
|
||||||
param.put("ShuffleQuestions", "1"); // 1 = qt mélangées, 0 = non mél
|
param.put("ShuffleQuestions", "1"); // 1 = qt m<EFBFBD>lang<EFBFBD>es, 0 = non m<EFBFBD>l
|
||||||
param.put("ShuffleAnswers", "1"); // 1= proposition rép mélangées, 0= non
|
param.put("ShuffleAnswers", "1"); // 1= proposition r<EFBFBD>p m<EFBFBD>lang<EFBFBD>es, 0= non
|
||||||
param.put("Code", "8"); // code étudiant = 8 chiffres (entre 1 et 16)
|
param.put("Code", "8"); // code <EFBFBD>tudiant = 8 chiffres (entre 1 et 16)
|
||||||
param.put("MarkFormat", "20/4"); // expl "20/4" pour des notes entre 0 et 20 notées à 0.25 points
|
param.put("MarkFormat", "20/4"); // expl "20/4" pour des notes entre 0 et 20 not<EFBFBD>es <EFBFBD> 0.25 points
|
||||||
param.put("NameField", "Nom et Prénom"); // remplace le texte
|
param.put("NameField", "Nom et Pr<EFBFBD>nom"); // remplace le texte
|
||||||
param.put("StudentField",
|
param.put("StudentField",
|
||||||
"Veuillez coder votre numéro\r\n d’étudiant ci-contre et écrire votre nom \r\n dans la case ci-dessous");
|
"Veuillez coder votre num<EFBFBD>ro\r\n d<><64>tudiant ci-contre et <20>crire votre nom \r\n dans la case ci-dessous");
|
||||||
// sert à remplacer le petit texte qui demande de coder son numéro d’étudiant et
|
// sert <EFBFBD> remplacer le petit texte qui demande de coder son num<EFBFBD>ro d<EFBFBD><EFBFBD>tudiant et
|
||||||
// inscrire son nom
|
// inscrire son nom
|
||||||
param.put("MarkField", "Veuillez coder le numéro de l'étudiant");
|
param.put("MarkField", "Veuillez coder le num<EFBFBD>ro de l'<27>tudiant");
|
||||||
param.put("SeparateAnswerSheet", "1"); // si 1 = feuille de réponse séparée.
|
param.put("SeparateAnswerSheet", "1"); // si 1 = feuille de r<EFBFBD>ponse s<EFBFBD>par<EFBFBD>e.
|
||||||
param.put("AnswerSheetTitle", "Title"); // titre à inscrire en tete de la feuille de rép
|
param.put("AnswerSheetTitle", "Title"); // titre <EFBFBD> inscrire en tete de la feuille de r<EFBFBD>p
|
||||||
param.put("AnswerSheetPresentation", "Presentation"); // Donne le texte de présentation de la feuille de réponse
|
param.put("AnswerSheetPresentation", "Presentation"); // Donne le texte de pr<EFBFBD>sentation de la feuille de r<EFBFBD>ponse
|
||||||
param.put("SingleSided", "Placeholder");// si valeur = 1, aucune page blanche entre feuille de sujet et de
|
param.put("SingleSided", "Placeholder");// si valeur = 1, aucune page blanche entre feuille de sujet et de
|
||||||
// réponse
|
// r<EFBFBD>ponse
|
||||||
param.put("DefaultScoringS", "Placeholder");// Donne le barème par défaut pour les questions simples
|
param.put("DefaultScoringS", "Placeholder");// Donne le bar<EFBFBD>me par d<EFBFBD>faut pour les questions simples
|
||||||
param.put("DefaultScoringM", "Placeholder");// Donne le barème par défaut pour les questions à choix multiple
|
param.put("DefaultScoringM", "Placeholder");// Donne le bar<EFBFBD>me par d<EFBFBD>faut pour les questions <EFBFBD> choix multiple
|
||||||
param.put("QuestionBlocks", "Placeholder");// prend 0 pour valeur pour permettre à la boite d'une question boite
|
param.put("QuestionBlocks", "Placeholder");// prend 0 pour valeur pour permettre <EFBFBD> la boite d'une question boite
|
||||||
// d'etre coupé sur plusieurs pages, prend 1 sinon
|
// d'etre coup<EFBFBD> sur plusieurs pages, prend 1 sinon
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void readConfig() {
|
public void readConfig() {
|
||||||
// Methode pour lire le fichier config en chemin dans la variable source
|
// Methode pour lire le fichier config en chemin dans la variable source
|
||||||
// Si une ligne du fichier correspond à un parametre, changer la valeur du
|
// Si une ligne du fichier correspond <EFBFBD> un parametre, changer la valeur du
|
||||||
// parametre avec celle dans le fichier (si valeur valide)
|
// parametre avec celle dans le fichier (si valeur valide)
|
||||||
// Gere aussi les questions dans le fichier source et les mets dans une liste de
|
// Gere aussi les questions dans le fichier source et les mets dans une liste de
|
||||||
// questions.
|
// questions.
|
||||||
@ -72,7 +72,7 @@ public class Config {
|
|||||||
Question q;
|
Question q;
|
||||||
ligne = scan.nextLine();
|
ligne = scan.nextLine();
|
||||||
// ligne pour gerer le code FEFF en UTF-8 BOM qui peut apparaitre si le fichier
|
// ligne pour gerer le code FEFF en UTF-8 BOM qui peut apparaitre si le fichier
|
||||||
// txt est edité avec windows notepad
|
// txt est edit<EFBFBD> avec windows notepad
|
||||||
// ce caractere apparait uniquement en debut de fichier
|
// ce caractere apparait uniquement en debut de fichier
|
||||||
if (ligne.startsWith("\uFEFF"))
|
if (ligne.startsWith("\uFEFF"))
|
||||||
ligne = ligne.substring(1);
|
ligne = ligne.substring(1);
|
||||||
@ -86,7 +86,7 @@ public class Config {
|
|||||||
{
|
{
|
||||||
q = makeQuestion(ligne);
|
q = makeQuestion(ligne);
|
||||||
ligne = scan.nextLine(); // on scan la prochaine ligne
|
ligne = scan.nextLine(); // on scan la prochaine ligne
|
||||||
while (!ligne.equals("")) // tant que la ligne n'est pas vide, on lit la suite qui est supposé
|
while (!ligne.equals("")) // tant que la ligne n'est pas vide, on lit la suite qui est suppos<EFBFBD>
|
||||||
// etre les reponses
|
// etre les reponses
|
||||||
{
|
{
|
||||||
q.addReponse(ligne);
|
q.addReponse(ligne);
|
||||||
@ -104,12 +104,12 @@ public class Config {
|
|||||||
}
|
}
|
||||||
scan.close();
|
scan.close();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
System.err.println(e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// methode pour creer une question
|
// methode pour creer une question
|
||||||
// methode utilisée à partir d'un string supposé lu sur un fichier config
|
// methode utilis<EFBFBD>e <EFBFBD> partir d'un string suppos<EFBFBD> lu sur un fichier config
|
||||||
// TODO : gestion des options telles que coeff et frozenanswer
|
// TODO : gestion des options telles que coeff et frozenanswer
|
||||||
public Question makeQuestion(String ligne) {
|
public Question makeQuestion(String ligne) {
|
||||||
Question q;
|
Question q;
|
||||||
@ -117,7 +117,7 @@ public class Config {
|
|||||||
switch (s) {
|
switch (s) {
|
||||||
|
|
||||||
case "*":
|
case "*":
|
||||||
// si c'est une * alors c'est une question à choix multiple
|
// si c'est une * alors c'est une question <EFBFBD> choix multiple
|
||||||
q = new Question(ligne.substring(3, ligne.length()), true);
|
q = new Question(ligne.substring(3, ligne.length()), true);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@ -126,14 +126,14 @@ public class Config {
|
|||||||
// si c'est une < alors c'est une question de type boite
|
// si c'est une < alors c'est une question de type boite
|
||||||
int debut = ligne.indexOf("="); // on cherche la position du =, le caractere apres le = sera le nb de lignes
|
int debut = ligne.indexOf("="); // on cherche la position du =, le caractere apres le = sera le nb de lignes
|
||||||
// de la boite
|
// de la boite
|
||||||
int fin = ligne.indexOf(">"); // on cherce la position du >, la suite de ce caractere sera l'intitulé de la
|
int fin = ligne.indexOf(">"); // on cherce la position du >, la suite de ce caractere sera l'intitul<EFBFBD> de la
|
||||||
// question
|
// question
|
||||||
int nblignes = Integer.parseInt(ligne.substring(debut + 1, fin));
|
int nblignes = Integer.parseInt(ligne.substring(debut + 1, fin));
|
||||||
q = new QuestionBoite(ligne.substring(fin + 2, ligne.length()), false, nblignes);
|
q = new QuestionBoite(ligne.substring(fin + 2, ligne.length()), false, nblignes);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// si pas une des conditions citées en haut, alors c'est une question à choix
|
// si pas une des conditions cit<EFBFBD>es en haut, alors c'est une question <EFBFBD> choix
|
||||||
// unique
|
// unique
|
||||||
q = new Question(ligne.substring(2, ligne.length()), false);
|
q = new Question(ligne.substring(2, ligne.length()), false);
|
||||||
}
|
}
|
||||||
@ -141,7 +141,7 @@ public class Config {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// modification des valeurs du hashmap param
|
// modification des valeurs du hashmap param
|
||||||
// lecture d'un string supposé lu sur un fichier config
|
// lecture d'un string suppos<EFBFBD> lu sur un fichier config
|
||||||
public void lireParam(String s) {
|
public void lireParam(String s) {
|
||||||
int n = s.indexOf(":"); // recherche de position du premier ":" pour pouvoir separer le nom du param de
|
int n = s.indexOf(":"); // recherche de position du premier ":" pour pouvoir separer le nom du param de
|
||||||
// sa valeur
|
// sa valeur
|
||||||
@ -149,7 +149,7 @@ public class Config {
|
|||||||
while (spl[1].substring(0, 1).equals(" "))
|
while (spl[1].substring(0, 1).equals(" "))
|
||||||
spl[1] = spl[1].substring(1, spl[1].length());
|
spl[1] = spl[1].substring(1, spl[1].length());
|
||||||
spl[0] = spl[0].toUpperCase(); // pour eviter la casse, on met tout en upper case
|
spl[0] = spl[0].toUpperCase(); // pour eviter la casse, on met tout en upper case
|
||||||
switch (spl[0]) // chaque case correspond à un parametre, pour le moment on ignore tout
|
switch (spl[0]) // chaque case correspond <EFBFBD> un parametre, pour le moment on ignore tout
|
||||||
// parametre qui n'est pas utile au programme.
|
// parametre qui n'est pas utile au programme.
|
||||||
{
|
{
|
||||||
case "PAPERSIZE":
|
case "PAPERSIZE":
|
||||||
@ -195,16 +195,16 @@ public class Config {
|
|||||||
setAnswerSheetPresentation(spl[1]);
|
setAnswerSheetPresentation(spl[1]);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
default: // parametre mal tapé ou non utile (pour le moment) au programme, on l'ignore
|
default: // parametre mal tap<EFBFBD> ou non utile (pour le moment) au programme, on l'ignore
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// liste des set de chaque valeur de parametre
|
// liste des set de chaque valeur de parametre
|
||||||
// actuellement, uniquement les parametres de l'étape 1 sont traités
|
// actuellement, uniquement les parametres de l'<EFBFBD>tape 1 sont trait<EFBFBD>s
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
// possibilité d'afficher sur la console messages de valeur invalide et valeur
|
// possibilit<EFBFBD> d'afficher sur la console messages de valeur invalide et valeur
|
||||||
// par défaut utilisée en cas d'erreur si verbose
|
// par d<EFBFBD>faut utilis<EFBFBD>e en cas d'erreur si verbose
|
||||||
public void setPaperSize(String s) {
|
public void setPaperSize(String s) {
|
||||||
s = s.toUpperCase();
|
s = s.toUpperCase();
|
||||||
s = s.trim();
|
s = s.trim();
|
||||||
|
@ -5,29 +5,35 @@ import java.io.FileNotFoundException;
|
|||||||
import java.io.PrintWriter;
|
import java.io.PrintWriter;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
public class GenerateCSV {
|
public class GenerateCSV {
|
||||||
|
|
||||||
HashMap<String,String> etudiants;
|
HashMap<String,String> etudiants;
|
||||||
int numLength;
|
int numLength;
|
||||||
String path = "../export";
|
String path = "../export";
|
||||||
|
Logger logger;
|
||||||
|
|
||||||
public GenerateCSV(HashMap<String,String> map, String length, String pth) {
|
public GenerateCSV(HashMap<String,String> map, String length, String pth, Logger lg) {
|
||||||
this.etudiants = map;
|
this.etudiants = map;
|
||||||
this.numLength = Integer.parseInt(length);
|
this.numLength = Integer.parseInt(length);
|
||||||
this.path = path+"/"+pth;
|
this.path = path+"/"+pth;
|
||||||
|
this.logger = lg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// TO DO : exploiter dans generation
|
// Teste validité du numero etudiant (selon param de la config passé : numLength)
|
||||||
|
|
||||||
public boolean isValid(String s) {
|
public boolean isValid(String s) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
logger.debug("Checking string validity");
|
||||||
if (s.length() == this.numLength) {
|
if (s.length() == this.numLength) {
|
||||||
while (i < s.length()) {
|
while (i < s.length()) {
|
||||||
|
|
||||||
int nb = Character.getNumericValue(s.charAt(i));
|
int nb = Character.getNumericValue(s.charAt(i));
|
||||||
|
|
||||||
if (nb <= 0 || nb >= 9) {
|
if (nb <= 0 || nb >= 9) {
|
||||||
System.err.println("Student id's characters are not recognized");
|
logger.fatal("Student id's characters are not recognized");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -35,10 +41,11 @@ public class GenerateCSV {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
logger.debug("String validity ok");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
System.err.println("Student id's length is not correct");
|
logger.fatal("Student id's length is not correct");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -50,6 +57,7 @@ public class GenerateCSV {
|
|||||||
public void createFile() {
|
public void createFile() {
|
||||||
try (PrintWriter writer = new PrintWriter(new File(this.path))) {
|
try (PrintWriter writer = new PrintWriter(new File(this.path))) {
|
||||||
|
|
||||||
|
logger.info("Creating csv file");
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
sb.append("Student number");
|
sb.append("Student number");
|
||||||
sb.append(';');
|
sb.append(';');
|
||||||
@ -58,15 +66,33 @@ public class GenerateCSV {
|
|||||||
|
|
||||||
writer.write(sb.toString());
|
writer.write(sb.toString());
|
||||||
|
|
||||||
for (String etud : this.etudiants.keySet()) {
|
if (!etudiants.isEmpty()) {
|
||||||
|
|
||||||
writer.write(etud+";"+etudiants.get(etud)+System.getProperty("line.separator"));
|
for (String etud : this.etudiants.keySet()) {
|
||||||
|
|
||||||
|
// Si etudiant HashMap est null, pas ecrit
|
||||||
|
if (!(etud == null)) {
|
||||||
|
|
||||||
|
if (this.isValid(etud)) {
|
||||||
|
writer.write(etud+";"+etudiants.get(etud)+System.getProperty("line.separator"));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
logger.debug("Null id not added to csv");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.info("File creation succeed");
|
||||||
}
|
}
|
||||||
System.out.println("Create File Done!");
|
else {
|
||||||
|
logger.fatal("Students list for csv generation is empty");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} catch (FileNotFoundException e) {
|
} catch (FileNotFoundException e) {
|
||||||
System.err.println(e.getMessage());
|
logger.fatal(e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,6 +64,7 @@ public class GestionnaireCopies {
|
|||||||
{
|
{
|
||||||
temp.put(c.getBase().gethMapImgs().get("NumEtu").getDescription(), c.getBase().gethMapImgs().get("Note").getDescription());
|
temp.put(c.getBase().gethMapImgs().get("NumEtu").getDescription(), c.getBase().gethMapImgs().get("Note").getDescription());
|
||||||
}
|
}
|
||||||
|
|
||||||
return temp;
|
return temp;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ package log4j;
|
|||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
|
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user