-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
0 parents
commit e19eddb
Showing
22 changed files
with
579 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
name: CI | ||
|
||
on: | ||
push: | ||
branches: [ main ] | ||
pull_request: | ||
branches: [ main ] | ||
|
||
# Allow to run this workflow manually from the Actions tab | ||
workflow_dispatch: | ||
|
||
jobs: | ||
linter: | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
python-version: ['3.10'] | ||
os: [ubuntu-latest] | ||
runs-on: ${{ matrix.os }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
- name: Install project | ||
run: make install | ||
- name: Run linter | ||
run: make lint | ||
|
||
tests_linux: | ||
needs: linter | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
python-version: ['3.10'] | ||
os: [ubuntu-latest] | ||
runs-on: ${{ matrix.os }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
- name: Install project | ||
run: make install | ||
- name: Run tests | ||
run: make test | ||
- name: Upload coverage reports to Codecov | ||
uses: codecov/codecov-action@v4.0.1 | ||
with: | ||
token: ${{ secrets.CODECOV_TOKEN }} | ||
|
||
tests_mac: | ||
needs: linter | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
python-version: ['3.10'] | ||
os: [macos-latest] | ||
runs-on: ${{ matrix.os }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
- name: Install project | ||
run: make install | ||
- name: Run tests | ||
run: make test | ||
|
||
tests_win: | ||
needs: linter | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
python-version: ['3.10'] | ||
os: [windows-latest] | ||
runs-on: ${{ matrix.os }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
- name: Install Pip | ||
run: pip install --user --upgrade pip | ||
- name: Install project | ||
run: pip install -e .[test] | ||
- name: run tests | ||
run: pytest -s -vvvv -l --tb=long tests |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,139 @@ | ||
# analysis output | ||
out/ | ||
|
||
# traces | ||
traces/**/* | ||
sample_traces/**/* | ||
|
||
# Byte-compiled / optimized / DLL files | ||
__pycache__/ | ||
*.py[cod] | ||
*$py.class | ||
|
||
# C extensions | ||
*.so | ||
|
||
# Distribution / packaging | ||
.Python | ||
build/ | ||
develop-eggs/ | ||
dist/ | ||
downloads/ | ||
eggs/ | ||
.eggs/ | ||
lib/ | ||
lib64/ | ||
parts/ | ||
sdist/ | ||
var/ | ||
wheels/ | ||
pip-wheel-metadata/ | ||
share/python-wheels/ | ||
*.egg-info/ | ||
.installed.cfg | ||
*.egg | ||
MANIFEST | ||
|
||
# PyInstaller | ||
# Usually these files are written by a python script from a template | ||
# before PyInstaller builds the exe, so as to inject date/other infos into it. | ||
*.manifest | ||
*.spec | ||
|
||
# Installer logs | ||
pip-log.txt | ||
pip-delete-this-directory.txt | ||
|
||
# Unit test / coverage reports | ||
htmlcov/ | ||
.tox/ | ||
.nox/ | ||
.coverage | ||
.coverage.* | ||
.cache | ||
nosetests.xml | ||
coverage.xml | ||
*.cover | ||
*.py,cover | ||
.hypothesis/ | ||
.pytest_cache/ | ||
|
||
# Translations | ||
*.mo | ||
*.pot | ||
|
||
# Django stuff: | ||
*.log | ||
local_settings.py | ||
db.sqlite3 | ||
db.sqlite3-journal | ||
|
||
# Flask stuff: | ||
instance/ | ||
.webassets-cache | ||
|
||
# Scrapy stuff: | ||
.scrapy | ||
|
||
# Sphinx documentation | ||
docs/_build/ | ||
|
||
# PyBuilder | ||
target/ | ||
|
||
# Jupyter Notebook | ||
.ipynb_checkpoints | ||
|
||
# IPython | ||
profile_default/ | ||
ipython_config.py | ||
|
||
# pyenv | ||
.python-version | ||
|
||
# pipenv | ||
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. | ||
# However, in case of collaboration, if having platform-specific dependencies or dependencies | ||
# having no cross-platform support, pipenv may install dependencies that don't work, or not | ||
# install all needed dependencies. | ||
#Pipfile.lock | ||
|
||
# PEP 582; used by e.g. github.com/David-OConnor/pyflow | ||
__pypackages__/ | ||
|
||
# Celery stuff | ||
celerybeat-schedule | ||
celerybeat.pid | ||
|
||
# SageMath parsed files | ||
*.sage.py | ||
|
||
# Environments | ||
.env | ||
.venv | ||
env/ | ||
venv/ | ||
ENV/ | ||
env.bak/ | ||
venv.bak/ | ||
|
||
# Spyder project settings | ||
.spyderproject | ||
.spyproject | ||
|
||
# Rope project settings | ||
.ropeproject | ||
|
||
# mkdocs documentation | ||
/site | ||
|
||
# mypy | ||
.mypy_cache/ | ||
.dmypy.json | ||
dmypy.json | ||
|
||
# Pyre type checker | ||
.pyre/ | ||
|
||
# templates | ||
.github/templates/* |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
{ | ||
"python.testing.pytestArgs": [ | ||
"tests" | ||
], | ||
"python.testing.unittestEnabled": false, | ||
"python.testing.pytestEnabled": true, | ||
"python.analysis.include": ["tests", "tod_attack_miner"] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
# How to develop on this project | ||
|
||
This project requires Python3. | ||
|
||
This instructions are for linux base systems. (Linux, MacOS, BSD, etc.) | ||
|
||
## Setting up your own virtual environment | ||
|
||
Run `make virtualenv` to create a virtual environment. | ||
then activate it with `source .venv/bin/activate`. | ||
|
||
## Install the project in develop mode | ||
|
||
Run `make install` to install the project in develop mode. | ||
|
||
## Run the tests to ensure everything is working | ||
|
||
Run `make test` to run the tests. | ||
|
||
## Format the code | ||
|
||
Run `make fmt` to format the code. | ||
|
||
## Run the linter | ||
|
||
Run `make lint` to run the linter. | ||
|
||
## Test your changes | ||
|
||
Run `make test` to run the tests. | ||
|
||
Ensure code coverage report shows `100%` coverage, add tests to your PR. | ||
|
||
## Build the docs locally | ||
|
||
Run `make docs` to build the docs. | ||
|
||
Ensure your new changes are documented. | ||
|
||
## Commit your changes | ||
|
||
This project uses [conventional git commit messages](https://www.conventionalcommits.org/en/v1.0.0/). | ||
|
||
Example: `fix(package): update setup.py arguments 🎉` (emojis are fine too) | ||
|
||
## Makefile utilities | ||
|
||
This project comes with a `Makefile` that contains a number of useful utility. | ||
|
||
```bash | ||
❯ make | ||
Usage: make <target> | ||
|
||
Targets: | ||
help: ## Show the help. | ||
install: ## Install the project in dev mode. | ||
fmt: ## Format code using black & isort. | ||
lint: ## Run pep8, black, mypy linters. | ||
test: lint ## Run tests and generate coverage report. | ||
watch: ## Run tests on every change. | ||
clean: ## Clean unused files. | ||
virtualenv: ## Create a virtual environment. | ||
release: ## Create a new tag for release. | ||
docs: ## Build the documentation. | ||
switch-to-poetry: ## Switch to poetry package manager. | ||
init: ## Initialize the project based on an application template. | ||
``` | ||
|
||
## Making a new release | ||
|
||
This project uses [semantic versioning](https://semver.org/) and tags releases with `X.Y.Z` | ||
Every time a new tag is created and pushed to the remote repo, github actions will | ||
automatically create a new release on github and trigger a release on PyPI. | ||
|
||
For this to work you need to setup a secret called `PIPY_API_TOKEN` on the project settings>secrets, | ||
this token can be generated on [pypi.org](https://pypi.org/account/). | ||
|
||
To trigger a new release all you need to do is. | ||
|
||
1. If you have changes to add to the repo | ||
* Make your changes following the steps described above. | ||
* Commit your changes following the [conventional git commit messages](https://www.conventionalcommits.org/en/v1.0.0/). | ||
2. Run the tests to ensure everything is working. | ||
4. Run `make release` to create a new tag and push it to the remote repo. | ||
|
||
the `make release` will ask you the version number to create the tag, ex: type `0.1.1` when you are asked. | ||
|
||
> **CAUTION**: The make release will change local changelog files and commit all the unstaged changes you have. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
FROM python:3.10-slim | ||
COPY . /app | ||
WORKDIR /app | ||
RUN pip install . | ||
CMD ["tod_attack_miner"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
include LICENSE | ||
include HISTORY.md | ||
include Containerfile | ||
graft tests | ||
graft tod_attack_miner |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
.ONESHELL: | ||
ENV_PREFIX=$(shell python -c "if __import__('pathlib').Path('.venv/bin/pip').exists(): print('.venv/bin/')") | ||
USING_POETRY=$(shell grep "tool.poetry" pyproject.toml && echo "yes") | ||
|
||
.PHONY: help | ||
help: ## Show the help. | ||
@echo "Usage: make <target>" | ||
@echo "" | ||
@echo "Targets:" | ||
@fgrep "##" Makefile | fgrep -v fgrep | ||
|
||
|
||
.PHONY: show | ||
show: ## Show the current environment. | ||
@echo "Current environment:" | ||
@if [ "$(USING_POETRY)" ]; then poetry env info && exit; fi | ||
@echo "Running using $(ENV_PREFIX)" | ||
@$(ENV_PREFIX)python -V | ||
@$(ENV_PREFIX)python -m site | ||
|
||
.PHONY: install | ||
install: ## Install the project in dev mode. | ||
@if [ "$(USING_POETRY)" ]; then poetry install && exit; fi | ||
@echo "Don't forget to run 'make virtualenv' if you got errors." | ||
$(ENV_PREFIX)pip install -e .[test] | ||
|
||
.PHONY: fmt | ||
fmt: ## Format/lint code using ruff format and ruff check | ||
$(ENV_PREFIX)ruff format | ||
$(ENV_PREFIX)ruff check --fix | ||
|
||
.PHONY: lint | ||
lint: ## Run ruff check and pyright | ||
$(ENV_PREFIX)ruff check | ||
$(ENV_PREFIX)pyright | ||
|
||
.PHONY: test | ||
test: lint ## Run tests and generate coverage report. | ||
$(ENV_PREFIX)pytest -v --cov-config .coveragerc --cov=tod_attack_miner -l --tb=short --maxfail=1 tests/ | ||
$(ENV_PREFIX)coverage xml | ||
$(ENV_PREFIX)coverage html | ||
|
||
.PHONY: watch | ||
watch: ## Run tests on every change. | ||
ls **/**.py | entr $(ENV_PREFIX)pytest -s -vvv -l --tb=long --maxfail=1 tests/ | ||
|
||
.PHONY: clean | ||
clean: ## Clean unused files. | ||
@find ./ -name '*.pyc' -exec rm -f {} \; | ||
@find ./ -name '__pycache__' -exec rm -rf {} \; | ||
@find ./ -name 'Thumbs.db' -exec rm -f {} \; | ||
@find ./ -name '*~' -exec rm -f {} \; | ||
@rm -rf .cache | ||
@rm -rf .pytest_cache | ||
@rm -rf build | ||
@rm -rf dist | ||
@rm -rf *.egg-info | ||
@rm -rf htmlcov | ||
@rm -rf .tox/ | ||
@rm -rf docs/_build | ||
|
||
.PHONY: virtualenv | ||
virtualenv: ## Create a virtual environment. | ||
@if [ "$(USING_POETRY)" ]; then poetry install && exit; fi | ||
@echo "creating virtualenv ..." | ||
@rm -rf .venv | ||
@python3 -m venv .venv | ||
@./.venv/bin/pip install -U pip | ||
@./.venv/bin/pip install -e .[test] | ||
@echo | ||
@echo "!!! Please run 'source .venv/bin/activate' to enable the environment !!!" | ||
|
||
.PHONY: release | ||
release: ## Create a new tag for release. | ||
@echo "WARNING: This operation will create s version tag and push to github" | ||
@read -p "Version? (provide the next x.y.z semver) : " TAG | ||
@echo "$${TAG}" > tod_attack_miner/VERSION | ||
@$(ENV_PREFIX)gitchangelog > HISTORY.md | ||
@git add tod_attack_miner/VERSION HISTORY.md | ||
@git commit -m "release: version $${TAG} 🚀" | ||
@echo "creating git tag : $${TAG}" | ||
@git tag $${TAG} | ||
@git push -u origin HEAD --tags | ||
@echo "Github Actions will detect the new tag and release the new version." | ||
|
||
.PHONY: docs | ||
docs: ## Build the documentation. | ||
@echo "building documentation ..." | ||
@$(ENV_PREFIX)mkdocs build | ||
URL="site/index.html"; xdg-open $$URL || sensible-browser $$URL || x-www-browser $$URL || gnome-open $$URL || open $$URL |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
# TOD attack miner | ||
|
||
[![codecov](https://codecov.io/gh/TOD-theses/tod_attack_miner/branch/main/graph/badge.svg?token=tod_attack_miner_token_here)](https://codecov.io/gh/TOD-theses/tod_attack_miner) | ||
[![CI](https://github.com/TOD-theses/tod_attack_miner/actions/workflows/main.yml/badge.svg)](https://github.com/TOD-theses/tod_attack_miner/actions/workflows/main.yml) | ||
|
||
See https://tod-theses.github.io/tod_attack_miner/. | ||
|
||
## Install | ||
|
||
See [CONTRIBUTING.md](CONTRIBUTING.md) for installation instructions. | ||
|
||
## Usage | ||
|
||
After installing it, you can run it as following: | ||
|
||
```bash | ||
$ python -m tod_attack_miner --help | ||
#or | ||
$ tod_attack_miner --help | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
coverage: | ||
status: | ||
project: | ||
default: | ||
informational: true | ||
patch: | ||
default: | ||
informational: true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
# TOD attack miner | ||
|
||
TODO... |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
site_name: Traces Analyzer | ||
theme: readthedocs | ||
|
||
nav: | ||
- Introduction: 'index.md' | ||
|
||
markdown_extensions: | ||
- admonition | ||
- plantuml_markdown: | ||
server: http://www.plantuml.com/plantuml # PlantUML server, for remote rendering |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
{ | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
# This requirements are for development and testing only, not for production. | ||
pytest | ||
coverage | ||
pytest-cov | ||
gitchangelog | ||
mkdocs | ||
plantuml_markdown | ||
pyright | ||
ruff |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
tqdm==4.66.1 | ||
typing_extensions==4.10.0 | ||
requests==2.31.0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
"""Python setup.py for tod_attack_miner package""" | ||
|
||
import io | ||
import os | ||
from setuptools import find_packages, setup # type: ignore | ||
|
||
|
||
def read(*paths, **kwargs): | ||
"""Read the contents of a text file safely. | ||
>>> read("tod_attack_miner", "VERSION") | ||
'0.1.0' | ||
>>> read("README.md") | ||
... | ||
""" | ||
|
||
content = "" | ||
with io.open( | ||
os.path.join(os.path.dirname(__file__), *paths), | ||
encoding=kwargs.get("encoding", "utf8"), | ||
) as open_file: | ||
content = open_file.read().strip() | ||
return content | ||
|
||
|
||
def read_requirements(path): | ||
return [ | ||
line.strip() | ||
for line in read(path).split("\n") | ||
if not line.startswith(('"', "#", "-", "git+")) | ||
] | ||
|
||
|
||
setup( | ||
name="tod_attack_miner", | ||
version=read("tod_attack_miner", "VERSION"), | ||
description="Analyze ethereum traces", | ||
url="https://github.com/TOD-theses/tod_attack_miner/", | ||
long_description=read("README.md"), | ||
long_description_content_type="text/markdown", | ||
author="TOD-theses", | ||
packages=find_packages(exclude=["tests", ".github"]), | ||
install_requires=read_requirements("requirements.txt"), | ||
entry_points={ | ||
"console_scripts": ["tod_attack_miner = tod_attack_miner.__main__:main"] | ||
}, | ||
extras_require={"test": read_requirements("requirements-test.txt")}, | ||
) |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
from pytest import FixtureRequest, fixture | ||
from pathlib import Path | ||
import sys | ||
|
||
|
||
@fixture | ||
def root_dir(request: FixtureRequest) -> Path: | ||
return request.config.rootpath | ||
|
||
|
||
# each test runs on cwd to its temp dir | ||
@fixture(autouse=True) | ||
def go_to_tmpdir(request: FixtureRequest): | ||
# Get the fixture dynamically by its name. | ||
tmpdir = request.getfixturevalue("tmpdir") | ||
# ensure local test created packages can be imported | ||
sys.path.insert(0, str(tmpdir)) | ||
# Chdir only for the duration of the test. | ||
with tmpdir.as_cwd(): | ||
yield |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
def test_demo(): | ||
pass |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
0.1.0 |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
"""Entry point for tod_attack_miner.""" | ||
|
||
from tod_attack_miner.cli import main # pragma: no cover | ||
|
||
if __name__ == "__main__": # pragma: no cover | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
"""CLI interface for tod_attack_miner project.""" | ||
|
||
from argparse import ArgumentParser, BooleanOptionalAction | ||
from pathlib import Path | ||
|
||
|
||
def main(): | ||
parser = ArgumentParser(description="Analyze bundles of transaction traces") | ||
parser.add_argument( | ||
"--out", | ||
type=Path, | ||
default=Path("out"), | ||
help="The directory where the reports should be saved", | ||
) | ||
parser.add_argument( | ||
"--bundles", | ||
type=Path, | ||
nargs="+", | ||
required=True, | ||
help="The directory path(s) that contain a metadata.json that describes what should be analyzed", | ||
) | ||
parser.add_argument("--verbose", action=BooleanOptionalAction, required=False) | ||
|
||
args = parser.parse_args() | ||
print(args) |