1
0
mirror of https://github.com/fadden/6502bench.git synced 2025-01-18 01:29:48 +00:00

Fix up the manual a bit

This commit is contained in:
Andy McFadden 2019-09-06 15:38:49 -07:00
parent 8727d49f43
commit a3b968f025
2 changed files with 35 additions and 20 deletions

View File

@ -53,7 +53,8 @@ method in <code>DisasmProject.cs</code>):</p>
and data operand formats.</li>
<li>Run the data analyzer. This looks for patterns in uncategorized
data, and connects instruction and data operands to target offsets.
The "nearby label" stuff is handled here. All of the results are
The "nearby label" stuff is handled here. Auto-labels are generated
for references to internal addresses. All of the results are
stored in the Anattribs array. (The data analysis pass is described in
more detail below.)</li>
<li>Remove hidden labels from the symbol table. These are user-specified
@ -62,11 +63,16 @@ method in <code>DisasmProject.cs</code>):</p>
want to pull them out of the symbol table. (Remember, symbolic
operands use "weak references", so a missing symbol just means the
operand is shown as a hex value.)</li>
<li>Resolve references to local variables. This sets the operand symbol
in Anattrib so we won't try to apply platform/project symbols to
zero-page addresses. If we somehow ended up with a variable that has
the same as a user label, we rename the variable.</li>
<li>Resolve references to platform and project external symbols.
This sets the operand symbol in Anattrib, and adds the symbol to
the list that is displayed in .EQ directives.</li>
<li>Generate cross-reference lists. This is done for file data and
for any platform/project symbols that are referenced.</li>
<li>Generate cross-reference lists. This is done for internal references,
for local variables, and for any platform/project symbols that are
referenced.</li>
<li>If annotated auto-labels are enabled, the simple labels are
replaced with the annotated versions here. (This can't be done earlier
because the annotations are generated from the cross-reference data.)</li>
@ -75,7 +81,8 @@ method in <code>DisasmProject.cs</code>):</p>
<p>Once analysis is complete, a line-by-line display list is generated
by walking through the annotated file data. Most of the actual strings
aren't rendered until they're needed.</p>
aren't rendered until they're needed. For complicated multi-line items
like string operands, the formatted text is cached.</p>
<h3><a name="auto-format">Automatic Formatting</a></h3>
@ -84,8 +91,9 @@ aren't rendered until they're needed.</p>
inline data byte. Some offsets are also marked as the start of an instruction
or data area. The start offsets may have a format descriptor associated
with them.</p>
<p>Format descriptors have a format (like "numeric" or "string") a
sub-format (like "hexadecimal" or "null-terminated"), and a length. For
<p>Format descriptors have a format (like "numeric" or
"null-terminated string") a sub-format (like "hexadecimal" or
"high ASCII"), and a length. For
an instruction operand the length is redundant, but for a data operand it
determines the width of the numeric value or length of the string. For
this reason, instructions do not need a format descriptor, but all
@ -140,8 +148,9 @@ code runs through the same set of steps. The advantage of this approach
is that the act of doing a thing, undoing a thing, and redoing a thing
are all handled the same way.</p>
<p>None of the editors modify the project data structures directly. All
changes are added to a change set, which is processed by a single function.
The change sets are kept in the undo/redo buffer indefinitely. After
changes are added to a change set, which is processed by a single
"apply changes" function. The change sets are kept in the undo/redo
buffer indefinitely. After
the changes are made, the Anattrib array and other data structures are
regenerated.</p>
@ -277,13 +286,13 @@ correctly will require improvements to the user interface.</p>
<h3><a name="extension-scripts">Extension Scripts</a></h3>
<p>Extension scripts can mark data that follows a JSR or JSL as inline
<p>Extension scripts can mark data that follows a JSR, JSL, or BRK as inline
data, or change the format of nearby data or instructions. The first
time a JSR/JSL instruction is encountered, all loaded extension scripts
are offered a chance to act.</p>
time a JSR/JSL/BRK instruction is encountered, all loaded extension scripts
that implement the appropriate interface are offered a chance to act.</p>
<p>The first script that applies a format wins. Attempts to re-format
instructions or data that has already been formatted will fail. This rule
instructions or data that have already been formatted will fail. This rule
ensures that anything explicitly formatted by the user will not be
overridden by a script.</p>
@ -298,9 +307,9 @@ before code analysis starts.)</p>
<h2><a name="data-analysis">Data Analysis</a></h2>
<p>The data analyzer performs two tasks. It matches operands with
offsets, and it analyzes uncategorized data. Either or both of
these can be disabled from the
<a href="settings.html#project-props">project properties</a></p>
offsets, and it analyzes uncategorized data. This behavior can be
modified in the
<a href="settings.html#project-properties">project properties</a>.</p>
<p>The data target analyzer examines every instruction and data operand
to see if it's referring to an offset within the data file. If the
@ -319,8 +328,8 @@ pieces, where contiguous regions hold nothing but data, are not split
across a ".ORG" directive, are not interrupted by data, and do not
contain anything that the user has chosen to format. Each region is
scanned for matching patterns. If a match is found, a format entry
is added to the Anattrib array. Otherwise, data is added as independent
byte values.</p>
is added to the Anattrib array. Otherwise, data is added as single-byte
values.</p>
</div>

View File

@ -470,9 +470,12 @@ exported symbols can be pulled directly into other projects.</p>
instructions or data offsets that are the target of operands. They're
formed by appending the hexadecimal address to the letter "L", with
additional characters added if some other symbol has already defined
that label. Auto labels are only added where they are needed. Because
auto labels may be redefined or disappear, the editor will try to prevent
you from referring to them when editing operands.</p>
that label. Options can be set that change the "L" to a character or
characters based on how the label is referenced, e.g. "B" for branch targets.
Auto labels are only added where they are needed, and are removed when
no longer necessary. Because auto labels may be renamed or vanish, the
editor will try to prevent you from referring to them when editing
operands.</p>
<h3><a name="local-vars">Local Variables</a></h3>
@ -536,6 +539,9 @@ ways for a table to erase an earlier definition:</p>
</ol>
<p>As you might expect, you're not allowed to have duplicate labels or
overlapping values in an individual table.</p>
<p>If a platform/project symbol has the same value as a local variable,
the local variable is used. If the local variable definition is cleared,
use of the platform/project symbol will resume.</p>
<p>Not all assemblers support redefinable variables. In those cases,
the symbol names will be modified to be unique (e.g. the second definition
of <code>PTR</code> becomes <code>PTR_1</code>), and variables will have