13
0
livetrax/libs/pbd/search_path.cc
Tim Mayberry 0abcfb16ba Replace code for finding ControlProtocols/Surface plugins with a portable equivalent.
Remove Session::control_protocol_path and the supporting non-portable
Session::suffixed_search_path from Session.

Add ARDOUR::control_protocol_search_path which is used in place of
Session::control_protocol_path

Replace ARDOUR::get_system_module_path with ARDOUR::system_module_directory which
is used by ARDOUR::control_protocol_search_path

Export ARDOUR_SURFACES_PATH in gtk2_ardour/ardev_common.sh which is returned
by ARDOUR::control_protocol_search_path if defined. This means the control surfaces
in the libs/surfaces/* directories can now be used without installing them.

Add pbd/file_utils.h/cc containing functions for finding files matching a certain
pattern

Update documentation in SearchPath and add another constructor that takes
a sys::path


git-svn-id: svn://localhost/ardour2/trunk@2049 d708f5d6-7413-0410-9779-e7cbd77b26cf
2007-06-27 12:12:18 +00:00

153 lines
3.1 KiB
C++

/*
Copyright (C) 2007 Tim Mayberry
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 2 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, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <pbd/tokenizer.h>
#include <pbd/search_path.h>
#include <pbd/error.h>
namespace {
#ifdef WIN32
const char * const path_delimiter = ";";
#else
const char * const path_delimiter = ":";
#endif
}
namespace PBD {
SearchPath::SearchPath ()
{
}
SearchPath::SearchPath (const string& path)
{
vector<sys::path> tmp;
if(tokenize (path, string(path_delimiter), std::back_inserter (tmp)))
{
add_directories (tmp);
}
}
SearchPath::SearchPath (const sys::path& directory_path)
{
add_directory (directory_path);
}
SearchPath::SearchPath (const vector<sys::path>& paths)
{
add_directories (paths);
}
SearchPath::SearchPath (const SearchPath& other)
: m_dirs(other.m_dirs)
{
}
void
SearchPath::add_directory (const sys::path& directory_path)
{
// test for existance and warn etc?
m_dirs.push_back(directory_path);
}
void
SearchPath::add_directories (const vector<sys::path>& paths)
{
for(vector<sys::path>::const_iterator i = paths.begin(); i != paths.end(); ++i) {
add_directory (*i);
}
}
const string
SearchPath::get_string () const
{
string path;
for (vector<sys::path>::const_iterator i = m_dirs.begin(); i != m_dirs.end(); ++i) {
path += (*i).to_string();
path += path_delimiter;
}
path = path.substr (0, path.length() - 1); // drop final separator
return path;
}
SearchPath&
SearchPath::operator= (const SearchPath& path)
{
m_dirs = path.m_dirs;
return *this;
}
SearchPath&
SearchPath::operator+= (const SearchPath& spath)
{
m_dirs.insert(m_dirs.end(), spath.m_dirs.begin(), spath.m_dirs.end());
return *this;
}
SearchPath&
SearchPath::operator+= (const sys::path& directory_path)
{
add_directory (directory_path);
return *this;
}
SearchPath&
SearchPath::operator+ (const sys::path& directory_path)
{
add_directory (directory_path);
return *this;
}
SearchPath&
SearchPath::operator+ (const SearchPath& spath)
{
// concatenate paths into new SearchPath
m_dirs.insert(m_dirs.end(), spath.m_dirs.begin(), spath.m_dirs.end());
return *this;
}
SearchPath&
SearchPath::add_subdirectory_to_paths (const string& subdir)
{
for (vector<sys::path>::iterator i = m_dirs.begin(); i != m_dirs.end(); ++i)
{
// should these new paths just be added to the end of
// the search path rather than replace?
*i /= subdir;
}
return *this;
}
SearchPath&
SearchPath::operator/= (const string& subdir)
{
return add_subdirectory_to_paths (subdir);
}
} // namespace PBD