Я собираюсь выполнить побочный проект, целью которого является перевод кода с одного языка программирования на другой. Языки, которые я начинаю с PHP и Python (с Python на PHP должно быть проще начать), но в идеале я мог бы добавить другие языки с (относительной) легкостью. План таков:
Это ориентировано на веб-разработку. Оригинал и целевой код будет находиться поверх фреймворков (которые мне тоже придется написать). Эти платформы будут охватывать шаблон проектирования MVC и следовать строгим соглашениям о кодировании. Это должно несколько упростить перевод.
Я также смотрю на IOC и внедрение зависимостей, поскольку они могут упростить процесс перевода и уменьшить вероятность ошибок.
Я воспользуюсь модулем синтаксического анализатора Python , который позволяет мне возиться с абстрактное синтаксическое дерево. По-видимому, самое близкое, что я могу получить с PHP, - это token_get_all () , что является началом.
С этого момента я могу создавать AST, таблицы символов и поток управления.
Тогда я могу начать выводить код. Мне не нужен идеальный перевод . Мне все равно придется просмотреть сгенерированный код и исправить проблемы. В идеале переводчик должен отмечать проблемные переводы.
Прежде чем вы спросите " )
val g : Function2[A, B, C] //or possibly
val g : Function1[(A, B), C]
в терминах f
?
scala> val f : Int => Int => Int = a => b => a + b
f: (Int) => (Int) => Int = <function1>
scala> Function.uncurried(f)
res0: (Int, Int) => Int = <function2>
Расширение ответа ретонима для полноты
val f : Int => Int => Int = a => b => a + b
val g: (Int, Int) => Int = Function.uncurried(f)
val h: ((Int, Int)) => Int = Function.tupled(g)
Обратные функции для обеих этих операций также предусмотрены в объекте Function, так что вы можете написать вышеизложенное в обратном порядке, если хотите
val h: ((Int, Int)) => Int = x =>(x._1 + x._2)
val g: (Int, Int) => Int = Function.untupled(h)
val f : Int => Int => Int = g.curried //Function.curried(g) would also work, but is deprecated. Wierd
Чтобы завершить ответ, хотя для этого есть библиотечный метод, может быть поучительным сделать это вручную:
scala> val f = (i: Int) => ((s: String) => i*s.length)
f: (Int) => (String) => Int = <function1>
scala> val g = (i: Int, s: String) => f(i)(s)
g: (Int, String) => Int = <function2>
Или в общем,
def uncurry[A,B,C](f: A=>B=>C): (A,B)=>C = {
(a: A, b: B) => f(a)(b)
}