GithubHelp home page GithubHelp logo

thdtjsdn / lightspark Goto Github PK

View Code? Open in Web Editor NEW

This project forked from lightspark/lightspark

0.0 1.0 0.0 40.81 MB

An open source flash player implementation

Home Page: http://lightspark.github.io/

License: GNU Lesser General Public License v3.0

Shell 0.46% C++ 81.56% Python 0.39% C 15.44% ActionScript 0.95% Assembly 0.17% HTML 0.05% CMake 0.96% GLSL 0.03%

lightspark's Introduction

Lightspark

GitHub release GitHub Last Commit Github Actions Status

Lightspark is an open source Flash player implementation for playing files in the SWF format. Lightspark can run as a web browser plugin or as a standalone application.

Lightspark supports SWF files written on all versions of the ActionScript language.

Building and Installation

In preparation for building Lightspark, you need development packages for:

  • opengl
  • curl
  • zlib
  • libavcodec
  • libswresample
  • libglew
  • librtmp
  • cairo
  • sdl2
  • libjpeg
  • libavformat
  • pango
  • liblzma

The following tools are also required:

  • cmake
  • nasm
  • gcc (version 4.6.0 or newer) or clang

To install these, run the following command(s):

Ubuntu (tested on 21.10):

sudo apt install git gcc g++ nasm cmake libcurl4-gnutls-dev libsdl2-dev libpango1.0-dev libcairo2-dev libavcodec-dev libswresample-dev libglew-dev librtmp-dev libjpeg-dev libavformat-dev liblzma-dev

Fedora (tested on 33):

RPMFusion is required and will be enabled as part of this process.

sudo dnf install https://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-$(rpm -E %fedora).noarch.rpm
sudo dnf builddep lightspark

Archlinux

sudo pacman -S ffmpeg pango rtmpdump glew sdl2 git cmake nasm

If you want commands for a distro not listed here, please create an issue if it doesn't already exist.

If JIT compilation using llvm is enabled (this is disabled by default), you also need the development packages for llvm (version 2.8 or >= 3.0).

If compiling the PPAPI (Chromium) plugin is enabled (on by default), keep in mind that it will replace the Adobe Flash plugin, as only one Flash plugin is allowed in Chromium.

There are two ways of building Lightspark. You can use the included script, by running ./build.sh. or for a debug build, run ./build.sh -d. You can also do it manually, with the following commands:

cd lightspark
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Release ..
make
sudo make install

The CMAKE_BUILD_TYPE options are: Debug LeanDebug Release RelWithDebInfo Profile

If you run into issues building Lightspark, firstly try deleting the contents of obj, and run ./build.sh file again. If you continue to have issues, please let us know.

Usage

Browser plugin

Most browsers including Firefox and Chromium don't support flash any longer, so the plugins don't work on their latest versions.

There are alternative browsers that still support flash, see https://github.com/lightspark/lightspark/wiki/Getting-Lightspark-up-and-running-in-Web-Browser

Lightspark registers itself as the plugin for application/x-shockwave-flash and for application/x-lightspark, so it should be recognisable in the about:plugins page. Its description string is Shockwave Flash 12.1 r<current version>. The current version is now "r710".

Command line

The command line version of Lightspark can play a local SWF file.

lightspark file.swf

Type lightspark to see all command line options.

Keyboard shortcuts

  • Ctrl+Q: quit (standalone player only)
  • Ctrl+F: toggle between normal and fullscreen view
  • Ctrl+M: mute/unmute sounds
  • Ctrl+P: show profiling data
  • Ctrl+S: create screenshot and save it as bmp file in temp folder
  • Ctrl+C: copy an error to the clipboard (when Lightspark fails)

Environment variables

  • LIGHTSPARK_USE_GNASH: if set to 1, lightspark will fall back to gnash for older swf files
  • LIGHTSPARK_PLUGIN_LOGLEVEL: sets the log level (0-4) (browser plugins only)
  • LIGHTSPARK_PLUGIN_LOGFILE: sets the file the log will be written to (browser plugins only)
  • LIGHTSPARK_PLUGIN_PARAMFILE: if set, the flash variables set by the website will be written to this file (browser plugins only)
  • LIGHTSPARK_RANDOM_SEED: if set, lightspark will use the provided integer value as seed for random numbers (this is useful for debugging to ensure you get the same sequence of random numbers in every run)

SWF Support

Many applications do not yet work yet because the implementation is incomplete. But we do support a number of them. See our compatibility page for more details.

Testing

An easy way to compare Lightspark to Adobe Flash Player is to use the Flash Player Projector, which is simply a standalone executable of Flash that can be quickly run directly from the command line.

The Flash Player Projector can be found here, or if that link is broken, on this page, under the Linux category. Extract the archive, and then you have your flashplayer executable.

This should be used when testing Lightspark, to discern what are genuine bugs with Lightspark, and what are simply bugs with the SWF file itself. If you think you have found a bug, see our bug reporting help for details.

lightspark's People

Contributors

alexp-sssup avatar dbluelle avatar mgehre avatar aajanki avatar timonvo avatar zerostride avatar huwdp avatar magcius avatar twied avatar qulogic avatar roysjosh avatar fenveireth avatar jhwgh1968 avatar cg9999 avatar eiglow avatar robert-ancell avatar devkral avatar jacopo avatar jobermayr avatar jamorton avatar adrianherrera avatar amdmi3 avatar fwienber avatar vfjpl avatar banthar avatar lnee94 avatar timretout avatar ousia avatar tettamanti avatar briefbanane avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.