АвтоЛИСП - реализация языка программирования

Глава 1
Введение
АвтоЛИСП - реализация языка программирования ЛИСП, вложенного в пределах системы АвтоКАД. АвтоЛИСП позволяет пользователям и разработчикам АвтоКАДА писать макропрограммы и функции на очень высоком, находящем графическое применение, уровне языка. ЛИСП очень гибок, легок в изучении и применении.
Замечание
Для более эффективного применения АвтоКАДА нет необходимости изучать АвтоЛИСП; если у вас нет опыта компьютерного программирования, прочтите тольно установочные требования в главе 2 - это позволит вам увидеть применяемые АвтоЛИСПом преимущества многочисленных меню АвтоКАДА. Однако, если вам нравится программировать, прочтите это руководство до конца, чтобы узнать как применять АвтоЛИСП для преобразования основного назначения пакета изготовления чертежей АвтоКАДА в более мощный инструмент программиста.
Данная книга - справочник, а не учебник по программированию. Хотя в главе 3 мы и приводим пример практического применения АвтоЛИСПа, мы все же рекомендуем достать различные тексты на ЛИСПе для изучения этого языка программирования: Винстон и Хорн "LISP" (второе издание), "Looking at LISP" Тони Хасемера (обе книги опубликованы Эддисоном Веслей). ЛИСП - язык, содержащий много диалектов: МакЛИСП, ИнтерЛИСП, ЗетаЛИСП и КоммонЛИСП. АвтоЛИСП по синтаксису и условным обозначениям наиболее близок к КоммонЛИСПу, но он с меньшим подмножеством и имеет больше специфических для АвтоКАДа дополнительных функций. Этот справочник содержит все функции автоЛИСПа и способы их применения.
1.1 Типы данных в АвтоЛИСПе
АвтоЛИСП содержит несколько различных типов данных:
- lists - списки
- symbols - символы
- strings - строчки
- real numbers - действительные числа
- integers - целые числа
- file descriptors -дескрипторы файла
- AutoCAD entity "names" - "имена" объектов АвтоКАДа
- AutoCAD selection-sets - секции установок АвтоКАДа
- subrs (build-in functions) - (встроенные функции)
Целые числа - 16-битные числа со знаком с диапазоном от -32768 до +32767. Действительные числа представлены как плавающая точка с двойной точностью. Строчки могут быть любой длины, их память динамически распределяется.
АвтоЛИСП содержит несколько встроенных функций по обеспечению базиса для программирования чертежей в двух и трех измерениях. При работе с графическими координатами, рассматриваются следующие условные обозначения:
2D points - выражены как перечни двух действительных чисел
(X Y):
(3.400000 7.520000 )
Первое значение - координата X, второе - Y.
3D points - выражены как перечни трех действительных чисел
(X Y Z ):
(3.400000 7.520000 1.000000)
Первое значение - координата X,второе -Y, третье -Z.
Всякий раз при требовании АвтоКАДа ввести определенный тип (например, точку или масштабный коэффициент) может применяться выражение этого типа или функция АвтоЛИСПа, вводящая в результате этот тип.
1.2 Вычислитель языка АвтоЛИСП
Вычислитель является основой интерпретатора каждого варианта ЛИСПа. Он берет строчку входных данных пользователя, вычисляет ее и выдает результат. В процессе вычисления АвтоЛИСПа участвуют:
- целые, действительные числа; строчки; дескрипторы файла; встроенные функции - вычисляются по отношению сами к себе;
- символы - вычисляются к значению их текущей компоновки;
- списки - вычисляются согласно их первого элемента, если они вычисляются в:
* список (или пустой список); список предполагает быть определением функции, а функция вычисляется с применением значений остальных элементов списка в качестве параметров.
* название внутренней функции (subrs); оставшиеся элементы списка проходят в subr как формальные параметры и вычисляются с помощью subr.
Если в ответ на подсказку АвтоКАДа "Command:" вы вводите выражение на языке АвтоЛИСП, АвтоЛИСП вычислит выражение и напишет результат. Подсказка АвтоКАДа "Command:" вновь появится на экране.
Если напечатано или прочитано из файла неправильное выражение, АвтоЛИСП выдаст следующую подсказку:
n>
где n - целое число, обозначающее сколько уровней левых скобок осталось незакрытыми. Если появилась эта подсказка, вы должны напечатать n правых скобок для того, чтобы выйти из этого состояния. Общая ошибка - игнорирование заключенного в круглых скобках значка (") в строке текста; в этом случае правые скобки будут интерпритированы как уже процитированные и не будут учитываться при изменении n. Для того, чтобы исправить это положение, напечатайте перед n правыми скобками кавычки.
1.3 Лексические условные обозначения
Процедура ввода АвтоЛИСПа имеет несколько форм. Ее можно проделать следующим образом: находясь в АвтоКАДе напечатать вызов с клавиатуры; прочитать из ASCII файла или из строчечной переменной. В любом случае необходимо следующее:
- имена символов могут состоять из любого сочетания печатных характеристик,кроме следующих: ( ). ' " ;
- имя символа или числовой константы будут завершаться следующими знаками:
( ) ' " ; (промежуток) (конец линии)
- выражения могут состоять из многочисленных линий;
- многочисленные промежутки между символами эквивалентны единичному промежутку. Пока не требуется смещение, вы можете применять их для придания ясности структуре ваших функций;
- символы и имена функций (subrs) не чувствительны к регистрам в АвтоЛИСПе. Имена символов могут и не начинаться с цифры;
- константы целых чисел могут начинаться с необязательных знаков "+" или "-". Как упоминалось ранее, они находятся в диапазоне от -32768 до +32767;
- константы действительных чисел содержат один или более цифровых разрядов, сопровождаемые точкой десятичной дроби, после которой следуют один или несколько цифровых знаков, например ".4" не рассматривается как действительное число, правильно будет "0.4". Аналогично,"5." недействительно, правильно - "5.0". Действительные числа могут применяться в научных записях т.е. могут встретиться необязательное "е" или "Е", сопровождаемое цифровым показателем;
- буквенные строчки - последовательность символов, заключенная в кавычки. Внутри строки, взятой в кавычки, символ (\) означает возможность включения контрольных символов. Рассмотрим следующие текущие коды:
\\ означает символ "\"
\e означает выход
\n означает новая строка
\r означает ввод
\t означает табуляцию
\nnn означает символ, чей восьмиричный код - nnn
Например, на новой линии появится следующая подсказка:
(prompt "\nEnter first point: ")
- единичный цитируемый символ может применяться как сокращение функции QUOTE. Так, 'foo эквивалентно (quote foo)
- комментарии, взятые из дисковых файлов, могут быть включены в программы АвтоЛИСПа. Комментарии начинаются с двоеточия и продолжаются до конца строки. Например,
:This entire line is a comment
:Эта полная строка - комментарий
(setq area (* pi r r )) :Compute area of circle
:Рассчитайте площадь круга
1.4 Условные обозначения примечаний
Это справочное пособие применяет определенные условные обозначения для документирования режима функций. Например,
(moo ...)
строка цифра
Имя функции показано таким, каким вы должны его ввести. Заключенные в кавычки элементы данных, следующие за именем функции, определяют количество и тип параметров, предполагаемых функцией.
В этом промере функция "moo" имеет два необходимых параметра: строка и цифра. Эллипсис ("...") определяет, что к функции могут быть присоединены дополнительные цифровые параметры. Не включайте в строку скобки или эллипсисы, если вы снабжаете функцию ссылками.
Вызов данного формата функции "moo" показан выше; для функции "moo" будут действительными следующие ссылки:
(moo "Hello" 5)
(moo "Hi" 1 2 3 )
Следующие примеры не соответствуют требуемому формату и приведут к ошибкам:
(moo 1 2 3 ) (первый параметр должен быть строкой)
(moo "Hello") (должен быть хотя бы один цифровой параметр)
(moo "do" '(1 2)) (второй параметр должен быть строкой,а не перечнем)
Когда необязательный параметр может возникнуть один раз, без повторений, он заключается в квадратные скобки ("[]"):
(foo [])
Здесь функция "foo" предполагает один строчечный параметр и принимает один необязательный цифровой параметр. Например, для функции "foo" будут действительны следующие вызовы:
(foo "catch")
(foo "catch" 22)
В этом примере показаны неправильные вызовы:
(foo 44 13) (первый параметр должен быть строчечным)
(foo "foe" 44 13) (слишком много параметров)
1.5 Изменения и расширения
Обработка ошибки
Если АвтоЛИСП сталкивается с ошибкой во время вычисления, он выдает сообщение следующей формы:
error:text
где text - описание ошибки. Если установлена функция "ERROR" (не ноль), АвтоЛИСП,вместо выдачи сообщения, выполняет эту функцию ("text"- ее единственный параметр). Если"ERROR" не установлена, или граничит с нулем, вычисление АвтоЛИСПа останавливается, а на экране появится обратный ход вызова функции и ее вызывающей программы до 100 уровней вглубь.
Глава 2
Установка АвтоЛИСПа
2.1 Требования
Выпуск формата
АвтоЛИСП снабжается любой копией Автокада. Никаких специальных установок не требуется. Файл "acadl.ovl" на рабочей дискете является оверлеем АвтоЛИСПа в АвтоКАДе.
Одна из рабочих дискет АвтоКАДа содержит файл "readme.doc". Просмотрите этот файл; он содержит самые последние изменения и корректировки в документации АвтоКАДа и АвтоЛИСПа.
2.2 Автоматические функции - файл "acad.lsp"
Начиная сеанс работы графического редактора АвтоКАДа, АвтоЛИСП загружает файл "acad.lsp" (если такой существует). На этом файле вы можете задать определения наиболее часто используемых функций и они будут автоматически высчитываться при редактировании чертежа. См.определение функции DEFUN в главе 4.
Глава 3
По садовой дорожке к АвтоЛИСПу
Большое количество мощности АвтоКАДа поступает за счет его способности заказывать ее. Поближе познакомившись с АвтоКАДом, можно заметить, что вам бы хотелось, чтобы у него была некоторая возможность, часто необходимая вам. Вы можете начать добавление последовательности команд, которые вы часто применяете на экране, кнопок или планшетного меню. Вы можете определить новые типы линий, образцы штриховки или текстовый шрифт. Этим вы используете преимущества открытой архитектуры АвтоКАДа - возможность расширить его и сформировать его в ваш персонально-спроектированный инструментарий, реагирующий на особенности вашего мышления и работы.
Язык АвтоЛИСП - наиболее мощное условие для расширения возможностей АвтоКАДа. Эти, обеспеченныеАвтоКАДом благоприятные условия - реализация языка программирования ЛИСП, в сочетании с АвтоКАДом. Составляя программу на АвтоЛИСПе, вы можете добавить команды для АвтоКАДа и иметь больше мощности для модифицирования АвтоКАДа (что и имеют наши разработчики программного обеспечения).
Вскоре мы добавим новую команду для АвтоКАДа. В процессе объяснения принципа работы АвтоЛИСПа, мы дадим вам возможность использования его мощности для работы на вас. Команда, которую мы собираемся создать, сориентирована на архитектуру поверхности, но принципы, которые вы изучите, - релевантные, не считающиеся с вашей областью применения.
3.1 Что вы должны знать перед началом работы
Мы предполагаем,что вы сносно владеете АвтоКАДом - т.е. вы знаете команды АвтоКАДа и общие принципы их применения. Мы также предполагаем, что вы знакомы с текстовым редактором, который может создавать ASCII файлы. Сейчас мы напишем программу, а вы применяйте свой текстовый редактор для выполнения наших заданий.
В этом примере мы будем применять много функций АвтоЛИСПа. Последующие главы этого руководства содержат полное объяснение всех этих функций.
3.2 Задача
Наша задача - создать новую программу для АвтоКАДа, которая рисует садовую дорожку и заполняет ее круглыми плитами.
Наша новая команда будет иметь следующую последовательность команд:
COMMAND: PATH (ДОРОЖКА)
Start point of path: start point
(Начальная точка дорожки: начальная точка)
End point of path: end point
(Конечная точка дорожки: конечная точка)
Half point of path: number
(Половина ширины дорожки: число)
Radius of tiles: number
(Радиус плит: число)
Spacing between tiles: number
(Расстояние между плитами: число)
где начальная и конечная точки определяют центральную линию дорожки. Определяется половина ширины дорожки и вводится радиус круглых плит. Наконец, определяется расстояние между плитами. Половину ширины дорожки мы определяем раньше, чем полную ее ширину потому, что это позволяет более четко определить отрезок типа "резиновая нить" от начальной точки.
3.3 Начало
Мы до конца разовьем эту прикладную задачу (по восходящей). В этой задаче мы будем применять жесткое задание углов.
АвтоЛИСП, как и многие другие языки программирования, определяет углы в радианах. Радианы измеряют углы от 0 до 2'PL. Так как большинство измеряет углы в градусах, мы определим функцию, которая преобразовывает градусы в радианы. Используя ваш редактор текста, создайте файл GP.LSP. Введите следующую программу:
: Convert angle in degree to radians
(defun dtr (a)
(*pi (/a 180.0))
)
Давайте рассмотрим, что это даст. Мы определили функцию, применив в АвтоЛИСПе функцию DEFUN. Функция называется DТR (сокращение от "degrees to radians" ("градусы в радианы")).
Она содержит один параметр "а" - угол в градусах. В результате - выражение:
PI * (a / 180.0)
которое в примечаниях ЛИСПа расшифровывается как: "произведение от PI, умноженное на коэффициент А, разделенное на 180 градусов". PI предопределяется ЛИСПом как 3.1459...; строчка, начинающаяся с двоеточия,- комментарий - АвтоЛИСП игнорирует текст, расположенный после двоеточия.
Сохраните файл на диске, затем перейдите на новый чертеж (имя не имеет значения, т.к. мы не будем сохранять чертеж).
Когда появится подсказка АвтоКАДа "Command:", загрузите функцию, введя:
Command: (load "gp")
АвтоЛИСП загрузит вашу функцию, отражая ее имя в "DТR". Далее в этом руководстве, когда мы говорим : "Введите АвтоКАД и загрузите программу", будет подразумеваться проделанная только что последовательность.
Сейчас мы проверим функцию, выполняя различные действия. Из определения радианы, 0 градусов должно соответствовать нулевой радиане; введите в АвтоКАД строчку:
Command: (dtr 0)
Печатая строку, начинающуюся с левой круглой скобки, вы заставляете АвтоКАД переводить эту строку в АвтоЛИСП для вычисления. В этом случае мы высчитываем функцию DIR, только что определенную нами, передавая ей параметр - ноль. После высчитывания функции, АвтоКАД выдаст результат; так наш ввод выдаст следующий ответ:
0.000000
Теперь давайте попробуем 180 градусов. Если вы введете
Command: (dtr 180)
вы получите ответ:
3.141593
Это показывает, что 180 градусов равно PI радианам. Если вы исследуете функцию, вы убедитесь, что это именно так.
Для выхода из АвтоКАДа введите:
Command: QUIT
и на подсказку
Really want to discard all changes to drawing? Y
(Действительно хотите не учитывать все изменения в чертеже? Д)
ответьте
0
в основном меню для возврата к DOS подсказке. Далее в руководстве под "Выйти из АвтоКАДа" будет подразумеваться эта процедура.
3.4 Ввод
Наша команда garden path (садовая дорожка) запросит у пользователя следующую информацию: где рисовать дорожку, какой ширины ее делать, размер конкретных плит и как близко друг к другу их размещать. Мы определим функцию, которая будет спрашивать пользователя по всем этим пунктам, а затем просчитает цифры, которые мы проставим в конце команды.
Используя редактор текста, добавьте следующие строчки в GP.LSP (мы будем применять вертикальную черту для выделения добавляемых строчек).
: Convert angle in degrees to radians
(defun dtr (a)
('pi (/ a 180.0))
)
| :Acquire information for garden path
| (defun gpuser ()
| (setq sp (getpoint "\nStart point of path:"))
| (setq ep (getpoint "\nEnd point of path:"))
| (setq hwidth (getdist "\nHalf width of path:"sp))
| (setq trad (getdist "\nRadius of tiles:"sp))
| (setq pangle (angle sp ep ))
| (setq plength (distance sp ep ))
| (setq width (' 2 hwidth))
| (setq angp90 (+pangle (dtr 90))) : Path angle +90 deg
| (setq angm90 (-pangle (dtr 90))) : Path angle -90 deg
Необязательно смещать выражения, содержащие ваши функции. Фактически вы можете ввести всю программу в одну строку. Однако, смещение и прерывание строчки служит созданию более понятной и четкой для чтения структуры программы. Также, расположение начальных и конечных круглых скобок основных выражений на одной оси, способствует уверенности, что ваши скобки верно сбалансированы.
Итак, мы определили функцию GPUSER. Она не принимает параметров, а спрашивает пользователя по всем пунктам. Функция SETQ приводит переменную АвтоЛИСПа к определенному значению. Первая SETQ приводит переменную SP (начальная точка ) к результату функции GETPOINT. Пользователь задает точки для функции GETPOINT. Для получения точки будет применяться строка, определяющая подсказку АвтоКАДа. "\n" заставляет подсказку появиться на новой линии. Мы применяем функцию GETPOINT для получения значения середины ширины дорожки, радиуса плиты и расстояния между плитами. Второй параметр функции GETPOINT, SP, определяет "базовую точку" расстояния. Расстояние можно создать, определив в АвтоКАДе точку, соответствующую начальной точке дорожки, и присоединив к ней линию резиновой нити.
После ввода высчитываются наиболее часто применяемые переменные. PANGLE обозначает угол от начальной до конечной точки дорожки. Функция ANGLE вводит этот угол по заданным двум точкам. PLENGTH вводит длину дорожки. Функция DISTANCE рассчитывает расстояние, заданное двумя точками. Задав половину ширины дорожки, мы рассчитываем общую ширину, умножив на два заданную величину. И, наконец, мы рассчитываем и сохраняем угол дорожки плюс-минус 90 градусов в переменных ANGP90 и ANGM90 соответственно (т.к. углы в АвтоЛИСПе рассчитываются в радианах, мы перед этими рассчетами применили функцию DTR для перевода градусов в радианы).
Сохраните эту откорректированную программу на диске, запустите АвтоКАД и загрузите программу. Сейчас мы проверим функцию ввода, чтобы убедиться, что она работает правильно.
Приведите в действие функцию, напечатав:
Command: (gpuser)
Ответьте на подсказки следующим образом:
Начальная точка дорожки: 2,2
Конечная точка дорожки: 9,8
Половина ширины дорожки: 2
Радиус плиты:.2
Расстояние между плитами:.1
GPUSER использует ваши ответы для подсчета необходимых ему дополнительных переменных и на экране появится результат последних подсчетов (в данном случае - 0,826169, значение ANGM90 в радианах). Вы можете разгрузить все переменные, установленные функцией GPUSER путем подстановки восклицательного знака (!) перед их именами. Это заставит АвтоКАД вычислить переменные и выдать результат на экран. Если вы введете следующие команды, вы получите следующие результаты:
Command: !sp
(2.000000 2.000000)
Command: !ep
(9.000000 8.000000)
Command: !hwidth
2.000000
Command: !width
4.000000
Command: !trad
0.200000
Command: !tspac
0.100000
Command: !pangle
0.708626
Command: !plength
9.219544
Command: !angp90
2.279423
Command: !angm90
-0.862169
Обратите внимание, что PANGLE, ANGP90 и ANGM90 представлены в радианах. После проверки этих значений, выйдите из АвтоКАДа и вернитесь в свой текстовый редактор в GP.LSP.
3.5 Добавление команд в АвтоКАД
Наконец, мы готовы объединить все составные части в команду АвтоКАДа. Если мы определим функцию с именем C:XXX на языке АвтоЛИСП, вводя ХХХ (предполагая,что ХХХ не является командой АвтоКАДа) мы активизируем функцию. Для завершенности ввода в работу нашей команды PATH, мы определяем функцию C:PATH, что дает возможность нам впоследствии после загрузки GP.LSP напечатать только PATH и наша команда garden path будет вычисляться.
Используйте ваш текстовый редактор для добавления указанной строчки в GP.LSP, затем запустите АвтоКАД и загрузите программу.
С добавлением функции C:PATH, мы добавили команду PATH в АвтоКАД. Вы можете проверить команду, осуществив следующий ввод:
Команда: PATH
Начальная точка дорожки: 2,2
Конечная точка дорожки: 9,8
Половина ширины дорожки: 2
Радиус плиты:.2
Расстояние между плитами:.1
3.6 Замораживание
Так как наша команда PATH выполняется, все команды, которые она представляет в АвтоКАД, будут передаваться в область команд/подсказок и все выбранные ею точки будут отмечаться на экране маленькими черточками (метками). Раз командная функция налажена, для появления вводных команд АвтоЛИСПа точно похожих на команды АвтоКАДа, этот ввод может быть отменен.
Применение функции GETVAR необходимо, чтобы получить текущие значения режимов АвтоКАДА BLIPMODE и CMDECHO. Они сохраняются через SETQ в SBLIP и SCMDE. Затем мы применяем функцию SETVAR для того, чтобы установить обе эти переменные АвтоКАДа в нулевое положение; этим делая недействительными метки и переданные команды. Обратите внимание, что мы установили эти переменные в нулевое положение после получения ввода от пользователя через GPUSER. Мы хотим, чтобы метки остались для подтверждения ввода пользователя.
После того, как мы закончили черчение дорожки, мы используем функцию SETVAR для восстановления первоначального значения этих переменных.
Сохраните файл, запустите АвтоКАД и попробуйте сейчас команду PATH. Испробуйте ее со всех сторон, определяя различные виды ввода как при помощи поинтера, так и клавиатуры.
3.7 Резюме
За короткий период времени вы ввели новую команду в АвтоКАД. Во многих системах КАД вам понадобится следующее: доступ к исходному коду системы КАД, квалификация программиста и большой запас знаний для проделывания операций, подобно этой. Открытая архитектура АвтоКАДа и АвтоЛИСПа предоставляет вам возможности, которые большинство продавцов систем КАД приберегают для себя.
Вы можете применять этот пример как исходную ступень к мастерству в АвтоЛИСПе. Вы можете начать с модифицирования и расширения команды PATH, создание которой вы сейчас завершили. Попробуйте начертить квадратные и шестиугольные плиты. Для более полной ориентации, создайте новую команду, которая принимает центральную точку и площадь, и рисует квадрат определенной площади, заполненный плитами. Вы можете просмотреть только что записанные функции в тесной связи с оставшимися главами этого руководства. Здесь мы дали очень краткое описание работы и возможностей функций. АвтоЛИСП содержит много возможностей, опробовав которые и ближе познакомившись с ними, вы сможете полнее их использовать.
Поскольку вы запустили АвтоЛИСП в работу, вы перешли на новый уровень совершенства в АвтоКАДе. По мере использования АвтоЛИСПа для автоматизации изготовления чертежей и конструкторских задач, вы освободите себя от различных деталей и сможете полностью посвятить себя проектированию. В "лице" АвтоЛИСПа вы приобрели неутомимого помощника, который будет служить вам десятилетия.
Глава 4
Функции АвтоЛИСПа
АвтоЛИСП снабжен многочисленными предопределенными функциями. Каждая функция вызывается путем задания ее имени (верхний или нижний регистр) как первого элемента списка, с параметрами (если такие существуют) как последующими элементами списка.
В этой главе вы найдете алфавитный список основных базовых функций АвтоЛИСПа. Для удобства пользования функции сгруппированы в предметном указателе в конце справочника. Вы обнаружите, что многие функции стандартные, их можно обнаружить в каждой реализации языка программирования ЛИСП. Другие же функции уникальны для интерактивных графических программных средств, обеспечиваемых АвтоКАДом. В последующих главах описываются некоторые функции с улучшенными свойствами.
4.1 (+ ...)
Эта функция вводит сумму всех <чисел>. Она может применяться с действительными и целыми числами. Если <числа> - целые числа, результат будет выражен целыми числами; если же одно из чисел - действительное, целые числа переходят в действительные и результат будет выражен действительным числом.
Например:
(+1 2) вводит 3
(+1 2 3 4.5) вводит 10.500000
(+1 2 3 4.0) вводит 10.000000
4.2 (- < number > ...)
Эта функция вычитает второе <число> из первого и вводит разницу. Если задано более двух <чисел>, из первого числа вычитается сумма от второго до последнего элемента и вводится конечный результат. Если задано только одно <число>, вводится результат вычитания его из нуля. Эта функция может применяться с действительнвми и целыми числами, со стандартными правилами перехода.
Например:
(-50 40) вводит 10
(-50 40.0 2) вводит 8.000000
(-50 40.0 2.5) вводит 7.500000
(-8) вводит -8
4.3 (* ...)
Эта функция вводит произведение всех <чисел>. Она может применяться с действительными и целыми числами со стандартными правилами перехода.
Например:
(* 2 3) вводит 6
(* 2 3 4.0) вводит 8.000000
(* 3 -4.5) вводит -13.500000
4.4 (/ ...)
Эта функция делит первое <число> на второе и вводит частное. Если задано более двух <чисел>, первое <число> делится на произведение второго и всех последующих чисел и вводится конечное частное.
Примеры:
(/100 2) вводит 50
(/100 2.0) вводит 50.000000
(/100 20 2.0) вводит 2.500000
(/100.0 20 2) вводит 2.500000
(/100 20 2) вводит 2
(/135 360) вводит 0
(/135 360.0) вводит 0.375000
4.5 (= ...)
Это относительная функция "равно чему-либо". Она вводит T, если все определенные <числа> равны в числовом отношении, во всех других случаях вводится ноль. Эта функция также действительна для строчек.
Примеры:
(=4 4.0) вводит T
(=20 388) вводит nil
(=2.4 2.4 2.4) вводит T
(=499 499 500) вводит nil
(="me" "me") вводит T
(="me" "you") вводит nil
4.6 (/= )
Это относительная функция "не равно чему-либо". Она вводит T, если <число 1> не равно <числу 2>, в противном случае вводится nil. Если задано более двух параметров, функция не определяется. Например:
(/=10 20) вводит T
(/=5.43 5.43) вводит nil
(/=5.43 5.44) вводит T
4.7 (< ...)
Это относительная функция "менее, чем". Она вводит T, если первое <число> меньше второго, и nil если наоборот. Если задано более двух <чисел>, T вводится в том случае, если каждые из чисел меньше, чем <число> справа от него. Например:
(< 10 20) вводит T
(< 4 4) вводит nil
(< 357 33.2) вводит nil
(< 2 3 88) вводит T
(< 2 3 4 4) вводит nil
4.8 (<= ...)
Это относительная функция "менее или равно". Она вводит T, если первое <число> менее или равно второму и nil в других случаях. Если задано более двух <чисел>, T вводится в том случае, если каждое число меньше или равно <числу>, стоящему справа от него. Например:
(<= 10 20) вводит T
(<= 4 4) вводит T
(<= 357 33.2) вводит nil
(<= 2 9 9) вводит T
(<= 2 9 4 5) вводит nil
4.9 (> ...)
Это относительная функция "больше, чем". Она вводит T, если первое <число> больше, чем второе и nil, если наоборот. Если задано больше двух <чисел>, T вводится при условии, что каждое число больше стоящего справа. Например:
(> 120 17) вводит T
(> 57 57) вводит nil
(> 3.5 1792) вводит nil
(> 77 4 2) вводит T
(> 77 4 4) вводит nil
4.10 (>= ...)
Это относительная функция "больше или равно". Она вводит T, если первое <число> больше или равно второму, и nil в противном случае. Если задано больше двух <чисел>, T вводится при условии, что каждое число больше или равно <числу> справа от него. Например:
(>= 120 17) вводит T
(>= 57 57) вводит T
(>= 3.5 1792) вводит nil
(>= 77 4 4) вводит T
(>= 77 4 9) вводит nil
4.11 (- )
Эта функция вводит подразрядный НЕТ (NOT) (чье-то дополнение) <чисел>. <Число> должно быть целым. Например:
(-3) вводит -4
(-100) вводит -101
(- -4) вводит 3
4.12 (1+ )
Эта функция вводит <число>, увеличенное на единицу (приращенное). <Число> может быть действительным или целым. Например:
(1+ 5) вводит 6
(1+ -17.5) вводит -16.500000
4.13 (1- )
Эта функция вводит <число>, уменьшенное на единицу (декрементированное). <Число> может быть действительным или целым. Например:
(1- 5) вводит 4
(1- -17.5) вводит -18.500000
4.14 (abs )
Эта функция вводит абсолютное значение <числа>. <Число> может быть действительным или целым. Например:
(abs 100) вводит 100
(abs -100) вводит 100
(abs -99.25) вводит 99.250000
4.15 (and ...)
Эта функция вводит логическое И (AND) списка выражений. Она вводит ноль, если любое из выражений вычисляется к нулю, в противном случае она вводит T. Например, заданы следующие назначения:
(setq a 103)
(setq b nil)
(setq c "string")
тогда:
(and 1.4 a c) вводит T
(and 1.4 a b c) вводит nil
4.16 (angle )
Эта функция вводит угол (в радианах) между 2D точками и , когда 2D точка - перечень двух действительных чисел. Например:
(angle '(1.0 1.0) '(1.0 4.0)) вводит 1.570796
(angle '(5.0 1.33) '(2.4 1.33)) вводит 3.141593
4.17 (angtos [ []])
Эта функция берет <угол> (действительный, в радианах) и вводит его отредактирован-ным в виде строки. Параметр /<режим> - целое число; следующим образом он диктует тип выполняемого редактирования:
Режим ANGTOS Формат Редактирования
------------ ---------------------
0 Градусы
1 Градусы/минуты/секунды
2 Грады
3 Радианы
4 Топографические единицы
Параметр /<точность> - целое число, которое выбирает желаемое количество десятичных знаков точности. <режим> и <точность> соответствуют системе переменых AUNITS и AUPREC АвтоКАДа. Если вы пропускаете параметры, будут применяться текущие установки AUNITS и AUPREC.
Например,заданы следующие назначения:
(setq pt1 '(5.0 1.33))
(setq pt2 '(2.4 1.33))
(setq a (angle pt1 pt2))
тогда:
(angtos a 0 0) вводит "180"
(angtos a 0 4) вводит "180.0000"
(angtos a 1 4) вводит "180d0'0"
(angtos a 3 4) вводит "3.1416r"
(angtos a 4 2) вводит "W"
4.18 (append ...)
Эта функция берет любое количество элементов (/<выражений>) и соединяет их вместе в один перечень. Например
(append '(a b) '(c d)) введет (A B C D)
(append '((a)(b)) '((c)(d)) введет ((A)(B)(C)(D))
APPEND требует,чтобы ее параметры были в виде списков.
4.19 (apply )
Выполняет функцию, определенную /<функцией> с параметрами, заданными в /<списке>. Например:
(apply ' + '(1 2 3)) вводит 6
(apply 'stract' ("a" "b" "c")) вводит "abc"
APPLY работает как со встроенными (subrs), так и с определенными пользователем (эти создаются как с помощью DEFUN, так и LAMBDA) функциями.
4.20 (ascii )
Эта функция вводит переход первого символа <строки> в ее знаковый код ASCII (целые числа). Это то же, что и функция ASC в языке БЕЙСИК. Например:
(ascii "A") вводит 65
(ascii "a") вводит 97
(ascii "BIG") вводит 66
4.21 (assoc )
Эта функция ищет список ассоциаций для единицы () как ключевого элемента и вводит содержимое . Если не найден как ключ в , ASSOC вводит ноль. Например, предположим, что список "al" определен как:
((name box) (width 3) (size 4.7263) (depth 5))
тогда:
(assoc 'size al) вводит (SIZE 4.7263)
(assoc 'weight al) вводит nil
Список ассоциаций часто используется для запоминания данных, которые могут выбираться как "ключ". Это похоже на матрицы и структуры в других языках программирования. Функция SUBST, описанная далее в этой главе, обеспечивает удобные способы отмены значений, ассоциируемые с одним ключем в перечне ассоциаций.
4.22 (atan [])
Если не задается, ATAN вводит арктангенс в радианах. может быть отрицательным, диапазон вводимых углов от -pt до +pt радиан. Например:
(atan 0.5) вводит 0.463647
(atan 1.0) вводит 0.785398
(atan -1.0) вводит -0.785398
(angtos (atan -1.0) 0 4) вводит "-45.0000"
Если заданы оба параметра ( и ), вводится арктангенс / в радианах. Если - ноль, вводится угол в плюс или минус 1.570796 радиан (90 или -90 градусов) в зависимости от знака . Например:
(atan 2.0 3.0) вводит 0.588002
(angtos (atan 2.0 3.0) 0 4) вводит "33.6901"
(atan 2.0 -3.0) вводит 2.553590
(angtos (atan 2.0 -3.0) 0 4) вводит "146.3099"
(atan -2.0 3.0) вводит -0.588002
(atan -2.0 -3.0) вводит -2.553590
(atan 1.0 0.0) вводит 1.570796
(angtos (atan 1.0 0.0) 0 4) вводит "90.0000
(atan -0.5 0.0) вводит -1.570796
(angtos (atan -0.5 0.0) 0 2) вводит "-90.00"
4.23 (atof )
Эта функция вводит преобразование строчки в действительные числа. Например:
(atof "97.1") вводит 97.100000
(atof "3") вводит 3.000000

4.24 (atoi )
Эта функция вводит преобразование строки в целое число.
(atoi "97") вводит 97
(atoi "3") вводит 3
(atoi "3.9) вводит 3
4.25 (atom )
Эта функция вводит ноль, если - список, в противном случае вводится T. Данные, поступающие не в виде строчек, проходят как atom. Например, даны выражения:
(setq a '(x y z))
(setq b 'a)
тогда:
(atom 'a) вводит T
(atom a) вводит nil
(atom 'b) вводит T
(atom b) вводит T
(atom '(a b c)) вводит nil
Некоторые варианты ЛИСПа различаются в своих интерпретациях ATOMа, так что поупражняйтесь в применении кода преобразования.
4.26 (Boole ...)
Это основная подразрядная булевая функция. - целое число от 0 до 15, представляющая одну из 16 возможных булевых функций на двух переменных. Последовательные параметры в виде целых чисел подразрядно (логически) скомбинированы, основываясь на этих функциях и истинностной таблице:
Int1 Int2 Func bit
---------------------
0 0 8
0 1 4
1 0 2
1 1 1
Каждый бит имеет пару соответствующего бита , выбирая один горизонтальный ряд истинностной таблицы. Бит результата или ноль, или 1, в зависимости от установки бита , соответствующего этому ряду истиностной таблицы. Если соответствующий бит задан в , бит результата 1, в противном случае бит результата - 0.
Некоторые значения для эквивалентны стандартным булевым операциям AND, OR, XOR и NOT. Они представлены ниже:
Функция Операция Бит результата 1,если...
-------------------------------------------------------
1 AND оба входных бита - 1
6 XOR только один из двух входных битов - 1
7 OR любой или оба из входных битов
8 NOT оба входных бита - 0 (чье-то дополнение)
Например:
(Boole 1 12 5)
определяет логическое AND для значений 12 и 5. Результат 4. Аналогично:
(Boole 6 6 5)
определяет логическое XOR для значений 6 и 5,в результате - 3.
Вы можете применять другие значения для выполнения других булевых операций, для которых эти имена не являются стандартными. Например, если - 4, биты результата заданы, если заданы соответствующие биты в , но не в . Таким образом:
(Boole 4 3 14)
введет 12.
4.27 (boundp )
Эта функция вводит T, если имеет значение, близкое к нему (не взирая на контекст). Если же нет значения, близкого к (или если оно близко к нулю), вводится ноль. Например, заданы назначения:
(setq a 2)
(setq b nil)
тогда:
(boundp 'a) вводит T
(doundp 'b) вводит nil
4.28 caar, cadr, cddr, cadar, etc.
АвтоЛИСП обеспечивает связь CAR и CDR до четырех уровней вглубь. Например, задано назначение:
(setq x '((a b) c d))
тогда:
(caar x ) эквивалентно (car (car x)) вводит A
(cdar x) эквивалентно (cdr (car x)) вводит (B)
(cadar x) эквивалентно (car (cdr (car x))) вводит B
(cadr x) эквивалентно (car (cdr x)) вводит С
(cddr x) эквивалентно (сdr (сdr x)) вводит (D)
(caddr x) эквивалентно (car (cdr (cdr x))) вводит D
В АвтоЛИСПе CADR частично применяется для получения координаты Y для точек 2D и 3D ( второй элемент в списке из двух или трех действительных чисел). Аналогично, CADDR может применяться для определения координаты Z для точки 3D. Например:
(setq pt2 '(5.2 1.0 (2D точка)
(setq pt3 '(5.2 1.0 3.0) (3D точка)
тогда:
(car pt2) вводит 5.200000
(cadr pt2) вводит 1.000000
(caddr pt2) вводит nil
(car pt3) вводит 5.200000
(cadr pt3) вводит 1.000000
(caddr pt3) вводит 3.000000
4.29 (car )
Эта функция вводит первый элемент <списка>. Если <список> пустой, вводится ноль. Например:
(car '(a b c)) вводит A
(car '((a b) c)) вводит (A B)
(car '()) вводит nil
4.30 (cdr )
Эта функция вводит весь <список>, кроме его первого элемента. Если <список> пустой, вводится ноль. Например:
(cdr '(a b c)) вводит (B C)
(cdr '((a b) c)) вводит (C)
(cdr '()) вводит nil
Когда параметры <списка> - разделенные точкой пары (см. ниже CONS), CDR вводит второй элемент без включения его в список. Например:
(cdr '(a. b) вводит B
(cdr '(1. "Text") вводит "Text"
4.31 (chr )
Эта функция вводит переход целых чисел, представленных в знаковом коде ASCII, в однознаковую строку (аналогично функции CHRS в языке БЕЙСИК). Например:
(chr 65) вводит "A"
(chr 66) вводит "B"
(chr 97) вводит "a"
4.32 (close )
Эта функция закрывает файл и вводит ноль. - дескриптор файла (оприсатель), полученный из функции OPEN. После CLOSE дескриптор файла не изменяется, но становится недействительным. Например, представьте, что Х - действительный открытый дескриптор файла,
(close x )
закроет предполагаемый файл и введет ноль.
4.33 (command ...)
Эта функция выполняет команду АвтоКАДа в пределах АвтоЛИСПа и всегда вводит ноль. Параметры, представляющие команды АвтоКАДа, и их подкоманды, каждый параметр высчитывается в АвтоКАД в качестве ответа на последующие подсказки. Имена команд и опции запускаются в виде строчек, точки 2D как списки из двух действительных чисел и 3D точки как списки из трех действительных чисел. Имена команд узнаются АвтоКАДом только при выходе подсказки "Command". Например:
(setq pt1 '(1.45 3.23))
(setq pt2 (getpoint "Enter a point: "))
(command "line" pt1 pt2)
(command "")
Предполагая, что подсказка АвтоКАДа "Command" не выполняется, указанная выше последовательность выражений устанавливает значение для точки "pt1", выдает подсказку для точки "pt2" и выполняет команду АвтоКАДа LINE с двумя точками как данными ввода. Параметрами COMMAND могут быть строчки, действительные и целые числа или точки, как предусматри-вается последовательностью подсказки для выполнения команды АвтоКАДа. Нулевая строчка ("") эквивалентна печатанью пробела на клавиатуре. Вызов COMMAND без параметров эквивалентен печатанию CTR C на клавиатуре; это отменит большинство команд АвтоКАДа.
Команды, выполняемые из функции COMMAND, не отражаются на экране, если система переменных АвтоКАДа CMDECHO (выбранная из SETVAR или GETVAR) установлена на нуле. Функция COMMAND - основной метод выбора команд АвтоКАДа из АвтоЛИСПа.
Вводимые функции пользователя
"GETxxx" (GETANGLE, GETSTRING, GETINT, GETPOINT) не могут применяться внутри функции. Попытка проделать это, приведет в результате к появлению сообщения:
"ошибка:забракованная АвтоКАДом функция" и выполнение функции прекращается. Если ввод пользователя необходим, заранее задайте функции GETxxx, как указано выше, или поместите их между удачными вызовами функции COMMAND.
Если команда АвтоКАДа выполняется и строка,состоящая из единичного мертвого хода ("/"), просчитывается как один из параметров функции COMMAND, эта функция приостановит прямой ввод пользователя (или смещение). Это идентично механизму паузы мертвого хода, которым снабжены меню. Однако, поскольку мертвый ход является специальным контрольным знаком в ЛИСПе, требуется два символа мертвого хода для того, чтобы получить один в текстовой строке.
Если вы выдаете промежуточные команды в то время, когда функция COMMAND приостановлена, она и остается приостановленной. Тем не менее, вы можете выполнять команду ZOOM или PAN во время паузы функции COMMAND. Пауза сохраняется до тех пор, пока АвтоКАД получает действительный ввод и в работе нет никаких промежуточных команд.
Например:
(command "circle" "5,5" "r" "\\" "line" "5,5" "7,5" "")
начинает команду CIRCLE, устанавливает центральную точку 5,5 и затем-пауза, позволяющая смещать радиус окружности на экране. Когда вы укажете необходимые точки (или напечатаете необходимый радиус), функция продолжает работу, рисуя линию от 5,5 до 7,5.
Меню ввода не отменяется паузой АвтоЛИСПа. Если элемент меню активен когда функция COMMAND находится в паузе для ввода, это требование ввода может быть удовлетворено при помощи меню. Если вы хотите отменить и элементы меню, вы должны ввести мертвый ход в элемент меню. Когда обнаружен действительный ввод, будут продолжаться как функция COMMAND, так и элемент меню.
4.34 (cond ( ...)
Эта функция принимает в качестве параметров любое количество списков. Она вычисляет первый элемент каждого списка (в установленной последовательности) пока один из этих элементов введет значение, отличное от нуля. Затем она вычисляет те выражения, которые следуют за тестом, и вводит значение последнего выражения в подсписке. Если в подсписке только одно выражение (например, пропущен ),вводится значение выражения . COND - исходная условная функция в АвтоЛИСПе.
Например,в этом случае COND используется для выполнения расчетов абсолютного значения:
(cond (minusp a) (-a))
(t a)
)
Если для "а" было установлено значение -10, будет введено 10. Как показано, COND может применяться как функция типа "case". Общепринято использовать T как последнее (по умолчанию) <тестовое> выражение. Далее, другой пример. Задана ответная строка пользователя в виде символа "s", эта функция проверяет ответ и вводит 1, если он "Y" или "y" и 0, если он "N" или "n", в остальных случаях -nil (нуль).
(cond (( = s "Y") 1)
(( = s "y") 1)
(( = s "N") 0)
(( = s "n") 0)
( t nil)
)
4.35 (cons )
Это основной список КОНСтруктора. Он берет элемент (<новый первый элемент>) и список (<список>), и вводит дополнение этого элемента в начало списка. Например:
(cons 'a '(b c d)) вводит (A B C D)
(cons '(a) '(b c d)) вводит ((A) B C D)
Обратите внимание, что первый элемент может быть атомом в списке. CONS также допускает атом на место параметра в <списке>, создающего структуру, известную как dotted pair (точечная пара). Когда на экран выдается точечная пара, АвтоЛИСП печатает период или точку между первым и вторым элементом пары. Точечные пары занимают меньше места в памяти, чем обычные списки; функция CDR может применяться для ввода второго атома. Таким образом:
(cons 'a 'b) вводит ( A. B)
(car (cons 'a 'b)) вводит A
(cdr (cons 'a 'b)) вводит B
4.36 (cons )
Эта функция вводит косинус <угла>, где <угол> выражен в радианах. Например:
(cos 0.0 ) вводит 1.000000
(cos pi ) вводит -1.000000
4.37 (defun ...)
DEFUN определяет функцию под именем (обратите внимание, что имя функции автоматически взято в угловые скобки, так что она не должна заключаться пользователем в скобки). За именем функции следует список параметров (возможно пустой), за ним косая черта не обязательна, и имена одного или более локальных символов для функции. Последний параметр (если таковой имеется) и первый локальный символ должны быть отделены косой чертой или хотя бы одним пробелом.
Если не объявляются ни параметры, ни локальные символы, после имени функции должны быть пустые круглые скобки. Например:
(defun myfunc (x y)...) (функция принимает 2 параметра)
(defun myfunc (/a b)...) (функция имеет 2 локальных символа)
(defun myfunc (x/temp)...) (один параметр и один локальный символ)
(defun myfunc ()...) (нет параметров и локальных символов)
Следующие за списком параметров и локальных символов одно или несколько выражений вычисляются при выполнении функции.
Сама функция DEFUN вводит имя определенной функции. Если вызвана определенная таким образом функция, ее параметры будут вычислены и ограничены (подогнаны) параметрами символов. Локальные символы могут применяться в функции без изменения их связи на внешних уровнях. После вычисления результата последнего выражения, функция будет введена. Все предыдущие выражения в функции имеют побочный эффект. Сама функция DEFUN вводит имя определенной функции. Например:
(defun add (x y)
(+ x y)
)
(add 10 5) вводит 15
(add -7. 4) вводит 2,60000
и
(defun dots ( x y/temp)
(setq temp (strcat x "..."))
(strcat temp y)
)
(dots "a" "b" ) вводит "а...b"
(dots "from" "to") вводит "from...to"
Никогда не применяйте имя встроенной функции или символа в качестве , поскольку это сделает встроенную функцию недоступной.
4.37.1. Функции библиотек и автоматическая загрузка
Определения функций могут храниться в файле и загружаться при помощи функции LOAD АвтоЛИСПа (эта функция описана дальше в этой главе). Если существует файл "acad.lsp", АвтоЛИСП будет загружать его автоматически каждый раз при введении графического редактора АвтоКАДа; вы можете применять эту функцию для создания библиотеки полезных функций и для создания гарантии присутствия этой библиотеки.
4.37.2. Функции С:ххх - дополнение команд АвтоКАДа
Вы можете ввести дополнительные команды в АвтоКАД, применяя функцию DEFUN для определения функций, вводящих в работу эти команды. Для того, чтобы применяться как команды АвтоКАДа, эти функции должны придерживаться следующих правил:
1. Функция должна иметь имя следующей формы: "С:ХХХ", где все буквы - верхнего регистра. Часть имени "С" должна присутствовать всегда, часть "ХХХ" может быть именем команды по вашему выбору, при условии, что она не дублирует никаких команд АвтоКАДа, встроенных или внешних.
2. Функция должна быть определена с нулевым списком параметров (но локальные символы могут присутствовать).
Например, функция: нарисовать квадрат при помощи Полилиний определяет следующее:
(defun C:PSQUARE ('pt1 pt2 pt3 pt4 len)
(setq pt1 (getpoint "Lower left corner:"))
(setq len (getdist pt1 "Length of one side:"))
(setq pt2 (polar pt1 0.0 len))
(setq pt3 (polar pt2 ('PI 2.0) len))
(setq pt4 (polar pt3 PI len))
(Command "PLINE" pt1 pt2 pt3 pt4 "C")
)
Функции, определенные таким образом, могут быть вызваны просто введением части "ХХХ" имени функции, при появлении подсказки АвтоКАДа "Command:". Если "ХХХ" - неизвестная команда, АвтоКАД попытается вызвать функцию АвтоЛИСПа "С:ХХХ" без параметров. Например, при функции C:PSQUARE диалог будет следующим:
Сommand: PSQUARE
Lower left corner: (enter a point)
Нижний левый угол: (введите точку)
Length of one side: (enter a distance)
Длина стороны: (введите размер)
Затем функция вызовет команду АвтоКАДа PLINE и введет в ее подсказки: нарисовать желаемый квадрат. Добавление таким образом команды в АвтоКАД - очень мощное свойство АвтоЛИСПа. Однажды определенная, новая команда может использовать все свойства, предоставляемые АвтоЛИСПом. Фактическое применение новой команды не требует окружения имени команды параметрами, так что эта введенная АвтоЛИСПом команда, применяется также, как и любая другая команда АвтоКАДа.
4.38.(distance )
Эта функция вводит расстояние между 2D точками и , где 2D точка - список из двух действительных чисел.
Например:
(distance '(1.0 2.5) '(7.7 2.5)) вводит 6.700000
(distance '(1.0 2.5) '(3.0 4.0)) вводит 2.828427
4.39. (eq )
Эта функция определяет, идентичны ли и , то есть, они фактически граничат с одним и тем же объектом (например,SETQ). EQ вводит T, если два выражения идентичны, в противном случае вводится ноль. Обычно она применяется для определения фактической идентичности двух списков. Например, даны следующие назначения:
(setq f1 '(a b c))
(setq f2 '(a b c))
(setq f3 f2)
тогда:
(eq f1 f2) вводит ноль (f1 и f2 - не один и тот же список!)
(eq f3 f2) вводит T (f3 и f2 - абсолютно одинаковые списки!)
См. также функцию EQUAL.
4.40 (equal )
Эта функция определяет, равны ли и , т.е. вычисляются ли они к одному предмету. Например, заданы следующие назначения:
(setq f1 '(a b c))
(setq f2 '(a b c))
(setq f3 f2)
тогда:
(equal f1 f2) вводит T (f1 и f2 вычисляются к одному и тому же)
(equal f3 f2) вводит Т (f2 и f3 абсолютно одинаковые списки)
Обратите внимание, что в то время, как два списка равны, они могут быть неидентичны, атомы, когда они равны, они всегда идентичны. И, наконец, если любые два списка или атомы идентичны, они всегда равны.
4.41.(eval )
Вводит результат вычисленных (выражений), где - любое выражение ЛИСПа. Например, заданы назначения:
(setq a 123)
(setq b 'a)
тогда:
(eval 4.0) вводит 4.000000
(eval (abs - 10 )) вводит 10
(eval a) вводит 123
(eval b) вводит 123
4.42.(exp )
Эта функция вводит е, возведенное в степень <числа> (обычный антилогарифм (antilog)). Она вводит действительные числа. Например,
(exp 1.0) вводит 2.718282
(exp 2.2) вводит 9.025013
(exp -0.4) вводит 0.670320
4.43. (expt )
Эта функция вводит <базу>, возведенную в определенную <степень>. Если оба параметра целые числа, результат будет целым числом. В противном случае, результат будет действительным числом. Примеры:
(expt 2 4) вводит 16
(expt 3.0 2.0) вводит 9.000000
4.44. (fix )
Эта функция вводит преобразование <числа> в действительное число. <Число> может быть как целым, так и действительным. Если оно действительное, оно усекается до ближайшего целого числа путем отбрасывания десятичной части. Например:
(fix 3) вводит 3
(fix 3.7) вводит 3.000000
4.45.(float )
Эта функция вводит преобразование <числа> в действительное число. <Число> может быть как целым, так и действительным. Например:
(float 3) вводит 3.000000
(float 3.7) вводит 3.700000
4.46.(foreach )
Эта функция проходит через <список>, присваивая <числа> каждому элементу и вычисляет каждое <выражение для каждого элемента в списке>. Любое количество <выражений > может быть определено. FOREACH вводит результат вычисления последнего <выражения>. Например:
(foreach n'(a b c)(print n))
эквивалентно
(print a)
(print b)
(print c)
кроме того FOREACH вводит результат только последнего вычисленного выражения.
4.47.(gcd )
Эта функция вводит наибольший общий знаменатель <числа1> и <числа2>. <Число1> и <число2> должны быть целыми. Например:
(gcd 81 57) вводит 3
(gcd 12 20) вводит 4
4.48.(getangle [][]
Для пользователя эта функция приостанавливает ввод угла. <Подсказка> - произвольная строка, которая появляется на экране в качестве подсказки, а - произвольная базовая точка 2D. Вы можете определить угол, напечатав цифру в текущем формате единиц угла АвтоКАДа. Отметьте, что хотя текущий формат единиц угла может быть выражен в градусах, градах и т.д., эта функция всегда вводит угол в радианах.
Вы можете также "показать" АвтоЛИСПу угол, отмечая точками два 2D расположения на экране графики. АвтоКАД рисует линию резиновой нити от первой точки до позиции текущего перекрестия, что поможет вам при визуализировании угла.
Необязательный параметр функции GETANGLE (если он определен) предполагается быть первой из этих двух точек, позволяя вам "показать" АвтоЛИСПу" угол, отмечая еще одну точку. Вызов GETANGLE демонстрирует следующее:
(setq ang (getangle))
(setq ang (getangle '(1.0 3.5))
(setq ang (getangle "Which way?")
(setq ang (getangle '(1.0 3.5)"Which way?")
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETANGLE. Попытка сделать это приведет к сообщению "Can't reenter Autolisp" (Не могу повторно ввести АвтоЛИСП"). См. также GETORIENT и INITGET.
4.49. (getcorner [])
Функция GETCORNER вводит точку так же, как и GETPOINT. Однако, GETCORNER требует параметр <базовой> точки и чертит прямоугольник из <базовой> точки по мере перемещения пользователем пересечения на экране. Для детального ознакомления см. GETPOINT и INITGET. В качестве ответа на требование GETCORNER, вы не можете ввести другое выражение ЛИСПа.
4.50.(getdist [][])
Для пользователя эта функция приостанавливает ввод расстояния. <Подсказка> - произвольная строка, которая появляется на экране в качестве подсказки, а - произвольная базовая точка. Вы можете определить расстояние, напечатав цифру в текущем формате единиц расстояния АвтоКАДа. Отметьте, что хотя текущий формат единиц расстояния может быть выражен в футах, дюймах (архитектурный), эта функция всегда вводит расстояние в действительных числах.
Вы можете "показать" АвтоЛИСПу расстояние, отметив точками два расположения на графическом экране. АвтоКАД рисует линию резиновой нити от первой точки до позиции текущего перекрестия, что поможет вам при визуализировании расстояния. Необязательный параметр функции GETDIST (если он определен) предполагается быть первой из этих двух точек, позволяя вам "показать" АвтоЛИСПу расстояние, отмечая еще одну точку.
Следующие примеры иллюстрируют применение GETDIST.
(setq dist (getdist))
(setq dist (getdist '(1.0 3.5))
(setq dist (getdist "How far?")
(setq dist (getdist '(1.0 3.5)"How far?")
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETDIST. См. также INITGET.
4.51.(getint[])
Для пользователя эта функция приостанавливает ввод целых чисел и возвращает это целое число. <Подсказка> - произвольная строка, которая появляется на экране в качестве подсказки.
Например:
(setq num (getint))
(setq num (getint "Enter a number:")) (Введите число)
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETINT. См. также INITGET.
4.52.(getkword [])
Функция GETKWORD требует от пользователя ключевого слова. Перед вызовом GETKWORD, устанавливается список действительных ключевых слов, применяя функцию INITGET (описанную ниже). GETWORD вводит ключевое слово, выравнивая в строку ввод пользователя. АвтоКАД повторит попытку, если ввод не соответствует одному из этих ключевых слов. Пустой (нулевой) ввод введет нуль (если это допустимо). Нуль также вводится, если создана строка ключевых слов. Например:
(initgent 1 "Yes Nо")
(setq x (getkword "Are you sure? (Yes or No)"))
подскажет пользователю и установит символ Х как для "Yes", так и для "No", в зависимости от ответа пользователя. Если подсказка не соответствует ни одному из ключевых слов, или если пользователь отвечает нулем, АвтоКАД попросит пользователя повторить процедуру.
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETKWORD. См. также INITGET.
4.53.(getorient [][])
В АвтоЛИСПе углы всегда представлены в радианах, с направлением в ноль-радиан вправо ( восток) и углом, увеличивающимся в направлении против часовой стрелки. Таким образом, будут иметь место некоторые преобразования, если пользователь выберет различные нуль-градусные базы или различные направления для увеличения угла посредством команды INITS или систем переменных ANGBASE и ANGDIR.
GETORIENT похож на функцию GETANGLE, но находится под влиянием нуль-градусной базы и направления для увеличения угла совсем по-другому, чем GETANGLE. GETANGLE должна применяться в том случае, когда вам необходима величина вращения (относительный угол), тогда как GETORIENT должна применяться для получения ориентации (абсолютный угол).
Представьте, что команда АвтоКАДа INITS применялась для выбора нуль-градусной базы 90 градусов (север) и направления для увеличения угла - по часовой стрелке. В таблице показано, что введут функции GETANGLE и GETORIENT (в радианах) для репрезентивного ввода переменных пользователем (в градусах).
Input (degrees) GETANGLE GETORIENT
0 0.000000 1.570796
90 1.570796 3.141593
180 3.141593 4.712389
90 (-90 270?) 4.712389 0.000000
Как показано в таблице, GETANGLE принимает на обработку направление увеличения угла, но игнорирует ноль-градусную базу. Таким образом, вы можете применять GETANGLE для получения величины вращения при вводе/вставке блока, так как ввод нуль-градуса всегда введет ноль радиан. С другой стороны, GETORIENT принимает на обработку как ноль-градусную базу, так и направление увеличения угла. Таким образом, вы должны применять GETORIENT для получения таких углов, как угол базовой линии для Элемента Текста. Например, для заданных выше установок UNITS, ориентация базовой линии для нормальной горизонтальной линии текста будет 90 градусов.
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETORIENT. См. также GETANGLE и INITGET.
4.54. (getpoint [] [])
Для пользователя эта функция приостанавливает ввод точки. - необязательная базовая точка, а - произвольная строка, которая появляется на экране в качестве подсказки. Вы можете определить точку поинтером или напечатав координату в текущем формате единиц. Если присутствует параметр необязательной базовой точки , АвтоКАД чертит линию резиновой нити от этой точки до позиции текущего перекрестия. Например:
(setq p (getpoint))
(setq p (getpoint "Where?")) "Где?"
(setq p (getpoint '(1.5 2.0) "Second point:")
Обычно GETPOINT вводит точку 2D (список из двух действительных чисел). Применяя функцию INITGET для установки контрольной отметки "точка.3D", вы можете заставить GETPOINT ввести точку 3D (список из трех действительных чисел).
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETPOINT. См. также GETCORNER и INITGET.
4.55.(getreal [])
Для пользователя эта функция приостанавливает ввод действительного числа и возвращает это действительное число. <Подсказка> - произвольная строка, которая появляется на экране в качестве подсказки. Например:
(setq val (getreal)
(setq val (getreal "фактор шкалы:")
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETREAL. См. также INITGET.
4.56.(getstring [][])
Для пользователя эта функция приостанавливает ввод строки и вводит эту строку. Если задан и он не равен нулю, вводимая строка может содержать пробелы (и должна поэтому быть завершена нажатием RETURN). В других случаях ввод строки завершается пробелом или RETURN. <Подсказка> - произвольная строка, появляющаяся на экране в качестве подсказки. Например:
(setq s (getstring))
(setq s (getstring "What's your first name?"))
(setq s (getstring T "What's your full name?"))
Если ввод пользователя должен быть одной из нескольких опций (ключевых слов), вместо GETSTRING может применяться описанная ранее функция GETKWORD.
Вы не можете ввести другое выражение ЛИСПа в качестве ответа на требование GETSTRING.
4.57.(getvar )
Эта функция отыскивает значения системных переменных АвтоКАДа. Имя переменной дожно быть заключено в двойные кавычки "". Например, предположим, что самый последний из определенных нами радиус округления был 0.25 единиц:
(getvar "FILLETRAD") введет 0.250000
Список текущих системных переменных АвтоКАДа можно найти в приложениях А книги пользователя АвтоКАДа. См. также функцию SETVAR.
4.58.(graphscr)
Функция GRAPHSCR переключается с текстового экрана на графический в одно-экранных системах (типа функциональной клавиши "Flip screen" в АвтоКАДе). GRAPHSCR всегда вводит ноль. См. также функцию TEXTSCR.
4.59.(if )
Эта функция условно вычисляет выражения. Если не ноль, тогда она вычисляет , в противном случае она вычисляет . Последнее выражение () - необязательное. IF вводит значение выбранного выражения; если пропущено, а равно нулю, IF вводит ноль. Например:
(if (=1 3)"Yes!!" "No") вводит "No"
(if (=2 (+1 1)) "Yes!!") вводит "Yes!!"
(if (=2 (+3 4)) "Yes!!") вводит nil
4.60.(initget [][])
Эта функция создает различные опции для дальнейшего использования их функцией GETxxx (кроме GETSTRING и GETVAR). INTGET всегда вводит ноль. Необязательный параметр - целое число со следующими значениями:


INITGET Bits Значение
1 не допускает нулевой ввод
2 не допускает нулевые значения
4 не допускает отрицательных значений
8 не проверяет границы,даже если действует limcheck
16 вводит точки 3D раньше,чем точки 2D
Биты могут складываться вместе в любой комбинации для создания значений от 0 до 31. Если пользователь при вводе определенных режимов ошибается (например, вводит нулевое значение, когда оно не допускается), АвтоКАД выдаст на экран сообщение и попросит пользователя повторить попытку. Например:
(initget (+ 1 2 4))
(setq age (getint "How old are you?") : возраст "Сколько вам лет?"
получит возраст пользователя, автоматически повторив попытку, если пользователь введет ноль, отрицательное число или нулевое значение. Если параметр не задан, предполагается ноль (нет режимов). Специальные контрольные значения принимаются на обработку только теми функциями GETxxx, для которых они имеют смысл (как показано в таблице):
Функция INITGET control bits honored (принимаемые на обработку контрольные байты функции INITGET)
No null No zerro No neg. No limits 3D hoints
GETINT * * *
GETREAL * * *
GETDIST * * *
GETANGLE * * *
GETORIENT * * *
GETPOINT * * *
GETCORNER * * *
GETKWORD *
GETSTRING
GETVAR
Необязательный параметр функции INITGET определяет список ключевых слов опции, которые будут проверены следующими требованиями GETxxx, если пользователь не ввел ожидаемый тип данных ввода (например, точку для GETPOINT). Если ввод пользователя соответствует одному из ключевых слов этого списка, это ключевое слово вводится с помощью функции GETxxx как результат функции STRING. Программа пользователя может контролировать ключевые слова и выполнять желаемые действия для каждого из них. Если ввод пользователя не ожидаемого типа и не соответствует ни одному из ключевых слов, АвтоКАД попросит повторить попытку. Список ключевых слов должен быть следующей формы: "KEY1 KEY2 KEY3 ABBREV3". Отдельные ключевые слова определены пробелами. Сокращения (аббривиатура) необязательны, есть два метода их определения.
Необходимая часть может быть написана заглавными буквами, а остальная - с применением нижнего регистра; или необходимая часть может быть повторена, отделенная от ключевого слова запятой. Второй способ предназначен для облегчения применения иностранных языков, где переключение регистров может быть затруднено или вообще невозможно. В каждом методе длина необходимой части - минимальная длина, которая должна точно соответствовать. (Для метода разделителя-запятой предполагается, что строка аббревиатуры - правильное подмножество начала ключевого слова).
Например: "LTYPE,LT" и "LType" - эквивалентные спецификации. Каждая означает, что вводы пользователя типа "LTYPE", "LTYP", "LTY" или "LT" применяемы, но "L"- недостаточно, а "LTSCALE" и "LTYPEX" не соответствуют.
Рассмотрим следующие, определенные пользователем функции
(defun getnum (ix)
(initget 1 "Pi Two-pi")
(setq x (getreal "Pi/Two-pi/:"))
(cond((eqx "Pi") pi)
((eq x "Two-pi")(*2.0 pi))
(T x)
)
)
Этот INITGET запрещает нулевой ввод и создает список из двух ключевых слов "Pi" и "TWO-Pi". Затем применяется GETREAL для получения целых чисел, издавая подсказку "Pi/Two-pi/:", результат перемещения в локальном символе Х.
Если пользователь вводит число, это число возвращается функцией GETNUM. Однако, если пользователь вводит ключевое слово "Pi" ( или просто "P"), функция GETPOINT возвращает ключевое слово "Pi". Функция COND обнаруживает это и, в данном случае, вводит значение Pi. Ключевое слово "Two-pi" обрабатывается аналогично. Созданные с помощью INITGET контрольные пометки и ключевые слова применяются только со следующим GETxxx вызовом, а затем автоматически отбрасываются. Это позволяет очистить специальный режим при необходимости вызова другой функции.
4.61.(inters [])
Функция INTERS исследует две линии и вводит точку их пересечения, или ноль, если они не пересекаются. и - конечные точки первой линии, а и - конечные точки второй линии. Если присутствует необязательный параметр и он равен нулю, линии считаются бесконечными по длине, INTERS вводит точку пересечения даже если она находится вне конца одной или обеих линий. Если параметр опущен или он - ноль, точка пересечения должна находиться на обеих линиях или INTERS введет ноль. Например, задано:
(setq a'(1.0 1.0) b'(9.0 9.0))
(setq c'(4.0 1.0) d'(4.0 2.0))
тогда:
(inters a b c d) введет nil
(inters a b c d T) введет nil
(inters a b c d nil)введет (4.000000 4.000000)
4.62.(itoa )
Эта функция вводит переход целых чисел в строку. Например:
(itoa 33) вводит "33"
(itoa -17) вводит "-17"
4.63 (lambda ...)
LAMBDA определяет "анонимную" функцию. Обычно она применяется когда заголовок при определении новой функции не выравнен. Она также помещает функцию на то место, где она должна применяться. LAMBDA вводит значение последнего <выражения> и часто применяется вместе с APPLY и/или MAPCAR для выполнения функции в списке. Например:
(apply '(lambda (x y z)
(* x (-y z)
)
'(5 20 14)
) вводит 30
или:
(mapcar '(lambda (x)
(setq counter (1 + counter))
(* x 5)
)
'(24 -6 10.2)
) вводит (10 20 -30 51.000000)
4.64.(last)
Эта функция вводит последний элемент <списка>. <Список> должен быть не нулевым. Например:
(last '(a b c d e)) вводит E
(last '(a b c (d e))) вводит (DE)
Как показано, LAST может вводить как атом, так и список. На первый взгляд может показаться,что LAST- отличный способ получения координаты Y точки. Пока это истинно для 2D точки (список из двух действительных чисел), LAST введет координату Z для 3D точки. Для того,чтобы ваша функция работала как следует, задавая точки 2D и 3D, мы советуем вам применять CADR для получения координаты Y и CADDR для получения координаты Z.
4.65.(length )
Эта функция вводит целое число, обозначающее номер элемента в <списке>. Например:
(length '(a b c d) вводит 4
(length '(a b (c d)) вводит 3
(length '()) вводит 0
4.66.(list ...)
Эта функция берет любое количество выражений () и соединяет их вместе, вводя список. Например:
(list 'a 'b 'c) вводит (A B C)
(list 'a '(d c) 'd) вводит (A (B C) D)
(list 3.9 6.7) вводит (3.90000 6.70000)
В АвтоЛИСПе эта функция часто применяется для определения переменных точек 2D и 3D (список из двух или трех действительных чисел).
4.67. (listp )
Эта функция вводит T, если - список, и nil в противном случае. Например:
(listp '(a b c)) вводит T
(listp 'a) вводит nil
(listp 4.343) вводит nil
4.68.(load )
Эта функция загружает файл выражений АвтоЛИСПа и вычисляет эти выражения. - строка, которая представляет имя файла без расширения (расширение ".lsp" допускается). может включать префикс с каталогом, как в "/function/test1" ("функция/тест 1"). В системах MS-DOS/PC-DOS также допускается имя накопителя (например, a: c:) и вы можете использовать мертвый ход вместо предшествующей косой черты (но помните, что вы должны применять "\\" для получения одной косой черты в строке).
Если операция удачна, LOAD вводит имя последней определенной в файле функции. Если операция дает сбой, LOAD введет имя файла в виде строки.
Например, предположим, что файл "/fred/test1.lsp" содержит DEFUN функции MY-FUNС, а файл "test2.lsp" не существует:
(load "/fred/test1") вводит MY-FUNC
(load "test2" вводит "test"
Функция LOAD не может быть вызвана внутри другой функции ЛИСПа. Она должна быть введена непосредственно с клавиатуры (или из меню, или файла сценария /script file/), пока не активна никакая другая функция ЛИСПа.
Каждый раз, когда начинается сеанс работы графического редактора АвтоКАДа, АвтоЛИСП загружает файл "acad.lsp", если он существует. Вы можете записать на этот файл определение или наиболее часто употребляемые команды, они будут вычисляться автоматически каждый раз, когда вы начнете редактировать чертеж.
4.69.(log )
Эта функция вводит в виде действительного числа естественный log <числа>. Например:
(log 4.5) вводит 1.504077
(log 1.22) вводит 0.198850
4.70.(logand ...)
Эта функция вводит результат логического подразрядного AND/И списка <чисел>. <Числа> должны быть целыми, результат также будет целым числом. Например:
(logand 7 15 3) вводит 3
(logand 2 3 15) вводит 2
(logand 8 3 4) вводит 0
4.71.(logior )
Эта функция вводит результат логического подразрядного включающего OR/ИЛИ списка <чисел>. <Числа> должны быть целыми, результат будет также целым числом. Например:
(logior 1 2 3) вводит 7
(logior 9 3) вводит 11
4.72.(lsh )
Эта функция вводит логическое подразрядное смещение битами . <Число1> и <количество битов> должны быть целыми числами, результат также целое число. Если <количество битов> положительное число, <число1> смещается влево, если отрицательное - вправо. В обоих случаях "нулевые" биты смещаются внутрь, а биты, сдвигаемые наружу без сохранения выдвигаемых разрядов, не учитываются (shift in/shift out). Если "один" бит смещен внутрь или наружу (into/out) от вершины (16-ого ) бита целого числа, его знак меняется. Например:
(lsh 2 1) вводит 4
(lsh 2 -1) вводит 1
(lsh 40 2) вводит 160
(lsh 16384 1) вводит -32768
4.73.(mapcar ...)
MAPCAR вводит результат выполненной <функции> с индивидуальными элементами <списка1> через <список n>, подаваемые как параметры <функции>. Количество <списков> должно соответствовать количеству параметров, требуемых <функцией>. Например:
(mapcar '1+'(10 20 30) вводит (11 21 31)
Это эквивалентно
(1 + 10)
(1 + 20)
(1 + 30)
Кроме этого MAPCAR вводит список результатов. Аналогично:
(mapcar '+'(10 20 30)'(4 3 2) вводит (14 23 32)
эквивалентно:
(+10 4)
(+20 3)
(+30 2)
Функция LAMBDA может определить "анонимную" функцию, которую выполнит MAPCAR. Это полезно, когда некоторые параметры функции - константы или подаются некоторыми другими путями. Например:
(mapcar '(lambda (x)(+ x 3))'(10 20 30) вводит (13 23 33)
и
(mapcar '(lambda (x y z)
(* x (-y z)
)
'(5 6)'(20 30)'(145.0)
) вводит (30 150.000000)
4.47.(max ...)
Эта функция вводит самое большое из заданных <чисел>. Каждое <число> может быть действительным или целым. Например:
(max 4.07 -144) вводит 4.070000
(max -88 19 5 2) вводит 19
4.75.(member )
Эта функция ищет <список> из имеющихся в наличии <выражений> и вводит остаточные члены <списка>, начиная с первого, имеющегося в наличии <выражения>. Если в <списке> нет нужных <выражений>, MEMBER вводит ноль. Например:
(member 'c '(a b c d e) вводит (C D E)
(member 'q '(a b c d e) вводит nil
4.76.(menucmd )
Функция MENUCMD снабжает средствами программы для переключения между подстраницами в меню АвтоКАДа. Таким образом, программа ЛИСПа может работать во взаимодействии с объединенным файлом меню, каждый раз при необходимости ввода пользователя, выводя на экран соответствующие подменю варианты/альтернативы. Параметр <строка> функции MENUCMD имеет следующую форму:
section - submenu (секция - подменю)
где
section определяет секцию/раздел меню. Действительны следующие имена:
S - для меню экрана (SCREEN)
B - для клавишного меню (BUTTONS)
T1-T4 - для меню планшета (TABLET) от 1 до 4
A1 - для AUXI меню.
submenu определяет какое из подменю активно. Имя должно быть или одним из знаков/обозначений меню (без "**") в текущем загруженном файле меню, или именем секции основного меню. Для дальнейшей информации см. Главу 5. Обратите внимание, что начальная "S", применяемая для ссылки на подменю в файле меню, здесь не применяется. Например:
(menucmd "S = OSNAP")
вызовет на экран подменю "OSNAP" (предполагая, что такое подменю существует в текущем файле меню). Аналогично:
(menucmd "B" = "MY-BUTTONS")
определит "MY-BUTTONS" для кнопочного меню. MENUCMD всегда вводит nil.
4.77.(min ...)
Эта функция вводит самое маленькое из заданных <чисел>. Каждое <число> должно быть действительным или целым. Например:
(min 683 -10.0) вводит -10.000000
(min 73 2 48 5) вводит 2
4.78.(minusp )
Эта функция вводит T, если - действительное или целое число и вычисляется к отрицательному значению, иначе она вводит nil. Для других типов функция не определяется. Например:
(minusp -1) вводит T
(minusp -4.293) вводит T
(minusp 830.2) вводит nil
4.79.(not )
Эта функция вводит T, если выражение - нулевое и ноль в противном случае. Как правило, функция NULL применяется для списков, а NOT применяется для других типов данных в сочетании с некоторыми типами контроля функций. Например, заданы следующие назначения:
(setq a 123)
(setq b "string")
(setq c nil)
тогда:
(not a) вводит nil
(not b) вводит nil
(not c) вводит T
(not '()) вводит T
4.80.(nth )
Эта функция вводит "nth" элемент <списка>, где - номер вводимого элемента (нулевой - первый элемент). Если больше, чем задано в <списке>, вводится nil. Например:
(nth 3 '(a b c d e)) вводит D
(nth 0 '(a b c d e)) вводит A
(nth 5 '(a b c d e) вводит nil
4.81.(null )
Эта функция вводит Т, если близок к нулю, иначе она введет nil. Например, заданы следующие назначения:
(setq a 123)
(setq b "string")
(setq c nil)
тогда:
(nul a) вводит nil
(nul b) вводит nil
(nul c) вводит T
(nul '()) вводит T
4.82.(numberp )
Эта функция вводит T, если - целое или действительное число, иначе она вводит ноль. Например, заданы назначения:
(setq a 123)
(setq b 'a)
тогда:
(numberp 4 ) вводит T
(numberp 3.8348) вводит T
(numberp "Howdy") вводит nil
(numberp 'a) вводит nil
(numberp a) вводит T
(numberp b) вводит nil
(numberp (eval b)) вводит T
4.83.(open )
Эта функция открывает файл для обращения к нему I/O функции АвтоЛИСПа. Она вводит дескриптор файла, который будет применяться другими I/O функциями, поэтому он должен начинаться с setq. Например:
(setq a(open "file.ext" "r"))
- строка, определяющая имя и расширение открываемого файла. - пометка для чтения/написания. Он должен быть в виде строки, состоящей их единичных букв нижнего регистра. Действительные для mode буквы описаны в следующей таблице:
ОPEN mode Описание
"r" Открыт для чтения. Если не существует, вводится ноль
"w" Открыт для написания. Если не существует, создается и открывается новый файл. Если существует, его существующие данные перепишутся.
"a" Открыт для дополнений. Если не существует, создается и открывается новый файл. Если уже существует, он открывается и дополняется позиция в конце существующих данных, так любые новые данные, записанные в файл, будут добавлены к существующим данным.
В системах DOS, некоторые программы и текстовые редакторы записывают файлы текста с маркером конец-файла (CTRL Z, десятичный ASCII код 26) в конце текста. При прочтении текстового файла DOS вводит статус конец-файла, если имеется маркер CTRL Z, даже если после него имеются еще данные. Если вы намерены применять "a" режим функции OPEN для дополнения данных в файл созданный другой программой, проверьте, чтобы другая программа не использовала маркер CTRL Z в конце своих текстовых файлов.
Представьте, что в данных примерах имен файлов не существует:
(setq f(open "new.tst" "w")) вводит
(setq f(open "nouch.fil" "r")) вводит nil
(setq f(open "logfile" "a")) вводит
может содержать прямой префикс, как в "test/func3" В системах MS-DOS также допускается управляющая буква; вы можете использовать обратную косую черту вместо прямой черты (но помните, что вы должны применять "\\" для получения в строке одной косой черты). Например:
(setq f(open "/x/new.tst" "w") вводит
(setq f(open nosuch.fil" "r") вводит nil
4.84.(or ..)
Эта функция вводит логическое OR/ИЛИ для списка выражений. Если все выражения вычисляются к нулю ИЛИ вводит ноль, в противном случае вводит Т. Например:
(or nil 'a '()) вводит T
(or nil '()) вводит nil
4.85.(osnap )
Эта функция вводит точку, которая является результатом применения режимов фиксации (snap) объекта, описанного к точке . - строка, состоящая из одного или более действительных зафиксированных объектов, определенные как "midpoint", "center" и т.д., отделенные запятыми. Например:
(setq pt2 (osnap pt1 "midp"))
(setq pt2 (osnap pt1 "midp,endp,center")
Если параметр -точка 2D (список из двух действительных чисел), вводится точка 2D. Если параметр точка 3D (список из трех действительных чисел), вводится точка 3D. Если в оснапе не находится точки, определенной /режимом, для заданной точки , вводится ноль.
4.86. pi
Это не функция, а константа pi. Она вычисляется приблизительно 3,1415926.
4.87.(polar )
Эта функция вводит точку под углом на расстоянии от точки . Точка - список из двух действительных чисел, угол выражен в радианах. Например:
(polar '(1.0 1.0) 0.785398 1.414214)
вводит (2.000000 2.000000)
4.88. (prin1[])
Эта функция печатает выражение на экране и вводит . могут быть любые выражения, но они не должны быть строкой. Если присутствует (и если это дескриптор для файла,открытого для написания), <выражение> в файле точно так, как оно должно появиться на экране. Печатаются только заданные <выражения>, новые линии или пробелы не включаются. Например, заданы следующие назначения:
(setq a 123)
(setq b '(a))
тогда
(prin1 'a) печатает A и вводит A
(prin1 a) печатает 123 и вводит 123
(prin1 b) печатает (A) и вводит (A)
(prin1 "Hello") печатает "Hello" и вводит "Hello"
Каждый из примеров печатается на экране, как только определяется <дескриптор файла>. Представьте, что F - действительный дескриптор файла, открытого для написания:
(prin1 "Hello" f)
напишет "Hello" в заданный файл и введет "Hello".
Если - строка, содержащая контрольные символы, PRIN1 отредактирует эти символы кавычками " ".
\e для escape переход
\n для newline новая линия
\r для return возврат,ввод
\t для tab табуляция
\nnn для символов,чей восьмиричный код nnn
Таким образом:
(prin1 (chr 2)) печатает "\002" и вводит "\002"
(prin1 (chr 10)) печатает "\n" и вводит "\n"
4.89.(princ [])
Эта функция такая же, как PRIN1, кроме того, что контрольные символы в печатаются без расширения. В общем, PRIN1 разработан для написания выражений в таком виде, чтобы они были совместимы с функцией LOAD, в то время как PRINC будет печатать их в пригодном для чтения функцией READ-LINE виде.
4.90. (print [])
Эта функция такая же, как PRIN1, кроме того, что новые линии печатаются перед , а в промежутке печатается следующее выражение.
4.91. (progn ...)
Эта функция последовательно вычисляет каждое <выражение> и вводит значение последнего выражения. Вы можете применять PROGN для вычисления нескольких выражений, где предусматривается только одно выражение. Например:
(if (=a b) (progn
(setq a (+a 10)
(setq b (-b 10)
)
Функция IF нормально вычисляет одно выражение "then", если тестовое выражение вычисляется к чему-либо отличному от нуля. В этом примере мы применяли PROGN для вычисления двух выражений вместо первоначального.
4.92.(prompt )
Эта функция высвечивает на экране в зоне подсказок /сообщение и вводит ноль. - строка. В двухэкранной конфигурации АвтоКАДа, функция PROMPT высвечивает на обоих экранах и поэтому предпочтительна для PRINC. Например:
(prompt "New value:")
на экранах появится "New value:" и вводится ноль.
4.93.(quote )
Вводит невычисляемое <выражение>. Она также может быть записана следующим образом:
'expr
Например:
(quote a) вводит A
(quote cat) вводит CAT
(quote (a b)) вводит (A B)
'a вводит A
'cat вводит CAT
'(a b) вводит (A B)
4.94. (read )
Эта функция вводит первый перечень или атом, полученные из <строки>. <строка> не должна содержать пробелов. Например:
(read "hello") вводит HELLO
(read "hi") вводит HI
(read "(a)") вводит (A)
4.95.(read-char [])
Эта функция читает единичный символ из буфера ввода клавиатуры или из открытого файла, описанного в . Она вводит (целое число) ASCII код, представляющий возможность прочесть символ.
Если не определен, а в буфере ввода клавиатуры нет символов, READ-CHAR ждет, пока вы что-либо напечатаете с клавиатуры (сопроводжая запись клавишей RETURN !). Например, предположим, что буфер ввода клавиатуры пуст:
(read-char)
будет ждать, чтобы что-то было введено. Если вы напечатаете "A B C", а затем нажмете RETURN, READ-CHAR введет 65 (код ASCII для буквы "A"). На следующие вызовы READ-CHAR введет 66, 67 и 10 (новая линия) соответственно. Если затем будут произведены следующие вызовы READ-CHAR, она опять будет ждать ввод.
4.96. (read-line [])
Эта функция читает строку с клавиатуры или из открытого файла, описанного в . Если конец файла не вычисляется, READ-LINE вводит ноль, в противном случае она вводит строку, которая была прочитана. Предположим, что F - действительный поинтер открытого файла:
(read-line f)
введет следующую входную линию из файла, или ноль, если был достигнут конец файла.
4.97 (redraw [[]])
Эффект функции зависит от количества заданных параметров. Если вызов без параметров,
(redraw)
он перерисует весь чертеж, как команда АвтоКАДа REDRAW. Если вызов с параметром имени объекта,
(redraw )
перечерчен будет выбранный объект. Это полезно при определении объекта на экране после применения GRCLEAR для очистки экрана.
Завершение контроля над перечерчиванием объекта осуществляется вызовом REDRAW с двумя параметрами:
()
где - имя объекта, который будет перечерчен, а - целое число с одним из следующих значений:
Redraw Mode Action/действие
1 Перечертить объект на экране
2 Уничтожить объект (внести пробелы)
3 Высвечивание объекта (если позволяет дисплей)
4 Отмена высвечивания объекта (если позволяет дисплей)
Если - заголовок или комплексный объект (Полилиния или Блок с дополнениями), главный объект и все его подобъекты будут отрабатываться, если параметр положительный. Если параметр отрицательный, управляемый функцией REDRAW будет только один заголовок. Если ошибок нет, REDRAW всегда вводит ноль.
4.98.(rem ...)
Эта функция делит на и вводит остаток ( вычисляет остаток ). mod mod - модуль операция вычисления остатка.
REM может применяться с действительными и целыми числами со стандартными правилами перевода. Например:
(rem 42 12) вводит 6
(rem 12.0 16) вводит 12.000000
(rem 60 3) вводит 0
4.99.(repeat ...)
В этой функции <число> представляет любое из положительных целых чисел. Функция вычисляет каждое количество раз и вводит значение последнего выражения. Например, заданы назначения:
(setq a 10)
(setq b 100)
тогда:
(repeat 4
(setq a(+ a 10)))
(setq b(+ b 10)))
) вводит 140
4.100.(reverse )
Эта функция вводит <список> с зарезервированными элементами. Например:
(reverse '((a)b c)) вводит (C B (A))
4.101. (rtos [])
Эта функция вводит строку, которая является представлением <числа> (действительного) согласно с установками / режим и /точность и переменной, задающей размеры АвтоКАДа DIMZIN. <режим> и <точность> - целые числа, которые выбирают линейные элементы режима и точности. Ниже перечислены обеспеченные значения <режима>:
RTOS Режим Редактируемый формат
1 Научный
2 Десятичный
3 Прикладной (футы и десятичные дюймы)
4 Архитектурный (футы и дробные дюймы)
5 Производные дробные элементы
Параметры и соответствуют системе переменных LUNITS и LUPREC АвтоКАДа. Если вы пропускаете параметры, будут применяться текущие установки LUPREC и LUNITS. Примеры RTOS:
(rtos 17.5 1 4) вводит "1.7500E+01"
(rtos 17.5 2 2) вводит "17.50"
(rtos 17.5 3 2) вводит "1'-5.50""
(rtos 17.5 4 2) вводит "1'-5 1/2""
(rtos 17.5 5 2) вводит "17 1/2"
Глава 5. Разработка интерфейсов пользователя
5.1. Меню пользователя
Меню пользователя служит для расширения и дополнения существующего и разработки собственного меню. Меню пользователя задается в файле меню.Файлы меню представляют собой текстовые файлы.
Исходные файлы меню имеют расширение.mnu. Компилированные файлы имеют расширение.mnx. LISP-файлы меню имеют расширение.mnl. Эти файлы автоматически загружаются в память при загрузке файла меню с таким же именем и содержат LISP-выражения, которые могут использоваться файлом меню. Файлы определения меню имеют расширение.mnd. Они являются специальными исходными файлами, содержащими макросы. Файлы этого типа компилируются с помощью программы mc, которая размещена в каталоге SAMPLE.
Файл.mnu компилируется, и создается файл с расширением.mnx, который имеет компактный внутренний формат, позволяет значительно быстрее осуществлять загрузку меню. При создании нового рисунка файл меню с именем, указанным в рисунке-прототипе, загружается автоматически. АвтоКАД предоставляет возможность заменить это меню на новое. Для компиляции и загрузки меню используется команда menu (меню). При этом АвтоКАД записывает в файл рисунка имя последнего использовавшегося с ним меню; при последующем редактировании этого рисунка меню загружается автоматически. Команда menu загружает файл меню с диска:
Command: MENU
Для задания имени файла на экран выводится стандартное диалоговое окно файлов с заголовком «Выбор файла меню». АвтоКАД ищет файл с расширением.mnu, если он найден, то ищет файл с расширением.mnx, и если MNX-файл имеет те же дату и время создания, что и MNU-файл, он загружается АвтоКАДом. Иначе компилируется MNU-файл и загружается MNX-файл. Если MNU-файл не найден, АвтоКАД ищет MNX-файл. Если MNX-файл найден, АвтоКАД его загружает, иначе высвечивается сообщение об ошибке и запрос на ввод другого файла меню.
Если отключена системная переменная FILEDIA, можно воспользоваться командной строкой для загрузки меню:
Command: MENU : (Команда: МЕНЮ)
Menu file name or. for none : : (Имя файла меню или. если оно не нужно <текущее имя>:
Имя файла задается без расширения.
Иногда имеет смысл полностью убрать меню, например, для очистки зоны экранного меню. Для этого необходимо ввести «.» в ответ на запрос команды MENU.
5.2. Структура файла меню
Файл меню можно логически разбить на разделы, каждый из которых относится к некоторому устройству, поддерживающему работу с меню, и содержит командные строки, предназначенные для этого устройства. Разделы идентифицируются с помощью меток разделов:
***SCREEN - экранное меню;
***BUTTONSn - кнопочное меню устройства указания, где n - число от 1 до 4;
***AUXn - дополнительное кнопочное меню, где n - число от 1 до 4;
***POPn - падающие и курсорные меню, где n - число от 1 до 16;
***ICON - графическое меню;
***TABLETn - область меню планшета, где n - число от 1 до 4.
Метки определяют, что соответствующие пункты меню до метки следующего раздела или до конца файла относятся к конкретному работающему с меню устройству. Например:
***SCREEN
[Help]help
[Bye]end
***BUTTONS
erase
oops
Пункты меню «Help» и «Bye» относятся к меню экрана, а пункты «erase» и «oops» - к кнопочному меню. Если в файле нет метки «***SCREEN», то система АвтоКАД действует так, как будто «***SCREEN» является первой меткой в файле.
5.3. Подменю
Пользователю предоставляется возможность определять подменю, которые представляют собой группы из пунктов меню, активизировать их и сделать доступными для выбора пользователя. Например, выбор пункта «ARC» из подменю «DRAW» может активизировать подменю, которое содержит варианты исполнения команды ARC. Пункты дополнительного меню временно заменяют все или часть текущего меню. Обычно по окончании использования подменю происходит возвращение к предыдущему меню. Подменю могут быть вложенными.
Начало подменю задается меткой подменю. Она имеет следующий формат:
** <имя меню> <номер>.
Имя меню представляет собой последовательность из не более чем 31 символа, содержащую буквы, цифры, а также специальные символы «$», «-» (дефис), «_» (подчеркивающая черта). Метка подменю должна находиться в отдельной строке файла меню и не должна содержать пробелов. Каждое имя подменю в пределах файла должно быть уникальным, например:
**MOVE 3
[MOVE:]^C^CMOVE
Window
Last
Previous
Crossing
Remove
Add
Undo
где имя «**MOVE» введено для подменю команды MOVE. Заголовок [MOVE:] ?????????, что это команда и ее выбор вызовет выполнение команды MOVE.
Подменю может содержать любое количество пунктов, но с учетом возможностей устройства, с которого задается меню. Например, в меню экрана необходимо учитывать, что на экране одновременно можно отобразить только 20 пунктов.
При активизации подменю его пункты обычно замещают пункты предыдущего меню. Например, для экрана пункты подменю заменяют пункты предыдущего меню, начиная с верхнего блока, при этом они могут заменять только часть предыдущего меню. Номер задает номер начальной строки подменю. Например, **MOVE 3 позволяет сохранять в экранном меню доступ к корневому меню АвтоКАДа и объектной динамической привязке «* * * *», а далее разместить подменю для команды «MOVE:».
Чтобы активизировать или деактивизировать некоторое подменю, в пункте меню используется следующая конструкция:
$<раздел>=<подменю>, где
<раздел> - метка меню. Допустимы следующие сокращения:
S - для меню SCREEN;
P1 - P16 - для меню POP от 1 до 16;
I - для меню ICON;
B1 - B4 - для меню BUTTONS;
T1 - T4 - для меню TABLET1 - TABLET4;
A1 - A4 - для меню AUX1.
<подменю> - указывает метку подменю без символов «**» или имя раздела меню, которое должно активизироваться.
Например, в подменю EDIT для активизации подменю с именем MOVE используется конструкция $S=MOVE:
**EDIT 3
...
[MOVE:]^C^C$S=MOVE
...
Прежде чем активизируется подменю, пункты меню, активизированные в текущий момент времени, в разделе переписываются в стек. Для того, чтобы восстановить пункты предыдущего экрана, в пункте меню должно выдаваться «$S=». Например, чтобы предусмотреть в текущем меню пункт LAST для возврата в предыдущее меню, должен быть создан следующий пункт:
[_LAST_]^C^C$S=
Именно так в меню, поставляемом с системой АвтоКАД, осуществляется возврат в предыдущее меню. Сохраняются до восьми вложенных подменю. Если количество вложенных меню больше восьми, первые меню пропадают.
Активизацию механизма подменю можно осуществлять в ходе выполнения некоторой команды без ее прерывания, т.е. допускаются такие последовательности команд, как «COLOR $=X $S=LACOLOR»:
[COLOR:]^C^CCOLOR $S=X $S=LACOLOR
...
**X 3
...
[_LAST]$S= $S=
[DRAW]^C^C$S=X $S=DR
[EDIT]^C^C$S=X $S=ED
...
**LACOLOR 3
[COLOR]
red
yellow
green
cyan
blue
magenta
white
...
При этом начинается выполнение команды COLOR, затем последовательно включаются дополнительные меню экрана X и LACOLOR и система ожидает ввода параметров команды COLOR.
5.4. Пункт меню
Каждый пункт меню может состоять из команды, параметра или последовательности команд и параметров. Обычно каждый пункт меню занимает одну строку файла.
В экранном меню могут появиться только первые восемь символов пункта меню. Например, команда «SNAP 0.01» отобразится на дисплее в виде «SNAP 0.0». В этом случае для пункта меню можно определить заголовок пункта, заключив его в квадратные скобки «[ ]». Заголовок пункта должен содержать не более восьми символов и начинаться с первой позиции. Заголовок отображается на дисплее в соответствующем месте экранного меню. Часть пункта, следующая после заголовка, выдается в диалоговом поле при выборе этого пункта меню:
[MYSNAP]SNAP 0.01
Примечание. Пробелы в заголовках пунктов меню не требуются. Они могут быть включены для того, чтобы сделать файл удобочитаемым.
Все метки меню, управляющие операторы и параметры могут вводиться на верхнем, нижнем регистрах или же в произвольном их сочетании. При считывании из файла они преобразуются в символы верхнего регистра.
Если некоторый пункт в файле меню не помещается в одну строку, то для его продолжения используется символ «+». Знак «+» размещается в качестве последнего символа строки, которую вы хотите продолжить.
Иногда требуется ввод информации с клавиатуры или при помощи устройства указания в середине пункта меню. Символ «\» определяет ввод информации. Например,
[CIRCLE-3]circle \3
[ERASE 1]erase \;
Здесь «CIRCLE-3» запрашивает точку центра, а затем считывает из меню радиус, равный 3. «ERASE 1» позволяет указанием выбрать один объект, символ «;» соответствует нажатию .
Выбранный пункт меню не возобновляется:
? до завершения выбора в режиме объектной привязки, если ожидается ввод точки;
? до завершения ввода всех координат точки, если используются координатные фильтры;
? до формирования всего набора в команде SELECT (ВЫБРАТЬ);
? при вводе прозрачной команды до ее выполнения и завершения ввода;
? если в качестве ответа указывается другой пункт меню (для выбора ключа или выполнения прозрачной команды), до выполнения этого пункта (в свою очередь, новый выбранный пункт может иметь свои символы обратной косой черты).
При разработке меню, которые используют в версиях АвтоКАДа на разных иностранных языках, стандартные команды и ключевые слова АвтоКАДа на английском языке будут автоматически переводиться в команды и ключевые слова АвтоКАДа национальной версии (например, русский), если перед каждой командой или ключевым словом стоит символ подчеркивания (_):
[Центр, Начало, Длина]^C^C_arc;_c;\\_l
Для отмены действия предыдущей команды можно использовать в пункте меню строку ^C^C. Ее действие аналогично двойному вводу . Хотя выполнение большинства команд отменяется одним ^C, ^C^C требуется для возврата к подсказке Command: из вложенной команды (например, DIM); поэтому для надежности рекомендуется использовать ^C^C.
Обычно символы, считанные из пункта меню, отображаются в зоне подсказок экрана, как при вводе с клавиатуры, а запросы высвечиваются даже в том случае, когда пункт меню включает ответы. Этот вывод можно подавить с помощью системной переменной MENUECHO. Если эхо-вывод отключен, управляющая последовательность ^P в пункте включает его.
При выборе пункта меню АвтоКАД автоматически ставит после него пробел. Иногда это нежелетельно. Поэтому существует два соглашения: если в пункте меню появляется символ «;», то система АвтоКАД заменяет его на «ENTER». Если строка заканчивается каким-либо управляющим символом «\», «;» или «+», то АвтоКАД не добавляет после него символа пробела.
Можно использовать управляющие символы кода ASCII в строке команд в пункте меню путем ввода символа «^» перед любым другим символом. Например, ^С будет преобразован в код, соответствующий /.
В системе предусмотрена возможность автоматического повтора часто используемых команд до выбора какой-либо другой команды. Если пункт меню начинается строкой *^C^C (следующей сразу за заголовком пункта), то он запоминается и будет автоматически вводиться в ответ на подсказку Command: до тех пор, пока не будет прерван нажатием или выбором другого пункта меню. ^C нельзя использовать внутри пунктов меню, начинающихся со строки *^C^C, т.к. при этом прерывается повтор пункта меню.
В файлах меню используются следующие управляющие последовательности символов:
*** - указывает заголовок раздела;
** - указывает метку раздела подменю;
[] - ограничивает заголовки для экранного, падающих, курсорного меню, пунктов меню, графических меню, имен слайдов или текста;
; - выдает нажатие клавиши ;
^M - выдает нажатие клавиши ;
^I - выдает нажатие клавиши ;
\ - выдает паузу для ввода пользователем;
_ - переводит следующую за ним команду и ключевое слово АвтоКАД;
+ - продолжает макрос на следующей строке, если является последним символом в строке
=* - выводит текущую пиктограмму, падающее или курсорное меню на экран;
*^C^C - префикс для повтора пункта;
$ - специальный код, используемый для указания АвтоКАДу загрузить раздел меню;
^B - переключает режим ШАГ;
^C - отменяет выполнение команды;
^D - переключает режим отображения координат;
^E - устанавливает следующую плоскость изометрии;
^G - переключает режим СЕТКА;
^H - выдает нажатие клавиши ;
^O - переключает режим ОРТО;
^P - переключает переменную MENUECHO;
^Q - переключает вывод эхо всех запросов, сообщений и вводов на принтер;
^T - переключает режим ПЛАНШЕТ;
^V - изменяет текущий видовой экран.
Для создания пунктов меню, предназначенных для решения сложных задач, можно использовать возможности символов и S-выражений языка АвтоЛИСП. Например, S-выражение, обеспечивающее вычерчивание прямоугольной ломаной с указанием точек в качестве ее углов:
[BOX](setq a (getpoint «Enter first corner:»));\+
(setq b (getpoint «Enter second corner:»));\+
pline !a (list (car a) (cadr b)) !b (list (car b) (cadr a)) c;
В АвтоКАДе допускается использование до 255 символов в ЛИСП-коде в файлах меню. В случае более длинных кодов их следует разбивать с помощью точки с запятой (;), чтобы АвтоКАД мог считывать и использовать их отдельными блоками.
Для более удобного и эффективного использования АвтоЛИСПа в меню можно разместить ЛИСП-процедуры в отдельных файлах и использовать файл автоматической загрузки с расширением.mnl. Основным содержанием данных файлов являются функции load. АвтоКАД автоматически загружает файл.mnl после загрузки файла меню с таким же именем.