WikiDer > Макропроцессор общего назначения

General-purpose macro processor

А универсальный макропроцессор или же общее назначение препроцессор это макрос процессор, который не привязан к определенному языку или части программного обеспечения и не интегрирован с ним.

Макропроцессор - это программа, которая копирует поток текста из одного места в другое, делая при этом систематический набор замен. Макропроцессоры часто встраиваются в другие программы, такие как ассемблеры и компиляторы. Иногда это отдельные программы, которые можно использовать для обработки любого текста.

Макропроцессоры использовались для расширения языка (определения новых языковых конструкций, которые могут быть выражены в терминах существующих языковых компонентов), для систематических замен текста, требующих принятия решений, и для переформатирования текста (например, условного извлечения материала из HTML файл).

Примеры макропроцессоров общего назначения

ИмяГодОписание
GPM1960-еОдним из первых макропроцессоров был GPM ( Макрогенератор общего назначения).[1] Он был разработан в Кембриджском университете, Великобритания, в середине 1960-х годов под руководством Кристофер Стрейчи.
ML / I1960-еОдним особенно важным макропроцессором общего назначения был (и остается) ML / I (Макро-язык один). Он был разработан в рамках докторского исследования аспирантом Кембриджа Питером Дж. Брауном. ML / I работает с потоком символов и не требует специального формата для его ввода или каких-либо специальных флаговых символов для введения макросов.
M61960-еРанний макропроцессор, разработанный в AT&T Bell Laboratories компанией Дуглас Макилрой, Роберт Моррис и Эндрю Холл. На него повлияли GPM и ПРОФ. Реализовано в FORTRAN IV,[2] он был перенесен на Версия 2 Unix.
aa_macro2017aa_macro - это язык обработки текста на основе потока символов с открытым исходным кодом, написанный на Python. Текст обрабатывается слева направо, изнутри наружу. Набор предварительно определенных встроенных функций обеспечивает основные механизмы обработки, которые могут использоваться напрямую или как элементы пользовательских стилей. Язык является расширяемым пользователем, и доступна веб-оболочка для подготовки документов wtfm с открытым исходным кодом.[3][4]
ЭТАП 21960-еСовременником ML / I был STAGE2,[5] часть Уильяма Уэйта Система мобильного программирования. Это тоже макропроцессор общего назначения, но он обрабатывает ввод по строке за раз, сопоставляя каждую строку с указанными шаблонами; он примечателен тем, что он не зависит от набора символов, требуя только, чтобы цифры 0-9 были смежными.
ТТМ1968ТТМ - это рекурсивный интерпретирующий язык, разработанный в первую очередь для обработки строк, редактирования текста, определения и расширения макросов и других приложений, обычно классифицируемых как системное программирование. Он был разработан в 1968 году Стивеном Кейном и Э. Кентом Гордоном в Калифорнийский технологический институт. Это происходит, прежде всего, из GAP.[6] и GPM.[1]
GMP1970-е годыДругой попыткой был GMP (General Macro Processor), разработанный в середине 1970-х годов М. Боулем в отделе DLB / GC компании CII на основе идей Р.Дж. Chevance. Протестированная в сотрудничестве с Университетом Бордо I. Первая версия работала с системой SIRIS8 / IRIS80. Он был перенесен на системы mini6 и был основным компонентом, задействованным в генерация системы для этого семейства компьютеров. Процессор GMP использовал грамматики C2-Chomsky для определения синтаксиса макросов и использовал императивный язык для выполнения вычислений и перехода к расширению макросов.
Гема1995gema - это контекстный макропроцессор, основанный на сопоставлении с образцом, написанный Дэвидом Н. Греем. Он заменяет / расширяет концепцию обычные выражения по контекстам. Контексты примерно соответствуют именованным наборам шаблонов. Как следствие, макросы в gema очень похожи на EBNF описание.[7]
GPP1996gpp - еще один общий макропроцессор, написанный Дени Ауро. Он похож на препроцессор C, но имеет более общую семантику и позволяет настраивать синтаксис (например, TeX, XHTML, и Пролог-подобные скрипты могут быть определены).[8]
M51999m5 - это макропроцессор общего назначения, написанный Уильямом А. Уордом-младшим. В отличие от многих макропроцессоров, m5 не интерпретирует напрямую свой ввод. Вместо этого он использует двухпроходный подход, в котором первый проход транслирует ввод в программу awk, а второй проход выполняет программу awk для получения окончательного вывода.
пиэспандер2011pyexpander - это макропроцессор общего назначения, основанный на Python язык программирования. В дополнение к простой замене макроса он позволяет оценивать произвольные выражения Python и выполнять код Python, делая pyexpander Тьюринг завершен.[9]
Ассемблер текста2014Text Assembler - это универсальный текстовый / макропроцессор, основанный на JavaScript язык программирования. Помимо простой замены макроса, он позволяет оценивать произвольные выражения JavaScript и выполнять код JavaScript. Он также может загружать модели данных JSON для более сложных задач обработки текста на основе данных.[10]
PP2016PP - это текстовый препроцессор, разработанный для Пандок (и в более общем плане Markdown и reStructuredText). ПП реализует: макросы, грамотное программирование, GraphViz, PlantUML и диаграммы дитаа, Bash, Cmd, PowerShell, Python и Haskell скрипты.[11]
XPOPXPOP ​​был еще одной попыткой создания общего языка обработки макросов, сделанной Марком Халперном из IBM в 1960-х годах.
M41977м4 был разработан для Unix к Брайан Керниган и Деннис Ричи.
MinimacMinimac - это минималистский макропроцессор общего назначения. Он работает как фильтр потока символов, рекурсивно расширяя макросы по мере их появления. Для макропроцессора необычно то, что он использует явный стек аргументов, а пользовательские функции определяются конкатенацией (аналогично Четвертый язык).[12]
СНОБОЛ1960-еСНОБОЛ - это язык обработки строк, который может выполнять большую часть предварительной обработки, которую может выполнять макропроцессор.
ЕЛЕНАПрограммное обеспечение: практика и опыт, Vol. 14, стр. 519–531, июнь 1984 г.

