From 27a29d9685bf243b393af0c6b3af85f1b1041221 Mon Sep 17 00:00:00 2001 From: Grazfather Date: Sun, 30 Jul 2023 11:47:32 -0400 Subject: [PATCH] Reformat README (#976) --- README.md | 56 +++++++++++++++++++++++++++++++++++++------------------ 1 file changed, 38 insertions(+), 18 deletions(-) diff --git a/README.md b/README.md index 4fee76a4e..7985bd718 100644 --- a/README.md +++ b/README.md @@ -8,13 +8,17 @@ Try GEF

-`GEF` (pronounced ʤɛf - "Jeff") is a set of commands for x86/64, ARM, MIPS, PowerPC and SPARC to assist exploit developers and reverse-engineers when using old school GDB. It provides additional features to GDB using the Python API to assist during the process of dynamic analysis and exploit development. Application developers will also benefit from it, as GEF lifts a great part of regular GDB obscurity, avoiding repeating traditional commands, or bringing out the relevant information from the debugging runtime. - - +`GEF` (pronounced ʤɛf - "Jeff") is a set of commands for x86/64, ARM, MIPS, PowerPC and SPARC to +assist exploit developers and reverse-engineers when using old school GDB. It provides additional +features to GDB using the Python API to assist during the process of dynamic analysis and exploit +development. Application developers will also benefit from it, as GEF lifts a great part of regular +GDB obscurity, avoiding repeating traditional commands, or bringing out the relevant information +from the debugging runtime. ## Instant Setup ## -Simply make sure you have [GDB 8.0 or higher](https://www.gnu.org/s/gdb) compiled with Python3.6+ bindings, then: +Simply make sure you have [GDB 8.0 or higher](https://www.gnu.org/s/gdb) compiled with Python3.6+ +bindings, then: ```bash @@ -34,7 +38,8 @@ $ gdb -q (gdb) pi import urllib.request as u, tempfile as t; g=t.NamedTemporaryFile(suffix='-gef.py'); open(g.name, 'wb+').write(u.urlopen('https://tinyurl.com/gef-main').read()); gdb.execute('source %s' % g.name) ``` -_Note_: to fetch the latest of GEF (i.e. from the `dev` branch), simply replace in the URL to https://gef.blah.cat/dev. +_Note_: to fetch the latest of GEF (i.e. from the `dev` branch), simply replace in the URL to +https://gef.blah.cat/dev. You can immediately see that GEF is correctly installed by launching GDB: @@ -42,21 +47,32 @@ You can immediately see that GEF is correctly installed by launching GDB: A few of `GEF` features include: - * **One** single GDB script - * Entirely **architecture agnostic**, **NO** dependencies: `GEF` is battery-included and [is installable instantly](https://hugsy.github.io/gef/#setup) - * **Fast** limiting the number of dependencies and optimizing code to make the commands as fast as possible - * Provides a great variety of commands to drastically change your experience in GDB. - * [**Easily** extensible](https://hugsy.github.io/gef/api/) to create other commands by providing more comprehensible layout to GDB Python API. - * Full Python3 support ([Python2 support was dropped](https://github.com/hugsy/gef/releases/tag/2020.03) - see [`gef-legacy`](https://github.com/hugsy/gef-legacy)). - * Built around an architecture abstraction layer, so all commands work in any GDB-supported architecture such as x86-32/64, ARMv5/6/7, AARCH64, SPARC, MIPS, PowerPC, etc. - * Suited for real-life apps debugging, exploit development, just as much as CTF - -Check out the [Screenshot page](docs/screenshots.md) for more or [try it online](https://demo.gef.blah.cat) (user:`gef`/password:`gef-demo`) +* **One** single GDB script +* Entirely **architecture agnostic**, **NO** dependencies: `GEF` is battery-included and [is + installable instantly](https://hugsy.github.io/gef/#setup) +* **Fast** limiting the number of dependencies and optimizing code to make the commands as fast as + possible +* Provides a great variety of commands to drastically change your experience in GDB. +* [**Easily** extensible](https://hugsy.github.io/gef/api/) to create other commands by providing +d more comprehensible layout to GDB Python API. +* Full Python3 support ([Python2 support was + dropped](https://github.com/hugsy/gef/releases/tag/2020.03) - see + [`gef-legacy`](https://github.com/hugsy/gef-legacy)). +* Built around an architecture abstraction layer, so all commands work in any GDB-supported + architecture such as x86-32/64, ARMv5/6/7, AARCH64, SPARC, MIPS, PowerPC, etc. +* Suited for real-life apps debugging, exploit development, just as much as CTF + +Check out the [Screenshot page](docs/screenshots.md) for more or [try it +online](https://demo.gef.blah.cat) (user:`gef`/password:`gef-demo`) ## Documentation ## -Unlike other GDB plugins, GEF has an extensive and up-to-date [documentation](https://hugsy.github.io/gef/). Users are recommended to refer to it as it may help them in their attempts to use GEF. In particular, new users should navigate through it (see the [FAQ](https://hugsy.github.io/gef/faq/) for common installation problems), and the problem persists, try to reach out for help on the Discord channel or submit an issue. +Unlike other GDB plugins, GEF has an extensive and up-to-date +[documentation](https://hugsy.github.io/gef/). Users are recommended to refer to it as it may help +them in their attempts to use GEF. In particular, new users should navigate through it (see the +[FAQ](https://hugsy.github.io/gef/faq/) for common installation problems), and the problem persists, +try to reach out for help on the Discord channel or submit an issue. ## Current status ## @@ -68,11 +84,15 @@ Unlike other GDB plugins, GEF has an extensive and up-to-date [documentation](ht ## Contribute ## -To get involved, refer to the [Contribution documentation](https://hugsy.github.io/gef/#contribution) and the [guidelines](https://github.com/hugsy/gef/blob/dev/.github/CONTRIBUTING.md) to start. +To get involved, refer to the [Contribution +documentation](https://hugsy.github.io/gef/#contribution) and the +[guidelines](https://github.com/hugsy/gef/blob/dev/.github/CONTRIBUTING.md) to start. ## Sponsors ## -Another way to contribute to keeping the project alive is by sponsoring it! Check out [the sponsoring documentation](https://hugsy.github.io/gef/#sponsors) for details so you can be part of the list of those [awesome sponsors](https://github.com/sponsors/hugsy). +Another way to contribute to keeping the project alive is by sponsoring it! Check out [the +sponsoring documentation](https://hugsy.github.io/gef/#sponsors) for details so you can be part of +the list of those [awesome sponsors](https://github.com/sponsors/hugsy). ## Happy Hacking 🍻 ##