WikiDer > POSXML

POSXML

POSXML (аббревиатура от пмазь Ож Sэль еИксухоженный MArkup Language) - это язык программирования, основанный на XML, который используется для создания приложений для POS терминал.

Обычно язык программирования используется для разработки таких приложений C или же C ++. Основное назначение POSXML - упростить разработку приложений для POS-терминалов. Он содержит набор инструкций и предварительно запрограммированных команд, которые позволяют напрямую взаимодействовать с машиной, что приводит к значительному сокращению времени разработки приложений.

Особенности языка

Структура POSXML

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

Пример:

<!-- Variables declaration --><строковая переменная значение ="" переменная ="sTicketInfo"/><строковая переменная значение ="" переменная ="sCityInfo"/><целочисленная переменная значение ="0" переменная =«iQtdTickets»/><целочисленная переменная значение ="0" переменная ="iInvalidInfo"/>		<!-- Function Display MAIN Menu --><функция имя ="fMainMenu">    <целочисленная переменная значение ="0" переменная =«iOption»/>			    <!-- Main Menu -->    <меню options =«ГЛАВНОЕ МЕНЮ:  1. ПРОДАЖА БИЛЕТОВ  2. ОТЧЕТ  3. ВЫХОД» переменная ="$ (iOption)"/>			    <!-- 1.SALE OF TICKETS -->    <если оператор ="равно" значение ="1" переменная ="$ (iOption)">       ...    </if>    ...			</function>

Скомпилированный язык

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

При компиляции программа, написанная на POSXML, становится набором байт-кодов, которые интерпретируются виртуальной машиной на POS-терминале, что приводит к реализации на POS-терминале.

Пример:

<дисплей линия ="0" столбец ="0" сообщение =«Пример байт-кода» />

Скомпилированный байт-код:

d0  x0A 0  x0A Пример байт-кода  x0A  x0D

Синтаксис

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

Примеры:

Команды, не требующие инструкций или параметров.

<network.hostdisconect/><чистый дисплей /><ключ ожидания />

Команды, требующие инструкций и параметров для взаимодействия с оборудованием.

<дисплей линия ="1" столбец ="1" сообщение =«POSXML» /><меню переменная ="$ (var1)" options =«МЕНЮ  1. Первая строка  2. Вторая строка  3. Третья строка»/><ждать миллисекунды ="1000" />

Имена, присвоенные функциям, переменным и страницам, также должны подчиняться правилам, написанным заглавными и строчными буквами, поэтому, если разработчик создает функцию с именем «Calcula_digito», он не сможет вызвать переменную через «Calcula_Digito». Вызов функции или страницы переменной должен соответствовать точному имени, присвоенному программистом.

Команды и инструкции

Поскольку это структурированный язык, основанный на XML, POSXML - это язык, который постоянно развивается, новые команды и инструкции могут быть добавлены в вашу библиотеку в любое время. Первоначально в языке было всего два десятка базовых команд для создания функционального приложения на POS-терминале с использованием нескольких ресурсов: только базовый дисплей (ЖК-дисплей), клавиатуру, устройство чтения магнитных карт и принтер.

С развитием языка теперь доступно почти сотня команд и инструкций для работы с файлами, изображениями, математическими операторами, функциями для управления переменными типа String, определения переменных, логических операторов, классов для работы с протоколом ISO 8583 ( Стандарт протокола для обмена информацией при транзакциях с кредитными картами), среди прочего.

Переменные и типы данных

Переменные в POSXML типизированы; есть только два типа: целые и строковые. POSXML ограничивает количество объявленных переменных до 512.

Эти переменные объявлены глобальными, т.е. они используются на всех запланированных страницах программы POSXML в процессе выполнения.

Примеры:

Переменная строкового типа:

<!-- Declaring a string type variable containing: "http://en.wikipedia.org/wiki/posxml" --><строковая переменная значение ="http://en.wikipedia.org/wiki/posxml" переменная ="URL" /><!-- Accessing the content of the declared variable --><дисплей линия ="0" столбец ="0" сообщение ="$ (url)" />

Переменная целочисленного типа:

<!-- Declaring an integer type variable containing: "0" --><целочисленная переменная значение ="0" переменная ="Я ценю" /> столбец ="0" линия ="0" сообщение ="Введите сумму:" переменная ="$ (iValue)" />

Вызов переменной, которая объявлена ​​в памяти, выполняется $ (name_of_the_variable), независимо от ее типа.

Также возможно преобразовать переменную одного типа в переменную другого типа. В POSXML для этого используются команды inttostring и stringtoint.

Примеры:

<целочисленная переменная значение ="1" переменная ="iOpcao_Tipo_Inteiro" /><строковая переменная значение =""  переменная ="sOpcao_Tipo_String" /> целочисленная переменная ="$ (iOpcao_Tipo_Inteiro)" stringvariable ="$ (sOpcao_Tipo_String)" />

Файловая система

При написании приложения для POS-терминала разработчик сталкивается с необходимостью записи в конкретную файловую систему оборудования. Язык POSXML работает с файлами типа WALK dbFile (файловая система, определяемая структурой, которая интерпретирует программу, скомпилированную POSXML). Эта файловая система WALK dbFile использует формат: ключ = буфер n ключ = буфер n, в основном формат текстовых файлов в среде Unix, где п используется для обертывания. В языке POSXML есть 8 основных команд для работы с файлами в POS-терминале, они есть.

  • редактировать файл
  • файл для чтения
  • readfilebyindex
  • удалить файл
  • file.open
  • file.write
  • file.read
  • file.close

