Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
This repository was archived by the owner on Jun 5, 2020. It is now read-only.

A JavaScript source file preprocessor in pure JavaScript, e.g. to build different versions of a library.

License

NotificationsYou must be signed in to change notification settings

dcodeIO/Preprocessor.js

Repository files navigation

Preprocessor.js - A JavaScript preprocessor

Provides a JavaScript source file preprocessor, e.g. to build different versions of a library. It's for example used tobuildProtoBuf.js (itsbuildandmain script are quite good examples).

Deprecation notice: Preprocessor.js has been deprecated in favor ofMetaScript,a much more JavaScripty way for build time meta programming using JavaScript itself as the meta language. Check out themigration guide to get a quick impression of its merits.

Directives

  • Includes (always relative to thebaseDirectory, defaults to "."):
...// #include "path/to/file.js"...
  • Static conditions:
// #ifdef FULLconsole.log("Including extension");// #include "path/to/extension.js"// #elseconsole.log("Not including extension");// #endif
  • Inverse static conditions:
// #ifndef FULLconsole.log("Not including extension");// #elseconsole.log("Including extension");// #include "path/to/extension.js"// #endif
  • Evaluable conditions:
// #if 1==2console.log("1==2");// #elif 2==2console.log("2==2");// #endif
  • Inline variables and functions:
// #define var PI=Math.PI// #define function RADTODEG(x){return x*180/PI}varangle=// #put RADTODEG(3)+";"
  • Writing the result of evaluated expressions:

    varversion=// #put '"'+VERSION+'";"'varstr=// #put "\"Hello world!\";"varonePlusOne=// #put (1+1)+";"

Features

  • CommonJS compatible
  • RequireJS/AMD compatible
  • Shim compatible (include the script, then use var ByteBuffer = dcodeIO.ByteBuffer;)
  • node.js compatible, also available vianpm
  • Closure Compiler ADVANCED_OPTIMIZATIONS compatible (fully annotated,Preprocessor.min.js has been compiled this way,Preprocessor.min.map is the source map)
  • Fully documented usingjsdoc3
  • Well tested throughnodeunit
  • Zero production dependencies
  • Small footprint

Command line utility

Install via npm:npm -g install preprocessor

Command line

Usage:preprocess sourceFile [baseDirectory] [-myKey[=myValue], ...] [> outFile]

preprocess Source.js. -FULL=true> Source.full.js

API

The API is quite simple:

varresult=newPreprocessor(mainFileSource,baseDirectoryOrIncludes).process(defines);

withbaseDirectoryOrIncludes being either a string containing the path to the base directory or an object of includedsources by filename. When running in a browser, only the later is supported.

node.js / CommonJS

varPreprocessor=require("preprocessor");varsource="...";// e.g. through fs.readFilevarpp=newPreprocessor(source,".");console.log(pp.process({FULL:true}));

RequireJS / AMD

require(["/path/to/Preprocessor.js"],function(Preprocessor){varsource="...";// e.g. through fs.readFile / $.ajaxvarpp=newPreprocessor(source,".");console.log(pp.process({FULL:true}));});

Browser / shim

Note: To use the#include directive in the browser, do not specify the base directory but an object of includedsources by filename:

<scriptsrc="//raw.github.com/dcodeIO/Preprocessor.js/master/Preprocessor.min.js"></script>
varPreprocessor=dcodeIO.Preprocessor;varsource="...";// e.g. through. $.ajaxvarpp=newPreprocessor(source,{"./includes/extension.js":"var myVar = 2;"// <- #include "includes/extension.js"});alert(pp.process({FULL:true}));

Using includes instead of a base directory like shown in the example above is supported regardless of the platform youare on.

Downloads

Documentation

Tests (& Examples)Build Status

License

Apache License, Version 2.0 -http://www.apache.org/licenses/LICENSE-2.0.html

About

A JavaScript source file preprocessor in pure JavaScript, e.g. to build different versions of a library.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors4

  •  
  •  
  •  
  •  

[8]ページ先頭

©2009-2025 Movatter.jp