# 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
}
PEQUOD (de) - Forgotten (2011)
Label : Thunderblast Records
Sortie du Scud : 9 avril 2011
Pays : Allemagne
Genre : Thrash / Death / Metalcore
Type : Album
Playtime : 11 Titres - 45 Mins
En voilà un groupe qui aura mis du temps à faire ses preuves. PEQUOD, ça s’est formé en 1998 à Munich et ça aura mis treize ans pour sortir un misérable premier album. Après l’EP éponyme de 2004, les rats ont quitté le navire et seuls Daniel Kirstein et Jens Burbass, les deux guitaristes, ont survécu à ce naufrage en bonne et due forme, approuvé par Francesco Schettino, capitaine émérite du Costa Concordia. Au début Thrash teinté d’Electro, la musique des Allemands s’est peu à peu affinée pour aboutir sur un Thrash / Metalcore bestial et explosif. La sortie de Forgotten en 2011 est donc le point de départ officiel d’une carrière qui, plus d’un an après la parution du disque, semble toujours au point mort. Et croyez-moi, c’est pas faute d’avoir essayé.
Parce qu’il est diablement bon, cet album. Peut-être un peu maladroit et rentre-dedans, mais quand même ! Un visuel délicieux, une musique qui l’est tout autant, il n’en fallait pas plus pour faire exploser PEQUOD. En vain. Ne serait-ce que l’introduction, « Bleed… », pourtant courte d’une minute et vingt secondes, suffit à poser les bases écrasantes de leur musique. Un Thrash dynamité au Death, alliage astucieux de nuances old-school et d’une production plastique très actuelle. Ce qui m’a vite frappé, c’est leur capacité à musicaliser leurs compositions. Le Thrash / Death, ça m’évoque un fouillis monstre d’où ressortent quelques solos placés au petit bonheur la chance pour faire illusion. Ces Allemands ne sont pas de ceux là. « … To Death » met rapidement l’accent sur des ambiances glauques, grâce à ses arrangements torturés et à sa vitesse supersonique. Mais c’est véritablement « Sickness » qui fera forte impression. Son début est plutôt commun, mais son final épique et mélodique, digne d’un AMON AMARTH est saisissant. Techniquement irréprochable, PEQUOD ne fera alors plus que confirmer ces belles dispositions. Entre « Tragedy » et « A Vortical Experience », mon cœur balance. Mais c’est finalement « Forgotten » qui remportera le morceau. Au moment même où je me disais qu’un petit mid-tempo ferait du bien, les Teutons sortent cette composition de derrière les fagots, aux accents presque Doom. Et le choix n’est pas innocent. Peut-être le saviez-vous déjà, mais Pequod est en réalité le nom du baleinier commandé par le capitaine Ahab dans la nouvelle Moby-Dick d’Herman Melville. Et devinez qui vient chanter sur cette compo ? Je vous le donne en mille. Daniel Droste du groupe de Funeral Doom AHAB ! Si ça, c’est pas de la symbolique, alors j’y comprends plus rien. Et le plus fort dans tout ça, c’est pas ce morceau, c’est celui qui suit. Probablement le mieux agencé et le plus équilibré de tout l’album, « My Redemption » est un énorme titre de Metal extrême moderne comme il ne s’en fait plus. Il y a tout dedans : l’intensité, le mordant, les variations rythmiques, l’écriture, les tempos martiaux, la petite mélodie perverse, la voix postillonnante de Roland Wagner (qui ne porte pas pour rien un patronyme célèbre). On retrouve d’ailleurs ce même phrasé humide sur « A Hunter’s Tale », en compagnie de Nick Kolar de COMMANDER. De A à Z, je n’ai pas peur de vous le crier, ce Forgotten est une tuerie !
Et je vais vous dire autre chose. Un album qui termine encore plus fort qu’il a commencé, c’est définitivement un grand album. Sorti de la banlieue munichoise, PEQUOD est une petite révolution en ces temps difficiles pour le Thrash / Death mélodique. Ils ont tout pour eux. Ils sont jeunes, ils sont talentueux, ils ont désormais une putain de référence sur leur C.V. Et avec tout ça, comment expliquer leur relative impopularité ? C’est ce genre de groupes qui devrait exploser, pas les THE CROWN et les FACEBREAKER… Forgotten, oui, ils ont été oubliés.
Ajouté : Mercredi 24 Octobre 2012 Chroniqueur : Stef. Score : Lien en relation: Pequod Website Hits: 11600
|