Примеры:

 имя файла ="test.txt" ключ ="$ (sChave)" значение ="$ (sValor)" /> <файл чтения имя файла ="test.txt" ключ ="$ (sChave)" variabledestination ="$ (sRetorno)" /> имя файла ="test.db" index ="0" variablekey ="$ (var1)" значение переменной ="$ (var2)" переменная возврат ="$ (var3)" />  имя файла ="test.txt" />

Примеры кода

Традиционный "Hello World"

<!-- An example application that shows the phgrase "Hello World" on the display. --><!--  The command "display" shows a message in a row and column specific. --><дисплей линия ="3" столбец ="0" сообщение ="Привет, мир" /><!--  The command "waitkey" waits till the operator press someone key for continue the execution. --><ключ ожидания />

Меню, функции и впечатления

<строковая переменная значение ="" переменная ="stringName" /><строковая переменная значение ="" переменная ="строковое значение" /><целочисленная переменная значение ="0" переменная ="integerValue" /><целочисленная переменная значение ="0" переменная ="integerOption" />  <!--  The command menu is used to show a menu in the terminal's display. The captured value is put in variable.  --><меню переменная ="$ (integerOption)" options =" Меню  1) Основная функция  2) Функция печати" /><если переменная ="$ (integerOption)" оператор ="равно" значение ="1" >   <!--  The command callfunction is used to call a function defined with the function instruction.  -->    имя ="Главный" /></if>  <если переменная ="$ (integerOption)" оператор ="равно" значение ="2" >   <!--  The command callfunction is used to call a function defined with the function instruction.  -->    имя ="Распечатать" /></if> <!-- The command function is used to make functions in PosXml Application. --><функция имя ="Главный" >         Терминал показывает маску с запятой и точками при нажатии цифровых клавиш.       Полученное значение умножается на 100 и помещается в переменную без запятой и точек.   -->    переменная ="$ (integerValue)" линия ="0" столбец ="0" сообщение ="Ввод значения:" />   <чистый дисплей />   <!-- The command inttostring is used to convert an integer variable in a string variable. -->    переменная целое число ="$ (integerValue)" переменная строка ="$ (stringValue)" />   <дисплей линия ="2" столбец ="0" сообщение ="Значение:" />   <дисплей линия ="3" столбец ="0" сообщение ="$ (stringValue)" />   <ключ ожидания /></function> <функция имя ="Распечатать" >           Формат указывается в параметре формата. Полученное значение помещается в переменную.    -->    переменная ="$ (имя_строки)" линия ="0" столбец ="0" сообщение ="Введите ваше имя:" формат =«АААААААААА» / >   <печать сообщение ="$ (имя_строки)" />   <!-- The command paperfeed is used to advance paper of the terminal's printer. -->   <подача бумаги /></function>

Работа с файлом POS

<строковая переменная значение ="" переменная ="stringRet" /><строковая переменная значение ="" переменная ="stringWriteKey" /><строковая переменная значение ="" переменная ="stringWriteValue" />   переменная ="$ (stringWriteKey)" линия ="0" столбец ="0" сообщение ="Введите ключ:" формат =«АААААААААА» /> переменная ="$ (stringWriteValue)" линия ="2" столбец ="0" сообщение ="Введите значение:" формат ="9999999999" />     Формат файла в 'формате Walk Db': ('ключ = значение  nключ = значение  n ...'). --> имя файла ="test.txt" ключ ="$ (stringWriteKey)" значение ="$ (stringWriteValue)" />     Формат файла в 'формате Walk Db': ('ключ = значение  nключ = значение  n ...').     Если файл или ключ существует, значением является пробел ''. --><файл чтения имя файла ="test.txt" ключ ="$ (stringWriteKey)" variabledestination ="$ (строкаRet)" /><!-- The command deletefile is used to remove a file from the terminal's memory. --> имя файла ="test.txt" /><!-- The command joinstring is used to join firstvalue and secondvalue in variabledestination. --><соединение firstvalue ="Результат:" второе значение ="$ (строкаRet)" variabledestination ="$ (строкаRet)" /><чистый дисплей /><дисплей линия ="4" столбец ="0" сообщение ="$ (stringRet)" /><ключ ожидания />

Пример с while "Пока"

<!-- The command "stringvariable" creates in memory one variable of a type string, in this case the name is "sData". --><строковая переменная значение ="" переменная ="stringData" /><строковая переменная значение =«KEY_CANCEL» переменная ="stringKey" />       когда значение sKey отличается от KEY_CANCEL. --><пока переменная ="$ (stringKey)" оператор ="равно" значение =«KEY_CANCEL» >   <!-- The command cleandisplay is used to clean the terminal's display. -->   <чистый дисплей />        и сохраните это значение в «variabledestination».    -->    формат ="д / м / гг ч: м: с" variabledestination ="$ (stringData)" />   <!-- The command "display" shows a message in a row and column specific. -->   <дисплей линия ="2" столбец ="0" сообщение ="$ (stringData)" />           В случае, если не будет жестких ключей, будет возвращено значение «KEY_CANCEL».    -->   <ключ чтения миллисекунды ="800" переменная возврат ="$ (stringKey)" /></while><дисплей линия ="2" столбец ="0" сообщение ="$ (stringKey)" /><ключ ожидания />

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

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