Stack Visualization Tool
Project description
A terminal based application for visualizing stack operations and creating stack diagrams.
pip install staq
cli
To run the cli;
staq
This will start the cli interface. Here is a quick example of some commands:
$> int etc[64]
$> call main(1,"hello")
$> char buf[64] --note note on local variable
$> call strcpy(buf,argv[0])
Because this is really just a tool for visualization, types are not strictly defined or used. For instance the following command is valid:
It will add a word to the stack with label i and value “index of buffer”
Local vars
you can declare local variables using standard C syntax.
char buffer[64]
int i = 0x89
Loading a C file
You can load a file with C syntax to import functions. The functions will be loaded into the context including arguments, local variables, and calls to other functions.
load test.c
Write
The write command lets you write data to the stack at a given address.
write 0x1000: 0x56, 0x78, 0x90, 0x12
#you can also use references to variables with offsets
write &buffer : 0x56, 0x78, 0x90, 0x12
write &buffer+4 : 0x56, 0x78, 0x90, 0x12
Push
push will push a single stack cell onto the stack. A cell contains one or more words. Each cell can have a label, note, and words
push arg1: 0x56 #Shortcut for 'push 0x56 ~~label arg1'
push ~~label buffer ~~size 64 #creates a 64 word cell with no specified data
push buf: 1,2,3,4,5 #creates a 5 word cell with the values filled in
push <main+0x54> ~~note return #creates a single word on the stack with no label, and a note
Pop
pop will remove words from the stack
pop #remove a single word
pop $esp #remove a single word and set the register esp to the value popped
pop 4 #remove 4 words
pop frame #remove current frame
Call
The call command will create a new stack frame and push the return address. If arguments are given, they will be pushed to the stack automatically.
Functions
The call command gets run through a CallingConvention subclass (currently only cdecl is available) and performs operations according to the convention:
push arguments to stack
create a new stack frame
pushes return address
You can declare functions to give the app context about argument type/size and labels, but you can also call arbitrary functions. It will just assume all arguments are a single row on the stack.
function myFunction(int a, int b)
call myFunction(41,32)
call undeclaredFunction(1,2,3,4) # Will assume all args are 32 bit values and label arg1, arg2, arg3, etc
run
The run command is similar to call, but it will continue calling the first known function call in each function until it runs out of calls or hits the ~~limit arg.
leave
The leave command will pop all local variables from the stack. This is the same as setting the stack pointer to the base of the current frame.
jmp
The jmp command will create a new stack frame and set the instruction pointer to the address given. It is similar to call but does not push args or a return address.
ret
ret will pop one word and then perform a jmp to that address.
save
The save command will save the current state of the stack to a file. The extension will determine the format. currently .html, .png, and .txt are supported.
.html will save the stack as an interactive html file.
.png will save the stack as a png image.
.txt will save the stack as a text file containing all of the commands to recreate the stack.
example png output:
back/forward
The session keeps a history of commands. You can move back and forward through the history with ctrl+ left-arrow and ctrl+ right-arrow
Sphinx extension
The package provides a Sphinx extension that allows you to add stack diaragrams to your documentation using the stack command structure
The stack directive can be used with inline code, or by pointing to a file
.. stack::
push ... ~~size 256
jmp main
char buf[64]
call printf("Args: %d, %d", 12,34)
.. stack:: assets/diagrams/demo.staq
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file staq-0.1.15.tar.gz
.
File metadata
- Download URL: staq-0.1.15.tar.gz
- Upload date:
- Size: 25.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 colorama/0.4.4 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/1.0.0 requests/2.32.3 rfc3986/1.5.0 tqdm/4.57.0 urllib3/2.2.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff335397e353e57f7ee8c409d1a1992d79bb57164d7584dc8b4f622e73d69604 |
|
MD5 | 0c0067b33e228adf33e3bed6f4ab30ea |
|
BLAKE2b-256 | 29c9ba67e1a5cab6d89e159b568d95a2433d21611acf66b25c7c2bcf9a82d1c0 |