qrscanner 0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +2 -0
- data/Manifest +478 -0
- data/README +41 -0
- data/Rakefile +9 -0
- data/bin/qrscanner +9 -0
- data/ext/qrscanner/extconf.rb +70 -0
- data/ext/qrscanner/qrscanner.c +32 -0
- data/ext/qrscanner/zxing/README +43 -0
- data/ext/qrscanner/zxing/SConscript +55 -0
- data/ext/qrscanner/zxing/SConstruct +7 -0
- data/ext/qrscanner/zxing/astyle-options +12 -0
- data/ext/qrscanner/zxing/blackboxtest.sh +45 -0
- data/ext/qrscanner/zxing/core/src/zxing/BarcodeFormat.cpp +38 -0
- data/ext/qrscanner/zxing/core/src/zxing/BarcodeFormat.h +42 -0
- data/ext/qrscanner/zxing/core/src/zxing/Binarizer.cpp +36 -0
- data/ext/qrscanner/zxing/core/src/zxing/Binarizer.h +46 -0
- data/ext/qrscanner/zxing/core/src/zxing/BinaryBitmap.cpp +67 -0
- data/ext/qrscanner/zxing/core/src/zxing/BinaryBitmap.h +57 -0
- data/ext/qrscanner/zxing/core/src/zxing/DecodeHints.cpp +111 -0
- data/ext/qrscanner/zxing/core/src/zxing/DecodeHints.h +69 -0
- data/ext/qrscanner/zxing/core/src/zxing/Exception.cpp +25 -0
- data/ext/qrscanner/zxing/core/src/zxing/Exception.h +39 -0
- data/ext/qrscanner/zxing/core/src/zxing/LuminanceSource.cpp +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/LuminanceSource.h +49 -0
- data/ext/qrscanner/zxing/core/src/zxing/MultiFormatReader.cpp +102 -0
- data/ext/qrscanner/zxing/core/src/zxing/MultiFormatReader.h +49 -0
- data/ext/qrscanner/zxing/core/src/zxing/Reader.cpp +31 -0
- data/ext/qrscanner/zxing/core/src/zxing/Reader.h +40 -0
- data/ext/qrscanner/zxing/core/src/zxing/ReaderException.cpp +32 -0
- data/ext/qrscanner/zxing/core/src/zxing/ReaderException.h +34 -0
- data/ext/qrscanner/zxing/core/src/zxing/Result.cpp +59 -0
- data/ext/qrscanner/zxing/core/src/zxing/Result.h +53 -0
- data/ext/qrscanner/zxing/core/src/zxing/ResultPoint.cpp +27 -0
- data/ext/qrscanner/zxing/core/src/zxing/ResultPoint.h +39 -0
- data/ext/qrscanner/zxing/core/src/zxing/ResultPointCallback.cpp +26 -0
- data/ext/qrscanner/zxing/core/src/zxing/ResultPointCallback.h +39 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Array.cpp +22 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Array.h +207 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/BitArray.cpp +129 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/BitArray.h +55 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/BitMatrix.cpp +178 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/BitMatrix.h +65 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/BitSource.cpp +75 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/BitSource.h +67 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Counted.cpp +32 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Counted.h +205 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/DecoderResult.cpp +37 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/DecoderResult.h +43 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/DetectorResult.cpp +41 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/DetectorResult.h +46 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/EdgeDetector.cpp +191 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/EdgeDetector.h +38 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GlobalHistogramBinarizer.cpp +209 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GlobalHistogramBinarizer.h +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GreyscaleLuminanceSource.cpp +70 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GreyscaleLuminanceSource.h +62 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GreyscaleRotatedLuminanceSource.cpp +65 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GreyscaleRotatedLuminanceSource.h +60 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GridSampler.cpp +101 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/GridSampler.h +43 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/HybridBinarizer.cpp +168 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/HybridBinarizer.h +55 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/IllegalArgumentException.cpp +31 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/IllegalArgumentException.h +33 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/PerspectiveTransform.cpp +107 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/PerspectiveTransform.h +49 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Point.h +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Str.cpp +38 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/Str.h +40 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/GF256.cpp +136 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/GF256.h +68 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/GF256Poly.cpp +198 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/GF256Poly.h +53 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/ReedSolomonDecoder.cpp +193 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/ReedSolomonDecoder.h +46 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/ReedSolomonException.cpp +30 -0
- data/ext/qrscanner/zxing/core/src/zxing/common/reedsolomon/ReedSolomonException.h +33 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/DataMatrixReader.cpp +82 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/DataMatrixReader.h +45 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/Version.cpp +199 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/Version.h +87 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/BitMatrixParser.cpp +364 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/BitMatrixParser.h +59 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/DataBlock.cpp +113 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/DataBlock.h +49 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/DecodedBitStreamParser.cpp +404 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/DecodedBitStreamParser.h +103 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/Decoder.cpp +96 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/decoder/Decoder.h +50 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/detector/CornerPoint.cpp +54 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/detector/CornerPoint.h +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/detector/Detector.cpp +315 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/detector/Detector.h +79 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/detector/MonochromeRectangleDetector.cpp +172 -0
- data/ext/qrscanner/zxing/core/src/zxing/datamatrix/detector/MonochromeRectangleDetector.h +61 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/Code128Reader.cpp +490 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/Code128Reader.h +63 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/Code39Reader.cpp +352 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/Code39Reader.h +58 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/EAN13Reader.cpp +95 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/EAN13Reader.h +44 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/EAN8Reader.cpp +73 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/EAN8Reader.h +41 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/ITFReader.cpp +363 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/ITFReader.h +56 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/MultiFormatOneDReader.cpp +66 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/MultiFormatOneDReader.h +38 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/MultiFormatUPCEANReader.cpp +87 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/MultiFormatUPCEANReader.h +38 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/OneDReader.cpp +206 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/OneDReader.h +50 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/OneDResultPoint.cpp +36 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/OneDResultPoint.h +40 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/UPCAReader.cpp +65 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/UPCAReader.h +49 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/UPCEANReader.cpp +311 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/UPCEANReader.h +77 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/UPCEReader.cpp +143 -0
- data/ext/qrscanner/zxing/core/src/zxing/oned/UPCEReader.h +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/ErrorCorrectionLevel.cpp +49 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/ErrorCorrectionLevel.h +46 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/FormatInformation.cpp +108 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/FormatInformation.h +54 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/QRCodeReader.cpp +82 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/QRCodeReader.h +43 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/Version.cpp +557 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/Version.h +85 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/BitMatrixParser.cpp +191 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/BitMatrixParser.h +56 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/DataBlock.cpp +118 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/DataBlock.h +50 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/DataMask.cpp +159 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/DataMask.h +50 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/DecodedBitStreamParser.cpp +353 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/DecodedBitStreamParser.h +59 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/Decoder.cpp +103 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/Decoder.h +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/Mode.cpp +73 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/decoder/Mode.h +50 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/AlignmentPattern.cpp +46 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/AlignmentPattern.h +45 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/AlignmentPatternFinder.cpp +209 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/AlignmentPatternFinder.h +68 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/Detector.cpp +286 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/Detector.h +64 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/FinderPattern.cpp +58 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/FinderPattern.h +48 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/FinderPatternFinder.cpp +540 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/FinderPatternFinder.h +69 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/FinderPatternInfo.cpp +41 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/FinderPatternInfo.h +47 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/QREdgeDetector.cpp +169 -0
- data/ext/qrscanner/zxing/core/src/zxing/qrcode/detector/QREdgeDetector.h +48 -0
- data/ext/qrscanner/zxing/core/tests/src/TestRunner.cpp +30 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BitArrayTest.cpp +96 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BitArrayTest.h +50 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BitMatrixTest.cpp +107 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BitMatrixTest.h +55 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BitSourceTest.cpp +49 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BitSourceTest.h +42 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BlackPointEstimatorTest.cpp +47 -0
- data/ext/qrscanner/zxing/core/tests/src/common/BlackPointEstimatorTest.h +45 -0
- data/ext/qrscanner/zxing/core/tests/src/common/CountedTest.cpp +54 -0
- data/ext/qrscanner/zxing/core/tests/src/common/CountedTest.h +46 -0
- data/ext/qrscanner/zxing/core/tests/src/common/PerspectiveTransformTest.cpp +69 -0
- data/ext/qrscanner/zxing/core/tests/src/common/PerspectiveTransformTest.h +47 -0
- data/ext/qrscanner/zxing/core/tests/src/common/reedsolomon/ReedSolomonTest.cpp +130 -0
- data/ext/qrscanner/zxing/core/tests/src/common/reedsolomon/ReedSolomonTest.h +62 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/ErrorCorrectionLevelTest.cpp +47 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/ErrorCorrectionLevelTest.h +45 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/FormatInformationTest.cpp +70 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/FormatInformationTest.h +47 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/VersionTest.cpp +88 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/VersionTest.h +49 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/decoder/DataMaskTest.cpp +134 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/decoder/DataMaskTest.h +91 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/decoder/ModeTest.cpp +52 -0
- data/ext/qrscanner/zxing/core/tests/src/qrcode/decoder/ModeTest.h +47 -0
- data/ext/qrscanner/zxing/format +2 -0
- data/ext/qrscanner/zxing/magick/src/MagickBitmapSource.cpp +99 -0
- data/ext/qrscanner/zxing/magick/src/MagickBitmapSource.h +49 -0
- data/ext/qrscanner/zxing/magick/src/example.cpp +83 -0
- data/ext/qrscanner/zxing/magick/src/main.cpp +241 -0
- data/ext/qrscanner/zxing/magick/src/qrscanner.cpp +188 -0
- data/ext/qrscanner/zxing/osx.xcodeproj/project.pbxproj +1045 -0
- data/ext/qrscanner/zxing/scons/scons-LICENSE +25 -0
- data/ext/qrscanner/zxing/scons/scons-README +204 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Action.py +1241 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Action.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Builder.py +877 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Builder.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/CacheDir.py +216 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/CacheDir.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Conftest.py +793 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Conftest.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Debug.py +220 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Debug.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Defaults.py +480 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Defaults.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Environment.py +2318 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Environment.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Errors.py +205 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Errors.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Executor.py +633 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Executor.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Job.py +435 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Job.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Memoize.py +244 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Memoize.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/Alias.py +152 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/Alias.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/FS.py +3142 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/FS.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/Python.py +128 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/Python.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/__init__.py +1328 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Node/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/BoolOption.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/BoolOption.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/EnumOption.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/EnumOption.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/ListOption.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/ListOption.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/PackageOption.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/PackageOption.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/PathOption.py +76 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/PathOption.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/__init__.py +67 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Options/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/PathList.py +231 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/PathList.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/__init__.py +241 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/aix.py +69 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/cygwin.py +55 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/darwin.py +46 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/hpux.py +46 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/irix.py +44 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/os2.py +58 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/posix.py +263 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/posix.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/sunos.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Platform/win32.py +385 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/SConf.py +1030 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/SConf.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/SConsign.py +383 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/SConsign.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/C.py +132 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/C.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/D.py +73 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/D.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/Dir.py +109 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/Dir.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/Fortran.py +316 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/Fortran.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/IDL.py +48 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/LaTeX.py +362 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/LaTeX.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/Prog.py +101 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/Prog.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/RC.py +55 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/__init__.py +413 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Scanner/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/Interactive.py +384 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/Interactive.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/Main.py +1334 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/Main.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/SConsOptions.py +939 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/SConsOptions.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/SConscript.py +640 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/SConscript.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/__init__.py +412 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Script/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Sig.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Subst.py +904 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Subst.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Taskmaster.py +1017 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Taskmaster.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/386asm.py +61 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/BitKeeper.py +67 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/BitKeeper.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/CVS.py +73 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/CVS.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/FortranCommon.py +246 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/FortranCommon.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/JavaCommon.py +323 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/JavaCommon.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/__init__.py +56 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/arch.py +61 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/common.py +240 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/netframework.py +82 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/sdk.py +391 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/vc.py +456 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/MSCommon/vs.py +499 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/Perforce.py +103 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/Perforce.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/PharLapCommon.py +137 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/PharLapCommon.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/RCS.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/RCS.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/SCCS.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/SCCS.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/Subversion.py +71 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/__init__.py +681 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/aixc++.py +82 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/aixcc.py +74 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/aixf77.py +80 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/aixlink.py +76 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/applelink.py +71 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ar.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ar.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/as.py +78 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/as.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/bcc32.py +81 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/c++.py +99 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/c++.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/cc.py +102 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/cc.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/cvf.py +58 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/default.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/default.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dmd.py +223 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dmd.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dvi.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dvipdf.py +124 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dvipdf.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dvips.py +94 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/dvips.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/f77.py +62 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/f77.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/f90.py +62 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/f90.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/f95.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/f95.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/filesystem.py +98 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/filesystem.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/fortran.py +62 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/fortran.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/g++.py +90 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/g++.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/g77.py +73 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/g77.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gas.py +53 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gas.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gcc.py +80 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gcc.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gfortran.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gfortran.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gnulink.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gnulink.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gs.py +81 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/gs.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/hpc++.py +84 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/hpcc.py +53 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/hplink.py +77 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/icc.py +59 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/icl.py +52 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ifl.py +72 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ifl.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ifort.py +88 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ifort.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ilink.py +59 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ilink32.py +60 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/install.py +229 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/install.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/intelc.py +482 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/ipkg.py +67 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/jar.py +110 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/jar.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/javac.py +230 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/javac.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/javah.py +137 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/javah.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/latex.py +79 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/latex.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/lex.py +97 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/lex.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/link.py +121 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/link.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/linkloc.py +112 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/m4.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/m4.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/masm.py +77 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/midl.py +88 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/mingw.py +158 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/mslib.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/mslink.py +266 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/mssdk.py +50 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/msvc.py +268 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/msvs.py +1388 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/mwcc.py +207 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/mwld.py +107 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/nasm.py +72 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/__init__.py +312 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/ipk.py +185 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/msi.py +527 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/rpm.py +365 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/src_tarbz2.py +43 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/src_targz.py +43 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/src_zip.py +43 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/tarbz2.py +44 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/targz.py +44 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/packaging/zip.py +44 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/pdf.py +78 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/pdf.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/pdflatex.py +83 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/pdflatex.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/pdftex.py +108 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/pdftex.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/qt.py +336 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/rmic.py +120 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/rmic.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/rpcgen.py +70 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/rpcgen.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/rpm.py +132 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/rpm.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sgiar.py +68 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sgic++.py +58 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sgicc.py +53 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sgilink.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sunar.py +67 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sunc++.py +142 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/suncc.py +58 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sunf77.py +63 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sunf90.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sunf95.py +64 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/sunlink.py +77 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/swig.py +182 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/swig.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/tar.py +73 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/tar.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/tex.py +807 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/tex.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/textfile.py +175 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/tlib.py +53 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/wix.py +99 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/wix.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/yacc.py +130 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/yacc.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/zip.py +99 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Tool/zip.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Util.py +1496 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Util.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/BoolVariable.py +89 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/BoolVariable.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/EnumVariable.py +103 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/EnumVariable.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/ListVariable.py +135 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/ListVariable.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/PackageVariable.py +106 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/PackageVariable.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/PathVariable.py +147 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/PathVariable.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/__init__.py +312 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Variables/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Warnings.py +246 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/Warnings.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/__init__.py +49 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/__init__.py +237 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/__init__.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_builtins.py +150 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_builtins.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_collections.py +45 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_dbm.py +45 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_hashlib.py +76 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_io.py +45 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_sets.py +563 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/compat/_scons_subprocess.py +1281 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/cpp.py +589 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/cpp.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/dblite.py +251 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/dblite.pyc +0 -0
- data/ext/qrscanner/zxing/scons/scons-local-2.0.0.final.0/SCons/exitfuncs.py +77 -0
- data/ext/qrscanner/zxing/scons/scons-time.py +1544 -0
- data/ext/qrscanner/zxing/scons/scons.py +196 -0
- data/ext/qrscanner/zxing/scons/sconsign.py +513 -0
- data/qrscanner.gemspec +33 -0
- metadata +1023 -0
@@ -0,0 +1,435 @@
|
|
1
|
+
"""SCons.Job
|
2
|
+
|
3
|
+
This module defines the Serial and Parallel classes that execute tasks to
|
4
|
+
complete a build. The Jobs class provides a higher level interface to start,
|
5
|
+
stop, and wait on jobs.
|
6
|
+
|
7
|
+
"""
|
8
|
+
|
9
|
+
#
|
10
|
+
# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 The SCons Foundation
|
11
|
+
#
|
12
|
+
# Permission is hereby granted, free of charge, to any person obtaining
|
13
|
+
# a copy of this software and associated documentation files (the
|
14
|
+
# "Software"), to deal in the Software without restriction, including
|
15
|
+
# without limitation the rights to use, copy, modify, merge, publish,
|
16
|
+
# distribute, sublicense, and/or sell copies of the Software, and to
|
17
|
+
# permit persons to whom the Software is furnished to do so, subject to
|
18
|
+
# the following conditions:
|
19
|
+
#
|
20
|
+
# The above copyright notice and this permission notice shall be included
|
21
|
+
# in all copies or substantial portions of the Software.
|
22
|
+
#
|
23
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
24
|
+
# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
25
|
+
# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
26
|
+
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
27
|
+
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
28
|
+
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
29
|
+
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
30
|
+
#
|
31
|
+
|
32
|
+
__revision__ = "src/engine/SCons/Job.py 5023 2010/06/14 22:05:46 scons"
|
33
|
+
|
34
|
+
import SCons.compat
|
35
|
+
|
36
|
+
import os
|
37
|
+
import signal
|
38
|
+
|
39
|
+
import SCons.Errors
|
40
|
+
|
41
|
+
# The default stack size (in kilobytes) of the threads used to execute
|
42
|
+
# jobs in parallel.
|
43
|
+
#
|
44
|
+
# We use a stack size of 256 kilobytes. The default on some platforms
|
45
|
+
# is too large and prevents us from creating enough threads to fully
|
46
|
+
# parallelized the build. For example, the default stack size on linux
|
47
|
+
# is 8 MBytes.
|
48
|
+
|
49
|
+
explicit_stack_size = None
|
50
|
+
default_stack_size = 256
|
51
|
+
|
52
|
+
interrupt_msg = 'Build interrupted.'
|
53
|
+
|
54
|
+
|
55
|
+
class InterruptState(object):
|
56
|
+
def __init__(self):
|
57
|
+
self.interrupted = False
|
58
|
+
|
59
|
+
def set(self):
|
60
|
+
self.interrupted = True
|
61
|
+
|
62
|
+
def __call__(self):
|
63
|
+
return self.interrupted
|
64
|
+
|
65
|
+
|
66
|
+
class Jobs(object):
|
67
|
+
"""An instance of this class initializes N jobs, and provides
|
68
|
+
methods for starting, stopping, and waiting on all N jobs.
|
69
|
+
"""
|
70
|
+
|
71
|
+
def __init__(self, num, taskmaster):
|
72
|
+
"""
|
73
|
+
create 'num' jobs using the given taskmaster.
|
74
|
+
|
75
|
+
If 'num' is 1 or less, then a serial job will be used,
|
76
|
+
otherwise a parallel job with 'num' worker threads will
|
77
|
+
be used.
|
78
|
+
|
79
|
+
The 'num_jobs' attribute will be set to the actual number of jobs
|
80
|
+
allocated. If more than one job is requested but the Parallel
|
81
|
+
class can't do it, it gets reset to 1. Wrapping interfaces that
|
82
|
+
care should check the value of 'num_jobs' after initialization.
|
83
|
+
"""
|
84
|
+
|
85
|
+
self.job = None
|
86
|
+
if num > 1:
|
87
|
+
stack_size = explicit_stack_size
|
88
|
+
if stack_size is None:
|
89
|
+
stack_size = default_stack_size
|
90
|
+
|
91
|
+
try:
|
92
|
+
self.job = Parallel(taskmaster, num, stack_size)
|
93
|
+
self.num_jobs = num
|
94
|
+
except NameError:
|
95
|
+
pass
|
96
|
+
if self.job is None:
|
97
|
+
self.job = Serial(taskmaster)
|
98
|
+
self.num_jobs = 1
|
99
|
+
|
100
|
+
def run(self, postfunc=lambda: None):
|
101
|
+
"""Run the jobs.
|
102
|
+
|
103
|
+
postfunc() will be invoked after the jobs has run. It will be
|
104
|
+
invoked even if the jobs are interrupted by a keyboard
|
105
|
+
interrupt (well, in fact by a signal such as either SIGINT,
|
106
|
+
SIGTERM or SIGHUP). The execution of postfunc() is protected
|
107
|
+
against keyboard interrupts and is guaranteed to run to
|
108
|
+
completion."""
|
109
|
+
self._setup_sig_handler()
|
110
|
+
try:
|
111
|
+
self.job.start()
|
112
|
+
finally:
|
113
|
+
postfunc()
|
114
|
+
self._reset_sig_handler()
|
115
|
+
|
116
|
+
def were_interrupted(self):
|
117
|
+
"""Returns whether the jobs were interrupted by a signal."""
|
118
|
+
return self.job.interrupted()
|
119
|
+
|
120
|
+
def _setup_sig_handler(self):
|
121
|
+
"""Setup an interrupt handler so that SCons can shutdown cleanly in
|
122
|
+
various conditions:
|
123
|
+
|
124
|
+
a) SIGINT: Keyboard interrupt
|
125
|
+
b) SIGTERM: kill or system shutdown
|
126
|
+
c) SIGHUP: Controlling shell exiting
|
127
|
+
|
128
|
+
We handle all of these cases by stopping the taskmaster. It
|
129
|
+
turns out that it very difficult to stop the build process
|
130
|
+
by throwing asynchronously an exception such as
|
131
|
+
KeyboardInterrupt. For example, the python Condition
|
132
|
+
variables (threading.Condition) and queue's do not seem to
|
133
|
+
asynchronous-exception-safe. It would require adding a whole
|
134
|
+
bunch of try/finally block and except KeyboardInterrupt all
|
135
|
+
over the place.
|
136
|
+
|
137
|
+
Note also that we have to be careful to handle the case when
|
138
|
+
SCons forks before executing another process. In that case, we
|
139
|
+
want the child to exit immediately.
|
140
|
+
"""
|
141
|
+
def handler(signum, stack, self=self, parentpid=os.getpid()):
|
142
|
+
if os.getpid() == parentpid:
|
143
|
+
self.job.taskmaster.stop()
|
144
|
+
self.job.interrupted.set()
|
145
|
+
else:
|
146
|
+
os._exit(2)
|
147
|
+
|
148
|
+
self.old_sigint = signal.signal(signal.SIGINT, handler)
|
149
|
+
self.old_sigterm = signal.signal(signal.SIGTERM, handler)
|
150
|
+
try:
|
151
|
+
self.old_sighup = signal.signal(signal.SIGHUP, handler)
|
152
|
+
except AttributeError:
|
153
|
+
pass
|
154
|
+
|
155
|
+
def _reset_sig_handler(self):
|
156
|
+
"""Restore the signal handlers to their previous state (before the
|
157
|
+
call to _setup_sig_handler()."""
|
158
|
+
|
159
|
+
signal.signal(signal.SIGINT, self.old_sigint)
|
160
|
+
signal.signal(signal.SIGTERM, self.old_sigterm)
|
161
|
+
try:
|
162
|
+
signal.signal(signal.SIGHUP, self.old_sighup)
|
163
|
+
except AttributeError:
|
164
|
+
pass
|
165
|
+
|
166
|
+
class Serial(object):
|
167
|
+
"""This class is used to execute tasks in series, and is more efficient
|
168
|
+
than Parallel, but is only appropriate for non-parallel builds. Only
|
169
|
+
one instance of this class should be in existence at a time.
|
170
|
+
|
171
|
+
This class is not thread safe.
|
172
|
+
"""
|
173
|
+
|
174
|
+
def __init__(self, taskmaster):
|
175
|
+
"""Create a new serial job given a taskmaster.
|
176
|
+
|
177
|
+
The taskmaster's next_task() method should return the next task
|
178
|
+
that needs to be executed, or None if there are no more tasks. The
|
179
|
+
taskmaster's executed() method will be called for each task when it
|
180
|
+
is successfully executed or failed() will be called if it failed to
|
181
|
+
execute (e.g. execute() raised an exception)."""
|
182
|
+
|
183
|
+
self.taskmaster = taskmaster
|
184
|
+
self.interrupted = InterruptState()
|
185
|
+
|
186
|
+
def start(self):
|
187
|
+
"""Start the job. This will begin pulling tasks from the taskmaster
|
188
|
+
and executing them, and return when there are no more tasks. If a task
|
189
|
+
fails to execute (i.e. execute() raises an exception), then the job will
|
190
|
+
stop."""
|
191
|
+
|
192
|
+
while True:
|
193
|
+
task = self.taskmaster.next_task()
|
194
|
+
|
195
|
+
if task is None:
|
196
|
+
break
|
197
|
+
|
198
|
+
try:
|
199
|
+
task.prepare()
|
200
|
+
if task.needs_execute():
|
201
|
+
task.execute()
|
202
|
+
except:
|
203
|
+
if self.interrupted():
|
204
|
+
try:
|
205
|
+
raise SCons.Errors.BuildError(
|
206
|
+
task.targets[0], errstr=interrupt_msg)
|
207
|
+
except:
|
208
|
+
task.exception_set()
|
209
|
+
else:
|
210
|
+
task.exception_set()
|
211
|
+
|
212
|
+
# Let the failed() callback function arrange for the
|
213
|
+
# build to stop if that's appropriate.
|
214
|
+
task.failed()
|
215
|
+
else:
|
216
|
+
task.executed()
|
217
|
+
|
218
|
+
task.postprocess()
|
219
|
+
self.taskmaster.cleanup()
|
220
|
+
|
221
|
+
|
222
|
+
# Trap import failure so that everything in the Job module but the
|
223
|
+
# Parallel class (and its dependent classes) will work if the interpreter
|
224
|
+
# doesn't support threads.
|
225
|
+
try:
|
226
|
+
import queue
|
227
|
+
import threading
|
228
|
+
except ImportError:
|
229
|
+
pass
|
230
|
+
else:
|
231
|
+
class Worker(threading.Thread):
|
232
|
+
"""A worker thread waits on a task to be posted to its request queue,
|
233
|
+
dequeues the task, executes it, and posts a tuple including the task
|
234
|
+
and a boolean indicating whether the task executed successfully. """
|
235
|
+
|
236
|
+
def __init__(self, requestQueue, resultsQueue, interrupted):
|
237
|
+
threading.Thread.__init__(self)
|
238
|
+
self.setDaemon(1)
|
239
|
+
self.requestQueue = requestQueue
|
240
|
+
self.resultsQueue = resultsQueue
|
241
|
+
self.interrupted = interrupted
|
242
|
+
self.start()
|
243
|
+
|
244
|
+
def run(self):
|
245
|
+
while True:
|
246
|
+
task = self.requestQueue.get()
|
247
|
+
|
248
|
+
if task is None:
|
249
|
+
# The "None" value is used as a sentinel by
|
250
|
+
# ThreadPool.cleanup(). This indicates that there
|
251
|
+
# are no more tasks, so we should quit.
|
252
|
+
break
|
253
|
+
|
254
|
+
try:
|
255
|
+
if self.interrupted():
|
256
|
+
raise SCons.Errors.BuildError(
|
257
|
+
task.targets[0], errstr=interrupt_msg)
|
258
|
+
task.execute()
|
259
|
+
except:
|
260
|
+
task.exception_set()
|
261
|
+
ok = False
|
262
|
+
else:
|
263
|
+
ok = True
|
264
|
+
|
265
|
+
self.resultsQueue.put((task, ok))
|
266
|
+
|
267
|
+
class ThreadPool(object):
|
268
|
+
"""This class is responsible for spawning and managing worker threads."""
|
269
|
+
|
270
|
+
def __init__(self, num, stack_size, interrupted):
|
271
|
+
"""Create the request and reply queues, and 'num' worker threads.
|
272
|
+
|
273
|
+
One must specify the stack size of the worker threads. The
|
274
|
+
stack size is specified in kilobytes.
|
275
|
+
"""
|
276
|
+
self.requestQueue = queue.Queue(0)
|
277
|
+
self.resultsQueue = queue.Queue(0)
|
278
|
+
|
279
|
+
try:
|
280
|
+
prev_size = threading.stack_size(stack_size*1024)
|
281
|
+
except AttributeError, e:
|
282
|
+
# Only print a warning if the stack size has been
|
283
|
+
# explicitly set.
|
284
|
+
if not explicit_stack_size is None:
|
285
|
+
msg = "Setting stack size is unsupported by this version of Python:\n " + \
|
286
|
+
e.args[0]
|
287
|
+
SCons.Warnings.warn(SCons.Warnings.StackSizeWarning, msg)
|
288
|
+
except ValueError, e:
|
289
|
+
msg = "Setting stack size failed:\n " + str(e)
|
290
|
+
SCons.Warnings.warn(SCons.Warnings.StackSizeWarning, msg)
|
291
|
+
|
292
|
+
# Create worker threads
|
293
|
+
self.workers = []
|
294
|
+
for _ in range(num):
|
295
|
+
worker = Worker(self.requestQueue, self.resultsQueue, interrupted)
|
296
|
+
self.workers.append(worker)
|
297
|
+
|
298
|
+
if 'prev_size' in locals():
|
299
|
+
threading.stack_size(prev_size)
|
300
|
+
|
301
|
+
def put(self, task):
|
302
|
+
"""Put task into request queue."""
|
303
|
+
self.requestQueue.put(task)
|
304
|
+
|
305
|
+
def get(self):
|
306
|
+
"""Remove and return a result tuple from the results queue."""
|
307
|
+
return self.resultsQueue.get()
|
308
|
+
|
309
|
+
def preparation_failed(self, task):
|
310
|
+
self.resultsQueue.put((task, False))
|
311
|
+
|
312
|
+
def cleanup(self):
|
313
|
+
"""
|
314
|
+
Shuts down the thread pool, giving each worker thread a
|
315
|
+
chance to shut down gracefully.
|
316
|
+
"""
|
317
|
+
# For each worker thread, put a sentinel "None" value
|
318
|
+
# on the requestQueue (indicating that there's no work
|
319
|
+
# to be done) so that each worker thread will get one and
|
320
|
+
# terminate gracefully.
|
321
|
+
for _ in self.workers:
|
322
|
+
self.requestQueue.put(None)
|
323
|
+
|
324
|
+
# Wait for all of the workers to terminate.
|
325
|
+
#
|
326
|
+
# If we don't do this, later Python versions (2.4, 2.5) often
|
327
|
+
# seem to raise exceptions during shutdown. This happens
|
328
|
+
# in requestQueue.get(), as an assertion failure that
|
329
|
+
# requestQueue.not_full is notified while not acquired,
|
330
|
+
# seemingly because the main thread has shut down (or is
|
331
|
+
# in the process of doing so) while the workers are still
|
332
|
+
# trying to pull sentinels off the requestQueue.
|
333
|
+
#
|
334
|
+
# Normally these terminations should happen fairly quickly,
|
335
|
+
# but we'll stick a one-second timeout on here just in case
|
336
|
+
# someone gets hung.
|
337
|
+
for worker in self.workers:
|
338
|
+
worker.join(1.0)
|
339
|
+
self.workers = []
|
340
|
+
|
341
|
+
class Parallel(object):
|
342
|
+
"""This class is used to execute tasks in parallel, and is somewhat
|
343
|
+
less efficient than Serial, but is appropriate for parallel builds.
|
344
|
+
|
345
|
+
This class is thread safe.
|
346
|
+
"""
|
347
|
+
|
348
|
+
def __init__(self, taskmaster, num, stack_size):
|
349
|
+
"""Create a new parallel job given a taskmaster.
|
350
|
+
|
351
|
+
The taskmaster's next_task() method should return the next
|
352
|
+
task that needs to be executed, or None if there are no more
|
353
|
+
tasks. The taskmaster's executed() method will be called
|
354
|
+
for each task when it is successfully executed or failed()
|
355
|
+
will be called if the task failed to execute (i.e. execute()
|
356
|
+
raised an exception).
|
357
|
+
|
358
|
+
Note: calls to taskmaster are serialized, but calls to
|
359
|
+
execute() on distinct tasks are not serialized, because
|
360
|
+
that is the whole point of parallel jobs: they can execute
|
361
|
+
multiple tasks simultaneously. """
|
362
|
+
|
363
|
+
self.taskmaster = taskmaster
|
364
|
+
self.interrupted = InterruptState()
|
365
|
+
self.tp = ThreadPool(num, stack_size, self.interrupted)
|
366
|
+
|
367
|
+
self.maxjobs = num
|
368
|
+
|
369
|
+
def start(self):
|
370
|
+
"""Start the job. This will begin pulling tasks from the
|
371
|
+
taskmaster and executing them, and return when there are no
|
372
|
+
more tasks. If a task fails to execute (i.e. execute() raises
|
373
|
+
an exception), then the job will stop."""
|
374
|
+
|
375
|
+
jobs = 0
|
376
|
+
|
377
|
+
while True:
|
378
|
+
# Start up as many available tasks as we're
|
379
|
+
# allowed to.
|
380
|
+
while jobs < self.maxjobs:
|
381
|
+
task = self.taskmaster.next_task()
|
382
|
+
if task is None:
|
383
|
+
break
|
384
|
+
|
385
|
+
try:
|
386
|
+
# prepare task for execution
|
387
|
+
task.prepare()
|
388
|
+
except:
|
389
|
+
task.exception_set()
|
390
|
+
task.failed()
|
391
|
+
task.postprocess()
|
392
|
+
else:
|
393
|
+
if task.needs_execute():
|
394
|
+
# dispatch task
|
395
|
+
self.tp.put(task)
|
396
|
+
jobs = jobs + 1
|
397
|
+
else:
|
398
|
+
task.executed()
|
399
|
+
task.postprocess()
|
400
|
+
|
401
|
+
if not task and not jobs: break
|
402
|
+
|
403
|
+
# Let any/all completed tasks finish up before we go
|
404
|
+
# back and put the next batch of tasks on the queue.
|
405
|
+
while True:
|
406
|
+
task, ok = self.tp.get()
|
407
|
+
jobs = jobs - 1
|
408
|
+
|
409
|
+
if ok:
|
410
|
+
task.executed()
|
411
|
+
else:
|
412
|
+
if self.interrupted():
|
413
|
+
try:
|
414
|
+
raise SCons.Errors.BuildError(
|
415
|
+
task.targets[0], errstr=interrupt_msg)
|
416
|
+
except:
|
417
|
+
task.exception_set()
|
418
|
+
|
419
|
+
# Let the failed() callback function arrange
|
420
|
+
# for the build to stop if that's appropriate.
|
421
|
+
task.failed()
|
422
|
+
|
423
|
+
task.postprocess()
|
424
|
+
|
425
|
+
if self.tp.resultsQueue.empty():
|
426
|
+
break
|
427
|
+
|
428
|
+
self.tp.cleanup()
|
429
|
+
self.taskmaster.cleanup()
|
430
|
+
|
431
|
+
# Local Variables:
|
432
|
+
# tab-width:4
|
433
|
+
# indent-tabs-mode:nil
|
434
|
+
# End:
|
435
|
+
# vim: set expandtab tabstop=4 shiftwidth=4:
|
Binary file
|
@@ -0,0 +1,244 @@
|
|
1
|
+
#
|
2
|
+
# Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 The SCons Foundation
|
3
|
+
#
|
4
|
+
# Permission is hereby granted, free of charge, to any person obtaining
|
5
|
+
# a copy of this software and associated documentation files (the
|
6
|
+
# "Software"), to deal in the Software without restriction, including
|
7
|
+
# without limitation the rights to use, copy, modify, merge, publish,
|
8
|
+
# distribute, sublicense, and/or sell copies of the Software, and to
|
9
|
+
# permit persons to whom the Software is furnished to do so, subject to
|
10
|
+
# the following conditions:
|
11
|
+
#
|
12
|
+
# The above copyright notice and this permission notice shall be included
|
13
|
+
# in all copies or substantial portions of the Software.
|
14
|
+
#
|
15
|
+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
16
|
+
# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
17
|
+
# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
18
|
+
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
19
|
+
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
20
|
+
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
21
|
+
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
22
|
+
#
|
23
|
+
|
24
|
+
__revision__ = "src/engine/SCons/Memoize.py 5023 2010/06/14 22:05:46 scons"
|
25
|
+
|
26
|
+
__doc__ = """Memoizer
|
27
|
+
|
28
|
+
A metaclass implementation to count hits and misses of the computed
|
29
|
+
values that various methods cache in memory.
|
30
|
+
|
31
|
+
Use of this modules assumes that wrapped methods be coded to cache their
|
32
|
+
values in a consistent way. Here is an example of wrapping a method
|
33
|
+
that returns a computed value, with no input parameters:
|
34
|
+
|
35
|
+
memoizer_counters = [] # Memoization
|
36
|
+
|
37
|
+
memoizer_counters.append(SCons.Memoize.CountValue('foo')) # Memoization
|
38
|
+
|
39
|
+
def foo(self):
|
40
|
+
|
41
|
+
try: # Memoization
|
42
|
+
return self._memo['foo'] # Memoization
|
43
|
+
except KeyError: # Memoization
|
44
|
+
pass # Memoization
|
45
|
+
|
46
|
+
result = self.compute_foo_value()
|
47
|
+
|
48
|
+
self._memo['foo'] = result # Memoization
|
49
|
+
|
50
|
+
return result
|
51
|
+
|
52
|
+
Here is an example of wrapping a method that will return different values
|
53
|
+
based on one or more input arguments:
|
54
|
+
|
55
|
+
def _bar_key(self, argument): # Memoization
|
56
|
+
return argument # Memoization
|
57
|
+
|
58
|
+
memoizer_counters.append(SCons.Memoize.CountDict('bar', _bar_key)) # Memoization
|
59
|
+
|
60
|
+
def bar(self, argument):
|
61
|
+
|
62
|
+
memo_key = argument # Memoization
|
63
|
+
try: # Memoization
|
64
|
+
memo_dict = self._memo['bar'] # Memoization
|
65
|
+
except KeyError: # Memoization
|
66
|
+
memo_dict = {} # Memoization
|
67
|
+
self._memo['dict'] = memo_dict # Memoization
|
68
|
+
else: # Memoization
|
69
|
+
try: # Memoization
|
70
|
+
return memo_dict[memo_key] # Memoization
|
71
|
+
except KeyError: # Memoization
|
72
|
+
pass # Memoization
|
73
|
+
|
74
|
+
result = self.compute_bar_value(argument)
|
75
|
+
|
76
|
+
memo_dict[memo_key] = result # Memoization
|
77
|
+
|
78
|
+
return result
|
79
|
+
|
80
|
+
At one point we avoided replicating this sort of logic in all the methods
|
81
|
+
by putting it right into this module, but we've moved away from that at
|
82
|
+
present (see the "Historical Note," below.).
|
83
|
+
|
84
|
+
Deciding what to cache is tricky, because different configurations
|
85
|
+
can have radically different performance tradeoffs, and because the
|
86
|
+
tradeoffs involved are often so non-obvious. Consequently, deciding
|
87
|
+
whether or not to cache a given method will likely be more of an art than
|
88
|
+
a science, but should still be based on available data from this module.
|
89
|
+
Here are some VERY GENERAL guidelines about deciding whether or not to
|
90
|
+
cache return values from a method that's being called a lot:
|
91
|
+
|
92
|
+
-- The first question to ask is, "Can we change the calling code
|
93
|
+
so this method isn't called so often?" Sometimes this can be
|
94
|
+
done by changing the algorithm. Sometimes the *caller* should
|
95
|
+
be memoized, not the method you're looking at.
|
96
|
+
|
97
|
+
-- The memoized function should be timed with multiple configurations
|
98
|
+
to make sure it doesn't inadvertently slow down some other
|
99
|
+
configuration.
|
100
|
+
|
101
|
+
-- When memoizing values based on a dictionary key composed of
|
102
|
+
input arguments, you don't need to use all of the arguments
|
103
|
+
if some of them don't affect the return values.
|
104
|
+
|
105
|
+
Historical Note: The initial Memoizer implementation actually handled
|
106
|
+
the caching of values for the wrapped methods, based on a set of generic
|
107
|
+
algorithms for computing hashable values based on the method's arguments.
|
108
|
+
This collected caching logic nicely, but had two drawbacks:
|
109
|
+
|
110
|
+
Running arguments through a generic key-conversion mechanism is slower
|
111
|
+
(and less flexible) than just coding these things directly. Since the
|
112
|
+
methods that need memoized values are generally performance-critical,
|
113
|
+
slowing them down in order to collect the logic isn't the right
|
114
|
+
tradeoff.
|
115
|
+
|
116
|
+
Use of the memoizer really obscured what was being called, because
|
117
|
+
all the memoized methods were wrapped with re-used generic methods.
|
118
|
+
This made it more difficult, for example, to use the Python profiler
|
119
|
+
to figure out how to optimize the underlying methods.
|
120
|
+
"""
|
121
|
+
|
122
|
+
import types
|
123
|
+
|
124
|
+
# A flag controlling whether or not we actually use memoization.
|
125
|
+
use_memoizer = None
|
126
|
+
|
127
|
+
CounterList = []
|
128
|
+
|
129
|
+
class Counter(object):
|
130
|
+
"""
|
131
|
+
Base class for counting memoization hits and misses.
|
132
|
+
|
133
|
+
We expect that the metaclass initialization will have filled in
|
134
|
+
the .name attribute that represents the name of the function
|
135
|
+
being counted.
|
136
|
+
"""
|
137
|
+
def __init__(self, method_name):
|
138
|
+
"""
|
139
|
+
"""
|
140
|
+
self.method_name = method_name
|
141
|
+
self.hit = 0
|
142
|
+
self.miss = 0
|
143
|
+
CounterList.append(self)
|
144
|
+
def display(self):
|
145
|
+
fmt = " %7d hits %7d misses %s()"
|
146
|
+
print fmt % (self.hit, self.miss, self.name)
|
147
|
+
def __cmp__(self, other):
|
148
|
+
try:
|
149
|
+
return cmp(self.name, other.name)
|
150
|
+
except AttributeError:
|
151
|
+
return 0
|
152
|
+
|
153
|
+
class CountValue(Counter):
|
154
|
+
"""
|
155
|
+
A counter class for simple, atomic memoized values.
|
156
|
+
|
157
|
+
A CountValue object should be instantiated in a class for each of
|
158
|
+
the class's methods that memoizes its return value by simply storing
|
159
|
+
the return value in its _memo dictionary.
|
160
|
+
|
161
|
+
We expect that the metaclass initialization will fill in the
|
162
|
+
.underlying_method attribute with the method that we're wrapping.
|
163
|
+
We then call the underlying_method method after counting whether
|
164
|
+
its memoized value has already been set (a hit) or not (a miss).
|
165
|
+
"""
|
166
|
+
def __call__(self, *args, **kw):
|
167
|
+
obj = args[0]
|
168
|
+
if self.method_name in obj._memo:
|
169
|
+
self.hit = self.hit + 1
|
170
|
+
else:
|
171
|
+
self.miss = self.miss + 1
|
172
|
+
return self.underlying_method(*args, **kw)
|
173
|
+
|
174
|
+
class CountDict(Counter):
|
175
|
+
"""
|
176
|
+
A counter class for memoized values stored in a dictionary, with
|
177
|
+
keys based on the method's input arguments.
|
178
|
+
|
179
|
+
A CountDict object is instantiated in a class for each of the
|
180
|
+
class's methods that memoizes its return value in a dictionary,
|
181
|
+
indexed by some key that can be computed from one or more of
|
182
|
+
its input arguments.
|
183
|
+
|
184
|
+
We expect that the metaclass initialization will fill in the
|
185
|
+
.underlying_method attribute with the method that we're wrapping.
|
186
|
+
We then call the underlying_method method after counting whether the
|
187
|
+
computed key value is already present in the memoization dictionary
|
188
|
+
(a hit) or not (a miss).
|
189
|
+
"""
|
190
|
+
def __init__(self, method_name, keymaker):
|
191
|
+
"""
|
192
|
+
"""
|
193
|
+
Counter.__init__(self, method_name)
|
194
|
+
self.keymaker = keymaker
|
195
|
+
def __call__(self, *args, **kw):
|
196
|
+
obj = args[0]
|
197
|
+
try:
|
198
|
+
memo_dict = obj._memo[self.method_name]
|
199
|
+
except KeyError:
|
200
|
+
self.miss = self.miss + 1
|
201
|
+
else:
|
202
|
+
key = self.keymaker(*args, **kw)
|
203
|
+
if key in memo_dict:
|
204
|
+
self.hit = self.hit + 1
|
205
|
+
else:
|
206
|
+
self.miss = self.miss + 1
|
207
|
+
return self.underlying_method(*args, **kw)
|
208
|
+
|
209
|
+
class Memoizer(object):
|
210
|
+
"""Object which performs caching of method calls for its 'primary'
|
211
|
+
instance."""
|
212
|
+
|
213
|
+
def __init__(self):
|
214
|
+
pass
|
215
|
+
|
216
|
+
def Dump(title=None):
|
217
|
+
if title:
|
218
|
+
print title
|
219
|
+
CounterList.sort()
|
220
|
+
for counter in CounterList:
|
221
|
+
counter.display()
|
222
|
+
|
223
|
+
class Memoized_Metaclass(type):
|
224
|
+
def __init__(cls, name, bases, cls_dict):
|
225
|
+
super(Memoized_Metaclass, cls).__init__(name, bases, cls_dict)
|
226
|
+
|
227
|
+
for counter in cls_dict.get('memoizer_counters', []):
|
228
|
+
method_name = counter.method_name
|
229
|
+
|
230
|
+
counter.name = cls.__name__ + '.' + method_name
|
231
|
+
counter.underlying_method = cls_dict[method_name]
|
232
|
+
|
233
|
+
replacement_method = types.MethodType(counter, None, cls)
|
234
|
+
setattr(cls, method_name, replacement_method)
|
235
|
+
|
236
|
+
def EnableMemoization():
|
237
|
+
global use_memoizer
|
238
|
+
use_memoizer = 1
|
239
|
+
|
240
|
+
# Local Variables:
|
241
|
+
# tab-width:4
|
242
|
+
# indent-tabs-mode:nil
|
243
|
+
# End:
|
244
|
+
# vim: set expandtab tabstop=4 shiftwidth=4:
|