-
Notifications
You must be signed in to change notification settings - Fork 9
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
The state of compression #53
Comments
Nice composure of different improvements, I think i'll switch to the developement branch asap and perhaps draft some of the mentioned improvements, like source maps etc. |
addendum: why does yahoo gotta prepend the retarded Y in front of everything? they just could have improved/PR-ed the orginal uglify |
When using a comma separated list, would Node use the given compressors in that order? Perhaps it's usefull to keep a few default scenarios in the documentation with a reasoning as to why that order is preferred in some cases etc. Automatic detection of compression sounds awesome. It really does. I know I don't take the time to verify it manually, so if square could improve that for me, I'd be a happy man. About using the App engine: would the end user need to have his/her own Google Apps account for this and if so, is it actually a free service? I know I'd stick to using a local compressor over using a web service, for all the obvious reasons, even though I have the bandwidth to not really care at all. |
@Swaagie As for the source maps, that implementation is probably going to be a huge pain, as we need to maintain a source map of the files when we concatenate them and a source map of the minified code. I'm not sure you can reference different source maps within a source map as some compressors come with the ability to also output a source map. As for the prepended @johmanx10 The App engine service is free and does not require the users to setup their own account, there are couple of limites how ever. They limit the amount of data that you could send to the service (i think it's 2MB) and limit the amount of compressions you could do per hour. So it's not an ideal situation, but requiring |
Compression is one of the most important things in a build system and I have the feeling that this is currently one of the weakest parts of our system. There are a couple of issues that I would like to see addressed before we move this project forward towards the glorified
1.0
release of the development branch.YUI compressor
YUI has recently announced the deprication of their YUI compressor project. They are moving away from their Java based compressor and are embrascing opensource as the base of their compressor which they have named yUglify as it's based upon the excellent uglifyjs compressor. The new version add's some additional fixes upon the regular uglify compressor. Some of these fixes are already in our code base as well, such as appending an extra
;
so it's easier to concatenate files after minification.The CSS compressor has been replaced by CSSMin which is included in their yUglify package. The version bundled is a forked version and maintained version of CSSMin.
UglifyJS
UglifyJS has gained a new brother, UglifyJS2 this is the successor of the current uglify parser and it should be able to compress more then the current stable version.
JSMin
We should also support JSMin as some people seem to fancy that, it's also available with sourcemaps
CSS compression
The only CSS compressor that we are currently supporting is the one bundled in the YUIcompressor.jar, we should also different CSS compressors such as sqwish
Closure compiler
Closure compiler is awesome, but it's depends that
Java
is installed on your system. I would love to get rid of this dependency and only requirenode
to be installed on the system. Google created a closure compiler service that runs on app-engine. We could leverage this service to compress the data if java is not installed.The level option
We currently allow people to configure the compressor using a
level
option, this is just silly and doesn't provide any useful information about what it actually does and is overly complicated to understand for new comers. Instead we should just allow a comma separated list of compressors they want to use on their code base.Compression detection
Less, important but nice to have.. Iterate over all the available compressors to figure out which compressor is the most effective for the given code base. As there are cases where closure compiler is more effective then uglifyjs. By checking out the best compilation we could advice users on compression levels. Also the order of compression is important, for example use closure first as it remove dead code and then uglify to save a couple more extra bytes.
Verification
We should verify if the compressed code is actually smaller when gzipped, if this is not the case, we should return the original source code.
Source maps
We need this.
TL;DR
java
is available on the system, and use the closure.jar to minify. When it's not available we should use the close compiler service API to minify the data.level
but add newengine
orcompressor
optionThe text was updated successfully, but these errors were encountered: