# Copyright (C) 2002-2004 gregoire HUBERT.
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# Author : gregoire HUBERT
#
# XML_node.objet
#
# This object is an XML node representation
#
# /- name (string)
# xml_node --- attributes (array)
# \- children (array) or value (string)
class xml_node {
var $name;
var $attributes = array();
var $children = array();
var $value = "";
function xml_node($name,$attributes,$children=array(),$value="") {
$this->name = $name;
if (is_array($attributes)) {
$this->attributes = $attributes;
}
$this->children = $children;
$this->value = $value;
}
}
# Copyright (C) 2003-2004 gregoire HUBERT.
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 2.1 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# Author : gregoire HUBERT
#
# xml_tree class
#
# This object parses an XML stream and offers a tree composed by xml_nodes
#
class xml_tree {
var $xml_stream;
var $current_node;
var $root_node;
var $index;
var $value;
function xml_tree() {
$this->root_node = new xml_node("__ROOT_NODE",array());
$this->current_node = $this->root_node;
}
function add_tree($xml_stream) {
# Managing the parser
$this->xml_stream = $xml_stream;
$xml_parser = xml_parser_create();
xml_parser_set_option($xml_parser,XML_OPTION_CASE_FOLDING,0);
xml_parser_set_option($xml_parser,XML_OPTION_SKIP_WHITE,1);
if (!xml_parse_into_struct($xml_parser,$this->xml_stream,$this->value,$this->index)) {
xml_parser_free($xml_parser);
die("XML Parse error");
}
xml_parser_free($xml_parser);
# Now, $this->value and $this->index are informed, we can use the get_node methode.
$tab_result = $this->get_node(0,count($this->value) - 1);
$this->root_node->children[] = $tab_result[0];
$this->current_node = $this->root_node;
}
function get_node($index_start,$index_stop) {
#echo " \n";
#echo "GET-NODE($index_start,$index_stop) \n";
# What we are going to return is an array of xml_nodes
$return_tab = array();
# depth is only here to check if everything is all right
$tab_node = $this->value[$index_start];
$depth = $tab_node["level"]-1;
# Now we have to be sure we do not forget a single node
for ($index = $index_start;$index <= $index_stop;$index++) {
#echo "\$index = $index ";
# get the current node
$tab_node = $this->value[$index];
# what type of node is it ?
switch($tab_node["type"]) {
case "complete" :
# Depth integrity check
if ($tab_node["level"] != $depth+1) {
die("ERREUR # contrainte d'intégrité au noeud complet $index, niveau $depth + 1 au lieu de ".$tab_node["level"]);
}
#echo "Noeud complet trouvé position $index TAG ".$tab_node["tag"]." \n";
# Easy one, no children to manage, only a value...
$return_tab[] = new xml_node($tab_node["tag"],$tab_node["attributes"],"",$tab_node["value"]);
break;
case "open" :
# Depth integrity check
if ($tab_node["level"] != $depth +1 ) {
die("ERREUR # contrainte d'intégrité au noeud ouvert $index, niveau $depth au lieu de ".$tab_node["level"]);
}
# Open tag, we re-use this methode to return its children
# Where is the correspondong close tag ?
$node_index = $this->index[$tab_node["tag"]];
$flipped_node_index = array_flip($node_index);
#echo "This ".$tab_node["tag"]." is at coords ".$flipped_node_index[$index]." ";
$i=1;
do {
$next_index = $node_index[$flipped_node_index[$index] + $i++];
$next_tag=$this->value[$next_index];
}
while ($next_tag["level"]!=$tab_node["level"]);
#echo "Ouverture de noeud détectée pos $index TAG ".$tab_node["tag"]." \n Parcours jusqu au $next_index \n";
# good, we can now instanciate our node
$return_tab[] = new xml_node($tab_node["tag"],$tab_node["attributes"],$this->get_node($index+1,$next_index),"");
# As we called the get_node methode, we are sure that nodes have been parsed to the corresponding close tag
$index = $next_index;
break;
case "close" :
# Depth integrity check
if ($tab_node["level"] != $depth ){
die("ERREUR # contrainte d'intégrité au noeud fermé $index, niveau $depth au lieu de ".$tab_node["level"]);
}
#echo "Fermeture de noeud detectée pos $index TAG ".$tab_node["tag"]."
\n";
# This ugly thing is useless because reaching a close tag means that $index==$index_stop but who knows ? =)
# it will be skipped soon
$index = $index_stop;
break;
default:
die("Erreur de type de TAG non déterminé :'".$tab_node["type"]."'");
}
}
# We are out ... returns the array with collected children...
return ($return_tab);
}
# this function browse the xml tree and set the current node to the selected node
function give_node($path) {
if ($path[0]=="/") {
$current_node=$this->root_node;
$path=substr($path,1);
#echo "ABSOLUTE PATH GIVEN=$path ";
}
else {
$current_node = $this->current_node;
}
#echo "PATH GIVEN=$path ";
$tab_path = split("/",$path);
foreach ($tab_path as $node_expr) {
#echo "STUDYING EXPR='$node_expr' ";
$node = $current_node;
$expr_tab = split("\?",$node_expr);
$node_name = $expr_tab[0];
$attr_tab = 0;
if (count($expr_tab)>1) {
##echo "TROUVE AU MOINS UNE CONDITION SUR LES ATTRIBUTS... ";
$attr_expr_tab=split(",",$expr_tab[1]);
$attr_tab=array();
foreach($attr_expr_tab as $attr_expr) {
$attr_split_expr=split("=",$attr_expr);
$attr_tab[$attr_split_expr[0]]=$attr_split_expr[1];
}
}
$last=0;
foreach ($node->children as $children) {
#echo "COMPARING WITH '$children->name' ";
if ($children->name == $node_name) {
##echo "TROUVE NOEUD CORRESPONDANT $node_name ";
if (is_array($attr_tab)) {
$node_attributes = $children->attributes;
foreach ($attr_tab as $key=>$value) {
if ($node_attributes[$key] == $value) {
#echo "ATTRIBUTE & CHANGE CURRENT NODE TO ".$children->name." ";
$current_node = $children;
$last = 1;
}
}
}
else {
##echo "CHILD=".$children->name." ";
#echo "CHANGE CURRENT NODE TO ".$children->name." ";
$current_node = $children;
$last=1;
}
}
if ($last) {
break;
}
}
if (!$last) {
#echo "PATH ERROR $node_name ";
#die("MMmmmh It seems that this file is not a DIA XML format...sorry...");
return 0;
}
}
return $current_node;
}
function browse_tree($path) {
$node = $this->give_node($path);
if (is_object($node)) {
$this->current_node = $node;
return 1;
}
return 0;
}
# this method dumps an html representation of the xml tree
function xml_show($node = "",$level=0,$last=0) {
if ($node=="") {
$node=$this->root_node;
}
if (!is_object($node)) {
die("ERROR : node is not an object");
}
$line="";
for($i=1;$i<=$level;$i++) {
if ((i==$level-1) and ($last)) {
$line.=" ";
}
else {
$line.=" |";
}
if ($i==$level) {
$line.="`-";
}
}
$line.=$node->name;
#echo $line;
$line.="".count($node->children)."";
if (count($node->children)==1) {
$line.=" (".$node->value.") \n";
echo "$line";
}
else {
$line.=" \n";
echo "$line";
$i=1;
foreach($node->children as $children) {
if ($i==count($node->children)) {
$this->xml_show($children,$level+1,1);
}
else {
$this->xml_show($children,$level+1);
}
$i++;
}
}
}
#END_CLASS
}
NOVEMBRE (it) - Materia (2006)

