Compactor 3.3 build: 9470 released: 2011-11-15 Compacts HTML removing excess whitespace for faster transmission.. Copyright: (c) 2012 Canadian Mind Products. Java application. Download from: http://mindprod.com/products1.html#COMPACTOR ===> Free <=== Full source included. You may even include the source code, modified or unmodified in free/commercial open source/proprietary programs that you write and distribute. May be used freely for any purpose but military. For more details on this restriction, see http://mindprod.com/contact/nonmil.html If you include any Canadian Mind Products code in your own applications, your app too must be labeled non-military use only. All Java jars and source code are included. ---- Prerequisites: This program runs under any OS, (e.g. Win2K/XP/Vista/W7x86/W7-64/OSX/Linux/Solaris/AIX...) so long as you have <><> Java version 1.6 <><> or later installed (32-bit or 64-bit Java). See http://mindprod.com/jgloss/installingjava.html for details. ---- Installing on a PC: Download source and compiled class files to run on your own machine as an application. First install a recent Java JDK or JVM. See http://mindprod.com/jgloss/installingjava.html. To install, extract the zip download with WinZip (or similar unzip utility) into any directory you please, often J:\ -- ticking off the "use folder names" option. To run as an application,type: java -ea -jar J:\com\mindprod\compactor\compactor.jar {put any parms here} adjusting as necessary to account for where the jar file is. ---- Installing on a MacIntosh: Use Safari to download source and compiled class files to run on your own machine as an application. Safari will automatically unpack the zip into ~/Downloads (version 10.5) [or on the Desktop (version 10.4 and earlier)]. First install a recent Java JDK or JVM. See http://mindprod.com/jgloss/installingjava.html. You may optionally move the download tree to a permanent home. I don't have a MacIntosh, just a PC, so I can't test my Java programs for Mac compatibility. In theory they should work without problems, but in practice that does not always happen. If you have problems please, let me know, preferably with screenshots and complete verbatim error messages. To run as an application, without parameters, just double click the jar file. To run as an application with parameters, in bash shell type: open Terminal.app cd ~/Desktop java -ea -jar com/mindprod/compactor/compactor.jar {put any parms here} adjusting as necessary to account for where the jar file is. ---- Rebuilding: The zip already contains the necessary class and jar files, so unless you modify the program, there is no need to recompile the source or rebuild the jar. Configure.java basedir="E:/" in rebuild.xml to the drive where your files are. Use ANT and rebuild.xml, not build.xml, to recompile and recreate the jar. ---- Use: Compacts HTML so that web pages are 20% smaller and hence 20% faster. It does this by removing all unnecessary white space. To fluff files up again, I suggest using SlickEdit beautify. The file will render on browsers exactly as they did before. Any
 sections are left intact. No comments
are removed. See http://mindprod.com/projects/compactor.html
for how it works.

NOTE THE COMPACTOR JUST COMPACTS YOUR HTML. IT DOES NOT
FLUFF UP AGAIN.

To install, Extract the zip download with WinZip, available from
http://www.winzip.com (or similar unzip utility) into any
directory you please, often C:\ -- ticking off the "user
folder names" option. To run as an application, type:

java -jar C:\com\mindprod\compactor\compactor.jar x.html y.html

adjusting as necessary to account for where the jar file is.
Put files and directories on command line you want to
compact. -s means recursively include all subdirectories for
everything to the right of -s.

You can also embed it in your own programs, by calling the
Compactor.compactString or Compactor.compactFile methods
like this:

import  com.mindprod.compactor;
...
Compactor compactor = new Compactor();
compactor.compactFile( true, new File("x.html") );
String result = compactor.compactString( big, "from file x.html" );


----

Version History:

 2.2 2006-03-15 Suppress IntelliJ Code Analyse that wants to make this default scope.

 2.3 2008-02-15 complete rewrite, mainly to handle removing space around 
  • and tags. 2.4 2008-02-15 add more tags that get trimmed. Charge $10 2.5 2008-02-28 tighter removal of whitespace surrounding comments. 2.6 2008-02-28 optionally allow comments to be stripped out entirely. Preserve some space around configurable magic macro comments that expand into text such as in a tag. < space will convert to < space. 2.8 2009-04-04 no longer correct missing entities. Just issue warning messages. 2.9 2010-01-18 refactor so you first allocate a Compactor object, permitting simultaneous compactings. 3.0 2010-02-12 trim space inside

    ..

    . 3.1 2010-12-21 avoid touching JavaScript and other scripts. 3.2 2010-12-24 handle