Я хотел бы создать функцию, которая создает регулярное выражение, соответствующее произвольной строке, заданной на входе. Например, когда я пишу его с помощью 123$, он должен соответствовать буквально "123$", а не 123 в конце строки.
def convert( xs: String ) = (xs map ( x => "\\"+x)).mkString
val text = """ 123 \d+ 567 """
val x = """\d+"""
val p1 = x.r
val p2 = convert(x).r
println( p1.toString )
\d+ // regex to match number
println( ( p1 findAllIn text ).toList )
List(123, 567) // ok, numbers are matched
println( p2.toString )
\\\d\+ // regex to match "backshash d plus"
println( ( p2 findAllIn text ).toList )
List() // nothing matched :(
Итак, последний findAllIn должен найти \d+ в тексте, но это не так. Что здесь не так?