assemble
assemble a sequence of addresses into an object
disassemble
break an object into its component addresses
pointto
obtain the expression pointed to by an address
addressof
obtain the address that points to an expression
Calling Sequence
Parameters
Description
Thread Safety
Examples
assemble(objectid, addrseq)
disassemble(addr)
pointto(addr)
addressof(expr)
objectid
-
integer or symbolic object type identifier
addrseq
sequence of integer addresses
addr
integer representing an address
expr
Maple expression
This collection of four functions is known as the ``hackware package'' in Maple. These functions allow access to the internal representations of Maple objects and to the addresses pointing to them.
You should become familiar with the internal representation of Maple objects before using this collection of functions. For details, refer to the Appendix in the Maple Programming Guide.
Extreme care is required when using these functions, because their use can lead to various types of unrecoverable internal errors. Maple does some rudimentary checks of the objects created through these functions, but it is not possible to check everything.
The functions assemble and disassemble are a complementary pair of functions:
assembleaddrseq→addr
disassembleaddr→addrseq
The first function, assemble, assembles an object identifier and a sequence of integer addresses into a Maple object and returns an integer addr that gives the address of the object.
The second function, disassemble, looks at the Maple object pointed to by the integer address addr, disassembles the object into its component parts, and returns the sequence of addresses of the component parts.
The object identifier objectid represents the type of the object, and can be expressed as an integer, or as a symbolic name. The valid object identifier names are:
AND
ASSIGN
BINARY
BREAK
CATENATE
COMPLEX
CONTROL
DCOLON
DEBUG
EQUATION
ERROR
EXPSEQ
FLOAT
FOR
FOREIGN
FUNCTION
GARBAGE
HASH
HASHTAB
HFLOAT
IF
IMPLIES
INEQUAT
INTNEG
INTPOS
LESSEQ
LESSTHAN
LEXICAL
LIST
LOCAL
MEMBER
MODDEF
MODULE
NAME
NEXT
NOT
OR
PARAM
POLY
POWER
PROC
PROD
RANGE
RATIONAL
READ
RETURN
RTABLE
SAVE
SDPOLY
SERIES
SET
STATSEQ
STOP
STRING
SUM
TABLE
TABLEREF
TRY
UNEVAL
USE
XOR
ZPPOLY
The kernelopts function with option dagtag can be used to map among these symbolic names and the corresponding integer values.
The functions pointto and addressof are a complementary pair of functions:
pointtoaddr→expr
addressofexpr→addr
The function pointto takes an integer address addr and returns the Maple expression to which it points.
The addressof function takes a Maple expression and returns the integer address that points to it.
An object whose only reference is through an addressof() reference could be collected by garbage collection. To avoid this, either make sure that all the objects for which you compute addressof() are assigned to variables, or delay garbage collection (see gc).
The assemble, disassemble, pointto and addressof commands are thread-safe as of Maple 15.
For more information on thread safety, see index/threadsafe.
f≔3x2+5.0
a≔addressoff
a≔36893628046471161444
pointtoa
3x2+5.0
d≔disassemblea
d≔16,36893628046378768108,36893488147419103235,36893628046470314940,36893488147419103231
kerneloptsdagtag=d1
pointtod2
x2
pointtod3
3
pointtod4
5.0
pointtod5
1
g≔assembled1,d2,d3
g≔36893628046368410644
pointtog
3x2
addressofg
36893628046369203900
h≔y=diffx2,x
h≔y=2x
b≔addressofh
b≔36893628046368192164
j≔disassembleb
j≔22,36893628046379112412,36893628046368192116
kerneloptsdagtag=j1
pointtoj2
y
pointtoj3
2x
n≔assembleINEQUAT,j2,j3
n≔36893628046367369420
pointton
y≠2x
See Also
dismantle
kernelopts
ProgrammingGuide/Appendix
The Maple debugger
Download Help Document