Смотрите также

Рекомендации

  1. ^ а б Стрейчи, Кристофер (Октябрь 1965 г.). «Макрогенератор общего назначения». Компьютерный журнал. 8 (3): 225–241. Дои:10.1093 / comjnl / 8.3.225.
  2. ^ Коул, А. Дж. (1981). Макро процессоры (2-е, перераб.). КУБОК Архив. п. 254.
  3. ^ "aa_macro". Получено 2017-11-24.
  4. ^ "wtfm". Получено 2017-11-24.
  5. ^ Уэйт, Уильям М. (июль 1970 г.). «Система мобильного программирования: STAGE2». Коммуникации ACM. Нью-Йорк, Нью-Йорк, США: ACM. 13 (7): 415–421. Дои:10.1145/362686.362691.
  6. ^ Фарбер, Д. Дж., Система сборки 635 - GAP. Вычислительный центр Bell Telephone Laboratories (1964).
  7. ^ "Хема". gema.sourceforge.net. Получено 2017-04-21.
  8. ^ «ГПЗ». logological.org/gpp. Получено 21 апреля, 2017.
  9. ^ «Добро пожаловать в документацию pyexpander! - документация pyexpander 1.7.0». pyexpander.sourceforge.net. Получено 2017-04-21.
  10. ^ «akiwi - Ассемблер текста». www.akiwi.co.uk. Получено 2017-04-21.
  11. ^ Делорд, Кристоф. "PP - общий препроцессор (с учетом Pandoc)". cdsoft.fr. Получено 2017-10-17.
  12. ^ "минимак". freshmeat.net. Получено 2017-04-21.