|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230 |
- <?php
- /*************************************************************************************
- * 6502acme.php
- * -------
- * Author: Warren Willmey
- * Copyright: (c) 2010 Warren Willmey.
- * Release Version: 1.0.8.11
- * Date Started: 2010/05/26
- *
- * MOS 6502 (more specifically 6510) ACME Cross Assembler 0.93 by Marco Baye language file for GeSHi.
- *
- * CHANGES
- * -------
- * 2010/07/22
- * - First Release
- *
- * TODO (updated 2010/07/22)
- * -------------------------
- *
- *************************************************************************************
- *
- * This file is part of GeSHi.
- *
- * GeSHi is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * GeSHi is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with GeSHi; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- *
- ************************************************************************************/
-
- $language_data = array (
- 'LANG_NAME' => 'MOS 6502 (6510) ACME Cross Assembler format',
- 'COMMENT_SINGLE' => array(1 => ';'),
- 'COMMENT_MULTI' => array(),
- 'CASE_KEYWORDS' => GESHI_CAPS_NO_CHANGE,
- 'QUOTEMARKS' => array("'", '"'),
- 'ESCAPE_CHAR' => '',
- 'KEYWORDS' => array(
- /* 6502/6510 Opcodes. */
- 1 => array(
- 'adc', 'and', 'asl', 'bcc', 'bcs', 'beq', 'bit', 'bmi',
- 'bne', 'bpl', 'brk', 'bvc', 'bvs', 'clc', 'cld', 'cli',
- 'clv', 'cmp', 'cpx', 'cpy', 'dec', 'dex', 'dey', 'eor',
- 'inc', 'inx', 'iny', 'jmp', 'jsr', 'lda', 'ldx', 'ldy',
- 'lsr', 'nop', 'ora', 'pha', 'php', 'pla', 'plp', 'rol',
- 'ror', 'rti', 'rts', 'sbc', 'sec', 'sed', 'sei', 'sta',
- 'stx', 'sty', 'tax', 'tay', 'tsx', 'txa', 'txs', 'tya',
- ),
- /* Index Registers, yes the 6502 has other registers by they are only
- * accessable by specific opcodes. The 65816 also has access to the stack pointer S. */
- 2 => array(
- 'x', 'y', 's'
- ),
- /* Directives or "pseudo opcodes" as defined by ACME 0.93 file AllPOs.txt. */
- 3 => array(
- '!8', '!08', '!by', '!byte',
- '!16', '!wo', '!word',
- '!24', '!32',
- '!fi', '!fill',
- '!align',
- '!ct', '!convtab',
- '!tx', '!text',
- '!pet',
- '!raw',
- '!scrxor',
- '!to',
- '!source',
- '!bin', '!binary',
- '!zn', '!zone',
- '!sl',
- '!svl',
- '!sal',
- '!if', '!ifdef',
- '!for',
- '!set',
- '!do', 'while', 'until',
- '!eof', '!endoffile',
- '!warn', '!error', '!serious',
- '!macro',
- // , '*=' // Not a valid keyword (uses both * and = signs) moved to symbols instead.
- '!initmem',
- '!pseudopc',
- '!cpu',
- '!al', '!as', '!rl', '!rs',
- ),
-
- /* 6502/6510 undocumented opcodes (often referred to as illegal instructions).
- * These are present in the 6502/6510 but NOT in the newer CMOS revisions of the 65C02 or 65816.
- * As they are undocumented instructions there are no "official" names for them, there are also
- * several more that mainly perform various forms of crash and are not supported by ACME 0.93.
- */
- 4 => array(
- 'anc', 'arr', 'asr', 'dcp', 'dop', 'isc', 'jam', 'lax',
- 'rla', 'rra', 'sax', 'sbx', 'slo', 'sre', 'top',
- ),
- /* 65c02 instructions, MOS added a few (much needed) instructions in the CMOS version of the 6502, but stupidly removed the undocumented/illegal opcodes.
- * ACME 0.93 does not support the rmb0-7 and smb0-7 instructions (they are currently rem'ed out). */
- 5 => array(
- 'bra', 'phx', 'phy', 'plx', 'ply', 'stz', 'trb', 'tsb'
- ),
- /* 65816 instructions. */
- 6 => array(
- 'brl', 'cop', 'jml', 'jsl', 'mvn', 'mvp', 'pea', 'pei',
- 'per', 'phb', 'phd', 'phk', 'plb', 'pld', 'rep', 'rtl',
- 'sep', 'tcd', 'tcs', 'tdc', 'tsc', 'txy', 'tyx', 'wdm',
- 'xba', 'xce',
- ),
- /* Deprecated directives or "pseudo opcodes" as defined by ACME 0.93 file AllPOs.txt. */
- 7 => array(
- '!cbm',
- '!sz', '!subzone',
- '!realpc',
- ),
- /* Math functions, some are aliases for the symbols. */
- 8 => array(
- 'not', 'div', 'mod', 'xor', 'or', 'sin', 'cos', 'tan',
- 'arcsin', 'arccos', 'arctan', 'int', 'float',
-
- ),
-
- ),
- 'SYMBOLS' => array(
- // '[', ']', '(', ')', '{', '}', // These are already defined by GeSHi as BRACKETS.
- '*=', '#', '!', '^', '-', '*', '/',
- '%', '+', '-', '<<', '>>', '>>>',
- '<', '>', '^', '<=', '<', '>=', '>', '!=',
- '=', '&', '|', '<>',
- ),
- 'CASE_SENSITIVE' => array(
- GESHI_COMMENTS => false,
- 1 => false,
- 2 => false,
- 3 => false,
- 4 => false,
- 5 => false,
- 6 => false,
- 7 => false,
- 8 => false,
- ),
- 'STYLES' => array(
- 'KEYWORDS' => array(
- 1 => 'color: #00f; font-weight:bold;',
- 2 => 'color: #00f; font-weight:bold;',
- 3 => 'color: #080; font-weight:bold;',
- 4 => 'color: #f00; font-weight:bold;',
- 5 => 'color: #80f; font-weight:bold;',
- 6 => 'color: #f08; font-weight:bold;',
- 7 => 'color: #a04; font-weight:bold; font-style: italic;',
- 8 => 'color: #000;',
- ),
- 'COMMENTS' => array(
- 1 => 'color: #999; font-style: italic;',
- ),
- 'ESCAPE_CHAR' => array(
- 0 => 'color: #009; font-weight: bold;'
- ),
- 'BRACKETS' => array(
- 0 => 'color: #000;'
- ),
- 'STRINGS' => array(
- 0 => 'color: #080;'
- ),
- 'NUMBERS' => array(
- GESHI_NUMBER_INT_BASIC => 'color: #f00;',
- GESHI_NUMBER_HEX_PREFIX_DOLLAR => 'color: #f00;',
- GESHI_NUMBER_HEX_PREFIX => 'color: #f00;',
- GESHI_NUMBER_BIN_PREFIX_PERCENT => 'color: #f00;',
- GESHI_NUMBER_FLT_NONSCI => 'color: #f00;',
- ),
- 'METHODS' => array(
- ),
- 'SYMBOLS' => array(
- 0 => 'color: #080;'
- ),
- 'REGEXPS' => array(
- 0 => 'color: #f00;'
- , 1 => 'color: #933;'
- ),
- 'SCRIPT' => array(
- )
- ),
- 'URLS' => array(
- 1 => '',
- 2 => '',
- 3 => '',
- 4 => '',
- 5 => '',
- 6 => '',
- 7 => '',
- 8 => '',
- ),
- 'OOLANG' => false,
- 'OBJECT_SPLITTERS' => array(
- ),
- 'NUMBERS' =>
- GESHI_NUMBER_INT_BASIC |
- GESHI_NUMBER_FLT_NONSCI |
- GESHI_NUMBER_HEX_PREFIX_DOLLAR |
- GESHI_NUMBER_HEX_PREFIX |
- GESHI_NUMBER_BIN_PREFIX_PERCENT,
- // AMCE Octal format not support and gets picked up as Decimal unfortunately.
- 'REGEXPS' => array(
- //ACME .# Binary number format. e.g. %..##..##..##
- 0 => '\%[\.\#]{1,64}',
- //ACME Local Labels
- 1 => '\.[_a-zA-Z][_a-zA-Z0-9]*',
- ),
- 'STRICT_MODE_APPLIES' => GESHI_NEVER,
- 'SCRIPT_DELIMITERS' => array(
- ),
- 'HIGHLIGHT_STRICT_BLOCK' => array(
- ),
- 'TAB_WIDTH' => 8,
- 'PARSER_CONTROL' => array(
- 'NUMBERS' => array(
- 'PRECHECK_RX' => '/[\da-fA-F\.\$\%]/'
- )
- )
- );
-
- ?>
|