Bumps [eslint](https://github.com/eslint/eslint) from 9.36.0 to 9.38.0. <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/eslint/eslint/releases">eslint's releases</a>.</em></p> <blockquote> <h2>v9.38.0</h2> <h2>Features</h2> <ul> <li><a href="ce40f74efd"><code>ce40f74</code></a> feat: update <code>complexity</code> rule to only highlight function header (<a href="https://redirect.github.com/eslint/eslint/issues/20048">#20048</a>) (Atul Nair)</li> <li><a href="e37e590aae"><code>e37e590</code></a> feat: correct <code>no-loss-of-precision</code> false positives with <code>e</code> notation (<a href="https://redirect.github.com/eslint/eslint/issues/20187">#20187</a>) (Francesco Trotta)</li> </ul> <h2>Bug Fixes</h2> <ul> <li><a href="50c3dfd980"><code>50c3dfd</code></a> fix: improve type support for isolated dependencies in pnpm (<a href="https://redirect.github.com/eslint/eslint/issues/20201">#20201</a>) (Francesco Trotta)</li> <li><a href="a1f06a350c"><code>a1f06a3</code></a> fix: correct SourceCode typings (<a href="https://redirect.github.com/eslint/eslint/issues/20114">#20114</a>) (Pixel998)</li> </ul> <h2>Documentation</h2> <ul> <li><a href="462675af8a"><code>462675a</code></a> docs: improve web accessibility by hiding non-semantic character (<a href="https://redirect.github.com/eslint/eslint/issues/20205">#20205</a>) (루밀LuMir)</li> <li><a href="c070e65f6b"><code>c070e65</code></a> docs: correct formatting in <code>no-irregular-whitespace</code> rule documentation (<a href="https://redirect.github.com/eslint/eslint/issues/20203">#20203</a>) (루밀LuMir)</li> <li><a href="b39e71a213"><code>b39e71a</code></a> docs: Update README (GitHub Actions Bot)</li> <li><a href="cd39983148"><code>cd39983</code></a> docs: move <code>custom-formatters</code> type descriptions to <code>nodejs-api</code> (<a href="https://redirect.github.com/eslint/eslint/issues/20190">#20190</a>) (Percy Ma)</li> </ul> <h2>Chores</h2> <ul> <li><a href="d17c795bf1"><code>d17c795</code></a> chore: upgrade <code>@eslint/js</code><a href="https://github.com/9"><code>@9</code></a>.38.0 (<a href="https://redirect.github.com/eslint/eslint/issues/20221">#20221</a>) (Milos Djermanovic)</li> <li><a href="25d0e33270"><code>25d0e33</code></a> chore: package.json update for <code>@eslint/js</code> release (Jenkins)</li> <li><a href="c82b5efa1f"><code>c82b5ef</code></a> refactor: Use types from <code>@eslint/core</code> (<a href="https://redirect.github.com/eslint/eslint/issues/20168">#20168</a>) (Nicholas C. Zakas)</li> <li><a href="ff31609f19"><code>ff31609</code></a> ci: add Node.js 25 to <code>ci.yml</code> (<a href="https://redirect.github.com/eslint/eslint/issues/20220">#20220</a>) (루밀LuMir)</li> <li><a href="004577eda2"><code>004577e</code></a> ci: bump github/codeql-action from 3 to 4 (<a href="https://redirect.github.com/eslint/eslint/issues/20211">#20211</a>) (dependabot[bot])</li> <li><a href="eac71fb771"><code>eac71fb</code></a> test: remove use of <code>nodejsScope</code> option of eslint-scope from tests (<a href="https://redirect.github.com/eslint/eslint/issues/20206">#20206</a>) (Milos Djermanovic)</li> <li><a href="4168a18b7e"><code>4168a18</code></a> chore: fix typo in legacy-eslint.js (<a href="https://redirect.github.com/eslint/eslint/issues/20202">#20202</a>) (Sweta Tanwar)</li> <li><a href="205dbd2d92"><code>205dbd2</code></a> chore: fix typos (<a href="https://redirect.github.com/eslint/eslint/issues/20200">#20200</a>) (ntnyq)</li> <li><a href="dbb200e360"><code>dbb200e</code></a> chore: use team member's username when name is not available in data (<a href="https://redirect.github.com/eslint/eslint/issues/20194">#20194</a>) (Milos Djermanovic)</li> <li><a href="8962089edb"><code>8962089</code></a> chore: mark deprecated rules as available until v11.0.0 (<a href="https://redirect.github.com/eslint/eslint/issues/20184">#20184</a>) (Pixel998)</li> </ul> <h2>v9.37.0</h2> <h2>Features</h2> <ul> <li><a href="39f7fb493a"><code>39f7fb4</code></a> feat: <code>preserve-caught-error</code> should recognize all static "cause" keys (<a href="https://redirect.github.com/eslint/eslint/issues/20163">#20163</a>) (Pixel998)</li> <li><a href="f81eabc584"><code>f81eabc</code></a> feat: support TS syntax in <code>no-restricted-imports</code> (<a href="https://redirect.github.com/eslint/eslint/issues/19562">#19562</a>) (Nitin Kumar)</li> </ul> <h2>Bug Fixes</h2> <ul> <li><a href="a129cced7a"><code>a129cce</code></a> fix: correct <code>no-loss-of-precision</code> false positives for leading zeros (<a href="https://redirect.github.com/eslint/eslint/issues/20164">#20164</a>) (Francesco Trotta)</li> <li><a href="09e04fcc3f"><code>09e04fc</code></a> fix: add missing AST token types (<a href="https://redirect.github.com/eslint/eslint/issues/20172">#20172</a>) (Pixel998)</li> <li><a href="861c6da2bd"><code>861c6da</code></a> fix: correct <code>ESLint</code> typings (<a href="https://redirect.github.com/eslint/eslint/issues/20122">#20122</a>) (Pixel998)</li> </ul> <h2>Documentation</h2> <ul> <li><a href="b950359c5f"><code>b950359</code></a> docs: fix typos across the docs (<a href="https://redirect.github.com/eslint/eslint/issues/20182">#20182</a>) (루밀LuMir)</li> <li><a href="42498a2798"><code>42498a2</code></a> docs: improve ToC accessibility by hiding non-semantic character (<a href="https://redirect.github.com/eslint/eslint/issues/20181">#20181</a>) (Percy Ma)</li> <li><a href="29ea092b93"><code>29ea092</code></a> docs: Update README (GitHub Actions Bot)</li> <li><a href="5c97a04578"><code>5c97a04</code></a> docs: show <code>availableUntil</code> in deprecated rule banner (<a href="https://redirect.github.com/eslint/eslint/issues/20170">#20170</a>) (Pixel998)</li> <li><a href="90a71bf502"><code>90a71bf</code></a> docs: update <code>README</code> files to add badge and instructions (<a href="https://redirect.github.com/eslint/eslint/issues/20115">#20115</a>) (루밀LuMir)</li> <li><a href="1603ae1526"><code>1603ae1</code></a> docs: update references from <code>master</code> to <code>main</code> (<a href="https://redirect.github.com/eslint/eslint/issues/20153">#20153</a>) (루밀LuMir)</li> </ul> <h2>Chores</h2> <ul> <li><a href="afe8a13469"><code>afe8a13</code></a> chore: update <code>@eslint/js</code> dependency to version 9.37.0 (<a href="https://redirect.github.com/eslint/eslint/issues/20183">#20183</a>) (Francesco Trotta)</li> <li><a href="abee4ca1fa"><code>abee4ca</code></a> chore: package.json update for <code>@eslint/js</code> release (Jenkins)</li> <li><a href="fc9381f6ca"><code>fc9381f</code></a> chore: fix typos in comments (<a href="https://redirect.github.com/eslint/eslint/issues/20175">#20175</a>) (overlookmotel)</li> <li><a href="e1574a22d3"><code>e1574a2</code></a> chore: unpin jiti (<a href="https://redirect.github.com/eslint/eslint/issues/20173">#20173</a>) (renovate[bot])</li> </ul> <!-- raw HTML omitted --> </blockquote> <p>... (truncated)</p> </details> <details> <summary>Commits</summary> <ul> <li><a href="8fe511b4c0"><code>8fe511b</code></a> 9.38.0</li> <li><a href="f961736693"><code>f961736</code></a> Build: changelog update for 9.38.0</li> <li><a href="d17c795bf1"><code>d17c795</code></a> chore: upgrade <code>@eslint/js</code><a href="https://github.com/9"><code>@9</code></a>.38.0 (<a href="https://redirect.github.com/eslint/eslint/issues/20221">#20221</a>)</li> <li><a href="25d0e33270"><code>25d0e33</code></a> chore: package.json update for <code>@eslint/js</code> release</li> <li><a href="50c3dfd980"><code>50c3dfd</code></a> fix: improve type support for isolated dependencies in pnpm (<a href="https://redirect.github.com/eslint/eslint/issues/20201">#20201</a>)</li> <li><a href="c82b5efa1f"><code>c82b5ef</code></a> refactor: Use types from <code>@eslint/core</code> (<a href="https://redirect.github.com/eslint/eslint/issues/20168">#20168</a>)</li> <li><a href="ff31609f19"><code>ff31609</code></a> ci: add Node.js 25 to <code>ci.yml</code> (<a href="https://redirect.github.com/eslint/eslint/issues/20220">#20220</a>)</li> <li><a href="ce40f74efd"><code>ce40f74</code></a> feat: update <code>complexity</code> rule to only highlight function header (<a href="https://redirect.github.com/eslint/eslint/issues/20048">#20048</a>)</li> <li><a href="e37e590aae"><code>e37e590</code></a> feat: correct <code>no-loss-of-precision</code> false positives with <code>e</code> notation (<a href="https://redirect.github.com/eslint/eslint/issues/20187">#20187</a>)</li> <li><a href="004577eda2"><code>004577e</code></a> ci: bump github/codeql-action from 3 to 4 (<a href="https://redirect.github.com/eslint/eslint/issues/20211">#20211</a>)</li> <li>Additional commits viewable in <a href="https://github.com/eslint/eslint/compare/v9.36.0...v9.38.0">compare view</a></li> </ul> </details> <br /> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details>
Sogen is a high-performance Windows user space emulator that operates at syscall level, providing full control over process execution through comprehensive hooking capabilities.
Perfect for security research, malware analysis, and DRM research where fine-grained control over process execution is required.
Built in C++ and powered by the Unicorn Engine (or the icicle-emu 🆕).
Try it out: sogen.dev
Key Features
- 🔄 Syscall-Level Emulation
- Instead of reimplementing Windows APIs, the emulator operates at the syscall level, allowing it to leverage existing system DLLs
- 📝 Advanced Memory Management
- Supports Windows-specific memory types including reserved, committed, built on top of Unicorn's memory management
- 📦 Complete PE Loading
- Handles executable and DLL loading with proper memory mapping, relocations, and TLS
- ⚡ Exception Handling
- Implements Windows structured exception handling (SEH) with proper exception dispatcher and unwinding support
- 🧵 Threading Support
- Provides a scheduled (round-robin) threading model
- 💾 State Management
- Supports both full state serialization and
fast in-memory snapshots(currently broken 😕)
- Supports both full state serialization and
- 💻 Debugging Interface
- Implements GDB serial protocol for integration with common debugging tools (IDA Pro, GDB, LLDB, VS Code, ...)
Preview
YouTube Overview
Click here for the slides.
Quick Start (Windows + Visual Studio)
Tip
Checkout the Wiki for more details on how to build & run the emulator on Windows, Linux, macOS, ...
1. Checkout the code:
git clone --recurse-submodules https://github.com/momo5502/sogen.git
2. Run the following command in an x64 Development Command Prompt in the cloned directory:
cmake --preset=vs2022
3. Build the solution that was generated at build/vs2022/emulator.sln
4. Create a registry dump by running the grab-registry.bat as administrator and place it in the artifacts folder next to the analyzer.exe
5. Run the program of your choice:
analyzer.exe C:\example.exe


