cleaner code:
All checks were successful
CI/CD Pipeline / test (push) Successful in 1m51s

This commit is contained in:
philipp 2024-02-16 09:21:21 +01:00
parent ac20dfcb48
commit bb8e5641f6
4 changed files with 153 additions and 98 deletions

View File

@ -209,7 +209,7 @@ New_par: § 83.;{"Item":[{"Text":"(1) Wer einen anderen am Körper verletzt oder
New_new_para_header: Schwere Körperverletzung New_new_para_header: Schwere Körperverletzung
New_par: § 84.;{"Item":[{"Text":"(1) Wer einen anderen am Körper misshandelt und dadurch fahrlässig eine länger als vierundzwanzig Tage dauernde Gesundheitsschädigung oder Berufsunfähigkeit oder eine an sich schwere Verletzung oder Gesundheitsschädigung zufügt, ist mit Freiheitsstrafe bis zu drei Jahren zu bestrafen."},{"Text":"(2) Ebenso ist zu bestrafen, wer eine Körperverletzung (§ 83 Abs. 1 oder Abs. 2) an einem Beamten, Zeugen oder Sachverständigen während oder wegen der Vollziehung seiner Aufgaben oder der Erfüllung seiner Pflichten begeht."},{"Text":"(3) Ebenso ist der Täter zu bestrafen, wenn er mindestens drei selbstständige Taten (§ 83 Abs. 1 oder Abs. 2) ohne begreiflichen Anlass und unter Anwendung erheblicher Gewalt begangen hat."},{"Text":"(4) Mit Freiheitsstrafe von sechs Monaten bis zu fünf Jahren ist zu bestrafen, wer einen anderen am Körper verletzt oder an der Gesundheit schädigt und dadurch, wenn auch nur fahrlässig, eine schwere Körperverletzung oder Gesundheitsschädigung (Abs. 1) des anderen herbeiführt."},{"List":[{"Text":"(5) Ebenso ist zu bestrafen, wer eine Körperverletzung (§ 83 Abs. 1 oder Abs. 2) begeht"},{"List":[{"List":[{"Text":"1. auf eine Weise, mit der Lebensgefahr verbunden ist,"},{"Text":"2. mit mindestens zwei Personen in verabredeter Verbindung oder"},{"Text":"3. unter Zufügung besonderer Qualen."}]}]}]}]} New_par: § 84.;{"Item":[{"Text":"(1) Wer einen anderen am Körper misshandelt und dadurch fahrlässig eine länger als vierundzwanzig Tage dauernde Gesundheitsschädigung oder Berufsunfähigkeit oder eine an sich schwere Verletzung oder Gesundheitsschädigung zufügt, ist mit Freiheitsstrafe bis zu drei Jahren zu bestrafen."},{"Text":"(2) Ebenso ist zu bestrafen, wer eine Körperverletzung (§ 83 Abs. 1 oder Abs. 2) an einem Beamten, Zeugen oder Sachverständigen während oder wegen der Vollziehung seiner Aufgaben oder der Erfüllung seiner Pflichten begeht."},{"Text":"(3) Ebenso ist der Täter zu bestrafen, wenn er mindestens drei selbstständige Taten (§ 83 Abs. 1 oder Abs. 2) ohne begreiflichen Anlass und unter Anwendung erheblicher Gewalt begangen hat."},{"Text":"(4) Mit Freiheitsstrafe von sechs Monaten bis zu fünf Jahren ist zu bestrafen, wer einen anderen am Körper verletzt oder an der Gesundheit schädigt und dadurch, wenn auch nur fahrlässig, eine schwere Körperverletzung oder Gesundheitsschädigung (Abs. 1) des anderen herbeiführt."},{"List":[{"Text":"(5) Ebenso ist zu bestrafen, wer eine Körperverletzung (§ 83 Abs. 1 oder Abs. 2) begeht"},{"List":[{"List":[{"Text":"1. auf eine Weise, mit der Lebensgefahr verbunden ist,"},{"Text":"2. mit mindestens zwei Personen in verabredeter Verbindung oder"},{"Text":"3. unter Zufügung besonderer Qualen."}]}]}]}]}
New_new_para_header: Körperverletzung mit schweren Dauerfolgen New_new_para_header: Körperverletzung mit schweren Dauerfolgen
New_par: § 85.;{"Item":[{"List":[{"Text":"(1) Wer einen anderen am Körper misshandelt und dadurch fahrlässig für immer oder für lange Zeit"},{"List":[{"List":[{"Text":"1. den Verlust oder eine schwere Schädigung der Sprache, des Sehvermögens, des Gehörs oder der Fortpflanzungsfähigkeit,"},{"Text":"2. eine erhebliche Verstümmelung oder eine auffallende Verunstaltung,"},{"Text":"2a. eine Verstümmelung oder sonstige Verletzung der Genitalien, die geeignet ist, eine nachhaltige Beeinträchtigung des sexuellen Empfindens herbeizuführen, oder"},{"Text":"3. ein schweres Leiden, Siechtum oder Berufsunfähigkeit des Geschädigten,"}]}]},{"Text":"herbeiführt, ist mit Freiheitsstrafe von sechs Monaten bis zu fünf Jahren zu bestrafen."}]},{"Text":"(2) Mit Freiheitsstrafe von einem bis zu zehn Jahren ist zu bestrafen, wer einen anderen am Körper verletzt oder an der Gesundheit schädigt und dadurch, wenn auch nur fahrlässig, eine schwere Dauerfolge (Abs. 1) beim Verletzten herbeiführt."}]} New_par: § 85.;{"Item":[{"List":[{"Text":"(1) Wer einen anderen am Körper misshandelt und dadurch fahrlässig für immer oder für lange Zeit"},{"List":[{"List":[{"Text":"1. den Verlust oder eine schwere Schädigung der Sprache, des Sehvermögens, des Gehörs oder der Fortpflanzungsfähigkeit,"},{"Text":"2. eine erhebliche Verstümmelung oder eine auffallende Verunstaltung,"},{"Text":"2a. eine Verstümmelung oder sonstige Verletzung der Genitalien, die geeignet ist, eine nachhaltige Beeinträchtigung des sexuellen Empfindens herbeizuführen, oder"},{"Text":"3. ein schweres Leiden, Siechtum oder Berufsunfähigkeit des Geschädigten,"}]},{"Text":"herbeiführt, ist mit Freiheitsstrafe von sechs Monaten bis zu fünf Jahren zu bestrafen."}]}]},{"Text":"(2) Mit Freiheitsstrafe von einem bis zu zehn Jahren ist zu bestrafen, wer einen anderen am Körper verletzt oder an der Gesundheit schädigt und dadurch, wenn auch nur fahrlässig, eine schwere Dauerfolge (Abs. 1) beim Verletzten herbeiführt."}]}
New_new_para_header: Körperverletzung mit tödlichem Ausgang New_new_para_header: Körperverletzung mit tödlichem Ausgang
New_par: § 86.;{"Item":[{"Text":"(1) Wer einen anderen am Körper misshandelt und dadurch fahrlässig dessen Tod herbeiführt, ist mit Freiheitsstrafe von einem bis zu zehn Jahren zu bestrafen."},{"Text":"(2) Wer einen anderen am Körper verletzt oder an der Gesundheit schädigt und dadurch fahrlässig dessen Tod herbeiführt, ist mit Freiheitsstrafe von einem bis zu fünfzehn Jahren zu bestrafen."}]} New_par: § 86.;{"Item":[{"Text":"(1) Wer einen anderen am Körper misshandelt und dadurch fahrlässig dessen Tod herbeiführt, ist mit Freiheitsstrafe von einem bis zu zehn Jahren zu bestrafen."},{"Text":"(2) Wer einen anderen am Körper verletzt oder an der Gesundheit schädigt und dadurch fahrlässig dessen Tod herbeiführt, ist mit Freiheitsstrafe von einem bis zu fünfzehn Jahren zu bestrafen."}]}
New_new_para_header: Absichtliche schwere Körperverletzung New_new_para_header: Absichtliche schwere Körperverletzung

View File

@ -4,8 +4,9 @@ use std::iter::Peekable;
use roxmltree::{Children, Node}; use roxmltree::{Children, Node};
use crate::law::LawBuilder; use crate::law::LawBuilder;
use crate::paragraph::parser::liste::Liste;
use crate::paragraph::parser::{ use crate::paragraph::parser::{
Absatz, AbsatzAbs, Content, Fzinhalt, Kzinhalt, Liste, Table, Ueberschrift, Absatz, AbsatzAbs, Content, Fzinhalt, Kzinhalt, Table, Ueberschrift,
}; };
#[derive(Debug, PartialEq, Default)] #[derive(Debug, PartialEq, Default)]
@ -30,56 +31,13 @@ impl Abschnitt {
} }
let mut absatze = Vec::new(); let mut absatze = Vec::new();
let absatz = AbsatzAbs::parse(c.next().expect("We need at least one 'Absatz'"));
let par_id = absatz
.gldsym
.clone()
.expect("First 'Absatz' needs to have § id");
// If there's a "liste" after an "absatz", the "liste" should be part of the "absatz" let (par_id, first_abs) = ret.parse_absatz(&mut c);
if let Some(child) = c.peek() { let par_id = match par_id {
if Liste::test(child) { Some(par_id) => par_id,
let liste = Liste::parse(c.next().unwrap()); None => panic!("First paragraph needs to have an id, not found"),
let mut to_add = vec![Content::Text(absatz.content), liste.get_content()]; };
if let Some(subchild) = c.peek() { absatze.push(first_abs);
if Absatz::test_with_typ(subchild, "satz") {
// After a 'liste' there can be a '<absatz typ="satz"' which should be part of the list
// (e.g. 85 StGB)
to_add.push(Content::Text(Absatz::parse(c.next().unwrap()).content));
}
}
absatze.push(Content::List(to_add));
} else if Table::test(child) {
// If there's a "table" after an "absatz", the "table" should be part of the "absatz"
let table = Table::parse(c.next().unwrap());
if let Some(child) = c.peek() {
if Absatz::test_with_typ(child, "erltext") {
let after_absatz = Absatz::parse(c.next().unwrap());
absatze.push(Content::List(vec![
Content::Text(absatz.content),
Content::List(table.get_list()),
Content::Text(after_absatz.content),
]));
} else {
absatze.push(Content::List(vec![
Content::Text(absatz.content),
Content::List(table.get_list()),
]));
}
}
} else if Absatz::test_with_typ(child, "satz") {
// After a 'liste' there can be a '<absatz typ="satz"' which should be part of the list
// (e.g. 1209 ABGB)
absatze.push(Content::List(vec![
Content::Text(absatz.content.clone()),
Content::Text(Absatz::parse(c.next().unwrap()).content),
]));
} else {
absatze.push(Content::Text(absatz.content.clone()));
}
} else {
absatze.push(Content::Text(absatz.content.clone()));
}
//There can be as many 'Absätze' as our lovely lawsetter wants //There can be as many 'Absätze' as our lovely lawsetter wants
while let Some(child) = c.peek() { while let Some(child) = c.peek() {
@ -229,4 +187,69 @@ impl Abschnitt {
} }
true true
} }
// Parses one logical 'Absatz'. If there's a List or Table after the Absatz, RIS assumes this
// one to be included in the paragraph
//
// # Returns
// - String: (optional) paragraph id
// - Content: content of the paragraph
fn parse_absatz(&self, c: &mut Peekable<Children>) -> (Option<String>, Content) {
let absatz = AbsatzAbs::parse(c.next().unwrap());
let par_id = absatz.gldsym;
// If there's a "liste" after an "absatz", the "liste" should be part of the "absatz"
if let Some(child) = c.peek() {
if Liste::test(child) {
println!("11@");
(
par_id,
Content::List(vec![
Content::Text(absatz.content),
Liste::parse_real(c).get_content(),
]),
)
} else if Table::test(child) {
// If there's a "table" after an "absatz", the "table" should be part of the "absatz"
let table = Table::parse(c.next().unwrap());
if let Some(child) = c.peek() {
if Absatz::test_with_typ(child, "erltext") {
let after_absatz = Absatz::parse(c.next().unwrap());
(
par_id,
Content::List(vec![
Content::Text(absatz.content),
Content::List(table.get_list()),
Content::Text(after_absatz.content),
]),
)
} else {
(
par_id,
Content::List(vec![
Content::Text(absatz.content),
Content::List(table.get_list()),
]),
)
}
} else {
(par_id, Content::Text("THIS SHOULD NOT HAPPEN".into()))
}
} else if Absatz::test_with_typ(child, "satz") {
// After a 'liste' there can be a '<absatz typ="satz"' which should be part of the list
// (e.g. 1209 ABGB)
(
par_id,
Content::List(vec![
Content::Text(absatz.content.clone()),
Content::Text(Absatz::parse(c.next().unwrap()).content),
]),
)
} else {
(par_id, Content::Text(absatz.content.clone()))
}
} else {
(par_id, Content::Text(absatz.content.clone()))
}
}
} }

