// // aegis - project change supervisor // Copyright (C) 1999, 2002-2006, 2008, 2012 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 // // NAME // os_dirname_relative - take path apart // // SYNOPSIS // string_ty *os_dirname_relative(string_ty *path); // // DESCRIPTION // Os_dirname is used to extract the directory part // of a pathname. If none, result is "." // // RETURNS // pointer to dynamically allocated string. // // CAVEAT // Use str_free() when you are done with the value returned. // string_ty * os_dirname_relative(string_ty *path) { trace(("os_dirname_relative(path = %p)\n{\n", path)); trace_string(path->str_text); const char *cp = strrchr(path->str_text, '/'); string_ty *s = 0; if (!cp) s = str_from_c("."); else if (cp == path->str_text) s = str_from_c("/"); else s = str_n_from_c(path->str_text, cp - path->str_text); trace_string(s->str_text); trace(("}\n")); return s; } nstring os_dirname_relative(const nstring &path) { trace(("os_dirname_relative(path = \"%s\")\n{\n", path.c_str())); const char *cp = strrchr(path.c_str(), '/'); if (!cp) { trace(("return \".\";\n}\n")); return "."; } if (cp == path.c_str()) { trace(("return \"/\";\n}\n")); return "/"; } nstring result(path.c_str(), cp - path.c_str()); trace(("return \"%s\";\n", result.c_str())); trace(("}\n")); return result; } // vim: set ts=8 sw=4 et :