/*^* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * @software : pluie-yaml * @version : 0.60 * @type : library * @date : 2018 * @license : GPLv3.0 * @author : a-Sansara <[dev]at[pluie]dot[org]> * @copyright : pluie.org * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * This file is part of pluie-yaml. * * pluie-yaml is free software (free as in speech) : you can redistribute it * and/or modify it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the License, * or (at your option) any later version. * * pluie-yaml 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 General Public License for * more details. * * You should have received a copy of the GNU General Public License * along with pluie-yaml. If not, see . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *^*/ /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * @software : pluie-yaml * @version : 0.5 * @type : library * @date : 2018 * @licence : GPLv3.0 * @author : a-Sansara <[dev]at[pluie]dot[org]> * @copyright : pluie.org * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * This file is part of pluie-yaml. * * pluie-yaml is free software (free as in speech) : you can redistribute it * and/or modify it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the License, * or (at your option) any later version. * * pluie-yaml 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 General Public License for * more details. * * You should have received a copy of the GNU General Public License * along with pluie-yaml. If not, see . * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ using GLib; using Gee; using Pluie; int main (string[] args) { Echo.init(false); var path = Yaml.DATA_PATH + "/tag.yml"; var done = false; of.title ("Pluie Yaml Library", Pluie.Yaml.VERSION, "a-sansara"); Pluie.Yaml.DEBUG = false; Yaml.Object? obj = null; var config = new Yaml.Config (path, true); var root = config.root_node (); root.display_childs (); var list = new Gee.HashMap (); if ((done = root != null)) { foreach (var node in root) { of.action ("Yaml.Object from node", node.name); of.echo (node.to_string (false)); if ((obj = (Yaml.Object) Yaml.Builder.from_node (node)) != null) { list[node.name] = obj; } else { of.error ("cannot set Yaml.Object from node : %s".printf (node.name), true); } node = node.next_sibling (); } } // hard code Samples.YamlObject? o = null; foreach (var entry in list.entries) { if ((o = (Samples.YamlObject) entry.value)!=null) { of.action ("Getting Hard coded values for Samples.YamlObject %s".printf (of.c (ECHO.MICROTIME).s (o.get_type().name ())), entry.key); of.keyval("yaml_name" , "%s" .printf(o.yaml_name)); of.keyval("type_int" , "%d" .printf(o.type_int)); of.keyval("type_bool" , "%s" .printf(o.type_bool.to_string ())); of.keyval("type_char" , "%c" .printf(o.type_char)); of.keyval("type_string" , "%s" .printf(o.type_string)); of.keyval("type_uchar" , "%u" .printf(o.type_uchar)); of.keyval("type_uint" , "%u" .printf(o.type_uint)); of.keyval("type_float" , "%f" .printf(o.type_float)); of.keyval("type_double" , "%f" .printf(o.type_double)); of.keyval("type_struct" , "%s" .printf(o.type_struct.to_string ())); of.keyval("type_enum" , "%d (%s)" .printf(o.type_enum, o.type_enum.infos())); of.keyval("type_object" , "%s" .printf(o.type_object.get_type ().name ())); of.keyval(" toto" , "%s (string)" .printf(o.type_object.toto)); of.keyval(" tapa" , "%s (string)" .printf(o.type_object.tata)); of.keyval(" titi" , "%d (int)" .printf(o.type_object.titi)); of.keyval(" tutu" , "%s (bool)" .printf(o.type_object.tutu.to_string ())); o.type_object.method_a (); if (o.type_gee_al!= null) { of.keyval("type_gee_al", "(%s)" .printf(o.type_gee_al.get_type ().name ())); foreach (var v in o.type_gee_al) { of.echo(" - item : %g".printf (v)); } } if (o.type_gee_alobject != null) { of.keyval("type_gee_alobject", "(%s<%s>)" .printf(o.type_gee_alobject.get_type ().name (), o.type_gee_alobject.element_type.name ())); foreach (var child in o.type_gee_alobject) { of.echo(" == entry (%s) ==".printf(child.get_type ().name ())); of.keyval(" toto" , "%s (string)" .printf(child.toto)); of.keyval(" tapa" , "%s (string)" .printf(child.tata)); of.keyval(" titi" , "%d (int)" .printf(child.titi)); of.keyval(" tutu" , "%s (bool)" .printf(child.tutu.to_string ())); child.method_a (); } } if (o.type_gee_hmap != null) { of.keyval("type_gee_hmap", "(%s<%s, %s>)" .printf(o.type_gee_hmap.get_type ().name (), o.type_gee_hmap.key_type.name (), o.type_gee_hmap.value_type.name ())); foreach (var child in o.type_gee_hmap.entries) { of.echo(" == entry (%s) ==".printf(child.key)); of.keyval(" toto" , "%s (string)" .printf(child.value.toto)); of.keyval(" tapa" , "%s (string)" .printf(child.value.tata)); of.keyval(" titi" , "%d (int)" .printf(child.value.titi)); of.keyval(" tutu" , "%s (bool)" .printf(child.value.tutu.to_string ())); } } if (o.type_gee_hmap2 != null) { of.keyval("type_gee_hmap", "(%s<%s, %s>)" .printf(o.type_gee_hmap2.get_type ().name (), o.type_gee_hmap2.key_type.name (), o.type_gee_hmap2.value_type.name ())); foreach (var child in o.type_gee_hmap2.entries) { of.echo(" == key =="); of.keyval(" obj :" , "%s" .printf(child.key.to_string ())); of.echo(" == val (%s) ==".printf(child.value.get_type ( ).name ())); of.keyval(" toto" , "%s (string)" .printf(child.value.toto)); of.keyval(" tapa" , "%s (string)" .printf(child.value.tata)); of.keyval(" titi" , "%d (int)" .printf(child.value.titi)); of.keyval(" tutu" , "%s (bool)" .printf(child.value.tutu.to_string ())); } } else { of.echo ("hmap2 null"); } } } of.rs (done); of.echo (); return (int) done; }