View File

@ -0,0 +1,78 @@
use std::iter::Peekable;
use roxmltree::{Children, Node};
use crate::{
law::Content,
paragraph::parser::{Absatz, Expect, Schlussteil, Ziffernliste},
};
#[derive(Debug)]
pub(crate) struct Liste {
content: Vec<Content>,
}
impl Liste {
pub(crate) fn test(n: &Node) -> bool {
n.tag_name().name() == "liste"
}
//TODO: rename: parse_full
pub(crate) fn parse_real(n: &mut Peekable<Children>) -> Self {
Expect::from(n.peek().unwrap()).tag("liste");
let mut content = Vec::new();
let mut c = n.next().unwrap().children().peekable();
// Parse stuff inside <liste>
while let Some(child) = c.peek() {
if Ziffernliste::test(child) {
content.push(Ziffernliste::parse(c.next().unwrap()).get_content());
} else if Schlussteil::test(child) {
// 162 Schifffahrtsgesetz show use that a 'schlussteil' can be at the start of a list
content.push(Content::Text(Schlussteil::parse(c.next().unwrap()).content));
} else {
break;
}
}
// Parse stuff after <liste>, which logically still is for the list
while let Some(child) = n.peek() {
if Absatz::test_with_typ(child, "satz") {
content.push(Content::Text(Absatz::parse(n.next().unwrap()).content));
} else {
break;
}
}
Self { content }
}
pub(crate) fn parse(n: Node) -> Self {
Expect::from(&n).tag("liste");
let mut content = Vec::new();
let mut c = n.children().peekable();
while let Some(child) = c.peek() {
if Ziffernliste::test(child) {
content.push(Ziffernliste::parse(c.next().unwrap()).get_content());
} else if Schlussteil::test(child) {
// 162 Schifffahrtsgesetz show use that a 'schlussteil' can be at the start of a list
content.push(Content::Text(Schlussteil::parse(c.next().unwrap()).content));
} else if Absatz::test_with_typ(child, "satz") {
content.push(Content::Text(Absatz::parse(c.next().unwrap()).content));
} else {
break;
}
}
assert_eq!(c.next(), None);
Self { content }
}
pub(crate) fn get_content(&self) -> Content {
Content::List(self.content.clone())
}
}

