Giter VIP home page Giter VIP logo

avatar-js's Introduction

Build Instructions

  1. Setup build environment. Install a git client, jdk8, ant, python, C++ compiler and linker

    1. Install the latest jdk8u20
    2. Ensure ant is installed and ant -version is 1.8+
    3. Ensure python is installed and python --version is 2.7.5+
      tip: python3 does not work
    4. Ensure ant, jdk8, python and appropriate platform-specific C++ compiler and linker are in the PATH
    5. If needed, install a git client for your OS. Windows users see below
    6. Extra steps for Windows users
      1. Install a unix emulation like cygwin or mingw/msys. If using Git for Windows, a version of msys is already included. This unix emulation provides the gnu diff and patch utilities.
      2. Install Microsoft Visual Studio. Any recent version should be OK (2010, 2012, 2013 have been known to work). Express versions will do.
      3. Ensure that link.exe is the one from Visual Studio and not from cygwin or mingw/msys.
      4. If a unix user, start bash --login from within a Visual Studio Command Prompt to ensure that the Visual Studio environment is inherited.
  2. Download node.js source

    1. git clone https://github.com/joyent/node.git source
    2. cd source
    3. git checkout v0.10.32
      tip: run git pull to refresh the repo if you get an error saying that this version is unknown
    4. cd ..
  3. Clone dependencies. Substitute <id> with your java.net id in the URLs below. Use the read-only URLs below if you do not have a java.net id. It is strongly recommended that all dependencies be cloned at the same level as node.js as in step 2.1 above

    1. git clone git://java.net/avatar-js~libuv-java libuv-java (read-only)
      git clone ssh://<id>@git.java.net/avatar-js~libuv-java libuv-java

    2. git clone git://java.net/avatar-js~http-parser-java http-parser-java (read-only)
      git clone ssh://<id>@git.java.net/avatar-js~http-parser-java http-parser-java

    3. git clone git://java.net/avatar-js~src avatar-js (read-only)
      git clone ssh://<id>@git.java.net/avatar-js~src avatar-js

    4. Download test-ng. Unzip the downloaded bundle and place testng jar somewhere in your workspace

  4. Edit ~/.avatar-js.properties to set various locations. Ensure that there are no double slashes and no trailing slash, for example

    source.home = /ws/source (from 2.1)
    libuv.home = /ws/libuv-java (from 3.1)
    http-parser.home = /ws/http-parser-java (from 3.2)
    avatar-js.home = /ws/avatar-js (from 3.3)
    testng.jar = /ws/lib/testng.jar (from 3.4)

  5. Setup your environment so that native libraries can be found

    export LD_LIBRARY_PATH=$PWD/dist:$LD_LIBRARY_PATH (linux)
    export DYLD_LIBRARY_PATH=$PWD/dist:$DYLD_LIBRARY_PATH (mac)
    export PATH=%CWD%/dist;%PATH% (windows)

  6. Configure

    cd avatar-js
    ant setup

  7. Build

    ant clean-all
    ant jar-all
    tip: ant -Dbuild.type=Release jar-all builds the Release configuration

  8. Test

    java -jar dist/avatar-js.jar src/test/js/test-runner.js test/simple (runs the unit tests)
    java -jar dist/avatar-js.jar src/test/js/test-runner.js test/crypto (runs the crypto tests)
    java -jar dist/avatar-js.jar src/test/js/test-runner.js -timeout 180 test/pummel (runs the pummel tests)

    tip: Some crypto tests require Java Cryptography Extension Unlimited Jurisdiction Policy Files. Follow the instructions in the download. Files for Java7 work in Java8.

    tip: Might need to set LANG=en_US.UTF-8

    tip: test-runner.js supports many options, run it with -help or look at its source for more information

  9. Running applications. For example

    java -jar dist/avatar-js.jar app.js
    or
    java -Djava.library.path=dist -jar dist/avatar-js.jar app.js
    or
    java -Xmx4g -Djava.library.path=dist -jar dist/avatar-js.jar app.js

Release Notes

  • Compatible with Node.js v0.10.32

  • Platforms tested. 32-bit variants have not been tested at all

    • Ubuntu Linux x64
    • Oracle Enterprise Linux x64
    • Mac OS X Mountain Lion
    • Windows 7 & 8 x64
  • Missing Features

    • the debugger module is not supported
  • Known failures

    • some tests fail on windows. These are listed in win32-test-exclusions.txt with associated issue
  • Globals. Some additional globals are exposed

  • Limitations of the vm module. Objects loaded in a new context and accessed from the current context have some strong limitations -

    • Only a subset of JavaScript API is available on these objects
    • equality (==, ===) will not work as expected
  • Limitations on __proto__

    • __proto__ cannot be set to undefined. Affects the ejs module used by express
  • No const keyword

    • the const keyword is not supported, replace with var. Affects the mongodb and grunt modules
  • No signal handlers installed by default

    • the JVM installs some of its own and we do not want to cause conflicts
    • an app can install signal handlers as needed using process.signals.start('SIGUSR1'); or process.signals.start(43);

avatar-js's People

Contributors

batsatt avatar irfan-ahmed avatar

Watchers

James Cloos 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.