Skip to content

Commit

Permalink
Fix namespace renaming so that it works with current Trunk.
Browse files Browse the repository at this point in the history
[SVN r62738]
  • Loading branch information
jzmaddock committed Jun 10, 2010
1 parent 638f0ca commit 19d628a
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 13 deletions.
7 changes: 4 additions & 3 deletions add_path.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -71,10 +71,11 @@ void bcp_implementation::add_directory(const fs::path& p)
std::string s(i->string());
if(m_boost_path.string().size())
s.erase(0, m_boost_path.string().size() + 1);
if(!m_dependencies.count(fs::path(s)))
fs::path np = s;
if(!m_dependencies.count(np))
{
m_dependencies[fs::path(s)] = p; // set up dependency tree
add_path(fs::path(s));
m_dependencies[np] = p; // set up dependency tree
add_path(np);
}
++i;
}
Expand Down
55 changes: 45 additions & 10 deletions copy_path.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,33 @@ void bcp_implementation::copy_path(const fs::path& p)
//
// do text based copy if requested:
//
if(m_namespace_name.size() && m_lib_names.size() && is_jam_file(p))
if(p.leaf() == "Jamroot")
{
static std::vector<char> v1, v2;
v1.clear();
v2.clear();
std::ifstream is((m_boost_path / p).native_file_string().c_str());
std::copy(std::istreambuf_iterator<char>(is), std::istreambuf_iterator<char>(), std::back_inserter(v1));

static boost::regex libname_matcher;
if(libname_matcher.empty())
{
libname_matcher.assign("boost_");
}

regex_replace(std::back_inserter(v2), v1.begin(), v1.end(), libname_matcher, m_namespace_name + "_");
std::swap(v1, v2);
v2.clear();

std::ofstream os;
if(m_unix_lines)
os.open((m_dest_path / p).native_file_string().c_str(), std::ios_base::binary | std::ios_base::out);
else
os.open((m_dest_path / p).native_file_string().c_str(), std::ios_base::out);
os.write(&*v1.begin(), v1.size());
os.close();
}
else if(m_namespace_name.size() && m_lib_names.size() && is_jam_file(p))
{
static std::vector<char> v1, v2;
v1.clear();
Expand Down Expand Up @@ -106,25 +132,33 @@ void bcp_implementation::copy_path(const fs::path& p)

static const boost::regex namespace_matcher(
"(?|"
"(namespace\\s+)boost(_\\w+)?"
"(namespace\\s+)boost(_\\w+)?(?:(\\s*::\\s*)phoenix)?"
"|"
"(namespace\\s+)(adstl|phoenix|rapidxml)\\>"
"|"
"()boost((?:_\\w+)?\\s*(?:::|,|\\)))"
"()\\<boost((?:_(?!intrusive_tags)\\w+)?\\s*(?:::))(?:(\\s*)phoenix)?"
"|"
"()((?:adstl|phoenix|rapidxml)\\s*(?:::|,|\\)))"
"()\\<((?:adstl|phoenix|rapidxml)\\s*(?:::))"
"|"
"(namespace\\s+\\w+\\s*=\\s*(?:::\\s*)?)boost(_\\w+)?"
"(namespace\\s+\\w+\\s*=\\s*(?:::\\s*)?)boost(_\\w+)?(?:(\\s*::\\s*)phoenix)?"
"|"
"(namespace\\s+\\w+\\s*=\\s*(?:::\\s*)?)(adstl|phoenix|rapidxml)\\>"
"(namespace\\s+\\w+\\s*=\\s*(?:::\\s*)?(?:\\w+\\s*::\\s*)?)(adstl|phoenix|rapidxml)\\>"
"|"
"(^\\s*#\\s*define[^\\n]+)boost((?:_\\w+)?\\s*)$"
"(^\\s*#\\s*define\\s+\\w+\\s+)boost((?:_\\w+)?\\s*)$"
"|"
"(^\\s*#\\s*define[^\\n]+)((?:adstl|phoenix|rapidxml)\\s*)$"
"|"
"()boost(_asio_detail_posix_thread_function|_regex_free_static_mutex)"
"|"
"()(lw_thread_routine|at_thread_exit|on_process_enter|on_process_exit|on_thread_enter|on_thread_exit|tss_cleanup_implemented)"
"|"
"(BOOST_CLASS_REQUIRE4?[^;]*)boost((?:_\\w+)?\\s*,)"
"|"
"(\\(\\s*)boost(\\s*\\))"
")"
);
);

regex_replace(std::back_inserter(v2), v1.begin(), v1.end(), namespace_matcher, "$1" + m_namespace_name + "$2");
regex_replace(std::back_inserter(v2), v1.begin(), v1.end(), namespace_matcher, "$1" + m_namespace_name + "$2(?3$3" + m_namespace_name + "phoenix)", boost::regex_constants::format_all);
std::swap(v1, v2);
v2.clear();

Expand Down Expand Up @@ -171,7 +205,8 @@ void bcp_implementation::copy_path(const fs::path& p)
os.open((m_dest_path / p).native_file_string().c_str(), std::ios_base::binary | std::ios_base::out);
else
os.open((m_dest_path / p).native_file_string().c_str(), std::ios_base::out);
os.write(&*v1.begin(), v1.size());
if(v1.size())
os.write(&*v1.begin(), v1.size());
os.close();
}
else if(m_unix_lines && !is_binary_file(p))
Expand Down

0 comments on commit 19d628a

Please sign in to comment.