View File

@ -15,6 +15,7 @@
// limitations under the Licence. // limitations under the Licence.
mod abschnitt; mod abschnitt;
mod liste;
use abschnitt::Abschnitt; use abschnitt::Abschnitt;
use roxmltree::Node; use roxmltree::Node;
@ -270,53 +271,6 @@ impl Schlussteil {
} }
} }
#[derive(Debug)]
pub(crate) struct Liste {
content: Vec<Content>,
}
impl Liste {
pub(crate) fn test(n: &Node) -> bool {
n.tag_name().name() == "liste"
}
pub(crate) fn parse(n: Node) -> Self {
assert!(Self::test(&n));
let mut content = Vec::new();
let mut c = n.children().peekable();
// 162 Schifffahrtsgesetz show use that a 'schlussteil' can be at the start of a list
while let Some(child) = c.peek() {
if Schlussteil::test(child) {
content.push(Content::Text(Schlussteil::parse(c.next().unwrap()).content));
} else {
break;
}
}
content.push(Ziffernliste::parse(c.next().unwrap()).get_content());
while let Some(child) = c.peek() {
if Ziffernliste::test(child) {
content.push(Ziffernliste::parse(c.next().unwrap()).get_content());
} else if Schlussteil::test(child) {
content.push(Content::Text(Schlussteil::parse(c.next().unwrap()).content));
} else {
break;
}
}
assert_eq!(c.next(), None);
Self { content }
}
pub(crate) fn get_content(&self) -> Content {
Content::List(self.content.clone())
}
}
#[derive(Debug, PartialEq)] #[derive(Debug, PartialEq)]
pub(crate) struct AbsatzAbs { pub(crate) struct AbsatzAbs {
gldsym: Option<String>, gldsym: Option<String>,