// // aegis - project change supervisor // Copyright (C) 1998, 1999, 2004-2008 Peter Miller // // This program is free software; 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. // // This program 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 this program. If not, see // . // #include #include #include #include #include #include #include #include rpt_func_basename::~rpt_func_basename() { } rpt_func_basename::rpt_func_basename() { } rpt_func::pointer rpt_func_basename::create() { return pointer(new rpt_func_basename()); } const char * rpt_func_basename::name() const { return "basename"; } bool rpt_func_basename::optimizable() const { return true; } bool rpt_func_basename::verify(const rpt_expr::pointer &ep) const { return (ep->get_nchildren() == 1); } rpt_value::pointer rpt_func_basename::run(const rpt_expr::pointer &ep, size_t, rpt_value::pointer *argv) const { rpt_value::pointer arg = argv[0]; assert(!arg->is_an_error()); arg = rpt_value::stringize(arg); rpt_value_string *rvsp = dynamic_cast(arg.get()); if (!rvsp) { sub_context_ty sc; sc.var_set_charstar("Function", "basename"); sc.var_set_long("Number", 1); sc.var_set_charstar("Name", argv[0]->name()); nstring s ( sc.subst_intl ( i18n("$function: argument $number: string value required " "(was given $name)") ) ); return rpt_value_error::create(ep->get_pos(), s); } nstring pathname(rvsp->query()); // // extract the final path element // nstring s = pathname.basename(); // // build the result // return rpt_value_string::create(s); } rpt_func_dirname::~rpt_func_dirname() { } rpt_func_dirname::rpt_func_dirname() { } rpt_func::pointer rpt_func_dirname::create() { return pointer(new rpt_func_dirname()); } const char * rpt_func_dirname::name() const { return "dirname"; } bool rpt_func_dirname::optimizable() const { return true; } bool rpt_func_dirname::verify(const rpt_expr::pointer &ep) const { return (ep->get_nchildren() == 1); } rpt_value::pointer rpt_func_dirname::run(const rpt_expr::pointer &ep, size_t, rpt_value::pointer *argv) const { rpt_value::pointer arg = argv[0]; assert(!arg->is_an_error()); arg = rpt_value::stringize(arg); rpt_value_string *rvsp = dynamic_cast(arg.get()); if (!rvsp) { sub_context_ty sc; sc.var_set_charstar("Function", "dirname"); sc.var_set_long("Number", 1); sc.var_set_charstar("Name", argv[0]->name()); nstring s ( sc.subst_intl ( i18n("$function: argument $number: string value required " "(was given $name)") ) ); return rpt_value_error::create(ep->get_pos(), s); } nstring pathname(rvsp->query()); // // extract the final path element // nstring d = pathname.dirname(); // // build the result // return rpt_value_string::create(d); }