当然我正在做一些非常错误的提升:replace_all。请进行理智检查?

时间:2012-11-29 10:32:49

标签: c++ string replace

我想要一种有效的方法来执行搜索并替换字符串(实际上它是一个着色器字符串),所以我做了一些研究并提出了boost :: replace_all。我的函数传递一个字符串和一个或多个向量。每对是一对弦;搜索并用字符串替换。我想迭代这组替换,修改进程中的字符串。这就是我想出的:

void 
Shader::Read(ShaderTypes type, std::string const & shader, std::vector<std::pair<std::string, std::string>> const & replace)
{
    // Perform search and replace on input string.

    std::string newShader = shader;

    std::for_each(replace.begin(), replace.end(), [newShader](std::pair<std::string, std::string> const & pair) {
        boost::replace_all(newShader, pair.first, pair.second);
    });




    // Create and compile shader.

    Read(type, newShader);
}

现在这不会编译。我从提升中得到了一些错误。我认为这与对象是const有关,但我不是100%肯定。当我尝试手动创建一个std ::对并用它调用replace_all时,它有效。不喜欢它从lambda到达的形式。

有人可以帮我吗?

2 个答案:

答案 0 :(得分:2)

您应该通过引用捕获newShader

std::for_each(replace.begin(), replace.end(), [&newShader](...

答案 1 :(得分:1)

我很确定应该通过引用lambda来传递newShader。而且您不必提供其名称,您可以使用[&amp;]自动捕获。