module ReplaceP where
replaceP :: String -> String
replaceP (x:y:z:u:v:xs) | x == '[' && y == '\"' && z == '[' && u == '\\' && v == '\\' = "[\"\\" ++ replaceP xs
| x == ',' && y == '\\' && z == '\\' = "\",\"\\" ++ replaceP (u:v:xs)
| x == ']' && y == '\"' && z == ']' = "\"]" ++ replaceP (u:v:xs)
| otherwise = x:replaceP (y:z:u:v:xs)
replaceP (x:y:z:u:xs) | x == ',' && y == '\\' && z == '\\' = "\",\"\\" ++ replaceP (u:xs)
| x == ']' && y == '\"' && z == ']' = "\"]" ++ replaceP (u:xs)
| otherwise = x:replaceP (y:z:u:xs)
replaceP (x:y:z:xs) | x == ',' && y == '\\' && z == '\\' = "\",\"\\" ++ replaceP xs
| x == ']' && y == '\"' && z == ']' = "\"]" ++ replaceP xs
| otherwise = x:replaceP (y:z:xs)
replaceP xs = xs
replaceP2 :: String -> String
replaceP2 (x:y:z:u:v:xs) | [x,y,z,u,v] == "\\1078" = '\1078':replaceP2 xs
| [x,y,z,u,v] == "\\1079" = '\1079':replaceP2 xs
| [x,y,z,u,v] == "\\1100" = '\1100':replaceP2 xs
| otherwise = x:replaceP2 (y:z:u:v:xs)
replaceP2 (x:xs) = x:replaceP2 xs
replaceP2 [] = []
replaceP3 :: String -> String
replaceP3 (x:y:xs) | [x,y] == "\\ж" = "\\1078" ++ replaceP3 xs
| [x,y] == "\\з" = "\\1079" ++ replaceP3 xs
| [x,y] == "\\ь" = "\\1100" ++ replaceP3 xs
| otherwise = x:replaceP3 (y:xs)
replaceP3 (x:xs) = x:replaceP3 xs
replaceP3 [] = []