Label : Peaceville Records / Pias
Sortie du Scud : 17 avril 2006
Pays : Italie
Genre : Gothic Metal
Type : Album
Playtime : 11 Titres - 68 Mins
Les groupes de Doom / Gothic Metal ont le vent en poupe en ce moment à en croire les ventes et le succès rencontrés par des formations telles que KATATONIA, MY DYING BRIDE ou MOONSPELL. Nouveau poulain dans la célèbre écurie Anglaise Peaceville Records, les Italiens de NOVEMBRE ont commencé leur carrière en 1990, époque à laquelle ils s’appelaient encore CATACOMB.
Le trio Romain composé des frères Orlando (Carmelo aux guitares et au chant, Giuseppe à la batterie) et de Massimiliano Pagliuso à la guitare en est à sa cinquième livraison studio avec ce Materia. Les Transalpins avaient entre-temps produit des albums qui ont connu du succès comme Dreams d’Azur en 2002 (ré-enregistrement de leur premier album Wish I Could Dream It Again) ou Novembrine Waltz édité en 2001.
Fini donc le Death Progressif présent sur Novembrine Waltz, le trio Romain a radicalement changé de direction et opté pour un Gothic Metal mélancolique, doux et enchanteur. Et force est de constater que NOVEMBRE n’a pas grand chose à envier aux groupes cités ci-dessus ! Au contraire, les Italiens s’en sortent avec les honneurs et démontrent qu’ils sont capables de catcher dans la même catégorie. Tout d’abord, on ne peut que louer leur propension à écrire leurs textes en italien et en anglais. Les paroles dans la langue de Dante se marient parfaitement avec le style pratiqué. De plus, les vocaux suaves tout en réverbe de Carmelo Orlando participent à la création de ce charme méditerranéen. Les riffs vaporeux et aériens de la doublette Orlando/Pagliuso sont en harmonies avec ses lignes vocales.
Généreux dans leurs expérimentations, surtout après un album de Death Prog’, les Romains n’hésitent pas à sortir des sentiers battus et à prendre leur public à contre-pied. Album aux nuances chargé d’ambiances spleen, les morceaux sont séduisants et emplis d’émotions. NOVEMBRE fait étalage de sa grande ouverture d’esprit à travers l’opus. Nombreux sont les passages mélodieux, à tel point que Materia constitue une sorte d’invitation à un voyage onirique dans un monde poétique et cafardeux à la fois. On passe ainsi des mélodies planantes et mélancoliques comme sur les titres « Verne » ou « Jules » à des morceaux plus durs mais tout aussi envoûtant comme le single « Memoria Stoica/ Vetro » et « Comedia », une piste bien plus nerveuse et qui renoue avec le passé musical de NOVEMBRE. D’autre part, pour montrer que les Italiens sont de bons songwriters, l’hypnotique et éthéré « The Promise » porte bien son nom. Quant au morceau éponyme, il s’agit là de Doom dans sa splendeur, sombre et morose, un des rare titre ou C.Orlando pose des voix typées Death. La plage dix répondant du nom de « Croma » se veut pour sa part être un titre à l’ambiance spleenesque et torturée.
La production rend grâce au talent du trio. Pas grand chose à redire si ce n’est que le gros son se fond bien avec des arrangements tout en discrétion et en douceur. Maintenant, revers de la médaille car il y en a un, là où réside la force de cet opus avec cette profusion de mélodies doucereuses et accablées, on ne peut que faire la mou lorsque l’on se rend compte de la longue durée des morceaux, ce qui peut procurer à l’auditeur un évident coup de fatigue et de déconcentration. Plus d’une heure, et on attend qu’une chose à la fin… la fin justement ! Nonobstant, les Italiens ont frappé un grand coup cette année avec ce bon album et prouve que l’Italie sait produire pas mal de groupes de Metal dans des styles divers et variés. Une direction qui nous espérons sera maintenu par NOVEMBRE…
Ajouté : Vendredi 23 Juin 2006 Chroniqueur : Loki Score :     Lien en relation: Novembre Website Hits: 14989
|