2c87888e28
In Flash, this also at least claims to halt ActionScript execution on the movie. No such implementation of AVM poisoning currently exists in Ruffle, primarily because it's unclear what gets poisoned and implementing some of these options isn't yet possible: 1. AVM (e.g. all movies) - we would need to make the AVM fail silently in this case. This is the most straightforward way to poison the movie, but I'm not sure if this is how Flash actually does it, or if it poisons... 2. Movie - the current structure of movies is incompatible with adding arbitrary data to them. We need to merge `moviefetch` in before we can attach data to loaded movies. 3. MovieClip - this would also be implementable but has problems. How do child MovieClips know that their parent has been poisoned, or vice versa? What if a movie clip is loaded from one movie and moved into another? As a result, I have decided to hold off on implementing recursion poisoning until I know where it's supposed to go and how to implement that. |
||
---|---|---|
.circleci | ||
core | ||
desktop | ||
scanner | ||
swf | ||
web | ||
.gitattributes | ||
.gitignore | ||
CONTRIBUTING.md | ||
Cargo.lock | ||
Cargo.toml | ||
LICENSE_APACHE | ||
LICENSE_MIT | ||
README.md | ||
rustfmt.toml |
README.md
website | demo | nightly builds | wiki
Ruffle
Ruffle is an Adobe Flash Player emulator written in the Rust programming language. Ruffle targets both the desktop and the web using WebAssembly.
Project status
Ruffle is in the proof-of-concept stage and can currently run early Flash animations. ActionScript support is still forthcoming; for more info, read the project roadmap.
Building from source
Follow the official guide to install Rust for your platform.
Desktop
cargo run --package=ruffle_desktop -- test.swf
Web
Running the web demo
cd web/demo
npm install
npm run serve
- Load indicated page in browser (usually http://localhost:8080)
Building the NPM package
cd web
wasm-pack build
Scanner
If you have a collection of "real world" SWFs to test against, the scanner may be used to benchmark ruffle's parsing capabilities. Provided with a folder and an output filename, it will attempt to read all of the flash files and report on the success of such a task.
cargo run --package=ruffle_scanner -- folder/with/swfs/ results.csv
Structure
core
contains the core emulator and common codedesktop
contains the desktop client (usesglium
)web
contains the web client (useswasm-bindgen
)scanner
contains a utility to bulk parse swf files
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE_APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE_MIT or http://opensource.org/licenses/MIT) at your option.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be dual licensed as above, without any additional terms or conditions.