From 442cb1bdb7e069eb4d0417619f35811b5ae63da5 Mon Sep 17 00:00:00 2001 From: Gary Sharp Date: Fri, 1 Feb 2013 12:52:29 +1100 Subject: [PATCH] Include Non-NuGet Resources --- Resources/.gitignore | 2 + .../Libraries/DotNetZip/Ionic.Zip.Reduced.dll | Bin 0 -> 253440 bytes .../DotNetZip/Source/BZip2/BZip2Compressor.cs | 1920 + .../Source/BZip2/BZip2InputStream.cs | 1447 + .../Source/BZip2/BZip2OutputStream.cs | 530 + .../DotNetZip/Source/BZip2/BitWriter.cs | 248 + .../Source/BZip2/ParallelBZip2OutputStream.cs | 999 + .../Libraries/DotNetZip/Source/BZip2/Rand.cs | 99 + .../DotNetZip/Source/CommonSrc/CRC32.cs | 814 + .../DotNetZip/Source/Zip/ComHelper.cs | 116 + .../Source/Zip/EncryptionAlgorithm.cs | 135 + .../Libraries/DotNetZip/Source/Zip/Events.cs | 684 + .../DotNetZip/Source/Zip/Exceptions.cs | 300 + .../Source/Zip/ExtractExistingFileAction.cs | 85 + .../DotNetZip/Source/Zip/FileSelector.cs | 1608 + .../DotNetZip/Source/Zip/OffsetStream.cs | 114 + .../Libraries/DotNetZip/Source/Zip/Shared.cs | 901 + .../DotNetZip/Source/Zip/WinZipAes.cs | 941 + .../DotNetZip/Source/Zip/ZipConstants.cs | 51 + .../DotNetZip/Source/Zip/ZipCrypto.cs | 455 + .../DotNetZip/Source/Zip/ZipDirEntry.cs | 381 + .../DotNetZip/Source/Zip/ZipEntry.Extract.cs | 1456 + .../DotNetZip/Source/Zip/ZipEntry.Read.cs | 798 + .../DotNetZip/Source/Zip/ZipEntry.Write.cs | 2582 + .../DotNetZip/Source/Zip/ZipEntry.cs | 2968 + .../DotNetZip/Source/Zip/ZipEntrySource.cs | 69 + .../DotNetZip/Source/Zip/ZipErrorAction.cs | 97 + .../DotNetZip/Source/Zip/ZipFile.AddUpdate.cs | 2163 + .../DotNetZip/Source/Zip/ZipFile.Check.cs | 352 + .../DotNetZip/Source/Zip/ZipFile.Events.cs | 1219 + .../DotNetZip/Source/Zip/ZipFile.Extract.cs | 298 + .../DotNetZip/Source/Zip/ZipFile.Read.cs | 1110 + .../DotNetZip/Source/Zip/ZipFile.Save.cs | 964 + .../Source/Zip/ZipFile.SaveSelfExtractor.cs | 1100 + .../DotNetZip/Source/Zip/ZipFile.Selector.cs | 1464 + .../Libraries/DotNetZip/Source/Zip/ZipFile.cs | 3910 ++ .../Source/Zip/ZipFile.x-IEnumerable.cs | 154 + .../DotNetZip/Source/Zip/ZipInputStream.cs | 827 + .../DotNetZip/Source/Zip/ZipOutputStream.cs | 1817 + .../Source/Zip/ZipSegmentedStream.cs | 571 + .../DotNetZip/Source/Zlib/Deflate.cs | 1879 + .../DotNetZip/Source/Zlib/DeflateStream.cs | 740 + .../DotNetZip/Source/Zlib/GZipStream.cs | 1029 + .../DotNetZip/Source/Zlib/InfTree.cs | 436 + .../DotNetZip/Source/Zlib/Inflate.cs | 1796 + .../Zlib/ParallelDeflateOutputStream.cs | 1386 + .../Libraries/DotNetZip/Source/Zlib/Tree.cs | 423 + .../Libraries/DotNetZip/Source/Zlib/Zlib.cs | 546 + .../DotNetZip/Source/Zlib/ZlibBaseStream.cs | 627 + .../DotNetZip/Source/Zlib/ZlibCodec.cs | 717 + .../DotNetZip/Source/Zlib/ZlibConstants.cs | 128 + .../DotNetZip/Source/Zlib/ZlibStream.cs | 725 + Resources/Libraries/FJ.Core/FJ.Core.dll | Bin 0 -> 55808 bytes Resources/Libraries/FJ.Core/FJ.Core.pdb | Bin 0 -> 146944 bytes .../LibTiff.NET/BitMiracle.LibTiff.NET.dll | Bin 0 -> 599552 bytes .../LibTiff.NET/BitMiracle.LibTiff.NET.xml | 4264 ++ Resources/Libraries/Quartz/C5.dll | Bin 0 -> 272384 bytes .../Libraries/Quartz/ClientProfile/Quartz.dll | Bin 0 -> 497664 bytes .../Libraries/Quartz/ClientProfile/Quartz.pdb | Bin 0 -> 1191424 bytes .../Libraries/Quartz/ClientProfile/Quartz.xml | 20066 +++++++ Resources/Libraries/Quartz/Common.Logging.dll | Bin 0 -> 49152 bytes Resources/Libraries/Quartz/Quartz.dll | Bin 0 -> 497664 bytes Resources/Libraries/Quartz/Quartz.pdb | Bin 0 -> 1191424 bytes Resources/Libraries/Quartz/Quartz.xml | 20066 +++++++ .../Libraries/SharpSSH/DiffieHellman.dll | Bin 0 -> 53248 bytes .../SharpSSH/Org.Mentalis.Security.dll | Bin 0 -> 184320 bytes .../Libraries/SharpSSH/Tamir.SharpSSH.dll | Bin 0 -> 212992 bytes .../Libraries/Spring.NET/Common.Logging.dll | Bin 0 -> 28672 bytes Resources/Libraries/Spring.NET/Spring.Aop.dll | Bin 0 -> 142848 bytes Resources/Libraries/Spring.NET/Spring.Aop.pdb | Bin 0 -> 527872 bytes Resources/Libraries/Spring.NET/Spring.Aop.xml | 11751 ++++ .../Libraries/Spring.NET/Spring.Core.dll | Bin 0 -> 775168 bytes .../Libraries/Spring.NET/Spring.Core.pdb | Bin 0 -> 2530816 bytes .../Libraries/Spring.NET/Spring.Core.xml | 49291 ++++++++++++++++ .../Spring.NET/Spring.Data.NHibernate20.dll | Bin 0 -> 76288 bytes .../Spring.NET/Spring.Data.NHibernate20.pdb | Bin 0 -> 228864 bytes .../Spring.NET/Spring.Data.NHibernate20.xml | 6095 ++ .../Spring.NET/Spring.Data.NHibernate21.dll | Bin 0 -> 92160 bytes .../Spring.NET/Spring.Data.NHibernate21.pdb | Bin 0 -> 286208 bytes .../Spring.NET/Spring.Data.NHibernate21.xml | 6711 +++ .../Spring.NET/Spring.Data.NHibernate30.dll | Bin 0 -> 92160 bytes .../Spring.NET/Spring.Data.NHibernate30.pdb | Bin 0 -> 286208 bytes .../Spring.NET/Spring.Data.NHibernate30.xml | 6711 +++ .../Spring.NET/Spring.Data.NHibernate31.dll | Bin 0 -> 92160 bytes .../Spring.NET/Spring.Data.NHibernate31.pdb | Bin 0 -> 286208 bytes .../Spring.NET/Spring.Data.NHibernate31.xml | 6711 +++ .../Spring.NET/Spring.Data.NHibernate32.dll | Bin 0 -> 92160 bytes .../Spring.NET/Spring.Data.NHibernate32.pdb | Bin 0 -> 286208 bytes .../Spring.NET/Spring.Data.NHibernate32.xml | 6711 +++ .../Libraries/Spring.NET/Spring.Data.dll | Bin 0 -> 384000 bytes .../Libraries/Spring.NET/Spring.Data.pdb | Bin 0 -> 708096 bytes .../Libraries/Spring.NET/Spring.Data.xml | 11693 ++++ .../Spring.NET/Spring.Messaging.Ems.dll | Bin 0 -> 111616 bytes .../Spring.NET/Spring.Messaging.Ems.pdb | Bin 0 -> 331264 bytes .../Spring.NET/Spring.Messaging.Ems.xml | 4922 ++ .../Spring.NET/Spring.Messaging.Nms.dll | Bin 0 -> 99840 bytes .../Spring.NET/Spring.Messaging.Nms.pdb | Bin 0 -> 253440 bytes .../Spring.NET/Spring.Messaging.Nms.xml | 4469 ++ .../Libraries/Spring.NET/Spring.Messaging.dll | Bin 0 -> 56320 bytes .../Libraries/Spring.NET/Spring.Messaging.pdb | Bin 0 -> 161280 bytes .../Libraries/Spring.NET/Spring.Messaging.xml | 2685 + .../Spring.NET/Spring.Scheduling.Quartz.dll | Bin 0 -> 34304 bytes .../Spring.NET/Spring.Scheduling.Quartz.pdb | Bin 0 -> 99840 bytes .../Spring.NET/Spring.Scheduling.Quartz.xml | 2040 + .../Libraries/Spring.NET/Spring.Services.dll | Bin 0 -> 85504 bytes .../Libraries/Spring.NET/Spring.Services.pdb | Bin 0 -> 181760 bytes .../Libraries/Spring.NET/Spring.Services.xml | 2127 + .../Spring.NET/Spring.Template.Velocity.dll | Bin 0 -> 32256 bytes .../Spring.NET/Spring.Template.Velocity.pdb | Bin 0 -> 40448 bytes .../Spring.NET/Spring.Template.Velocity.xml | 698 + .../Spring.NET/Spring.Testing.Microsoft.dll | Bin 0 -> 14848 bytes .../Spring.NET/Spring.Testing.Microsoft.pdb | Bin 0 -> 34304 bytes .../Spring.NET/Spring.Testing.Microsoft.xml | 521 + .../Spring.NET/Spring.Testing.NUnit.dll | Bin 0 -> 18432 bytes .../Spring.NET/Spring.Testing.NUnit.pdb | Bin 0 -> 42496 bytes .../Spring.NET/Spring.Testing.NUnit.xml | 655 + .../Spring.NET/Spring.Web.Extensions.dll | Bin 0 -> 7680 bytes .../Spring.NET/Spring.Web.Extensions.pdb | Bin 0 -> 13824 bytes .../Spring.NET/Spring.Web.Extensions.xml | 50 + .../Libraries/Spring.NET/Spring.Web.Mvc.dll | Bin 0 -> 13824 bytes .../Libraries/Spring.NET/Spring.Web.Mvc.pdb | Bin 0 -> 28160 bytes .../Libraries/Spring.NET/Spring.Web.Mvc.xml | 260 + .../Libraries/Spring.NET/Spring.Web.Mvc3.dll | Bin 0 -> 8704 bytes .../Libraries/Spring.NET/Spring.Web.Mvc3.pdb | Bin 0 -> 22016 bytes .../Libraries/Spring.NET/Spring.Web.Mvc3.xml | 218 + Resources/Libraries/Spring.NET/Spring.Web.dll | Bin 0 -> 165888 bytes Resources/Libraries/Spring.NET/Spring.Web.pdb | Bin 0 -> 540160 bytes Resources/Libraries/Spring.NET/Spring.Web.xml | 9254 +++ Resources/Libraries/ZXing/zxing.dll | Bin 0 -> 217088 bytes Resources/Libraries/ZXing/zxing.pdb | Bin 0 -> 796160 bytes Resources/Libraries/fastJSON/fastJSON-SL.dll | Bin 0 -> 23552 bytes Resources/Libraries/fastJSON/fastJSON-SL.pdb | Bin 0 -> 48640 bytes Resources/Libraries/fastJSON/fastJSON.dll | Bin 0 -> 30208 bytes Resources/Libraries/fastJSON/fastJSON.pdb | Bin 0 -> 56832 bytes Resources/Libraries/iTextSharp/itextsharp.dll | Bin 0 -> 3526656 bytes 135 files changed, 224150 insertions(+) create mode 100644 Resources/.gitignore create mode 100644 Resources/Libraries/DotNetZip/Ionic.Zip.Reduced.dll create mode 100644 Resources/Libraries/DotNetZip/Source/BZip2/BZip2Compressor.cs create mode 100644 Resources/Libraries/DotNetZip/Source/BZip2/BZip2InputStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/BZip2/BZip2OutputStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/BZip2/BitWriter.cs create mode 100644 Resources/Libraries/DotNetZip/Source/BZip2/ParallelBZip2OutputStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/BZip2/Rand.cs create mode 100644 Resources/Libraries/DotNetZip/Source/CommonSrc/CRC32.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ComHelper.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/EncryptionAlgorithm.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/Events.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/Exceptions.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ExtractExistingFileAction.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/FileSelector.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/OffsetStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/Shared.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/WinZipAes.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipConstants.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipCrypto.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipDirEntry.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Extract.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Read.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Write.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipEntrySource.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipErrorAction.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.AddUpdate.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Check.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Events.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Extract.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Read.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Save.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.SaveSelfExtractor.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Selector.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipFile.x-IEnumerable.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipInputStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipOutputStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zip/ZipSegmentedStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/Deflate.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/DeflateStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/GZipStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/InfTree.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/Inflate.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/ParallelDeflateOutputStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/Tree.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/Zlib.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/ZlibBaseStream.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/ZlibCodec.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/ZlibConstants.cs create mode 100644 Resources/Libraries/DotNetZip/Source/Zlib/ZlibStream.cs create mode 100644 Resources/Libraries/FJ.Core/FJ.Core.dll create mode 100644 Resources/Libraries/FJ.Core/FJ.Core.pdb create mode 100644 Resources/Libraries/LibTiff.NET/BitMiracle.LibTiff.NET.dll create mode 100644 Resources/Libraries/LibTiff.NET/BitMiracle.LibTiff.NET.xml create mode 100644 Resources/Libraries/Quartz/C5.dll create mode 100644 Resources/Libraries/Quartz/ClientProfile/Quartz.dll create mode 100644 Resources/Libraries/Quartz/ClientProfile/Quartz.pdb create mode 100644 Resources/Libraries/Quartz/ClientProfile/Quartz.xml create mode 100644 Resources/Libraries/Quartz/Common.Logging.dll create mode 100644 Resources/Libraries/Quartz/Quartz.dll create mode 100644 Resources/Libraries/Quartz/Quartz.pdb create mode 100644 Resources/Libraries/Quartz/Quartz.xml create mode 100644 Resources/Libraries/SharpSSH/DiffieHellman.dll create mode 100644 Resources/Libraries/SharpSSH/Org.Mentalis.Security.dll create mode 100644 Resources/Libraries/SharpSSH/Tamir.SharpSSH.dll create mode 100644 Resources/Libraries/Spring.NET/Common.Logging.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Aop.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Aop.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Aop.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Core.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Core.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Core.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Data.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.Ems.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.Ems.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.Ems.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.Nms.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.Nms.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.Nms.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Messaging.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Services.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Services.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Services.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Template.Velocity.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Template.Velocity.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Template.Velocity.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Testing.NUnit.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Testing.NUnit.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Testing.NUnit.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Extensions.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Extensions.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Extensions.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Mvc.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Mvc.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Mvc.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Mvc3.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Mvc3.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.Mvc3.xml create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.dll create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.pdb create mode 100644 Resources/Libraries/Spring.NET/Spring.Web.xml create mode 100644 Resources/Libraries/ZXing/zxing.dll create mode 100644 Resources/Libraries/ZXing/zxing.pdb create mode 100644 Resources/Libraries/fastJSON/fastJSON-SL.dll create mode 100644 Resources/Libraries/fastJSON/fastJSON-SL.pdb create mode 100644 Resources/Libraries/fastJSON/fastJSON.dll create mode 100644 Resources/Libraries/fastJSON/fastJSON.pdb create mode 100644 Resources/Libraries/iTextSharp/itextsharp.dll diff --git a/Resources/.gitignore b/Resources/.gitignore new file mode 100644 index 00000000..1014a953 --- /dev/null +++ b/Resources/.gitignore @@ -0,0 +1,2 @@ +# Include all Resources +!* \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Ionic.Zip.Reduced.dll b/Resources/Libraries/DotNetZip/Ionic.Zip.Reduced.dll new file mode 100644 index 0000000000000000000000000000000000000000..9622cc53ed6f3e6728fe48d34795cfdb7704ed1f GIT binary patch literal 253440 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

4Z)dERWh|aoDva@FY|(*m=Ew6Piu2VA4;aUJ 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 ((qwE}hlBV=(N({}J_M)Qf>0KLh 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 C{sMIX literal 0 HcmV?d00001 diff --git a/Resources/Libraries/DotNetZip/Source/BZip2/BZip2Compressor.cs b/Resources/Libraries/DotNetZip/Source/BZip2/BZip2Compressor.cs new file mode 100644 index 00000000..68099d2a --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/BZip2/BZip2Compressor.cs @@ -0,0 +1,1920 @@ +// BZip2Compressor.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-July-28 06:17:22> +// +// ------------------------------------------------------------------ +// +// This module defines the BZip2Compressor class, which is a +// BZIP2-compressing encoder. It is used internally in the BZIP2 +// library, by the BZip2OutputStream class and its parallel variant, +// ParallelBZip2OutputStream. This code was originally based on Apache +// commons source code, and significantly modified. The license below +// applies to the original Apache code and to this modified variant. +// +// ------------------------------------------------------------------ + + +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +/* + * This package is based on the work done by Keiron Liddle, Aftex Software + * to whom the Ant project is very grateful for his + * great code. + */ + + +// +// Design notes: +// +// This class performs BZip2 compression. It is derived from the +// BZip2OutputStream from the Apache commons source code, but is +// significantly modified from that code. While the Apache class is a +// stream that compresses, this particular class simply performs +// compression. It follows a Manager pattern. It manages an internal +// buffer for uncompressed data; callers place data into the buffer +// using the Fill() method. This class then compresses the data and +// writes the compressed form out, via the CompressAndWrite() method. +// Because BZip2 uses byte-shredding, this class relies on a BitWriter, +// and not a .NET Stream, to emit its output. (*Think of the BitWriter +// class as an Adapter that enables Bit-oriented output to a standard +// byte-oriented .NET stream.) +// +// This class exists to support the two distinct output streams that +// perform BZip2 compression: BZip2OutputStream and +// ParallelBZip2OutputStream. These streams rely on BZip2Compressor to +// provide the encoder/compression logic. This code has been derived +// from the bzip2 output stream in the Apache commons library; it has +// been significantly modified from that form, in order to provide a +// single compressor that could support both types of streams. +// +// In a bz2 file or stream, there is never any bit padding except for 0..7 +// bits in the final byte in the file. Successive compressed blocks in a +// .bz2 file are not byte-aligned. +// +// + +using System; +using System.IO; + +// flymake: csc.exe /t:module BZip2InputStream.cs BZip2OutputStream.cs Rand.cs BCRC32.cs @@FILE@@ + +namespace Ionic.BZip2 +{ + internal class BZip2Compressor + { + private int blockSize100k; // 0...9 + private int currentByte = -1; + private int runLength = 0; + private int last; // index into the block of the last char processed + private int outBlockFillThreshold; + private CompressionState cstate; + private readonly Ionic.Crc.CRC32 crc = new Ionic.Crc.CRC32(true); + BitWriter bw; + int runs; + + /* + * The following three vars are used when sorting. If too many long + * comparisons happen, we stop sorting, randomise the block slightly, and + * try again. I think this wrinkle in the implementation was removed from + * a later rev of the C-language bzip, not sure. -DPC 24 Jul 2011 + * + */ + private int workDone; + private int workLimit; + private bool firstAttempt; + private bool blockRandomised; + private int origPtr; + + private int nInUse; + private int nMTF; + + private static readonly int SETMASK = (1 << 21); + private static readonly int CLEARMASK = (~SETMASK); + private static readonly byte GREATER_ICOST = 15; + private static readonly byte LESSER_ICOST = 0; + private static readonly int SMALL_THRESH = 20; + private static readonly int DEPTH_THRESH = 10; + private static readonly int WORK_FACTOR = 30; + + /** + * Knuth's increments seem to work better than Incerpi-Sedgewick here. + * Possibly because the number of elems to sort is usually small, typically + * <= 20. + */ + private static readonly int[] increments = { 1, 4, 13, 40, 121, 364, 1093, 3280, + 9841, 29524, 88573, 265720, 797161, + 2391484 }; + + ///

+ /// BZip2Compressor writes its compressed data out via a BitWriter. This + /// is necessary because BZip2 does byte shredding. + /// + public BZip2Compressor(BitWriter writer) + : this(writer, BZip2.MaxBlockSize) + { + } + + public BZip2Compressor(BitWriter writer, int blockSize) + { + this.blockSize100k = blockSize; + this.bw = writer; + + // 20 provides a margin of slop (not to say "Safety"). The maximum + // size of an encoded run in the output block is 5 bytes, so really, 5 + // bytes ought to do, but this is a margin of slop found in the + // original bzip code. Not sure if important for decoding + // (decompressing). So we'll leave the slop. + this.outBlockFillThreshold = (blockSize * BZip2.BlockSizeMultiple) - 20; + this.cstate = new CompressionState(blockSize); + Reset(); + } + + + void Reset() + { + // initBlock(); + this.crc.Reset(); + this.currentByte = -1; + this.runLength = 0; + this.last = -1; + for (int i = 256; --i >= 0;) + this.cstate.inUse[i] = false; + //bw.Reset(); xxx? want this? no no no + } + + + public int BlockSize + { + get { return this.blockSize100k; } + } + + public uint Crc32 + { + get; private set; + } + + public int AvailableBytesOut + { + get; private set; + } + + /// + /// The number of uncompressed bytes being held in the buffer. + /// + /// + /// + /// I am thinking this may be useful in a Stream that uses this + /// compressor class. In the Close() method on the stream it could + /// check this value to see if anything has been written at all. You + /// may think the stream could easily track the number of bytes it + /// wrote, which would eliminate the need for this. But, there is the + /// case where the stream writes a complete block, and it is full, and + /// then writes no more. In that case the stream may want to check. + /// + /// + public int UncompressedBytes + { + get { return this.last + 1; } + } + + + /// + /// Accept new bytes into the compressor data buffer + /// + /// + /// + /// This method does the first-level (cheap) run-length encoding, and + /// stores the encoded data into the rle block. + /// + /// + public int Fill(byte[] buffer, int offset, int count) + { + if (this.last >= this.outBlockFillThreshold) + return 0; // We're full, I tell you! + + int bytesWritten = 0; + int limit = offset + count; + int rc; + + // do run-length-encoding until block is full + do + { + rc = write0(buffer[offset++]); + if (rc > 0) bytesWritten++; + } while (offset < limit && rc == 1); + + return bytesWritten; + } + + + + /// + /// Process one input byte into the block. + /// + /// + /// + /// + /// To "process" the byte means to do the run-length encoding. + /// There are 3 possible return values: + /// + /// 0 - the byte was not written, in other words, not + /// encoded into the block. This happens when the + /// byte b would require the start of a new run, and + /// the block has no more room for new runs. + /// + /// 1 - the byte was written, and the block is not full. + /// + /// 2 - the byte was written, and the block is full. + /// + /// + /// + /// 0 if the byte was not written, non-zero if written. + private int write0(byte b) + { + bool rc; + // there is no current run in progress + if (this.currentByte == -1) + { + this.currentByte = b; + this.runLength++; + return 1; + } + + // this byte is the same as the current run in progress + if (this.currentByte == b) + { + if (++this.runLength > 254) + { + rc = AddRunToOutputBlock(false); + this.currentByte = -1; + this.runLength = 0; + return (rc) ? 2 : 1; + } + return 1; // not full + } + + // This byte requires a new run. + // Put the prior run into the Run-length-encoded block, + // and try to start a new run. + rc = AddRunToOutputBlock(false); + + if (rc) + { + this.currentByte = -1; + this.runLength = 0; + // returning 0 implies the block is full, and the byte was not written. + return 0; + } + + // start a new run + this.runLength = 1; + this.currentByte = b; + return 1; + } + + /// + /// Append one run to the output block. + /// + /// + /// + /// + /// This compressor does run-length-encoding before BWT and etc. This + /// method simply appends a run to the output block. The append always + /// succeeds. The return value indicates whether the block is full: + /// false (not full) implies that at least one additional run could be + /// processed. + /// + /// + /// true if the block is now full; otherwise false. + private bool AddRunToOutputBlock(bool final) + { + runs++; + /* add_pair_to_block ( EState* s ) */ + int previousLast = this.last; + + // sanity check only - because of the check done at the + // bottom of this method, and the logic in write0(), this + // should never ever happen. + if (previousLast >= this.outBlockFillThreshold && !final) + { + var msg = String.Format("block overrun(final={2}): {0} >= threshold ({1})", + previousLast, this.outBlockFillThreshold, final); + throw new Exception(msg); + } + + // NB: the index used here into block is always (last+2). This is + // because last is -1 based - the initial value is -1, a flag value + // used to indicate that nothing has yet been written into the + // block. The endBlock() fn tests for -1 to detect empty blocks. Also, + // the first byte of block is used, during sorting, to hold block[last + // +1], which is the final byte value that had been written into the + // rle block. For those two reasons, the base offset from last is + // always +2. + + byte b = (byte) this.currentByte; + byte[] block = this.cstate.block; + this.cstate.inUse[b] = true; + int rl = this.runLength; + this.crc.UpdateCRC(b, rl); + + switch (rl) + { + case 1: + block[previousLast + 2] = b; + this.last = previousLast + 1; + break; + + case 2: + block[previousLast + 2] = b; + block[previousLast + 3] = b; + this.last = previousLast + 2; + break; + + case 3: + block[previousLast + 2] = b; + block[previousLast + 3] = b; + block[previousLast + 4] = b; + this.last = previousLast + 3; + break; + + default: + rl -= 4; + this.cstate.inUse[rl] = true; + block[previousLast + 2] = b; + block[previousLast + 3] = b; + block[previousLast + 4] = b; + block[previousLast + 5] = b; + block[previousLast + 6] = (byte) rl; + this.last = previousLast + 5; + break; + } + + // is full? + return (this.last >= this.outBlockFillThreshold); + } + + + /// + /// Compress the data that has been placed (Run-length-encoded) into the + /// block. The compressed data goes into the CompressedBytes array. + /// + /// + /// + /// Side effects: 1. fills the CompressedBytes array. 2. sets the + /// AvailableBytesOut property. + /// + /// + public void CompressAndWrite() // endBlock + { + if (this.runLength > 0) + AddRunToOutputBlock(true); + + this.currentByte = -1; + + // Console.WriteLine(" BZip2Compressor:CompressAndWrite (r={0} bcrc={1:X8})", + // runs, this.crc.Crc32Result); + + // has any data been written? + if (this.last == -1) + return; // no data; nothing to compress + + /* sort the block and establish posn of original string */ + blockSort(); + + /* + * A 6-byte block header, the value chosen arbitrarily as 0x314159265359 + * :-). A 32 bit value does not really give a strong enough guarantee + * that the value will not appear by chance in the compressed + * datastream. Worst-case probability of this event, for a 900k block, + * is about 2.0e-3 for 32 bits, 1.0e-5 for 40 bits and 4.0e-8 for 48 + * bits. For a compressed file of size 100Gb -- about 100000 blocks -- + * only a 48-bit marker will do. NB: normal compression/ decompression + * donot rely on these statistical properties. They are only important + * when trying to recover blocks from damaged files. + */ + this.bw.WriteByte(0x31); + this.bw.WriteByte(0x41); + this.bw.WriteByte(0x59); + this.bw.WriteByte(0x26); + this.bw.WriteByte(0x53); + this.bw.WriteByte(0x59); + + this.Crc32 = (uint) this.crc.Crc32Result; + this.bw.WriteInt(this.Crc32); + + /* Now a single bit indicating randomisation. */ + this.bw.WriteBits(1, (this.blockRandomised)?1U:0U); + + /* Finally, block's contents proper. */ + moveToFrontCodeAndSend(); + + Reset(); + } + + + private void randomiseBlock() + { + bool[] inUse = this.cstate.inUse; + byte[] block = this.cstate.block; + int lastShadow = this.last; + + for (int i = 256; --i >= 0;) + inUse[i] = false; + + int rNToGo = 0; + int rTPos = 0; + for (int i = 0, j = 1; i <= lastShadow; i = j, j++) + { + if (rNToGo == 0) + { + rNToGo = (char) Rand.Rnums(rTPos); + if (++rTPos == 512) + { + rTPos = 0; + } + } + + rNToGo--; + block[j] ^= (byte) ((rNToGo == 1) ? 1 : 0); + + // handle 16 bit signed numbers + inUse[block[j] & 0xff] = true; + } + + this.blockRandomised = true; + } + + private void mainSort() + { + CompressionState dataShadow = this.cstate; + int[] runningOrder = dataShadow.mainSort_runningOrder; + int[] copy = dataShadow.mainSort_copy; + bool[] bigDone = dataShadow.mainSort_bigDone; + int[] ftab = dataShadow.ftab; + byte[] block = dataShadow.block; + int[] fmap = dataShadow.fmap; + char[] quadrant = dataShadow.quadrant; + int lastShadow = this.last; + int workLimitShadow = this.workLimit; + bool firstAttemptShadow = this.firstAttempt; + + // Set up the 2-byte frequency table + for (int i = 65537; --i >= 0;) + { + ftab[i] = 0; + } + + /* + * In the various block-sized structures, live data runs from 0 to + * last+NUM_OVERSHOOT_BYTES inclusive. First, set up the overshoot area + * for block. + */ + for (int i = 0; i < BZip2.NUM_OVERSHOOT_BYTES; i++) + { + block[lastShadow + i + 2] = block[(i % (lastShadow + 1)) + 1]; + } + for (int i = lastShadow + BZip2.NUM_OVERSHOOT_BYTES +1; --i >= 0;) + { + quadrant[i] = '\0'; + } + block[0] = block[lastShadow + 1]; + + // Complete the initial radix sort: + + int c1 = block[0] & 0xff; + for (int i = 0; i <= lastShadow; i++) + { + int c2 = block[i + 1] & 0xff; + ftab[(c1 << 8) + c2]++; + c1 = c2; + } + + for (int i = 1; i <= 65536; i++) + ftab[i] += ftab[i - 1]; + + c1 = block[1] & 0xff; + for (int i = 0; i < lastShadow; i++) + { + int c2 = block[i + 2] & 0xff; + fmap[--ftab[(c1 << 8) + c2]] = i; + c1 = c2; + } + + fmap[--ftab[((block[lastShadow + 1] & 0xff) << 8) + (block[1] & 0xff)]] = lastShadow; + + /* + * Now ftab contains the first loc of every small bucket. Calculate the + * running order, from smallest to largest big bucket. + */ + for (int i = 256; --i >= 0;) + { + bigDone[i] = false; + runningOrder[i] = i; + } + + for (int h = 364; h != 1;) + { + h /= 3; + for (int i = h; i <= 255; i++) + { + int vv = runningOrder[i]; + int a = ftab[(vv + 1) << 8] - ftab[vv << 8]; + int b = h - 1; + int j = i; + for (int ro = runningOrder[j - h]; (ftab[(ro + 1) << 8] - ftab[ro << 8]) > a; ro = runningOrder[j + - h]) + { + runningOrder[j] = ro; + j -= h; + if (j <= b) + { + break; + } + } + runningOrder[j] = vv; + } + } + + /* + * The main sorting loop. + */ + for (int i = 0; i <= 255; i++) + { + /* + * Process big buckets, starting with the least full. + */ + int ss = runningOrder[i]; + + // Step 1: + /* + * Complete the big bucket [ss] by quicksorting any unsorted small + * buckets [ss, j]. Hopefully previous pointer-scanning phases have + * already completed many of the small buckets [ss, j], so we don't + * have to sort them at all. + */ + for (int j = 0; j <= 255; j++) + { + int sb = (ss << 8) + j; + int ftab_sb = ftab[sb]; + if ((ftab_sb & SETMASK) != SETMASK) + { + int lo = ftab_sb & CLEARMASK; + int hi = (ftab[sb + 1] & CLEARMASK) - 1; + if (hi > lo) + { + mainQSort3(dataShadow, lo, hi, 2); + if (firstAttemptShadow + && (this.workDone > workLimitShadow)) + { + return; + } + } + ftab[sb] = ftab_sb | SETMASK; + } + } + + // Step 2: + // Now scan this big bucket so as to synthesise the + // sorted order for small buckets [t, ss] for all t != ss. + + for (int j = 0; j <= 255; j++) + { + copy[j] = ftab[(j << 8) + ss] & CLEARMASK; + } + + for (int j = ftab[ss << 8] & CLEARMASK, hj = (ftab[(ss + 1) << 8] & CLEARMASK); j < hj; j++) + { + int fmap_j = fmap[j]; + c1 = block[fmap_j] & 0xff; + if (!bigDone[c1]) + { + fmap[copy[c1]] = (fmap_j == 0) ? lastShadow : (fmap_j - 1); + copy[c1]++; + } + } + + for (int j = 256; --j >= 0;) + ftab[(j << 8) + ss] |= SETMASK; + + // Step 3: + /* + * The ss big bucket is now done. Record this fact, and update the + * quadrant descriptors. Remember to update quadrants in the + * overshoot area too, if necessary. The "if (i < 255)" test merely + * skips this updating for the last bucket processed, since updating + * for the last bucket is pointless. + */ + bigDone[ss] = true; + + if (i < 255) + { + int bbStart = ftab[ss << 8] & CLEARMASK; + int bbSize = (ftab[(ss + 1) << 8] & CLEARMASK) - bbStart; + int shifts = 0; + + while ((bbSize >> shifts) > 65534) + { + shifts++; + } + + for (int j = 0; j < bbSize; j++) + { + int a2update = fmap[bbStart + j]; + char qVal = (char) (j >> shifts); + quadrant[a2update] = qVal; + if (a2update < BZip2.NUM_OVERSHOOT_BYTES) + { + quadrant[a2update + lastShadow + 1] = qVal; + } + } + } + + } + } + + + private void blockSort() + { + this.workLimit = WORK_FACTOR * this.last; + this.workDone = 0; + this.blockRandomised = false; + this.firstAttempt = true; + mainSort(); + + if (this.firstAttempt && (this.workDone > this.workLimit)) + { + randomiseBlock(); + this.workLimit = this.workDone = 0; + this.firstAttempt = false; + mainSort(); + } + + int[] fmap = this.cstate.fmap; + this.origPtr = -1; + for (int i = 0, lastShadow = this.last; i <= lastShadow; i++) + { + if (fmap[i] == 0) + { + this.origPtr = i; + break; + } + } + + // assert (this.origPtr != -1) : this.origPtr; + } + + + /** + * This is the most hammered method of this class. + * + *

+ * This is the version using unrolled loops. + *

+ */ + private bool mainSimpleSort(CompressionState dataShadow, int lo, + int hi, int d) + { + int bigN = hi - lo + 1; + if (bigN < 2) + { + return this.firstAttempt && (this.workDone > this.workLimit); + } + + int hp = 0; + while (increments[hp] < bigN) + hp++; + + int[] fmap = dataShadow.fmap; + char[] quadrant = dataShadow.quadrant; + byte[] block = dataShadow.block; + int lastShadow = this.last; + int lastPlus1 = lastShadow + 1; + bool firstAttemptShadow = this.firstAttempt; + int workLimitShadow = this.workLimit; + int workDoneShadow = this.workDone; + + // Following block contains unrolled code which could be shortened by + // coding it in additional loops. + + // HP: + while (--hp >= 0) + { + int h = increments[hp]; + int mj = lo + h - 1; + + for (int i = lo + h; i <= hi;) + { + // copy + for (int k = 3; (i <= hi) && (--k >= 0); i++) + { + int v = fmap[i]; + int vd = v + d; + int j = i; + + // for (int a; + // (j > mj) && mainGtU((a = fmap[j - h]) + d, vd, + // block, quadrant, lastShadow); + // j -= h) { + // fmap[j] = a; + // } + // + // unrolled version: + + // start inline mainGTU + bool onceRunned = false; + int a = 0; + + HAMMER: while (true) + { + if (onceRunned) + { + fmap[j] = a; + if ((j -= h) <= mj) + { + goto END_HAMMER; + } + } + else { + onceRunned = true; + } + + a = fmap[j - h]; + int i1 = a + d; + int i2 = vd; + + // following could be done in a loop, but + // unrolled it for performance: + if (block[i1 + 1] == block[i2 + 1]) + { + if (block[i1 + 2] == block[i2 + 2]) + { + if (block[i1 + 3] == block[i2 + 3]) + { + if (block[i1 + 4] == block[i2 + 4]) + { + if (block[i1 + 5] == block[i2 + 5]) + { + if (block[(i1 += 6)] == block[(i2 += 6)]) + { + int x = lastShadow; + X: while (x > 0) + { + x -= 4; + + if (block[i1 + 1] == block[i2 + 1]) + { + if (quadrant[i1] == quadrant[i2]) + { + if (block[i1 + 2] == block[i2 + 2]) + { + if (quadrant[i1 + 1] == quadrant[i2 + 1]) + { + if (block[i1 + 3] == block[i2 + 3]) + { + if (quadrant[i1 + 2] == quadrant[i2 + 2]) + { + if (block[i1 + 4] == block[i2 + 4]) + { + if (quadrant[i1 + 3] == quadrant[i2 + 3]) + { + if ((i1 += 4) >= lastPlus1) + { + i1 -= lastPlus1; + } + if ((i2 += 4) >= lastPlus1) + { + i2 -= lastPlus1; + } + workDoneShadow++; + goto X; + } + else if ((quadrant[i1 + 3] > quadrant[i2 + 3])) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 4] & 0xff) > (block[i2 + 4] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((quadrant[i1 + 2] > quadrant[i2 + 2])) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 3] & 0xff) > (block[i2 + 3] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((quadrant[i1 + 1] > quadrant[i2 + 1])) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 2] & 0xff) > (block[i2 + 2] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((quadrant[i1] > quadrant[i2])) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 1] & 0xff) > (block[i2 + 1] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + + } + goto END_HAMMER; + } // while x > 0 + else { + if ((block[i1] & 0xff) > (block[i2] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + } + else if ((block[i1 + 5] & 0xff) > (block[i2 + 5] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 4] & 0xff) > (block[i2 + 4] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 3] & 0xff) > (block[i2 + 3] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 2] & 0xff) > (block[i2 + 2] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + } + else if ((block[i1 + 1] & 0xff) > (block[i2 + 1] & 0xff)) + { + goto HAMMER; + } + else { + goto END_HAMMER; + } + + } // HAMMER + + END_HAMMER: + // end inline mainGTU + + fmap[j] = v; + } + + if (firstAttemptShadow && (i <= hi) + && (workDoneShadow > workLimitShadow)) + { + goto END_HP; + } + } + } + END_HP: + + this.workDone = workDoneShadow; + return firstAttemptShadow && (workDoneShadow > workLimitShadow); + } + + + + private static void vswap(int[] fmap, int p1, int p2, int n) + { + n += p1; + while (p1 < n) + { + int t = fmap[p1]; + fmap[p1++] = fmap[p2]; + fmap[p2++] = t; + } + } + + private static byte med3(byte a, byte b, byte c) + { + return (a < b) ? (b < c ? b : a < c ? c : a) : (b > c ? b : a > c ? c + : a); + } + + + /** + * Method "mainQSort3", file "blocksort.c", BZip2 1.0.2 + */ + private void mainQSort3(CompressionState dataShadow, int loSt, + int hiSt, int dSt) + { + int[] stack_ll = dataShadow.stack_ll; + int[] stack_hh = dataShadow.stack_hh; + int[] stack_dd = dataShadow.stack_dd; + int[] fmap = dataShadow.fmap; + byte[] block = dataShadow.block; + + stack_ll[0] = loSt; + stack_hh[0] = hiSt; + stack_dd[0] = dSt; + + for (int sp = 1; --sp >= 0;) + { + int lo = stack_ll[sp]; + int hi = stack_hh[sp]; + int d = stack_dd[sp]; + + if ((hi - lo < SMALL_THRESH) || (d > DEPTH_THRESH)) + { + if (mainSimpleSort(dataShadow, lo, hi, d)) + { + return; + } + } + else { + int d1 = d + 1; + int med = med3(block[fmap[lo] + d1], + block[fmap[hi] + d1], block[fmap[(lo + hi) >> 1] + d1]) & 0xff; + + int unLo = lo; + int unHi = hi; + int ltLo = lo; + int gtHi = hi; + + while (true) + { + while (unLo <= unHi) + { + int n = (block[fmap[unLo] + d1] & 0xff) + - med; + if (n == 0) + { + int temp = fmap[unLo]; + fmap[unLo++] = fmap[ltLo]; + fmap[ltLo++] = temp; + } + else if (n < 0) + { + unLo++; + } + else { + break; + } + } + + while (unLo <= unHi) + { + int n = (block[fmap[unHi] + d1] & 0xff) + - med; + if (n == 0) + { + int temp = fmap[unHi]; + fmap[unHi--] = fmap[gtHi]; + fmap[gtHi--] = temp; + } + else if (n > 0) + { + unHi--; + } + else { + break; + } + } + + if (unLo <= unHi) + { + int temp = fmap[unLo]; + fmap[unLo++] = fmap[unHi]; + fmap[unHi--] = temp; + } + else { + break; + } + } + + if (gtHi < ltLo) + { + stack_ll[sp] = lo; + stack_hh[sp] = hi; + stack_dd[sp] = d1; + sp++; + } + else { + int n = ((ltLo - lo) < (unLo - ltLo)) ? (ltLo - lo) + : (unLo - ltLo); + vswap(fmap, lo, unLo - n, n); + int m = ((hi - gtHi) < (gtHi - unHi)) ? (hi - gtHi) + : (gtHi - unHi); + vswap(fmap, unLo, hi - m + 1, m); + + n = lo + unLo - ltLo - 1; + m = hi - (gtHi - unHi) + 1; + + stack_ll[sp] = lo; + stack_hh[sp] = n; + stack_dd[sp] = d; + sp++; + + stack_ll[sp] = n + 1; + stack_hh[sp] = m - 1; + stack_dd[sp] = d1; + sp++; + + stack_ll[sp] = m; + stack_hh[sp] = hi; + stack_dd[sp] = d; + sp++; + } + } + } + } + + + + private void generateMTFValues() + { + int lastShadow = this.last; + CompressionState dataShadow = this.cstate; + bool[] inUse = dataShadow.inUse; + byte[] block = dataShadow.block; + int[] fmap = dataShadow.fmap; + char[] sfmap = dataShadow.sfmap; + int[] mtfFreq = dataShadow.mtfFreq; + byte[] unseqToSeq = dataShadow.unseqToSeq; + byte[] yy = dataShadow.generateMTFValues_yy; + + // make maps + int nInUseShadow = 0; + for (int i = 0; i < 256; i++) + { + if (inUse[i]) + { + unseqToSeq[i] = (byte) nInUseShadow; + nInUseShadow++; + } + } + this.nInUse = nInUseShadow; + + int eob = nInUseShadow + 1; + + for (int i = eob; i >= 0; i--) + { + mtfFreq[i] = 0; + } + + for (int i = nInUseShadow; --i >= 0;) + { + yy[i] = (byte) i; + } + + int wr = 0; + int zPend = 0; + + for (int i = 0; i <= lastShadow; i++) + { + byte ll_i = unseqToSeq[block[fmap[i]] & 0xff]; + byte tmp = yy[0]; + int j = 0; + + while (ll_i != tmp) + { + j++; + byte tmp2 = tmp; + tmp = yy[j]; + yy[j] = tmp2; + } + yy[0] = tmp; + + if (j == 0) + { + zPend++; + } + else + { + if (zPend > 0) + { + zPend--; + while (true) + { + if ((zPend & 1) == 0) + { + sfmap[wr] = BZip2.RUNA; + wr++; + mtfFreq[BZip2.RUNA]++; + } + else + { + sfmap[wr] = BZip2.RUNB; + wr++; + mtfFreq[BZip2.RUNB]++; + } + + if (zPend >= 2) + { + zPend = (zPend - 2) >> 1; + } + else + { + break; + } + } + zPend = 0; + } + sfmap[wr] = (char) (j + 1); + wr++; + mtfFreq[j + 1]++; + } + } + + if (zPend > 0) + { + zPend--; + while (true) + { + if ((zPend & 1) == 0) + { + sfmap[wr] = BZip2.RUNA; + wr++; + mtfFreq[BZip2.RUNA]++; + } + else + { + sfmap[wr] = BZip2.RUNB; + wr++; + mtfFreq[BZip2.RUNB]++; + } + + if (zPend >= 2) + { + zPend = (zPend - 2) >> 1; + } + else + { + break; + } + } + } + + sfmap[wr] = (char) eob; + mtfFreq[eob]++; + this.nMTF = wr + 1; + } + + + private static void hbAssignCodes(int[] code, byte[] length, + int minLen, int maxLen, + int alphaSize) + { + int vec = 0; + for (int n = minLen; n <= maxLen; n++) + { + for (int i = 0; i < alphaSize; i++) + { + if ((length[i] & 0xff) == n) + { + code[i] = vec; + vec++; + } + } + vec <<= 1; + } + } + + + + + private void sendMTFValues() + { + byte[][] len = this.cstate.sendMTFValues_len; + int alphaSize = this.nInUse + 2; + + for (int t = BZip2.NGroups; --t >= 0;) + { + byte[] len_t = len[t]; + for (int v = alphaSize; --v >= 0;) + { + len_t[v] = GREATER_ICOST; + } + } + + /* Decide how many coding tables to use */ + // assert (this.nMTF > 0) : this.nMTF; + int nGroups = (this.nMTF < 200) ? 2 : (this.nMTF < 600) ? 3 + : (this.nMTF < 1200) ? 4 : (this.nMTF < 2400) ? 5 : 6; + + /* Generate an initial set of coding tables */ + sendMTFValues0(nGroups, alphaSize); + + /* + * Iterate up to N_ITERS times to improve the tables. + */ + int nSelectors = sendMTFValues1(nGroups, alphaSize); + + /* Compute MTF values for the selectors. */ + sendMTFValues2(nGroups, nSelectors); + + /* Assign actual codes for the tables. */ + sendMTFValues3(nGroups, alphaSize); + + /* Transmit the mapping table. */ + sendMTFValues4(); + + /* Now the selectors. */ + sendMTFValues5(nGroups, nSelectors); + + /* Now the coding tables. */ + sendMTFValues6(nGroups, alphaSize); + + /* And finally, the block data proper */ + sendMTFValues7(nSelectors); + } + + private void sendMTFValues0(int nGroups, int alphaSize) + { + byte[][] len = this.cstate.sendMTFValues_len; + int[] mtfFreq = this.cstate.mtfFreq; + + int remF = this.nMTF; + int gs = 0; + + for (int nPart = nGroups; nPart > 0; nPart--) + { + int tFreq = remF / nPart; + int ge = gs - 1; + int aFreq = 0; + + for (int a = alphaSize - 1; (aFreq < tFreq) && (ge < a);) + { + aFreq += mtfFreq[++ge]; + } + + if ((ge > gs) && (nPart != nGroups) && (nPart != 1) + && (((nGroups - nPart) & 1) != 0)) + { + aFreq -= mtfFreq[ge--]; + } + + byte[] len_np = len[nPart - 1]; + for (int v = alphaSize; --v >= 0;) + { + if ((v >= gs) && (v <= ge)) + { + len_np[v] = LESSER_ICOST; + } + else { + len_np[v] = GREATER_ICOST; + } + } + + gs = ge + 1; + remF -= aFreq; + } + } + + + private static void hbMakeCodeLengths(byte[] len, int[] freq, + CompressionState state1, int alphaSize, + int maxLen) + { + /* + * Nodes and heap entries run from 1. Entry 0 for both the heap and + * nodes is a sentinel. + */ + int[] heap = state1.heap; + int[] weight = state1.weight; + int[] parent = state1.parent; + + for (int i = alphaSize; --i >= 0;) + { + weight[i + 1] = (freq[i] == 0 ? 1 : freq[i]) << 8; + } + + for (bool tooLong = true; tooLong;) + { + tooLong = false; + + int nNodes = alphaSize; + int nHeap = 0; + heap[0] = 0; + weight[0] = 0; + parent[0] = -2; + + for (int i = 1; i <= alphaSize; i++) + { + parent[i] = -1; + nHeap++; + heap[nHeap] = i; + + int zz = nHeap; + int tmp = heap[zz]; + while (weight[tmp] < weight[heap[zz >> 1]]) + { + heap[zz] = heap[zz >> 1]; + zz >>= 1; + } + heap[zz] = tmp; + } + + while (nHeap > 1) + { + int n1 = heap[1]; + heap[1] = heap[nHeap]; + nHeap--; + + int yy = 0; + int zz = 1; + int tmp = heap[1]; + + while (true) + { + yy = zz << 1; + + if (yy > nHeap) + { + break; + } + + if ((yy < nHeap) + && (weight[heap[yy + 1]] < weight[heap[yy]])) + { + yy++; + } + + if (weight[tmp] < weight[heap[yy]]) + { + break; + } + + heap[zz] = heap[yy]; + zz = yy; + } + + heap[zz] = tmp; + + int n2 = heap[1]; + heap[1] = heap[nHeap]; + nHeap--; + + yy = 0; + zz = 1; + tmp = heap[1]; + + while (true) + { + yy = zz << 1; + + if (yy > nHeap) + { + break; + } + + if ((yy < nHeap) + && (weight[heap[yy + 1]] < weight[heap[yy]])) + { + yy++; + } + + if (weight[tmp] < weight[heap[yy]]) + { + break; + } + + heap[zz] = heap[yy]; + zz = yy; + } + + heap[zz] = tmp; + nNodes++; + parent[n1] = parent[n2] = nNodes; + + int weight_n1 = weight[n1]; + int weight_n2 = weight[n2]; + weight[nNodes] = (int) (((uint)weight_n1 & 0xffffff00U) + + ((uint)weight_n2 & 0xffffff00U)) + | (1 + (((weight_n1 & 0x000000ff) + > (weight_n2 & 0x000000ff)) + ? (weight_n1 & 0x000000ff) + : (weight_n2 & 0x000000ff))); + + parent[nNodes] = -1; + nHeap++; + heap[nHeap] = nNodes; + + tmp = 0; + zz = nHeap; + tmp = heap[zz]; + int weight_tmp = weight[tmp]; + while (weight_tmp < weight[heap[zz >> 1]]) + { + heap[zz] = heap[zz >> 1]; + zz >>= 1; + } + heap[zz] = tmp; + + } + + for (int i = 1; i <= alphaSize; i++) + { + int j = 0; + int k = i; + + for (int parent_k; (parent_k = parent[k]) >= 0;) + { + k = parent_k; + j++; + } + + len[i - 1] = (byte) j; + if (j > maxLen) + { + tooLong = true; + } + } + + if (tooLong) + { + for (int i = 1; i < alphaSize; i++) + { + int j = weight[i] >> 8; + j = 1 + (j >> 1); + weight[i] = j << 8; + } + } + } + } + + + private int sendMTFValues1(int nGroups, int alphaSize) + { + CompressionState dataShadow = this.cstate; + int[][] rfreq = dataShadow.sendMTFValues_rfreq; + int[] fave = dataShadow.sendMTFValues_fave; + short[] cost = dataShadow.sendMTFValues_cost; + char[] sfmap = dataShadow.sfmap; + byte[] selector = dataShadow.selector; + byte[][] len = dataShadow.sendMTFValues_len; + byte[] len_0 = len[0]; + byte[] len_1 = len[1]; + byte[] len_2 = len[2]; + byte[] len_3 = len[3]; + byte[] len_4 = len[4]; + byte[] len_5 = len[5]; + int nMTFShadow = this.nMTF; + + int nSelectors = 0; + + for (int iter = 0; iter < BZip2.N_ITERS; iter++) + { + for (int t = nGroups; --t >= 0;) + { + fave[t] = 0; + int[] rfreqt = rfreq[t]; + for (int i = alphaSize; --i >= 0;) + { + rfreqt[i] = 0; + } + } + + nSelectors = 0; + + for (int gs = 0; gs < this.nMTF;) + { + /* Set group start & end marks. */ + + /* + * Calculate the cost of this group as coded by each of the + * coding tables. + */ + + int ge = Math.Min(gs + BZip2.G_SIZE - 1, nMTFShadow - 1); + + if (nGroups == BZip2.NGroups) + { + // unrolled version of the else-block + + int[] c = new int[6]; + + for (int i = gs; i <= ge; i++) + { + int icv = sfmap[i]; + c[0] += len_0[icv] & 0xff; + c[1] += len_1[icv] & 0xff; + c[2] += len_2[icv] & 0xff; + c[3] += len_3[icv] & 0xff; + c[4] += len_4[icv] & 0xff; + c[5] += len_5[icv] & 0xff; + } + + cost[0] = (short) c[0]; + cost[1] = (short) c[1]; + cost[2] = (short) c[2]; + cost[3] = (short) c[3]; + cost[4] = (short) c[4]; + cost[5] = (short) c[5]; + } + else + { + for (int t = nGroups; --t >= 0;) + { + cost[t] = 0; + } + + for (int i = gs; i <= ge; i++) + { + int icv = sfmap[i]; + for (int t = nGroups; --t >= 0;) + { + cost[t] += (short) (len[t][icv] & 0xff); + } + } + } + + /* + * Find the coding table which is best for this group, and + * record its identity in the selector table. + */ + int bt = -1; + for (int t = nGroups, bc = 999999999; --t >= 0;) + { + int cost_t = cost[t]; + if (cost_t < bc) + { + bc = cost_t; + bt = t; + } + } + + fave[bt]++; + selector[nSelectors] = (byte) bt; + nSelectors++; + + /* + * Increment the symbol frequencies for the selected table. + */ + int[] rfreq_bt = rfreq[bt]; + for (int i = gs; i <= ge; i++) + { + rfreq_bt[sfmap[i]]++; + } + + gs = ge + 1; + } + + /* + * Recompute the tables based on the accumulated frequencies. + */ + for (int t = 0; t < nGroups; t++) + { + hbMakeCodeLengths(len[t], rfreq[t], this.cstate, alphaSize, 20); + } + } + + return nSelectors; + } + + private void sendMTFValues2(int nGroups, int nSelectors) + { + // assert (nGroups < 8) : nGroups; + + CompressionState dataShadow = this.cstate; + byte[] pos = dataShadow.sendMTFValues2_pos; + + for (int i = nGroups; --i >= 0;) + { + pos[i] = (byte) i; + } + + for (int i = 0; i < nSelectors; i++) + { + byte ll_i = dataShadow.selector[i]; + byte tmp = pos[0]; + int j = 0; + + while (ll_i != tmp) + { + j++; + byte tmp2 = tmp; + tmp = pos[j]; + pos[j] = tmp2; + } + + pos[0] = tmp; + dataShadow.selectorMtf[i] = (byte) j; + } + } + + private void sendMTFValues3(int nGroups, int alphaSize) + { + int[][] code = this.cstate.sendMTFValues_code; + byte[][] len = this.cstate.sendMTFValues_len; + + for (int t = 0; t < nGroups; t++) + { + int minLen = 32; + int maxLen = 0; + byte[] len_t = len[t]; + for (int i = alphaSize; --i >= 0;) + { + int l = len_t[i] & 0xff; + if (l > maxLen) + { + maxLen = l; + } + if (l < minLen) + { + minLen = l; + } + } + + // assert (maxLen <= 20) : maxLen; + // assert (minLen >= 1) : minLen; + + hbAssignCodes(code[t], len[t], minLen, maxLen, alphaSize); + } + } + + private void sendMTFValues4() + { + bool[] inUse = this.cstate.inUse; + bool[] inUse16 = this.cstate.sentMTFValues4_inUse16; + + for (int i = 16; --i >= 0;) + { + inUse16[i] = false; + int i16 = i * 16; + for (int j = 16; --j >= 0;) + { + if (inUse[i16 + j]) + { + inUse16[i] = true; + } + } + } + + uint u = 0; + for (int i = 0; i < 16; i++) + { + if (inUse16[i]) + u |= 1U << (16 - i - 1); + } + this.bw.WriteBits(16, u); + + + for (int i = 0; i < 16; i++) + { + if (inUse16[i]) + { + int i16 = i * 16; + u = 0; + for (int j = 0; j < 16; j++) + { + if (inUse[i16 + j]) + { + u |= 1U << (16 - j - 1); + } + } + this.bw.WriteBits(16, u); + } + } + } + + + private void sendMTFValues5(int nGroups, int nSelectors) + { + this.bw.WriteBits(3, (uint) nGroups); + this.bw.WriteBits(15, (uint) nSelectors); + + byte[] selectorMtf = this.cstate.selectorMtf; + + for (int i = 0; i < nSelectors; i++) + { + for (int j = 0, hj = selectorMtf[i] & 0xff; j < hj; j++) + { + this.bw.WriteBits(1, 1); + } + + this.bw.WriteBits(1, 0); + } + } + + private void sendMTFValues6(int nGroups, int alphaSize) + { + byte[][] len = this.cstate.sendMTFValues_len; + + for (int t = 0; t < nGroups; t++) + { + byte[] len_t = len[t]; + uint curr = (uint) (len_t[0] & 0xff); + this.bw.WriteBits(5, curr); + + for (int i = 0; i < alphaSize; i++) + { + int lti = len_t[i] & 0xff; + while (curr < lti) + { + this.bw.WriteBits(2, 2U); + curr++; /* 10 */ + } + + while (curr > lti) + { + this.bw.WriteBits(2, 3U); + curr--; /* 11 */ + } + + this.bw.WriteBits(1, 0U); + } + } + } + + + private void sendMTFValues7(int nSelectors) + { + byte[][] len = this.cstate.sendMTFValues_len; + int[][] code = this.cstate.sendMTFValues_code; + byte[] selector = this.cstate.selector; + char[] sfmap = this.cstate.sfmap; + int nMTFShadow = this.nMTF; + + int selCtr = 0; + + for (int gs = 0; gs < nMTFShadow;) + { + int ge = Math.Min(gs + BZip2.G_SIZE - 1, nMTFShadow - 1); + int ix = selector[selCtr] & 0xff; + int[] code_selCtr = code[ix]; + byte[] len_selCtr = len[ix]; + + while (gs <= ge) + { + int sfmap_i = sfmap[gs]; + int n = len_selCtr[sfmap_i] & 0xFF; + this.bw.WriteBits(n, (uint) code_selCtr[sfmap_i]); + gs++; + } + + gs = ge + 1; + selCtr++; + } + } + + private void moveToFrontCodeAndSend() + { + this.bw.WriteBits(24, (uint) this.origPtr); + generateMTFValues(); + sendMTFValues(); + } + + + + + + + private class CompressionState + { + // with blockSize 900k + public readonly bool[] inUse = new bool[256]; // 256 byte + public readonly byte[] unseqToSeq = new byte[256]; // 256 byte + public readonly int[] mtfFreq = new int[BZip2.MaxAlphaSize]; // 1032 byte + public readonly byte[] selector = new byte[BZip2.MaxSelectors]; // 18002 byte + public readonly byte[] selectorMtf = new byte[BZip2.MaxSelectors]; // 18002 byte + + public readonly byte[] generateMTFValues_yy = new byte[256]; // 256 byte + public byte[][] sendMTFValues_len; + + // byte + public int[][] sendMTFValues_rfreq; + + // byte + public readonly int[] sendMTFValues_fave = new int[BZip2.NGroups]; // 24 byte + public readonly short[] sendMTFValues_cost = new short[BZip2.NGroups]; // 12 byte + public int[][] sendMTFValues_code; + + // byte + public readonly byte[] sendMTFValues2_pos = new byte[BZip2.NGroups]; // 6 byte + public readonly bool[] sentMTFValues4_inUse16 = new bool[16]; // 16 byte + + public readonly int[] stack_ll = new int[BZip2.QSORT_STACK_SIZE]; // 4000 byte + public readonly int[] stack_hh = new int[BZip2.QSORT_STACK_SIZE]; // 4000 byte + public readonly int[] stack_dd = new int[BZip2.QSORT_STACK_SIZE]; // 4000 byte + + public readonly int[] mainSort_runningOrder = new int[256]; // 1024 byte + public readonly int[] mainSort_copy = new int[256]; // 1024 byte + public readonly bool[] mainSort_bigDone = new bool[256]; // 256 byte + + public int[] heap = new int[BZip2.MaxAlphaSize + 2]; // 1040 byte + public int[] weight = new int[BZip2.MaxAlphaSize * 2]; // 2064 byte + public int[] parent = new int[BZip2.MaxAlphaSize * 2]; // 2064 byte + + public readonly int[] ftab = new int[65537]; // 262148 byte + // ------------ + // 333408 byte + + public byte[] block; // 900021 byte + public int[] fmap; // 3600000 byte + public char[] sfmap; // 3600000 byte + + // ------------ + // 8433529 byte + // ============ + + /** + * Array instance identical to sfmap, both are used only + * temporarily and independently, so we do not need to allocate + * additional memory. + */ + public char[] quadrant; + + public CompressionState(int blockSize100k) + { + int n = blockSize100k * BZip2.BlockSizeMultiple; + this.block = new byte[(n + 1 + BZip2.NUM_OVERSHOOT_BYTES)]; + this.fmap = new int[n]; + this.sfmap = new char[2 * n]; + this.quadrant = this.sfmap; + this.sendMTFValues_len = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + this.sendMTFValues_rfreq = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + this.sendMTFValues_code = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + } + + } + + + + } +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/BZip2/BZip2InputStream.cs b/Resources/Libraries/DotNetZip/Source/BZip2/BZip2InputStream.cs new file mode 100644 index 00000000..1c152d58 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/BZip2/BZip2InputStream.cs @@ -0,0 +1,1447 @@ +// BZip2InputStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-July-31 11:57:32> +// +// ------------------------------------------------------------------ +// +// This module defines the BZip2InputStream class, which is a decompressing +// stream that handles BZIP2. This code is derived from Apache commons source code. +// The license below applies to the original Apache code. +// +// ------------------------------------------------------------------ + +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + +/* + * This package is based on the work done by Keiron Liddle, Aftex Software + * to whom the Ant project is very grateful for his + * great code. + */ + +// compile: msbuild +// not: csc.exe /t:library /debug+ /out:Ionic.BZip2.dll BZip2InputStream.cs BCRC32.cs Rand.cs + + + +using System; +using System.IO; + +namespace Ionic.BZip2 +{ + + /// + /// A read-only decorator stream that performs BZip2 decompression on Read. + /// + public class BZip2InputStream : System.IO.Stream + { + bool _disposed; + bool _leaveOpen; + Int64 totalBytesRead; + private int last; + + /* for undoing the Burrows-Wheeler transform */ + private int origPtr; + + // blockSize100k: 0 .. 9. + // + // This var name is a misnomer. The actual block size is 100000 + // * blockSize100k. (not 100k * blocksize100k) + private int blockSize100k; + private bool blockRandomised; + private int bsBuff; + private int bsLive; + private readonly Ionic.Crc.CRC32 crc = new Ionic.Crc.CRC32(true); + private int nInUse; + private Stream input; + private int currentChar = -1; + + /// + /// Compressor State + /// + enum CState + { + EOF = 0, + START_BLOCK = 1, + RAND_PART_A = 2, + RAND_PART_B = 3, + RAND_PART_C = 4, + NO_RAND_PART_A = 5, + NO_RAND_PART_B = 6, + NO_RAND_PART_C = 7, + } + + private CState currentState = CState.START_BLOCK; + + private uint storedBlockCRC, storedCombinedCRC; + private uint computedBlockCRC, computedCombinedCRC; + + // Variables used by setup* methods exclusively + private int su_count; + private int su_ch2; + private int su_chPrev; + private int su_i2; + private int su_j2; + private int su_rNToGo; + private int su_rTPos; + private int su_tPos; + private char su_z; + private BZip2InputStream.DecompressionState data; + + + /// + /// Create a BZip2InputStream, wrapping it around the given input Stream. + /// + /// + /// + /// The input stream will be closed when the BZip2InputStream is closed. + /// + /// + /// The stream from which to read compressed data + public BZip2InputStream(Stream input) + : this(input, false) + {} + + + /// + /// Create a BZip2InputStream with the given stream, and + /// specifying whether to leave the wrapped stream open when + /// the BZip2InputStream is closed. + /// + /// The stream from which to read compressed data + /// + /// Whether to leave the input stream open, when the BZip2InputStream closes. + /// + /// + /// + /// + /// This example reads a bzip2-compressed file, decompresses it, + /// and writes the decompressed data into a newly created file. + /// + /// + /// var fname = "logfile.log.bz2"; + /// using (var fs = File.OpenRead(fname)) + /// { + /// using (var decompressor = new Ionic.BZip2.BZip2InputStream(fs)) + /// { + /// var outFname = fname + ".decompressed"; + /// using (var output = File.Create(outFname)) + /// { + /// byte[] buffer = new byte[2048]; + /// int n; + /// while ((n = decompressor.Read(buffer, 0, buffer.Length)) > 0) + /// { + /// output.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + public BZip2InputStream(Stream input, bool leaveOpen) + : base() + { + + this.input = input; + this._leaveOpen = leaveOpen; + init(); + } + + /// + /// Read data from the stream. + /// + /// + /// + /// + /// To decompress a BZip2 data stream, create a BZip2InputStream, + /// providing a stream that reads compressed data. Then call Read() on + /// that BZip2InputStream, and the data read will be decompressed + /// as you read. + /// + /// + /// + /// A BZip2InputStream can be used only for Read(), not for Write(). + /// + /// + /// + /// The buffer into which the read data should be placed. + /// the offset within that data array to put the first byte read. + /// the number of bytes to read. + /// the number of bytes actually read + public override int Read(byte[] buffer, int offset, int count) + { + if (offset < 0) + throw new IndexOutOfRangeException(String.Format("offset ({0}) must be > 0", offset)); + + if (count < 0) + throw new IndexOutOfRangeException(String.Format("count ({0}) must be > 0", count)); + + if (offset + count > buffer.Length) + throw new IndexOutOfRangeException(String.Format("offset({0}) count({1}) bLength({2})", + offset, count, buffer.Length)); + + if (this.input == null) + throw new IOException("the stream is not open"); + + + int hi = offset + count; + int destOffset = offset; + for (int b; (destOffset < hi) && ((b = ReadByte()) >= 0);) + { + buffer[destOffset++] = (byte) b; + } + + return (destOffset == offset) ? -1 : (destOffset - offset); + } + + private void MakeMaps() + { + bool[] inUse = this.data.inUse; + byte[] seqToUnseq = this.data.seqToUnseq; + + int n = 0; + + for (int i = 0; i < 256; i++) + { + if (inUse[i]) + seqToUnseq[n++] = (byte) i; + } + + this.nInUse = n; + } + + /// + /// Read a single byte from the stream. + /// + /// the byte read from the stream, or -1 if EOF + public override int ReadByte() + { + int retChar = this.currentChar; + totalBytesRead++; + switch (this.currentState) + { + case CState.EOF: + return -1; + + case CState.START_BLOCK: + throw new IOException("bad state"); + + case CState.RAND_PART_A: + throw new IOException("bad state"); + + case CState.RAND_PART_B: + SetupRandPartB(); + break; + + case CState.RAND_PART_C: + SetupRandPartC(); + break; + + case CState.NO_RAND_PART_A: + throw new IOException("bad state"); + + case CState.NO_RAND_PART_B: + SetupNoRandPartB(); + break; + + case CState.NO_RAND_PART_C: + SetupNoRandPartC(); + break; + + default: + throw new IOException("bad state"); + } + + return retChar; + } + + + + + /// + /// Indicates whether the stream can be read. + /// + /// + /// The return value depends on whether the captive stream supports reading. + /// + public override bool CanRead + { + get + { + if (_disposed) throw new ObjectDisposedException("BZip2Stream"); + return this.input.CanRead; + } + } + + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + + /// + /// Indicates whether the stream can be written. + /// + /// + /// The return value depends on whether the captive stream supports writing. + /// + public override bool CanWrite + { + get + { + if (_disposed) throw new ObjectDisposedException("BZip2Stream"); + return input.CanWrite; + } + } + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (_disposed) throw new ObjectDisposedException("BZip2Stream"); + input.Flush(); + } + + /// + /// Reading this property always throws a . + /// + public override long Length + { + get { throw new NotImplementedException(); } + } + + /// + /// The position of the stream pointer. + /// + /// + /// + /// Setting this property always throws a . Reading will return the + /// total number of uncompressed bytes read in. + /// + public override long Position + { + get + { + return this.totalBytesRead; + } + set { throw new NotImplementedException(); } + } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + /// this is irrelevant, since it will always throw! + /// irrelevant! + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this parameter is never used + /// this parameter is never used + /// this parameter is never used + public override void Write(byte[] buffer, int offset, int count) + { + throw new NotImplementedException(); + } + + + /// + /// Dispose the stream. + /// + /// + /// indicates whether the Dispose method was invoked by user code. + /// + protected override void Dispose(bool disposing) + { + try + { + if (!_disposed) + { + if (disposing && (this.input != null)) + this.input.Close(); + _disposed = true; + } + } + finally + { + base.Dispose(disposing); + } + } + + + void init() + { + if (null == this.input) + throw new IOException("No input Stream"); + + if (!this.input.CanRead) + throw new IOException("Unreadable input Stream"); + + CheckMagicChar('B', 0); + CheckMagicChar('Z', 1); + CheckMagicChar('h', 2); + + int blockSize = this.input.ReadByte(); + + if ((blockSize < '1') || (blockSize > '9')) + throw new IOException("Stream is not BZip2 formatted: illegal " + + "blocksize " + (char) blockSize); + + this.blockSize100k = blockSize - '0'; + + InitBlock(); + SetupBlock(); + } + + + void CheckMagicChar(char expected, int position) + { + int magic = this.input.ReadByte(); + if (magic != (int)expected) + { + var msg = String.Format("Not a valid BZip2 stream. byte {0}, expected '{1}', got '{2}'", + position, (int)expected, magic); + throw new IOException(msg); + } + } + + + void InitBlock() + { + char magic0 = bsGetUByte(); + char magic1 = bsGetUByte(); + char magic2 = bsGetUByte(); + char magic3 = bsGetUByte(); + char magic4 = bsGetUByte(); + char magic5 = bsGetUByte(); + + if (magic0 == 0x17 && magic1 == 0x72 && magic2 == 0x45 + && magic3 == 0x38 && magic4 == 0x50 && magic5 == 0x90) + { + complete(); // end of file + } + else if (magic0 != 0x31 || + magic1 != 0x41 || + magic2 != 0x59 || + magic3 != 0x26 || + magic4 != 0x53 || + magic5 != 0x59) + { + this.currentState = CState.EOF; + var msg = String.Format("bad block header at offset 0x{0:X}", + this.input.Position); + throw new IOException(msg); + } + else + { + this.storedBlockCRC = bsGetInt(); + // Console.WriteLine(" stored block CRC : {0:X8}", this.storedBlockCRC); + + this.blockRandomised = (GetBits(1) == 1); + + // Lazily allocate data + if (this.data == null) + this.data = new DecompressionState(this.blockSize100k); + + // currBlockNo++; + getAndMoveToFrontDecode(); + + this.crc.Reset(); + this.currentState = CState.START_BLOCK; + } + } + + + private void EndBlock() + { + this.computedBlockCRC = (uint)this.crc.Crc32Result; + + // A bad CRC is considered a fatal error. + if (this.storedBlockCRC != this.computedBlockCRC) + { + // make next blocks readable without error + // (repair feature, not yet documented, not tested) + // this.computedCombinedCRC = (this.storedCombinedCRC << 1) + // | (this.storedCombinedCRC >> 31); + // this.computedCombinedCRC ^= this.storedBlockCRC; + + var msg = String.Format("BZip2 CRC error (expected {0:X8}, computed {1:X8})", + this.storedBlockCRC, this.computedBlockCRC); + throw new IOException(msg); + } + + // Console.WriteLine(" combined CRC (before): {0:X8}", this.computedCombinedCRC); + this.computedCombinedCRC = (this.computedCombinedCRC << 1) + | (this.computedCombinedCRC >> 31); + this.computedCombinedCRC ^= this.computedBlockCRC; + // Console.WriteLine(" computed block CRC : {0:X8}", this.computedBlockCRC); + // Console.WriteLine(" combined CRC (after) : {0:X8}", this.computedCombinedCRC); + // Console.WriteLine(); + } + + + private void complete() + { + this.storedCombinedCRC = bsGetInt(); + this.currentState = CState.EOF; + this.data = null; + + if (this.storedCombinedCRC != this.computedCombinedCRC) + { + var msg = String.Format("BZip2 CRC error (expected {0:X8}, computed {1:X8})", + this.storedCombinedCRC, this.computedCombinedCRC); + + throw new IOException(msg); + } + } + + /// + /// Close the stream. + /// + public override void Close() + { + Stream inShadow = this.input; + if (inShadow != null) + { + try + { + if (!this._leaveOpen) + inShadow.Close(); + } + finally + { + this.data = null; + this.input = null; + } + } + } + + + /// + /// Read n bits from input, right justifying the result. + /// + /// + /// + /// For example, if you read 1 bit, the result is either 0 + /// or 1. + /// + /// + /// + /// The number of bits to read, always between 1 and 32. + /// + private int GetBits(int n) + { + int bsLiveShadow = this.bsLive; + int bsBuffShadow = this.bsBuff; + + if (bsLiveShadow < n) + { + do + { + int thech = this.input.ReadByte(); + + if (thech < 0) + throw new IOException("unexpected end of stream"); + + // Console.WriteLine("R {0:X2}", thech); + + bsBuffShadow = (bsBuffShadow << 8) | thech; + bsLiveShadow += 8; + } while (bsLiveShadow < n); + + this.bsBuff = bsBuffShadow; + } + + this.bsLive = bsLiveShadow - n; + return (bsBuffShadow >> (bsLiveShadow - n)) & ((1 << n) - 1); + } + + + // private bool bsGetBit() + // { + // int bsLiveShadow = this.bsLive; + // int bsBuffShadow = this.bsBuff; + // + // if (bsLiveShadow < 1) + // { + // int thech = this.input.ReadByte(); + // + // if (thech < 0) + // { + // throw new IOException("unexpected end of stream"); + // } + // + // bsBuffShadow = (bsBuffShadow << 8) | thech; + // bsLiveShadow += 8; + // this.bsBuff = bsBuffShadow; + // } + // + // this.bsLive = bsLiveShadow - 1; + // return ((bsBuffShadow >> (bsLiveShadow - 1)) & 1) != 0; + // } + + private bool bsGetBit() + { + int bit = GetBits(1); + return bit != 0; + } + + private char bsGetUByte() + { + return (char) GetBits(8); + } + + private uint bsGetInt() + { + return (uint)((((((GetBits(8) << 8) | GetBits(8)) << 8) | GetBits(8)) << 8) | GetBits(8)); + } + + + /** + * Called by createHuffmanDecodingTables() exclusively. + */ + private static void hbCreateDecodeTables(int[] limit, + int[] bbase, int[] perm, char[] length, + int minLen, int maxLen, int alphaSize) + { + for (int i = minLen, pp = 0; i <= maxLen; i++) + { + for (int j = 0; j < alphaSize; j++) + { + if (length[j] == i) + { + perm[pp++] = j; + } + } + } + + for (int i = BZip2.MaxCodeLength; --i > 0;) + { + bbase[i] = 0; + limit[i] = 0; + } + + for (int i = 0; i < alphaSize; i++) + { + bbase[length[i] + 1]++; + } + + for (int i = 1, b = bbase[0]; i < BZip2.MaxCodeLength; i++) + { + b += bbase[i]; + bbase[i] = b; + } + + for (int i = minLen, vec = 0, b = bbase[i]; i <= maxLen; i++) + { + int nb = bbase[i + 1]; + vec += nb - b; + b = nb; + limit[i] = vec - 1; + vec <<= 1; + } + + for (int i = minLen + 1; i <= maxLen; i++) + { + bbase[i] = ((limit[i - 1] + 1) << 1) - bbase[i]; + } + } + + + + private void recvDecodingTables() + { + var s = this.data; + bool[] inUse = s.inUse; + byte[] pos = s.recvDecodingTables_pos; + //byte[] selector = s.selector; + + int inUse16 = 0; + + /* Receive the mapping table */ + for (int i = 0; i < 16; i++) + { + if (bsGetBit()) + { + inUse16 |= 1 << i; + } + } + + for (int i = 256; --i >= 0;) + { + inUse[i] = false; + } + + for (int i = 0; i < 16; i++) + { + if ((inUse16 & (1 << i)) != 0) + { + int i16 = i << 4; + for (int j = 0; j < 16; j++) + { + if (bsGetBit()) + { + inUse[i16 + j] = true; + } + } + } + } + + MakeMaps(); + int alphaSize = this.nInUse + 2; + + /* Now the selectors */ + int nGroups = GetBits(3); + int nSelectors = GetBits(15); + + for (int i = 0; i < nSelectors; i++) + { + int j = 0; + while (bsGetBit()) + { + j++; + } + s.selectorMtf[i] = (byte) j; + } + + /* Undo the MTF values for the selectors. */ + for (int v = nGroups; --v >= 0;) + { + pos[v] = (byte) v; + } + + for (int i = 0; i < nSelectors; i++) + { + int v = s.selectorMtf[i]; + byte tmp = pos[v]; + while (v > 0) + { + // nearly all times v is zero, 4 in most other cases + pos[v] = pos[v - 1]; + v--; + } + pos[0] = tmp; + s.selector[i] = tmp; + } + + char[][] len = s.temp_charArray2d; + + /* Now the coding tables */ + for (int t = 0; t < nGroups; t++) + { + int curr = GetBits(5); + char[] len_t = len[t]; + for (int i = 0; i < alphaSize; i++) + { + while (bsGetBit()) + { + curr += bsGetBit() ? -1 : 1; + } + len_t[i] = (char) curr; + } + } + + // finally create the Huffman tables + createHuffmanDecodingTables(alphaSize, nGroups); + } + + + /** + * Called by recvDecodingTables() exclusively. + */ + private void createHuffmanDecodingTables(int alphaSize, + int nGroups) + { + var s = this.data; + char[][] len = s.temp_charArray2d; + + for (int t = 0; t < nGroups; t++) + { + int minLen = 32; + int maxLen = 0; + char[] len_t = len[t]; + for (int i = alphaSize; --i >= 0;) + { + char lent = len_t[i]; + if (lent > maxLen) + maxLen = lent; + + if (lent < minLen) + minLen = lent; + } + hbCreateDecodeTables(s.gLimit[t], s.gBase[t], s.gPerm[t], len[t], minLen, + maxLen, alphaSize); + s.gMinlen[t] = minLen; + } + } + + + + private void getAndMoveToFrontDecode() + { + var s = this.data; + this.origPtr = GetBits(24); + + if (this.origPtr < 0) + throw new IOException("BZ_DATA_ERROR"); + if (this.origPtr > 10 + BZip2.BlockSizeMultiple * this.blockSize100k) + throw new IOException("BZ_DATA_ERROR"); + + recvDecodingTables(); + + byte[] yy = s.getAndMoveToFrontDecode_yy; + int limitLast = this.blockSize100k * BZip2.BlockSizeMultiple; + + /* + * Setting up the unzftab entries here is not strictly necessary, but it + * does save having to do it later in a separate pass, and so saves a + * block's worth of cache misses. + */ + for (int i = 256; --i >= 0;) + { + yy[i] = (byte) i; + s.unzftab[i] = 0; + } + + int groupNo = 0; + int groupPos = BZip2.G_SIZE - 1; + int eob = this.nInUse + 1; + int nextSym = getAndMoveToFrontDecode0(0); + int bsBuffShadow = this.bsBuff; + int bsLiveShadow = this.bsLive; + int lastShadow = -1; + int zt = s.selector[groupNo] & 0xff; + int[] base_zt = s.gBase[zt]; + int[] limit_zt = s.gLimit[zt]; + int[] perm_zt = s.gPerm[zt]; + int minLens_zt = s.gMinlen[zt]; + + while (nextSym != eob) + { + if ((nextSym == BZip2.RUNA) || (nextSym == BZip2.RUNB)) + { + int es = -1; + + for (int n = 1; true; n <<= 1) + { + if (nextSym == BZip2.RUNA) + { + es += n; + } + else if (nextSym == BZip2.RUNB) + { + es += n << 1; + } + else + { + break; + } + + if (groupPos == 0) + { + groupPos = BZip2.G_SIZE - 1; + zt = s.selector[++groupNo] & 0xff; + base_zt = s.gBase[zt]; + limit_zt = s.gLimit[zt]; + perm_zt = s.gPerm[zt]; + minLens_zt = s.gMinlen[zt]; + } + else + { + groupPos--; + } + + int zn = minLens_zt; + + // Inlined: + // int zvec = GetBits(zn); + while (bsLiveShadow < zn) + { + int thech = this.input.ReadByte(); + if (thech >= 0) + { + bsBuffShadow = (bsBuffShadow << 8) | thech; + bsLiveShadow += 8; + continue; + } + else + { + throw new IOException("unexpected end of stream"); + } + } + int zvec = (bsBuffShadow >> (bsLiveShadow - zn)) + & ((1 << zn) - 1); + bsLiveShadow -= zn; + + while (zvec > limit_zt[zn]) + { + zn++; + while (bsLiveShadow < 1) + { + int thech = this.input.ReadByte(); + if (thech >= 0) + { + bsBuffShadow = (bsBuffShadow << 8) | thech; + bsLiveShadow += 8; + continue; + } + else + { + throw new IOException("unexpected end of stream"); + } + } + bsLiveShadow--; + zvec = (zvec << 1) + | ((bsBuffShadow >> bsLiveShadow) & 1); + } + nextSym = perm_zt[zvec - base_zt[zn]]; + } + + byte ch = s.seqToUnseq[yy[0]]; + s.unzftab[ch & 0xff] += es + 1; + + while (es-- >= 0) + { + s.ll8[++lastShadow] = ch; + } + + if (lastShadow >= limitLast) + throw new IOException("block overrun"); + } + else + { + if (++lastShadow >= limitLast) + throw new IOException("block overrun"); + + byte tmp = yy[nextSym - 1]; + s.unzftab[s.seqToUnseq[tmp] & 0xff]++; + s.ll8[lastShadow] = s.seqToUnseq[tmp]; + + /* + * This loop is hammered during decompression, hence avoid + * native method call overhead of System.Buffer.BlockCopy for very + * small ranges to copy. + */ + if (nextSym <= 16) + { + for (int j = nextSym - 1; j > 0;) + { + yy[j] = yy[--j]; + } + } + else + { + System.Buffer.BlockCopy(yy, 0, yy, 1, nextSym - 1); + } + + yy[0] = tmp; + + if (groupPos == 0) + { + groupPos = BZip2.G_SIZE - 1; + zt = s.selector[++groupNo] & 0xff; + base_zt = s.gBase[zt]; + limit_zt = s.gLimit[zt]; + perm_zt = s.gPerm[zt]; + minLens_zt = s.gMinlen[zt]; + } + else + { + groupPos--; + } + + int zn = minLens_zt; + + // Inlined: + // int zvec = GetBits(zn); + while (bsLiveShadow < zn) + { + int thech = this.input.ReadByte(); + if (thech >= 0) + { + bsBuffShadow = (bsBuffShadow << 8) | thech; + bsLiveShadow += 8; + continue; + } + else + { + throw new IOException("unexpected end of stream"); + } + } + int zvec = (bsBuffShadow >> (bsLiveShadow - zn)) + & ((1 << zn) - 1); + bsLiveShadow -= zn; + + while (zvec > limit_zt[zn]) + { + zn++; + while (bsLiveShadow < 1) + { + int thech = this.input.ReadByte(); + if (thech >= 0) + { + bsBuffShadow = (bsBuffShadow << 8) | thech; + bsLiveShadow += 8; + continue; + } + else + { + throw new IOException("unexpected end of stream"); + } + } + bsLiveShadow--; + zvec = (zvec << 1) | ((bsBuffShadow >> bsLiveShadow) & 1); + } + nextSym = perm_zt[zvec - base_zt[zn]]; + } + } + + this.last = lastShadow; + this.bsLive = bsLiveShadow; + this.bsBuff = bsBuffShadow; + } + + + private int getAndMoveToFrontDecode0(int groupNo) + { + var s = this.data; + int zt = s.selector[groupNo] & 0xff; + int[] limit_zt = s.gLimit[zt]; + int zn = s.gMinlen[zt]; + int zvec = GetBits(zn); + int bsLiveShadow = this.bsLive; + int bsBuffShadow = this.bsBuff; + + while (zvec > limit_zt[zn]) + { + zn++; + while (bsLiveShadow < 1) + { + int thech = this.input.ReadByte(); + + if (thech >= 0) + { + bsBuffShadow = (bsBuffShadow << 8) | thech; + bsLiveShadow += 8; + continue; + } + else + { + throw new IOException("unexpected end of stream"); + } + } + bsLiveShadow--; + zvec = (zvec << 1) | ((bsBuffShadow >> bsLiveShadow) & 1); + } + + this.bsLive = bsLiveShadow; + this.bsBuff = bsBuffShadow; + + return s.gPerm[zt][zvec - s.gBase[zt][zn]]; + } + + + private void SetupBlock() + { + if (this.data == null) + return; + + int i; + var s = this.data; + int[] tt = s.initTT(this.last + 1); + + // xxxx + + /* Check: unzftab entries in range. */ + for (i = 0; i <= 255; i++) + { + if (s.unzftab[i] < 0 || s.unzftab[i] > this.last) + throw new Exception("BZ_DATA_ERROR"); + } + + /* Actually generate cftab. */ + s.cftab[0] = 0; + for (i = 1; i <= 256; i++) s.cftab[i] = s.unzftab[i-1]; + for (i = 1; i <= 256; i++) s.cftab[i] += s.cftab[i-1]; + /* Check: cftab entries in range. */ + for (i = 0; i <= 256; i++) + { + if (s.cftab[i] < 0 || s.cftab[i] > this.last+1) + { + var msg = String.Format("BZ_DATA_ERROR: cftab[{0}]={1} last={2}", + i, s.cftab[i], this.last); + throw new Exception(msg); + } + } + /* Check: cftab entries non-descending. */ + for (i = 1; i <= 256; i++) + { + if (s.cftab[i-1] > s.cftab[i]) + throw new Exception("BZ_DATA_ERROR"); + } + + int lastShadow; + for (i = 0, lastShadow = this.last; i <= lastShadow; i++) + { + tt[s.cftab[s.ll8[i] & 0xff]++] = i; + } + + if ((this.origPtr < 0) || (this.origPtr >= tt.Length)) + throw new IOException("stream corrupted"); + + this.su_tPos = tt[this.origPtr]; + this.su_count = 0; + this.su_i2 = 0; + this.su_ch2 = 256; /* not a valid 8-bit byte value?, and not EOF */ + + if (this.blockRandomised) + { + this.su_rNToGo = 0; + this.su_rTPos = 0; + SetupRandPartA(); + } + else + { + SetupNoRandPartA(); + } + } + + + + private void SetupRandPartA() + { + if (this.su_i2 <= this.last) + { + this.su_chPrev = this.su_ch2; + int su_ch2Shadow = this.data.ll8[this.su_tPos] & 0xff; + this.su_tPos = this.data.tt[this.su_tPos]; + if (this.su_rNToGo == 0) + { + this.su_rNToGo = Rand.Rnums(this.su_rTPos) - 1; + if (++this.su_rTPos == 512) + { + this.su_rTPos = 0; + } + } + else + { + this.su_rNToGo--; + } + this.su_ch2 = su_ch2Shadow ^= (this.su_rNToGo == 1) ? 1 : 0; + this.su_i2++; + this.currentChar = su_ch2Shadow; + this.currentState = CState.RAND_PART_B; + this.crc.UpdateCRC((byte)su_ch2Shadow); + } + else + { + EndBlock(); + InitBlock(); + SetupBlock(); + } + } + + private void SetupNoRandPartA() + { + if (this.su_i2 <= this.last) + { + this.su_chPrev = this.su_ch2; + int su_ch2Shadow = this.data.ll8[this.su_tPos] & 0xff; + this.su_ch2 = su_ch2Shadow; + this.su_tPos = this.data.tt[this.su_tPos]; + this.su_i2++; + this.currentChar = su_ch2Shadow; + this.currentState = CState.NO_RAND_PART_B; + this.crc.UpdateCRC((byte)su_ch2Shadow); + } + else + { + this.currentState = CState.NO_RAND_PART_A; + EndBlock(); + InitBlock(); + SetupBlock(); + } + } + + private void SetupRandPartB() + { + if (this.su_ch2 != this.su_chPrev) + { + this.currentState = CState.RAND_PART_A; + this.su_count = 1; + SetupRandPartA(); + } + else if (++this.su_count >= 4) + { + this.su_z = (char) (this.data.ll8[this.su_tPos] & 0xff); + this.su_tPos = this.data.tt[this.su_tPos]; + if (this.su_rNToGo == 0) + { + this.su_rNToGo = Rand.Rnums(this.su_rTPos) - 1; + if (++this.su_rTPos == 512) + { + this.su_rTPos = 0; + } + } + else + { + this.su_rNToGo--; + } + this.su_j2 = 0; + this.currentState = CState.RAND_PART_C; + if (this.su_rNToGo == 1) + { + this.su_z ^= (char)1; + } + SetupRandPartC(); + } + else + { + this.currentState = CState.RAND_PART_A; + SetupRandPartA(); + } + } + + private void SetupRandPartC() + { + if (this.su_j2 < this.su_z) + { + this.currentChar = this.su_ch2; + this.crc.UpdateCRC((byte)this.su_ch2); + this.su_j2++; + } + else + { + this.currentState = CState.RAND_PART_A; + this.su_i2++; + this.su_count = 0; + SetupRandPartA(); + } + } + + private void SetupNoRandPartB() + { + if (this.su_ch2 != this.su_chPrev) + { + this.su_count = 1; + SetupNoRandPartA(); + } + else if (++this.su_count >= 4) + { + this.su_z = (char) (this.data.ll8[this.su_tPos] & 0xff); + this.su_tPos = this.data.tt[this.su_tPos]; + this.su_j2 = 0; + SetupNoRandPartC(); + } + else + { + SetupNoRandPartA(); + } + } + + private void SetupNoRandPartC() + { + if (this.su_j2 < this.su_z) + { + int su_ch2Shadow = this.su_ch2; + this.currentChar = su_ch2Shadow; + this.crc.UpdateCRC((byte)su_ch2Shadow); + this.su_j2++; + this.currentState = CState.NO_RAND_PART_C; + } + else + { + this.su_i2++; + this.su_count = 0; + SetupNoRandPartA(); + } + } + + private sealed class DecompressionState + { + // (with blockSize 900k) + readonly public bool[] inUse = new bool[256]; + readonly public byte[] seqToUnseq = new byte[256]; // 256 byte + readonly public byte[] selector = new byte[BZip2.MaxSelectors]; // 18002 byte + readonly public byte[] selectorMtf = new byte[BZip2.MaxSelectors]; // 18002 byte + + /** + * Freq table collected to save a pass over the data during + * decompression. + */ + public readonly int[] unzftab; + public readonly int[][] gLimit; + public readonly int[][] gBase; + public readonly int[][] gPerm; + public readonly int[] gMinlen; + + public readonly int[] cftab; + public readonly byte[] getAndMoveToFrontDecode_yy; + public readonly char[][] temp_charArray2d; + public readonly byte[] recvDecodingTables_pos; + // --------------- + // 60798 byte + + public int[] tt; // 3600000 byte + public byte[] ll8; // 900000 byte + + // --------------- + // 4560782 byte + // =============== + + public DecompressionState(int blockSize100k) + { + this.unzftab = new int[256]; // 1024 byte + + this.gLimit = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + this.gBase = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + this.gPerm = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + this.gMinlen = new int[BZip2.NGroups]; // 24 byte + + this.cftab = new int[257]; // 1028 byte + this.getAndMoveToFrontDecode_yy = new byte[256]; // 512 byte + this.temp_charArray2d = BZip2.InitRectangularArray(BZip2.NGroups,BZip2.MaxAlphaSize); + this.recvDecodingTables_pos = new byte[BZip2.NGroups]; // 6 byte + + this.ll8 = new byte[blockSize100k * BZip2.BlockSizeMultiple]; + } + + /** + * Initializes the tt array. + * + * This method is called when the required length of the array is known. + * I don't initialize it at construction time to avoid unneccessary + * memory allocation when compressing small files. + */ + public int[] initTT(int length) + { + int[] ttShadow = this.tt; + + // tt.length should always be >= length, but theoretically + // it can happen, if the compressor mixed small and large + // blocks. Normally only the last block will be smaller + // than others. + if ((ttShadow == null) || (ttShadow.Length < length)) + { + this.tt = ttShadow = new int[length]; + } + + return ttShadow; + } + } + + + } + + // /** + // * Checks if the signature matches what is expected for a bzip2 file. + // * + // * @param signature + // * the bytes to check + // * @param length + // * the number of bytes to check + // * @return true, if this stream is a bzip2 compressed stream, false otherwise + // * + // * @since Apache Commons Compress 1.1 + // */ + // public static boolean MatchesSig(byte[] signature) + // { + // if ((signature.Length < 3) || + // (signature[0] != 'B') || + // (signature[1] != 'Z') || + // (signature[2] != 'h')) + // return false; + // + // return true; + // } + + + internal static class BZip2 + { + internal static T[][] InitRectangularArray(int d1, int d2) + { + var x = new T[d1][]; + for (int i=0; i < d1; i++) + { + x[i] = new T[d2]; + } + return x; + } + + public static readonly int BlockSizeMultiple = 100000; + public static readonly int MinBlockSize = 1; + public static readonly int MaxBlockSize = 9; + public static readonly int MaxAlphaSize = 258; + public static readonly int MaxCodeLength = 23; + public static readonly char RUNA = (char) 0; + public static readonly char RUNB = (char) 1; + public static readonly int NGroups = 6; + public static readonly int G_SIZE = 50; + public static readonly int N_ITERS = 4; + public static readonly int MaxSelectors = (2 + (900000 / G_SIZE)); + public static readonly int NUM_OVERSHOOT_BYTES = 20; + /* + *

If you are ever unlucky/improbable enough to get a stack + * overflow whilst sorting, increase the following constant and + * try again. In practice I have never seen the stack go above 27 + * elems, so the following limit seems very generous.

+ */ + internal static readonly int QSORT_STACK_SIZE = 1000; + + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/BZip2/BZip2OutputStream.cs b/Resources/Libraries/DotNetZip/Source/BZip2/BZip2OutputStream.cs new file mode 100644 index 00000000..74dce3ca --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/BZip2/BZip2OutputStream.cs @@ -0,0 +1,530 @@ +//#define Trace + +// BZip2OutputStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-August-02 16:44:11> +// +// ------------------------------------------------------------------ +// +// This module defines the BZip2OutputStream class, which is a +// compressing stream that handles BZIP2. This code may have been +// derived in part from Apache commons source code. The license below +// applies to the original Apache code. +// +// ------------------------------------------------------------------ +// flymake: csc.exe /t:module BZip2InputStream.cs BZip2Compressor.cs Rand.cs BCRC32.cs @@FILE@@ + +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + + +// Design Notes: +// +// This class follows the classic Decorator pattern: it is a Stream that +// wraps itself around a Stream, and in doing so provides bzip2 +// compression as callers Write into it. +// +// BZip2 is a straightforward data format: there are 4 magic bytes at +// the top of the file, followed by 1 or more compressed blocks. There +// is a small "magic byte" trailer after all compressed blocks. This +// class emits the magic bytes for the header and trailer, and relies on +// a BZip2Compressor to generate each of the compressed data blocks. +// +// BZip2 does byte-shredding - it uses partial fractions of bytes to +// represent independent pieces of information. This class relies on the +// BitWriter to adapt the bit-oriented BZip2 output to the byte-oriented +// model of the .NET Stream class. +// +// ---- +// +// Regarding the Apache code base: Most of the code in this particular +// class is related to stream operations, and is my own code. It largely +// does not rely on any code obtained from Apache commons. If you +// compare this code with the Apache commons BZip2OutputStream, you will +// see very little code that is common, except for the +// nearly-boilerplate structure that is common to all subtypes of +// System.IO.Stream. There may be some small remnants of code in this +// module derived from the Apache stuff, which is why I left the license +// in here. Most of the Apache commons compressor magic has been ported +// into the BZip2Compressor class. +// + +using System; +using System.IO; + + +namespace Ionic.BZip2 +{ + /// + /// A write-only decorator stream that compresses data as it is + /// written using the BZip2 algorithm. + /// + public class BZip2OutputStream : System.IO.Stream + { + int totalBytesWrittenIn; + bool leaveOpen; + BZip2Compressor compressor; + uint combinedCRC; + Stream output; + BitWriter bw; + int blockSize100k; // 0...9 + + private TraceBits desiredTrace = TraceBits.Crc | TraceBits.Write; + + /// + /// Constructs a new BZip2OutputStream, that sends its + /// compressed output to the given output stream. + /// + /// + /// + /// The destination stream, to which compressed output will be sent. + /// + /// + /// + /// + /// This example reads a file, then compresses it with bzip2 file, + /// and writes the compressed data into a newly created file. + /// + /// + /// var fname = "logfile.log"; + /// using (var fs = File.OpenRead(fname)) + /// { + /// var outFname = fname + ".bz2"; + /// using (var output = File.Create(outFname)) + /// { + /// using (var compressor = new Ionic.BZip2.BZip2OutputStream(output)) + /// { + /// byte[] buffer = new byte[2048]; + /// int n; + /// while ((n = fs.Read(buffer, 0, buffer.Length)) > 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + public BZip2OutputStream(Stream output) + : this(output, BZip2.MaxBlockSize, false) + { + } + + + /// + /// Constructs a new BZip2OutputStream with specified blocksize. + /// + /// the destination stream. + /// + /// The blockSize in units of 100000 bytes. + /// The valid range is 1..9. + /// + public BZip2OutputStream(Stream output, int blockSize) + : this(output, blockSize, false) + { + } + + + /// + /// Constructs a new BZip2OutputStream. + /// + /// the destination stream. + /// + /// whether to leave the captive stream open upon closing this stream. + /// + public BZip2OutputStream(Stream output, bool leaveOpen) + : this(output, BZip2.MaxBlockSize, leaveOpen) + { + } + + + /// + /// Constructs a new BZip2OutputStream with specified blocksize, + /// and explicitly specifies whether to leave the wrapped stream open. + /// + /// + /// the destination stream. + /// + /// The blockSize in units of 100000 bytes. + /// The valid range is 1..9. + /// + /// + /// whether to leave the captive stream open upon closing this stream. + /// + public BZip2OutputStream(Stream output, int blockSize, bool leaveOpen) + { + if (blockSize < BZip2.MinBlockSize || + blockSize > BZip2.MaxBlockSize) + { + var msg = String.Format("blockSize={0} is out of range; must be between {1} and {2}", + blockSize, + BZip2.MinBlockSize, BZip2.MaxBlockSize); + throw new ArgumentException(msg, "blockSize"); + } + + this.output = output; + if (!this.output.CanWrite) + throw new ArgumentException("The stream is not writable.", "output"); + + this.bw = new BitWriter(this.output); + this.blockSize100k = blockSize; + this.compressor = new BZip2Compressor(this.bw, blockSize); + this.leaveOpen = leaveOpen; + this.combinedCRC = 0; + EmitHeader(); + } + + + + + /// + /// Close the stream. + /// + /// + /// + /// This may or may not close the underlying stream. Check the + /// constructors that accept a bool value. + /// + /// + public override void Close() + { + if (output != null) + { + Stream o = this.output; + Finish(); + if (!leaveOpen) + o.Close(); + } + } + + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (this.output != null) + { + this.bw.Flush(); + this.output.Flush(); + } + } + + private void EmitHeader() + { + var magic = new byte[] { + (byte) 'B', + (byte) 'Z', + (byte) 'h', + (byte) ('0' + this.blockSize100k) + }; + + // not necessary to shred the initial magic bytes + this.output.Write(magic, 0, magic.Length); + } + + private void EmitTrailer() + { + // A magic 48-bit number, 0x177245385090, to indicate the end + // of the last block. (sqrt(pi), if you want to know) + + TraceOutput(TraceBits.Write, "total written out: {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut); + + // must shred + this.bw.WriteByte(0x17); + this.bw.WriteByte(0x72); + this.bw.WriteByte(0x45); + this.bw.WriteByte(0x38); + this.bw.WriteByte(0x50); + this.bw.WriteByte(0x90); + + this.bw.WriteInt(this.combinedCRC); + + this.bw.FinishAndPad(); + + TraceOutput(TraceBits.Write, "final total: {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut); + } + + void Finish() + { + // Console.WriteLine("BZip2:Finish"); + + try + { + var totalBefore = this.bw.TotalBytesWrittenOut; + this.compressor.CompressAndWrite(); + TraceOutput(TraceBits.Write,"out block length (bytes): {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut - totalBefore); + + TraceOutput(TraceBits.Crc, " combined CRC (before): {0:X8}", + this.combinedCRC); + this.combinedCRC = (this.combinedCRC << 1) | (this.combinedCRC >> 31); + this.combinedCRC ^= (uint) compressor.Crc32; + TraceOutput(TraceBits.Crc, " block CRC : {0:X8}", + this.compressor.Crc32); + TraceOutput(TraceBits.Crc, " combined CRC (final) : {0:X8}", + this.combinedCRC); + + EmitTrailer(); + } + finally + { + this.output = null; + this.compressor = null; + this.bw = null; + } + } + + + /// + /// The blocksize parameter specified at construction time. + /// + public int BlockSize + { + get { return this.blockSize100k; } + } + + + /// + /// Write data to the stream. + /// + /// + /// + /// + /// Use the BZip2OutputStream to compress data while writing: + /// create a BZip2OutputStream with a writable output stream. + /// Then call Write() on that BZip2OutputStream, providing + /// uncompressed data as input. The data sent to the output stream will + /// be the compressed form of the input data. + /// + /// + /// + /// A BZip2OutputStream can be used only for Write() not for Read(). + /// + /// + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + if (offset < 0) + throw new IndexOutOfRangeException(String.Format("offset ({0}) must be > 0", offset)); + if (count < 0) + throw new IndexOutOfRangeException(String.Format("count ({0}) must be > 0", count)); + if (offset + count > buffer.Length) + throw new IndexOutOfRangeException(String.Format("offset({0}) count({1}) bLength({2})", + offset, count, buffer.Length)); + if (this.output == null) + throw new IOException("the stream is not open"); + + if (count == 0) return; // nothing to do + + int bytesWritten = 0; + int bytesRemaining = count; + + do + { + int n = compressor.Fill(buffer, offset, bytesRemaining); + if (n != bytesRemaining) + { + // The compressor data block is full. Compress and + // write out the compressed data, then reset the + // compressor and continue. + + var totalBefore = this.bw.TotalBytesWrittenOut; + this.compressor.CompressAndWrite(); + TraceOutput(TraceBits.Write,"out block length (bytes): {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut - totalBefore); + + // and now any remaining bits + TraceOutput(TraceBits.Write, + " remaining: {0} 0x{1:X}", + this.bw.NumRemainingBits, + this.bw.RemainingBits); + + TraceOutput(TraceBits.Crc, " combined CRC (before): {0:X8}", + this.combinedCRC); + this.combinedCRC = (this.combinedCRC << 1) | (this.combinedCRC >> 31); + this.combinedCRC ^= (uint) compressor.Crc32; + TraceOutput(TraceBits.Crc, " block CRC : {0:X8}", + compressor.Crc32); + TraceOutput(TraceBits.Crc, " combined CRC (after) : {0:X8}", + this.combinedCRC); + offset += n; + } + bytesRemaining -= n; + bytesWritten += n; + } while (bytesRemaining > 0); + + totalBytesWrittenIn += bytesWritten; + } + + + + + /// + /// Indicates whether the stream can be read. + /// + /// + /// The return value is always false. + /// + public override bool CanRead + { + get { return false; } + } + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + /// + /// Indicates whether the stream can be written. + /// + /// + /// The return value should always be true, unless and until the + /// object is disposed and closed. + /// + public override bool CanWrite + { + get + { + if (this.output == null) throw new ObjectDisposedException("BZip2Stream"); + return this.output.CanWrite; + } + } + + /// + /// Reading this property always throws a . + /// + public override long Length + { + get { throw new NotImplementedException(); } + } + + /// + /// The position of the stream pointer. + /// + /// + /// + /// Setting this property always throws a . Reading will return the + /// total number of uncompressed bytes written through. + /// + public override long Position + { + get + { + return this.totalBytesWrittenIn; + } + set { throw new NotImplementedException(); } + } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + /// this is irrelevant, since it will always throw! + /// irrelevant! + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this parameter is never used + /// this parameter is never used + /// this parameter is never used + /// never returns anything; always throws + public override int Read(byte[] buffer, int offset, int count) + { + throw new NotImplementedException(); + } + + + // used only when Trace is defined + [Flags] + enum TraceBits : uint + { + None = 0, + Crc = 1, + Write = 2, + All = 0xffffffff, + } + + + [System.Diagnostics.ConditionalAttribute("Trace")] + private void TraceOutput(TraceBits bits, string format, params object[] varParams) + { + if ((bits & this.desiredTrace) != 0) + { + //lock(outputLock) + { + int tid = System.Threading.Thread.CurrentThread.GetHashCode(); +#if !SILVERLIGHT && !NETCF + Console.ForegroundColor = (ConsoleColor) (tid % 8 + 10); +#endif + Console.Write("{0:000} PBOS ", tid); + Console.WriteLine(format, varParams); +#if !SILVERLIGHT && !NETCF + Console.ResetColor(); +#endif + } + } + } + + + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/BZip2/BitWriter.cs b/Resources/Libraries/DotNetZip/Source/BZip2/BitWriter.cs new file mode 100644 index 00000000..55cc36c3 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/BZip2/BitWriter.cs @@ -0,0 +1,248 @@ +// BitWriter.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-July-25 18:57:31> +// +// ------------------------------------------------------------------ +// +// This module defines the BitWriter class, which writes bits at a time +// to an output stream. It's used by the BZip2Compressor class, and by +// the BZip2OutputStream class and its parallel variant, +// ParallelBZip2OutputStream. +// +// ------------------------------------------------------------------ + +// +// Design notes: +// +// BZip2 employs byte-shredding in its data format - rather than +// aligning all data items in a compressed .bz2 file on byte barriers, +// the BZip2 format uses portions of bytes to represent independent +// pieces of information. This "shredding" starts with the first +// "randomised" bit - just 12 bytes or so into a bz2 file or stream. But +// the approach is used extensively in bzip2 files - sometimes 5 bits +// are used, sometimes 24 or 3 bits, sometimes just 1 bit, and so on. +// It's not possible to send this information directly to a stream in +// this form; Streams in .NET accept byte-oriented input. Therefore, +// when actually writing a bz2 file, the output data must be organized +// into a byte-aligned format before being written to the output stream. +// +// This BitWriter class provides the byte-shredding necessary for BZip2 +// output. Think of this class as an Adapter that enables Bit-oriented +// output to a standard byte-oriented .NET stream. This class writes +// data out to the captive output stream only after the data bits have +// been accumulated and aligned. For example, suppose that during +// operation, the BZip2 compressor emits 5 bits, then 24 bits, then 32 +// bits. When the first 5 bits are sent to the BitWriter, nothing is +// written to the output stream; instead these 5 bits are simply stored +// in the internal accumulator. When the next 24 bits are written, the +// first 3 bits are gathered with the accumulated bits. The resulting +// 5+3 constitutes an entire byte; the BitWriter then actually writes +// that byte to the output stream. This leaves 21 bits. BitWriter writes +// 2 more whole bytes (16 more bits), in 8-bit chunks, leaving 5 in the +// accumulator. BitWriter then follows the same procedure with the 32 +// new bits. And so on. +// +// A quick tour of the implementation: +// +// The accumulator is a uint - so it can accumulate at most 4 bytes of +// information. In practice because of the design of this class, it +// never accumulates more than 3 bytes. +// +// The Flush() method emits all whole bytes available. After calling +// Flush(), there may be between 0-7 bits yet to be emitted into the +// output stream. +// +// FinishAndPad() emits all data, including the last partial byte and +// any necessary padding. In effect, it establishes a byte-alignment +// barrier. To support bzip2, FinishAndPad() should be called only once +// for a bz2 file, after the last bit of data has been written through +// this adapter. Other binary file formats may use byte-alignment at +// various points within the file, and FinishAndPad() would support that +// scenario. +// +// The internal fn Reset() is used to reset the state of the adapter; +// this class is used by BZip2Compressor, instances of which get re-used +// by multiple distinct threads, for different blocks of data. +// + + +using System; +using System.IO; + +namespace Ionic.BZip2 +{ + + internal class BitWriter + { + uint accumulator; + int nAccumulatedBits; + Stream output; + int totalBytesWrittenOut; + + public BitWriter(Stream s) + { + this.output = s; + } + + /// + /// Delivers the remaining bits, left-aligned, in a byte. + /// + /// + /// + /// This is valid only if NumRemainingBits is less than 8; + /// in other words it is valid only after a call to Flush(). + /// + /// + public byte RemainingBits + { + get + { + return (byte) (this.accumulator >> (32 - this.nAccumulatedBits) & 0xff); + } + } + + public int NumRemainingBits + { + get + { + return this.nAccumulatedBits; + } + } + + public int TotalBytesWrittenOut + { + get + { + return this.totalBytesWrittenOut; + } + } + + /// + /// Reset the BitWriter. + /// + /// + /// + /// This is useful when the BitWriter writes into a MemoryStream, and + /// is used by a BZip2Compressor, which itself is re-used for multiple + /// distinct data blocks. + /// + /// + public void Reset() + { + this.accumulator = 0; + this.nAccumulatedBits = 0; + this.totalBytesWrittenOut = 0; + this.output.Seek(0, SeekOrigin.Begin); + this.output.SetLength(0); + } + + /// + /// Write some number of bits from the given value, into the output. + /// + /// + /// + /// The nbits value should be a max of 25, for safety. For performance + /// reasons, this method does not check! + /// + /// + public void WriteBits(int nbits, uint value) + { + int nAccumulated = this.nAccumulatedBits; + uint u = this.accumulator; + + while (nAccumulated >= 8) + { + this.output.WriteByte ((byte)(u >> 24 & 0xff)); + this.totalBytesWrittenOut++; + u <<= 8; + nAccumulated -= 8; + } + + this.accumulator = u | (value << (32 - nAccumulated - nbits)); + this.nAccumulatedBits = nAccumulated + nbits; + + // Console.WriteLine("WriteBits({0}, 0x{1:X2}) => {2:X8} n({3})", + // nbits, value, accumulator, nAccumulatedBits); + // Console.ReadLine(); + + // At this point the accumulator may contain up to 31 bits waiting for + // output. + } + + + /// + /// Write a full 8-bit byte into the output. + /// + public void WriteByte(byte b) + { + WriteBits(8, b); + } + + /// + /// Write four 8-bit bytes into the output. + /// + public void WriteInt(uint u) + { + WriteBits(8, (u >> 24) & 0xff); + WriteBits(8, (u >> 16) & 0xff); + WriteBits(8, (u >> 8) & 0xff); + WriteBits(8, u & 0xff); + } + + /// + /// Write all available byte-aligned bytes. + /// + /// + /// + /// This method writes no new output, but flushes any accumulated + /// bits. At completion, the accumulator may contain up to 7 + /// bits. + /// + /// + /// This is necessary when re-assembling output from N independent + /// compressors, one for each of N blocks. The output of any + /// particular compressor will in general have some fragment of a byte + /// remaining. This fragment needs to be accumulated into the + /// parent BZip2OutputStream. + /// + /// + public void Flush() + { + WriteBits(0,0); + } + + + /// + /// Writes all available bytes, and emits padding for the final byte as + /// necessary. This must be the last method invoked on an instance of + /// BitWriter. + /// + public void FinishAndPad() + { + Flush(); + + if (this.NumRemainingBits > 0) + { + byte b = (byte)((this.accumulator >> 24) & 0xff); + this.output.WriteByte(b); + this.totalBytesWrittenOut++; + } + } + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/BZip2/ParallelBZip2OutputStream.cs b/Resources/Libraries/DotNetZip/Source/BZip2/ParallelBZip2OutputStream.cs new file mode 100644 index 00000000..b6f241f6 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/BZip2/ParallelBZip2OutputStream.cs @@ -0,0 +1,999 @@ +//#define Trace + +// ParallelBZip2OutputStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-August-02 16:44:24> +// +// ------------------------------------------------------------------ +// +// This module defines the ParallelBZip2OutputStream class, which is a +// BZip2 compressing stream. This code was derived in part from Apache +// commons source code. The license below applies to the original Apache +// code. +// +// ------------------------------------------------------------------ +// flymake: csc.exe /t:module BZip2InputStream.cs BZip2Compressor.cs Rand.cs BCRC32.cs @@FILE@@ + + +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, + * software distributed under the License is distributed on an + * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY + * KIND, either express or implied. See the License for the + * specific language governing permissions and limitations + * under the License. + */ + + +// Design Notes: +// +// This class follows the classic Decorator pattern: it is a Stream that +// wraps itself around a Stream, and in doing so provides bzip2 +// compression as callers Write into it. It is exactly the same in +// outward function as the BZip2OutputStream, except that this class can +// perform compression using multiple independent threads. Because of +// that, and because of the CPU-intensive nature of BZip2 compression, +// this class can perform significantly better (in terms of wall-click +// time) than the single-threaded variant, at the expense of memory and +// CPU utilization. +// +// BZip2 is a straightforward data format: there are 4 magic bytes at +// the top of the file, followed by 1 or more compressed blocks. There +// is a small "magic byte" trailer after all compressed blocks. +// +// In concept parallelizing BZip2 is simple: do the CPU-intensive +// compression for each block in a separate thread, then emit the +// compressed output, in order, to the output stream. Each block can be +// compressed independently, so a block is the natural candidate for the +// parcel of work that can be passed to an independent worker thread. +// +// The design approach used here is simple: within the Write() method of +// the stream, fill a block. When the block is full, pass it to a +// background worker thread for compression. When the compressor thread +// completes its work, the main thread (the application thread that +// calls Write()) can send the compressed data to the output stream, +// being careful to respect the order of the compressed blocks. +// +// The challenge of ordering the compressed data is a solved and +// well-understood problem - it is the same approach here as DotNetZip +// uses in the ParallelDeflateOutputStream. It is a map/reduce approach +// in design intent. +// +// One new twist for BZip2 is that the compressor output is not +// byte-aligned. In other words the final output of a compressed block +// will in general be a number of bits that is not a multiple of +// 8. Therefore, combining the ordered results of the N compressor +// threads requires additional byte-shredding by the parent +// stream. Hence this stream uses a BitWriter to adapt bit-oriented +// BZip2 output to the byte-oriented .NET Stream. +// +// The approach used here creates N instances of the BZip2Compressor +// type, where N is governed by the number of cores (cpus) and limited +// by the MaxWorkers property exposed by this class. Each +// BZip2Compressor instance gets its own MemoryStream, to which it +// writes its data, via a BitWriter. +// +// along with the bit accumulator described above. The MemoryStream +// would gather the byte-aligned compressed output of the compressor. + +// When reducing the output of the various workers, this class must +// again do the byte-shredding thing. The data from the compressors is +// therefore shredded twice: once when being placed into the +// MemoryStream, and again when emitted into the final output stream +// that this class decorates. This is an unfortunate and seemingly +// unavoidable inefficiency. Two rounds of byte-shredding will use more +// CPU than we'd like, but I haven't imagined a way to avoid it. +// +// The BZip2Compressor is designed to write directly into the parent +// stream's accumulator (BitWriter) when possible, and write into a +// distinct BitWriter when necessary. The former can be used in a +// single-thread scenario, while the latter is required in a +// multi-thread scenario. +// +// ---- +// +// Regarding the Apache code base: Most of the code in this particular +// class is related to stream operations and thread synchronization, and +// is my own code. It largely does not rely on any code obtained from +// Apache commons. If you compare this code with the Apache commons +// BZip2OutputStream, you will see very little code that is common, +// except for the nearly-boilerplate structure that is common to all +// subtypes of System.IO.Stream. There may be some small remnants of +// code in this module derived from the Apache stuff, which is why I +// left the license in here. Most of the Apache commons compressor magic +// has been ported into the BZip2Compressor class. +// + +using System; +using System.IO; +using System.Collections.Generic; +using System.Threading; + +namespace Ionic.BZip2 +{ + internal class WorkItem + { + public int index; + public BZip2Compressor Compressor { get; private set; } + public MemoryStream ms; + public int ordinal; + public BitWriter bw; + + public WorkItem(int ix, int blockSize) + { + // compressed data gets written to a MemoryStream + this.ms = new MemoryStream(); + this.bw = new BitWriter(ms); + this.Compressor = new BZip2Compressor(bw, blockSize); + this.index = ix; + } + } + + + /// + /// A write-only decorator stream that compresses data as it is + /// written using the BZip2 algorithm. This stream compresses by + /// block using multiple threads. + /// + /// + /// This class performs BZIP2 compression through writing. For + /// more information on the BZIP2 algorithm, see + /// . + /// + /// + /// + /// This class is similar to , + /// except that this implementation uses an approach that employs multiple + /// worker threads to perform the compression. On a multi-cpu or multi-core + /// computer, the performance of this class can be significantly higher than + /// the single-threaded BZip2OutputStream, particularly for larger streams. + /// How large? Anything over 10mb is a good candidate for parallel + /// compression. + /// + /// + /// + /// The tradeoff is that this class uses more memory and more CPU than the + /// vanilla BZip2OutputStream. Also, for small files, the + /// ParallelBZip2OutputStream can be much slower than the vanilla + /// BZip2OutputStream, because of the overhead associated to using the + /// thread pool. + /// + /// + /// + public class ParallelBZip2OutputStream : System.IO.Stream + { + private static readonly int BufferPairsPerCore = 4; + private int _maxWorkers; + private bool firstWriteDone; + private int lastFilled; + private int lastWritten; + private int latestCompressed; + private int currentlyFilling; + private volatile Exception pendingException; + private bool handlingException; + private bool emitting; + private System.Collections.Generic.Queue toWrite; + private System.Collections.Generic.Queue toFill; + private System.Collections.Generic.List pool; + private object latestLock = new object(); + private object eLock = new object(); // for exceptions + private object outputLock = new object(); // for multi-thread output + private AutoResetEvent newlyCompressedBlob; + + long totalBytesWrittenIn; + long totalBytesWrittenOut; + bool leaveOpen; + uint combinedCRC; + Stream output; + BitWriter bw; + int blockSize100k; // 0...9 + + private TraceBits desiredTrace = TraceBits.Crc | TraceBits.Write; + + /// + /// Constructs a new ParallelBZip2OutputStream, that sends its + /// compressed output to the given output stream. + /// + /// + /// + /// The destination stream, to which compressed output will be sent. + /// + /// + /// + /// + /// This example reads a file, then compresses it with bzip2 file, + /// and writes the compressed data into a newly created file. + /// + /// + /// var fname = "logfile.log"; + /// using (var fs = File.OpenRead(fname)) + /// { + /// var outFname = fname + ".bz2"; + /// using (var output = File.Create(outFname)) + /// { + /// using (var compressor = new Ionic.BZip2.ParallelBZip2OutputStream(output)) + /// { + /// byte[] buffer = new byte[2048]; + /// int n; + /// while ((n = fs.Read(buffer, 0, buffer.Length)) > 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + public ParallelBZip2OutputStream(Stream output) + : this(output, BZip2.MaxBlockSize, false) + { + } + + /// + /// Constructs a new ParallelBZip2OutputStream with specified blocksize. + /// + /// the destination stream. + /// + /// The blockSize in units of 100000 bytes. + /// The valid range is 1..9. + /// + public ParallelBZip2OutputStream(Stream output, int blockSize) + : this(output, blockSize, false) + { + } + + /// + /// Constructs a new ParallelBZip2OutputStream. + /// + /// the destination stream. + /// + /// whether to leave the captive stream open upon closing this stream. + /// + public ParallelBZip2OutputStream(Stream output, bool leaveOpen) + : this(output, BZip2.MaxBlockSize, leaveOpen) + { + } + + /// + /// Constructs a new ParallelBZip2OutputStream with specified blocksize, + /// and explicitly specifies whether to leave the wrapped stream open. + /// + /// + /// the destination stream. + /// + /// The blockSize in units of 100000 bytes. + /// The valid range is 1..9. + /// + /// + /// whether to leave the captive stream open upon closing this stream. + /// + public ParallelBZip2OutputStream(Stream output, int blockSize, bool leaveOpen) + { + if (blockSize < BZip2.MinBlockSize || blockSize > BZip2.MaxBlockSize) + { + var msg = String.Format("blockSize={0} is out of range; must be between {1} and {2}", + blockSize, + BZip2.MinBlockSize, BZip2.MaxBlockSize); + throw new ArgumentException(msg, "blockSize"); + } + + this.output = output; + if (!this.output.CanWrite) + throw new ArgumentException("The stream is not writable.", "output"); + + this.bw = new BitWriter(this.output); + this.blockSize100k = blockSize; + this.leaveOpen = leaveOpen; + this.combinedCRC = 0; + this.MaxWorkers = 16; // default + EmitHeader(); + } + + + private void InitializePoolOfWorkItems() + { + this.toWrite = new Queue(); + this.toFill = new Queue(); + this.pool = new System.Collections.Generic.List(); + int nWorkers = BufferPairsPerCore * Environment.ProcessorCount; + nWorkers = Math.Min(nWorkers, this.MaxWorkers); + for(int i=0; i < nWorkers; i++) + { + this.pool.Add(new WorkItem(i, this.blockSize100k)); + this.toFill.Enqueue(i); + } + + this.newlyCompressedBlob = new AutoResetEvent(false); + this.currentlyFilling = -1; + this.lastFilled = -1; + this.lastWritten = -1; + this.latestCompressed = -1; + } + + + /// + /// The maximum number of concurrent compression worker threads to use. + /// + /// + /// + /// + /// This property sets an upper limit on the number of concurrent worker + /// threads to employ for compression. The implementation of this stream + /// employs multiple threads from the .NET thread pool, via + /// ThreadPool.QueueUserWorkItem(), to compress the incoming data by + /// block. As each block of data is compressed, this stream re-orders the + /// compressed blocks and writes them to the output stream. + /// + /// + /// + /// A higher number of workers enables a higher degree of + /// parallelism, which tends to increase the speed of compression on + /// multi-cpu computers. On the other hand, a higher number of buffer + /// pairs also implies a larger memory consumption, more active worker + /// threads, and a higher cpu utilization for any compression. This + /// property enables the application to limit its memory consumption and + /// CPU utilization behavior depending on requirements. + /// + /// + /// + /// By default, DotNetZip allocates 4 workers per CPU core, subject to the + /// upper limit specified in this property. For example, suppose the + /// application sets this property to 16. Then, on a machine with 2 + /// cores, DotNetZip will use 8 workers; that number does not exceed the + /// upper limit specified by this property, so the actual number of + /// workers used will be 4 * 2 = 8. On a machine with 4 cores, DotNetZip + /// will use 16 workers; again, the limit does not apply. On a machine + /// with 8 cores, DotNetZip will use 16 workers, because of the limit. + /// + /// + /// + /// For each compression "worker thread" that occurs in parallel, there is + /// up to 2mb of memory allocated, for buffering and processing. The + /// actual number depends on the property. + /// + /// + /// + /// CPU utilization will also go up with additional workers, because a + /// larger number of buffer pairs allows a larger number of background + /// threads to compress in parallel. If you find that parallel + /// compression is consuming too much memory or CPU, you can adjust this + /// value downward. + /// + /// + /// + /// The default value is 16. Different values may deliver better or + /// worse results, depending on your priorities and the dynamic + /// performance characteristics of your storage and compute resources. + /// + /// + /// + /// The application can set this value at any time, but it is effective + /// only before the first call to Write(), which is when the buffers are + /// allocated. + /// + /// + public int MaxWorkers + { + get + { + return _maxWorkers; + } + set + { + if (value < 4) + throw new ArgumentException("MaxWorkers", + "Value must be 4 or greater."); + _maxWorkers = value; + } + } + + /// + /// Close the stream. + /// + /// + /// + /// This may or may not close the underlying stream. Check the + /// constructors that accept a bool value. + /// + /// + public override void Close() + { + if (this.pendingException != null) + { + this.handlingException = true; + var pe = this.pendingException; + this.pendingException = null; + throw pe; + } + + if (this.handlingException) + return; + + if (output == null) + return; + + Stream o = this.output; + + try + { + FlushOutput(true); + } + finally + { + this.output = null; + this.bw = null; + } + + if (!leaveOpen) + o.Close(); + } + + + private void FlushOutput(bool lastInput) + { + if (this.emitting) return; + + // compress and write whatever is ready + if (this.currentlyFilling >= 0) + { + WorkItem workitem = this.pool[this.currentlyFilling]; + CompressOne(workitem); + this.currentlyFilling = -1; // get a new buffer next Write() + } + + if (lastInput) + { + EmitPendingBuffers(true, false); + EmitTrailer(); + } + else + { + EmitPendingBuffers(false, false); + } + } + + + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (this.output != null) + { + FlushOutput(false); + this.bw.Flush(); + this.output.Flush(); + } + } + + private void EmitHeader() + { + var magic = new byte[] { + (byte) 'B', + (byte) 'Z', + (byte) 'h', + (byte) ('0' + this.blockSize100k) + }; + + // not necessary to shred the initial magic bytes + this.output.Write(magic, 0, magic.Length); + } + + private void EmitTrailer() + { + // A magic 48-bit number, 0x177245385090, to indicate the end + // of the last block. (sqrt(pi), if you want to know) + + TraceOutput(TraceBits.Write, "total written out: {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut); + + // must shred + this.bw.WriteByte(0x17); + this.bw.WriteByte(0x72); + this.bw.WriteByte(0x45); + this.bw.WriteByte(0x38); + this.bw.WriteByte(0x50); + this.bw.WriteByte(0x90); + + this.bw.WriteInt(this.combinedCRC); + + this.bw.FinishAndPad(); + + TraceOutput(TraceBits.Write, "final total : {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut); + } + + + /// + /// The blocksize parameter specified at construction time. + /// + public int BlockSize + { + get { return this.blockSize100k; } + } + + + /// + /// Write data to the stream. + /// + /// + /// + /// + /// Use the ParallelBZip2OutputStream to compress data while + /// writing: create a ParallelBZip2OutputStream with a writable + /// output stream. Then call Write() on that + /// ParallelBZip2OutputStream, providing uncompressed data as + /// input. The data sent to the output stream will be the compressed + /// form of the input data. + /// + /// + /// + /// A ParallelBZip2OutputStream can be used only for + /// Write() not for Read(). + /// + /// + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + bool mustWait = false; + + // This method does this: + // 0. handles any pending exceptions + // 1. write any buffers that are ready to be written + // 2. fills a compressor buffer; when full, flip state to 'Filled', + // 3. if more data to be written, goto step 1 + + if (this.output == null) + throw new IOException("the stream is not open"); + + // dispense any exceptions that occurred on the BG threads + if (this.pendingException != null) + { + this.handlingException = true; + var pe = this.pendingException; + this.pendingException = null; + throw pe; + } + + if (offset < 0) + throw new IndexOutOfRangeException(String.Format("offset ({0}) must be > 0", offset)); + if (count < 0) + throw new IndexOutOfRangeException(String.Format("count ({0}) must be > 0", count)); + if (offset + count > buffer.Length) + throw new IndexOutOfRangeException(String.Format("offset({0}) count({1}) bLength({2})", + offset, count, buffer.Length)); + + + if (count == 0) return; // nothing to do + + + if (!this.firstWriteDone) + { + // Want to do this on first Write, first session, and not in the + // constructor. Must allow the MaxWorkers to change after + // construction, but before first Write(). + InitializePoolOfWorkItems(); + this.firstWriteDone = true; + } + + int bytesWritten = 0; + int bytesRemaining = count; + + do + { + // may need to make buffers available + EmitPendingBuffers(false, mustWait); + + mustWait = false; + + // get a compressor to fill + int ix = -1; + if (this.currentlyFilling >= 0) + { + ix = this.currentlyFilling; + } + else + { + if (this.toFill.Count == 0) + { + // No compressors available to fill, so... need to emit + // compressed buffers. + mustWait = true; + continue; + } + + ix = this.toFill.Dequeue(); + ++this.lastFilled; + } + + WorkItem workitem = this.pool[ix]; + workitem.ordinal = this.lastFilled; + + int n = workitem.Compressor.Fill(buffer, offset, bytesRemaining); + if (n != bytesRemaining) + { + if (!ThreadPool.QueueUserWorkItem( CompressOne, workitem )) + throw new Exception("Cannot enqueue workitem"); + + this.currentlyFilling = -1; // will get a new buffer next time + offset += n; + } + else + this.currentlyFilling = ix; + + bytesRemaining -= n; + bytesWritten += n; + } + while (bytesRemaining > 0); + + totalBytesWrittenIn += bytesWritten; + return; + } + + + + private void EmitPendingBuffers(bool doAll, bool mustWait) + { + // When combining parallel compression with a ZipSegmentedStream, it's + // possible for the ZSS to throw from within this method. In that + // case, Close/Dispose will be called on this stream, if this stream + // is employed within a using or try/finally pair as required. But + // this stream is unaware of the pending exception, so the Close() + // method invokes this method AGAIN. This can lead to a deadlock. + // Therefore, failfast if re-entering. + + if (emitting) return; + emitting = true; + + if (doAll || mustWait) + this.newlyCompressedBlob.WaitOne(); + + do + { + int firstSkip = -1; + int millisecondsToWait = doAll ? 200 : (mustWait ? -1 : 0); + int nextToWrite = -1; + + do + { + if (Monitor.TryEnter(this.toWrite, millisecondsToWait)) + { + nextToWrite = -1; + try + { + if (this.toWrite.Count > 0) + nextToWrite = this.toWrite.Dequeue(); + } + finally + { + Monitor.Exit(this.toWrite); + } + + if (nextToWrite >= 0) + { + WorkItem workitem = this.pool[nextToWrite]; + if (workitem.ordinal != this.lastWritten + 1) + { + // out of order. requeue and try again. + lock(this.toWrite) + { + this.toWrite.Enqueue(nextToWrite); + } + + if (firstSkip == nextToWrite) + { + // We went around the list once. + // None of the items in the list is the one we want. + // Now wait for a compressor to signal again. + this.newlyCompressedBlob.WaitOne(); + firstSkip = -1; + } + else if (firstSkip == -1) + firstSkip = nextToWrite; + + continue; + } + + firstSkip = -1; + + TraceOutput(TraceBits.Write, + "Writing block {0}", workitem.ordinal); + + // write the data to the output + var bw2 = workitem.bw; + bw2.Flush(); // not bw2.FinishAndPad()! + var ms = workitem.ms; + ms.Seek(0,SeekOrigin.Begin); + + // cannot dump bytes!! + // ms.WriteTo(this.output); + // + // must do byte shredding: + int n; + int y = -1; + long totOut = 0; + var buffer = new byte[1024]; + while ((n = ms.Read(buffer,0,buffer.Length)) > 0) + { +#if Trace + if (y == -1) // diagnostics only + { + var sb1 = new System.Text.StringBuilder(); + sb1.Append("first 16 whole bytes in block: "); + for (int z=0; z < 16; z++) + sb1.Append(String.Format(" {0:X2}", buffer[z])); + TraceOutput(TraceBits.Write, sb1.ToString()); + } +#endif + y = n; + for (int k=0; k < n; k++) + { + this.bw.WriteByte(buffer[k]); + } + totOut += n; + } +#if Trace + TraceOutput(TraceBits.Write,"out block length (bytes): {0} (0x{0:X})", totOut); + var sb = new System.Text.StringBuilder(); + sb.Append("final 16 whole bytes in block: "); + for (int z=0; z < 16; z++) + sb.Append(String.Format(" {0:X2}", buffer[y-1-12+z])); + TraceOutput(TraceBits.Write, sb.ToString()); +#endif + + // and now any remaining bits + TraceOutput(TraceBits.Write, + " remaining bits: {0} 0x{1:X}", + bw2.NumRemainingBits, + bw2.RemainingBits); + if (bw2.NumRemainingBits > 0) + { + this.bw.WriteBits(bw2.NumRemainingBits, bw2.RemainingBits); + } + + TraceOutput(TraceBits.Crc," combined CRC (before): {0:X8}", + this.combinedCRC); + this.combinedCRC = (this.combinedCRC << 1) | (this.combinedCRC >> 31); + this.combinedCRC ^= (uint) workitem.Compressor.Crc32; + + TraceOutput(TraceBits.Crc, + " block CRC : {0:X8}", + workitem.Compressor.Crc32); + TraceOutput(TraceBits.Crc, + " combined CRC (after) : {0:X8}", + this.combinedCRC); + TraceOutput(TraceBits.Write, + "total written out: {0} (0x{0:X})", + this.bw.TotalBytesWrittenOut); + TraceOutput(TraceBits.Write | TraceBits.Crc, ""); + + this.totalBytesWrittenOut += totOut; + + bw2.Reset(); + this.lastWritten = workitem.ordinal; + workitem.ordinal = -1; + this.toFill.Enqueue(workitem.index); + + // don't wait next time through + if (millisecondsToWait == -1) millisecondsToWait = 0; + } + } + else + nextToWrite = -1; + + } while (nextToWrite >= 0); + + } while (doAll && (this.lastWritten != this.latestCompressed)); + + if (doAll) + { + TraceOutput(TraceBits.Crc, + " combined CRC (final) : {0:X8}", this.combinedCRC); + } + + emitting = false; + } + + + private void CompressOne(Object wi) + { + // compress and one buffer + WorkItem workitem = (WorkItem) wi; + try + { + // compress and write to the compressor's MemoryStream + workitem.Compressor.CompressAndWrite(); + + lock(this.latestLock) + { + if (workitem.ordinal > this.latestCompressed) + this.latestCompressed = workitem.ordinal; + } + lock (this.toWrite) + { + this.toWrite.Enqueue(workitem.index); + } + this.newlyCompressedBlob.Set(); + } + catch (System.Exception exc1) + { + lock(this.eLock) + { + // expose the exception to the main thread + if (this.pendingException!=null) + this.pendingException = exc1; + } + } + } + + + + + /// + /// Indicates whether the stream can be read. + /// + /// + /// The return value is always false. + /// + public override bool CanRead + { + get { return false; } + } + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + /// + /// Indicates whether the stream can be written. + /// + /// + /// The return value depends on whether the captive stream supports writing. + /// + public override bool CanWrite + { + get + { + if (this.output == null) throw new ObjectDisposedException("BZip2Stream"); + return this.output.CanWrite; + } + } + + /// + /// Reading this property always throws a . + /// + public override long Length + { + get { throw new NotImplementedException(); } + } + + /// + /// The position of the stream pointer. + /// + /// + /// + /// Setting this property always throws a . Reading will return the + /// total number of uncompressed bytes written through. + /// + public override long Position + { + get + { + return this.totalBytesWrittenIn; + } + set { throw new NotImplementedException(); } + } + + /// + /// The total number of bytes written out by the stream. + /// + /// + /// This value is meaningful only after a call to Close(). + /// + public Int64 BytesWrittenOut { get { return totalBytesWrittenOut; } } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + /// this is irrelevant, since it will always throw! + /// irrelevant! + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this parameter is never used + /// this parameter is never used + /// this parameter is never used + /// never returns anything; always throws + public override int Read(byte[] buffer, int offset, int count) + { + throw new NotImplementedException(); + } + + + // used only when Trace is defined + [Flags] + enum TraceBits : uint + { + None = 0, + Crc = 1, + Write = 2, + All = 0xffffffff, + } + + + [System.Diagnostics.ConditionalAttribute("Trace")] + private void TraceOutput(TraceBits bits, string format, params object[] varParams) + { + if ((bits & this.desiredTrace) != 0) + { + lock(outputLock) + { + int tid = Thread.CurrentThread.GetHashCode(); +#if !SILVERLIGHT + Console.ForegroundColor = (ConsoleColor) (tid % 8 + 10); +#endif + Console.Write("{0:000} PBOS ", tid); + Console.WriteLine(format, varParams); +#if !SILVERLIGHT + Console.ResetColor(); +#endif + } + } + } + + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/BZip2/Rand.cs b/Resources/Libraries/DotNetZip/Source/BZip2/Rand.cs new file mode 100644 index 00000000..08169dbd --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/BZip2/Rand.cs @@ -0,0 +1,99 @@ +// Rand.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-July-31 15:09:16> +// +// ------------------------------------------------------------------ +// +// This module defines a helper class for the BZip2 classes. This code +// is derived from the original BZip2 source code. +// +// ------------------------------------------------------------------ + + +namespace Ionic.BZip2 +{ + internal static class Rand + { + private static int[] RNUMS = + { + 619, 720, 127, 481, 931, 816, 813, 233, 566, 247, + 985, 724, 205, 454, 863, 491, 741, 242, 949, 214, + 733, 859, 335, 708, 621, 574, 73, 654, 730, 472, + 419, 436, 278, 496, 867, 210, 399, 680, 480, 51, + 878, 465, 811, 169, 869, 675, 611, 697, 867, 561, + 862, 687, 507, 283, 482, 129, 807, 591, 733, 623, + 150, 238, 59, 379, 684, 877, 625, 169, 643, 105, + 170, 607, 520, 932, 727, 476, 693, 425, 174, 647, + 73, 122, 335, 530, 442, 853, 695, 249, 445, 515, + 909, 545, 703, 919, 874, 474, 882, 500, 594, 612, + 641, 801, 220, 162, 819, 984, 589, 513, 495, 799, + 161, 604, 958, 533, 221, 400, 386, 867, 600, 782, + 382, 596, 414, 171, 516, 375, 682, 485, 911, 276, + 98, 553, 163, 354, 666, 933, 424, 341, 533, 870, + 227, 730, 475, 186, 263, 647, 537, 686, 600, 224, + 469, 68, 770, 919, 190, 373, 294, 822, 808, 206, + 184, 943, 795, 384, 383, 461, 404, 758, 839, 887, + 715, 67, 618, 276, 204, 918, 873, 777, 604, 560, + 951, 160, 578, 722, 79, 804, 96, 409, 713, 940, + 652, 934, 970, 447, 318, 353, 859, 672, 112, 785, + 645, 863, 803, 350, 139, 93, 354, 99, 820, 908, + 609, 772, 154, 274, 580, 184, 79, 626, 630, 742, + 653, 282, 762, 623, 680, 81, 927, 626, 789, 125, + 411, 521, 938, 300, 821, 78, 343, 175, 128, 250, + 170, 774, 972, 275, 999, 639, 495, 78, 352, 126, + 857, 956, 358, 619, 580, 124, 737, 594, 701, 612, + 669, 112, 134, 694, 363, 992, 809, 743, 168, 974, + 944, 375, 748, 52, 600, 747, 642, 182, 862, 81, + 344, 805, 988, 739, 511, 655, 814, 334, 249, 515, + 897, 955, 664, 981, 649, 113, 974, 459, 893, 228, + 433, 837, 553, 268, 926, 240, 102, 654, 459, 51, + 686, 754, 806, 760, 493, 403, 415, 394, 687, 700, + 946, 670, 656, 610, 738, 392, 760, 799, 887, 653, + 978, 321, 576, 617, 626, 502, 894, 679, 243, 440, + 680, 879, 194, 572, 640, 724, 926, 56, 204, 700, + 707, 151, 457, 449, 797, 195, 791, 558, 945, 679, + 297, 59, 87, 824, 713, 663, 412, 693, 342, 606, + 134, 108, 571, 364, 631, 212, 174, 643, 304, 329, + 343, 97, 430, 751, 497, 314, 983, 374, 822, 928, + 140, 206, 73, 263, 980, 736, 876, 478, 430, 305, + 170, 514, 364, 692, 829, 82, 855, 953, 676, 246, + 369, 970, 294, 750, 807, 827, 150, 790, 288, 923, + 804, 378, 215, 828, 592, 281, 565, 555, 710, 82, + 896, 831, 547, 261, 524, 462, 293, 465, 502, 56, + 661, 821, 976, 991, 658, 869, 905, 758, 745, 193, + 768, 550, 608, 933, 378, 286, 215, 979, 792, 961, + 61, 688, 793, 644, 986, 403, 106, 366, 905, 644, + 372, 567, 466, 434, 645, 210, 389, 550, 919, 135, + 780, 773, 635, 389, 707, 100, 626, 958, 165, 504, + 920, 176, 193, 713, 857, 265, 203, 50, 668, 108, + 645, 990, 626, 197, 510, 357, 358, 850, 858, 364, + 936, 638 + }; + + + /// + /// Returns the "random" number at a specific index. + /// + /// the index + /// the random number + internal static int Rnums(int i) + { + return RNUMS[i]; + } + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/CommonSrc/CRC32.cs b/Resources/Libraries/DotNetZip/Source/CommonSrc/CRC32.cs new file mode 100644 index 00000000..53a4fa37 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/CommonSrc/CRC32.cs @@ -0,0 +1,814 @@ +// CRC32.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-August-02 18:25:54> +// +// ------------------------------------------------------------------ +// +// This module defines the CRC32 class, which can do the CRC32 algorithm, using +// arbitrary starting polynomials, and bit reversal. The bit reversal is what +// distinguishes this CRC-32 used in BZip2 from the CRC-32 that is used in PKZIP +// files, or GZIP files. This class does both. +// +// ------------------------------------------------------------------ + + +using System; +using Interop = System.Runtime.InteropServices; + +namespace Ionic.Crc +{ + /// + /// Computes a CRC-32. The CRC-32 algorithm is parameterized - you + /// can set the polynomial and enable or disable bit + /// reversal. This can be used for GZIP, BZip2, or ZIP. + /// + /// + /// This type is used internally by DotNetZip; it is generally not used + /// directly by applications wishing to create, read, or manipulate zip + /// archive files. + /// + + [Interop.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d0000C")] + [Interop.ComVisible(true)] +#if !NETCF + [Interop.ClassInterface(Interop.ClassInterfaceType.AutoDispatch)] +#endif + public class CRC32 + { + /// + /// Indicates the total number of bytes applied to the CRC. + /// + public Int64 TotalBytesRead + { + get + { + return _TotalBytesRead; + } + } + + /// + /// Indicates the current CRC for all blocks slurped in. + /// + public Int32 Crc32Result + { + get + { + return unchecked((Int32)(~_register)); + } + } + + /// + /// Returns the CRC32 for the specified stream. + /// + /// The stream over which to calculate the CRC32 + /// the CRC32 calculation + public Int32 GetCrc32(System.IO.Stream input) + { + return GetCrc32AndCopy(input, null); + } + + /// + /// Returns the CRC32 for the specified stream, and writes the input into the + /// output stream. + /// + /// The stream over which to calculate the CRC32 + /// The stream into which to deflate the input + /// the CRC32 calculation + public Int32 GetCrc32AndCopy(System.IO.Stream input, System.IO.Stream output) + { + if (input == null) + throw new Exception("The input stream must not be null."); + + unchecked + { + byte[] buffer = new byte[BUFFER_SIZE]; + int readSize = BUFFER_SIZE; + + _TotalBytesRead = 0; + int count = input.Read(buffer, 0, readSize); + if (output != null) output.Write(buffer, 0, count); + _TotalBytesRead += count; + while (count > 0) + { + SlurpBlock(buffer, 0, count); + count = input.Read(buffer, 0, readSize); + if (output != null) output.Write(buffer, 0, count); + _TotalBytesRead += count; + } + + return (Int32)(~_register); + } + } + + + /// + /// Get the CRC32 for the given (word,byte) combo. This is a + /// computation defined by PKzip for PKZIP 2.0 (weak) encryption. + /// + /// The word to start with. + /// The byte to combine it with. + /// The CRC-ized result. + public Int32 ComputeCrc32(Int32 W, byte B) + { + return _InternalComputeCrc32((UInt32)W, B); + } + + internal Int32 _InternalComputeCrc32(UInt32 W, byte B) + { + return (Int32)(crc32Table[(W ^ B) & 0xFF] ^ (W >> 8)); + } + + + /// + /// Update the value for the running CRC32 using the given block of bytes. + /// This is useful when using the CRC32() class in a Stream. + /// + /// block of bytes to slurp + /// starting point in the block + /// how many bytes within the block to slurp + public void SlurpBlock(byte[] block, int offset, int count) + { + if (block == null) + throw new Exception("The data buffer must not be null."); + + // bzip algorithm + for (int i = 0; i < count; i++) + { + int x = offset + i; + byte b = block[x]; + if (this.reverseBits) + { + UInt32 temp = (_register >> 24) ^ b; + _register = (_register << 8) ^ crc32Table[temp]; + } + else + { + UInt32 temp = (_register & 0x000000FF) ^ b; + _register = (_register >> 8) ^ crc32Table[temp]; + } + } + _TotalBytesRead += count; + } + + + /// + /// Process one byte in the CRC. + /// + /// the byte to include into the CRC . + public void UpdateCRC(byte b) + { + if (this.reverseBits) + { + UInt32 temp = (_register >> 24) ^ b; + _register = (_register << 8) ^ crc32Table[temp]; + } + else + { + UInt32 temp = (_register & 0x000000FF) ^ b; + _register = (_register >> 8) ^ crc32Table[temp]; + } + } + + /// + /// Process a run of N identical bytes into the CRC. + /// + /// + /// + /// This method serves as an optimization for updating the CRC when a + /// run of identical bytes is found. Rather than passing in a buffer of + /// length n, containing all identical bytes b, this method accepts the + /// byte value and the length of the (virtual) buffer - the length of + /// the run. + /// + /// + /// the byte to include into the CRC. + /// the number of times that byte should be repeated. + public void UpdateCRC(byte b, int n) + { + while (n-- > 0) + { + if (this.reverseBits) + { + uint temp = (_register >> 24) ^ b; + _register = (_register << 8) ^ crc32Table[(temp >= 0) + ? temp + : (temp + 256)]; + } + else + { + UInt32 temp = (_register & 0x000000FF) ^ b; + _register = (_register >> 8) ^ crc32Table[(temp >= 0) + ? temp + : (temp + 256)]; + + } + } + } + + + + private static uint ReverseBits(uint data) + { + unchecked + { + uint ret = data; + ret = (ret & 0x55555555) << 1 | (ret >> 1) & 0x55555555; + ret = (ret & 0x33333333) << 2 | (ret >> 2) & 0x33333333; + ret = (ret & 0x0F0F0F0F) << 4 | (ret >> 4) & 0x0F0F0F0F; + ret = (ret << 24) | ((ret & 0xFF00) << 8) | ((ret >> 8) & 0xFF00) | (ret >> 24); + return ret; + } + } + + private static byte ReverseBits(byte data) + { + unchecked + { + uint u = (uint)data * 0x00020202; + uint m = 0x01044010; + uint s = u & m; + uint t = (u << 2) & (m << 1); + return (byte)((0x01001001 * (s + t)) >> 24); + } + } + + + + private void GenerateLookupTable() + { + crc32Table = new UInt32[256]; + unchecked + { + UInt32 dwCrc; + byte i = 0; + do + { + dwCrc = i; + for (byte j = 8; j > 0; j--) + { + if ((dwCrc & 1) == 1) + { + dwCrc = (dwCrc >> 1) ^ dwPolynomial; + } + else + { + dwCrc >>= 1; + } + } + if (reverseBits) + { + crc32Table[ReverseBits(i)] = ReverseBits(dwCrc); + } + else + { + crc32Table[i] = dwCrc; + } + i++; + } while (i!=0); + } + +#if VERBOSE + Console.WriteLine(); + Console.WriteLine("private static readonly UInt32[] crc32Table = {"); + for (int i = 0; i < crc32Table.Length; i+=4) + { + Console.Write(" "); + for (int j=0; j < 4; j++) + { + Console.Write(" 0x{0:X8}U,", crc32Table[i+j]); + } + Console.WriteLine(); + } + Console.WriteLine("};"); + Console.WriteLine(); +#endif + } + + + private uint gf2_matrix_times(uint[] matrix, uint vec) + { + uint sum = 0; + int i=0; + while (vec != 0) + { + if ((vec & 0x01)== 0x01) + sum ^= matrix[i]; + vec >>= 1; + i++; + } + return sum; + } + + private void gf2_matrix_square(uint[] square, uint[] mat) + { + for (int i = 0; i < 32; i++) + square[i] = gf2_matrix_times(mat, mat[i]); + } + + + + /// + /// Combines the given CRC32 value with the current running total. + /// + /// + /// This is useful when using a divide-and-conquer approach to + /// calculating a CRC. Multiple threads can each calculate a + /// CRC32 on a segment of the data, and then combine the + /// individual CRC32 values at the end. + /// + /// the crc value to be combined with this one + /// the length of data the CRC value was calculated on + public void Combine(int crc, int length) + { + uint[] even = new uint[32]; // even-power-of-two zeros operator + uint[] odd = new uint[32]; // odd-power-of-two zeros operator + + if (length == 0) + return; + + uint crc1= ~_register; + uint crc2= (uint) crc; + + // put operator for one zero bit in odd + odd[0] = this.dwPolynomial; // the CRC-32 polynomial + uint row = 1; + for (int i = 1; i < 32; i++) + { + odd[i] = row; + row <<= 1; + } + + // put operator for two zero bits in even + gf2_matrix_square(even, odd); + + // put operator for four zero bits in odd + gf2_matrix_square(odd, even); + + uint len2 = (uint) length; + + // apply len2 zeros to crc1 (first square will put the operator for one + // zero byte, eight zero bits, in even) + do { + // apply zeros operator for this bit of len2 + gf2_matrix_square(even, odd); + + if ((len2 & 1)== 1) + crc1 = gf2_matrix_times(even, crc1); + len2 >>= 1; + + if (len2 == 0) + break; + + // another iteration of the loop with odd and even swapped + gf2_matrix_square(odd, even); + if ((len2 & 1)==1) + crc1 = gf2_matrix_times(odd, crc1); + len2 >>= 1; + + + } while (len2 != 0); + + crc1 ^= crc2; + + _register= ~crc1; + + //return (int) crc1; + return; + } + + + /// + /// Create an instance of the CRC32 class using the default settings: no + /// bit reversal, and a polynomial of 0xEDB88320. + /// + public CRC32() : this(false) + { + } + + /// + /// Create an instance of the CRC32 class, specifying whether to reverse + /// data bits or not. + /// + /// + /// specify true if the instance should reverse data bits. + /// + /// + /// + /// In the CRC-32 used by BZip2, the bits are reversed. Therefore if you + /// want a CRC32 with compatibility with BZip2, you should pass true + /// here. In the CRC-32 used by GZIP and PKZIP, the bits are not + /// reversed; Therefore if you want a CRC32 with compatibility with + /// those, you should pass false. + /// + /// + public CRC32(bool reverseBits) : + this( unchecked((int)0xEDB88320), reverseBits) + { + } + + + /// + /// Create an instance of the CRC32 class, specifying the polynomial and + /// whether to reverse data bits or not. + /// + /// + /// The polynomial to use for the CRC, expressed in the reversed (LSB) + /// format: the highest ordered bit in the polynomial value is the + /// coefficient of the 0th power; the second-highest order bit is the + /// coefficient of the 1 power, and so on. Expressed this way, the + /// polynomial for the CRC-32C used in IEEE 802.3, is 0xEDB88320. + /// + /// + /// specify true if the instance should reverse data bits. + /// + /// + /// + /// + /// In the CRC-32 used by BZip2, the bits are reversed. Therefore if you + /// want a CRC32 with compatibility with BZip2, you should pass true + /// here for the reverseBits parameter. In the CRC-32 used by + /// GZIP and PKZIP, the bits are not reversed; Therefore if you want a + /// CRC32 with compatibility with those, you should pass false for the + /// reverseBits parameter. + /// + /// + public CRC32(int polynomial, bool reverseBits) + { + this.reverseBits = reverseBits; + this.dwPolynomial = (uint) polynomial; + this.GenerateLookupTable(); + } + + /// + /// Reset the CRC-32 class - clear the CRC "remainder register." + /// + /// + /// + /// Use this when employing a single instance of this class to compute + /// multiple, distinct CRCs on multiple, distinct data blocks. + /// + /// + public void Reset() + { + _register = 0xFFFFFFFFU; + } + + // private member vars + private UInt32 dwPolynomial; + private Int64 _TotalBytesRead; + private bool reverseBits; + private UInt32[] crc32Table; + private const int BUFFER_SIZE = 8192; + private UInt32 _register = 0xFFFFFFFFU; + } + + + /// + /// A Stream that calculates a CRC32 (a checksum) on all bytes read, + /// or on all bytes written. + /// + /// + /// + /// + /// This class can be used to verify the CRC of a ZipEntry when + /// reading from a stream, or to calculate a CRC when writing to a + /// stream. The stream should be used to either read, or write, but + /// not both. If you intermix reads and writes, the results are not + /// defined. + /// + /// + /// + /// This class is intended primarily for use internally by the + /// DotNetZip library. + /// + /// + public class CrcCalculatorStream : System.IO.Stream, System.IDisposable + { + private static readonly Int64 UnsetLengthLimit = -99; + + internal System.IO.Stream _innerStream; + private CRC32 _Crc32; + private Int64 _lengthLimit = -99; + private bool _leaveOpen; + + /// + /// The default constructor. + /// + /// + /// + /// Instances returned from this constructor will leave the underlying + /// stream open upon Close(). The stream uses the default CRC32 + /// algorithm, which implies a polynomial of 0xEDB88320. + /// + /// + /// The underlying stream + public CrcCalculatorStream(System.IO.Stream stream) + : this(true, CrcCalculatorStream.UnsetLengthLimit, stream, null) + { + } + + /// + /// The constructor allows the caller to specify how to handle the + /// underlying stream at close. + /// + /// + /// + /// The stream uses the default CRC32 algorithm, which implies a + /// polynomial of 0xEDB88320. + /// + /// + /// The underlying stream + /// true to leave the underlying stream + /// open upon close of the CrcCalculatorStream; false otherwise. + public CrcCalculatorStream(System.IO.Stream stream, bool leaveOpen) + : this(leaveOpen, CrcCalculatorStream.UnsetLengthLimit, stream, null) + { + } + + /// + /// A constructor allowing the specification of the length of the stream + /// to read. + /// + /// + /// + /// The stream uses the default CRC32 algorithm, which implies a + /// polynomial of 0xEDB88320. + /// + /// + /// Instances returned from this constructor will leave the underlying + /// stream open upon Close(). + /// + /// + /// The underlying stream + /// The length of the stream to slurp + public CrcCalculatorStream(System.IO.Stream stream, Int64 length) + : this(true, length, stream, null) + { + if (length < 0) + throw new ArgumentException("length"); + } + + /// + /// A constructor allowing the specification of the length of the stream + /// to read, as well as whether to keep the underlying stream open upon + /// Close(). + /// + /// + /// + /// The stream uses the default CRC32 algorithm, which implies a + /// polynomial of 0xEDB88320. + /// + /// + /// The underlying stream + /// The length of the stream to slurp + /// true to leave the underlying stream + /// open upon close of the CrcCalculatorStream; false otherwise. + public CrcCalculatorStream(System.IO.Stream stream, Int64 length, bool leaveOpen) + : this(leaveOpen, length, stream, null) + { + if (length < 0) + throw new ArgumentException("length"); + } + + /// + /// A constructor allowing the specification of the length of the stream + /// to read, as well as whether to keep the underlying stream open upon + /// Close(), and the CRC32 instance to use. + /// + /// + /// + /// The stream uses the specified CRC32 instance, which allows the + /// application to specify how the CRC gets calculated. + /// + /// + /// The underlying stream + /// The length of the stream to slurp + /// true to leave the underlying stream + /// open upon close of the CrcCalculatorStream; false otherwise. + /// the CRC32 instance to use to calculate the CRC32 + public CrcCalculatorStream(System.IO.Stream stream, Int64 length, bool leaveOpen, + CRC32 crc32) + : this(leaveOpen, length, stream, crc32) + { + if (length < 0) + throw new ArgumentException("length"); + } + + + // This ctor is private - no validation is done here. This is to allow the use + // of a (specific) negative value for the _lengthLimit, to indicate that there + // is no length set. So we validate the length limit in those ctors that use an + // explicit param, otherwise we don't validate, because it could be our special + // value. + private CrcCalculatorStream + (bool leaveOpen, Int64 length, System.IO.Stream stream, CRC32 crc32) + : base() + { + _innerStream = stream; + _Crc32 = crc32 ?? new CRC32(); + _lengthLimit = length; + _leaveOpen = leaveOpen; + } + + + /// + /// Gets the total number of bytes run through the CRC32 calculator. + /// + /// + /// + /// This is either the total number of bytes read, or the total number of + /// bytes written, depending on the direction of this stream. + /// + public Int64 TotalBytesSlurped + { + get { return _Crc32.TotalBytesRead; } + } + + /// + /// Provides the current CRC for all blocks slurped in. + /// + /// + /// + /// The running total of the CRC is kept as data is written or read + /// through the stream. read this property after all reads or writes to + /// get an accurate CRC for the entire stream. + /// + /// + public Int32 Crc + { + get { return _Crc32.Crc32Result; } + } + + /// + /// Indicates whether the underlying stream will be left open when the + /// CrcCalculatorStream is Closed. + /// + /// + /// + /// Set this at any point before calling . + /// + /// + public bool LeaveOpen + { + get { return _leaveOpen; } + set { _leaveOpen = value; } + } + + /// + /// Read from the stream + /// + /// the buffer to read + /// the offset at which to start + /// the number of bytes to read + /// the number of bytes actually read + public override int Read(byte[] buffer, int offset, int count) + { + int bytesToRead = count; + + // Need to limit the # of bytes returned, if the stream is intended to have + // a definite length. This is especially useful when returning a stream for + // the uncompressed data directly to the application. The app won't + // necessarily read only the UncompressedSize number of bytes. For example + // wrapping the stream returned from OpenReader() into a StreadReader() and + // calling ReadToEnd() on it, We can "over-read" the zip data and get a + // corrupt string. The length limits that, prevents that problem. + + if (_lengthLimit != CrcCalculatorStream.UnsetLengthLimit) + { + if (_Crc32.TotalBytesRead >= _lengthLimit) return 0; // EOF + Int64 bytesRemaining = _lengthLimit - _Crc32.TotalBytesRead; + if (bytesRemaining < count) bytesToRead = (int)bytesRemaining; + } + int n = _innerStream.Read(buffer, offset, bytesToRead); + if (n > 0) _Crc32.SlurpBlock(buffer, offset, n); + return n; + } + + /// + /// Write to the stream. + /// + /// the buffer from which to write + /// the offset at which to start writing + /// the number of bytes to write + public override void Write(byte[] buffer, int offset, int count) + { + if (count > 0) _Crc32.SlurpBlock(buffer, offset, count); + _innerStream.Write(buffer, offset, count); + } + + /// + /// Indicates whether the stream supports reading. + /// + public override bool CanRead + { + get { return _innerStream.CanRead; } + } + + /// + /// Indicates whether the stream supports seeking. + /// + /// + /// + /// Always returns false. + /// + /// + public override bool CanSeek + { + get { return false; } + } + + /// + /// Indicates whether the stream supports writing. + /// + public override bool CanWrite + { + get { return _innerStream.CanWrite; } + } + + /// + /// Flush the stream. + /// + public override void Flush() + { + _innerStream.Flush(); + } + + /// + /// Returns the length of the underlying stream. + /// + public override long Length + { + get + { + if (_lengthLimit == CrcCalculatorStream.UnsetLengthLimit) + return _innerStream.Length; + else return _lengthLimit; + } + } + + /// + /// The getter for this property returns the total bytes read. + /// If you use the setter, it will throw + /// . + /// + public override long Position + { + get { return _Crc32.TotalBytesRead; } + set { throw new NotSupportedException(); } + } + + /// + /// Seeking is not supported on this stream. This method always throws + /// + /// + /// N/A + /// N/A + /// N/A + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotSupportedException(); + } + + /// + /// This method always throws + /// + /// + /// N/A + public override void SetLength(long value) + { + throw new NotSupportedException(); + } + + + void IDisposable.Dispose() + { + Close(); + } + + /// + /// Closes the stream. + /// + public override void Close() + { + base.Close(); + if (!_leaveOpen) + _innerStream.Close(); + } + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ComHelper.cs b/Resources/Libraries/DotNetZip/Source/Zip/ComHelper.cs new file mode 100644 index 00000000..ccc20c8d --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ComHelper.cs @@ -0,0 +1,116 @@ +// ComHelper.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-June-13 17:04:06> +// +// ------------------------------------------------------------------ +// +// This module defines a COM Helper class. +// +// Created: Tue, 08 Sep 2009 22:03 +// + +using Interop=System.Runtime.InteropServices; + +namespace Ionic.Zip +{ + /// + /// This class exposes a set of COM-accessible wrappers for static + /// methods available on the ZipFile class. You don't need this + /// class unless you are using DotNetZip from a COM environment. + /// + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d0000F")] + [System.Runtime.InteropServices.ComVisible(true)] +#if !NETCF + [System.Runtime.InteropServices.ClassInterface(System.Runtime.InteropServices.ClassInterfaceType.AutoDispatch)] +#endif + + public class ComHelper + { + /// + /// A wrapper for ZipFile.IsZipFile(string) + /// + /// The filename to of the zip file to check. + /// true if the file contains a valid zip file. + public bool IsZipFile(string filename) + { + return ZipFile.IsZipFile(filename); + } + + /// + /// A wrapper for ZipFile.IsZipFile(string, bool) + /// + /// + /// We cannot use "overloaded" Method names in COM interop. + /// So, here, we use a unique name. + /// + /// The filename to of the zip file to check. + /// true if the file contains a valid zip file. + public bool IsZipFileWithExtract(string filename) + { + return ZipFile.IsZipFile(filename, true); + } + +#if !NETCF + /// + /// A wrapper for ZipFile.CheckZip(string) + /// + /// The filename to of the zip file to check. + /// + /// true if the named zip file checks OK. Otherwise, false. + public bool CheckZip(string filename) + { + return ZipFile.CheckZip(filename); + } + + /// + /// A COM-friendly wrapper for the static method . + /// + /// + /// The filename to of the zip file to check. + /// + /// The password to check. + /// + /// true if the named zip file checks OK. Otherwise, false. + public bool CheckZipPassword(string filename, string password) + { + return ZipFile.CheckZipPassword(filename, password); + } + + /// + /// A wrapper for ZipFile.FixZipDirectory(string) + /// + /// The filename to of the zip file to fix. + public void FixZipDirectory(string filename) + { + ZipFile.FixZipDirectory(filename); + } +#endif + + /// + /// A wrapper for ZipFile.LibraryVersion + /// + /// + /// the version number on the DotNetZip assembly, formatted as a string. + /// + public string GetZipLibraryVersion() + { + return ZipFile.LibraryVersion.ToString(); + } + + } +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/EncryptionAlgorithm.cs b/Resources/Libraries/DotNetZip/Source/Zip/EncryptionAlgorithm.cs new file mode 100644 index 00000000..391a8026 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/EncryptionAlgorithm.cs @@ -0,0 +1,135 @@ +// EncryptionAlgorithm.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-October-21 17:24:45> +// +// ------------------------------------------------------------------ +// +// This module defines the EncryptionAgorithm enum +// +// +// ------------------------------------------------------------------ + + +namespace Ionic.Zip +{ + /// + /// An enum that provides the various encryption algorithms supported by this + /// library. + /// + /// + /// + /// + /// + /// PkzipWeak implies the use of Zip 2.0 encryption, which is known to be + /// weak and subvertible. + /// + /// + /// + /// A note on interoperability: Values of PkzipWeak and None are + /// specified in PKWARE's zip + /// specification, and are considered to be "standard". Zip archives + /// produced using these options will be interoperable with many other zip tools + /// and libraries, including Windows Explorer. + /// + /// + /// + /// Values of WinZipAes128 and WinZipAes256 are not part of the Zip + /// specification, but rather imply the use of a vendor-specific extension from + /// WinZip. If you want to produce interoperable Zip archives, do not use these + /// values. For example, if you produce a zip archive using WinZipAes256, you + /// will be able to open it in Windows Explorer on Windows XP and Vista, but you + /// will not be able to extract entries; trying this will lead to an "unspecified + /// error". For this reason, some people have said that a zip archive that uses + /// WinZip's AES encryption is not actually a zip archive at all. A zip archive + /// produced this way will be readable with the WinZip tool (Version 11 and + /// beyond). + /// + /// + /// + /// There are other third-party tools and libraries, both commercial and + /// otherwise, that support WinZip's AES encryption. These will be able to read + /// AES-encrypted zip archives produced by DotNetZip, and conversely applications + /// that use DotNetZip to read zip archives will be able to read AES-encrypted + /// archives produced by those tools or libraries. Consult the documentation for + /// those other tools and libraries to find out if WinZip's AES encryption is + /// supported. + /// + /// + /// + /// In case you care: According to the WinZip specification, the + /// actual AES key used is derived from the via an + /// algorithm that complies with RFC 2898, using an iteration + /// count of 1000. The algorithm is sometimes referred to as PBKDF2, which stands + /// for "Password Based Key Derivation Function #2". + /// + /// + /// + /// A word about password strength and length: The AES encryption technology is + /// very good, but any system is only as secure as the weakest link. If you want + /// to secure your data, be sure to use a password that is hard to guess. To make + /// it harder to guess (increase its "entropy"), you should make it longer. If + /// you use normal characters from an ASCII keyboard, a password of length 20 will + /// be strong enough that it will be impossible to guess. For more information on + /// that, I'd encourage you to read this + /// article. + /// + /// + /// + /// The WinZip AES algorithms are not supported with the version of DotNetZip that + /// runs on the .NET Compact Framework. This is because .NET CF lacks the + /// HMACSHA1 class that is required for producing the archive. + /// + /// + public enum EncryptionAlgorithm + { + /// + /// No encryption at all. + /// + None = 0, + + /// + /// Traditional or Classic pkzip encryption. + /// + PkzipWeak, + +#if AESCRYPTO + /// + /// WinZip AES encryption (128 key bits). + /// + WinZipAes128, + + /// + /// WinZip AES encryption (256 key bits). + /// + WinZipAes256, +#endif + + /// + /// An encryption algorithm that is not supported by DotNetZip. + /// + Unsupported = 4, + + + // others... not implemented (yet?) + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/Events.cs b/Resources/Libraries/DotNetZip/Source/Zip/Events.cs new file mode 100644 index 00000000..ad4497e0 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/Events.cs @@ -0,0 +1,684 @@ +// Events.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2006, 2007, 2008, 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-06 12:26:24> +// +// ------------------------------------------------------------------ +// +// This module defines events used by the ZipFile class. +// +// + +using System; +using System.Collections.Generic; +using System.Text; + +namespace Ionic.Zip +{ + /// + /// Delegate in which the application writes the ZipEntry content for the named entry. + /// + /// + /// The name of the entry that must be written. + /// The stream to which the entry data should be written. + /// + /// + /// When you add an entry and specify a WriteDelegate, via , the application + /// code provides the logic that writes the entry data directly into the zip file. + /// + /// + /// + /// + /// This example shows how to define a WriteDelegate that obtains a DataSet, and then + /// writes the XML for the DataSet into the zip archive. There's no need to + /// save the XML to a disk file first. + /// + /// + /// private void WriteEntry (String filename, Stream output) + /// { + /// DataSet ds1 = ObtainDataSet(); + /// ds1.WriteXml(output); + /// } + /// + /// private void Run() + /// { + /// using (var zip = new ZipFile()) + /// { + /// zip.AddEntry(zipEntryName, WriteEntry); + /// zip.Save(zipFileName); + /// } + /// } + /// + /// + /// + /// Private Sub WriteEntry (ByVal filename As String, ByVal output As Stream) + /// DataSet ds1 = ObtainDataSet() + /// ds1.WriteXml(stream) + /// End Sub + /// + /// Public Sub Run() + /// Using zip = New ZipFile + /// zip.AddEntry(zipEntryName, New WriteDelegate(AddressOf WriteEntry)) + /// zip.Save(zipFileName) + /// End Using + /// End Sub + /// + /// + /// + public delegate void WriteDelegate(string entryName, System.IO.Stream stream); + + + /// + /// Delegate in which the application opens the stream, just-in-time, for the named entry. + /// + /// + /// + /// The name of the ZipEntry that the application should open the stream for. + /// + /// + /// + /// When you add an entry via , the application code provides the logic that + /// opens and closes the stream for the given ZipEntry. + /// + /// + /// + public delegate System.IO.Stream OpenDelegate(string entryName); + + /// + /// Delegate in which the application closes the stream, just-in-time, for the named entry. + /// + /// + /// + /// The name of the ZipEntry that the application should close the stream for. + /// + /// + /// The stream to be closed. + /// + /// + /// When you add an entry via , the application code provides the logic that + /// opens and closes the stream for the given ZipEntry. + /// + /// + /// + public delegate void CloseDelegate(string entryName, System.IO.Stream stream); + + /// + /// Delegate for the callback by which the application tells the + /// library the CompressionLevel to use for a file. + /// + /// + /// + /// + /// Using this callback, the application can, for example, specify that + /// previously-compressed files (.mp3, .png, .docx, etc) should use a + /// CompressionLevel of None, or can set the compression level based + /// on any other factor. + /// + /// + /// + public delegate Ionic.Zlib.CompressionLevel SetCompressionCallback(string localFileName, string fileNameInArchive); + + /// + /// In an EventArgs type, indicates which sort of progress event is being + /// reported. + /// + /// + /// There are events for reading, events for saving, and events for + /// extracting. This enumeration allows a single EventArgs type to be sued to + /// describe one of multiple subevents. For example, a SaveProgress event is + /// invoked before, after, and during the saving of a single entry. The value + /// of an enum with this type, specifies which event is being triggered. The + /// same applies to Extraction, Reading and Adding events. + /// + public enum ZipProgressEventType + { + /// + /// Indicates that a Add() operation has started. + /// + Adding_Started, + + /// + /// Indicates that an individual entry in the archive has been added. + /// + Adding_AfterAddEntry, + + /// + /// Indicates that a Add() operation has completed. + /// + Adding_Completed, + + /// + /// Indicates that a Read() operation has started. + /// + Reading_Started, + + /// + /// Indicates that an individual entry in the archive is about to be read. + /// + Reading_BeforeReadEntry, + + /// + /// Indicates that an individual entry in the archive has just been read. + /// + Reading_AfterReadEntry, + + /// + /// Indicates that a Read() operation has completed. + /// + Reading_Completed, + + /// + /// The given event reports the number of bytes read so far + /// during a Read() operation. + /// + Reading_ArchiveBytesRead, + + /// + /// Indicates that a Save() operation has started. + /// + Saving_Started, + + /// + /// Indicates that an individual entry in the archive is about to be written. + /// + Saving_BeforeWriteEntry, + + /// + /// Indicates that an individual entry in the archive has just been saved. + /// + Saving_AfterWriteEntry, + + /// + /// Indicates that a Save() operation has completed. + /// + Saving_Completed, + + /// + /// Indicates that the zip archive has been created in a + /// temporary location during a Save() operation. + /// + Saving_AfterSaveTempArchive, + + /// + /// Indicates that the temporary file is about to be renamed to the final archive + /// name during a Save() operation. + /// + Saving_BeforeRenameTempArchive, + + /// + /// Indicates that the temporary file is has just been renamed to the final archive + /// name during a Save() operation. + /// + Saving_AfterRenameTempArchive, + + /// + /// Indicates that the self-extracting archive has been compiled + /// during a Save() operation. + /// + Saving_AfterCompileSelfExtractor, + + /// + /// The given event is reporting the number of source bytes that have run through the compressor so far + /// during a Save() operation. + /// + Saving_EntryBytesRead, + + /// + /// Indicates that an entry is about to be extracted. + /// + Extracting_BeforeExtractEntry, + + /// + /// Indicates that an entry has just been extracted. + /// + Extracting_AfterExtractEntry, + + /// + /// Indicates that extraction of an entry would overwrite an existing + /// filesystem file. You must use + /// + /// ExtractExistingFileAction.InvokeExtractProgressEvent in the call + /// to ZipEntry.Extract() in order to receive this event. + /// + Extracting_ExtractEntryWouldOverwrite, + + /// + /// The given event is reporting the number of bytes written so far for + /// the current entry during an Extract() operation. + /// + Extracting_EntryBytesWritten, + + /// + /// Indicates that an ExtractAll operation is about to begin. + /// + Extracting_BeforeExtractAll, + + /// + /// Indicates that an ExtractAll operation has completed. + /// + Extracting_AfterExtractAll, + + /// + /// Indicates that an error has occurred while saving a zip file. + /// This generally means the file cannot be opened, because it has been + /// removed, or because it is locked by another process. It can also + /// mean that the file cannot be Read, because of a range lock conflict. + /// + Error_Saving, + } + + + /// + /// Provides information about the progress of a save, read, or extract operation. + /// This is a base class; you will probably use one of the classes derived from this one. + /// + public class ZipProgressEventArgs : EventArgs + { + private int _entriesTotal; + private bool _cancel; + private ZipEntry _latestEntry; + private ZipProgressEventType _flavor; + private String _archiveName; + private Int64 _bytesTransferred; + private Int64 _totalBytesToTransfer; + + + internal ZipProgressEventArgs() { } + + internal ZipProgressEventArgs(string archiveName, ZipProgressEventType flavor) + { + this._archiveName = archiveName; + this._flavor = flavor; + } + + /// + /// The total number of entries to be saved or extracted. + /// + public int EntriesTotal + { + get { return _entriesTotal; } + set { _entriesTotal = value; } + } + + /// + /// The name of the last entry saved or extracted. + /// + public ZipEntry CurrentEntry + { + get { return _latestEntry; } + set { _latestEntry = value; } + } + + /// + /// In an event handler, set this to cancel the save or extract + /// operation that is in progress. + /// + public bool Cancel + { + get { return _cancel; } + set { _cancel = _cancel || value; } + } + + /// + /// The type of event being reported. + /// + public ZipProgressEventType EventType + { + get { return _flavor; } + set { _flavor = value; } + } + + /// + /// Returns the archive name associated to this event. + /// + public String ArchiveName + { + get { return _archiveName; } + set { _archiveName = value; } + } + + + /// + /// The number of bytes read or written so far for this entry. + /// + public Int64 BytesTransferred + { + get { return _bytesTransferred; } + set { _bytesTransferred = value; } + } + + + + /// + /// Total number of bytes that will be read or written for this entry. + /// This number will be -1 if the value cannot be determined. + /// + public Int64 TotalBytesToTransfer + { + get { return _totalBytesToTransfer; } + set { _totalBytesToTransfer = value; } + } + } + + + + /// + /// Provides information about the progress of a Read operation. + /// + public class ReadProgressEventArgs : ZipProgressEventArgs + { + + internal ReadProgressEventArgs() { } + + private ReadProgressEventArgs(string archiveName, ZipProgressEventType flavor) + : base(archiveName, flavor) + { } + + internal static ReadProgressEventArgs Before(string archiveName, int entriesTotal) + { + var x = new ReadProgressEventArgs(archiveName, ZipProgressEventType.Reading_BeforeReadEntry); + x.EntriesTotal = entriesTotal; + return x; + } + + internal static ReadProgressEventArgs After(string archiveName, ZipEntry entry, int entriesTotal) + { + var x = new ReadProgressEventArgs(archiveName, ZipProgressEventType.Reading_AfterReadEntry); + x.EntriesTotal = entriesTotal; + x.CurrentEntry = entry; + return x; + } + + internal static ReadProgressEventArgs Started(string archiveName) + { + var x = new ReadProgressEventArgs(archiveName, ZipProgressEventType.Reading_Started); + return x; + } + + internal static ReadProgressEventArgs ByteUpdate(string archiveName, ZipEntry entry, Int64 bytesXferred, Int64 totalBytes) + { + var x = new ReadProgressEventArgs(archiveName, ZipProgressEventType.Reading_ArchiveBytesRead); + x.CurrentEntry = entry; + x.BytesTransferred = bytesXferred; + x.TotalBytesToTransfer = totalBytes; + return x; + } + + internal static ReadProgressEventArgs Completed(string archiveName) + { + var x = new ReadProgressEventArgs(archiveName, ZipProgressEventType.Reading_Completed); + return x; + } + + } + + + /// + /// Provides information about the progress of a Add operation. + /// + public class AddProgressEventArgs : ZipProgressEventArgs + { + internal AddProgressEventArgs() { } + + private AddProgressEventArgs(string archiveName, ZipProgressEventType flavor) + : base(archiveName, flavor) + { } + + internal static AddProgressEventArgs AfterEntry(string archiveName, ZipEntry entry, int entriesTotal) + { + var x = new AddProgressEventArgs(archiveName, ZipProgressEventType.Adding_AfterAddEntry); + x.EntriesTotal = entriesTotal; + x.CurrentEntry = entry; + return x; + } + + internal static AddProgressEventArgs Started(string archiveName) + { + var x = new AddProgressEventArgs(archiveName, ZipProgressEventType.Adding_Started); + return x; + } + + internal static AddProgressEventArgs Completed(string archiveName) + { + var x = new AddProgressEventArgs(archiveName, ZipProgressEventType.Adding_Completed); + return x; + } + + } + + /// + /// Provides information about the progress of a save operation. + /// + public class SaveProgressEventArgs : ZipProgressEventArgs + { + private int _entriesSaved; + + /// + /// Constructor for the SaveProgressEventArgs. + /// + /// the name of the zip archive. + /// whether this is before saving the entry, or after + /// The total number of entries in the zip archive. + /// Number of entries that have been saved. + /// The entry involved in the event. + internal SaveProgressEventArgs(string archiveName, bool before, int entriesTotal, int entriesSaved, ZipEntry entry) + : base(archiveName, (before) ? ZipProgressEventType.Saving_BeforeWriteEntry : ZipProgressEventType.Saving_AfterWriteEntry) + { + this.EntriesTotal = entriesTotal; + this.CurrentEntry = entry; + this._entriesSaved = entriesSaved; + } + + internal SaveProgressEventArgs() { } + + internal SaveProgressEventArgs(string archiveName, ZipProgressEventType flavor) + : base(archiveName, flavor) + { } + + + internal static SaveProgressEventArgs ByteUpdate(string archiveName, ZipEntry entry, Int64 bytesXferred, Int64 totalBytes) + { + var x = new SaveProgressEventArgs(archiveName, ZipProgressEventType.Saving_EntryBytesRead); + x.ArchiveName = archiveName; + x.CurrentEntry = entry; + x.BytesTransferred = bytesXferred; + x.TotalBytesToTransfer = totalBytes; + return x; + } + + internal static SaveProgressEventArgs Started(string archiveName) + { + var x = new SaveProgressEventArgs(archiveName, ZipProgressEventType.Saving_Started); + return x; + } + + internal static SaveProgressEventArgs Completed(string archiveName) + { + var x = new SaveProgressEventArgs(archiveName, ZipProgressEventType.Saving_Completed); + return x; + } + + /// + /// Number of entries saved so far. + /// + public int EntriesSaved + { + get { return _entriesSaved; } + } + } + + + /// + /// Provides information about the progress of the extract operation. + /// + public class ExtractProgressEventArgs : ZipProgressEventArgs + { + private int _entriesExtracted; + private string _target; + + /// + /// Constructor for the ExtractProgressEventArgs. + /// + /// the name of the zip archive. + /// whether this is before saving the entry, or after + /// The total number of entries in the zip archive. + /// Number of entries that have been extracted. + /// The entry involved in the event. + /// The location to which entries are extracted. + internal ExtractProgressEventArgs(string archiveName, bool before, int entriesTotal, int entriesExtracted, ZipEntry entry, string extractLocation) + : base(archiveName, (before) ? ZipProgressEventType.Extracting_BeforeExtractEntry : ZipProgressEventType.Extracting_AfterExtractEntry) + { + this.EntriesTotal = entriesTotal; + this.CurrentEntry = entry; + this._entriesExtracted = entriesExtracted; + this._target = extractLocation; + } + + internal ExtractProgressEventArgs(string archiveName, ZipProgressEventType flavor) + : base(archiveName, flavor) + { } + + internal ExtractProgressEventArgs() + { } + + + internal static ExtractProgressEventArgs BeforeExtractEntry(string archiveName, ZipEntry entry, string extractLocation) + { + var x = new ExtractProgressEventArgs + { + ArchiveName = archiveName, + EventType = ZipProgressEventType.Extracting_BeforeExtractEntry, + CurrentEntry = entry, + _target = extractLocation, + }; + return x; + } + + internal static ExtractProgressEventArgs ExtractExisting(string archiveName, ZipEntry entry, string extractLocation) + { + var x = new ExtractProgressEventArgs + { + ArchiveName = archiveName, + EventType = ZipProgressEventType.Extracting_ExtractEntryWouldOverwrite, + CurrentEntry = entry, + _target = extractLocation, + }; + return x; + } + + internal static ExtractProgressEventArgs AfterExtractEntry(string archiveName, ZipEntry entry, string extractLocation) + { + var x = new ExtractProgressEventArgs + { + ArchiveName = archiveName, + EventType = ZipProgressEventType.Extracting_AfterExtractEntry, + CurrentEntry = entry, + _target = extractLocation, + }; + return x; + } + + internal static ExtractProgressEventArgs ExtractAllStarted(string archiveName, string extractLocation) + { + var x = new ExtractProgressEventArgs(archiveName, ZipProgressEventType.Extracting_BeforeExtractAll); + x._target = extractLocation; + return x; + } + + internal static ExtractProgressEventArgs ExtractAllCompleted(string archiveName, string extractLocation) + { + var x = new ExtractProgressEventArgs(archiveName, ZipProgressEventType.Extracting_AfterExtractAll); + x._target = extractLocation; + return x; + } + + + internal static ExtractProgressEventArgs ByteUpdate(string archiveName, ZipEntry entry, Int64 bytesWritten, Int64 totalBytes) + { + var x = new ExtractProgressEventArgs(archiveName, ZipProgressEventType.Extracting_EntryBytesWritten); + x.ArchiveName = archiveName; + x.CurrentEntry = entry; + x.BytesTransferred = bytesWritten; + x.TotalBytesToTransfer = totalBytes; + return x; + } + + + + /// + /// Number of entries extracted so far. This is set only if the + /// EventType is Extracting_BeforeExtractEntry or Extracting_AfterExtractEntry, and + /// the Extract() is occurring witin the scope of a call to ExtractAll(). + /// + public int EntriesExtracted + { + get { return _entriesExtracted; } + } + + /// + /// Returns the extraction target location, a filesystem path. + /// + public String ExtractLocation + { + get { return _target; } + } + + } + + + + /// + /// Provides information about the an error that occurred while zipping. + /// + public class ZipErrorEventArgs : ZipProgressEventArgs + { + private Exception _exc; + private ZipErrorEventArgs() { } + internal static ZipErrorEventArgs Saving(string archiveName, ZipEntry entry, Exception exception) + { + var x = new ZipErrorEventArgs + { + EventType = ZipProgressEventType.Error_Saving, + ArchiveName = archiveName, + CurrentEntry = entry, + _exc = exception + }; + return x; + } + + /// + /// Returns the exception that occurred, if any. + /// + public Exception @Exception + { + get { return _exc; } + } + + /// + /// Returns the name of the file that caused the exception, if any. + /// + public String FileName + { + get { return CurrentEntry.LocalFileName; } + } + } + + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/Exceptions.cs b/Resources/Libraries/DotNetZip/Source/Zip/Exceptions.cs new file mode 100644 index 00000000..a42757e8 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/Exceptions.cs @@ -0,0 +1,300 @@ +// Exceptions.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2008, 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-12 12:19:10> +// +// ------------------------------------------------------------------ +// +// This module defines exceptions used in the class library. +// + + + +using System; +using System.Collections.Generic; +using System.Text; +#if !NETCF +using System.Runtime.Serialization; +#endif + +namespace Ionic.Zip +{ + ///// + ///// Base exception type for all custom exceptions in the Zip library. It acts as a marker class. + ///// + //[AttributeUsage(AttributeTargets.Class)] + //public class ZipExceptionAttribute : Attribute { } + + + + /// + /// Issued when an ZipEntry.ExtractWithPassword() method is invoked + /// with an incorrect password. + /// +#if !SILVERLIGHT + [Serializable] +#endif + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d0000B")] + public class BadPasswordException : ZipException + { + /// + /// Default ctor. + /// + public BadPasswordException() { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + public BadPasswordException(String message) + : base(message) + { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + /// The innerException for this exception. + public BadPasswordException(String message, Exception innerException) + : base(message, innerException) + { + } + + +#if ! (NETCF || SILVERLIGHT) + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The serialization info for the exception. + /// The streaming context from which to deserialize. + protected BadPasswordException(SerializationInfo info, StreamingContext context) + : base(info, context) + { } +#endif + + } + + /// + /// Indicates that a read was attempted on a stream, and bad or incomplete data was + /// received. + /// +#if !SILVERLIGHT + [Serializable] +#endif + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d0000A")] + public class BadReadException : ZipException + { + /// + /// Default ctor. + /// + public BadReadException() { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + public BadReadException(String message) + : base(message) + { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + /// The innerException for this exception. + public BadReadException(String message, Exception innerException) + : base(message, innerException) + { + } + +#if ! (NETCF || SILVERLIGHT) + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The serialization info for the exception. + /// The streaming context from which to deserialize. + protected BadReadException(SerializationInfo info, StreamingContext context) + : base(info, context) + { } +#endif + + } + + + + /// + /// Issued when an CRC check fails upon extracting an entry from a zip archive. + /// +#if !SILVERLIGHT + [Serializable] +#endif + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d00009")] + public class BadCrcException : ZipException + { + /// + /// Default ctor. + /// + public BadCrcException() { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + public BadCrcException(String message) + : base(message) + { } + + +#if ! (NETCF || SILVERLIGHT) + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The serialization info for the exception. + /// The streaming context from which to deserialize. + protected BadCrcException(SerializationInfo info, StreamingContext context) + : base(info, context) + { } +#endif + + } + + + /// + /// Issued when errors occur saving a self-extracting archive. + /// +#if !SILVERLIGHT + [Serializable] +#endif + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d00008")] + public class SfxGenerationException : ZipException + { + /// + /// Default ctor. + /// + public SfxGenerationException() { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + public SfxGenerationException(String message) + : base(message) + { } + +#if ! (NETCF || SILVERLIGHT) + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The serialization info for the exception. + /// The streaming context from which to deserialize. + protected SfxGenerationException(SerializationInfo info, StreamingContext context) + : base(info, context) + { } +#endif + + } + + + /// + /// Indicates that an operation was attempted on a ZipFile which was not possible + /// given the state of the instance. For example, if you call Save() on a ZipFile + /// which has no filename set, you can get this exception. + /// +#if !SILVERLIGHT + [Serializable] +#endif + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d00007")] + public class BadStateException : ZipException + { + /// + /// Default ctor. + /// + public BadStateException() { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + public BadStateException(String message) + : base(message) + { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + /// The innerException for this exception. + public BadStateException(String message, Exception innerException) + : base(message, innerException) + {} + +#if ! (NETCF || SILVERLIGHT) + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The serialization info for the exception. + /// The streaming context from which to deserialize. + protected BadStateException(SerializationInfo info, StreamingContext context) + : base(info, context) + { } +#endif + + } + + /// + /// Base class for all exceptions defined by and throw by the Zip library. + /// +#if !SILVERLIGHT + [Serializable] +#endif + [System.Runtime.InteropServices.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d00006")] + public class ZipException : Exception + { + /// + /// Default ctor. + /// + public ZipException() { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + public ZipException(String message) : base(message) { } + + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The message in the exception. + /// The innerException for this exception. + public ZipException(String message, Exception innerException) + : base(message, innerException) + { } + +#if ! (NETCF || SILVERLIGHT) + /// + /// Come on, you know how exceptions work. Why are you looking at this documentation? + /// + /// The serialization info for the exception. + /// The streaming context from which to deserialize. + protected ZipException(SerializationInfo info, StreamingContext context) + : base(info, context) + { } +#endif + + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ExtractExistingFileAction.cs b/Resources/Libraries/DotNetZip/Source/Zip/ExtractExistingFileAction.cs new file mode 100644 index 00000000..01f3555b --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ExtractExistingFileAction.cs @@ -0,0 +1,85 @@ +// ExtractExistingFileAction.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-August-25 08:44:37> +// +// ------------------------------------------------------------------ +// +// This module defines the ExtractExistingFileAction enum +// +// +// ------------------------------------------------------------------ + + +namespace Ionic.Zip +{ + + /// + /// An enum for the options when extracting an entry would overwrite an existing file. + /// + /// + /// + /// + /// This enum describes the actions that the library can take when an + /// Extract() or ExtractWithPassword() method is called to extract an + /// entry to a filesystem, and the extraction would overwrite an existing filesystem + /// file. + /// + /// + /// + public enum ExtractExistingFileAction + { + /// + /// Throw an exception when extraction would overwrite an existing file. (For + /// COM clients, this is a 0 (zero).) + /// + Throw, + + /// + /// When extraction would overwrite an existing file, overwrite the file silently. + /// The overwrite will happen even if the target file is marked as read-only. + /// (For COM clients, this is a 1.) + /// + OverwriteSilently, + + /// + /// When extraction would overwrite an existing file, don't overwrite the file, silently. + /// (For COM clients, this is a 2.) + /// + DoNotOverwrite, + + /// + /// When extraction would overwrite an existing file, invoke the ExtractProgress + /// event, using an event type of . In + /// this way, the application can decide, just-in-time, whether to overwrite the + /// file. For example, a GUI application may wish to pop up a dialog to allow + /// the user to choose. You may want to examine the property before making + /// the decision. If, after your processing in the Extract progress event, you + /// want to NOT extract the file, set + /// on the ZipProgressEventArgs.CurrentEntry to DoNotOverwrite. + /// If you do want to extract the file, set ZipEntry.ExtractExistingFile + /// to OverwriteSilently. If you want to cancel the Extraction, set + /// ZipProgressEventArgs.Cancel to true. Cancelling differs from using + /// DoNotOverwrite in that a cancel will not extract any further entries, if + /// there are any. (For COM clients, the value of this enum is a 3.) + /// + InvokeExtractProgressEvent, + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/FileSelector.cs b/Resources/Libraries/DotNetZip/Source/Zip/FileSelector.cs new file mode 100644 index 00000000..92555230 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/FileSelector.cs @@ -0,0 +1,1608 @@ +//#define SelectorTrace + +// FileSelector.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2008-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved: <2011-August-05 11:03:11> +// +// ------------------------------------------------------------------ +// +// This module implements a "file selector" that finds files based on a +// set of inclusion criteria, including filename, size, file time, and +// potentially file attributes. The criteria are given in a string with +// a simple expression language. Examples: +// +// find all .txt files: +// name = *.txt +// +// shorthand for the above +// *.txt +// +// all files modified after January 1st, 2009 +// mtime > 2009-01-01 +// +// All .txt files modified after the first of the year +// name = *.txt AND mtime > 2009-01-01 +// +// All .txt files modified after the first of the year, or any file with the archive bit set +// (name = *.txt AND mtime > 2009-01-01) or (attribtues = A) +// +// All .txt files or any file greater than 1mb in size +// (name = *.txt or size > 1mb) +// +// and so on. +// ------------------------------------------------------------------ + + +using System; +using System.IO; +using System.Text; +using System.Reflection; +using System.ComponentModel; +using System.Text.RegularExpressions; +using System.Collections.Generic; +#if SILVERLIGHT +using System.Linq; +#endif + +namespace Ionic +{ + + /// + /// Enumerates the options for a logical conjunction. This enum is intended for use + /// internally by the FileSelector class. + /// + internal enum LogicalConjunction + { + NONE, + AND, + OR, + XOR, + } + + internal enum WhichTime + { + atime, + mtime, + ctime, + } + + + internal enum ComparisonOperator + { + [Description(">")] + GreaterThan, + [Description(">=")] + GreaterThanOrEqualTo, + [Description("<")] + LesserThan, + [Description("<=")] + LesserThanOrEqualTo, + [Description("=")] + EqualTo, + [Description("!=")] + NotEqualTo + } + + + internal abstract partial class SelectionCriterion + { + internal virtual bool Verbose + { + get;set; + } + internal abstract bool Evaluate(string filename); + + [System.Diagnostics.Conditional("SelectorTrace")] + protected static void CriterionTrace(string format, params object[] args) + { + //System.Console.WriteLine(" " + format, args); + } + } + + + internal partial class SizeCriterion : SelectionCriterion + { + internal ComparisonOperator Operator; + internal Int64 Size; + + public override String ToString() + { + StringBuilder sb = new StringBuilder(); + sb.Append("size ").Append(EnumUtil.GetDescription(Operator)).Append(" ").Append(Size.ToString()); + return sb.ToString(); + } + + internal override bool Evaluate(string filename) + { + System.IO.FileInfo fi = new System.IO.FileInfo(filename); + CriterionTrace("SizeCriterion::Evaluate('{0}' [{1}])", + filename, this.ToString()); + return _Evaluate(fi.Length); + } + + private bool _Evaluate(Int64 Length) + { + bool result = false; + switch (Operator) + { + case ComparisonOperator.GreaterThanOrEqualTo: + result = Length >= Size; + break; + case ComparisonOperator.GreaterThan: + result = Length > Size; + break; + case ComparisonOperator.LesserThanOrEqualTo: + result = Length <= Size; + break; + case ComparisonOperator.LesserThan: + result = Length < Size; + break; + case ComparisonOperator.EqualTo: + result = Length == Size; + break; + case ComparisonOperator.NotEqualTo: + result = Length != Size; + break; + default: + throw new ArgumentException("Operator"); + } + return result; + } + + } + + + + internal partial class TimeCriterion : SelectionCriterion + { + internal ComparisonOperator Operator; + internal WhichTime Which; + internal DateTime Time; + + public override String ToString() + { + StringBuilder sb = new StringBuilder(); + sb.Append(Which.ToString()).Append(" ").Append(EnumUtil.GetDescription(Operator)).Append(" ").Append(Time.ToString("yyyy-MM-dd-HH:mm:ss")); + return sb.ToString(); + } + + internal override bool Evaluate(string filename) + { + DateTime x; + switch (Which) + { + case WhichTime.atime: + x = System.IO.File.GetLastAccessTime(filename).ToUniversalTime(); + break; + case WhichTime.mtime: + x = System.IO.File.GetLastWriteTime(filename).ToUniversalTime(); + break; + case WhichTime.ctime: + x = System.IO.File.GetCreationTime(filename).ToUniversalTime(); + break; + default: + throw new ArgumentException("Operator"); + } + CriterionTrace("TimeCriterion({0},{1})= {2}", filename, Which.ToString(), x); + return _Evaluate(x); + } + + + private bool _Evaluate(DateTime x) + { + bool result = false; + switch (Operator) + { + case ComparisonOperator.GreaterThanOrEqualTo: + result = (x >= Time); + break; + case ComparisonOperator.GreaterThan: + result = (x > Time); + break; + case ComparisonOperator.LesserThanOrEqualTo: + result = (x <= Time); + break; + case ComparisonOperator.LesserThan: + result = (x < Time); + break; + case ComparisonOperator.EqualTo: + result = (x == Time); + break; + case ComparisonOperator.NotEqualTo: + result = (x != Time); + break; + default: + throw new ArgumentException("Operator"); + } + + CriterionTrace("TimeCriterion: {0}", result); + return result; + } + } + + + + internal partial class NameCriterion : SelectionCriterion + { + private Regex _re; + private String _regexString; + internal ComparisonOperator Operator; + private string _MatchingFileSpec; + internal virtual string MatchingFileSpec + { + set + { + // workitem 8245 + if (Directory.Exists(value)) + { + _MatchingFileSpec = ".\\" + value + "\\*.*"; + } + else + { + _MatchingFileSpec = value; + } + + _regexString = "^" + + Regex.Escape(_MatchingFileSpec) + .Replace(@"\\\*\.\*", @"\\([^\.]+|.*\.[^\\\.]*)") + .Replace(@"\.\*", @"\.[^\\\.]*") + .Replace(@"\*", @".*") + //.Replace(@"\*", @"[^\\\.]*") // ill-conceived + .Replace(@"\?", @"[^\\\.]") + + "$"; + + CriterionTrace("NameCriterion regexString({0})", _regexString); + + _re = new Regex(_regexString, RegexOptions.IgnoreCase); + } + } + + + public override String ToString() + { + StringBuilder sb = new StringBuilder(); + sb.Append("name ").Append(EnumUtil.GetDescription(Operator)) + .Append(" '") + .Append(_MatchingFileSpec) + .Append("'"); + return sb.ToString(); + } + + + internal override bool Evaluate(string filename) + { + CriterionTrace("NameCriterion::Evaluate('{0}' pattern[{1}])", + filename, _MatchingFileSpec); + return _Evaluate(filename); + } + + private bool _Evaluate(string fullpath) + { + CriterionTrace("NameCriterion::Evaluate({0})", fullpath); + // No slash in the pattern implicitly means recurse, which means compare to + // filename only, not full path. + String f = (_MatchingFileSpec.IndexOf('\\') == -1) + ? System.IO.Path.GetFileName(fullpath) + : fullpath; // compare to fullpath + + bool result = _re.IsMatch(f); + + if (Operator != ComparisonOperator.EqualTo) + result = !result; + return result; + } + } + + + internal partial class TypeCriterion : SelectionCriterion + { + private char ObjectType; // 'D' = Directory, 'F' = File + internal ComparisonOperator Operator; + internal string AttributeString + { + get + { + return ObjectType.ToString(); + } + set + { + if (value.Length != 1 || + (value[0]!='D' && value[0]!='F')) + throw new ArgumentException("Specify a single character: either D or F"); + ObjectType = value[0]; + } + } + + public override String ToString() + { + StringBuilder sb = new StringBuilder(); + sb.Append("type ").Append(EnumUtil.GetDescription(Operator)).Append(" ").Append(AttributeString); + return sb.ToString(); + } + + internal override bool Evaluate(string filename) + { + CriterionTrace("TypeCriterion::Evaluate({0})", filename); + + bool result = (ObjectType == 'D') + ? Directory.Exists(filename) + : File.Exists(filename); + + if (Operator != ComparisonOperator.EqualTo) + result = !result; + return result; + } + } + + +#if !SILVERLIGHT + internal partial class AttributesCriterion : SelectionCriterion + { + private FileAttributes _Attributes; + internal ComparisonOperator Operator; + internal string AttributeString + { + get + { + string result = ""; + if ((_Attributes & FileAttributes.Hidden) != 0) + result += "H"; + if ((_Attributes & FileAttributes.System) != 0) + result += "S"; + if ((_Attributes & FileAttributes.ReadOnly) != 0) + result += "R"; + if ((_Attributes & FileAttributes.Archive) != 0) + result += "A"; + if ((_Attributes & FileAttributes.ReparsePoint) != 0) + result += "L"; + if ((_Attributes & FileAttributes.NotContentIndexed) != 0) + result += "I"; + return result; + } + + set + { + _Attributes = FileAttributes.Normal; + foreach (char c in value.ToUpper()) + { + switch (c) + { + case 'H': + if ((_Attributes & FileAttributes.Hidden) != 0) + throw new ArgumentException(String.Format("Repeated flag. ({0})", c), "value"); + _Attributes |= FileAttributes.Hidden; + break; + + case 'R': + if ((_Attributes & FileAttributes.ReadOnly) != 0) + throw new ArgumentException(String.Format("Repeated flag. ({0})", c), "value"); + _Attributes |= FileAttributes.ReadOnly; + break; + + case 'S': + if ((_Attributes & FileAttributes.System) != 0) + throw new ArgumentException(String.Format("Repeated flag. ({0})", c), "value"); + _Attributes |= FileAttributes.System; + break; + + case 'A': + if ((_Attributes & FileAttributes.Archive) != 0) + throw new ArgumentException(String.Format("Repeated flag. ({0})", c), "value"); + _Attributes |= FileAttributes.Archive; + break; + + case 'I': + if ((_Attributes & FileAttributes.NotContentIndexed) != 0) + throw new ArgumentException(String.Format("Repeated flag. ({0})", c), "value"); + _Attributes |= FileAttributes.NotContentIndexed; + break; + + case 'L': + if ((_Attributes & FileAttributes.ReparsePoint) != 0) + throw new ArgumentException(String.Format("Repeated flag. ({0})", c), "value"); + _Attributes |= FileAttributes.ReparsePoint; + break; + + default: + throw new ArgumentException(value); + } + } + } + } + + + public override String ToString() + { + StringBuilder sb = new StringBuilder(); + sb.Append("attributes ").Append(EnumUtil.GetDescription(Operator)).Append(" ").Append(AttributeString); + return sb.ToString(); + } + + private bool _EvaluateOne(FileAttributes fileAttrs, FileAttributes criterionAttrs) + { + bool result = false; + if ((_Attributes & criterionAttrs) == criterionAttrs) + result = ((fileAttrs & criterionAttrs) == criterionAttrs); + else + result = true; + return result; + } + + + + internal override bool Evaluate(string filename) + { + // workitem 10191 + if (Directory.Exists(filename)) + { + // Directories don't have file attributes, so the result + // of an evaluation is always NO. This gets negated if + // the operator is NotEqualTo. + return (Operator != ComparisonOperator.EqualTo); + } +#if NETCF + FileAttributes fileAttrs = NetCfFile.GetAttributes(filename); +#else + FileAttributes fileAttrs = System.IO.File.GetAttributes(filename); +#endif + + return _Evaluate(fileAttrs); + } + + private bool _Evaluate(FileAttributes fileAttrs) + { + bool result = _EvaluateOne(fileAttrs, FileAttributes.Hidden); + if (result) + result = _EvaluateOne(fileAttrs, FileAttributes.System); + if (result) + result = _EvaluateOne(fileAttrs, FileAttributes.ReadOnly); + if (result) + result = _EvaluateOne(fileAttrs, FileAttributes.Archive); + if (result) + result = _EvaluateOne(fileAttrs, FileAttributes.NotContentIndexed); + if (result) + result = _EvaluateOne(fileAttrs, FileAttributes.ReparsePoint); + + if (Operator != ComparisonOperator.EqualTo) + result = !result; + + return result; + } + } +#endif + + + internal partial class CompoundCriterion : SelectionCriterion + { + internal LogicalConjunction Conjunction; + internal SelectionCriterion Left; + + private SelectionCriterion _Right; + internal SelectionCriterion Right + { + get { return _Right; } + set + { + _Right = value; + if (value == null) + Conjunction = LogicalConjunction.NONE; + else if (Conjunction == LogicalConjunction.NONE) + Conjunction = LogicalConjunction.AND; + } + } + + + internal override bool Evaluate(string filename) + { + bool result = Left.Evaluate(filename); + switch (Conjunction) + { + case LogicalConjunction.AND: + if (result) + result = Right.Evaluate(filename); + break; + case LogicalConjunction.OR: + if (!result) + result = Right.Evaluate(filename); + break; + case LogicalConjunction.XOR: + result ^= Right.Evaluate(filename); + break; + default: + throw new ArgumentException("Conjunction"); + } + return result; + } + + + public override String ToString() + { + StringBuilder sb = new StringBuilder(); + sb.Append("(") + .Append((Left != null) ? Left.ToString() : "null") + .Append(" ") + .Append(Conjunction.ToString()) + .Append(" ") + .Append((Right != null) ? Right.ToString() : "null") + .Append(")"); + return sb.ToString(); + } + } + + + + /// + /// FileSelector encapsulates logic that selects files from a source - a zip file + /// or the filesystem - based on a set of criteria. This class is used internally + /// by the DotNetZip library, in particular for the AddSelectedFiles() methods. + /// This class can also be used independently of the zip capability in DotNetZip. + /// + /// + /// + /// + /// + /// The FileSelector class is used internally by the ZipFile class for selecting + /// files for inclusion into the ZipFile, when the method, or one of + /// its overloads, is called. It's also used for the methods. Typically, an + /// application that creates or manipulates Zip archives will not directly + /// interact with the FileSelector class. + /// + /// + /// + /// Some applications may wish to use the FileSelector class directly, to + /// select files from disk volumes based on a set of criteria, without creating or + /// querying Zip archives. The file selection criteria include: a pattern to + /// match the filename; the last modified, created, or last accessed time of the + /// file; the size of the file; and the attributes of the file. + /// + /// + /// + /// Consult the documentation for + /// for more information on specifying the selection criteria. + /// + /// + /// + public partial class FileSelector + { + internal SelectionCriterion _Criterion; + +#if NOTUSED + /// + /// The default constructor. + /// + /// + /// Typically, applications won't use this constructor. Instead they'll + /// call the constructor that accepts a selectionCriteria string. If you + /// use this constructor, you'll want to set the SelectionCriteria + /// property on the instance before calling SelectFiles(). + /// + protected FileSelector() { } +#endif + /// + /// Constructor that allows the caller to specify file selection criteria. + /// + /// + /// + /// + /// This constructor allows the caller to specify a set of criteria for + /// selection of files. + /// + /// + /// + /// See for a description of + /// the syntax of the selectionCriteria string. + /// + /// + /// + /// By default the FileSelector will traverse NTFS Reparse Points. To + /// change this, use FileSelector(String, bool). + /// + /// + /// + /// The criteria for file selection. + public FileSelector(String selectionCriteria) + : this(selectionCriteria, true) + { + } + + /// + /// Constructor that allows the caller to specify file selection criteria. + /// + /// + /// + /// + /// This constructor allows the caller to specify a set of criteria for + /// selection of files. + /// + /// + /// + /// See for a description of + /// the syntax of the selectionCriteria string. + /// + /// + /// + /// The criteria for file selection. + /// + /// whether to traverse NTFS reparse points (junctions). + /// + public FileSelector(String selectionCriteria, bool traverseDirectoryReparsePoints) + { + if (!String.IsNullOrEmpty(selectionCriteria)) + _Criterion = _ParseCriterion(selectionCriteria); + TraverseReparsePoints = traverseDirectoryReparsePoints; + } + + + + /// + /// The string specifying which files to include when retrieving. + /// + /// + /// + /// + /// Specify the criteria in statements of 3 elements: a noun, an operator, + /// and a value. Consider the string "name != *.doc" . The noun is + /// "name". The operator is "!=", implying "Not Equal". The value is + /// "*.doc". That criterion, in English, says "all files with a name that + /// does not end in the .doc extension." + /// + /// + /// + /// Supported nouns include "name" (or "filename") for the filename; + /// "atime", "mtime", and "ctime" for last access time, last modfied time, + /// and created time of the file, respectively; "attributes" (or "attrs") + /// for the file attributes; "size" (or "length") for the file length + /// (uncompressed); and "type" for the type of object, either a file or a + /// directory. The "attributes", "type", and "name" nouns all support = + /// and != as operators. The "size", "atime", "mtime", and "ctime" nouns + /// support = and !=, and >, >=, <, <= as well. The times are + /// taken to be expressed in local time. + /// + /// + /// + /// Specify values for the file attributes as a string with one or more of + /// the characters H,R,S,A,I,L in any order, implying file attributes of + /// Hidden, ReadOnly, System, Archive, NotContextIndexed, and ReparsePoint + /// (symbolic link) respectively. + /// + /// + /// + /// To specify a time, use YYYY-MM-DD-HH:mm:ss or YYYY/MM/DD-HH:mm:ss as + /// the format. If you omit the HH:mm:ss portion, it is assumed to be + /// 00:00:00 (midnight). + /// + /// + /// + /// The value for a size criterion is expressed in integer quantities of + /// bytes, kilobytes (use k or kb after the number), megabytes (m or mb), + /// or gigabytes (g or gb). + /// + /// + /// + /// The value for a name is a pattern to match against the filename, + /// potentially including wildcards. The pattern follows CMD.exe glob + /// rules: * implies one or more of any character, while ? implies one + /// character. If the name pattern contains any slashes, it is matched to + /// the entire filename, including the path; otherwise, it is matched + /// against only the filename without the path. This means a pattern of + /// "*\*.*" matches all files one directory level deep, while a pattern of + /// "*.*" matches all files in all directories. + /// + /// + /// + /// To specify a name pattern that includes spaces, use single quotes + /// around the pattern. A pattern of "'* *.*'" will match all files that + /// have spaces in the filename. The full criteria string for that would + /// be "name = '* *.*'" . + /// + /// + /// + /// The value for a type criterion is either F (implying a file) or D + /// (implying a directory). + /// + /// + /// + /// Some examples: + /// + /// + /// + /// + /// criteria + /// Files retrieved + /// + /// + /// + /// name != *.xls + /// any file with an extension that is not .xls + /// + /// + /// + /// + /// name = *.mp3 + /// any file with a .mp3 extension. + /// + /// + /// + /// + /// *.mp3 + /// (same as above) any file with a .mp3 extension. + /// + /// + /// + /// + /// attributes = A + /// all files whose attributes include the Archive bit. + /// + /// + /// + /// + /// attributes != H + /// all files whose attributes do not include the Hidden bit. + /// + /// + /// + /// + /// mtime > 2009-01-01 + /// all files with a last modified time after January 1st, 2009. + /// + /// + /// + /// + /// ctime > 2009/01/01-03:00:00 + /// all files with a created time after 3am (local time), + /// on January 1st, 2009. + /// + /// + /// + /// + /// size > 2gb + /// all files whose uncompressed size is greater than 2gb. + /// + /// + /// + /// + /// type = D + /// all directories in the filesystem. + /// + /// + /// + /// + /// + /// You can combine criteria with the conjunctions AND, OR, and XOR. Using + /// a string like "name = *.txt AND size >= 100k" for the + /// selectionCriteria retrieves entries whose names end in .txt, and whose + /// uncompressed size is greater than or equal to 100 kilobytes. + /// + /// + /// + /// For more complex combinations of criteria, you can use parenthesis to + /// group clauses in the boolean logic. Absent parenthesis, the + /// precedence of the criterion atoms is determined by order of + /// appearance. Unlike the C# language, the AND conjunction does not take + /// precendence over the logical OR. This is important only in strings + /// that contain 3 or more criterion atoms. In other words, "name = *.txt + /// and size > 1000 or attributes = H" implies "((name = *.txt AND size + /// > 1000) OR attributes = H)" while "attributes = H OR name = *.txt + /// and size > 1000" evaluates to "((attributes = H OR name = *.txt) + /// AND size > 1000)". When in doubt, use parenthesis. + /// + /// + /// + /// Using time properties requires some extra care. If you want to + /// retrieve all entries that were last updated on 2009 February 14, + /// specify "mtime >= 2009-02-14 AND mtime < 2009-02-15". Read this + /// to say: all files updated after 12:00am on February 14th, until + /// 12:00am on February 15th. You can use the same bracketing approach to + /// specify any time period - a year, a month, a week, and so on. + /// + /// + /// + /// The syntax allows one special case: if you provide a string with no + /// spaces, it is treated as a pattern to match for the filename. + /// Therefore a string like "*.xls" will be equivalent to specifying "name + /// = *.xls". This "shorthand" notation does not work with compound + /// criteria. + /// + /// + /// + /// There is no logic in this class that insures that the inclusion + /// criteria are internally consistent. For example, it's possible to + /// specify criteria that says the file must have a size of less than 100 + /// bytes, as well as a size that is greater than 1000 bytes. Obviously + /// no file will ever satisfy such criteria, but this class does not check + /// for or detect such inconsistencies. + /// + /// + /// + /// + /// + /// Thrown in the setter if the value has an invalid syntax. + /// + public String SelectionCriteria + { + get + { + if (_Criterion == null) return null; + return _Criterion.ToString(); + } + set + { + if (value == null) _Criterion = null; + else if (value.Trim() == "") _Criterion = null; + else + _Criterion = _ParseCriterion(value); + } + } + + /// + /// Indicates whether searches will traverse NTFS reparse points, like Junctions. + /// + public bool TraverseReparsePoints + { + get; set; + } + + + private enum ParseState + { + Start, + OpenParen, + CriterionDone, + ConjunctionPending, + Whitespace, + } + + + private static class RegexAssertions + { + public static readonly String PrecededByOddNumberOfSingleQuotes = "(?<=(?:[^']*'[^']*')*'[^']*)"; + public static readonly String FollowedByOddNumberOfSingleQuotesAndLineEnd = "(?=[^']*'(?:[^']*'[^']*')*[^']*$)"; + + public static readonly String PrecededByEvenNumberOfSingleQuotes = "(?<=(?:[^']*'[^']*')*[^']*)"; + public static readonly String FollowedByEvenNumberOfSingleQuotesAndLineEnd = "(?=(?:[^']*'[^']*')*[^']*$)"; + } + + + private static string NormalizeCriteriaExpression(string source) + { + // The goal here is to normalize the criterion expression. At output, in + // the transformed criterion string, every significant syntactic element + // - a property element, grouping paren for the boolean logic, operator + // ( = < > != ), conjunction, or property value - will be separated from + // its neighbors by at least one space. Thus, + // + // before after + // ------------------------------------------------------------------- + // name=*.txt name = *.txt + // (size>100)AND(name=*.txt) ( size > 100 ) AND ( name = *.txt ) + // + // This is relatively straightforward using regular expression + // replacement. This method applies a distinct regex pattern and + // corresponding replacement string for each one of a number of cases: + // an open paren followed by a word; a word followed by a close-paren; a + // pair of open parens; a close paren followed by a word (which should + // then be followed by an open paren). And so on. These patterns and + // replacements are all stored in prPairs. By applying each of these + // regex replacements in turn, we get the transformed string. Easy. + // + // The resulting "normalized" criterion string, is then used as the + // subject that gets parsed, by splitting the string into tokens that + // are separated by spaces. Here, there's a twist. The spaces within + // single-quote delimiters do not delimit distinct tokens. So, this + // normalization method temporarily replaces those spaces with + // ASCII 6 (0x06), a control character which is not a legal + // character in a filename. The parsing logic that happens later will + // revert that change, restoring the original value of the filename + // specification. + // + // To illustrate, for a "before" string of [(size>100)AND(name='Name + // (with Parens).txt')] , the "after" string is [( size > 100 ) AND + // ( name = 'Name\u0006(with\u0006Parens).txt' )]. + // + + string[][] prPairs = + { + // A. opening double parens - insert a space between them + new string[] { @"([^']*)\(\(([^']+)", "$1( ($2" }, + + // B. closing double parens - insert a space between + new string[] { @"(.)\)\)", "$1) )" }, + + // C. single open paren with a following word - insert a space between + new string[] { @"\((\S)", "( $1" }, + + // D. single close paren with a preceding word - insert a space between the two + new string[] { @"(\S)\)", "$1 )" }, + + // E. close paren at line start?, insert a space before the close paren + // this seems like a degenerate case. I don't recall why it's here. + new string[] { @"^\)", " )" }, + + // F. a word (likely a conjunction) followed by an open paren - insert a space between + new string[] { @"(\S)\(", "$1 (" }, + + // G. single close paren followed by word - insert a paren after close paren + new string[] { @"\)(\S)", ") $1" }, + + // H. insert space between = and a following single quote + //new string[] { @"(=|!=)('[^']*')", "$1 $2" }, + new string[] { @"(=)('[^']*')", "$1 $2" }, + + // I. insert space between property names and the following operator + //new string[] { @"([^ ])([><(?:!=)=])", "$1 $2" }, + new string[] { @"([^ !><])(>|<|!=|=)", "$1 $2" }, + + // J. insert spaces between operators and the following values + //new string[] { @"([><(?:!=)=])([^ ])", "$1 $2" }, + new string[] { @"(>|<|!=|=)([^ =])", "$1 $2" }, + + // K. replace fwd slash with backslash + new string[] { @"/", "\\" }, + }; + + string interim = source; + + for (int i=0; i < prPairs.Length; i++) + { + //char caseIdx = (char)('A' + i); + string pattern = RegexAssertions.PrecededByEvenNumberOfSingleQuotes + + prPairs[i][0] + + RegexAssertions.FollowedByEvenNumberOfSingleQuotesAndLineEnd; + + interim = Regex.Replace(interim, pattern, prPairs[i][1]); + } + + // match a fwd slash, followed by an odd number of single quotes. + // This matches fwd slashes only inside a pair of single quote delimiters, + // eg, a filename. This must be done as well as the case above, to handle + // filenames specified inside quotes as well as filenames without quotes. + var regexPattern = @"/" + + RegexAssertions.FollowedByOddNumberOfSingleQuotesAndLineEnd; + // replace with backslash + interim = Regex.Replace(interim, regexPattern, "\\"); + + // match a space, followed by an odd number of single quotes. + // This matches spaces only inside a pair of single quote delimiters. + regexPattern = " " + + RegexAssertions.FollowedByOddNumberOfSingleQuotesAndLineEnd; + + // Replace all spaces that appear inside single quotes, with + // ascii 6. This allows a split on spaces to get tokens in + // the expression. The split will not split any filename or + // wildcard that appears within single quotes. After tokenizing, we + // need to replace ascii 6 with ascii 32 to revert the + // spaces within quotes. + return Regex.Replace(interim, regexPattern, "\u0006"); + } + + + private static SelectionCriterion _ParseCriterion(String s) + { + if (s == null) return null; + + // inject spaces after open paren and before close paren, etc + s = NormalizeCriteriaExpression(s); + + // no spaces in the criteria is shorthand for filename glob + if (s.IndexOf(" ") == -1) + s = "name = " + s; + + // split the expression into tokens + string[] tokens = s.Trim().Split(' ', '\t'); + + if (tokens.Length < 3) throw new ArgumentException(s); + + SelectionCriterion current = null; + + LogicalConjunction pendingConjunction = LogicalConjunction.NONE; + + ParseState state; + var stateStack = new System.Collections.Generic.Stack(); + var critStack = new System.Collections.Generic.Stack(); + stateStack.Push(ParseState.Start); + + for (int i = 0; i < tokens.Length; i++) + { + string tok1 = tokens[i].ToLower(); + switch (tok1) + { + case "and": + case "xor": + case "or": + state = stateStack.Peek(); + if (state != ParseState.CriterionDone) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + if (tokens.Length <= i + 3) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + pendingConjunction = (LogicalConjunction)Enum.Parse(typeof(LogicalConjunction), tokens[i].ToUpper(), true); + current = new CompoundCriterion { Left = current, Right = null, Conjunction = pendingConjunction }; + stateStack.Push(state); + stateStack.Push(ParseState.ConjunctionPending); + critStack.Push(current); + break; + + case "(": + state = stateStack.Peek(); + if (state != ParseState.Start && state != ParseState.ConjunctionPending && state != ParseState.OpenParen) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + if (tokens.Length <= i + 4) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + stateStack.Push(ParseState.OpenParen); + break; + + case ")": + state = stateStack.Pop(); + if (stateStack.Peek() != ParseState.OpenParen) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + stateStack.Pop(); + stateStack.Push(ParseState.CriterionDone); + break; + + case "atime": + case "ctime": + case "mtime": + if (tokens.Length <= i + 2) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + DateTime t; + try + { + t = DateTime.ParseExact(tokens[i + 2], "yyyy-MM-dd-HH:mm:ss", null); + } + catch (FormatException) + { + try + { + t = DateTime.ParseExact(tokens[i + 2], "yyyy/MM/dd-HH:mm:ss", null); + } + catch (FormatException) + { + try + { + t = DateTime.ParseExact(tokens[i + 2], "yyyy/MM/dd", null); + } + catch (FormatException) + { + try + { + t = DateTime.ParseExact(tokens[i + 2], "MM/dd/yyyy", null); + } + catch (FormatException) + { + t = DateTime.ParseExact(tokens[i + 2], "yyyy-MM-dd", null); + } + } + } + } + t= DateTime.SpecifyKind(t, DateTimeKind.Local).ToUniversalTime(); + current = new TimeCriterion + { + Which = (WhichTime)Enum.Parse(typeof(WhichTime), tokens[i], true), + Operator = (ComparisonOperator)EnumUtil.Parse(typeof(ComparisonOperator), tokens[i + 1]), + Time = t + }; + i += 2; + stateStack.Push(ParseState.CriterionDone); + break; + + + case "length": + case "size": + if (tokens.Length <= i + 2) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + Int64 sz = 0; + string v = tokens[i + 2]; + if (v.ToUpper().EndsWith("K")) + sz = Int64.Parse(v.Substring(0, v.Length - 1)) * 1024; + else if (v.ToUpper().EndsWith("KB")) + sz = Int64.Parse(v.Substring(0, v.Length - 2)) * 1024; + else if (v.ToUpper().EndsWith("M")) + sz = Int64.Parse(v.Substring(0, v.Length - 1)) * 1024 * 1024; + else if (v.ToUpper().EndsWith("MB")) + sz = Int64.Parse(v.Substring(0, v.Length - 2)) * 1024 * 1024; + else if (v.ToUpper().EndsWith("G")) + sz = Int64.Parse(v.Substring(0, v.Length - 1)) * 1024 * 1024 * 1024; + else if (v.ToUpper().EndsWith("GB")) + sz = Int64.Parse(v.Substring(0, v.Length - 2)) * 1024 * 1024 * 1024; + else sz = Int64.Parse(tokens[i + 2]); + + current = new SizeCriterion + { + Size = sz, + Operator = (ComparisonOperator)EnumUtil.Parse(typeof(ComparisonOperator), tokens[i + 1]) + }; + i += 2; + stateStack.Push(ParseState.CriterionDone); + break; + + case "filename": + case "name": + { + if (tokens.Length <= i + 2) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + ComparisonOperator c = + (ComparisonOperator)EnumUtil.Parse(typeof(ComparisonOperator), tokens[i + 1]); + + if (c != ComparisonOperator.NotEqualTo && c != ComparisonOperator.EqualTo) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + string m = tokens[i + 2]; + + // handle single-quoted filespecs (used to include + // spaces in filename patterns) + if (m.StartsWith("'") && m.EndsWith("'")) + { + // trim off leading and trailing single quotes and + // revert the control characters to spaces. + m = m.Substring(1, m.Length - 2) + .Replace("\u0006", " "); + } + + // if (m.StartsWith("'")) + // m = m.Replace("\u0006", " "); + + current = new NameCriterion + { + MatchingFileSpec = m, + Operator = c + }; + i += 2; + stateStack.Push(ParseState.CriterionDone); + } + break; + +#if !SILVERLIGHT + case "attrs": + case "attributes": +#endif + case "type": + { + if (tokens.Length <= i + 2) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + + ComparisonOperator c = + (ComparisonOperator)EnumUtil.Parse(typeof(ComparisonOperator), tokens[i + 1]); + + if (c != ComparisonOperator.NotEqualTo && c != ComparisonOperator.EqualTo) + throw new ArgumentException(String.Join(" ", tokens, i, tokens.Length - i)); + +#if SILVERLIGHT + current = (SelectionCriterion) new TypeCriterion + { + AttributeString = tokens[i + 2], + Operator = c + }; +#else + current = (tok1 == "type") + ? (SelectionCriterion) new TypeCriterion + { + AttributeString = tokens[i + 2], + Operator = c + } + : (SelectionCriterion) new AttributesCriterion + { + AttributeString = tokens[i + 2], + Operator = c + }; +#endif + i += 2; + stateStack.Push(ParseState.CriterionDone); + } + break; + + case "": + // NOP + stateStack.Push(ParseState.Whitespace); + break; + + default: + throw new ArgumentException("'" + tokens[i] + "'"); + } + + state = stateStack.Peek(); + if (state == ParseState.CriterionDone) + { + stateStack.Pop(); + if (stateStack.Peek() == ParseState.ConjunctionPending) + { + while (stateStack.Peek() == ParseState.ConjunctionPending) + { + var cc = critStack.Pop() as CompoundCriterion; + cc.Right = current; + current = cc; // mark the parent as current (walk up the tree) + stateStack.Pop(); // the conjunction is no longer pending + + state = stateStack.Pop(); + if (state != ParseState.CriterionDone) + throw new ArgumentException("??"); + } + } + else stateStack.Push(ParseState.CriterionDone); // not sure? + } + + if (state == ParseState.Whitespace) + stateStack.Pop(); + } + + return current; + } + + + /// + /// Returns a string representation of the FileSelector object. + /// + /// The string representation of the boolean logic statement of the file + /// selection criteria for this instance. + public override String ToString() + { + return "FileSelector("+_Criterion.ToString()+")"; + } + + + private bool Evaluate(string filename) + { + // dinoch - Thu, 11 Feb 2010 18:34 + SelectorTrace("Evaluate({0})", filename); + bool result = _Criterion.Evaluate(filename); + return result; + } + + [System.Diagnostics.Conditional("SelectorTrace")] + private void SelectorTrace(string format, params object[] args) + { + if (_Criterion != null && _Criterion.Verbose) + System.Console.WriteLine(format, args); + } + + /// + /// Returns the names of the files in the specified directory + /// that fit the selection criteria specified in the FileSelector. + /// + /// + /// + /// This is equivalent to calling + /// with recurseDirectories = false. + /// + /// + /// + /// The name of the directory over which to apply the FileSelector + /// criteria. + /// + /// + /// + /// A collection of strings containing fully-qualified pathnames of files + /// that match the criteria specified in the FileSelector instance. + /// + public System.Collections.Generic.ICollection SelectFiles(String directory) + { + return SelectFiles(directory, false); + } + + + /// + /// Returns the names of the files in the specified directory that fit the + /// selection criteria specified in the FileSelector, optionally recursing + /// through subdirectories. + /// + /// + /// + /// This method applies the file selection criteria contained in the + /// FileSelector to the files contained in the given directory, and + /// returns the names of files that conform to the criteria. + /// + /// + /// + /// The name of the directory over which to apply the FileSelector + /// criteria. + /// + /// + /// + /// Whether to recurse through subdirectories when applying the file + /// selection criteria. + /// + /// + /// + /// A collection of strings containing fully-qualified pathnames of files + /// that match the criteria specified in the FileSelector instance. + /// + public System.Collections.ObjectModel.ReadOnlyCollection + SelectFiles(String directory, + bool recurseDirectories) + { + if (_Criterion == null) + throw new ArgumentException("SelectionCriteria has not been set"); + + var list = new List(); + try + { + if (Directory.Exists(directory)) + { + String[] filenames = Directory.GetFiles(directory); + + // add the files: + foreach (String filename in filenames) + { + if (Evaluate(filename)) + list.Add(filename); + } + + if (recurseDirectories) + { + // add the subdirectories: + String[] dirnames = Directory.GetDirectories(directory); + foreach (String dir in dirnames) + { + if (this.TraverseReparsePoints +#if !SILVERLIGHT + || ((File.GetAttributes(dir) & FileAttributes.ReparsePoint) == 0) +#endif + ) + { + // workitem 10191 + if (Evaluate(dir)) list.Add(dir); + list.AddRange(this.SelectFiles(dir, recurseDirectories)); + } + } + } + } + } + // can get System.UnauthorizedAccessException here + catch (System.UnauthorizedAccessException) + { + } + catch (System.IO.IOException) + { + } + + return list.AsReadOnly(); + } + } + + + + /// + /// Summary description for EnumUtil. + /// + internal sealed class EnumUtil + { + private EnumUtil() { } + /// + /// Returns the value of the DescriptionAttribute if the specified Enum + /// value has one. If not, returns the ToString() representation of the + /// Enum value. + /// + /// The Enum to get the description for + /// + internal static string GetDescription(System.Enum value) + { + FieldInfo fi = value.GetType().GetField(value.ToString()); + var attributes = (DescriptionAttribute[])fi.GetCustomAttributes(typeof(DescriptionAttribute), false); + if (attributes.Length > 0) + return attributes[0].Description; + else + return value.ToString(); + } + + /// + /// Converts the string representation of the name or numeric value of one + /// or more enumerated constants to an equivalent enumerated object. + /// Note: use the DescriptionAttribute on enum values to enable this. + /// + /// The System.Type of the enumeration. + /// + /// A string containing the name or value to convert. + /// + /// + internal static object Parse(Type enumType, string stringRepresentation) + { + return Parse(enumType, stringRepresentation, false); + } + + +#if SILVERLIGHT + public static System.Enum[] GetEnumValues(Type type) + { + if (!type.IsEnum) + throw new ArgumentException("not an enum"); + + return ( + from field in type.GetFields(BindingFlags.Public | BindingFlags.Static) + where field.IsLiteral + select (System.Enum)field.GetValue(null) + ).ToArray(); + } + + public static string[] GetEnumStrings() + { + var type = typeof(T); + if (!type.IsEnum) + throw new ArgumentException("not an enum"); + + return ( + from field in type.GetFields(BindingFlags.Public | BindingFlags.Static) + where field.IsLiteral + select field.Name + ).ToArray(); + } +#endif + + /// + /// Converts the string representation of the name or numeric value of one + /// or more enumerated constants to an equivalent enumerated object. A + /// parameter specified whether the operation is case-sensitive. Note: + /// use the DescriptionAttribute on enum values to enable this. + /// + /// The System.Type of the enumeration. + /// + /// A string containing the name or value to convert. + /// + /// + /// Whether the operation is case-sensitive or not. + /// + internal static object Parse(Type enumType, string stringRepresentation, bool ignoreCase) + { + if (ignoreCase) + stringRepresentation = stringRepresentation.ToLower(); + +#if SILVERLIGHT + foreach (System.Enum enumVal in GetEnumValues(enumType)) +#else + foreach (System.Enum enumVal in System.Enum.GetValues(enumType)) +#endif + { + string description = GetDescription(enumVal); + if (ignoreCase) + description = description.ToLower(); + if (description == stringRepresentation) + return enumVal; + } + + return System.Enum.Parse(enumType, stringRepresentation, ignoreCase); + } + } + + +#if DEMO + public class DemonstrateFileSelector + { + private string _directory; + private bool _recurse; + private bool _traverse; + private bool _verbose; + private string _selectionCriteria; + private FileSelector f; + + public DemonstrateFileSelector() + { + this._directory = "."; + this._recurse = true; + } + + public DemonstrateFileSelector(string[] args) : this() + { + for (int i = 0; i < args.Length; i++) + { + switch(args[i]) + { + case"-?": + Usage(); + Environment.Exit(0); + break; + case "-d": + i++; + if (args.Length <= i) + throw new ArgumentException("-directory"); + this._directory = args[i]; + break; + case "-norecurse": + this._recurse = false; + break; + + case "-j-": + this._traverse = false; + break; + + case "-j+": + this._traverse = true; + break; + + case "-v": + this._verbose = true; + break; + + default: + if (this._selectionCriteria != null) + throw new ArgumentException(args[i]); + this._selectionCriteria = args[i]; + break; + } + + if (this._selectionCriteria != null) + this.f = new FileSelector(this._selectionCriteria); + } + } + + + public static void Main(string[] args) + { + try + { + Console.WriteLine(); + new DemonstrateFileSelector(args).Run(); + } + catch (Exception exc1) + { + Console.WriteLine("Exception: {0}", exc1.ToString()); + Usage(); + } + } + + + public void Run() + { + if (this.f == null) + this.f = new FileSelector("name = *.jpg AND (size > 1000 OR atime < 2009-02-14-01:00:00)"); + + this.f.TraverseReparsePoints = _traverse; + this.f.Verbose = this._verbose; + Console.WriteLine(); + Console.WriteLine(new String(':', 88)); + Console.WriteLine("Selecting files:\n" + this.f.ToString()); + var files = this.f.SelectFiles(this._directory, this._recurse); + if (files.Count == 0) + { + Console.WriteLine("no files."); + } + else + { + Console.WriteLine("files: {0}", files.Count); + foreach (string file in files) + { + Console.WriteLine(" " + file); + } + } + } + + public static void Usage() + { + Console.WriteLine("FileSelector: select files based on selection criteria.\n"); + Console.WriteLine("Usage:\n FileSelector [options]\n" + + "\n" + + " -d
directory to select from (Default .)\n" + + " -norecurse don't recurse into subdirs\n" + + " -j- don't traverse junctions\n" + + " -v verbose output\n"); + } + } + +#endif + + + +} + + diff --git a/Resources/Libraries/DotNetZip/Source/Zip/OffsetStream.cs b/Resources/Libraries/DotNetZip/Source/Zip/OffsetStream.cs new file mode 100644 index 00000000..8ae2811d --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/OffsetStream.cs @@ -0,0 +1,114 @@ +// OffsetStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-August-27 12:50:35> +// +// ------------------------------------------------------------------ +// +// This module defines logic for handling reading of zip archives embedded +// into larger streams. The initial position of the stream serves as +// the base offset for all future Seek() operations. +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; + +namespace Ionic.Zip +{ + internal class OffsetStream : System.IO.Stream, System.IDisposable + { + private Int64 _originalPosition; + private Stream _innerStream; + + public OffsetStream(Stream s) + : base() + { + _originalPosition = s.Position; + _innerStream = s; + } + + public override int Read(byte[] buffer, int offset, int count) + { + return _innerStream.Read(buffer, offset, count); + } + + public override void Write(byte[] buffer, int offset, int count) + { + throw new NotImplementedException(); + } + + public override bool CanRead + { + get { return _innerStream.CanRead; } + } + + public override bool CanSeek + { + get { return _innerStream.CanSeek; } + } + + public override bool CanWrite + { + get { return false; } + } + + public override void Flush() + { + _innerStream.Flush(); + } + + public override long Length + { + get + { + return _innerStream.Length; + } + } + + public override long Position + { + get { return _innerStream.Position - _originalPosition; } + set { _innerStream.Position = _originalPosition + value; } + } + + + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + return _innerStream.Seek(_originalPosition + offset, origin) - _originalPosition; + } + + + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + void IDisposable.Dispose() + { + Close(); + } + + public override void Close() + { + base.Close(); + } + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/Shared.cs b/Resources/Libraries/DotNetZip/Source/Zip/Shared.cs new file mode 100644 index 00000000..4b1854b6 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/Shared.cs @@ -0,0 +1,901 @@ +// Shared.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2006-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-August-02 19:41:01> +// +// ------------------------------------------------------------------ +// +// This module defines some shared utility classes and methods. +// +// Created: Tue, 27 Mar 2007 15:30 +// + +using System; +using System.IO; +using System.Security.Permissions; + +namespace Ionic.Zip +{ + /// + /// Collects general purpose utility methods. + /// + internal static class SharedUtilities + { + /// private null constructor + //private SharedUtilities() { } + + // workitem 8423 + public static Int64 GetFileLength(string fileName) + { + if (!File.Exists(fileName)) + throw new System.IO.FileNotFoundException(fileName); + + long fileLength = 0L; + FileShare fs = FileShare.ReadWrite; +#if !NETCF + // FileShare.Delete is not defined for the Compact Framework + fs |= FileShare.Delete; +#endif + using (var s = File.Open(fileName, FileMode.Open, FileAccess.Read, fs)) + { + fileLength = s.Length; + } + return fileLength; + } + + + [System.Diagnostics.Conditional("NETCF")] + public static void Workaround_Ladybug318918(Stream s) + { + // This is a workaround for this issue: + // https://connect.microsoft.com/VisualStudio/feedback/details/318918 + // It's required only on NETCF. + s.Flush(); + } + + +#if LEGACY + /// + /// Round the given DateTime value to an even second value. + /// + /// + /// + /// + /// Round up in the case of an odd second value. The rounding does not consider + /// fractional seconds. + /// + /// + /// This is useful because the Zip spec allows storage of time only to the nearest + /// even second. So if you want to compare the time of an entry in the archive with + /// it's actual time in the filesystem, you need to round the actual filesystem + /// time, or use a 2-second threshold for the comparison. + /// + /// + /// This is most nautrally an extension method for the DateTime class but this + /// library is built for .NET 2.0, not for .NET 3.5; This means extension methods + /// are a no-no. + /// + /// + /// The DateTime value to round + /// The ruonded DateTime value + public static DateTime RoundToEvenSecond(DateTime source) + { + // round to nearest second: + if ((source.Second % 2) == 1) + source += new TimeSpan(0, 0, 1); + + DateTime dtRounded = new DateTime(source.Year, source.Month, source.Day, source.Hour, source.Minute, source.Second); + //if (source.Millisecond >= 500) dtRounded = dtRounded.AddSeconds(1); + return dtRounded; + } +#endif + +#if YOU_LIKE_REDUNDANT_CODE + internal static string NormalizePath(string path) + { + // remove leading single dot slash + if (path.StartsWith(".\\")) path = path.Substring(2); + + // remove intervening dot-slash + path = path.Replace("\\.\\", "\\"); + + // remove double dot when preceded by a directory name + var re = new System.Text.RegularExpressions.Regex(@"^(.*\\)?([^\\\.]+\\\.\.\\)(.+)$"); + path = re.Replace(path, "$1$3"); + return path; + } +#endif + + private static System.Text.RegularExpressions.Regex doubleDotRegex1 = + new System.Text.RegularExpressions.Regex(@"^(.*/)?([^/\\.]+/\\.\\./)(.+)$"); + + private static string SimplifyFwdSlashPath(string path) + { + if (path.StartsWith("./")) path = path.Substring(2); + path = path.Replace("/./", "/"); + + // Replace foo/anything/../bar with foo/bar + path = doubleDotRegex1.Replace(path, "$1$3"); + return path; + } + + + /// + /// Utility routine for transforming path names from filesystem format (on Windows that means backslashes) to + /// a format suitable for use within zipfiles. This means trimming the volume letter and colon (if any) And + /// swapping backslashes for forward slashes. + /// + /// source path. + /// transformed path + public static string NormalizePathForUseInZipFile(string pathName) + { + // boundary case + if (String.IsNullOrEmpty(pathName)) return pathName; + + // trim volume if necessary + if ((pathName.Length >= 2) && ((pathName[1] == ':') && (pathName[2] == '\\'))) + pathName = pathName.Substring(3); + + // swap slashes + pathName = pathName.Replace('\\', '/'); + + // trim all leading slashes + while (pathName.StartsWith("/")) pathName = pathName.Substring(1); + + return SimplifyFwdSlashPath(pathName); + } + + + static System.Text.Encoding ibm437 = System.Text.Encoding.GetEncoding("IBM437"); + static System.Text.Encoding utf8 = System.Text.Encoding.GetEncoding("UTF-8"); + + internal static byte[] StringToByteArray(string value, System.Text.Encoding encoding) + { + byte[] a = encoding.GetBytes(value); + return a; + } + internal static byte[] StringToByteArray(string value) + { + return StringToByteArray(value, ibm437); + } + + //internal static byte[] Utf8StringToByteArray(string value) + //{ + // return StringToByteArray(value, utf8); + //} + + //internal static string StringFromBuffer(byte[] buf, int maxlength) + //{ + // return StringFromBuffer(buf, maxlength, ibm437); + //} + + internal static string Utf8StringFromBuffer(byte[] buf) + { + return StringFromBuffer(buf, utf8); + } + + internal static string StringFromBuffer(byte[] buf, System.Text.Encoding encoding) + { + // this form of the GetString() method is required for .NET CF compatibility + string s = encoding.GetString(buf, 0, buf.Length); + return s; + } + + + internal static int ReadSignature(System.IO.Stream s) + { + int x = 0; + try { x = _ReadFourBytes(s, "n/a"); } + catch (BadReadException) { } + return x; + } + + + internal static int ReadEntrySignature(System.IO.Stream s) + { + // handle the case of ill-formatted zip archives - includes a data descriptor + // when none is expected. + int x = 0; + try + { + x = _ReadFourBytes(s, "n/a"); + if (x == ZipConstants.ZipEntryDataDescriptorSignature) + { + // advance past data descriptor - 12 bytes if not zip64 + s.Seek(12, SeekOrigin.Current); + // workitem 10178 + Workaround_Ladybug318918(s); + x = _ReadFourBytes(s, "n/a"); + if (x != ZipConstants.ZipEntrySignature) + { + // Maybe zip64 was in use for the prior entry. + // Therefore, skip another 8 bytes. + s.Seek(8, SeekOrigin.Current); + // workitem 10178 + Workaround_Ladybug318918(s); + x = _ReadFourBytes(s, "n/a"); + if (x != ZipConstants.ZipEntrySignature) + { + // seek back to the first spot + s.Seek(-24, SeekOrigin.Current); + // workitem 10178 + Workaround_Ladybug318918(s); + x = _ReadFourBytes(s, "n/a"); + } + } + } + } + catch (BadReadException) { } + return x; + } + + + internal static int ReadInt(System.IO.Stream s) + { + return _ReadFourBytes(s, "Could not read block - no data! (position 0x{0:X8})"); + } + + private static int _ReadFourBytes(System.IO.Stream s, string message) + { + int n = 0; + byte[] block = new byte[4]; +#if NETCF + // workitem 9181 + // Reading here in NETCF sometimes reads "backwards". Seems to happen for + // larger files. Not sure why. Maybe an error in caching. If the data is: + // + // 00100210: 9efa 0f00 7072 6f6a 6563 742e 6963 7750 ....project.icwP + // 00100220: 4b05 0600 0000 0006 0006 0091 0100 008e K............... + // 00100230: 0010 0000 00 ..... + // + // ...and the stream Position is 10021F, then a Read of 4 bytes is returning + // 50776369, instead of 06054b50. This seems to happen the 2nd time Read() + // is called from that Position.. + // + // submitted to connect.microsoft.com + // https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=318918#tabs + // + for (int i = 0; i < block.Length; i++) + { + n+= s.Read(block, i, 1); + } +#else + n = s.Read(block, 0, block.Length); +#endif + if (n != block.Length) throw new BadReadException(String.Format(message, s.Position)); + int data = unchecked((((block[3] * 256 + block[2]) * 256) + block[1]) * 256 + block[0]); + return data; + } + + + + /// + /// Finds a signature in the zip stream. This is useful for finding + /// the end of a zip entry, for example, or the beginning of the next ZipEntry. + /// + /// + /// + /// + /// Scans through 64k at a time. + /// + /// + /// + /// If the method fails to find the requested signature, the stream Position + /// after completion of this method is unchanged. If the method succeeds in + /// finding the requested signature, the stream position after completion is + /// direct AFTER the signature found in the stream. + /// + /// + /// + /// The stream to search + /// The 4-byte signature to find + /// The number of bytes read + internal static long FindSignature(System.IO.Stream stream, int SignatureToFind) + { + long startingPosition = stream.Position; + + int BATCH_SIZE = 65536; // 8192; + byte[] targetBytes = new byte[4]; + targetBytes[0] = (byte)(SignatureToFind >> 24); + targetBytes[1] = (byte)((SignatureToFind & 0x00FF0000) >> 16); + targetBytes[2] = (byte)((SignatureToFind & 0x0000FF00) >> 8); + targetBytes[3] = (byte)(SignatureToFind & 0x000000FF); + byte[] batch = new byte[BATCH_SIZE]; + int n = 0; + bool success = false; + do + { + n = stream.Read(batch, 0, batch.Length); + if (n != 0) + { + for (int i = 0; i < n; i++) + { + if (batch[i] == targetBytes[3]) + { + long curPosition = stream.Position; + stream.Seek(i - n, System.IO.SeekOrigin.Current); + // workitem 10178 + Workaround_Ladybug318918(stream); + + // workitem 7711 + int sig = ReadSignature(stream); + + success = (sig == SignatureToFind); + if (!success) + { + stream.Seek(curPosition, System.IO.SeekOrigin.Begin); + // workitem 10178 + Workaround_Ladybug318918(stream); + } + else + break; // out of for loop + } + } + } + else break; + if (success) break; + + } while (true); + + if (!success) + { + stream.Seek(startingPosition, System.IO.SeekOrigin.Begin); + // workitem 10178 + Workaround_Ladybug318918(stream); + return -1; // or throw? + } + + // subtract 4 for the signature. + long bytesRead = (stream.Position - startingPosition) - 4; + + return bytesRead; + } + + + // If I have a time in the .NET environment, and I want to use it for + // SetWastWriteTime() etc, then I need to adjust it for Win32. + internal static DateTime AdjustTime_Reverse(DateTime time) + { + if (time.Kind == DateTimeKind.Utc) return time; + DateTime adjusted = time; + if (DateTime.Now.IsDaylightSavingTime() && !time.IsDaylightSavingTime()) + adjusted = time - new System.TimeSpan(1, 0, 0); + + else if (!DateTime.Now.IsDaylightSavingTime() && time.IsDaylightSavingTime()) + adjusted = time + new System.TimeSpan(1, 0, 0); + + return adjusted; + } + +#if NECESSARY + // If I read a time from a file with GetLastWriteTime() (etc), I need + // to adjust it for display in the .NET environment. + internal static DateTime AdjustTime_Forward(DateTime time) + { + if (time.Kind == DateTimeKind.Utc) return time; + DateTime adjusted = time; + if (DateTime.Now.IsDaylightSavingTime() && !time.IsDaylightSavingTime()) + adjusted = time + new System.TimeSpan(1, 0, 0); + + else if (!DateTime.Now.IsDaylightSavingTime() && time.IsDaylightSavingTime()) + adjusted = time - new System.TimeSpan(1, 0, 0); + + return adjusted; + } +#endif + + + internal static DateTime PackedToDateTime(Int32 packedDateTime) + { + // workitem 7074 & workitem 7170 + if (packedDateTime == 0xFFFF || packedDateTime == 0) + return new System.DateTime(1995, 1, 1, 0, 0, 0, 0); // return a fixed date when none is supplied. + + Int16 packedTime = unchecked((Int16)(packedDateTime & 0x0000ffff)); + Int16 packedDate = unchecked((Int16)((packedDateTime & 0xffff0000) >> 16)); + + int year = 1980 + ((packedDate & 0xFE00) >> 9); + int month = (packedDate & 0x01E0) >> 5; + int day = packedDate & 0x001F; + + int hour = (packedTime & 0xF800) >> 11; + int minute = (packedTime & 0x07E0) >> 5; + //int second = packedTime & 0x001F; + int second = (packedTime & 0x001F) * 2; + + // validation and error checking. + // this is not foolproof but will catch most errors. + if (second >= 60) { minute++; second = 0; } + if (minute >= 60) { hour++; minute = 0; } + if (hour >= 24) { day++; hour = 0; } + + DateTime d = System.DateTime.Now; + bool success= false; + try + { + d = new System.DateTime(year, month, day, hour, minute, second, 0); + success= true; + } + catch (System.ArgumentOutOfRangeException) + { + if (year == 1980 && (month == 0 || day == 0)) + { + try + { + d = new System.DateTime(1980, 1, 1, hour, minute, second, 0); + success= true; + } + catch (System.ArgumentOutOfRangeException) + { + try + { + d = new System.DateTime(1980, 1, 1, 0, 0, 0, 0); + success= true; + } + catch (System.ArgumentOutOfRangeException) { } + + } + } + // workitem 8814 + // my god, I can't believe how many different ways applications + // can mess up a simple date format. + else + { + try + { + while (year < 1980) year++; + while (year > 2030) year--; + while (month < 1) month++; + while (month > 12) month--; + while (day < 1) day++; + while (day > 28) day--; + while (minute < 0) minute++; + while (minute > 59) minute--; + while (second < 0) second++; + while (second > 59) second--; + d = new System.DateTime(year, month, day, hour, minute, second, 0); + success= true; + } + catch (System.ArgumentOutOfRangeException) { } + } + } + if (!success) + { + string msg = String.Format("y({0}) m({1}) d({2}) h({3}) m({4}) s({5})", year, month, day, hour, minute, second); + throw new ZipException(String.Format("Bad date/time format in the zip file. ({0})", msg)); + + } + // workitem 6191 + //d = AdjustTime_Reverse(d); + d = DateTime.SpecifyKind(d, DateTimeKind.Local); + return d; + } + + + internal + static Int32 DateTimeToPacked(DateTime time) + { + // The time is passed in here only for purposes of writing LastModified to the + // zip archive. It should always be LocalTime, but we convert anyway. And, + // since the time is being written out, it needs to be adjusted. + + time = time.ToLocalTime(); + // workitem 7966 + //time = AdjustTime_Forward(time); + + // see http://www.vsft.com/hal/dostime.htm for the format + UInt16 packedDate = (UInt16)((time.Day & 0x0000001F) | ((time.Month << 5) & 0x000001E0) | (((time.Year - 1980) << 9) & 0x0000FE00)); + UInt16 packedTime = (UInt16)((time.Second / 2 & 0x0000001F) | ((time.Minute << 5) & 0x000007E0) | ((time.Hour << 11) & 0x0000F800)); + + Int32 result = (Int32)(((UInt32)(packedDate << 16)) | packedTime); + return result; + } + + + /// + /// Create a pseudo-random filename, suitable for use as a temporary + /// file, and open it. + /// + /// + /// + /// The System.IO.Path.GetRandomFileName() method is not available on + /// the Compact Framework, so this library provides its own substitute + /// on NETCF. + /// + /// + /// This method produces a filename of the form + /// DotNetZip-xxxxxxxx.tmp, where xxxxxxxx is replaced by randomly + /// chosen characters, and creates that file. + /// + /// + public static void CreateAndOpenUniqueTempFile(string dir, + out Stream fs, + out string filename) + { + // workitem 9763 + // http://dotnet.org.za/markn/archive/2006/04/15/51594.aspx + // try 3 times: + for (int i = 0; i < 3; i++) + { + try + { + filename = Path.Combine(dir, InternalGetTempFileName()); + fs = new FileStream(filename, FileMode.CreateNew); + return; + } + catch (IOException) + { + if (i == 2) throw; + } + } + throw new IOException(); + } + +#if NETCF || SILVERLIGHT + public static string InternalGetTempFileName() + { + return "DotNetZip-" + GenerateRandomStringImpl(8,0) + ".tmp"; + } + + internal static string GenerateRandomStringImpl(int length, int delta) + { + bool WantMixedCase = (delta == 0); + System.Random rnd = new System.Random(); + + string result = ""; + char[] a = new char[length]; + + for (int i = 0; i < length; i++) + { + // delta == 65 means uppercase + // delta == 97 means lowercase + if (WantMixedCase) + delta = (rnd.Next(2) == 0) ? 65 : 97; + a[i] = (char)(rnd.Next(26) + delta); + } + + result = new System.String(a); + return result; + } +#else + public static string InternalGetTempFileName() + { + return "DotNetZip-" + Path.GetRandomFileName().Substring(0, 8) + ".tmp"; + } + +#endif + + + /// + /// Workitem 7889: handle ERROR_LOCK_VIOLATION during read + /// + /// + /// This could be gracefully handled with an extension attribute, but + /// This assembly is built for .NET 2.0, so I cannot use them. + /// + internal static int ReadWithRetry(System.IO.Stream s, byte[] buffer, int offset, int count, string FileName) + { + int n = 0; + bool done = false; +#if !NETCF && !SILVERLIGHT + int retries = 0; +#endif + do + { + try + { + n = s.Read(buffer, offset, count); + done = true; + } +#if NETCF || SILVERLIGHT + catch (System.IO.IOException) + { + throw; + } +#else + catch (System.IO.IOException ioexc1) + { + // Check if we can call GetHRForException, + // which makes unmanaged code calls. + var p = new SecurityPermission(SecurityPermissionFlag.UnmanagedCode); + if (p.IsUnrestricted()) + { + uint hresult = _HRForException(ioexc1); + if (hresult != 0x80070021) // ERROR_LOCK_VIOLATION + throw new System.IO.IOException(String.Format("Cannot read file {0}", FileName), ioexc1); + retries++; + if (retries > 10) + throw new System.IO.IOException(String.Format("Cannot read file {0}, at offset 0x{1:X8} after 10 retries", FileName, offset), ioexc1); + + // max time waited on last retry = 250 + 10*550 = 5.75s + // aggregate time waited after 10 retries: 250 + 55*550 = 30.5s + System.Threading.Thread.Sleep(250 + retries * 550); + } + else + { + // The permission.Demand() failed. Therefore, we cannot call + // GetHRForException, and cannot do the subtle handling of + // ERROR_LOCK_VIOLATION. Just bail. + throw; + } + } +#endif + } + while (!done); + + return n; + } + + +#if !NETCF + // workitem 8009 + // + // This method must remain separate. + // + // Marshal.GetHRForException() is needed to do special exception handling for + // the read. But, that method requires UnmanagedCode permissions, and is marked + // with LinkDemand for UnmanagedCode. In an ASP.NET medium trust environment, + // where UnmanagedCode is restricted, will generate a SecurityException at the + // time of JIT of the method that calls a method that is marked with LinkDemand + // for UnmanagedCode. The SecurityException, if it is restricted, will occur + // when this method is JITed. + // + // The Marshal.GetHRForException() is factored out of ReadWithRetry in order to + // avoid the SecurityException at JIT compile time. Because _HRForException is + // called only when the UnmanagedCode is allowed. This means .NET never + // JIT-compiles this method when UnmanagedCode is disallowed, and thus never + // generates the JIT-compile time exception. + // +#endif + private static uint _HRForException(System.Exception ex1) + { + return unchecked((uint)System.Runtime.InteropServices.Marshal.GetHRForException(ex1)); + } + + } + + + + /// + /// A decorator stream. It wraps another stream, and performs bookkeeping + /// to keep track of the stream Position. + /// + /// + /// + /// In some cases, it is not possible to get the Position of a stream, let's + /// say, on a write-only output stream like ASP.NET's + /// Response.OutputStream, or on a different write-only stream + /// provided as the destination for the zip by the application. In this + /// case, programmers can use this counting stream to count the bytes read + /// or written. + /// + /// + /// Consider the scenario of an application that saves a self-extracting + /// archive (SFX), that uses a custom SFX stub. + /// + /// + /// Saving to a filesystem file, the application would open the + /// filesystem file (getting a FileStream), save the custom sfx stub + /// into it, and then call ZipFile.Save(), specifying the same + /// FileStream. ZipFile.Save() does the right thing for the zipentry + /// offsets, by inquiring the Position of the FileStream before writing + /// any data, and then adding that initial offset into any ZipEntry + /// offsets in the zip directory. Everything works fine. + /// + /// + /// Now suppose the application is an ASPNET application and it saves + /// directly to Response.OutputStream. It's not possible for DotNetZip to + /// inquire the Position, so the offsets for the SFX will be wrong. + /// + /// + /// The workaround is for the application to use this class to wrap + /// HttpResponse.OutputStream, then write the SFX stub and the ZipFile + /// into that wrapper stream. Because ZipFile.Save() can inquire the + /// Position, it will then do the right thing with the offsets. + /// + /// + public class CountingStream : System.IO.Stream + { + // workitem 12374: this class is now public + private System.IO.Stream _s; + private Int64 _bytesWritten; + private Int64 _bytesRead; + private Int64 _initialOffset; + + /// + /// The constructor. + /// + /// The underlying stream + public CountingStream(System.IO.Stream stream) + : base() + { + _s = stream; + try + { + _initialOffset = _s.Position; + } + catch + { + _initialOffset = 0L; + } + } + + /// + /// Gets the wrapped stream. + /// + public Stream WrappedStream + { + get + { + return _s; + } + } + + /// + /// The count of bytes written out to the stream. + /// + public Int64 BytesWritten + { + get { return _bytesWritten; } + } + + /// + /// the count of bytes that have been read from the stream. + /// + public Int64 BytesRead + { + get { return _bytesRead; } + } + + /// + /// Adjust the byte count on the stream. + /// + /// + /// + /// the number of bytes to subtract from the count. + /// + /// + /// + /// + /// Subtract delta from the count of bytes written to the stream. + /// This is necessary when seeking back, and writing additional data, + /// as happens in some cases when saving Zip files. + /// + /// + public void Adjust(Int64 delta) + { + _bytesWritten -= delta; + if (_bytesWritten < 0) + throw new InvalidOperationException(); + if (_s as CountingStream != null) + ((CountingStream)_s).Adjust(delta); + } + + /// + /// The read method. + /// + /// The buffer to hold the data read from the stream. + /// the offset within the buffer to copy the first byte read. + /// the number of bytes to read. + /// the number of bytes read, after decryption and decompression. + public override int Read(byte[] buffer, int offset, int count) + { + int n = _s.Read(buffer, offset, count); + _bytesRead += n; + return n; + } + + /// + /// Write data into the stream. + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + if (count == 0) return; + _s.Write(buffer, offset, count); + _bytesWritten += count; + } + + /// + /// Whether the stream can be read. + /// + public override bool CanRead + { + get { return _s.CanRead; } + } + + /// + /// Whether it is possible to call Seek() on the stream. + /// + public override bool CanSeek + { + get { return _s.CanSeek; } + } + + /// + /// Whether it is possible to call Write() on the stream. + /// + public override bool CanWrite + { + get { return _s.CanWrite; } + } + + /// + /// Flushes the underlying stream. + /// + public override void Flush() + { + _s.Flush(); + } + + /// + /// The length of the underlying stream. + /// + public override long Length + { + get { return _s.Length; } // bytesWritten?? + } + + /// + /// Returns the sum of number of bytes written, plus the initial + /// offset before writing. + /// + public long ComputedPosition + { + get { return _initialOffset + _bytesWritten; } + } + + + /// + /// The Position of the stream. + /// + public override long Position + { + get { return _s.Position; } + set + { + _s.Seek(value, System.IO.SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_s); + } + } + + /// + /// Seek in the stream. + /// + /// the offset point to seek to + /// the reference point from which to seek + /// The new position + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + return _s.Seek(offset, origin); + } + + /// + /// Set the length of the underlying stream. Be careful with this! + /// + /// + /// the length to set on the underlying stream. + public override void SetLength(long value) + { + _s.SetLength(value); + } + } + + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/WinZipAes.cs b/Resources/Libraries/DotNetZip/Source/Zip/WinZipAes.cs new file mode 100644 index 00000000..0654742c --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/WinZipAes.cs @@ -0,0 +1,941 @@ +//#define Trace + +// WinZipAes.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-12 13:42:06> +// +// ------------------------------------------------------------------ +// +// This module defines the classes for dealing with WinZip's AES encryption, +// according to the specifications for the format available on WinZip's website. +// +// Created: January 2009 +// +// ------------------------------------------------------------------ + +using System; +using System.IO; +using System.Collections.Generic; +using System.Security.Cryptography; + +#if AESCRYPTO +namespace Ionic.Zip +{ + /// + /// This is a helper class supporting WinZip AES encryption. + /// This class is intended for use only by the DotNetZip library. + /// + /// + /// + /// Most uses of the DotNetZip library will not involve direct calls into + /// the WinZipAesCrypto class. Instead, the WinZipAesCrypto class is + /// instantiated and used by the ZipEntry() class when WinZip AES + /// encryption or decryption on an entry is employed. + /// + internal class WinZipAesCrypto + { + internal byte[] _Salt; + internal byte[] _providedPv; + internal byte[] _generatedPv; + internal int _KeyStrengthInBits; + private byte[] _MacInitializationVector; + private byte[] _StoredMac; + private byte[] _keyBytes; + private Int16 PasswordVerificationStored; + private Int16 PasswordVerificationGenerated; + private int Rfc2898KeygenIterations = 1000; + private string _Password; + private bool _cryptoGenerated ; + + private WinZipAesCrypto(string password, int KeyStrengthInBits) + { + _Password = password; + _KeyStrengthInBits = KeyStrengthInBits; + } + + public static WinZipAesCrypto Generate(string password, int KeyStrengthInBits) + { + WinZipAesCrypto c = new WinZipAesCrypto(password, KeyStrengthInBits); + + int saltSizeInBytes = c._KeyStrengthInBytes / 2; + c._Salt = new byte[saltSizeInBytes]; + Random rnd = new Random(); + rnd.NextBytes(c._Salt); + return c; + } + + + + public static WinZipAesCrypto ReadFromStream(string password, int KeyStrengthInBits, Stream s) + { + // from http://www.winzip.com/aes_info.htm + // + // Size(bytes) Content + // ----------------------------------- + // Variable Salt value + // 2 Password verification value + // Variable Encrypted file data + // 10 Authentication code + // + // ZipEntry.CompressedSize represents the size of all of those elements. + + // salt size varies with key length: + // 128 bit key => 8 bytes salt + // 192 bits => 12 bytes salt + // 256 bits => 16 bytes salt + + WinZipAesCrypto c = new WinZipAesCrypto(password, KeyStrengthInBits); + + int saltSizeInBytes = c._KeyStrengthInBytes / 2; + c._Salt = new byte[saltSizeInBytes]; + c._providedPv = new byte[2]; + + s.Read(c._Salt, 0, c._Salt.Length); + s.Read(c._providedPv, 0, c._providedPv.Length); + + c.PasswordVerificationStored = (Int16)(c._providedPv[0] + c._providedPv[1] * 256); + if (password != null) + { + c.PasswordVerificationGenerated = (Int16)(c.GeneratedPV[0] + c.GeneratedPV[1] * 256); + if (c.PasswordVerificationGenerated != c.PasswordVerificationStored) + throw new BadPasswordException("bad password"); + } + + return c; + } + + public byte[] GeneratedPV + { + get + { + if (!_cryptoGenerated) _GenerateCryptoBytes(); + return _generatedPv; + } + } + + + public byte[] Salt + { + get + { + return _Salt; + } + } + + + private int _KeyStrengthInBytes + { + get + { + return _KeyStrengthInBits / 8; + + } + } + + public int SizeOfEncryptionMetadata + { + get + { + // 10 bytes after, (n-10) before the compressed data + return _KeyStrengthInBytes / 2 + 10 + 2; + } + } + + public string Password + { + set + { + _Password = value; + if (_Password != null) + { + PasswordVerificationGenerated = (Int16)(GeneratedPV[0] + GeneratedPV[1] * 256); + if (PasswordVerificationGenerated != PasswordVerificationStored) + throw new Ionic.Zip.BadPasswordException(); + } + } + private get + { + return _Password; + } + } + + + private void _GenerateCryptoBytes() + { + //Console.WriteLine(" provided password: '{0}'", _Password); + + System.Security.Cryptography.Rfc2898DeriveBytes rfc2898 = + new System.Security.Cryptography.Rfc2898DeriveBytes(_Password, Salt, Rfc2898KeygenIterations); + + _keyBytes = rfc2898.GetBytes(_KeyStrengthInBytes); // 16 or 24 or 32 ??? + _MacInitializationVector = rfc2898.GetBytes(_KeyStrengthInBytes); + _generatedPv = rfc2898.GetBytes(2); + + _cryptoGenerated = true; + } + + + public byte[] KeyBytes + { + get + { + if (!_cryptoGenerated) _GenerateCryptoBytes(); + return _keyBytes; + } + } + + + public byte[] MacIv + { + get + { + if (!_cryptoGenerated) _GenerateCryptoBytes(); + return _MacInitializationVector; + } + } + + public byte[] CalculatedMac; + + + public void ReadAndVerifyMac(System.IO.Stream s) + { + bool invalid = false; + + // read integrityCheckVector. + // caller must ensure that the file pointer is in the right spot! + _StoredMac = new byte[10]; // aka "authentication code" + s.Read(_StoredMac, 0, _StoredMac.Length); + + if (_StoredMac.Length != CalculatedMac.Length) + invalid = true; + + if (!invalid) + { + for (int i = 0; i < _StoredMac.Length; i++) + { + if (_StoredMac[i] != CalculatedMac[i]) + invalid = true; + } + } + + if (invalid) + throw new Ionic.Zip.BadStateException("The MAC does not match."); + } + + } + + + #region DONT_COMPILE_BUT_KEEP_FOR_POTENTIAL_FUTURE_USE +#if NO + internal class Util + { + private static void _Format(System.Text.StringBuilder sb1, + byte[] b, + int offset, + int length) + { + + System.Text.StringBuilder sb2 = new System.Text.StringBuilder(); + sb1.Append("0000 "); + int i; + for (i = 0; i < length; i++) + { + int x = offset+i; + if (i != 0 && i % 16 == 0) + { + sb1.Append(" ") + .Append(sb2) + .Append("\n") + .Append(String.Format("{0:X4} ", i)); + sb2.Remove(0,sb2.Length); + } + sb1.Append(System.String.Format("{0:X2} ", b[x])); + if (b[x] >=32 && b[x] <= 126) + sb2.Append((char)b[x]); + else + sb2.Append("."); + } + if (sb2.Length > 0) + { + sb1.Append(new String(' ', ((16 - i%16) * 3) + 4)) + .Append(sb2); + } + } + + + + internal static string FormatByteArray(byte[] b, int limit) + { + System.Text.StringBuilder sb1 = new System.Text.StringBuilder(); + + if ((limit * 2 > b.Length) || limit == 0) + { + _Format(sb1, b, 0, b.Length); + } + else + { + // first N bytes of the buffer + _Format(sb1, b, 0, limit); + + if (b.Length > limit * 2) + sb1.Append(String.Format("\n ...({0} other bytes here)....\n", b.Length - limit * 2)); + + // last N bytes of the buffer + _Format(sb1, b, b.Length - limit, limit); + } + + return sb1.ToString(); + } + + + internal static string FormatByteArray(byte[] b) + { + return FormatByteArray(b, 0); + } + } + +#endif + #endregion + + + + + /// + /// A stream that encrypts as it writes, or decrypts as it reads. The + /// Crypto is AES in CTR (counter) mode, which is compatible with the AES + /// encryption employed by WinZip 12.0. + /// + /// + /// + /// The AES/CTR encryption protocol used by WinZip works like this: + /// + /// - start with a counter, initialized to zero. + /// + /// - to encrypt, take the data by 16-byte blocks. For each block: + /// - apply the transform to the counter + /// - increement the counter + /// - XOR the result of the transform with the plaintext to + /// get the ciphertext. + /// - compute the mac on the encrypted bytes + /// - when finished with all blocks, store the computed MAC. + /// + /// - to decrypt, take the data by 16-byte blocks. For each block: + /// - compute the mac on the encrypted bytes, + /// - apply the transform to the counter + /// - increement the counter + /// - XOR the result of the transform with the ciphertext to + /// get the plaintext. + /// - when finished with all blocks, compare the computed MAC against + /// the stored MAC + /// + /// + /// + // + internal class WinZipAesCipherStream : Stream + { + private WinZipAesCrypto _params; + private System.IO.Stream _s; + private CryptoMode _mode; + private int _nonce; + private bool _finalBlock; + + internal HMACSHA1 _mac; + + // Use RijndaelManaged from .NET 2.0. + // AesManaged came in .NET 3.5, but we want to limit + // dependency to .NET 2.0. AES is just a restricted form + // of Rijndael (fixed block size of 128, some crypto modes not supported). + + internal RijndaelManaged _aesCipher; + internal ICryptoTransform _xform; + + private const int BLOCK_SIZE_IN_BYTES = 16; + + private byte[] counter = new byte[BLOCK_SIZE_IN_BYTES]; + private byte[] counterOut = new byte[BLOCK_SIZE_IN_BYTES]; + + // I've had a problem when wrapping a WinZipAesCipherStream inside + // a DeflateStream. Calling Read() on the DeflateStream results in + // a Read() on the WinZipAesCipherStream, but the buffer is larger + // than the total size of the encrypted data, and larger than the + // initial Read() on the DeflateStream! When the encrypted + // bytestream is embedded within a larger stream (As in a zip + // archive), the Read() doesn't fail with EOF. This causes bad + // data to be returned, and it messes up the MAC. + + // This field is used to provide a hard-stop to the size of + // data that can be read from the stream. In Read(), if the buffer or + // read request goes beyond the stop, we truncate it. + + private long _length; + private long _totalBytesXferred; + private byte[] _PendingWriteBlock; + private int _pendingCount; + private byte[] _iobuf; + + /// + /// The constructor. + /// + /// The underlying stream + /// To either encrypt or decrypt. + /// The pre-initialized WinZipAesCrypto object. + /// The maximum number of bytes to read from the stream. + internal WinZipAesCipherStream(System.IO.Stream s, WinZipAesCrypto cryptoParams, long length, CryptoMode mode) + : this(s, cryptoParams, mode) + { + // don't read beyond this limit! + _length = length; + //Console.WriteLine("max length of AES stream: {0}", _length); + } + + +#if WANT_TRACE + Stream untransformed; + String traceFileUntransformed; + Stream transformed; + String traceFileTransformed; +#endif + + + internal WinZipAesCipherStream(System.IO.Stream s, WinZipAesCrypto cryptoParams, CryptoMode mode) + : base() + { + TraceOutput("-------------------------------------------------------"); + TraceOutput("Create {0:X8}", this.GetHashCode()); + + _params = cryptoParams; + _s = s; + _mode = mode; + _nonce = 1; + + if (_params == null) + throw new BadPasswordException("Supply a password to use AES encryption."); + + int keySizeInBits = _params.KeyBytes.Length * 8; + if (keySizeInBits != 256 && keySizeInBits != 128 && keySizeInBits != 192) + throw new ArgumentOutOfRangeException("keysize", + "size of key must be 128, 192, or 256"); + + _mac = new HMACSHA1(_params.MacIv); + + _aesCipher = new System.Security.Cryptography.RijndaelManaged(); + _aesCipher.BlockSize = 128; + _aesCipher.KeySize = keySizeInBits; // 128, 192, 256 + _aesCipher.Mode = CipherMode.ECB; + _aesCipher.Padding = PaddingMode.None; + + byte[] iv = new byte[BLOCK_SIZE_IN_BYTES]; // all zeroes + + // Create an ENCRYPTOR, regardless whether doing decryption or encryption. + // It is reflexive. + _xform = _aesCipher.CreateEncryptor(_params.KeyBytes, iv); + + if (_mode == CryptoMode.Encrypt) + { + _iobuf = new byte[2048]; + _PendingWriteBlock = new byte[BLOCK_SIZE_IN_BYTES]; + } + + +#if WANT_TRACE + traceFileUntransformed = "unpack\\WinZipAesCipherStream.trace.untransformed.out"; + traceFileTransformed = "unpack\\WinZipAesCipherStream.trace.transformed.out"; + + untransformed = System.IO.File.Create(traceFileUntransformed); + transformed = System.IO.File.Create(traceFileTransformed); +#endif + } + + private void XorInPlace(byte[] buffer, int offset, int count) + { + for (int i = 0; i < count; i++) + { + buffer[offset + i] = (byte)(counterOut[i] ^ buffer[offset + i]); + } + } + + private void WriteTransformOneBlock(byte[] buffer, int offset) + { + System.Array.Copy(BitConverter.GetBytes(_nonce++), 0, counter, 0, 4); + _xform.TransformBlock(counter, + 0, + BLOCK_SIZE_IN_BYTES, + counterOut, + 0); + XorInPlace(buffer, offset, BLOCK_SIZE_IN_BYTES); + _mac.TransformBlock(buffer, offset, BLOCK_SIZE_IN_BYTES, null, 0); + } + + + private void WriteTransformBlocks(byte[] buffer, int offset, int count) + { + int posn = offset; + int last = count + offset; + + while (posn < buffer.Length && posn < last) + { + WriteTransformOneBlock (buffer, posn); + posn += BLOCK_SIZE_IN_BYTES; + } + } + + + private void WriteTransformFinalBlock() + { + if (_pendingCount == 0) + throw new InvalidOperationException("No bytes available."); + + if (_finalBlock) + throw new InvalidOperationException("The final block has already been transformed."); + + System.Array.Copy(BitConverter.GetBytes(_nonce++), 0, counter, 0, 4); + counterOut = _xform.TransformFinalBlock(counter, + 0, + BLOCK_SIZE_IN_BYTES); + XorInPlace(_PendingWriteBlock, 0, _pendingCount); + _mac.TransformFinalBlock(_PendingWriteBlock, 0, _pendingCount); + _finalBlock = true; + } + + + + + + private int ReadTransformOneBlock(byte[] buffer, int offset, int last) + { + if (_finalBlock) + throw new NotSupportedException(); + + int bytesRemaining = last - offset; + int bytesToRead = (bytesRemaining > BLOCK_SIZE_IN_BYTES) + ? BLOCK_SIZE_IN_BYTES + : bytesRemaining; + + // update the counter + System.Array.Copy(BitConverter.GetBytes(_nonce++), 0, counter, 0, 4); + + // Determine if this is the final block + if ((bytesToRead == bytesRemaining) && + (_length > 0) && + (_totalBytesXferred + last == _length)) + { + _mac.TransformFinalBlock(buffer, offset, bytesToRead); + counterOut = _xform.TransformFinalBlock(counter, + 0, + BLOCK_SIZE_IN_BYTES); + _finalBlock = true; + } + else + { + _mac.TransformBlock(buffer, offset, bytesToRead, null, 0); + _xform.TransformBlock(counter, + 0, // offset + BLOCK_SIZE_IN_BYTES, + counterOut, + 0); // offset + } + + XorInPlace(buffer, offset, bytesToRead); + return bytesToRead; + } + + + + private void ReadTransformBlocks(byte[] buffer, int offset, int count) + { + int posn = offset; + int last = count + offset; + + while (posn < buffer.Length && posn < last ) + { + int n = ReadTransformOneBlock (buffer, posn, last); + posn += n; + } + } + + + + public override int Read(byte[] buffer, int offset, int count) + { + if (_mode == CryptoMode.Encrypt) + throw new NotSupportedException(); + + if (buffer == null) + throw new ArgumentNullException("buffer"); + + if (offset < 0) + throw new ArgumentOutOfRangeException("offset", + "Must not be less than zero."); + if (count < 0) + throw new ArgumentOutOfRangeException("count", + "Must not be less than zero."); + + if (buffer.Length < offset + count) + throw new ArgumentException("The buffer is too small"); + + // When I wrap a WinZipAesStream in a DeflateStream, the + // DeflateStream asks its captive to read 4k blocks, even if the + // encrypted bytestream is smaller than that. This is a way to + // limit the number of bytes read. + + int bytesToRead = count; + + if (_totalBytesXferred >= _length) + { + return 0; // EOF + } + + long bytesRemaining = _length - _totalBytesXferred; + if (bytesRemaining < count) bytesToRead = (int)bytesRemaining; + + int n = _s.Read(buffer, offset, bytesToRead); + + +#if WANT_TRACE + untransformed.Write(buffer, offset, bytesToRead); +#endif + + ReadTransformBlocks(buffer, offset, bytesToRead); + +#if WANT_TRACE + transformed.Write(buffer, offset, bytesToRead); +#endif + _totalBytesXferred += n; + return n; + } + + + + /// + /// Returns the final HMAC-SHA1-80 for the data that was encrypted. + /// + public byte[] FinalAuthentication + { + get + { + if (!_finalBlock) + { + // special-case zero-byte files + if ( _totalBytesXferred != 0) + throw new BadStateException("The final hash has not been computed."); + + // Must call ComputeHash on an empty byte array when no data + // has run through the MAC. + + byte[] b = { }; + _mac.ComputeHash(b); + // fall through + } + byte[] macBytes10 = new byte[10]; + System.Array.Copy(_mac.Hash, 0, macBytes10, 0, 10); + return macBytes10; + } + } + + + public override void Write(byte[] buffer, int offset, int count) + { + if (_finalBlock) + throw new InvalidOperationException("The final block has already been transformed."); + + if (_mode == CryptoMode.Decrypt) + throw new NotSupportedException(); + + if (buffer == null) + throw new ArgumentNullException("buffer"); + + if (offset < 0) + throw new ArgumentOutOfRangeException("offset", + "Must not be less than zero."); + if (count < 0) + throw new ArgumentOutOfRangeException("count", + "Must not be less than zero."); + if (buffer.Length < offset + count) + throw new ArgumentException("The offset and count are too large"); + + if (count == 0) + return; + + TraceOutput("Write off({0}) count({1})", offset, count); + +#if WANT_TRACE + untransformed.Write(buffer, offset, count); +#endif + + // For proper AES encryption, an AES encryptor application calls + // TransformBlock repeatedly for all 16-byte blocks except the + // last. For the last block, it then calls TransformFinalBlock(). + // + // This class is a stream that encrypts via Write(). But, it's not + // possible to recognize which are the "last" bytes from within the call + // to Write(). The caller can call Write() several times in succession, + // with varying buffers. This class only "knows" that the last bytes + // have been written when the app calls Close(). + // + // Therefore, this class buffers writes: After completion every Write(), + // a 16-byte "pending" block (_PendingWriteBlock) must hold between 1 + // and 16 bytes, which will be used in TransformFinalBlock if the app + // calls Close() immediately thereafter. Also, every write must + // transform any pending bytes, before transforming the data passed in + // to the current call. + // + // In operation, after the first call to Write() and before the call to + // Close(), one full or partial block of bytes is always available, + // pending. At time of Close(), this class calls + // WriteTransformFinalBlock() to flush the pending bytes. + // + // This approach works whether the caller writes in odd-sized batches, + // for example 5000 bytes, or in batches that are neat multiples of the + // blocksize (16). + // + // Logicaly, what we do is this: + // + // 1. if there are fewer than 16 bytes (pending + current), then + // just copy them into th pending buffer and return. + // + // 2. there are more than 16 bytes to write. So, take the leading slice + // of bytes from the current buffer, enough to fill the pending + // buffer. Transform the pending block, and write it out. + // + // 3. Take the trailing slice of bytes (a full block or a partial block), + // and copy it to the pending block for next time. + // + // 4. transform and write all the other blocks, the middle slice. + // + + // There are 16 or fewer bytes, so just buffer the bytes. + if (count + _pendingCount <= BLOCK_SIZE_IN_BYTES) + { + Buffer.BlockCopy(buffer, + offset, + _PendingWriteBlock, + _pendingCount, + count); + _pendingCount += count; + + // At this point, _PendingWriteBlock contains up to + // BLOCK_SIZE_IN_BYTES bytes, and _pendingCount ranges from 0 to + // BLOCK_SIZE_IN_BYTES. We don't want to xform+write them yet, + // because this may have been the last block. The last block gets + // written at Close(). + return; + } + + // We know there are at least 17 bytes, counting those in the current + // buffer, along with the (possibly empty) pending block. + + int bytesRemaining = count; + int curOffset = offset; + + // workitem 12815 + // + // xform chunkwise ... Cannot transform in place using the original + // buffer because that is user-maintained. + + if (_pendingCount != 0) + { + // We have more than one block of data to write, therefore it is safe + // to xform+write. + int fillCount = BLOCK_SIZE_IN_BYTES - _pendingCount; + + // fillCount is possibly zero here. That happens when the pending + // buffer held 16 bytes (one complete block) before this call to + // Write. + if (fillCount > 0) + { + Buffer.BlockCopy(buffer, + offset, + _PendingWriteBlock, + _pendingCount, + fillCount); + + // adjust counts: + bytesRemaining -= fillCount; + curOffset += fillCount; + } + + // xform and write: + WriteTransformOneBlock(_PendingWriteBlock, 0); + _s.Write(_PendingWriteBlock, 0, BLOCK_SIZE_IN_BYTES); + _totalBytesXferred += BLOCK_SIZE_IN_BYTES; + _pendingCount = 0; + } + + // At this point _PendingWriteBlock is empty, and bytesRemaining is + // always greater than 0. + + // Now, xform N blocks, where N = floor((bytesRemaining-1)/16). If + // writing 32 bytes, then xform 1 block, and stage the remaining 16. If + // writing 10037 bytes, xform 627 blocks of 16 bytes, then stage the + // remaining 5 bytes. + + int blocksToXform = (bytesRemaining-1)/BLOCK_SIZE_IN_BYTES; + _pendingCount = bytesRemaining - (blocksToXform * BLOCK_SIZE_IN_BYTES); + + // _pendingCount is ALWAYS between 1 and 16. + // Put the last _pendingCount bytes into the pending block. + Buffer.BlockCopy(buffer, + curOffset + bytesRemaining - _pendingCount, + _PendingWriteBlock, + 0, + _pendingCount); + bytesRemaining -= _pendingCount; + _totalBytesXferred += bytesRemaining; // will be true after the loop + + // now, transform all the full blocks preceding that. + // bytesRemaining is always a multiple of 16 . + if (blocksToXform > 0) + { + do + { + int c = _iobuf.Length; + if (c > bytesRemaining) c = bytesRemaining; + Buffer.BlockCopy(buffer, + curOffset, + _iobuf, + 0, + c); + + WriteTransformBlocks(_iobuf, 0, c); + _s.Write(_iobuf, 0, c); + bytesRemaining -= c; + curOffset += c; + } while(bytesRemaining > 0); + } + } + + + + /// + /// Close the stream. + /// + public override void Close() + { + TraceOutput("Close {0:X8}", this.GetHashCode()); + + // In the degenerate case, no bytes have been written to the + // stream at all. Need to check here, and NOT emit the + // final block if Write has not been called. + if (_pendingCount > 0) + { + WriteTransformFinalBlock(); + _s.Write(_PendingWriteBlock, 0, _pendingCount); + _totalBytesXferred += _pendingCount; + _pendingCount = 0; + } + _s.Close(); + +#if WANT_TRACE + untransformed.Close(); + transformed.Close(); + Console.WriteLine("\nuntransformed bytestream is in {0}", traceFileUntransformed); + Console.WriteLine("\ntransformed bytestream is in {0}", traceFileTransformed); +#endif + TraceOutput("-------------------------------------------------------"); + } + + + /// + /// Returns true if the stream can be read. + /// + public override bool CanRead + { + get + { + if (_mode != CryptoMode.Decrypt) return false; + return true; + } + } + + + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + /// + /// Returns true if the CryptoMode is Encrypt. + /// + public override bool CanWrite + { + get { return (_mode == CryptoMode.Encrypt); } + } + + /// + /// Flush the content in the stream. + /// + public override void Flush() + { + _s.Flush(); + } + + /// + /// Getting this property throws a NotImplementedException. + /// + public override long Length + { + get { throw new NotImplementedException(); } + } + + /// + /// Getting or Setting this property throws a NotImplementedException. + /// + public override long Position + { + get { throw new NotImplementedException(); } + set { throw new NotImplementedException(); } + } + + /// + /// This method throws a NotImplementedException. + /// + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotImplementedException(); + } + + /// + /// This method throws a NotImplementedException. + /// + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + + + [System.Diagnostics.ConditionalAttribute("Trace")] + private void TraceOutput(string format, params object[] varParams) + { + lock(_outputLock) + { + int tid = System.Threading.Thread.CurrentThread.GetHashCode(); + Console.ForegroundColor = (ConsoleColor) (tid % 8 + 8); + Console.Write("{0:000} WZACS ", tid); + Console.WriteLine(format, varParams); + Console.ResetColor(); + } + } + + private object _outputLock = new Object(); + } +} +#endif diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipConstants.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipConstants.cs new file mode 100644 index 00000000..d958d316 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipConstants.cs @@ -0,0 +1,51 @@ +// ZipConstants.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2006, 2007, 2008, 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-August-27 23:22:32> +// +// ------------------------------------------------------------------ +// +// This module defines a few constants that are used in the project. +// +// ------------------------------------------------------------------ + +using System; + +namespace Ionic.Zip +{ + static class ZipConstants + { + public const UInt32 PackedToRemovableMedia = 0x30304b50; + public const UInt32 Zip64EndOfCentralDirectoryRecordSignature = 0x06064b50; + public const UInt32 Zip64EndOfCentralDirectoryLocatorSignature = 0x07064b50; + public const UInt32 EndOfCentralDirectorySignature = 0x06054b50; + public const int ZipEntrySignature = 0x04034b50; + public const int ZipEntryDataDescriptorSignature = 0x08074b50; + public const int SplitArchiveSignature = 0x08074b50; + public const int ZipDirEntrySignature = 0x02014b50; + + + // These are dictated by the Zip Spec.See APPNOTE.txt + public const int AesKeySize = 192; // 128, 192, 256 + public const int AesBlockSize = 128; // ??? + + public const UInt16 AesAlgId128 = 0x660E; + public const UInt16 AesAlgId192 = 0x660F; + public const UInt16 AesAlgId256 = 0x6610; + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipCrypto.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipCrypto.cs new file mode 100644 index 00000000..7f94e455 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipCrypto.cs @@ -0,0 +1,455 @@ +// ZipCrypto.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2008, 2009, 2011 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-28 06:30:59> +// +// ------------------------------------------------------------------ +// +// This module provides the implementation for "traditional" Zip encryption. +// +// Created Tue Apr 15 17:39:56 2008 +// +// ------------------------------------------------------------------ + +using System; + +namespace Ionic.Zip +{ + /// + /// This class implements the "traditional" or "classic" PKZip encryption, + /// which today is considered to be weak. On the other hand it is + /// ubiquitous. This class is intended for use only by the DotNetZip + /// library. + /// + /// + /// + /// Most uses of the DotNetZip library will not involve direct calls into + /// the ZipCrypto class. Instead, the ZipCrypto class is instantiated and + /// used by the ZipEntry() class when encryption or decryption on an entry + /// is employed. If for some reason you really wanted to use a weak + /// encryption algorithm in some other application, you might use this + /// library. But you would be much better off using one of the built-in + /// strong encryption libraries in the .NET Framework, like the AES + /// algorithm or SHA. + /// + internal class ZipCrypto + { + /// + /// The default constructor for ZipCrypto. + /// + /// + /// + /// This class is intended for internal use by the library only. It's + /// probably not useful to you. Seriously. Stop reading this + /// documentation. It's a waste of your time. Go do something else. + /// Check the football scores. Go get an ice cream with a friend. + /// Seriously. + /// + /// + private ZipCrypto() { } + + public static ZipCrypto ForWrite(string password) + { + ZipCrypto z = new ZipCrypto(); + if (password == null) + throw new BadPasswordException("This entry requires a password."); + z.InitCipher(password); + return z; + } + + + public static ZipCrypto ForRead(string password, ZipEntry e) + { + System.IO.Stream s = e._archiveStream; + e._WeakEncryptionHeader = new byte[12]; + byte[] eh = e._WeakEncryptionHeader; + ZipCrypto z = new ZipCrypto(); + + if (password == null) + throw new BadPasswordException("This entry requires a password."); + + z.InitCipher(password); + + ZipEntry.ReadWeakEncryptionHeader(s, eh); + + // Decrypt the header. This has a side effect of "further initializing the + // encryption keys" in the traditional zip encryption. + byte[] DecryptedHeader = z.DecryptMessage(eh, eh.Length); + + // CRC check + // According to the pkzip spec, the final byte in the decrypted header + // is the highest-order byte in the CRC. We check it here. + if (DecryptedHeader[11] != (byte)((e._Crc32 >> 24) & 0xff)) + { + // In the case that bit 3 of the general purpose bit flag is set to + // indicate the presence of an 'Extended File Header' or a 'data + // descriptor' (signature 0x08074b50), the last byte of the decrypted + // header is sometimes compared with the high-order byte of the + // lastmodified time, rather than the high-order byte of the CRC, to + // verify the password. + // + // This is not documented in the PKWare Appnote.txt. It was + // discovered this by analysis of the Crypt.c source file in the + // InfoZip library http://www.info-zip.org/pub/infozip/ + // + // The reason for this is that the CRC for a file cannot be known + // until the entire contents of the file have been streamed. This + // means a tool would have to read the file content TWICE in its + // entirety in order to perform PKZIP encryption - once to compute + // the CRC, and again to actually encrypt. + // + // This is so important for performance that using the timeblob as + // the verification should be the standard practice for DotNetZip + // when using PKZIP encryption. This implies that bit 3 must be + // set. The downside is that some tools still cannot cope with ZIP + // files that use bit 3. Therefore, DotNetZip DOES NOT force bit 3 + // when PKZIP encryption is in use, and instead, reads the stream + // twice. + // + + if ((e._BitField & 0x0008) != 0x0008) + { + throw new BadPasswordException("The password did not match."); + } + else if (DecryptedHeader[11] != (byte)((e._TimeBlob >> 8) & 0xff)) + { + throw new BadPasswordException("The password did not match."); + } + + // We have a good password. + } + else + { + // A-OK + } + return z; + } + + + + + /// + /// From AppNote.txt: + /// unsigned char decrypt_byte() + /// local unsigned short temp + /// temp :=- Key(2) | 2 + /// decrypt_byte := (temp * (temp ^ 1)) bitshift-right 8 + /// end decrypt_byte + /// + private byte MagicByte + { + get + { + UInt16 t = (UInt16)((UInt16)(_Keys[2] & 0xFFFF) | 2); + return (byte)((t * (t ^ 1)) >> 8); + } + } + + // Decrypting: + // From AppNote.txt: + // loop for i from 0 to 11 + // C := buffer(i) ^ decrypt_byte() + // update_keys(C) + // buffer(i) := C + // end loop + + + /// + /// Call this method on a cipher text to render the plaintext. You must + /// first initialize the cipher with a call to InitCipher. + /// + /// + /// + /// + /// var cipher = new ZipCrypto(); + /// cipher.InitCipher(Password); + /// // Decrypt the header. This has a side effect of "further initializing the + /// // encryption keys" in the traditional zip encryption. + /// byte[] DecryptedMessage = cipher.DecryptMessage(EncryptedMessage); + /// + /// + /// + /// The encrypted buffer. + /// + /// The number of bytes to encrypt. + /// Should be less than or equal to CipherText.Length. + /// + /// + /// The plaintext. + public byte[] DecryptMessage(byte[] cipherText, int length) + { + if (cipherText == null) + throw new ArgumentNullException("cipherText"); + + if (length > cipherText.Length) + throw new ArgumentOutOfRangeException("length", + "Bad length during Decryption: the length parameter must be smaller than or equal to the size of the destination array."); + + byte[] plainText = new byte[length]; + for (int i = 0; i < length; i++) + { + byte C = (byte)(cipherText[i] ^ MagicByte); + UpdateKeys(C); + plainText[i] = C; + } + return plainText; + } + + /// + /// This is the converse of DecryptMessage. It encrypts the plaintext + /// and produces a ciphertext. + /// + /// + /// The plain text buffer. + /// + /// + /// The number of bytes to encrypt. + /// Should be less than or equal to plainText.Length. + /// + /// + /// The ciphertext. + public byte[] EncryptMessage(byte[] plainText, int length) + { + if (plainText == null) + throw new ArgumentNullException("plaintext"); + + if (length > plainText.Length) + throw new ArgumentOutOfRangeException("length", + "Bad length during Encryption: The length parameter must be smaller than or equal to the size of the destination array."); + + byte[] cipherText = new byte[length]; + for (int i = 0; i < length; i++) + { + byte C = plainText[i]; + cipherText[i] = (byte)(plainText[i] ^ MagicByte); + UpdateKeys(C); + } + return cipherText; + } + + + /// + /// This initializes the cipher with the given password. + /// See AppNote.txt for details. + /// + /// + /// + /// The passphrase for encrypting or decrypting with this cipher. + /// + /// + /// + /// + /// Step 1 - Initializing the encryption keys + /// ----------------------------------------- + /// Start with these keys: + /// Key(0) := 305419896 (0x12345678) + /// Key(1) := 591751049 (0x23456789) + /// Key(2) := 878082192 (0x34567890) + /// + /// Then, initialize the keys with a password: + /// + /// loop for i from 0 to length(password)-1 + /// update_keys(password(i)) + /// end loop + /// + /// Where update_keys() is defined as: + /// + /// update_keys(char): + /// Key(0) := crc32(key(0),char) + /// Key(1) := Key(1) + (Key(0) bitwiseAND 000000ffH) + /// Key(1) := Key(1) * 134775813 + 1 + /// Key(2) := crc32(key(2),key(1) rightshift 24) + /// end update_keys + /// + /// Where crc32(old_crc,char) is a routine that given a CRC value and a + /// character, returns an updated CRC value after applying the CRC-32 + /// algorithm described elsewhere in this document. + /// + /// + /// + /// + /// After the keys are initialized, then you can use the cipher to + /// encrypt the plaintext. + /// + /// + /// + /// Essentially we encrypt the password with the keys, then discard the + /// ciphertext for the password. This initializes the keys for later use. + /// + /// + /// + public void InitCipher(string passphrase) + { + byte[] p = SharedUtilities.StringToByteArray(passphrase); + for (int i = 0; i < passphrase.Length; i++) + UpdateKeys(p[i]); + } + + + private void UpdateKeys(byte byteValue) + { + _Keys[0] = (UInt32)crc32.ComputeCrc32((int)_Keys[0], byteValue); + _Keys[1] = _Keys[1] + (byte)_Keys[0]; + _Keys[1] = _Keys[1] * 0x08088405 + 1; + _Keys[2] = (UInt32)crc32.ComputeCrc32((int)_Keys[2], (byte)(_Keys[1] >> 24)); + } + + ///// + ///// The byte array representing the seed keys used. + ///// Get this after calling InitCipher. The 12 bytes represents + ///// what the zip spec calls the "EncryptionHeader". + ///// + //public byte[] KeyHeader + //{ + // get + // { + // byte[] result = new byte[12]; + // result[0] = (byte)(_Keys[0] & 0xff); + // result[1] = (byte)((_Keys[0] >> 8) & 0xff); + // result[2] = (byte)((_Keys[0] >> 16) & 0xff); + // result[3] = (byte)((_Keys[0] >> 24) & 0xff); + // result[4] = (byte)(_Keys[1] & 0xff); + // result[5] = (byte)((_Keys[1] >> 8) & 0xff); + // result[6] = (byte)((_Keys[1] >> 16) & 0xff); + // result[7] = (byte)((_Keys[1] >> 24) & 0xff); + // result[8] = (byte)(_Keys[2] & 0xff); + // result[9] = (byte)((_Keys[2] >> 8) & 0xff); + // result[10] = (byte)((_Keys[2] >> 16) & 0xff); + // result[11] = (byte)((_Keys[2] >> 24) & 0xff); + // return result; + // } + //} + + // private fields for the crypto stuff: + private UInt32[] _Keys = { 0x12345678, 0x23456789, 0x34567890 }; + private Ionic.Crc.CRC32 crc32 = new Ionic.Crc.CRC32(); + + } + + internal enum CryptoMode + { + Encrypt, + Decrypt + } + + /// + /// A Stream for reading and concurrently decrypting data from a zip file, + /// or for writing and concurrently encrypting data to a zip file. + /// + internal class ZipCipherStream : System.IO.Stream + { + private ZipCrypto _cipher; + private System.IO.Stream _s; + private CryptoMode _mode; + + /// The constructor. + /// The underlying stream + /// To either encrypt or decrypt. + /// The pre-initialized ZipCrypto object. + public ZipCipherStream(System.IO.Stream s, ZipCrypto cipher, CryptoMode mode) + : base() + { + _cipher = cipher; + _s = s; + _mode = mode; + } + + public override int Read(byte[] buffer, int offset, int count) + { + if (_mode == CryptoMode.Encrypt) + throw new NotSupportedException("This stream does not encrypt via Read()"); + + if (buffer == null) + throw new ArgumentNullException("buffer"); + + byte[] db = new byte[count]; + int n = _s.Read(db, 0, count); + byte[] decrypted = _cipher.DecryptMessage(db, n); + for (int i = 0; i < n; i++) + { + buffer[offset + i] = decrypted[i]; + } + return n; + } + + public override void Write(byte[] buffer, int offset, int count) + { + if (_mode == CryptoMode.Decrypt) + throw new NotSupportedException("This stream does not Decrypt via Write()"); + + if (buffer == null) + throw new ArgumentNullException("buffer"); + + // workitem 7696 + if (count == 0) return; + + byte[] plaintext = null; + if (offset != 0) + { + plaintext = new byte[count]; + for (int i = 0; i < count; i++) + { + plaintext[i] = buffer[offset + i]; + } + } + else plaintext = buffer; + + byte[] encrypted = _cipher.EncryptMessage(plaintext, count); + _s.Write(encrypted, 0, encrypted.Length); + } + + + public override bool CanRead + { + get { return (_mode == CryptoMode.Decrypt); } + } + public override bool CanSeek + { + get { return false; } + } + + public override bool CanWrite + { + get { return (_mode == CryptoMode.Encrypt); } + } + + public override void Flush() + { + //throw new NotSupportedException(); + } + + public override long Length + { + get { throw new NotSupportedException(); } + } + + public override long Position + { + get { throw new NotSupportedException(); } + set { throw new NotSupportedException(); } + } + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotSupportedException(); + } + + public override void SetLength(long value) + { + throw new NotSupportedException(); + } + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipDirEntry.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipDirEntry.cs new file mode 100644 index 00000000..6c67236a --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipDirEntry.cs @@ -0,0 +1,381 @@ +// ZipDirEntry.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2006-2011 Dino Chiesa . +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-11 12:03:03> +// +// ------------------------------------------------------------------ +// +// This module defines members of the ZipEntry class for reading the +// Zip file central directory. +// +// Created: Tue, 27 Mar 2007 15:30 +// +// ------------------------------------------------------------------ + + +using System; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + + partial class ZipEntry + { + /// + /// True if the referenced entry is a directory. + /// + internal bool AttributesIndicateDirectory + { + get { return ((_InternalFileAttrs == 0) && ((_ExternalFileAttrs & 0x0010) == 0x0010)); } + } + + + internal void ResetDirEntry() + { + // __FileDataPosition is the position of the file data for an entry. + // It is _RelativeOffsetOfLocalHeader + size of local header. + + // We cannot know the __FileDataPosition until we read the local + // header. + + // The local header is not necessarily the same length as the record + // in the central directory. + + // Set to -1, to indicate we need to read this later. + this.__FileDataPosition = -1; + + // set _LengthOfHeader to 0, to indicate we need to read later. + this._LengthOfHeader = 0; + } + + /// + /// Provides a human-readable string with information about the ZipEntry. + /// + public string Info + { + get + { + var builder = new System.Text.StringBuilder(); + builder + .Append(string.Format(" ZipEntry: {0}\n", this.FileName)) + .Append(string.Format(" Version Made By: {0}\n", this._VersionMadeBy)) + .Append(string.Format(" Needed to extract: {0}\n", this.VersionNeeded)); + + if (this._IsDirectory) + builder.Append(" Entry type: directory\n"); + else + { + builder.Append(string.Format(" File type: {0}\n", this._IsText? "text":"binary")) + .Append(string.Format(" Compression: {0}\n", this.CompressionMethod)) + .Append(string.Format(" Compressed: 0x{0:X}\n", this.CompressedSize)) + .Append(string.Format(" Uncompressed: 0x{0:X}\n", this.UncompressedSize)) + .Append(string.Format(" CRC32: 0x{0:X8}\n", this._Crc32)); + } + builder.Append(string.Format(" Disk Number: {0}\n", this._diskNumber)); + if (this._RelativeOffsetOfLocalHeader > 0xFFFFFFFF) + builder + .Append(string.Format(" Relative Offset: 0x{0:X16}\n", this._RelativeOffsetOfLocalHeader)); + else + builder + .Append(string.Format(" Relative Offset: 0x{0:X8}\n", this._RelativeOffsetOfLocalHeader)); + + builder + .Append(string.Format(" Bit Field: 0x{0:X4}\n", this._BitField)) + .Append(string.Format(" Encrypted?: {0}\n", this._sourceIsEncrypted)) + .Append(string.Format(" Timeblob: 0x{0:X8}\n", this._TimeBlob)) + .Append(string.Format(" Time: {0}\n", Ionic.Zip.SharedUtilities.PackedToDateTime(this._TimeBlob))); + + builder.Append(string.Format(" Is Zip64?: {0}\n", this._InputUsesZip64)); + if (!string.IsNullOrEmpty(this._Comment)) + { + builder.Append(string.Format(" Comment: {0}\n", this._Comment)); + } + builder.Append("\n"); + return builder.ToString(); + } + } + + + // workitem 10330 + private class CopyHelper + { + private static System.Text.RegularExpressions.Regex re = + new System.Text.RegularExpressions.Regex(" \\(copy (\\d+)\\)$"); + + private static int callCount = 0; + + internal static string AppendCopyToFileName(string f) + { + callCount++; + if (callCount > 25) + throw new OverflowException("overflow while creating filename"); + + int n = 1; + int r = f.LastIndexOf("."); + + if (r == -1) + { + // there is no extension + System.Text.RegularExpressions.Match m = re.Match(f); + if (m.Success) + { + n = Int32.Parse(m.Groups[1].Value) + 1; + string copy = String.Format(" (copy {0})", n); + f = f.Substring(0, m.Index) + copy; + } + else + { + string copy = String.Format(" (copy {0})", n); + f = f + copy; + } + } + else + { + //System.Console.WriteLine("HasExtension"); + System.Text.RegularExpressions.Match m = re.Match(f.Substring(0, r)); + if (m.Success) + { + n = Int32.Parse(m.Groups[1].Value) + 1; + string copy = String.Format(" (copy {0})", n); + f = f.Substring(0, m.Index) + copy + f.Substring(r); + } + else + { + string copy = String.Format(" (copy {0})", n); + f = f.Substring(0, r) + copy + f.Substring(r); + } + + //System.Console.WriteLine("returning f({0})", f); + } + return f; + } + } + + + + /// + /// Reads one entry from the zip directory structure in the zip file. + /// + /// + /// + /// The zipfile for which a directory entry will be read. From this param, the + /// method gets the ReadStream and the expected text encoding + /// (ProvisionalAlternateEncoding) which is used if the entry is not marked + /// UTF-8. + /// + /// + /// + /// a list of previously seen entry names; used to prevent duplicates. + /// + /// + /// the entry read from the archive. + internal static ZipEntry ReadDirEntry(ZipFile zf, + Dictionary previouslySeen) + { + System.IO.Stream s = zf.ReadStream; + System.Text.Encoding expectedEncoding = (zf.AlternateEncodingUsage == ZipOption.Always) + ? zf.AlternateEncoding + : ZipFile.DefaultEncoding; + + int signature = Ionic.Zip.SharedUtilities.ReadSignature(s); + // return null if this is not a local file header signature + if (IsNotValidZipDirEntrySig(signature)) + { + s.Seek(-4, System.IO.SeekOrigin.Current); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + + // Getting "not a ZipDirEntry signature" here is not always wrong or an + // error. This can happen when walking through a zipfile. After the + // last ZipDirEntry, we expect to read an + // EndOfCentralDirectorySignature. When we get this is how we know + // we've reached the end of the central directory. + if (signature != ZipConstants.EndOfCentralDirectorySignature && + signature != ZipConstants.Zip64EndOfCentralDirectoryRecordSignature && + signature != ZipConstants.ZipEntrySignature // workitem 8299 + ) + { + throw new BadReadException(String.Format(" Bad signature (0x{0:X8}) at position 0x{1:X8}", signature, s.Position)); + } + return null; + } + + int bytesRead = 42 + 4; + byte[] block = new byte[42]; + int n = s.Read(block, 0, block.Length); + if (n != block.Length) return null; + + int i = 0; + ZipEntry zde = new ZipEntry(); + zde.AlternateEncoding = expectedEncoding; + zde._Source = ZipEntrySource.ZipFile; + zde._container = new ZipContainer(zf); + + unchecked + { + zde._VersionMadeBy = (short)(block[i++] + block[i++] * 256); + zde._VersionNeeded = (short)(block[i++] + block[i++] * 256); + zde._BitField = (short)(block[i++] + block[i++] * 256); + zde._CompressionMethod = (Int16)(block[i++] + block[i++] * 256); + zde._TimeBlob = block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256; + zde._LastModified = Ionic.Zip.SharedUtilities.PackedToDateTime(zde._TimeBlob); + zde._timestamp |= ZipEntryTimestamp.DOS; + + zde._Crc32 = block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256; + zde._CompressedSize = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + zde._UncompressedSize = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + } + + // preserve + zde._CompressionMethod_FromZipFile = zde._CompressionMethod; + + zde._filenameLength = (short)(block[i++] + block[i++] * 256); + zde._extraFieldLength = (short)(block[i++] + block[i++] * 256); + zde._commentLength = (short)(block[i++] + block[i++] * 256); + zde._diskNumber = (UInt32)(block[i++] + block[i++] * 256); + + zde._InternalFileAttrs = (short)(block[i++] + block[i++] * 256); + zde._ExternalFileAttrs = block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256; + + zde._RelativeOffsetOfLocalHeader = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + + // workitem 7801 + zde.IsText = ((zde._InternalFileAttrs & 0x01) == 0x01); + + block = new byte[zde._filenameLength]; + n = s.Read(block, 0, block.Length); + bytesRead += n; + if ((zde._BitField & 0x0800) == 0x0800) + { + // UTF-8 is in use + zde._FileNameInArchive = Ionic.Zip.SharedUtilities.Utf8StringFromBuffer(block); + } + else + { + zde._FileNameInArchive = Ionic.Zip.SharedUtilities.StringFromBuffer(block, expectedEncoding); + } + + // workitem 10330 + // insure unique entry names + while (previouslySeen.ContainsKey(zde._FileNameInArchive)) + { + zde._FileNameInArchive = CopyHelper.AppendCopyToFileName(zde._FileNameInArchive); + zde._metadataChanged = true; + } + + if (zde.AttributesIndicateDirectory) + zde.MarkAsDirectory(); // may append a slash to filename if nec. + // workitem 6898 + else if (zde._FileNameInArchive.EndsWith("/")) zde.MarkAsDirectory(); + + zde._CompressedFileDataSize = zde._CompressedSize; + if ((zde._BitField & 0x01) == 0x01) + { + // this may change after processing the Extra field + zde._Encryption_FromZipFile = zde._Encryption = + EncryptionAlgorithm.PkzipWeak; + zde._sourceIsEncrypted = true; + } + + if (zde._extraFieldLength > 0) + { + zde._InputUsesZip64 = (zde._CompressedSize == 0xFFFFFFFF || + zde._UncompressedSize == 0xFFFFFFFF || + zde._RelativeOffsetOfLocalHeader == 0xFFFFFFFF); + + // Console.WriteLine(" Input uses Z64?: {0}", zde._InputUsesZip64); + + bytesRead += zde.ProcessExtraField(s, zde._extraFieldLength); + zde._CompressedFileDataSize = zde._CompressedSize; + } + + // we've processed the extra field, so we know the encryption method is set now. + if (zde._Encryption == EncryptionAlgorithm.PkzipWeak) + { + // the "encryption header" of 12 bytes precedes the file data + zde._CompressedFileDataSize -= 12; + } +#if AESCRYPTO + else if (zde.Encryption == EncryptionAlgorithm.WinZipAes128 || + zde.Encryption == EncryptionAlgorithm.WinZipAes256) + { + zde._CompressedFileDataSize = zde.CompressedSize - + (ZipEntry.GetLengthOfCryptoHeaderBytes(zde.Encryption) + 10); + zde._LengthOfTrailer = 10; + } +#endif + + // tally the trailing descriptor + if ((zde._BitField & 0x0008) == 0x0008) + { + // sig, CRC, Comp and Uncomp sizes + if (zde._InputUsesZip64) + zde._LengthOfTrailer += 24; + else + zde._LengthOfTrailer += 16; + } + + // workitem 12744 + zde.AlternateEncoding = ((zde._BitField & 0x0800) == 0x0800) + ? System.Text.Encoding.UTF8 + :expectedEncoding; + + zde.AlternateEncodingUsage = ZipOption.Always; + + if (zde._commentLength > 0) + { + block = new byte[zde._commentLength]; + n = s.Read(block, 0, block.Length); + bytesRead += n; + if ((zde._BitField & 0x0800) == 0x0800) + { + // UTF-8 is in use + zde._Comment = Ionic.Zip.SharedUtilities.Utf8StringFromBuffer(block); + } + else + { + zde._Comment = Ionic.Zip.SharedUtilities.StringFromBuffer(block, expectedEncoding); + } + } + //zde._LengthOfDirEntry = bytesRead; + return zde; + } + + + /// + /// Returns true if the passed-in value is a valid signature for a ZipDirEntry. + /// + /// the candidate 4-byte signature value. + /// true, if the signature is valid according to the PKWare spec. + internal static bool IsNotValidZipDirEntrySig(int signature) + { + return (signature != ZipConstants.ZipDirEntrySignature); + } + + + private Int16 _VersionMadeBy; + private Int16 _InternalFileAttrs; + private Int32 _ExternalFileAttrs; + + //private Int32 _LengthOfDirEntry; + private Int16 _filenameLength; + private Int16 _extraFieldLength; + private Int16 _commentLength; + } + + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Extract.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Extract.cs new file mode 100644 index 00000000..76cd9a7e --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Extract.cs @@ -0,0 +1,1456 @@ +// ZipEntry.Extract.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-06 18:08:21> +// +// ------------------------------------------------------------------ +// +// This module defines logic for Extract methods on the ZipEntry class. +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; + +namespace Ionic.Zip +{ + + public partial class ZipEntry + { + /// + /// Extract the entry to the filesystem, starting at the current + /// working directory. + /// + /// + /// + /// This method has a bunch of overloads! One of them is sure to + /// be the right one for you... If you don't like these, check + /// out the ExtractWithPassword() methods. + /// + /// + /// + /// + /// + /// + /// + /// + /// This method extracts an entry from a zip file into the current + /// working directory. The path of the entry as extracted is the full + /// path as specified in the zip archive, relative to the current + /// working directory. After the file is extracted successfully, the + /// file attributes and timestamps are set. + /// + /// + /// + /// The action taken when extraction an entry would overwrite an + /// existing file is determined by the property. + /// + /// + /// + /// Within the call to Extract(), the content for the entry is + /// written into a filesystem file, and then the last modified time of the + /// file is set according to the property on + /// the entry. See the remarks the property for + /// some details about the last modified time. + /// + /// + /// + public void Extract() + { + InternalExtract(".", null, null); + } + + + /// + /// Extract the entry to a file in the filesystem, using the specified + /// behavior when extraction would overwrite an existing file. + /// + /// + /// + /// + /// See the remarks on the property, for some + /// details about how the last modified time of the file is set after + /// extraction. + /// + /// + /// + /// + /// The action to take if extraction would overwrite an existing file. + /// + public void Extract(ExtractExistingFileAction extractExistingFile) + { + ExtractExistingFile = extractExistingFile; + InternalExtract(".", null, null); + } + + /// + /// Extracts the entry to the specified stream. + /// + /// + /// + /// + /// The caller can specify any write-able stream, for example a , a , or ASP.NET's + /// Response.OutputStream. The content will be decrypted and + /// decompressed as necessary. If the entry is encrypted and no password + /// is provided, this method will throw. + /// + /// + /// The position on the stream is not reset by this method before it extracts. + /// You may want to call stream.Seek() before calling ZipEntry.Extract(). + /// + /// + /// + /// + /// the stream to which the entry should be extracted. + /// + /// + public void Extract(Stream stream) + { + InternalExtract(null, stream, null); + } + + /// + /// Extract the entry to the filesystem, starting at the specified base + /// directory. + /// + /// + /// the pathname of the base directory + /// + /// + /// + /// + /// + /// This example extracts only the entries in a zip file that are .txt files, + /// into a directory called "textfiles". + /// + /// using (ZipFile zip = ZipFile.Read("PackedDocuments.zip")) + /// { + /// foreach (string s1 in zip.EntryFilenames) + /// { + /// if (s1.EndsWith(".txt")) + /// { + /// zip[s1].Extract("textfiles"); + /// } + /// } + /// } + /// + /// + /// Using zip As ZipFile = ZipFile.Read("PackedDocuments.zip") + /// Dim s1 As String + /// For Each s1 In zip.EntryFilenames + /// If s1.EndsWith(".txt") Then + /// zip(s1).Extract("textfiles") + /// End If + /// Next + /// End Using + /// + /// + /// + /// + /// + /// + /// Using this method, existing entries in the filesystem will not be + /// overwritten. If you would like to force the overwrite of existing + /// files, see the property, or call + /// . + /// + /// + /// + /// See the remarks on the property, for some + /// details about how the last modified time of the created file is set. + /// + /// + public void Extract(string baseDirectory) + { + InternalExtract(baseDirectory, null, null); + } + + + + + + /// + /// Extract the entry to the filesystem, starting at the specified base + /// directory, and using the specified behavior when extraction would + /// overwrite an existing file. + /// + /// + /// + /// + /// See the remarks on the property, for some + /// details about how the last modified time of the created file is set. + /// + /// + /// + /// + /// + /// String sZipPath = "Airborne.zip"; + /// String sFilePath = "Readme.txt"; + /// String sRootFolder = "Digado"; + /// using (ZipFile zip = ZipFile.Read(sZipPath)) + /// { + /// if (zip.EntryFileNames.Contains(sFilePath)) + /// { + /// // use the string indexer on the zip file + /// zip[sFileName].Extract(sRootFolder, + /// ExtractExistingFileAction.OverwriteSilently); + /// } + /// } + /// + /// + /// + /// Dim sZipPath as String = "Airborne.zip" + /// Dim sFilePath As String = "Readme.txt" + /// Dim sRootFolder As String = "Digado" + /// Using zip As ZipFile = ZipFile.Read(sZipPath) + /// If zip.EntryFileNames.Contains(sFilePath) + /// ' use the string indexer on the zip file + /// zip(sFilePath).Extract(sRootFolder, _ + /// ExtractExistingFileAction.OverwriteSilently) + /// End If + /// End Using + /// + /// + /// + /// the pathname of the base directory + /// + /// The action to take if extraction would overwrite an existing file. + /// + public void Extract(string baseDirectory, ExtractExistingFileAction extractExistingFile) + { + ExtractExistingFile = extractExistingFile; + InternalExtract(baseDirectory, null, null); + } + + + /// + /// Extract the entry to the filesystem, using the current working directory + /// and the specified password. + /// + /// + /// + /// This method has a bunch of overloads! One of them is sure to be + /// the right one for you... + /// + /// + /// + /// + /// + /// + /// + /// + /// Existing entries in the filesystem will not be overwritten. If you + /// would like to force the overwrite of existing files, see the property, or call + /// . + /// + /// + /// + /// See the remarks on the property for some + /// details about how the "last modified" time of the created file is + /// set. + /// + /// + /// + /// + /// In this example, entries that use encryption are extracted using a + /// particular password. + /// + /// using (var zip = ZipFile.Read(FilePath)) + /// { + /// foreach (ZipEntry e in zip) + /// { + /// if (e.UsesEncryption) + /// e.ExtractWithPassword("Secret!"); + /// else + /// e.Extract(); + /// } + /// } + /// + /// + /// Using zip As ZipFile = ZipFile.Read(FilePath) + /// Dim e As ZipEntry + /// For Each e In zip + /// If (e.UsesEncryption) + /// e.ExtractWithPassword("Secret!") + /// Else + /// e.Extract + /// End If + /// Next + /// End Using + /// + /// + /// The Password to use for decrypting the entry. + public void ExtractWithPassword(string password) + { + InternalExtract(".", null, password); + } + + /// + /// Extract the entry to the filesystem, starting at the specified base + /// directory, and using the specified password. + /// + /// + /// + /// + /// + /// + /// + /// Existing entries in the filesystem will not be overwritten. If you + /// would like to force the overwrite of existing files, see the property, or call + /// . + /// + /// + /// + /// See the remarks on the property, for some + /// details about how the last modified time of the created file is set. + /// + /// + /// + /// The pathname of the base directory. + /// The Password to use for decrypting the entry. + public void ExtractWithPassword(string baseDirectory, string password) + { + InternalExtract(baseDirectory, null, password); + } + + + + + /// + /// Extract the entry to a file in the filesystem, relative to the + /// current directory, using the specified behavior when extraction + /// would overwrite an existing file. + /// + /// + /// + /// + /// See the remarks on the property, for some + /// details about how the last modified time of the created file is set. + /// + /// + /// + /// The Password to use for decrypting the entry. + /// + /// + /// The action to take if extraction would overwrite an existing file. + /// + public void ExtractWithPassword(ExtractExistingFileAction extractExistingFile, string password) + { + ExtractExistingFile = extractExistingFile; + InternalExtract(".", null, password); + } + + + + /// + /// Extract the entry to the filesystem, starting at the specified base + /// directory, and using the specified behavior when extraction would + /// overwrite an existing file. + /// + /// + /// + /// See the remarks on the property, for some + /// details about how the last modified time of the created file is set. + /// + /// + /// the pathname of the base directory + /// + /// The action to take if extraction would + /// overwrite an existing file. + /// + /// The Password to use for decrypting the entry. + public void ExtractWithPassword(string baseDirectory, ExtractExistingFileAction extractExistingFile, string password) + { + ExtractExistingFile = extractExistingFile; + InternalExtract(baseDirectory, null, password); + } + + /// + /// Extracts the entry to the specified stream, using the specified + /// Password. For example, the caller could extract to Console.Out, or + /// to a MemoryStream. + /// + /// + /// + /// + /// The caller can specify any write-able stream, for example a , a , or ASP.NET's + /// Response.OutputStream. The content will be decrypted and + /// decompressed as necessary. If the entry is encrypted and no password + /// is provided, this method will throw. + /// + /// + /// The position on the stream is not reset by this method before it extracts. + /// You may want to call stream.Seek() before calling ZipEntry.Extract(). + /// + /// + /// + /// + /// + /// the stream to which the entry should be extracted. + /// + /// + /// The password to use for decrypting the entry. + /// + public void ExtractWithPassword(Stream stream, string password) + { + InternalExtract(null, stream, password); + } + + + /// + /// Opens a readable stream corresponding to the zip entry in the + /// archive. The stream decompresses and decrypts as necessary, as it + /// is read. + /// + /// + /// + /// + /// + /// DotNetZip offers a variety of ways to extract entries from a zip + /// file. This method allows an application to extract an entry by + /// reading a . + /// + /// + /// + /// The return value is of type . Use it as you would any + /// stream for reading. When an application calls on that stream, it will + /// receive data from the zip entry that is decrypted and decompressed + /// as necessary. + /// + /// + /// + /// CrcCalculatorStream adds one additional feature: it keeps a + /// CRC32 checksum on the bytes of the stream as it is read. The CRC + /// value is available in the property on the + /// CrcCalculatorStream. When the read is complete, your + /// application + /// should check this CRC against the + /// property on the ZipEntry to validate the content of the + /// ZipEntry. You don't have to validate the entry using the CRC, but + /// you should, to verify integrity. Check the example for how to do + /// this. + /// + /// + /// + /// If the entry is protected with a password, then you need to provide + /// a password prior to calling , either by + /// setting the property on the entry, or the + /// property on the ZipFile + /// itself. Or, you can use , the + /// overload of OpenReader that accepts a password parameter. + /// + /// + /// + /// If you want to extract entry data into a write-able stream that is + /// already opened, like a , do not + /// use this method. Instead, use . + /// + /// + /// + /// Your application may use only one stream created by OpenReader() at + /// a time, and you should not call other Extract methods before + /// completing your reads on a stream obtained from OpenReader(). This + /// is because there is really only one source stream for the compressed + /// content. A call to OpenReader() seeks in the source stream, to the + /// beginning of the compressed content. A subsequent call to + /// OpenReader() on a different entry will seek to a different position + /// in the source stream, as will a call to Extract() or one of its + /// overloads. This will corrupt the state for the decompressing stream + /// from the original call to OpenReader(). + /// + /// + /// + /// The OpenReader() method works only when the ZipEntry is + /// obtained from an instance of ZipFile. This method will throw + /// an exception if the ZipEntry is obtained from a . + /// + /// + /// + /// + /// This example shows how to open a zip archive, then read in a named + /// entry via a stream. After the read loop is complete, the code + /// compares the calculated during the read loop with the expected CRC + /// on the ZipEntry, to verify the extraction. + /// + /// using (ZipFile zip = new ZipFile(ZipFileToRead)) + /// { + /// ZipEntry e1= zip["Elevation.mp3"]; + /// using (Ionic.Zlib.CrcCalculatorStream s = e1.OpenReader()) + /// { + /// byte[] buffer = new byte[4096]; + /// int n, totalBytesRead= 0; + /// do { + /// n = s.Read(buffer,0, buffer.Length); + /// totalBytesRead+=n; + /// } while (n>0); + /// if (s.Crc32 != e1.Crc32) + /// throw new Exception(string.Format("The Zip Entry failed the CRC Check. (0x{0:X8}!=0x{1:X8})", s.Crc32, e1.Crc32)); + /// if (totalBytesRead != e1.UncompressedSize) + /// throw new Exception(string.Format("We read an unexpected number of bytes. ({0}!={1})", totalBytesRead, e1.UncompressedSize)); + /// } + /// } + /// + /// + /// Using zip As New ZipFile(ZipFileToRead) + /// Dim e1 As ZipEntry = zip.Item("Elevation.mp3") + /// Using s As Ionic.Zlib.CrcCalculatorStream = e1.OpenReader + /// Dim n As Integer + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim totalBytesRead As Integer = 0 + /// Do + /// n = s.Read(buffer, 0, buffer.Length) + /// totalBytesRead = (totalBytesRead + n) + /// Loop While (n > 0) + /// If (s.Crc32 <> e1.Crc32) Then + /// Throw New Exception(String.Format("The Zip Entry failed the CRC Check. (0x{0:X8}!=0x{1:X8})", s.Crc32, e1.Crc32)) + /// End If + /// If (totalBytesRead <> e1.UncompressedSize) Then + /// Throw New Exception(String.Format("We read an unexpected number of bytes. ({0}!={1})", totalBytesRead, e1.UncompressedSize)) + /// End If + /// End Using + /// End Using + /// + /// + /// + /// The Stream for reading. + public Ionic.Crc.CrcCalculatorStream OpenReader() + { + // workitem 10923 + if (_container.ZipFile == null) + throw new InvalidOperationException("Use OpenReader() only with ZipFile."); + + // use the entry password if it is non-null, + // else use the zipfile password, which is possibly null + return InternalOpenReader(this._Password ?? this._container.Password); + } + + /// + /// Opens a readable stream for an encrypted zip entry in the archive. + /// The stream decompresses and decrypts as necessary, as it is read. + /// + /// + /// + /// + /// See the documentation on the method for + /// full details. This overload allows the application to specify a + /// password for the ZipEntry to be read. + /// + /// + /// + /// The password to use for decrypting the entry. + /// The Stream for reading. + public Ionic.Crc.CrcCalculatorStream OpenReader(string password) + { + // workitem 10923 + if (_container.ZipFile == null) + throw new InvalidOperationException("Use OpenReader() only with ZipFile."); + + return InternalOpenReader(password); + } + + + + internal Ionic.Crc.CrcCalculatorStream InternalOpenReader(string password) + { + ValidateCompression(); + ValidateEncryption(); + SetupCryptoForExtract(password); + + // workitem 7958 + if (this._Source != ZipEntrySource.ZipFile) + throw new BadStateException("You must call ZipFile.Save before calling OpenReader"); + + // LeftToRead is a count of bytes remaining to be read (out) + // from the stream AFTER decompression and decryption. + // It is the uncompressed size, unless ... there is no compression in which + // case ...? :< I'm not sure why it's not always UncompressedSize + Int64 LeftToRead = (_CompressionMethod_FromZipFile == (short)CompressionMethod.None) + ? this._CompressedFileDataSize + : this.UncompressedSize; + + Stream input = this.ArchiveStream; + + this.ArchiveStream.Seek(this.FileDataPosition, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + + _inputDecryptorStream = GetExtractDecryptor(input); + Stream input3 = GetExtractDecompressor(_inputDecryptorStream); + + return new Ionic.Crc.CrcCalculatorStream(input3, LeftToRead); + } + + + + private void OnExtractProgress(Int64 bytesWritten, Int64 totalBytesToWrite) + { + if (_container.ZipFile != null) + _ioOperationCanceled = _container.ZipFile.OnExtractBlock(this, bytesWritten, totalBytesToWrite); + } + + + private void OnBeforeExtract(string path) + { + // When in the context of a ZipFile.ExtractAll, the events are generated from + // the ZipFile method, not from within the ZipEntry instance. (why?) + // Therefore we suppress the events originating from the ZipEntry method. + if (_container.ZipFile != null) + { + if (!_container.ZipFile._inExtractAll) + { + _ioOperationCanceled = _container.ZipFile.OnSingleEntryExtract(this, path, true); + } + } + } + + private void OnAfterExtract(string path) + { + // When in the context of a ZipFile.ExtractAll, the events are generated from + // the ZipFile method, not from within the ZipEntry instance. (why?) + // Therefore we suppress the events originating from the ZipEntry method. + if (_container.ZipFile != null) + { + if (!_container.ZipFile._inExtractAll) + { + _container.ZipFile.OnSingleEntryExtract(this, path, false); + } + } + } + + private void OnExtractExisting(string path) + { + if (_container.ZipFile != null) + _ioOperationCanceled = _container.ZipFile.OnExtractExisting(this, path); + } + + private static void ReallyDelete(string fileName) + { + // workitem 7881 + // reset ReadOnly bit if necessary +#if NETCF + if ( (NetCfFile.GetAttributes(fileName) & (uint)FileAttributes.ReadOnly) == (uint)FileAttributes.ReadOnly) + NetCfFile.SetAttributes(fileName, (uint)FileAttributes.Normal); +#elif SILVERLIGHT +#else + if ((File.GetAttributes(fileName) & FileAttributes.ReadOnly) == FileAttributes.ReadOnly) + File.SetAttributes(fileName, FileAttributes.Normal); +#endif + File.Delete(fileName); + } + + + private void WriteStatus(string format, params Object[] args) + { + if (_container.ZipFile != null && _container.ZipFile.Verbose) _container.ZipFile.StatusMessageTextWriter.WriteLine(format, args); + } + + + // Pass in either basedir or s, but not both. + // In other words, you can extract to a stream or to a directory (filesystem), but not both! + // The Password param is required for encrypted entries. + private void InternalExtract(string baseDir, Stream outstream, string password) + { + // workitem 7958 + if (_container == null) + throw new BadStateException("This entry is an orphan"); + + // workitem 10355 + if (_container.ZipFile == null) + throw new InvalidOperationException("Use Extract() only with ZipFile."); + + _container.ZipFile.Reset(false); + + if (this._Source != ZipEntrySource.ZipFile) + throw new BadStateException("You must call ZipFile.Save before calling any Extract method"); + + OnBeforeExtract(baseDir); + _ioOperationCanceled = false; + string targetFileName = null; + Stream output = null; + bool fileExistsBeforeExtraction = false; + bool checkLaterForResetDirTimes = false; + try + { + ValidateCompression(); + ValidateEncryption(); + + if (ValidateOutput(baseDir, outstream, out targetFileName)) + { + WriteStatus("extract dir {0}...", targetFileName); + // if true, then the entry was a directory and has been created. + // We need to fire the Extract Event. + OnAfterExtract(baseDir); + return; + } + + // workitem 10639 + // do we want to extract to a regular filesystem file? + if (targetFileName != null) + { + // Check for extracting to a previously extant file. The user + // can specify bejavior for that case: overwrite, don't + // overwrite, and throw. Also, if the file exists prior to + // extraction, it affects exception handling: whether to delete + // the target of extraction or not. This check needs to be done + // before the password check is done, because password check may + // throw a BadPasswordException, which triggers the catch, + // wherein the extant file may be deleted if not flagged as + // pre-existing. + if (File.Exists(targetFileName)) + { + fileExistsBeforeExtraction = true; + int rc = CheckExtractExistingFile(baseDir, targetFileName); + if (rc == 2) goto ExitTry; // cancel + if (rc == 1) return; // do not overwrite + } + } + + // If no password explicitly specified, use the password on the entry itself, + // or on the zipfile itself. + string p = password ?? this._Password ?? this._container.Password; + if (_Encryption_FromZipFile != EncryptionAlgorithm.None) + { + if (p == null) + throw new BadPasswordException(); + SetupCryptoForExtract(p); + } + + + // set up the output stream + if (targetFileName != null) + { + WriteStatus("extract file {0}...", targetFileName); + targetFileName += ".tmp"; + var dirName = Path.GetDirectoryName(targetFileName); + // ensure the target path exists + if (!Directory.Exists(dirName)) + { + // we create the directory here, but we do not set the + // create/modified/accessed times on it because it is being + // created implicitly, not explcitly. There's no entry in the + // zip archive for the directory. + Directory.CreateDirectory(dirName); + } + else + { + // workitem 8264 + if (_container.ZipFile != null) + checkLaterForResetDirTimes = _container.ZipFile._inExtractAll; + } + + // File.Create(CreateNew) will overwrite any existing file. + output = new FileStream(targetFileName, FileMode.CreateNew); + } + else + { + WriteStatus("extract entry {0} to stream...", FileName); + output = outstream; + } + + + if (_ioOperationCanceled) + goto ExitTry; + + Int32 ActualCrc32 = ExtractOne(output); + + if (_ioOperationCanceled) + goto ExitTry; + + VerifyCrcAfterExtract(ActualCrc32); + + if (targetFileName != null) + { + output.Close(); + output = null; + + // workitem 10639 + // move file to permanent home + string tmpName = targetFileName; + string zombie = null; + targetFileName = tmpName.Substring(0,tmpName.Length-4); + + if (fileExistsBeforeExtraction) + { + // An AV program may hold the target file open, which means + // File.Delete() will succeed, though the actual deletion + // remains pending. This will prevent a subsequent + // File.Move() from succeeding. To avoid this, when the file + // already exists, we need to replace it in 3 steps: + // + // 1. rename the existing file to a zombie name; + // 2. rename the extracted file from the temp name to + // the target file name; + // 3. delete the zombie. + // + zombie = targetFileName + ".PendingOverwrite"; + File.Move(targetFileName, zombie); + } + + File.Move(tmpName, targetFileName); + _SetTimes(targetFileName, true); + + if (zombie != null && File.Exists(zombie)) + ReallyDelete(zombie); + + // workitem 8264 + if (checkLaterForResetDirTimes) + { + // This is sort of a hack. What I do here is set the time on + // the parent directory, every time a file is extracted into + // it. If there is a directory with 1000 files, then I set + // the time on the dir, 1000 times. This allows the directory + // to have times that reflect the actual time on the entry in + // the zip archive. + + // String.Contains is not available on .NET CF 2.0 + if (this.FileName.IndexOf('/') != -1) + { + string dirname = Path.GetDirectoryName(this.FileName); + if (this._container.ZipFile[dirname] == null) + { + _SetTimes(Path.GetDirectoryName(targetFileName), false); + } + } + } + +#if NETCF + // workitem 7926 - version made by OS can be zero or 10 + if ((_VersionMadeBy & 0xFF00) == 0x0a00 || (_VersionMadeBy & 0xFF00) == 0x0000) + NetCfFile.SetAttributes(targetFileName, (uint)_ExternalFileAttrs); + +#else + // workitem 7071 + // + // We can only apply attributes if they are relevant to the NTFS + // OS. Must do this LAST because it may involve a ReadOnly bit, + // which would prevent us from setting the time, etc. + // + // workitem 7926 - version made by OS can be zero (FAT) or 10 + // (NTFS) + if ((_VersionMadeBy & 0xFF00) == 0x0a00 || (_VersionMadeBy & 0xFF00) == 0x0000) + File.SetAttributes(targetFileName, (FileAttributes)_ExternalFileAttrs); +#endif + } + + OnAfterExtract(baseDir); + + ExitTry: ; + } + catch (Exception) + { + _ioOperationCanceled = true; + throw; + } + finally + { + if (_ioOperationCanceled) + { + if (targetFileName != null) + { + try + { + if (output != null) output.Close(); + // An exception has occurred. If the file exists, check + // to see if it existed before we tried extracting. If + // it did not, attempt to remove the target file. There + // is a small possibility that the existing file has + // been extracted successfully, overwriting a previously + // existing file, and an exception was thrown after that + // but before final completion (setting times, etc). In + // that case the file will remain, even though some + // error occurred. Nothing to be done about it. + if (File.Exists(targetFileName) && !fileExistsBeforeExtraction) + File.Delete(targetFileName); + + } + finally { } + } + } + } + } + + +#if NOT + internal void CalcWinZipAesMac(Stream input) + { + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + if (input is WinZipAesCipherStream) + wzs = input as WinZipAesCipherStream; + + else if (input is Ionic.Zlib.CrcCalculatorStream) + { + xxx; + } + + } + } +#endif + + + internal void VerifyCrcAfterExtract(Int32 actualCrc32) + { + +#if AESCRYPTO + // After extracting, Validate the CRC32 + if (actualCrc32 != _Crc32) + { + // CRC is not meaningful with WinZipAES and AES method 2 (AE-2) + if ((Encryption != EncryptionAlgorithm.WinZipAes128 && + Encryption != EncryptionAlgorithm.WinZipAes256) + || _WinZipAesMethod != 0x02) + throw new BadCrcException("CRC error: the file being extracted appears to be corrupted. " + + String.Format("Expected 0x{0:X8}, Actual 0x{1:X8}", _Crc32, actualCrc32)); + } + + // ignore MAC if the size of the file is zero + if (this.UncompressedSize == 0) + return; + + // calculate the MAC + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + WinZipAesCipherStream wzs = _inputDecryptorStream as WinZipAesCipherStream; + _aesCrypto_forExtract.CalculatedMac = wzs.FinalAuthentication; + + _aesCrypto_forExtract.ReadAndVerifyMac(this.ArchiveStream); // throws if MAC is bad + // side effect: advances file position. + } + + + + +#else + if (actualCrc32 != _Crc32) + throw new BadCrcException("CRC error: the file being extracted appears to be corrupted. " + + String.Format("Expected 0x{0:X8}, Actual 0x{1:X8}", _Crc32, actualCrc32)); +#endif + } + + + + + private int CheckExtractExistingFile(string baseDir, string targetFileName) + { + int loop = 0; + // returns: 0 == extract, 1 = don't, 2 = cancel + do + { + switch (ExtractExistingFile) + { + case ExtractExistingFileAction.OverwriteSilently: + WriteStatus("the file {0} exists; will overwrite it...", targetFileName); + return 0; + + case ExtractExistingFileAction.DoNotOverwrite: + WriteStatus("the file {0} exists; not extracting entry...", FileName); + OnAfterExtract(baseDir); + return 1; + + case ExtractExistingFileAction.InvokeExtractProgressEvent: + if (loop>0) + throw new ZipException(String.Format("The file {0} already exists.", targetFileName)); + OnExtractExisting(baseDir); + if (_ioOperationCanceled) + return 2; + + // loop around + break; + + case ExtractExistingFileAction.Throw: + default: + throw new ZipException(String.Format("The file {0} already exists.", targetFileName)); + } + loop++; + } + while (true); + } + + + + + private void _CheckRead(int nbytes) + { + if (nbytes == 0) + throw new BadReadException(String.Format("bad read of entry {0} from compressed archive.", + this.FileName)); + } + + + private Stream _inputDecryptorStream; + + private Int32 ExtractOne(Stream output) + { + Int32 CrcResult = 0; + Stream input = this.ArchiveStream; + + try + { + // change for workitem 8098 + input.Seek(this.FileDataPosition, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(input); + + byte[] bytes = new byte[BufferSize]; + + // The extraction process varies depending on how the entry was + // stored. It could have been encrypted, and it coould have + // been compressed, or both, or neither. So we need to check + // both the encryption flag and the compression flag, and take + // the proper action in all cases. + + Int64 LeftToRead = (_CompressionMethod_FromZipFile != (short)CompressionMethod.None) + ? this.UncompressedSize + : this._CompressedFileDataSize; + + // Get a stream that either decrypts or not. + _inputDecryptorStream = GetExtractDecryptor(input); + + Stream input3 = GetExtractDecompressor( _inputDecryptorStream ); + + Int64 bytesWritten = 0; + // As we read, we maybe decrypt, and then we maybe decompress. Then we write. + using (var s1 = new Ionic.Crc.CrcCalculatorStream(input3)) + { + while (LeftToRead > 0) + { + //Console.WriteLine("ExtractOne: LeftToRead {0}", LeftToRead); + + // Casting LeftToRead down to an int is ok here in the else clause, + // because that only happens when it is less than bytes.Length, + // which is much less than MAX_INT. + int len = (LeftToRead > bytes.Length) ? bytes.Length : (int)LeftToRead; + int n = s1.Read(bytes, 0, len); + + // must check data read - essential for detecting corrupt zip files + _CheckRead(n); + + output.Write(bytes, 0, n); + LeftToRead -= n; + bytesWritten += n; + + // fire the progress event, check for cancels + OnExtractProgress(bytesWritten, UncompressedSize); + if (_ioOperationCanceled) + { + break; + } + } + + CrcResult = s1.Crc; + } + } + finally + { + var zss = input as ZipSegmentedStream; + if (zss != null) + { +#if NETCF + zss.Close(); +#else + // need to dispose it + zss.Dispose(); +#endif + _archiveStream = null; + } + } + + return CrcResult; + } + + + + internal Stream GetExtractDecompressor(Stream input2) + { + // get a stream that either decompresses or not. + switch (_CompressionMethod_FromZipFile) + { + case (short)CompressionMethod.None: + return input2; + case (short)CompressionMethod.Deflate: + return new Ionic.Zlib.DeflateStream(input2, Ionic.Zlib.CompressionMode.Decompress, true); +#if BZIP + case (short)CompressionMethod.BZip2: + return new Ionic.BZip2.BZip2InputStream(input2, true); +#endif + } + + return null; + } + + + + internal Stream GetExtractDecryptor(Stream input) + { + Stream input2 = null; + if (_Encryption_FromZipFile == EncryptionAlgorithm.PkzipWeak) + input2 = new ZipCipherStream(input, _zipCrypto_forExtract, CryptoMode.Decrypt); + +#if AESCRYPTO + else if (_Encryption_FromZipFile == EncryptionAlgorithm.WinZipAes128 || + _Encryption_FromZipFile == EncryptionAlgorithm.WinZipAes256) + input2 = new WinZipAesCipherStream(input, _aesCrypto_forExtract, _CompressedFileDataSize, CryptoMode.Decrypt); +#endif + + else + input2 = input; + + return input2; + } + + + + + internal void _SetTimes(string fileOrDirectory, bool isFile) + { +#if SILVERLIGHT + // punt on setting file times +#else + // workitem 8807: + // Because setting the time is not considered to be a fatal error, + // and because other applications can interfere with the setting + // of a time on a directory, we're going to swallow IO exceptions + // in this method. + + try + { + if (_ntfsTimesAreSet) + { +#if NETCF + // workitem 7944: set time should not be a fatal error on CF + int rc = NetCfFile.SetTimes(fileOrDirectory, _Ctime, _Atime, _Mtime); + if ( rc != 0) + { + WriteStatus("Warning: SetTimes failed. entry({0}) file({1}) rc({2})", + FileName, fileOrDirectory, rc); + } +#else + if (isFile) + { + // It's possible that the extract was cancelled, in which case, + // the file does not exist. + if (File.Exists(fileOrDirectory)) + { + File.SetCreationTimeUtc(fileOrDirectory, _Ctime); + File.SetLastAccessTimeUtc(fileOrDirectory, _Atime); + File.SetLastWriteTimeUtc(fileOrDirectory, _Mtime); + } + } + else + { + // It's possible that the extract was cancelled, in which case, + // the directory does not exist. + if (Directory.Exists(fileOrDirectory)) + { + Directory.SetCreationTimeUtc(fileOrDirectory, _Ctime); + Directory.SetLastAccessTimeUtc(fileOrDirectory, _Atime); + Directory.SetLastWriteTimeUtc(fileOrDirectory, _Mtime); + } + } +#endif + } + else + { + // workitem 6191 + DateTime AdjustedLastModified = Ionic.Zip.SharedUtilities.AdjustTime_Reverse(LastModified); + +#if NETCF + int rc = NetCfFile.SetLastWriteTime(fileOrDirectory, AdjustedLastModified); + + if ( rc != 0) + { + WriteStatus("Warning: SetLastWriteTime failed. entry({0}) file({1}) rc({2})", + FileName, fileOrDirectory, rc); + } +#else + if (isFile) + File.SetLastWriteTime(fileOrDirectory, AdjustedLastModified); + else + Directory.SetLastWriteTime(fileOrDirectory, AdjustedLastModified); +#endif + } + } + catch (System.IO.IOException ioexc1) + { + WriteStatus("failed to set time on {0}: {1}", fileOrDirectory, ioexc1.Message); + } +#endif + } + + + #region Support methods + + + // workitem 7968 + private string UnsupportedAlgorithm + { + get + { + string alg = String.Empty; + switch (_UnsupportedAlgorithmId) + { + case 0: + alg = "--"; + break; + case 0x6601: + alg = "DES"; + break; + case 0x6602: // - RC2 (version needed to extract < 5.2) + alg = "RC2"; + break; + case 0x6603: // - 3DES 168 + alg = "3DES-168"; + break; + case 0x6609: // - 3DES 112 + alg = "3DES-112"; + break; + case 0x660E: // - AES 128 + alg = "PKWare AES128"; + break; + case 0x660F: // - AES 192 + alg = "PKWare AES192"; + break; + case 0x6610: // - AES 256 + alg = "PKWare AES256"; + break; + case 0x6702: // - RC2 (version needed to extract >= 5.2) + alg = "RC2"; + break; + case 0x6720: // - Blowfish + alg = "Blowfish"; + break; + case 0x6721: // - Twofish + alg = "Twofish"; + break; + case 0x6801: // - RC4 + alg = "RC4"; + break; + case 0xFFFF: // - Unknown algorithm + default: + alg = String.Format("Unknown (0x{0:X4})", _UnsupportedAlgorithmId); + break; + } + return alg; + } + } + + // workitem 7968 + private string UnsupportedCompressionMethod + { + get + { + string meth = String.Empty; + switch ((int)_CompressionMethod) + { + case 0: + meth = "Store"; + break; + case 1: + meth = "Shrink"; + break; + case 8: + meth = "DEFLATE"; + break; + case 9: + meth = "Deflate64"; + break; + case 12: + meth = "BZIP2"; // only if BZIP not compiled in + break; + case 14: + meth = "LZMA"; + break; + case 19: + meth = "LZ77"; + break; + case 98: + meth = "PPMd"; + break; + default: + meth = String.Format("Unknown (0x{0:X4})", _CompressionMethod); + break; + } + return meth; + } + } + + + internal void ValidateEncryption() + { + if (Encryption != EncryptionAlgorithm.PkzipWeak && +#if AESCRYPTO + Encryption != EncryptionAlgorithm.WinZipAes128 && + Encryption != EncryptionAlgorithm.WinZipAes256 && +#endif + Encryption != EncryptionAlgorithm.None) + { + // workitem 7968 + if (_UnsupportedAlgorithmId != 0) + throw new ZipException(String.Format("Cannot extract: Entry {0} is encrypted with an algorithm not supported by DotNetZip: {1}", + FileName, UnsupportedAlgorithm)); + else + throw new ZipException(String.Format("Cannot extract: Entry {0} uses an unsupported encryption algorithm ({1:X2})", + FileName, (int)Encryption)); + } + } + + + private void ValidateCompression() + { + if ((_CompressionMethod_FromZipFile != (short)CompressionMethod.None) && + (_CompressionMethod_FromZipFile != (short)CompressionMethod.Deflate) +#if BZIP + && (_CompressionMethod_FromZipFile != (short)CompressionMethod.BZip2) +#endif + ) + throw new ZipException(String.Format("Entry {0} uses an unsupported compression method (0x{1:X2}, {2})", + FileName, _CompressionMethod_FromZipFile, UnsupportedCompressionMethod)); + } + + + private void SetupCryptoForExtract(string password) + { + //if (password == null) return; + if (_Encryption_FromZipFile == EncryptionAlgorithm.None) return; + + if (_Encryption_FromZipFile == EncryptionAlgorithm.PkzipWeak) + { + if (password == null) + throw new ZipException("Missing password."); + + this.ArchiveStream.Seek(this.FileDataPosition - 12, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + _zipCrypto_forExtract = ZipCrypto.ForRead(password, this); + } + +#if AESCRYPTO + else if (_Encryption_FromZipFile == EncryptionAlgorithm.WinZipAes128 || + _Encryption_FromZipFile == EncryptionAlgorithm.WinZipAes256) + { + if (password == null) + throw new ZipException("Missing password."); + + // If we already have a WinZipAesCrypto object in place, use it. + // It can be set up in the ReadDirEntry(), or during a previous Extract. + if (_aesCrypto_forExtract != null) + { + _aesCrypto_forExtract.Password = password; + } + else + { + int sizeOfSaltAndPv = GetLengthOfCryptoHeaderBytes(_Encryption_FromZipFile); + this.ArchiveStream.Seek(this.FileDataPosition - sizeOfSaltAndPv, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + int keystrength = GetKeyStrengthInBits(_Encryption_FromZipFile); + _aesCrypto_forExtract = WinZipAesCrypto.ReadFromStream(password, keystrength, this.ArchiveStream); + } + } +#endif + } + + + + /// + /// Validates that the args are consistent. + /// + /// + /// Only one of {baseDir, outStream} can be non-null. + /// If baseDir is non-null, then the outputFile is created. + /// + private bool ValidateOutput(string basedir, Stream outstream, out string outFileName) + { + if (basedir != null) + { + // Sometimes the name on the entry starts with a slash. + // Rather than unpack to the root of the volume, we're going to + // drop the slash and unpack to the specified base directory. + string f = this.FileName.Replace("\\","/"); + + // workitem 11772: remove drive letter with separator + if (f.IndexOf(':') == 1) + f= f.Substring(2); + + if (f.StartsWith("/")) + f= f.Substring(1); + + // String.Contains is not available on .NET CF 2.0 + + if (_container.ZipFile.FlattenFoldersOnExtract) + outFileName = Path.Combine(basedir, + (f.IndexOf('/') != -1) ? Path.GetFileName(f) : f); + else + outFileName = Path.Combine(basedir, f); + + // workitem 10639 + outFileName = outFileName.Replace("/","\\"); + + // check if it is a directory + if ((IsDirectory) || (FileName.EndsWith("/"))) + { + if (!Directory.Exists(outFileName)) + { + Directory.CreateDirectory(outFileName); + _SetTimes(outFileName, false); + } + else + { + // the dir exists, maybe we want to overwrite times. + if (ExtractExistingFile == ExtractExistingFileAction.OverwriteSilently) + _SetTimes(outFileName, false); + } + return true; // true == all done, caller will return + } + return false; // false == work to do by caller. + } + + if (outstream != null) + { + outFileName = null; + if ((IsDirectory) || (FileName.EndsWith("/"))) + { + // extract a directory to streamwriter? nothing to do! + return true; // true == all done! caller can return + } + return false; + } + + throw new ArgumentNullException("outstream"); + } + + + #endregion + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Read.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Read.cs new file mode 100644 index 00000000..a1aba115 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Read.cs @@ -0,0 +1,798 @@ +// ZipEntry.Read.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-09 21:31:28> +// +// ------------------------------------------------------------------ +// +// This module defines logic for Reading the ZipEntry from a +// zip file. +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; + +namespace Ionic.Zip +{ + public partial class ZipEntry + { + private int _readExtraDepth; + private void ReadExtraField() + { + _readExtraDepth++; + // workitem 8098: ok (restore) + long posn = this.ArchiveStream.Position; + this.ArchiveStream.Seek(this._RelativeOffsetOfLocalHeader, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + + byte[] block = new byte[30]; + this.ArchiveStream.Read(block, 0, block.Length); + int i = 26; + Int16 filenameLength = (short)(block[i++] + block[i++] * 256); + Int16 extraFieldLength = (short)(block[i++] + block[i++] * 256); + + // workitem 8098: ok (relative) + this.ArchiveStream.Seek(filenameLength, SeekOrigin.Current); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + + ProcessExtraField(this.ArchiveStream, extraFieldLength); + + // workitem 8098: ok (restore) + this.ArchiveStream.Seek(posn, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + _readExtraDepth--; + } + + + private static bool ReadHeader(ZipEntry ze, System.Text.Encoding defaultEncoding) + { + int bytesRead = 0; + + // change for workitem 8098 + ze._RelativeOffsetOfLocalHeader = ze.ArchiveStream.Position; + + int signature = Ionic.Zip.SharedUtilities.ReadEntrySignature(ze.ArchiveStream); + bytesRead += 4; + + // Return false if this is not a local file header signature. + if (ZipEntry.IsNotValidSig(signature)) + { + // Getting "not a ZipEntry signature" is not always wrong or an error. + // This will happen after the last entry in a zipfile. In that case, we + // expect to read : + // a ZipDirEntry signature (if a non-empty zip file) or + // a ZipConstants.EndOfCentralDirectorySignature. + // + // Anything else is a surprise. + + ze.ArchiveStream.Seek(-4, SeekOrigin.Current); // unread the signature + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(ze.ArchiveStream); + if (ZipEntry.IsNotValidZipDirEntrySig(signature) && (signature != ZipConstants.EndOfCentralDirectorySignature)) + { + throw new BadReadException(String.Format(" Bad signature (0x{0:X8}) at position 0x{1:X8}", signature, ze.ArchiveStream.Position)); + } + return false; + } + + byte[] block = new byte[26]; + int n = ze.ArchiveStream.Read(block, 0, block.Length); + if (n != block.Length) return false; + bytesRead += n; + + int i = 0; + ze._VersionNeeded = (Int16)(block[i++] + block[i++] * 256); + ze._BitField = (Int16)(block[i++] + block[i++] * 256); + ze._CompressionMethod_FromZipFile = ze._CompressionMethod = (Int16)(block[i++] + block[i++] * 256); + ze._TimeBlob = block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256; + // transform the time data into something usable (a DateTime) + ze._LastModified = Ionic.Zip.SharedUtilities.PackedToDateTime(ze._TimeBlob); + ze._timestamp |= ZipEntryTimestamp.DOS; + + if ((ze._BitField & 0x01) == 0x01) + { + ze._Encryption_FromZipFile = ze._Encryption = EncryptionAlgorithm.PkzipWeak; // this *may* change after processing the Extra field + ze._sourceIsEncrypted = true; + } + + // NB: if ((ze._BitField & 0x0008) != 0x0008), then the Compressed, uncompressed and + // CRC values are not true values; the true values will follow the entry data. + // But, regardless of the status of bit 3 in the bitfield, the slots for + // the three amigos may contain marker values for ZIP64. So we must read them. + { + ze._Crc32 = (Int32)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + ze._CompressedSize = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + ze._UncompressedSize = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + + if ((uint)ze._CompressedSize == 0xFFFFFFFF || + (uint)ze._UncompressedSize == 0xFFFFFFFF) + + ze._InputUsesZip64 = true; + } + + Int16 filenameLength = (short)(block[i++] + block[i++] * 256); + Int16 extraFieldLength = (short)(block[i++] + block[i++] * 256); + + block = new byte[filenameLength]; + n = ze.ArchiveStream.Read(block, 0, block.Length); + bytesRead += n; + + // if the UTF8 bit is set for this entry, override the + // encoding the application requested. + + if ((ze._BitField & 0x0800) == 0x0800) + { + // workitem 12744 + ze.AlternateEncoding = System.Text.Encoding.UTF8; + ze.AlternateEncodingUsage = ZipOption.Always; + } + + // need to use this form of GetString() for .NET CF + ze._FileNameInArchive = ze.AlternateEncoding.GetString(block, 0, block.Length); + + // workitem 6898 + if (ze._FileNameInArchive.EndsWith("/")) ze.MarkAsDirectory(); + + bytesRead += ze.ProcessExtraField(ze.ArchiveStream, extraFieldLength); + + ze._LengthOfTrailer = 0; + + // workitem 6607 - don't read for directories + // actually get the compressed size and CRC if necessary + if (!ze._FileNameInArchive.EndsWith("/") && (ze._BitField & 0x0008) == 0x0008) + { + // This descriptor exists only if bit 3 of the general + // purpose bit flag is set (see below). It is byte aligned + // and immediately follows the last byte of compressed data, + // as well as any encryption trailer, as with AES. + // This descriptor is used only when it was not possible to + // seek in the output .ZIP file, e.g., when the output .ZIP file + // was standard output or a non-seekable device. For ZIP64(tm) format + // archives, the compressed and uncompressed sizes are 8 bytes each. + + // workitem 8098: ok (restore) + long posn = ze.ArchiveStream.Position; + + // Here, we're going to loop until we find a ZipEntryDataDescriptorSignature and + // a consistent data record after that. To be consistent, the data record must + // indicate the length of the entry data. + bool wantMore = true; + long SizeOfDataRead = 0; + int tries = 0; + while (wantMore) + { + tries++; + // We call the FindSignature shared routine to find the specified signature + // in the already-opened zip archive, starting from the current cursor + // position in that filestream. If we cannot find the signature, then the + // routine returns -1, and the ReadHeader() method returns false, + // indicating we cannot read a legal entry header. If we have found it, + // then the FindSignature() method returns the number of bytes in the + // stream we had to seek forward, to find the sig. We need this to + // determine if the zip entry is valid, later. + + if (ze._container.ZipFile != null) + ze._container.ZipFile.OnReadBytes(ze); + + long d = Ionic.Zip.SharedUtilities.FindSignature(ze.ArchiveStream, ZipConstants.ZipEntryDataDescriptorSignature); + if (d == -1) return false; + + // total size of data read (through all loops of this). + SizeOfDataRead += d; + + if (ze._InputUsesZip64) + { + // read 1x 4-byte (CRC) and 2x 8-bytes (Compressed Size, Uncompressed Size) + block = new byte[20]; + n = ze.ArchiveStream.Read(block, 0, block.Length); + if (n != 20) return false; + + // do not increment bytesRead - it is for entry header only. + // the data we have just read is a footer (falls after the file data) + //bytesRead += n; + + i = 0; + ze._Crc32 = (Int32)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + ze._CompressedSize = BitConverter.ToInt64(block, i); + i += 8; + ze._UncompressedSize = BitConverter.ToInt64(block, i); + i += 8; + + ze._LengthOfTrailer += 24; // bytes including sig, CRC, Comp and Uncomp sizes + } + else + { + // read 3x 4-byte fields (CRC, Compressed Size, Uncompressed Size) + block = new byte[12]; + n = ze.ArchiveStream.Read(block, 0, block.Length); + if (n != 12) return false; + + // do not increment bytesRead - it is for entry header only. + // the data we have just read is a footer (falls after the file data) + //bytesRead += n; + + i = 0; + ze._Crc32 = (Int32)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + ze._CompressedSize = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + ze._UncompressedSize = (uint)(block[i++] + block[i++] * 256 + block[i++] * 256 * 256 + block[i++] * 256 * 256 * 256); + + ze._LengthOfTrailer += 16; // bytes including sig, CRC, Comp and Uncomp sizes + + } + + wantMore = (SizeOfDataRead != ze._CompressedSize); + + if (wantMore) + { + // Seek back to un-read the last 12 bytes - maybe THEY contain + // the ZipEntryDataDescriptorSignature. + // (12 bytes for the CRC, Comp and Uncomp size.) + ze.ArchiveStream.Seek(-12, SeekOrigin.Current); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(ze.ArchiveStream); + + // Adjust the size to account for the false signature read in + // FindSignature(). + SizeOfDataRead += 4; + } + } + + // seek back to previous position, to prepare to read file data + // workitem 8098: ok (restore) + ze.ArchiveStream.Seek(posn, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(ze.ArchiveStream); + } + + ze._CompressedFileDataSize = ze._CompressedSize; + + + // bit 0 set indicates that some kind of encryption is in use + if ((ze._BitField & 0x01) == 0x01) + { +#if AESCRYPTO + if (ze.Encryption == EncryptionAlgorithm.WinZipAes128 || + ze.Encryption == EncryptionAlgorithm.WinZipAes256) + { + int bits = ZipEntry.GetKeyStrengthInBits(ze._Encryption_FromZipFile); + // read in the WinZip AES metadata: salt + PV. 18 bytes for AES256. 10 bytes for AES128. + ze._aesCrypto_forExtract = WinZipAesCrypto.ReadFromStream(null, bits, ze.ArchiveStream); + bytesRead += ze._aesCrypto_forExtract.SizeOfEncryptionMetadata - 10; // MAC (follows crypto bytes) + // according to WinZip, the CompressedSize includes the AES Crypto framing data. + ze._CompressedFileDataSize -= ze._aesCrypto_forExtract.SizeOfEncryptionMetadata; + ze._LengthOfTrailer += 10; // MAC + } + else +#endif + { + // read in the header data for "weak" encryption + ze._WeakEncryptionHeader = new byte[12]; + bytesRead += ZipEntry.ReadWeakEncryptionHeader(ze._archiveStream, ze._WeakEncryptionHeader); + // decrease the filedata size by 12 bytes + ze._CompressedFileDataSize -= 12; + } + } + + // Remember the size of the blob for this entry. + // We also have the starting position in the stream for this entry. + ze._LengthOfHeader = bytesRead; + ze._TotalEntrySize = ze._LengthOfHeader + ze._CompressedFileDataSize + ze._LengthOfTrailer; + + + // We've read in the regular entry header, the extra field, and any + // encryption header. The pointer in the file is now at the start of the + // filedata, which is potentially compressed and encrypted. Just ahead in + // the file, there are _CompressedFileDataSize bytes of data, followed by + // potentially a non-zero length trailer, consisting of optionally, some + // encryption stuff (10 byte MAC for AES), and the bit-3 trailer (16 or 24 + // bytes). + + return true; + } + + + + internal static int ReadWeakEncryptionHeader(Stream s, byte[] buffer) + { + // PKZIP encrypts the compressed data stream. Encrypted files must + // be decrypted before they can be extracted. + + // Each PKZIP-encrypted file has an extra 12 bytes stored at the start of the data + // area defining the encryption header for that file. The encryption header is + // originally set to random values, and then itself encrypted, using three, 32-bit + // keys. The key values are initialized using the supplied encryption password. + // After each byte is encrypted, the keys are then updated using pseudo-random + // number generation techniques in combination with the same CRC-32 algorithm used + // in PKZIP and implemented in the CRC32.cs module in this project. + + // read the 12-byte encryption header + int additionalBytesRead = s.Read(buffer, 0, 12); + if (additionalBytesRead != 12) + throw new ZipException(String.Format("Unexpected end of data at position 0x{0:X8}", s.Position)); + + return additionalBytesRead; + } + + + + private static bool IsNotValidSig(int signature) + { + return (signature != ZipConstants.ZipEntrySignature); + } + + + /// + /// Reads one ZipEntry from the given stream. The content for + /// the entry does not get decompressed or decrypted. This method + /// basically reads metadata, and seeks. + /// + /// the ZipContainer this entry belongs to. + /// + /// true of this is the first entry being read from the stream. + /// + /// the ZipEntry read from the stream. + internal static ZipEntry ReadEntry(ZipContainer zc, bool first) + { + ZipFile zf = zc.ZipFile; + Stream s = zc.ReadStream; + System.Text.Encoding defaultEncoding = zc.AlternateEncoding; + ZipEntry entry = new ZipEntry(); + entry._Source = ZipEntrySource.ZipFile; + entry._container = zc; + entry._archiveStream = s; + if (zf != null) + zf.OnReadEntry(true, null); + + if (first) HandlePK00Prefix(s); + + // Read entry header, including any encryption header + if (!ReadHeader(entry, defaultEncoding)) return null; + + // Store the position in the stream for this entry + // change for workitem 8098 + entry.__FileDataPosition = entry.ArchiveStream.Position; + + // seek past the data without reading it. We will read on Extract() + s.Seek(entry._CompressedFileDataSize + entry._LengthOfTrailer, SeekOrigin.Current); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + + // ReadHeader moves the file pointer to the end of the entry header, + // as well as any encryption header. + + // CompressedFileDataSize includes: + // the maybe compressed, maybe encrypted file data + // the encryption trailer, if any + // the bit 3 descriptor, if any + + // workitem 5306 + // http://www.codeplex.com/DotNetZip/WorkItem/View.aspx?WorkItemId=5306 + HandleUnexpectedDataDescriptor(entry); + + if (zf != null) + { + zf.OnReadBytes(entry); + zf.OnReadEntry(false, entry); + } + + return entry; + } + + + internal static void HandlePK00Prefix(Stream s) + { + // in some cases, the zip file begins with "PK00". This is a throwback and is rare, + // but we handle it anyway. We do not change behavior based on it. + uint datum = (uint)Ionic.Zip.SharedUtilities.ReadInt(s); + if (datum != ZipConstants.PackedToRemovableMedia) + { + s.Seek(-4, SeekOrigin.Current); // unread the block + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + } + } + + + + private static void HandleUnexpectedDataDescriptor(ZipEntry entry) + { + Stream s = entry.ArchiveStream; + + // In some cases, the "data descriptor" is present, without a signature, even when + // bit 3 of the BitField is NOT SET. This is the CRC, followed + // by the compressed length and the uncompressed length (4 bytes for each + // of those three elements). Need to check that here. + // + uint datum = (uint)Ionic.Zip.SharedUtilities.ReadInt(s); + if (datum == entry._Crc32) + { + int sz = Ionic.Zip.SharedUtilities.ReadInt(s); + if (sz == entry._CompressedSize) + { + sz = Ionic.Zip.SharedUtilities.ReadInt(s); + if (sz == entry._UncompressedSize) + { + // ignore everything and discard it. + } + else + { + s.Seek(-12, SeekOrigin.Current); // unread the three blocks + + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + } + } + else + { + s.Seek(-8, SeekOrigin.Current); // unread the two blocks + + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + } + } + else + { + s.Seek(-4, SeekOrigin.Current); // unread the block + + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + } + } + + + /// + /// Finds a particular segment in the given extra field. + /// This is used when modifying a previously-generated + /// extra field, in particular when removing the AES crypto + /// segment in the extra field. + /// + static internal int FindExtraFieldSegment(byte[] extra, int offx, UInt16 targetHeaderId) + { + int j = offx; + while (j + 3 < extra.Length) + { + UInt16 headerId = (UInt16)(extra[j++] + extra[j++] * 256); + if (headerId == targetHeaderId) return j-2; + + // else advance to next segment + Int16 dataSize = (short)(extra[j++] + extra[j++] * 256); + j+= dataSize; + } + + return -1; + } + + + /// + /// At current cursor position in the stream, read the extra + /// field, and set the properties on the ZipEntry instance + /// appropriately. This can be called when processing the + /// Extra field in the Central Directory, or in the local + /// header. + /// + internal int ProcessExtraField(Stream s, Int16 extraFieldLength) + { + int additionalBytesRead = 0; + if (extraFieldLength > 0) + { + byte[] buffer = this._Extra = new byte[extraFieldLength]; + additionalBytesRead = s.Read(buffer, 0, buffer.Length); + long posn = s.Position - additionalBytesRead; + int j = 0; + while (j + 3 < buffer.Length) + { + int start = j; + UInt16 headerId = (UInt16)(buffer[j++] + buffer[j++] * 256); + Int16 dataSize = (short)(buffer[j++] + buffer[j++] * 256); + + switch (headerId) + { + case 0x000a: // NTFS ctime, atime, mtime + j = ProcessExtraFieldWindowsTimes(buffer, j, dataSize, posn); + break; + + case 0x5455: // Unix ctime, atime, mtime + j = ProcessExtraFieldUnixTimes(buffer, j, dataSize, posn); + break; + + case 0x5855: // Info-zip Extra field (outdated) + // This is outdated, so the field is supported on + // read only. + j = ProcessExtraFieldInfoZipTimes(buffer, j, dataSize, posn); + break; + + case 0x7855: // Unix uid/gid + // ignored. DotNetZip does not handle this field. + break; + + case 0x7875: // ?? + // ignored. I could not find documentation on this field, + // though it appears in some zip files. + break; + + case 0x0001: // ZIP64 + j = ProcessExtraFieldZip64(buffer, j, dataSize, posn); + break; + +#if AESCRYPTO + case 0x9901: // WinZip AES encryption is in use. (workitem 6834) + // we will handle this extra field only if compressionmethod is 0x63 + j = ProcessExtraFieldWinZipAes(buffer, j, dataSize, posn); + break; +#endif + case 0x0017: // workitem 7968: handle PKWare Strong encryption header + j = ProcessExtraFieldPkwareStrongEncryption(buffer, j); + break; + } + + // move to the next Header in the extra field + j = start + dataSize + 4; + } + } + return additionalBytesRead; + } + + private int ProcessExtraFieldPkwareStrongEncryption(byte[] Buffer, int j) + { + // Value Size Description + // ----- ---- ----------- + // 0x0017 2 bytes Tag for this "extra" block type + // TSize 2 bytes Size of data that follows + // Format 2 bytes Format definition for this record + // AlgID 2 bytes Encryption algorithm identifier + // Bitlen 2 bytes Bit length of encryption key + // Flags 2 bytes Processing flags + // CertData TSize-8 Certificate decryption extra field data + // (refer to the explanation for CertData + // in the section describing the + // Certificate Processing Method under + // the Strong Encryption Specification) + + j += 2; + _UnsupportedAlgorithmId = (UInt16)(Buffer[j++] + Buffer[j++] * 256); + _Encryption_FromZipFile = _Encryption = EncryptionAlgorithm.Unsupported; + + // DotNetZip doesn't support this algorithm, but we don't need to throw + // here. we might just be reading the archive, which is fine. We'll + // need to throw if Extract() is called. + + return j; + } + + +#if AESCRYPTO + private int ProcessExtraFieldWinZipAes(byte[] buffer, int j, Int16 dataSize, long posn) + { + if (this._CompressionMethod == 0x0063) + { + if ((this._BitField & 0x01) != 0x01) + throw new BadReadException(String.Format(" Inconsistent metadata at position 0x{0:X16}", posn)); + + this._sourceIsEncrypted = true; + + //this._aesCrypto = new WinZipAesCrypto(this); + // see spec at http://www.winzip.com/aes_info.htm + if (dataSize != 7) + throw new BadReadException(String.Format(" Inconsistent size (0x{0:X4}) in WinZip AES field at position 0x{1:X16}", dataSize, posn)); + + this._WinZipAesMethod = BitConverter.ToInt16(buffer, j); + j += 2; + if (this._WinZipAesMethod != 0x01 && this._WinZipAesMethod != 0x02) + throw new BadReadException(String.Format(" Unexpected vendor version number (0x{0:X4}) for WinZip AES metadata at position 0x{1:X16}", + this._WinZipAesMethod, posn)); + + Int16 vendorId = BitConverter.ToInt16(buffer, j); + j += 2; + if (vendorId != 0x4541) + throw new BadReadException(String.Format(" Unexpected vendor ID (0x{0:X4}) for WinZip AES metadata at position 0x{1:X16}", vendorId, posn)); + + int keystrength = (buffer[j] == 1) ? 128 : (buffer[j] == 3) ? 256 : -1; + if (keystrength < 0) + throw new BadReadException(String.Format("Invalid key strength ({0})", keystrength)); + + _Encryption_FromZipFile = this._Encryption = (keystrength == 128) + ? EncryptionAlgorithm.WinZipAes128 + : EncryptionAlgorithm.WinZipAes256; + + j++; + + // set the actual compression method + this._CompressionMethod_FromZipFile = + this._CompressionMethod = BitConverter.ToInt16(buffer, j); + j += 2; // for the next segment of the extra field + } + return j; + } + +#endif + + private delegate T Func(); + + private int ProcessExtraFieldZip64(byte[] buffer, int j, Int16 dataSize, long posn) + { + // The PKWare spec says that any of {UncompressedSize, CompressedSize, + // RelativeOffset} exceeding 0xFFFFFFFF can lead to the ZIP64 header, + // and the ZIP64 header may contain one or more of those. If the + // values are present, they will be found in the prescribed order. + // There may also be a 4-byte "disk start number." + // This means that the DataSize must be 28 bytes or less. + + this._InputUsesZip64 = true; + + // workitem 7941: check datasize before reading. + if (dataSize > 28) + throw new BadReadException(String.Format(" Inconsistent size (0x{0:X4}) for ZIP64 extra field at position 0x{1:X16}", + dataSize, posn)); + int remainingData = dataSize; + + var slurp = new Func( () => { + if (remainingData < 8) + throw new BadReadException(String.Format(" Missing data for ZIP64 extra field, position 0x{0:X16}", posn)); + var x = BitConverter.ToInt64(buffer, j); + j+= 8; + remainingData -= 8; + return x; + }); + + if (this._UncompressedSize == 0xFFFFFFFF) + this._UncompressedSize = slurp(); + + if (this._CompressedSize == 0xFFFFFFFF) + this._CompressedSize = slurp(); + + if (this._RelativeOffsetOfLocalHeader == 0xFFFFFFFF) + this._RelativeOffsetOfLocalHeader = slurp(); + + // Ignore anything else. Potentially there are 4 more bytes for the + // disk start number. DotNetZip currently doesn't handle multi-disk + // archives. + return j; + } + + + private int ProcessExtraFieldInfoZipTimes(byte[] buffer, int j, Int16 dataSize, long posn) + { + if (dataSize != 12 && dataSize != 8) + throw new BadReadException(String.Format(" Unexpected size (0x{0:X4}) for InfoZip v1 extra field at position 0x{1:X16}", dataSize, posn)); + + Int32 timet = BitConverter.ToInt32(buffer, j); + this._Mtime = _unixEpoch.AddSeconds(timet); + j += 4; + + timet = BitConverter.ToInt32(buffer, j); + this._Atime = _unixEpoch.AddSeconds(timet); + j += 4; + + this._Ctime = DateTime.UtcNow; + + _ntfsTimesAreSet = true; + _timestamp |= ZipEntryTimestamp.InfoZip1; return j; + } + + + + private int ProcessExtraFieldUnixTimes(byte[] buffer, int j, Int16 dataSize, long posn) + { + // The Unix filetimes are 32-bit unsigned integers, + // storing seconds since Unix epoch. + + if (dataSize != 13 && dataSize != 9 && dataSize != 5) + throw new BadReadException(String.Format(" Unexpected size (0x{0:X4}) for Extended Timestamp extra field at position 0x{1:X16}", dataSize, posn)); + + int remainingData = dataSize; + + var slurp = new Func( () => { + Int32 timet = BitConverter.ToInt32(buffer, j); + j += 4; + remainingData -= 4; + return _unixEpoch.AddSeconds(timet); + }); + + if (dataSize == 13 || _readExtraDepth > 0) + { + byte flag = buffer[j++]; + remainingData--; + + if ((flag & 0x0001) != 0 && remainingData >= 4) + this._Mtime = slurp(); + + this._Atime = ((flag & 0x0002) != 0 && remainingData >= 4) + ? slurp() + : DateTime.UtcNow; + + this._Ctime = ((flag & 0x0004) != 0 && remainingData >= 4) + ? slurp() + :DateTime.UtcNow; + + _timestamp |= ZipEntryTimestamp.Unix; + _ntfsTimesAreSet = true; + _emitUnixTimes = true; + } + else + ReadExtraField(); // will recurse + + return j; + } + + + private int ProcessExtraFieldWindowsTimes(byte[] buffer, int j, Int16 dataSize, long posn) + { + // The NTFS filetimes are 64-bit unsigned integers, stored in Intel + // (least significant byte first) byte order. They are expressed as the + // number of 1.0E-07 seconds (1/10th microseconds!) past WinNT "epoch", + // which is "01-Jan-1601 00:00:00 UTC". + // + // HeaderId 2 bytes 0x000a == NTFS stuff + // Datasize 2 bytes ?? (usually 32) + // reserved 4 bytes ?? + // timetag 2 bytes 0x0001 == time + // size 2 bytes 24 == 8 bytes each for ctime, mtime, atime + // mtime 8 bytes win32 ticks since win32epoch + // atime 8 bytes win32 ticks since win32epoch + // ctime 8 bytes win32 ticks since win32epoch + + if (dataSize != 32) + throw new BadReadException(String.Format(" Unexpected size (0x{0:X4}) for NTFS times extra field at position 0x{1:X16}", dataSize, posn)); + + j += 4; // reserved + Int16 timetag = (Int16)(buffer[j] + buffer[j + 1] * 256); + Int16 addlsize = (Int16)(buffer[j + 2] + buffer[j + 3] * 256); + j += 4; // tag and size + + if (timetag == 0x0001 && addlsize == 24) + { + Int64 z = BitConverter.ToInt64(buffer, j); + this._Mtime = DateTime.FromFileTimeUtc(z); + j += 8; + + // At this point the library *could* set the LastModified value + // to coincide with the Mtime value. In theory, they refer to + // the same property of the file, and should be the same anyway, + // allowing for differences in precision. But they are + // independent quantities in the zip archive, and this library + // will keep them separate in the object model. There is no ill + // effect from this, because as files are extracted, the + // higher-precision value (Mtime) is used if it is present. + // Apps may wish to compare the Mtime versus LastModified + // values, but any difference when both are present is not + // germaine to the correctness of the library. but note: when + // explicitly setting either value, both are set. See the setter + // for LastModified or the SetNtfsTimes() method. + + z = BitConverter.ToInt64(buffer, j); + this._Atime = DateTime.FromFileTimeUtc(z); + j += 8; + + z = BitConverter.ToInt64(buffer, j); + this._Ctime = DateTime.FromFileTimeUtc(z); + j += 8; + + _ntfsTimesAreSet = true; + _timestamp |= ZipEntryTimestamp.Windows; + _emitNtfsTimes = true; + } + return j; + } + + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Write.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Write.cs new file mode 100644 index 00000000..1106de42 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.Write.cs @@ -0,0 +1,2582 @@ +//#define Trace + +// ZipEntry.Write.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-July-30 14:55:47> +// +// ------------------------------------------------------------------ +// +// This module defines logic for writing (saving) the ZipEntry into a +// zip file. +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; +using RE = System.Text.RegularExpressions; + +namespace Ionic.Zip +{ + public partial class ZipEntry + { + internal void WriteCentralDirectoryEntry(Stream s) + { + byte[] bytes = new byte[4096]; + int i = 0; + // signature + bytes[i++] = (byte)(ZipConstants.ZipDirEntrySignature & 0x000000FF); + bytes[i++] = (byte)((ZipConstants.ZipDirEntrySignature & 0x0000FF00) >> 8); + bytes[i++] = (byte)((ZipConstants.ZipDirEntrySignature & 0x00FF0000) >> 16); + bytes[i++] = (byte)((ZipConstants.ZipDirEntrySignature & 0xFF000000) >> 24); + + // Version Made By + // workitem 7071 + // We must not overwrite the VersionMadeBy field when writing out a zip + // archive. The VersionMadeBy tells the zip reader the meaning of the + // File attributes. Overwriting the VersionMadeBy will result in + // inconsistent metadata. Consider the scenario where the application + // opens and reads a zip file that had been created on Linux. Then the + // app adds one file to the Zip archive, and saves it. The file + // attributes for all the entries added on Linux will be significant for + // Linux. Therefore the VersionMadeBy for those entries must not be + // changed. Only the entries that are actually created on Windows NTFS + // should get the VersionMadeBy indicating Windows/NTFS. + bytes[i++] = (byte)(_VersionMadeBy & 0x00FF); + bytes[i++] = (byte)((_VersionMadeBy & 0xFF00) >> 8); + + // Apparently we want to duplicate the extra field here; we cannot + // simply zero it out and assume tools and apps will use the right one. + + ////Int16 extraFieldLengthSave = (short)(_EntryHeader[28] + _EntryHeader[29] * 256); + ////_EntryHeader[28] = 0; + ////_EntryHeader[29] = 0; + + // Version Needed, Bitfield, compression method, lastmod, + // crc, compressed and uncompressed sizes, filename length and extra field length. + // These are all present in the local file header, but they may be zero values there. + // So we cannot just copy them. + + // workitem 11969: Version Needed To Extract in central directory must be + // the same as the local entry or MS .NET System.IO.Zip fails read. + Int16 vNeeded = (Int16)(VersionNeeded != 0 ? VersionNeeded : 20); + // workitem 12964 + if (_OutputUsesZip64==null) + { + // a zipentry in a zipoutputstream, with zero bytes written + _OutputUsesZip64 = new Nullable(_container.Zip64 == Zip64Option.Always); + } + + Int16 versionNeededToExtract = (Int16)(_OutputUsesZip64.Value ? 45 : vNeeded); +#if BZIP + if (this.CompressionMethod == Ionic.Zip.CompressionMethod.BZip2) + versionNeededToExtract = 46; +#endif + + bytes[i++] = (byte)(versionNeededToExtract & 0x00FF); + bytes[i++] = (byte)((versionNeededToExtract & 0xFF00) >> 8); + + bytes[i++] = (byte)(_BitField & 0x00FF); + bytes[i++] = (byte)((_BitField & 0xFF00) >> 8); + + bytes[i++] = (byte)(_CompressionMethod & 0x00FF); + bytes[i++] = (byte)((_CompressionMethod & 0xFF00) >> 8); + +#if AESCRYPTO + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + i -= 2; + bytes[i++] = 0x63; + bytes[i++] = 0; + } +#endif + + bytes[i++] = (byte)(_TimeBlob & 0x000000FF); + bytes[i++] = (byte)((_TimeBlob & 0x0000FF00) >> 8); + bytes[i++] = (byte)((_TimeBlob & 0x00FF0000) >> 16); + bytes[i++] = (byte)((_TimeBlob & 0xFF000000) >> 24); + bytes[i++] = (byte)(_Crc32 & 0x000000FF); + bytes[i++] = (byte)((_Crc32 & 0x0000FF00) >> 8); + bytes[i++] = (byte)((_Crc32 & 0x00FF0000) >> 16); + bytes[i++] = (byte)((_Crc32 & 0xFF000000) >> 24); + + int j = 0; + if (_OutputUsesZip64.Value) + { + // CompressedSize (Int32) and UncompressedSize - all 0xFF + for (j = 0; j < 8; j++) + bytes[i++] = 0xFF; + } + else + { + bytes[i++] = (byte)(_CompressedSize & 0x000000FF); + bytes[i++] = (byte)((_CompressedSize & 0x0000FF00) >> 8); + bytes[i++] = (byte)((_CompressedSize & 0x00FF0000) >> 16); + bytes[i++] = (byte)((_CompressedSize & 0xFF000000) >> 24); + + bytes[i++] = (byte)(_UncompressedSize & 0x000000FF); + bytes[i++] = (byte)((_UncompressedSize & 0x0000FF00) >> 8); + bytes[i++] = (byte)((_UncompressedSize & 0x00FF0000) >> 16); + bytes[i++] = (byte)((_UncompressedSize & 0xFF000000) >> 24); + } + + byte[] fileNameBytes = GetEncodedFileNameBytes(); + Int16 filenameLength = (Int16)fileNameBytes.Length; + bytes[i++] = (byte)(filenameLength & 0x00FF); + bytes[i++] = (byte)((filenameLength & 0xFF00) >> 8); + + // do this again because now we have real data + _presumeZip64 = _OutputUsesZip64.Value; + + // workitem 11131 + // + // cannot generate the extra field again, here's why: In the case of a + // zero-byte entry, which uses encryption, DotNetZip will "remove" the + // encryption from the entry. It does this in PostProcessOutput; it + // modifies the entry header, and rewrites it, resetting the Bitfield + // (one bit indicates encryption), and potentially resetting the + // compression method - for AES the Compression method is 0x63, and it + // would get reset to zero (no compression). It then calls SetLength() + // to truncate the stream to remove the encryption header (12 bytes for + // AES256). But, it leaves the previously-generated "Extra Field" + // metadata (11 bytes) for AES in the entry header. This extra field + // data is now "orphaned" - it refers to AES encryption when in fact no + // AES encryption is used. But no problem, the PKWARE spec says that + // unrecognized extra fields can just be ignored. ok. After "removal" + // of AES encryption, the length of the Extra Field can remains the + // same; it's just that there will be 11 bytes in there that previously + // pertained to AES which are now unused. Even the field code is still + // there, but it will be unused by readers, as the encryption bit is not + // set. + // + // Re-calculating the Extra field now would produce a block that is 11 + // bytes shorter, and that mismatch - between the extra field in the + // local header and the extra field in the Central Directory - would + // cause problems. (where? why? what problems?) So we can't do + // that. It's all good though, because though the content may have + // changed, the length definitely has not. Also, the _EntryHeader + // contains the "updated" extra field (after PostProcessOutput) at + // offset (30 + filenameLength). + + _Extra = ConstructExtraField(true); + + Int16 extraFieldLength = (Int16)((_Extra == null) ? 0 : _Extra.Length); + bytes[i++] = (byte)(extraFieldLength & 0x00FF); + bytes[i++] = (byte)((extraFieldLength & 0xFF00) >> 8); + + // File (entry) Comment Length + // the _CommentBytes private field was set during WriteHeader() + int commentLength = (_CommentBytes == null) ? 0 : _CommentBytes.Length; + + // the size of our buffer defines the max length of the comment we can write + if (commentLength + i > bytes.Length) commentLength = bytes.Length - i; + bytes[i++] = (byte)(commentLength & 0x00FF); + bytes[i++] = (byte)((commentLength & 0xFF00) >> 8); + + // Disk number start + bool segmented = (this._container.ZipFile != null) && + (this._container.ZipFile.MaxOutputSegmentSize != 0); + if (segmented) // workitem 13915 + { + // Emit nonzero disknumber only if saving segmented archive. + bytes[i++] = (byte)(_diskNumber & 0x00FF); + bytes[i++] = (byte)((_diskNumber & 0xFF00) >> 8); + } + else + { + // If reading a segmneted archive and saving to a regular archive, + // ZipEntry._diskNumber will be non-zero but it should be saved as + // zero. + bytes[i++] = 0; + bytes[i++] = 0; + } + + // internal file attrs + // workitem 7801 + bytes[i++] = (byte)((_IsText) ? 1 : 0); // lo bit: filetype hint. 0=bin, 1=txt. + bytes[i++] = 0; + + // external file attrs + // workitem 7071 + bytes[i++] = (byte)(_ExternalFileAttrs & 0x000000FF); + bytes[i++] = (byte)((_ExternalFileAttrs & 0x0000FF00) >> 8); + bytes[i++] = (byte)((_ExternalFileAttrs & 0x00FF0000) >> 16); + bytes[i++] = (byte)((_ExternalFileAttrs & 0xFF000000) >> 24); + + // workitem 11131 + // relative offset of local header. + // + // If necessary to go to 64-bit value, then emit 0xFFFFFFFF, + // else write out the value. + // + // Even if zip64 is required for other reasons - number of the entry + // > 65534, or uncompressed size of the entry > MAX_INT32, the ROLH + // need not be stored in a 64-bit field . + if (_RelativeOffsetOfLocalHeader > 0xFFFFFFFFL) // _OutputUsesZip64.Value + { + bytes[i++] = 0xFF; + bytes[i++] = 0xFF; + bytes[i++] = 0xFF; + bytes[i++] = 0xFF; + } + else + { + bytes[i++] = (byte)(_RelativeOffsetOfLocalHeader & 0x000000FF); + bytes[i++] = (byte)((_RelativeOffsetOfLocalHeader & 0x0000FF00) >> 8); + bytes[i++] = (byte)((_RelativeOffsetOfLocalHeader & 0x00FF0000) >> 16); + bytes[i++] = (byte)((_RelativeOffsetOfLocalHeader & 0xFF000000) >> 24); + } + + // actual filename + Buffer.BlockCopy(fileNameBytes, 0, bytes, i, filenameLength); + i += filenameLength; + + // "Extra field" + if (_Extra != null) + { + // workitem 11131 + // + // copy from EntryHeader if available - it may have been updated. + // if not, copy from Extra. This would be unnecessary if I just + // updated the Extra field when updating EntryHeader, in + // PostProcessOutput. + + //?? I don't understand why I wouldn't want to just use + // the recalculated Extra field. ?? + + // byte[] h = _EntryHeader ?? _Extra; + // int offx = (h == _EntryHeader) ? 30 + filenameLength : 0; + // Buffer.BlockCopy(h, offx, bytes, i, extraFieldLength); + // i += extraFieldLength; + + byte[] h = _Extra; + int offx = 0; + Buffer.BlockCopy(h, offx, bytes, i, extraFieldLength); + i += extraFieldLength; + } + + // file (entry) comment + if (commentLength != 0) + { + // now actually write the comment itself into the byte buffer + Buffer.BlockCopy(_CommentBytes, 0, bytes, i, commentLength); + // for (j = 0; (j < commentLength) && (i + j < bytes.Length); j++) + // bytes[i + j] = _CommentBytes[j]; + i += commentLength; + } + + s.Write(bytes, 0, i); + } + + +#if INFOZIP_UTF8 + static private bool FileNameIsUtf8(char[] FileNameChars) + { + bool isUTF8 = false; + bool isUnicode = false; + for (int j = 0; j < FileNameChars.Length; j++) + { + byte[] b = System.BitConverter.GetBytes(FileNameChars[j]); + isUnicode |= (b.Length != 2); + isUnicode |= (b[1] != 0); + isUTF8 |= ((b[0] & 0x80) != 0); + } + + return isUTF8; + } +#endif + + + private byte[] ConstructExtraField(bool forCentralDirectory) + { + var listOfBlocks = new System.Collections.Generic.List(); + byte[] block; + + // Conditionally emit an extra field with Zip64 information. If the + // Zip64 option is Always, we emit the field, before knowing that it's + // necessary. Later, if it turns out this entry does not need zip64, + // we'll set the header ID to rubbish and the data will be ignored. + // This results in additional overhead metadata in the zip file, but + // it will be small in comparison to the entry data. + // + // On the other hand if the Zip64 option is AsNecessary and it's NOT + // for the central directory, then we do the same thing. Or, if the + // Zip64 option is AsNecessary and it IS for the central directory, + // and the entry requires zip64, then emit the header. + if (_container.Zip64 == Zip64Option.Always || + (_container.Zip64 == Zip64Option.AsNecessary && + (!forCentralDirectory || _entryRequiresZip64.Value))) + { + // add extra field for zip64 here + // workitem 7924 + int sz = 4 + (forCentralDirectory ? 28 : 16); + block = new byte[sz]; + int i = 0; + + if (_presumeZip64 || forCentralDirectory) + { + // HeaderId = always use zip64 extensions. + block[i++] = 0x01; + block[i++] = 0x00; + } + else + { + // HeaderId = dummy data now, maybe set to 0x0001 (ZIP64) later. + block[i++] = 0x99; + block[i++] = 0x99; + } + + // DataSize + block[i++] = (byte)(sz - 4); // decimal 28 or 16 (workitem 7924) + block[i++] = 0x00; + + // The actual metadata - we may or may not have real values yet... + + // uncompressed size + Array.Copy(BitConverter.GetBytes(_UncompressedSize), 0, block, i, 8); + i += 8; + // compressed size + Array.Copy(BitConverter.GetBytes(_CompressedSize), 0, block, i, 8); + i += 8; + + // workitem 7924 - only include this if the "extra" field is for + // use in the central directory. It is unnecessary and not useful + // for local header; makes WinZip choke. + if (forCentralDirectory) + { + // relative offset + Array.Copy(BitConverter.GetBytes(_RelativeOffsetOfLocalHeader), 0, block, i, 8); + i += 8; + + // starting disk number + Array.Copy(BitConverter.GetBytes(0), 0, block, i, 4); + } + listOfBlocks.Add(block); + } + + +#if AESCRYPTO + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + block = new byte[4 + 7]; + int i = 0; + // extra field for WinZip AES + // header id + block[i++] = 0x01; + block[i++] = 0x99; + + // data size + block[i++] = 0x07; + block[i++] = 0x00; + + // vendor number + block[i++] = 0x01; // AE-1 - means "Verify CRC" + block[i++] = 0x00; + + // vendor id "AE" + block[i++] = 0x41; + block[i++] = 0x45; + + // key strength + int keystrength = GetKeyStrengthInBits(Encryption); + if (keystrength == 128) + block[i] = 1; + else if (keystrength == 256) + block[i] = 3; + else + block[i] = 0xFF; + i++; + + // actual compression method + block[i++] = (byte)(_CompressionMethod & 0x00FF); + block[i++] = (byte)(_CompressionMethod & 0xFF00); + + listOfBlocks.Add(block); + } +#endif + + if (_ntfsTimesAreSet && _emitNtfsTimes) + { + block = new byte[32 + 4]; + // HeaderId 2 bytes 0x000a == NTFS times + // Datasize 2 bytes 32 + // reserved 4 bytes ?? don't care + // timetag 2 bytes 0x0001 == NTFS time + // size 2 bytes 24 == 8 bytes each for ctime, mtime, atime + // mtime 8 bytes win32 ticks since win32epoch + // atime 8 bytes win32 ticks since win32epoch + // ctime 8 bytes win32 ticks since win32epoch + int i = 0; + // extra field for NTFS times + // header id + block[i++] = 0x0a; + block[i++] = 0x00; + + // data size + block[i++] = 32; + block[i++] = 0; + + i += 4; // reserved + + // time tag + block[i++] = 0x01; + block[i++] = 0x00; + + // data size (again) + block[i++] = 24; + block[i++] = 0; + + Int64 z = _Mtime.ToFileTime(); + Array.Copy(BitConverter.GetBytes(z), 0, block, i, 8); + i += 8; + z = _Atime.ToFileTime(); + Array.Copy(BitConverter.GetBytes(z), 0, block, i, 8); + i += 8; + z = _Ctime.ToFileTime(); + Array.Copy(BitConverter.GetBytes(z), 0, block, i, 8); + i += 8; + + listOfBlocks.Add(block); + } + + if (_ntfsTimesAreSet && _emitUnixTimes) + { + int len = 5 + 4; + if (!forCentralDirectory) len += 8; + + block = new byte[len]; + // local form: + // -------------- + // HeaderId 2 bytes 0x5455 == unix timestamp + // Datasize 2 bytes 13 + // flags 1 byte 7 (low three bits all set) + // mtime 4 bytes seconds since unix epoch + // atime 4 bytes seconds since unix epoch + // ctime 4 bytes seconds since unix epoch + // + // central directory form: + //--------------------------------- + // HeaderId 2 bytes 0x5455 == unix timestamp + // Datasize 2 bytes 5 + // flags 1 byte 7 (low three bits all set) + // mtime 4 bytes seconds since unix epoch + // + int i = 0; + // extra field for "unix" times + // header id + block[i++] = 0x55; + block[i++] = 0x54; + + // data size + block[i++] = unchecked((byte)(len - 4)); + block[i++] = 0; + + // flags + block[i++] = 0x07; + + Int32 z = unchecked((int)((_Mtime - _unixEpoch).TotalSeconds)); + Array.Copy(BitConverter.GetBytes(z), 0, block, i, 4); + i += 4; + if (!forCentralDirectory) + { + z = unchecked((int)((_Atime - _unixEpoch).TotalSeconds)); + Array.Copy(BitConverter.GetBytes(z), 0, block, i, 4); + i += 4; + z = unchecked((int)((_Ctime - _unixEpoch).TotalSeconds)); + Array.Copy(BitConverter.GetBytes(z), 0, block, i, 4); + i += 4; + } + listOfBlocks.Add(block); + } + + + // inject other blocks here... + + + // concatenate any blocks we've got: + byte[] aggregateBlock = null; + if (listOfBlocks.Count > 0) + { + int totalLength = 0; + int i, current = 0; + for (i = 0; i < listOfBlocks.Count; i++) + totalLength += listOfBlocks[i].Length; + aggregateBlock = new byte[totalLength]; + for (i = 0; i < listOfBlocks.Count; i++) + { + System.Array.Copy(listOfBlocks[i], 0, aggregateBlock, current, listOfBlocks[i].Length); + current += listOfBlocks[i].Length; + } + } + + return aggregateBlock; + } + + + + // private System.Text.Encoding GenerateCommentBytes() + // { + // var getEncoding = new Func({ + // switch (AlternateEncodingUsage) + // { + // case ZipOption.Always: + // return AlternateEncoding; + // case ZipOption.Never: + // return ibm437; + // } + // var cb = ibm437.GetBytes(_Comment); + // // need to use this form of GetString() for .NET CF + // string s1 = ibm437.GetString(cb, 0, cb.Length); + // if (s1 == _Comment) + // return ibm437; + // return AlternateEncoding; + // }); + // + // var encoding = getEncoding(); + // _CommentBytes = encoding.GetBytes(_Comment); + // return encoding; + // } + + + private string NormalizeFileName() + { + // here, we need to flip the backslashes to forward-slashes, + // also, we need to trim the \\server\share syntax from any UNC path. + // and finally, we need to remove any leading .\ + + string SlashFixed = FileName.Replace("\\", "/"); + string s1 = null; + if ((_TrimVolumeFromFullyQualifiedPaths) && (FileName.Length >= 3) + && (FileName[1] == ':') && (SlashFixed[2] == '/')) + { + // trim off volume letter, colon, and slash + s1 = SlashFixed.Substring(3); + } + else if ((FileName.Length >= 4) + && ((SlashFixed[0] == '/') && (SlashFixed[1] == '/'))) + { + int n = SlashFixed.IndexOf('/', 2); + if (n == -1) + throw new ArgumentException("The path for that entry appears to be badly formatted"); + s1 = SlashFixed.Substring(n + 1); + } + else if ((FileName.Length >= 3) + && ((SlashFixed[0] == '.') && (SlashFixed[1] == '/'))) + { + // trim off dot and slash + s1 = SlashFixed.Substring(2); + } + else + { + s1 = SlashFixed; + } + return s1; + } + + + /// + /// generate and return a byte array that encodes the filename + /// for the entry. + /// + /// + /// + /// side effects: generate and store into _CommentBytes the + /// byte array for any comment attached to the entry. Also + /// sets _actualEncoding to indicate the actual encoding + /// used. The same encoding is used for both filename and + /// comment. + /// + /// + private byte[] GetEncodedFileNameBytes() + { + // workitem 6513 + var s1 = NormalizeFileName(); + + switch(AlternateEncodingUsage) + { + case ZipOption.Always: + if (!(_Comment == null || _Comment.Length == 0)) + _CommentBytes = AlternateEncoding.GetBytes(_Comment); + _actualEncoding = AlternateEncoding; + return AlternateEncoding.GetBytes(s1); + + case ZipOption.Never: + if (!(_Comment == null || _Comment.Length == 0)) + _CommentBytes = ibm437.GetBytes(_Comment); + _actualEncoding = ibm437; + return ibm437.GetBytes(s1); + } + + // arriving here means AlternateEncodingUsage is "AsNecessary" + + // case ZipOption.AsNecessary: + // workitem 6513: when writing, use the alternative encoding + // only when _actualEncoding is not yet set (it can be set + // during Read), and when ibm437 will not do. + + byte[] result = ibm437.GetBytes(s1); + // need to use this form of GetString() for .NET CF + string s2 = ibm437.GetString(result, 0, result.Length); + _CommentBytes = null; + if (s2 != s1) + { + // Encoding the filename with ibm437 does not allow round-trips. + // Therefore, use the alternate encoding. Assume it will work, + // no checking of round trips here. + result = AlternateEncoding.GetBytes(s1); + if (_Comment != null && _Comment.Length != 0) + _CommentBytes = AlternateEncoding.GetBytes(_Comment); + _actualEncoding = AlternateEncoding; + return result; + } + + _actualEncoding = ibm437; + + // Using ibm437, FileName can be encoded without information + // loss; now try the Comment. + + // if there is no comment, use ibm437. + if (_Comment == null || _Comment.Length == 0) + return result; + + // there is a comment. Get the encoded form. + byte[] cbytes = ibm437.GetBytes(_Comment); + string c2 = ibm437.GetString(cbytes,0,cbytes.Length); + + // Check for round-trip. + if (c2 != Comment) + { + // Comment cannot correctly be encoded with ibm437. Use + // the alternate encoding. + + result = AlternateEncoding.GetBytes(s1); + _CommentBytes = AlternateEncoding.GetBytes(_Comment); + _actualEncoding = AlternateEncoding; + return result; + } + + // use IBM437 + _CommentBytes = cbytes; + return result; + } + + + + private bool WantReadAgain() + { + if (_UncompressedSize < 0x10) return false; + if (_CompressionMethod == 0x00) return false; + if (CompressionLevel == Ionic.Zlib.CompressionLevel.None) return false; + if (_CompressedSize < _UncompressedSize) return false; + + if (this._Source == ZipEntrySource.Stream && !this._sourceStream.CanSeek) return false; + +#if AESCRYPTO + if (_aesCrypto_forWrite != null && (CompressedSize - _aesCrypto_forWrite.SizeOfEncryptionMetadata) <= UncompressedSize + 0x10) return false; +#endif + + if (_zipCrypto_forWrite != null && (CompressedSize - 12) <= UncompressedSize) return false; + + return true; + } + + + + private void MaybeUnsetCompressionMethodForWriting(int cycle) + { + // if we've already tried with compression... turn it off this time + if (cycle > 1) + { + _CompressionMethod = 0x0; + return; + } + // compression for directories = 0x00 (No Compression) + if (IsDirectory) + { + _CompressionMethod = 0x0; + return; + } + + if (this._Source == ZipEntrySource.ZipFile) + { + return; // do nothing + } + + // If __FileDataPosition is zero, then that means we will get the data + // from a file or stream. + + // It is never possible to compress a zero-length file, so we check for + // this condition. + + if (this._Source == ZipEntrySource.Stream) + { + // workitem 7742 + if (_sourceStream != null && _sourceStream.CanSeek) + { + // Length prop will throw if CanSeek is false + long fileLength = _sourceStream.Length; + if (fileLength == 0) + { + _CompressionMethod = 0x00; + return; + } + } + } + else if ((this._Source == ZipEntrySource.FileSystem) && (SharedUtilities.GetFileLength(LocalFileName) == 0L)) + { + _CompressionMethod = 0x00; + return; + } + + // Ok, we're getting the data to be compressed from a + // non-zero-length file or stream, or a file or stream of + // unknown length, and we presume that it is non-zero. In + // that case we check the callback to see if the app wants + // to tell us whether to compress or not. + if (SetCompression != null) + CompressionLevel = SetCompression(LocalFileName, _FileNameInArchive); + + // finally, set CompressionMethod to None if CompressionLevel is None + if (CompressionLevel == (short)Ionic.Zlib.CompressionLevel.None && + CompressionMethod == Ionic.Zip.CompressionMethod.Deflate) + _CompressionMethod = 0x00; + + return; + } + + + + // write the header info for an entry + internal void WriteHeader(Stream s, int cycle) + { + // Must remember the offset, within the output stream, of this particular + // entry header. + // + // This is for 2 reasons: + // + // 1. so we can determine the RelativeOffsetOfLocalHeader (ROLH) for + // use in the central directory. + // 2. so we can seek backward in case there is an error opening or reading + // the file, and the application decides to skip the file. In this case, + // we need to seek backward in the output stream to allow the next entry + // to be added to the zipfile output stream. + // + // Normally you would just store the offset before writing to the output + // stream and be done with it. But the possibility to use split archives + // makes this approach ineffective. In split archives, each file or segment + // is bound to a max size limit, and each local file header must not span a + // segment boundary; it must be written contiguously. If it will fit in the + // current segment, then the ROLH is just the current Position in the output + // stream. If it won't fit, then we need a new file (segment) and the ROLH + // is zero. + // + // But we only can know if it is possible to write a header contiguously + // after we know the size of the local header, a size that varies with + // things like filename length, comments, and extra fields. We have to + // compute the header fully before knowing whether it will fit. + // + // That takes care of item #1 above. Now, regarding #2. If an error occurs + // while computing the local header, we want to just seek backward. The + // exception handling logic (in the caller of WriteHeader) uses ROLH to + // scroll back. + // + // All this means we have to preserve the starting offset before computing + // the header, and also we have to compute the offset later, to handle the + // case of split archives. + + var counter = s as CountingStream; + + // workitem 8098: ok (output) + // This may change later, for split archives + + // Don't set _RelativeOffsetOfLocalHeader. Instead, set a temp variable. + // This allows for re-streaming, where a zip entry might be read from a + // zip archive (and maybe decrypted, and maybe decompressed) and then + // written to another zip archive, with different settings for + // compression method, compression level, or encryption algorithm. + _future_ROLH = (counter != null) + ? counter.ComputedPosition + : s.Position; + + int j = 0, i = 0; + + byte[] block = new byte[30]; + + // signature + block[i++] = (byte)(ZipConstants.ZipEntrySignature & 0x000000FF); + block[i++] = (byte)((ZipConstants.ZipEntrySignature & 0x0000FF00) >> 8); + block[i++] = (byte)((ZipConstants.ZipEntrySignature & 0x00FF0000) >> 16); + block[i++] = (byte)((ZipConstants.ZipEntrySignature & 0xFF000000) >> 24); + + // Design notes for ZIP64: + // + // The specification says that the header must include the Compressed + // and Uncompressed sizes, as well as the CRC32 value. When creating + // a zip via streamed processing, these quantities are not known until + // after the compression is done. Thus, a typical way to do it is to + // insert zeroes for these quantities, then do the compression, then + // seek back to insert the appropriate values, then seek forward to + // the end of the file data. + // + // There is also the option of using bit 3 in the GP bitfield - to + // specify that there is a data descriptor after the file data + // containing these three quantities. + // + // This works when the size of the quantities is known, either 32-bits + // or 64 bits as with the ZIP64 extensions. + // + // With Zip64, the 4-byte fields are set to 0xffffffff, and there is a + // corresponding data block in the "extra field" that contains the + // actual Compressed, uncompressed sizes. (As well as an additional + // field, the "Relative Offset of Local Header") + // + // The problem is when the app desires to use ZIP64 extensions + // optionally, only when necessary. Suppose the library assumes no + // zip64 extensions when writing the header, then after compression + // finds that the size of the data requires zip64. At this point, the + // header, already written to the file, won't have the necessary data + // block in the "extra field". The size of the entry header is fixed, + // so it is not possible to just "add on" the zip64 data block after + // compressing the file. On the other hand, always using zip64 will + // break interoperability with many other systems and apps. + // + // The approach we take is to insert a 32-byte dummy data block in the + // extra field, whenever zip64 is to be used "as necessary". This data + // block will get the actual zip64 HeaderId and zip64 metadata if + // necessary. If not necessary, the data block will get a meaningless + // HeaderId (0x1111), and will be filled with zeroes. + // + // When zip64 is actually in use, we also need to set the + // VersionNeededToExtract field to 45. + // + // There is one additional wrinkle: using zip64 as necessary conflicts + // with output to non-seekable devices. The header is emitted and + // must indicate whether zip64 is in use, before we know if zip64 is + // necessary. Because there is no seeking, the header can never be + // changed. Therefore, on non-seekable devices, + // Zip64Option.AsNecessary is the same as Zip64Option.Always. + // + + + // version needed- see AppNote.txt. + // + // need v5.1 for PKZIP strong encryption, or v2.0 for no encryption or + // for PK encryption, 4.5 for zip64. We may reset this later, as + // necessary or zip64. + + _presumeZip64 = (_container.Zip64 == Zip64Option.Always || + (_container.Zip64 == Zip64Option.AsNecessary && !s.CanSeek)); + Int16 VersionNeededToExtract = (Int16)(_presumeZip64 ? 45 : 20); +#if BZIP + if (this.CompressionMethod == Ionic.Zip.CompressionMethod.BZip2) + VersionNeededToExtract = 46; +#endif + + // (i==4) + block[i++] = (byte)(VersionNeededToExtract & 0x00FF); + block[i++] = (byte)((VersionNeededToExtract & 0xFF00) >> 8); + + // Get byte array. Side effect: sets ActualEncoding. + // Must determine encoding before setting the bitfield. + // workitem 6513 + byte[] fileNameBytes = GetEncodedFileNameBytes(); + Int16 filenameLength = (Int16)fileNameBytes.Length; + + // general purpose bitfield + // In the current implementation, this library uses only these bits + // in the GP bitfield: + // bit 0 = if set, indicates the entry is encrypted + // bit 3 = if set, indicates the CRC, C and UC sizes follow the file data. + // bit 6 = strong encryption - for pkware's meaning of strong encryption + // bit 11 = UTF-8 encoding is used in the comment and filename + + + // Here we set or unset the encryption bit. + // _BitField may already be set, as with a ZipEntry added into ZipOutputStream, which + // has bit 3 always set. We only want to set one bit + if (_Encryption == EncryptionAlgorithm.None) + _BitField &= ~1; // encryption bit OFF + else + _BitField |= 1; // encryption bit ON + + + // workitem 7941: WinZip does not the "strong encryption" bit when using AES. + // This "Strong Encryption" is a PKWare Strong encryption thing. + // _BitField |= 0x0020; + + // set the UTF8 bit if necessary +#if SILVERLIGHT + if (_actualEncoding.WebName == "utf-8") +#else + if (_actualEncoding.CodePage == System.Text.Encoding.UTF8.CodePage) +#endif + _BitField |= 0x0800; + + // The PKZIP spec says that if bit 3 is set (0x0008) in the General + // Purpose BitField, then the CRC, Compressed size, and uncompressed + // size are written directly after the file data. + // + // These 3 quantities are normally present in the regular zip entry + // header. But, they are not knowable until after the compression is + // done. So, in the normal case, we + // + // - write the header, using zeros for these quantities + // - compress the data, and incidentally compute these quantities. + // - seek back and write the correct values them into the header. + // + // This is nice because, while it is more complicated to write the zip + // file, it is simpler and less error prone to read the zip file, and + // as a result more applications can read zip files produced this way, + // with those 3 quantities in the header. + // + // But if seeking in the output stream is not possible, then we need + // to set the appropriate bitfield and emit these quantities after the + // compressed file data in the output. + // + // workitem 7216 - having trouble formatting a zip64 file that is + // readable by WinZip. not sure why! What I found is that setting + // bit 3 and following all the implications, the zip64 file is + // readable by WinZip 12. and Perl's IO::Compress::Zip . Perl takes + // an interesting approach - it always sets bit 3 if ZIP64 in use. + // DotNetZip now does the same; this gives better compatibility with + // WinZip 12. + + if (IsDirectory || cycle == 99) + { + // (cycle == 99) indicates a zero-length entry written by ZipOutputStream + + _BitField &= ~0x0008; // unset bit 3 - no "data descriptor" - ever + _BitField &= ~0x0001; // unset bit 1 - no encryption - ever + Encryption = EncryptionAlgorithm.None; + Password = null; + } + else if (!s.CanSeek) + _BitField |= 0x0008; + +#if DONT_GO_THERE + else if (this.Encryption == EncryptionAlgorithm.PkzipWeak && + this._Source != ZipEntrySource.ZipFile) + { + // Set bit 3 to avoid the double-read perf issue. + // + // When PKZIP encryption is used, byte 11 of the encryption header is + // used as a consistency check. It is normally set to the MSByte of the + // CRC. But this means the cRC must be known ebfore compression and + // encryption, which means the entire stream has to be read twice. To + // avoid that, the high-byte of the time blob (when in DOS format) can + // be used for the consistency check (byte 11 in the encryption header). + // But this means the entry must have bit 3 set. + // + // Previously I used a more complex arrangement - using the methods like + // FigureCrc32(), PrepOutputStream() and others, in order to manage the + // seek-back in the source stream. Why? Because bit 3 is not always + // friendly with third-party zip tools, like those on the Mac. + // + // This is why this code is still ifdef'd out. + // + // Might consider making this yet another programmable option - + // AlwaysUseBit3ForPkzip. But that's for another day. + // + _BitField |= 0x0008; + } +#endif + + // (i==6) + block[i++] = (byte)(_BitField & 0x00FF); + block[i++] = (byte)((_BitField & 0xFF00) >> 8); + + // Here, we want to set values for Compressed Size, Uncompressed Size, + // and CRC. If we have __FileDataPosition as not -1 (zero is a valid + // FDP), then that means we are reading this zip entry from a zip + // file, and we have good values for those quantities. + // + // If _FileDataPosition is -1, then we are constructing this Entry + // from nothing. We zero those quantities now, and we will compute + // actual values for the three quantities later, when we do the + // compression, and then seek back to write them into the appropriate + // place in the header. + if (this.__FileDataPosition == -1) + { + //_UncompressedSize = 0; // do not unset - may need this value for restream + // _Crc32 = 0; // ditto + _CompressedSize = 0; + _crcCalculated = false; + } + + // set compression method here + MaybeUnsetCompressionMethodForWriting(cycle); + + // (i==8) compression method + block[i++] = (byte)(_CompressionMethod & 0x00FF); + block[i++] = (byte)((_CompressionMethod & 0xFF00) >> 8); + + if (cycle == 99) + { + // (cycle == 99) indicates a zero-length entry written by ZipOutputStream + SetZip64Flags(); + } + +#if AESCRYPTO + else if (Encryption == EncryptionAlgorithm.WinZipAes128 || Encryption == EncryptionAlgorithm.WinZipAes256) + { + i -= 2; + block[i++] = 0x63; + block[i++] = 0; + } +#endif + + // LastMod + _TimeBlob = Ionic.Zip.SharedUtilities.DateTimeToPacked(LastModified); + + // (i==10) time blob + block[i++] = (byte)(_TimeBlob & 0x000000FF); + block[i++] = (byte)((_TimeBlob & 0x0000FF00) >> 8); + block[i++] = (byte)((_TimeBlob & 0x00FF0000) >> 16); + block[i++] = (byte)((_TimeBlob & 0xFF000000) >> 24); + + // (i==14) CRC - if source==filesystem, this is zero now, actual value + // will be calculated later. if source==archive, this is a bonafide + // value. + block[i++] = (byte)(_Crc32 & 0x000000FF); + block[i++] = (byte)((_Crc32 & 0x0000FF00) >> 8); + block[i++] = (byte)((_Crc32 & 0x00FF0000) >> 16); + block[i++] = (byte)((_Crc32 & 0xFF000000) >> 24); + + if (_presumeZip64) + { + // (i==18) CompressedSize (Int32) and UncompressedSize - all 0xFF for now + for (j = 0; j < 8; j++) + block[i++] = 0xFF; + } + else + { + // (i==18) CompressedSize (Int32) - this value may or may not be + // bonafide. if source == filesystem, then it is zero, and we'll + // learn it after we compress. if source == archive, then it is + // bonafide data. + block[i++] = (byte)(_CompressedSize & 0x000000FF); + block[i++] = (byte)((_CompressedSize & 0x0000FF00) >> 8); + block[i++] = (byte)((_CompressedSize & 0x00FF0000) >> 16); + block[i++] = (byte)((_CompressedSize & 0xFF000000) >> 24); + + // (i==22) UncompressedSize (Int32) - this value may or may not be + // bonafide. + block[i++] = (byte)(_UncompressedSize & 0x000000FF); + block[i++] = (byte)((_UncompressedSize & 0x0000FF00) >> 8); + block[i++] = (byte)((_UncompressedSize & 0x00FF0000) >> 16); + block[i++] = (byte)((_UncompressedSize & 0xFF000000) >> 24); + } + + // (i==26) filename length (Int16) + block[i++] = (byte)(filenameLength & 0x00FF); + block[i++] = (byte)((filenameLength & 0xFF00) >> 8); + + _Extra = ConstructExtraField(false); + + // (i==28) extra field length (short) + Int16 extraFieldLength = (Int16)((_Extra == null) ? 0 : _Extra.Length); + block[i++] = (byte)(extraFieldLength & 0x00FF); + block[i++] = (byte)((extraFieldLength & 0xFF00) >> 8); + + // workitem 13542 + byte[] bytes = new byte[i + filenameLength + extraFieldLength]; + + // get the fixed portion + Buffer.BlockCopy(block, 0, bytes, 0, i); + //for (j = 0; j < i; j++) bytes[j] = block[j]; + + // The filename written to the archive. + Buffer.BlockCopy(fileNameBytes, 0, bytes, i, fileNameBytes.Length); + // for (j = 0; j < fileNameBytes.Length; j++) + // bytes[i + j] = fileNameBytes[j]; + + i += fileNameBytes.Length; + + // "Extra field" + if (_Extra != null) + { + Buffer.BlockCopy(_Extra, 0, bytes, i, _Extra.Length); + // for (j = 0; j < _Extra.Length; j++) + // bytes[i + j] = _Extra[j]; + i += _Extra.Length; + } + + _LengthOfHeader = i; + + // handle split archives + var zss = s as ZipSegmentedStream; + if (zss != null) + { + zss.ContiguousWrite = true; + UInt32 requiredSegment = zss.ComputeSegment(i); + if (requiredSegment != zss.CurrentSegment) + _future_ROLH = 0; // rollover! + else + _future_ROLH = zss.Position; + + _diskNumber = requiredSegment; + } + + // validate the ZIP64 usage + if (_container.Zip64 == Zip64Option.Never && (uint)_RelativeOffsetOfLocalHeader >= 0xFFFFFFFF) + throw new ZipException("Offset within the zip archive exceeds 0xFFFFFFFF. Consider setting the UseZip64WhenSaving property on the ZipFile instance."); + + + // finally, write the header to the stream + s.Write(bytes, 0, i); + + // now that the header is written, we can turn off the contiguous write restriction. + if (zss != null) + zss.ContiguousWrite = false; + + // Preserve this header data, we'll use it again later. + // ..when seeking backward, to write again, after we have the Crc, compressed + // and uncompressed sizes. + // ..and when writing the central directory structure. + _EntryHeader = bytes; + } + + + + + private Int32 FigureCrc32() + { + if (_crcCalculated == false) + { + Stream input = null; + // get the original stream: + if (this._Source == ZipEntrySource.WriteDelegate) + { + var output = new Ionic.Crc.CrcCalculatorStream(Stream.Null); + // allow the application to write the data + this._WriteDelegate(this.FileName, output); + _Crc32 = output.Crc; + } + else if (this._Source == ZipEntrySource.ZipFile) + { + // nothing to do - the CRC is already set + } + else + { + if (this._Source == ZipEntrySource.Stream) + { + PrepSourceStream(); + input = this._sourceStream; + } + else if (this._Source == ZipEntrySource.JitStream) + { + // allow the application to open the stream + if (this._sourceStream == null) + _sourceStream = this._OpenDelegate(this.FileName); + PrepSourceStream(); + input = this._sourceStream; + } + else if (this._Source == ZipEntrySource.ZipOutputStream) + { + } + else + { + //input = File.OpenRead(LocalFileName); + input = File.Open(LocalFileName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); + } + + var crc32 = new Ionic.Crc.CRC32(); + _Crc32 = crc32.GetCrc32(input); + + if (_sourceStream == null) + { +#if NETCF + input.Close(); +#else + input.Dispose(); +#endif + } + } + _crcCalculated = true; + } + return _Crc32; + } + + + /// + /// Stores the position of the entry source stream, or, if the position is + /// already stored, seeks to that position. + /// + /// + /// + /// + /// This method is called in prep for reading the source stream. If PKZIP + /// encryption is used, then we need to calc the CRC32 before doing the + /// encryption, because the CRC is used in the 12th byte of the PKZIP + /// encryption header. So, we need to be able to seek backward in the source + /// when saving the ZipEntry. This method is called from the place that + /// calculates the CRC, and also from the method that does the encryption of + /// the file data. + /// + /// + /// + /// The first time through, this method sets the _sourceStreamOriginalPosition + /// field. Subsequent calls to this method seek to that position. + /// + /// + private void PrepSourceStream() + { + if (_sourceStream == null) + throw new ZipException(String.Format("The input stream is null for entry '{0}'.", FileName)); + + if (this._sourceStreamOriginalPosition != null) + { + // this will happen the 2nd cycle through, if the stream is seekable + this._sourceStream.Position = this._sourceStreamOriginalPosition.Value; + } + else if (this._sourceStream.CanSeek) + { + // this will happen the first cycle through, if seekable + this._sourceStreamOriginalPosition = new Nullable(this._sourceStream.Position); + } + else if (this.Encryption == EncryptionAlgorithm.PkzipWeak) + { + // In general, using PKZIP encryption on a a zip entry whose input + // comes from a non-seekable stream, is tricky. Here's why: + // + // Byte 11 of the PKZIP encryption header is used for password + // validation and consistency checknig. + // + // Normally, the highest byte of the CRC is used as the 11th (last) byte + // in the PKZIP encryption header. This means the CRC must be known + // before encryption is performed. Normally that means we read the full + // data stream, compute the CRC, then seek back and read it again for + // the compression+encryption phase. Obviously this is bad for + // performance with a large input file. + // + // There's a twist in the ZIP spec (actually documented only in infozip + // code, not in the spec itself) that allows the high-order byte of the + // last modified time for the entry, when the lastmod time is in packed + // (DOS) format, to be used for Byte 11 in the encryption header. In + // this case, the bit 3 "data descriptor" must be used. + // + // An intelligent implementation would therefore force the use of the + // bit 3 data descriptor when PKZIP encryption is in use, regardless. + // This avoids the double-read of the stream to be encrypted. So far, + // DotNetZip doesn't do that; it just punts when the input stream is + // non-seekable, and the output does not use Bit 3. + // + // The other option is to use the CRC when it is already available, eg, + // when the source for the data is a ZipEntry (when the zip file is + // being updated). In this case we already know the CRC and can just use + // what we know. + + if (this._Source != ZipEntrySource.ZipFile && ((this._BitField & 0x0008) != 0x0008)) + throw new ZipException("It is not possible to use PKZIP encryption on a non-seekable input stream"); + } + } + + + /// + /// Copy metadata that may have been changed by the app. We do this when + /// resetting the zipFile instance. If the app calls Save() on a ZipFile, then + /// tries to party on that file some more, we may need to Reset() it , which + /// means re-reading the entries and then copying the metadata. I think. + /// + internal void CopyMetaData(ZipEntry source) + { + this.__FileDataPosition = source.__FileDataPosition; + this.CompressionMethod = source.CompressionMethod; + this._CompressionMethod_FromZipFile = source._CompressionMethod_FromZipFile; + this._CompressedFileDataSize = source._CompressedFileDataSize; + this._UncompressedSize = source._UncompressedSize; + this._BitField = source._BitField; + this._Source = source._Source; + this._LastModified = source._LastModified; + this._Mtime = source._Mtime; + this._Atime = source._Atime; + this._Ctime = source._Ctime; + this._ntfsTimesAreSet = source._ntfsTimesAreSet; + this._emitUnixTimes = source._emitUnixTimes; + this._emitNtfsTimes = source._emitNtfsTimes; + } + + + private void OnWriteBlock(Int64 bytesXferred, Int64 totalBytesToXfer) + { + if (_container.ZipFile != null) + _ioOperationCanceled = _container.ZipFile.OnSaveBlock(this, bytesXferred, totalBytesToXfer); + } + + + + private void _WriteEntryData(Stream s) + { + // Read in the data from the input stream (often a file in the filesystem), + // and write it to the output stream, calculating a CRC on it as we go. + // We will also compress and encrypt as necessary. + + Stream input = null; + long fdp = -1L; + try + { + // Want to record the position in the zip file of the zip entry + // data (as opposed to the metadata). s.Position may fail on some + // write-only streams, eg stdout or System.Web.HttpResponseStream. + // We swallow that exception, because we don't care, in that case. + // But, don't set __FileDataPosition directly. It may be needed + // to READ the zip entry from the zip file, if this is a + // "re-stream" situation. In other words if the zip entry has + // changed compression level, or compression method, or (maybe?) + // encryption algorithm. In that case if the original entry is + // encrypted, we need __FileDataPosition to be the value for the + // input zip file. This s.Position is for the output zipfile. So + // we copy fdp to __FileDataPosition after this entry has been + // (maybe) restreamed. + fdp = s.Position; + } + catch (Exception) { } + + try + { + // Use fileLength for progress updates, and to decide whether we can + // skip encryption and compression altogether (in case of length==zero) + long fileLength = SetInputAndFigureFileLength(ref input); + + // Wrap a counting stream around the raw output stream: + // This is the last thing that happens before the bits go to the + // application-provided stream. + // + // Sometimes s is a CountingStream. Doesn't matter. Wrap it with a + // counter anyway. We need to count at both levels. + + CountingStream entryCounter = new CountingStream(s); + + Stream encryptor; + Stream compressor; + + if (fileLength != 0L) + { + // Maybe wrap an encrypting stream around the counter: This will + // happen BEFORE output counting, and AFTER compression, if encryption + // is used. + encryptor = MaybeApplyEncryption(entryCounter); + + // Maybe wrap a compressing Stream around that. + // This will happen BEFORE encryption (if any) as we write data out. + compressor = MaybeApplyCompression(encryptor, fileLength); + } + else + { + encryptor = compressor = entryCounter; + } + + // Wrap a CrcCalculatorStream around that. + // This will happen BEFORE compression (if any) as we write data out. + var output = new Ionic.Crc.CrcCalculatorStream(compressor, true); + + // output.Write() causes this flow: + // calc-crc -> compress -> encrypt -> count -> actually write + + if (this._Source == ZipEntrySource.WriteDelegate) + { + // allow the application to write the data + this._WriteDelegate(this.FileName, output); + } + else + { + // synchronously copy the input stream to the output stream-chain + byte[] buffer = new byte[BufferSize]; + int n; + while ((n = SharedUtilities.ReadWithRetry(input, buffer, 0, buffer.Length, FileName)) != 0) + { + output.Write(buffer, 0, n); + OnWriteBlock(output.TotalBytesSlurped, fileLength); + if (_ioOperationCanceled) + break; + } + } + + FinishOutputStream(s, entryCounter, encryptor, compressor, output); + } + finally + { + if (this._Source == ZipEntrySource.JitStream) + { + // allow the application to close the stream + if (this._CloseDelegate != null) + this._CloseDelegate(this.FileName, input); + } + else if ((input as FileStream) != null) + { +#if NETCF + input.Close(); +#else + input.Dispose(); +#endif + } + } + + if (_ioOperationCanceled) + return; + + // set FDP now, to allow for re-streaming + this.__FileDataPosition = fdp; + PostProcessOutput(s); + } + + + /// + /// Set the input stream and get its length, if possible. The length is + /// used for progress updates, AND, to allow an optimization in case of + /// a stream/file of zero length. In that case we skip the Encrypt and + /// compression Stream. (like DeflateStream or BZip2OutputStream) + /// + private long SetInputAndFigureFileLength(ref Stream input) + { + long fileLength = -1L; + // get the original stream: + if (this._Source == ZipEntrySource.Stream) + { + PrepSourceStream(); + input = this._sourceStream; + + // Try to get the length, no big deal if not available. + try { fileLength = this._sourceStream.Length; } + catch (NotSupportedException) { } + } + else if (this._Source == ZipEntrySource.ZipFile) + { + // we are "re-streaming" the zip entry. + string pwd = (_Encryption_FromZipFile == EncryptionAlgorithm.None) ? null : (this._Password ?? this._container.Password); + this._sourceStream = InternalOpenReader(pwd); + PrepSourceStream(); + input = this._sourceStream; + fileLength = this._sourceStream.Length; + } + else if (this._Source == ZipEntrySource.JitStream) + { + // allow the application to open the stream + if (this._sourceStream == null) _sourceStream = this._OpenDelegate(this.FileName); + PrepSourceStream(); + input = this._sourceStream; + try { fileLength = this._sourceStream.Length; } + catch (NotSupportedException) { } + } + else if (this._Source == ZipEntrySource.FileSystem) + { + // workitem 7145 + FileShare fs = FileShare.ReadWrite; +#if !NETCF + // FileShare.Delete is not defined for the Compact Framework + fs |= FileShare.Delete; +#endif + // workitem 8423 + input = File.Open(LocalFileName, FileMode.Open, FileAccess.Read, fs); + fileLength = input.Length; + } + + return fileLength; + } + + + + internal void FinishOutputStream(Stream s, + CountingStream entryCounter, + Stream encryptor, + Stream compressor, + Ionic.Crc.CrcCalculatorStream output) + { + if (output == null) return; + + output.Close(); + + // by calling Close() on the deflate stream, we write the footer bytes, as necessary. + if ((compressor as Ionic.Zlib.DeflateStream) != null) + compressor.Close(); +#if BZIP + else if ((compressor as Ionic.BZip2.BZip2OutputStream) != null) + compressor.Close(); +#if !NETCF + else if ((compressor as Ionic.BZip2.ParallelBZip2OutputStream) != null) + compressor.Close(); +#endif +#endif + +#if !NETCF + else if ((compressor as Ionic.Zlib.ParallelDeflateOutputStream) != null) + compressor.Close(); +#endif + + encryptor.Flush(); + encryptor.Close(); + + _LengthOfTrailer = 0; + + _UncompressedSize = output.TotalBytesSlurped; + +#if AESCRYPTO + WinZipAesCipherStream wzacs = encryptor as WinZipAesCipherStream; + if (wzacs != null && _UncompressedSize > 0) + { + s.Write(wzacs.FinalAuthentication, 0, 10); + _LengthOfTrailer += 10; + } +#endif + _CompressedFileDataSize = entryCounter.BytesWritten; + _CompressedSize = _CompressedFileDataSize; // may be adjusted + _Crc32 = output.Crc; + + // Set _RelativeOffsetOfLocalHeader now, to allow for re-streaming + StoreRelativeOffset(); + } + + + + + internal void PostProcessOutput(Stream s) + { + var s1 = s as CountingStream; + + // workitem 8931 - for WriteDelegate. + // The WriteDelegate changes things because there can be a zero-byte stream + // written. In all other cases DotNetZip knows the length of the stream + // before compressing and encrypting. In this case we have to circle back, + // and omit all the crypto stuff - the GP bitfield, and the crypto header. + if (_UncompressedSize == 0 && _CompressedSize == 0) + { + if (this._Source == ZipEntrySource.ZipOutputStream) return; // nothing to do... + + if (_Password != null) + { + int headerBytesToRetract = 0; + if (Encryption == EncryptionAlgorithm.PkzipWeak) + headerBytesToRetract = 12; +#if AESCRYPTO + else if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + headerBytesToRetract = _aesCrypto_forWrite._Salt.Length + _aesCrypto_forWrite.GeneratedPV.Length; + } +#endif + if (this._Source == ZipEntrySource.ZipOutputStream && !s.CanSeek) + throw new ZipException("Zero bytes written, encryption in use, and non-seekable output."); + + if (Encryption != EncryptionAlgorithm.None) + { + // seek back in the stream to un-output the security metadata + s.Seek(-1 * headerBytesToRetract, SeekOrigin.Current); + s.SetLength(s.Position); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(s); + + // workitem 11131 + // adjust the count on the CountingStream as necessary + if (s1 != null) s1.Adjust(headerBytesToRetract); + + // subtract the size of the security header from the _LengthOfHeader + _LengthOfHeader -= headerBytesToRetract; + __FileDataPosition -= headerBytesToRetract; + } + _Password = null; + + // turn off the encryption bit + _BitField &= ~(0x0001); + + // copy the updated bitfield value into the header + int j = 6; + _EntryHeader[j++] = (byte)(_BitField & 0x00FF); + _EntryHeader[j++] = (byte)((_BitField & 0xFF00) >> 8); + +#if AESCRYPTO + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + // Fix the extra field - overwrite the 0x9901 headerId + // with dummy data. (arbitrarily, 0x9999) + Int16 fnLength = (short)(_EntryHeader[26] + _EntryHeader[27] * 256); + int offx = 30 + fnLength; + int aesIndex = FindExtraFieldSegment(_EntryHeader, offx, 0x9901); + if (aesIndex >= 0) + { + _EntryHeader[aesIndex++] = 0x99; + _EntryHeader[aesIndex++] = 0x99; + } + } +#endif + } + + CompressionMethod = 0; + Encryption = EncryptionAlgorithm.None; + } + else if (_zipCrypto_forWrite != null +#if AESCRYPTO + || _aesCrypto_forWrite != null +#endif + ) + + { + if (Encryption == EncryptionAlgorithm.PkzipWeak) + { + _CompressedSize += 12; // 12 extra bytes for the encryption header + } +#if AESCRYPTO + else if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + // adjust the compressed size to include the variable (salt+pv) + // security header and 10-byte trailer. According to the winzip AES + // spec, that metadata is included in the "Compressed Size" figure + // when encoding the zip archive. + _CompressedSize += _aesCrypto_forWrite.SizeOfEncryptionMetadata; + } +#endif + } + + int i = 8; + _EntryHeader[i++] = (byte)(_CompressionMethod & 0x00FF); + _EntryHeader[i++] = (byte)((_CompressionMethod & 0xFF00) >> 8); + + i = 14; + // CRC - the correct value now + _EntryHeader[i++] = (byte)(_Crc32 & 0x000000FF); + _EntryHeader[i++] = (byte)((_Crc32 & 0x0000FF00) >> 8); + _EntryHeader[i++] = (byte)((_Crc32 & 0x00FF0000) >> 16); + _EntryHeader[i++] = (byte)((_Crc32 & 0xFF000000) >> 24); + + SetZip64Flags(); + + // (i==26) filename length (Int16) + Int16 filenameLength = (short)(_EntryHeader[26] + _EntryHeader[27] * 256); + Int16 extraFieldLength = (short)(_EntryHeader[28] + _EntryHeader[29] * 256); + + if (_OutputUsesZip64.Value) + { + // VersionNeededToExtract - set to 45 to indicate zip64 + _EntryHeader[4] = (byte)(45 & 0x00FF); + _EntryHeader[5] = 0x00; + + // workitem 7924 - don't need bit 3 + // // workitem 7917 + // // set bit 3 for ZIP64 compatibility with WinZip12 + // _BitField |= 0x0008; + // _EntryHeader[6] = (byte)(_BitField & 0x00FF); + + // CompressedSize and UncompressedSize - 0xFF + for (int j = 0; j < 8; j++) + _EntryHeader[i++] = 0xff; + + // At this point we need to find the "Extra field" that follows the + // filename. We had already emitted it, but the data (uncomp, comp, + // ROLH) was not available at the time we did so. Here, we emit it + // again, with final values. + + i = 30 + filenameLength; + _EntryHeader[i++] = 0x01; // zip64 + _EntryHeader[i++] = 0x00; + + i += 2; // skip over data size, which is 16+4 + + Array.Copy(BitConverter.GetBytes(_UncompressedSize), 0, _EntryHeader, i, 8); + i += 8; + Array.Copy(BitConverter.GetBytes(_CompressedSize), 0, _EntryHeader, i, 8); + } + else + { + // VersionNeededToExtract - reset to 20 since no zip64 + _EntryHeader[4] = (byte)(20 & 0x00FF); + _EntryHeader[5] = 0x00; + + // CompressedSize - the correct value now + i = 18; + _EntryHeader[i++] = (byte)(_CompressedSize & 0x000000FF); + _EntryHeader[i++] = (byte)((_CompressedSize & 0x0000FF00) >> 8); + _EntryHeader[i++] = (byte)((_CompressedSize & 0x00FF0000) >> 16); + _EntryHeader[i++] = (byte)((_CompressedSize & 0xFF000000) >> 24); + + // UncompressedSize - the correct value now + _EntryHeader[i++] = (byte)(_UncompressedSize & 0x000000FF); + _EntryHeader[i++] = (byte)((_UncompressedSize & 0x0000FF00) >> 8); + _EntryHeader[i++] = (byte)((_UncompressedSize & 0x00FF0000) >> 16); + _EntryHeader[i++] = (byte)((_UncompressedSize & 0xFF000000) >> 24); + + // The HeaderId in the extra field header, is already dummied out. + if (extraFieldLength != 0) + { + i = 30 + filenameLength; + // For zip archives written by this library, if the zip64 + // header exists, it is the first header. Because of the logic + // used when first writing the _EntryHeader bytes, the + // HeaderId is not guaranteed to be any particular value. So + // we determine if the first header is a putative zip64 header + // by examining the datasize. UInt16 HeaderId = + // (UInt16)(_EntryHeader[i] + _EntryHeader[i + 1] * 256); + Int16 DataSize = (short)(_EntryHeader[i + 2] + _EntryHeader[i + 3] * 256); + if (DataSize == 16) + { + // reset to Header Id to dummy value, effectively dummy-ing out the zip64 metadata + _EntryHeader[i++] = 0x99; + _EntryHeader[i++] = 0x99; + } + } + } + + +#if AESCRYPTO + + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + // Must set compressionmethod to 0x0063 (decimal 99) + // + // and then set the compression method bytes inside the extra + // field to the actual compression method value. + + i = 8; + _EntryHeader[i++] = 0x63; + _EntryHeader[i++] = 0; + + i = 30 + filenameLength; + do + { + UInt16 HeaderId = (UInt16)(_EntryHeader[i] + _EntryHeader[i + 1] * 256); + Int16 DataSize = (short)(_EntryHeader[i + 2] + _EntryHeader[i + 3] * 256); + if (HeaderId != 0x9901) + { + // skip this header + i += DataSize + 4; + } + else + { + i += 9; + // actual compression method + _EntryHeader[i++] = (byte)(_CompressionMethod & 0x00FF); + _EntryHeader[i++] = (byte)(_CompressionMethod & 0xFF00); + } + } while (i < (extraFieldLength - 30 - filenameLength)); + } +#endif + + // finally, write the data. + + // workitem 7216 - sometimes we don't seek even if we CAN. ASP.NET + // Response.OutputStream, or stdout are non-seekable. But we may also want + // to NOT seek in other cases, eg zip64. For all cases, we just check bit 3 + // to see if we want to seek. There's one exception - if using a + // ZipOutputStream, and PKZip encryption is in use, then we set bit 3 even + // if the out is seekable. This is so the check on the last byte of the + // PKZip Encryption Header can be done on the current time, as opposed to + // the CRC, to prevent streaming the file twice. So, test for + // ZipOutputStream and seekable, and if so, seek back, even if bit 3 is set. + + if ((_BitField & 0x0008) != 0x0008 || + (this._Source == ZipEntrySource.ZipOutputStream && s.CanSeek)) + { + // seek back and rewrite the entry header + var zss = s as ZipSegmentedStream; + if (zss != null && _diskNumber != zss.CurrentSegment) + { + // In this case the entry header is in a different file, + // which has already been closed. Need to re-open it. + using (Stream hseg = ZipSegmentedStream.ForUpdate(this._container.ZipFile.Name, _diskNumber)) + { + hseg.Seek(this._RelativeOffsetOfLocalHeader, SeekOrigin.Begin); + hseg.Write(_EntryHeader, 0, _EntryHeader.Length); + } + } + else + { + // seek in the raw output stream, to the beginning of the header for + // this entry. + // workitem 8098: ok (output) + s.Seek(this._RelativeOffsetOfLocalHeader, SeekOrigin.Begin); + + // write the updated header to the output stream + s.Write(_EntryHeader, 0, _EntryHeader.Length); + + // adjust the count on the CountingStream as necessary + if (s1 != null) s1.Adjust(_EntryHeader.Length); + + // seek in the raw output stream, to the end of the file data + // for this entry + s.Seek(_CompressedSize, SeekOrigin.Current); + } + } + + // emit the descriptor - only if not a directory. + if (((_BitField & 0x0008) == 0x0008) && !IsDirectory) + { + byte[] Descriptor = new byte[16 + (_OutputUsesZip64.Value ? 8 : 0)]; + i = 0; + + // signature + Array.Copy(BitConverter.GetBytes(ZipConstants.ZipEntryDataDescriptorSignature), 0, Descriptor, i, 4); + i += 4; + + // CRC - the correct value now + Array.Copy(BitConverter.GetBytes(_Crc32), 0, Descriptor, i, 4); + i += 4; + + // workitem 7917 + if (_OutputUsesZip64.Value) + { + // CompressedSize - the correct value now + Array.Copy(BitConverter.GetBytes(_CompressedSize), 0, Descriptor, i, 8); + i += 8; + + // UncompressedSize - the correct value now + Array.Copy(BitConverter.GetBytes(_UncompressedSize), 0, Descriptor, i, 8); + i += 8; + } + else + { + // CompressedSize - (lower 32 bits) the correct value now + Descriptor[i++] = (byte)(_CompressedSize & 0x000000FF); + Descriptor[i++] = (byte)((_CompressedSize & 0x0000FF00) >> 8); + Descriptor[i++] = (byte)((_CompressedSize & 0x00FF0000) >> 16); + Descriptor[i++] = (byte)((_CompressedSize & 0xFF000000) >> 24); + + // UncompressedSize - (lower 32 bits) the correct value now + Descriptor[i++] = (byte)(_UncompressedSize & 0x000000FF); + Descriptor[i++] = (byte)((_UncompressedSize & 0x0000FF00) >> 8); + Descriptor[i++] = (byte)((_UncompressedSize & 0x00FF0000) >> 16); + Descriptor[i++] = (byte)((_UncompressedSize & 0xFF000000) >> 24); + } + + // finally, write the trailing descriptor to the output stream + s.Write(Descriptor, 0, Descriptor.Length); + + _LengthOfTrailer += Descriptor.Length; + } + } + + + + private void SetZip64Flags() + { + // zip64 housekeeping + _entryRequiresZip64 = new Nullable + (_CompressedSize >= 0xFFFFFFFF || _UncompressedSize >= 0xFFFFFFFF || _RelativeOffsetOfLocalHeader >= 0xFFFFFFFF); + + // validate the ZIP64 usage + if (_container.Zip64 == Zip64Option.Never && _entryRequiresZip64.Value) + throw new ZipException("Compressed or Uncompressed size, or offset exceeds the maximum value. Consider setting the UseZip64WhenSaving property on the ZipFile instance."); + + _OutputUsesZip64 = new Nullable(_container.Zip64 == Zip64Option.Always || _entryRequiresZip64.Value); + } + + + + /// + /// Prepare the given stream for output - wrap it in a CountingStream, and + /// then in a CRC stream, and an encryptor and deflator as appropriate. + /// + /// + /// + /// Previously this was used in ZipEntry.Write(), but in an effort to + /// introduce some efficiencies in that method I've refactored to put the + /// code inline. This method still gets called by ZipOutputStream. + /// + /// + internal void PrepOutputStream(Stream s, + long streamLength, + out CountingStream outputCounter, + out Stream encryptor, + out Stream compressor, + out Ionic.Crc.CrcCalculatorStream output) + { + TraceWriteLine("PrepOutputStream: e({0}) comp({1}) crypto({2}) zf({3})", + FileName, + CompressionLevel, + Encryption, + _container.Name); + + // Wrap a counting stream around the raw output stream: + // This is the last thing that happens before the bits go to the + // application-provided stream. + outputCounter = new CountingStream(s); + + // Sometimes the incoming "raw" output stream is already a CountingStream. + // Doesn't matter. Wrap it with a counter anyway. We need to count at both + // levels. + + if (streamLength != 0L) + { + // Maybe wrap an encrypting stream around that: + // This will happen BEFORE output counting, and AFTER deflation, if encryption + // is used. + encryptor = MaybeApplyEncryption(outputCounter); + + // Maybe wrap a compressing Stream around that. + // This will happen BEFORE encryption (if any) as we write data out. + compressor = MaybeApplyCompression(encryptor, streamLength); + } + else + { + encryptor = compressor = outputCounter; + } + // Wrap a CrcCalculatorStream around that. + // This will happen BEFORE compression (if any) as we write data out. + output = new Ionic.Crc.CrcCalculatorStream(compressor, true); + } + + + + private Stream MaybeApplyCompression(Stream s, long streamLength) + { + if (_CompressionMethod == 0x08 && CompressionLevel != Ionic.Zlib.CompressionLevel.None) + { +#if !NETCF + // ParallelDeflateThreshold == 0 means ALWAYS use parallel deflate + // ParallelDeflateThreshold == -1L means NEVER use parallel deflate + // Other values specify the actual threshold. + if (_container.ParallelDeflateThreshold == 0L || + (streamLength > _container.ParallelDeflateThreshold && + _container.ParallelDeflateThreshold > 0L)) + { + // This is sort of hacky. + // + // It's expensive to create a ParallelDeflateOutputStream, because + // of the large memory buffers. But the class is unlike most Stream + // classes in that it can be re-used, so the caller can compress + // multiple files with it, one file at a time. The key is to call + // Reset() on it, in between uses. + // + // The ParallelDeflateOutputStream is attached to the container + // itself - there is just one for the entire ZipFile or + // ZipOutputStream. So it gets created once, per save, and then + // re-used many times. + // + // This approach will break when we go to a "parallel save" + // approach, where multiple entries within the zip file are being + // compressed and saved at the same time. But for now it's ok. + // + + // instantiate the ParallelDeflateOutputStream + if (_container.ParallelDeflater == null) + { + _container.ParallelDeflater = + new Ionic.Zlib.ParallelDeflateOutputStream(s, + CompressionLevel, + _container.Strategy, + true); + // can set the codec buffer size only before the first call to Write(). + if (_container.CodecBufferSize > 0) + _container.ParallelDeflater.BufferSize = _container.CodecBufferSize; + if (_container.ParallelDeflateMaxBufferPairs > 0) + _container.ParallelDeflater.MaxBufferPairs = + _container.ParallelDeflateMaxBufferPairs; + } + // reset it with the new stream + Ionic.Zlib.ParallelDeflateOutputStream o1 = _container.ParallelDeflater; + o1.Reset(s); + return o1; + } +#endif + var o = new Ionic.Zlib.DeflateStream(s, Ionic.Zlib.CompressionMode.Compress, + CompressionLevel, + true); + if (_container.CodecBufferSize > 0) + o.BufferSize = _container.CodecBufferSize; + o.Strategy = _container.Strategy; + return o; + } + + +#if BZIP + if (_CompressionMethod == 0x0c) + { +#if !NETCF + if (_container.ParallelDeflateThreshold == 0L || + (streamLength > _container.ParallelDeflateThreshold && + _container.ParallelDeflateThreshold > 0L)) + { + + var o1 = new Ionic.BZip2.ParallelBZip2OutputStream(s, true); + return o1; + } +#endif + var o = new Ionic.BZip2.BZip2OutputStream(s, true); + return o; + } +#endif + + return s; + } + + + + private Stream MaybeApplyEncryption(Stream s) + { + if (Encryption == EncryptionAlgorithm.PkzipWeak) + { + TraceWriteLine("MaybeApplyEncryption: e({0}) PKZIP", FileName); + + return new ZipCipherStream(s, _zipCrypto_forWrite, CryptoMode.Encrypt); + } +#if AESCRYPTO + if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + TraceWriteLine("MaybeApplyEncryption: e({0}) AES", FileName); + + return new WinZipAesCipherStream(s, _aesCrypto_forWrite, CryptoMode.Encrypt); + } +#endif + TraceWriteLine("MaybeApplyEncryption: e({0}) None", FileName); + + return s; + } + + + + private void OnZipErrorWhileSaving(Exception e) + { + if (_container.ZipFile != null) + _ioOperationCanceled = _container.ZipFile.OnZipErrorSaving(this, e); + } + + + + internal void Write(Stream s) + { + var cs1 = s as CountingStream; + var zss1 = s as ZipSegmentedStream; + + bool done = false; + do + { + try + { + // When the app is updating a zip file, it may be possible to + // just copy data for a ZipEntry from the source zipfile to the + // destination, as a block, without decompressing and + // recompressing, etc. But, in some cases the app modifies the + // properties on a ZipEntry prior to calling Save(). A change to + // any of the metadata - the FileName, CompressioLeve and so on, + // means DotNetZip cannot simply copy through the existing + // ZipEntry data unchanged. + // + // There are two cases: + // + // 1. Changes to only metadata, which means the header and + // central directory must be changed. + // + // 2. Changes to the properties that affect the compressed + // stream, such as CompressionMethod, CompressionLevel, or + // EncryptionAlgorithm. In this case, DotNetZip must + // "re-stream" the data: the old entry data must be maybe + // decrypted, maybe decompressed, then maybe re-compressed + // and maybe re-encrypted. + // + // This test checks if the source for the entry data is a zip file, and + // if a restream is necessary. If NOT, then it just copies through + // one entry, potentially changing the metadata. + + if (_Source == ZipEntrySource.ZipFile && !_restreamRequiredOnSave) + { + CopyThroughOneEntry(s); + return; + } + + // Is the entry a directory? If so, the write is relatively simple. + if (IsDirectory) + { + WriteHeader(s, 1); + StoreRelativeOffset(); + _entryRequiresZip64 = new Nullable(_RelativeOffsetOfLocalHeader >= 0xFFFFFFFF); + _OutputUsesZip64 = new Nullable(_container.Zip64 == Zip64Option.Always || _entryRequiresZip64.Value); + // handle case for split archives + if (zss1 != null) + _diskNumber = zss1.CurrentSegment; + + return; + } + + // At this point, the source for this entry is not a directory, and + // not a previously created zip file, or the source for the entry IS + // a previously created zip but the settings whave changed in + // important ways and therefore we will need to process the + // bytestream (compute crc, maybe compress, maybe encrypt) in order + // to write the content into the new zip. + // + // We do this in potentially 2 passes: The first time we do it as + // requested, maybe with compression and maybe encryption. If that + // causes the bytestream to inflate in size, and if compression was + // on, then we turn off compression and do it again. + + + bool readAgain = true; + int nCycles = 0; + do + { + nCycles++; + + WriteHeader(s, nCycles); + + // write the encrypted header + WriteSecurityMetadata(s); + + // write the (potentially compressed, potentially encrypted) file data + _WriteEntryData(s); + + // track total entry size (including the trailing descriptor and MAC) + _TotalEntrySize = _LengthOfHeader + _CompressedFileDataSize + _LengthOfTrailer; + + // The file data has now been written to the stream, and + // the file pointer is positioned directly after file data. + + if (nCycles > 1) readAgain = false; + else if (!s.CanSeek) readAgain = false; + else readAgain = WantReadAgain(); + + if (readAgain) + { + // Seek back in the raw output stream, to the beginning of the file + // data for this entry. + + // handle case for split archives + if (zss1 != null) + { + // Console.WriteLine("***_diskNumber/first: {0}", _diskNumber); + // Console.WriteLine("***_diskNumber/current: {0}", zss.CurrentSegment); + zss1.TruncateBackward(_diskNumber, _RelativeOffsetOfLocalHeader); + } + else + // workitem 8098: ok (output). + s.Seek(_RelativeOffsetOfLocalHeader, SeekOrigin.Begin); + + // If the last entry expands, we read again; but here, we must + // truncate the stream to prevent garbage data after the + // end-of-central-directory. + + // workitem 8098: ok (output). + s.SetLength(s.Position); + + // Adjust the count on the CountingStream as necessary. + if (cs1 != null) cs1.Adjust(_TotalEntrySize); + } + } + while (readAgain); + _skippedDuringSave = false; + done = true; + } + catch (System.Exception exc1) + { + ZipErrorAction orig = this.ZipErrorAction; + int loop = 0; + do + { + if (ZipErrorAction == ZipErrorAction.Throw) + throw; + + if (ZipErrorAction == ZipErrorAction.Skip || + ZipErrorAction == ZipErrorAction.Retry) + { + // must reset file pointer here. + // workitem 13903 - seek back only when necessary + long p1 = (cs1 != null) + ? cs1.ComputedPosition + : s.Position; + long delta = p1 - _future_ROLH; + if (delta > 0) + { + s.Seek(delta, SeekOrigin.Current); // may throw + long p2 = s.Position; + s.SetLength(s.Position); // to prevent garbage if this is the last entry + if (cs1 != null) cs1.Adjust(p1 - p2); + } + if (ZipErrorAction == ZipErrorAction.Skip) + { + WriteStatus("Skipping file {0} (exception: {1})", LocalFileName, exc1.ToString()); + + _skippedDuringSave = true; + done = true; + } + else + this.ZipErrorAction = orig; + break; + } + + if (loop > 0) throw; + + if (ZipErrorAction == ZipErrorAction.InvokeErrorEvent) + { + OnZipErrorWhileSaving(exc1); + if (_ioOperationCanceled) + { + done = true; + break; + } + } + loop++; + } + while (true); + } + } + while (!done); + } + + + internal void StoreRelativeOffset() + { + _RelativeOffsetOfLocalHeader = _future_ROLH; + } + + + + internal void NotifySaveComplete() + { + // When updating a zip file, there are two contexts for properties + // like Encryption or CompressionMethod - the values read from the + // original zip file, and the values used in the updated zip file. + // The _FromZipFile versions are the originals. At the end of a save, + // these values are the same. So we need to update them. This takes + // care of the boundary case where a single zipfile instance can be + // saved multiple times, with distinct changes to the properties on + // the entries, in between each Save(). + _Encryption_FromZipFile = _Encryption; + _CompressionMethod_FromZipFile = _CompressionMethod; + _restreamRequiredOnSave = false; + _metadataChanged = false; + //_Source = ZipEntrySource.None; + _Source = ZipEntrySource.ZipFile; // workitem 10694 + } + + + internal void WriteSecurityMetadata(Stream outstream) + { + if (Encryption == EncryptionAlgorithm.None) + return; + + string pwd = this._Password; + + // special handling for source == ZipFile. + // Want to support the case where we re-stream an encrypted entry. This will involve, + // at runtime, reading, decrypting, and decompressing from the original zip file, then + // compressing, encrypting, and writing to the output zip file. + + // If that's what we're doing, and the password hasn't been set on the entry, + // we use the container (ZipFile/ZipOutputStream) password to decrypt. + // This test here says to use the container password to re-encrypt, as well, + // with that password, if the entry password is null. + + if (this._Source == ZipEntrySource.ZipFile && pwd == null) + pwd = this._container.Password; + + if (pwd == null) + { + _zipCrypto_forWrite = null; +#if AESCRYPTO + _aesCrypto_forWrite = null; +#endif + return; + } + + TraceWriteLine("WriteSecurityMetadata: e({0}) crypto({1}) pw({2})", + FileName, Encryption.ToString(), pwd); + + if (Encryption == EncryptionAlgorithm.PkzipWeak) + { + // If PKZip (weak) encryption is in use, then the encrypted entry data + // is preceded by 12-byte "encryption header" for the entry. + + _zipCrypto_forWrite = ZipCrypto.ForWrite(pwd); + + // generate the random 12-byte header: + var rnd = new System.Random(); + byte[] encryptionHeader = new byte[12]; + rnd.NextBytes(encryptionHeader); + + // workitem 8271 + if ((this._BitField & 0x0008) == 0x0008) + { + // In the case that bit 3 of the general purpose bit flag is set to + // indicate the presence of a 'data descriptor' (signature + // 0x08074b50), the last byte of the decrypted header is sometimes + // compared with the high-order byte of the lastmodified time, + // rather than the high-order byte of the CRC, to verify the + // password. + // + // This is not documented in the PKWare Appnote.txt. + // This was discovered this by analysis of the Crypt.c source file in the + // InfoZip library + // http://www.info-zip.org/pub/infozip/ + + // Also, winzip insists on this! + _TimeBlob = Ionic.Zip.SharedUtilities.DateTimeToPacked(LastModified); + encryptionHeader[11] = (byte)((this._TimeBlob >> 8) & 0xff); + } + else + { + // When bit 3 is not set, the CRC value is required before + // encryption of the file data begins. In this case there is no way + // around it: must read the stream in its entirety to compute the + // actual CRC before proceeding. + FigureCrc32(); + encryptionHeader[11] = (byte)((this._Crc32 >> 24) & 0xff); + } + + // Encrypt the random header, INCLUDING the final byte which is either + // the high-order byte of the CRC32, or the high-order byte of the + // _TimeBlob. Must do this BEFORE encrypting the file data. This + // step changes the state of the cipher, or in the words of the PKZIP + // spec, it "further initializes" the cipher keys. + + byte[] cipherText = _zipCrypto_forWrite.EncryptMessage(encryptionHeader, encryptionHeader.Length); + + // Write the ciphered bonafide encryption header. + outstream.Write(cipherText, 0, cipherText.Length); + _LengthOfHeader += cipherText.Length; // 12 bytes + } + +#if AESCRYPTO + else if (Encryption == EncryptionAlgorithm.WinZipAes128 || + Encryption == EncryptionAlgorithm.WinZipAes256) + { + // If WinZip AES encryption is in use, then the encrypted entry data is + // preceded by a variable-sized Salt and a 2-byte "password + // verification" value for the entry. + + int keystrength = GetKeyStrengthInBits(Encryption); + _aesCrypto_forWrite = WinZipAesCrypto.Generate(pwd, keystrength); + outstream.Write(_aesCrypto_forWrite.Salt, 0, _aesCrypto_forWrite._Salt.Length); + outstream.Write(_aesCrypto_forWrite.GeneratedPV, 0, _aesCrypto_forWrite.GeneratedPV.Length); + _LengthOfHeader += _aesCrypto_forWrite._Salt.Length + _aesCrypto_forWrite.GeneratedPV.Length; + + TraceWriteLine("WriteSecurityMetadata: AES e({0}) keybits({1}) _LOH({2})", + FileName, keystrength, _LengthOfHeader); + + } +#endif + + } + + + + private void CopyThroughOneEntry(Stream outStream) + { + // Just read the entry from the existing input zipfile and write to the output. + // But, if metadata has changed (like file times or attributes), or if the ZIP64 + // option has changed, we can re-stream the entry data but must recompute the + // metadata. + if (this.LengthOfHeader == 0) + throw new BadStateException("Bad header length."); + + // is it necessary to re-constitute new metadata for this entry? + bool needRecompute = _metadataChanged || + (this.ArchiveStream is ZipSegmentedStream) || + (outStream is ZipSegmentedStream) || + (_InputUsesZip64 && _container.UseZip64WhenSaving == Zip64Option.Never) || + (!_InputUsesZip64 && _container.UseZip64WhenSaving == Zip64Option.Always); + + if (needRecompute) + CopyThroughWithRecompute(outStream); + else + CopyThroughWithNoChange(outStream); + + // zip64 housekeeping + _entryRequiresZip64 = new Nullable + (_CompressedSize >= 0xFFFFFFFF || _UncompressedSize >= 0xFFFFFFFF || + _RelativeOffsetOfLocalHeader >= 0xFFFFFFFF + ); + + _OutputUsesZip64 = new Nullable(_container.Zip64 == Zip64Option.Always || _entryRequiresZip64.Value); + } + + + + private void CopyThroughWithRecompute(Stream outstream) + { + int n; + byte[] bytes = new byte[BufferSize]; + var input = new CountingStream(this.ArchiveStream); + + long origRelativeOffsetOfHeader = _RelativeOffsetOfLocalHeader; + + // The header length may change due to rename of file, add a comment, etc. + // We need to retain the original. + int origLengthOfHeader = LengthOfHeader; // including crypto bytes! + + // WriteHeader() has the side effect of changing _RelativeOffsetOfLocalHeader + // and setting _LengthOfHeader. While ReadHeader() reads the crypto header if + // present, WriteHeader() does not write the crypto header. + WriteHeader(outstream, 0); + StoreRelativeOffset(); + + if (!this.FileName.EndsWith("/")) + { + // Not a directory; there is file data. + // Seek to the beginning of the entry data in the input stream. + + long pos = origRelativeOffsetOfHeader + origLengthOfHeader; + int len = GetLengthOfCryptoHeaderBytes(_Encryption_FromZipFile); + pos -= len; // want to keep the crypto header + _LengthOfHeader += len; + + input.Seek(pos, SeekOrigin.Begin); + + // copy through everything after the header to the output stream + long remaining = this._CompressedSize; + + while (remaining > 0) + { + len = (remaining > bytes.Length) ? bytes.Length : (int)remaining; + + // read + n = input.Read(bytes, 0, len); + //_CheckRead(n); + + // write + outstream.Write(bytes, 0, n); + remaining -= n; + OnWriteBlock(input.BytesRead, this._CompressedSize); + if (_ioOperationCanceled) + break; + } + + // bit 3 descriptor + if ((this._BitField & 0x0008) == 0x0008) + { + int size = 16; + if (_InputUsesZip64) size += 8; + byte[] Descriptor = new byte[size]; + input.Read(Descriptor, 0, size); + + if (_InputUsesZip64 && _container.UseZip64WhenSaving == Zip64Option.Never) + { + // original descriptor was 24 bytes, now we need 16. + // Must check for underflow here. + // signature + CRC. + outstream.Write(Descriptor, 0, 8); + + // Compressed + if (_CompressedSize > 0xFFFFFFFF) + throw new InvalidOperationException("ZIP64 is required"); + outstream.Write(Descriptor, 8, 4); + + // UnCompressed + if (_UncompressedSize > 0xFFFFFFFF) + throw new InvalidOperationException("ZIP64 is required"); + outstream.Write(Descriptor, 16, 4); + _LengthOfTrailer -= 8; + } + else if (!_InputUsesZip64 && _container.UseZip64WhenSaving == Zip64Option.Always) + { + // original descriptor was 16 bytes, now we need 24 + // signature + CRC + byte[] pad = new byte[4]; + outstream.Write(Descriptor, 0, 8); + // Compressed + outstream.Write(Descriptor, 8, 4); + outstream.Write(pad, 0, 4); + // UnCompressed + outstream.Write(Descriptor, 12, 4); + outstream.Write(pad, 0, 4); + _LengthOfTrailer += 8; + } + else + { + // same descriptor on input and output. Copy it through. + outstream.Write(Descriptor, 0, size); + //_LengthOfTrailer += size; + } + } + } + + _TotalEntrySize = _LengthOfHeader + _CompressedFileDataSize + _LengthOfTrailer; + } + + + private void CopyThroughWithNoChange(Stream outstream) + { + int n; + byte[] bytes = new byte[BufferSize]; + var input = new CountingStream(this.ArchiveStream); + + // seek to the beginning of the entry data in the input stream + input.Seek(this._RelativeOffsetOfLocalHeader, SeekOrigin.Begin); + + if (this._TotalEntrySize == 0) + { + // We've never set the length of the entry. + // Set it here. + this._TotalEntrySize = this._LengthOfHeader + this._CompressedFileDataSize + _LengthOfTrailer; + + // The CompressedSize includes all the leading metadata associated + // to encryption, if any, as well as the compressed data, or + // compressed-then-encrypted data, and the trailer in case of AES. + + // The CompressedFileData size is the same, less the encryption + // framing data (12 bytes header for PKZip; 10/18 bytes header and + // 10 byte trailer for AES). + + // The _LengthOfHeader includes all the zip entry header plus the + // crypto header, if any. The _LengthOfTrailer includes the + // 10-byte MAC for AES, where appropriate, and the bit-3 + // Descriptor, where applicable. + } + + + // workitem 5616 + // remember the offset, within the output stream, of this particular entry header. + // This may have changed if any of the other entries changed (eg, if a different + // entry was removed or added.) + var counter = outstream as CountingStream; + _RelativeOffsetOfLocalHeader = (counter != null) + ? counter.ComputedPosition + : outstream.Position; // BytesWritten + + // copy through the header, filedata, trailer, everything... + long remaining = this._TotalEntrySize; + while (remaining > 0) + { + int len = (remaining > bytes.Length) ? bytes.Length : (int)remaining; + + // read + n = input.Read(bytes, 0, len); + //_CheckRead(n); + + // write + outstream.Write(bytes, 0, n); + remaining -= n; + OnWriteBlock(input.BytesRead, this._TotalEntrySize); + if (_ioOperationCanceled) + break; + } + } + + + + + [System.Diagnostics.ConditionalAttribute("Trace")] + private void TraceWriteLine(string format, params object[] varParams) + { + lock (_outputLock) + { + int tid = System.Threading.Thread.CurrentThread.GetHashCode(); +#if ! (NETCF || SILVERLIGHT) + Console.ForegroundColor = (ConsoleColor)(tid % 8 + 8); +#endif + Console.Write("{0:000} ZipEntry.Write ", tid); + Console.WriteLine(format, varParams); +#if ! (NETCF || SILVERLIGHT) + Console.ResetColor(); +#endif + } + } + + private object _outputLock = new Object(); + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.cs new file mode 100644 index 00000000..fdb576fb --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntry.cs @@ -0,0 +1,2968 @@ +// ZipEntry.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2006-2010 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-06 17:25:53> +// +// ------------------------------------------------------------------ +// +// This module defines the ZipEntry class, which models the entries within a zip file. +// +// Created: Tue, 27 Mar 2007 15:30 +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; +using Interop = System.Runtime.InteropServices; + +namespace Ionic.Zip +{ + /// + /// Represents a single entry in a ZipFile. Typically, applications get a ZipEntry + /// by enumerating the entries within a ZipFile, or by adding an entry to a ZipFile. + /// + + [Interop.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d00004")] + [Interop.ComVisible(true)] +#if !NETCF + [Interop.ClassInterface(Interop.ClassInterfaceType.AutoDispatch)] // AutoDual +#endif + public partial class ZipEntry + { + /// + /// Default constructor. + /// + /// + /// Applications should never need to call this directly. It is exposed to + /// support COM Automation environments. + /// + public ZipEntry() + { + _CompressionMethod = (Int16)CompressionMethod.Deflate; + _CompressionLevel = Ionic.Zlib.CompressionLevel.Default; + _Encryption = EncryptionAlgorithm.None; + _Source = ZipEntrySource.None; + AlternateEncoding = System.Text.Encoding.GetEncoding("IBM437"); + AlternateEncodingUsage = ZipOption.Never; + } + + /// + /// The time and date at which the file indicated by the ZipEntry was + /// last modified. + /// + /// + /// + /// + /// The DotNetZip library sets the LastModified value for an entry, equal to + /// the Last Modified time of the file in the filesystem. If an entry is + /// added from a stream, the library uses System.DateTime.Now for this + /// value, for the given entry. + /// + /// + /// + /// This property allows the application to retrieve and possibly set the + /// LastModified value on an entry, to an arbitrary value. values with a + /// setting of DateTimeKind.Unspecified are taken to be expressed as + /// DateTimeKind.Local. + /// + /// + /// + /// Be aware that because of the way PKWare's + /// Zip specification describes how times are stored in the zip file, + /// the full precision of the System.DateTime datatype is not stored + /// for the last modified time when saving zip files. For more information on + /// how times are formatted, see the PKZip specification. + /// + /// + /// + /// The actual last modified time of a file can be stored in multiple ways in + /// the zip file, and they are not mutually exclusive: + /// + /// + /// + /// + /// In the so-called "DOS" format, which has a 2-second precision. Values + /// are rounded to the nearest even second. For example, if the time on the + /// file is 12:34:43, then it will be stored as 12:34:44. This first value + /// is accessible via the LastModified property. This value is always + /// present in the metadata for each zip entry. In some cases the value is + /// invalid, or zero. + /// + /// + /// + /// In the so-called "Windows" or "NTFS" format, as an 8-byte integer + /// quantity expressed as the number of 1/10 milliseconds (in other words + /// the number of 100 nanosecond units) since January 1, 1601 (UTC). This + /// format is how Windows represents file times. This time is accessible + /// via the ModifiedTime property. + /// + /// + /// + /// In the "Unix" format, a 4-byte quantity specifying the number of seconds since + /// January 1, 1970 UTC. + /// + /// + /// + /// In an older format, now deprecated but still used by some current + /// tools. This format is also a 4-byte quantity specifying the number of + /// seconds since January 1, 1970 UTC. + /// + /// + /// + /// + /// + /// Zip tools and libraries will always at least handle (read or write) the + /// DOS time, and may also handle the other time formats. Keep in mind that + /// while the names refer to particular operating systems, there is nothing in + /// the time formats themselves that prevents their use on other operating + /// systems. + /// + /// + /// + /// When reading ZIP files, the DotNetZip library reads the Windows-formatted + /// time, if it is stored in the entry, and sets both LastModified and + /// ModifiedTime to that value. When writing ZIP files, the DotNetZip + /// library by default will write both time quantities. It can also emit the + /// Unix-formatted time if desired (See .) + /// + /// + /// + /// The last modified time of the file created upon a call to + /// ZipEntry.Extract() may be adjusted during extraction to compensate + /// for differences in how the .NET Base Class Library deals with daylight + /// saving time (DST) versus how the Windows filesystem deals with daylight + /// saving time. Raymond Chen provides + /// some good context. + /// + /// + /// + /// In a nutshell: Daylight savings time rules change regularly. In 2007, for + /// example, the inception week of DST changed. In 1977, DST was in place all + /// year round. In 1945, likewise. And so on. Win32 does not attempt to + /// guess which time zone rules were in effect at the time in question. It + /// will render a time as "standard time" and allow the app to change to DST + /// as necessary. .NET makes a different choice. + /// + /// + /// + /// Compare the output of FileInfo.LastWriteTime.ToString("f") with what you + /// see in the Windows Explorer property sheet for a file that was last + /// written to on the other side of the DST transition. For example, suppose + /// the file was last modified on October 17, 2003, during DST but DST is not + /// currently in effect. Explorer's file properties reports Thursday, October + /// 17, 2003, 8:45:38 AM, but .NETs FileInfo reports Thursday, October 17, + /// 2003, 9:45 AM. + /// + /// + /// + /// Win32 says, "Thursday, October 17, 2002 8:45:38 AM PST". Note: Pacific + /// STANDARD Time. Even though October 17 of that year occurred during Pacific + /// Daylight Time, Win32 displays the time as standard time because that's + /// what time it is NOW. + /// + /// + /// + /// .NET BCL assumes that the current DST rules were in place at the time in + /// question. So, .NET says, "Well, if the rules in effect now were also in + /// effect on October 17, 2003, then that would be daylight time" so it + /// displays "Thursday, October 17, 2003, 9:45 AM PDT" - daylight time. + /// + /// + /// + /// So .NET gives a value which is more intuitively correct, but is also + /// potentially incorrect, and which is not invertible. Win32 gives a value + /// which is intuitively incorrect, but is strictly correct. + /// + /// + /// + /// Because of this funkiness, this library adds one hour to the LastModified + /// time on the extracted file, if necessary. That is to say, if the time in + /// question had occurred in what the .NET Base Class Library assumed to be + /// DST. This assumption may be wrong given the constantly changing DST rules, + /// but it is the best we can do. + /// + /// + /// + /// + public DateTime LastModified + { + get { return _LastModified.ToLocalTime(); } + set + { + _LastModified = (value.Kind == DateTimeKind.Unspecified) + ? DateTime.SpecifyKind(value, DateTimeKind.Local) + : value.ToLocalTime(); + _Mtime = Ionic.Zip.SharedUtilities.AdjustTime_Reverse(_LastModified).ToUniversalTime(); + _metadataChanged = true; + } + } + + + private int BufferSize + { + get + { + return this._container.BufferSize; + } + } + + /// + /// Last Modified time for the file represented by the entry. + /// + /// + /// + /// + /// + /// This value corresponds to the "last modified" time in the NTFS file times + /// as described in the Zip + /// specification. When getting this property, the value may be + /// different from . When setting the property, + /// the property also gets set, but with a lower + /// precision. + /// + /// + /// + /// Let me explain. It's going to take a while, so get + /// comfortable. Originally, waaaaay back in 1989 when the ZIP specification + /// was originally described by the esteemed Mr. Phil Katz, the dominant + /// operating system of the time was MS-DOS. MSDOS stored file times with a + /// 2-second precision, because, c'mon, who is ever going to need better + /// resolution than THAT? And so ZIP files, regardless of the platform on + /// which the zip file was created, store file times in exactly the same format that DOS used + /// in 1989. + /// + /// + /// + /// Since then, the ZIP spec has evolved, but the internal format for file + /// timestamps remains the same. Despite the fact that the way times are + /// stored in a zip file is rooted in DOS heritage, any program on any + /// operating system can format a time in this way, and most zip tools and + /// libraries DO - they round file times to the nearest even second and store + /// it just like DOS did 25+ years ago. + /// + /// + /// + /// PKWare extended the ZIP specification to allow a zip file to store what + /// are called "NTFS Times" and "Unix(tm) times" for a file. These are the + /// last write, last access, and file creation + /// times of a particular file. These metadata are not actually specific + /// to NTFS or Unix. They are tracked for each file by NTFS and by various + /// Unix filesystems, but they are also tracked by other filesystems, too. + /// The key point is that the times are formatted in the zip file + /// in the same way that NTFS formats the time (ticks since win32 epoch), + /// or in the same way that Unix formats the time (seconds since Unix + /// epoch). As with the DOS time, any tool or library running on any + /// operating system is capable of formatting a time in one of these ways + /// and embedding it into the zip file. + /// + /// + /// + /// These extended times are higher precision quantities than the DOS time. + /// As described above, the (DOS) LastModified has a precision of 2 seconds. + /// The Unix time is stored with a precision of 1 second. The NTFS time is + /// stored with a precision of 0.0000001 seconds. The quantities are easily + /// convertible, except for the loss of precision you may incur. + /// + /// + /// + /// A zip archive can store the {C,A,M} times in NTFS format, in Unix format, + /// or not at all. Often a tool running on Unix or Mac will embed the times + /// in Unix format (1 second precision), while WinZip running on Windows might + /// embed the times in NTFS format (precision of of 0.0000001 seconds). When + /// reading a zip file with these "extended" times, in either format, + /// DotNetZip represents the values with the + /// ModifiedTime, AccessedTime and CreationTime + /// properties on the ZipEntry. + /// + /// + /// + /// While any zip application or library, regardless of the platform it + /// runs on, could use any of the time formats allowed by the ZIP + /// specification, not all zip tools or libraries do support all these + /// formats. Storing the higher-precision times for each entry is + /// optional for zip files, and many tools and libraries don't use the + /// higher precision quantities at all. The old DOS time, represented by + /// , is guaranteed to be present, though it + /// sometimes unset. + /// + /// + /// + /// Ok, getting back to the question about how the LastModified + /// property relates to this ModifiedTime + /// property... LastModified is always set, while + /// ModifiedTime is not. (The other times stored in the NTFS + /// times extension, CreationTime and AccessedTime also + /// may not be set on an entry that is read from an existing zip file.) + /// When reading a zip file, then LastModified takes the DOS time + /// that is stored with the file. If the DOS time has been stored as zero + /// in the zipfile, then this library will use DateTime.Now for the + /// LastModified value. If the ZIP file was created by an evolved + /// tool, then there will also be higher precision NTFS or Unix times in + /// the zip file. In that case, this library will read those times, and + /// set LastModified and ModifiedTime to the same value, the + /// one corresponding to the last write time of the file. If there are no + /// higher precision times stored for the entry, then ModifiedTime + /// remains unset (likewise AccessedTime and CreationTime), + /// and LastModified keeps its DOS time. + /// + /// + /// + /// When creating zip files with this library, by default the extended time + /// properties (ModifiedTime, AccessedTime, and + /// CreationTime) are set on the ZipEntry instance, and these data are + /// stored in the zip archive for each entry, in NTFS format. If you add an + /// entry from an actual filesystem file, then the entry gets the actual file + /// times for that file, to NTFS-level precision. If you add an entry from a + /// stream, or a string, then the times get the value DateTime.Now. In + /// this case LastModified and ModifiedTime will be identical, + /// to 2 seconds of precision. You can explicitly set the + /// CreationTime, AccessedTime, and ModifiedTime of an + /// entry using the property setters. If you want to set all of those + /// quantities, it's more efficient to use the method. Those + /// changes are not made permanent in the zip file until you call or one of its cousins. + /// + /// + /// + /// When creating a zip file, you can override the default behavior of + /// this library for formatting times in the zip file, disabling the + /// embedding of file times in NTFS format or enabling the storage of file + /// times in Unix format, or both. You may want to do this, for example, + /// when creating a zip file on Windows, that will be consumed on a Mac, + /// by an application that is not hip to the "NTFS times" format. To do + /// this, use the and + /// properties. A valid zip + /// file may store the file times in both formats. But, there are no + /// guarantees that a program running on Mac or Linux will gracefully + /// handle the NTFS-formatted times when Unix times are present, or that a + /// non-DotNetZip-powered application running on Windows will be able to + /// handle file times in Unix format. DotNetZip will always do something + /// reasonable; other libraries or tools may not. When in doubt, test. + /// + /// + /// + /// I'll bet you didn't think one person could type so much about time, eh? + /// And reading it was so enjoyable, too! Well, in appreciation, maybe you + /// should donate? + /// + /// + /// + /// + /// + /// + /// + public DateTime ModifiedTime + { + get { return _Mtime; } + set + { + SetEntryTimes(_Ctime, _Atime, value); + } + } + + /// + /// Last Access time for the file represented by the entry. + /// + /// + /// This value may or may not be meaningful. If the ZipEntry was read from an existing + /// Zip archive, this information may not be available. For an explanation of why, see + /// . + /// + /// + /// + /// + public DateTime AccessedTime + { + get { return _Atime; } + set + { + SetEntryTimes(_Ctime, value, _Mtime); + } + } + + /// + /// The file creation time for the file represented by the entry. + /// + /// + /// + /// This value may or may not be meaningful. If the ZipEntry was read + /// from an existing zip archive, and the creation time was not set on the entry + /// when the zip file was created, then this property may be meaningless. For an + /// explanation of why, see . + /// + /// + /// + /// + public DateTime CreationTime + { + get { return _Ctime; } + set + { + SetEntryTimes(value, _Atime, _Mtime); + } + } + + /// + /// Sets the NTFS Creation, Access, and Modified times for the given entry. + /// + /// + /// + /// + /// When adding an entry from a file or directory, the Creation, Access, and + /// Modified times for the given entry are automatically set from the + /// filesystem values. When adding an entry from a stream or string, the + /// values are implicitly set to DateTime.Now. The application may wish to + /// set these values to some arbitrary value, before saving the archive, and + /// can do so using the various setters. If you want to set all of the times, + /// this method is more efficient. + /// + /// + /// + /// The values you set here will be retrievable with the , and properties. + /// + /// + /// + /// When this method is called, if both and are false, then the + /// EmitTimesInWindowsFormatWhenSaving flag is automatically set. + /// + /// + /// + /// DateTime values provided here without a DateTimeKind are assumed to be Local Time. + /// + /// + /// + /// the creation time of the entry. + /// the last access time of the entry. + /// the last modified time of the entry. + /// + /// + /// + /// + /// + /// + public void SetEntryTimes(DateTime created, DateTime accessed, DateTime modified) + { + _ntfsTimesAreSet = true; + if (created == _zeroHour && created.Kind == _zeroHour.Kind) created = _win32Epoch; + if (accessed == _zeroHour && accessed.Kind == _zeroHour.Kind) accessed = _win32Epoch; + if (modified == _zeroHour && modified.Kind == _zeroHour.Kind) modified = _win32Epoch; + _Ctime = created.ToUniversalTime(); + _Atime = accessed.ToUniversalTime(); + _Mtime = modified.ToUniversalTime(); + _LastModified = _Mtime; + if (!_emitUnixTimes && !_emitNtfsTimes) + _emitNtfsTimes = true; + _metadataChanged = true; + } + + + + /// + /// Specifies whether the Creation, Access, and Modified times for the given + /// entry will be emitted in "Windows format" when the zip archive is saved. + /// + /// + /// + /// + /// An application creating a zip archive can use this flag to explicitly + /// specify that the file times for the entry should or should not be stored + /// in the zip archive in the format used by Windows. The default value of + /// this property is true. + /// + /// + /// + /// When adding an entry from a file or directory, the Creation (), Access (), and Modified + /// () times for the given entry are automatically + /// set from the filesystem values. When adding an entry from a stream or + /// string, all three values are implicitly set to DateTime.Now. Applications + /// can also explicitly set those times by calling . + /// + /// + /// + /// PKWARE's + /// zip specification describes multiple ways to format these times in a + /// zip file. One is the format Windows applications normally use: 100ns ticks + /// since Jan 1, 1601 UTC. The other is a format Unix applications typically + /// use: seconds since January 1, 1970 UTC. Each format can be stored in an + /// "extra field" in the zip entry when saving the zip archive. The former + /// uses an extra field with a Header Id of 0x000A, while the latter uses a + /// header ID of 0x5455. + /// + /// + /// + /// Not all zip tools and libraries can interpret these fields. Windows + /// compressed folders is one that can read the Windows Format timestamps, + /// while I believe the Infozip + /// tools can read the Unix format timestamps. Although the time values are + /// easily convertible, subject to a loss of precision, some tools and + /// libraries may be able to read only one or the other. DotNetZip can read or + /// write times in either or both formats. + /// + /// + /// + /// The times stored are taken from , , and . + /// + /// + /// + /// This property is not mutually exclusive from the property. It is + /// possible that a zip entry can embed the timestamps in both forms, one + /// form, or neither. But, there are no guarantees that a program running on + /// Mac or Linux will gracefully handle NTFS Formatted times, or that a + /// non-DotNetZip-powered application running on Windows will be able to + /// handle file times in Unix format. When in doubt, test. + /// + /// + /// + /// Normally you will use the ZipFile.EmitTimesInWindowsFormatWhenSaving + /// property, to specify the behavior for all entries in a zip, rather than + /// the property on each individual entry. + /// + /// + /// + /// + /// + /// + /// + /// + /// + public bool EmitTimesInWindowsFormatWhenSaving + { + get + { + return _emitNtfsTimes; + } + set + { + _emitNtfsTimes = value; + _metadataChanged = true; + } + } + + /// + /// Specifies whether the Creation, Access, and Modified times for the given + /// entry will be emitted in "Unix(tm) format" when the zip archive is saved. + /// + /// + /// + /// + /// An application creating a zip archive can use this flag to explicitly + /// specify that the file times for the entry should or should not be stored + /// in the zip archive in the format used by Unix. By default this flag is + /// false, meaning the Unix-format times are not stored in the zip + /// archive. + /// + /// + /// + /// When adding an entry from a file or directory, the Creation (), Access (), and Modified + /// () times for the given entry are automatically + /// set from the filesystem values. When adding an entry from a stream or + /// string, all three values are implicitly set to DateTime.Now. Applications + /// can also explicitly set those times by calling . + /// + /// + /// + /// PKWARE's + /// zip specification describes multiple ways to format these times in a + /// zip file. One is the format Windows applications normally use: 100ns ticks + /// since Jan 1, 1601 UTC. The other is a format Unix applications typically + /// use: seconds since Jan 1, 1970 UTC. Each format can be stored in an + /// "extra field" in the zip entry when saving the zip archive. The former + /// uses an extra field with a Header Id of 0x000A, while the latter uses a + /// header ID of 0x5455. + /// + /// + /// + /// Not all tools and libraries can interpret these fields. Windows + /// compressed folders is one that can read the Windows Format timestamps, + /// while I believe the Infozip + /// tools can read the Unix format timestamps. Although the time values are + /// easily convertible, subject to a loss of precision, some tools and + /// libraries may be able to read only one or the other. DotNetZip can read or + /// write times in either or both formats. + /// + /// + /// + /// The times stored are taken from , , and . + /// + /// + /// + /// This property is not mutually exclusive from the property. It is + /// possible that a zip entry can embed the timestamps in both forms, one + /// form, or neither. But, there are no guarantees that a program running on + /// Mac or Linux will gracefully handle NTFS Formatted times, or that a + /// non-DotNetZip-powered application running on Windows will be able to + /// handle file times in Unix format. When in doubt, test. + /// + /// + /// + /// Normally you will use the ZipFile.EmitTimesInUnixFormatWhenSaving + /// property, to specify the behavior for all entries, rather than the + /// property on each individual entry. + /// + /// + /// + /// + /// + /// + /// + /// + /// + public bool EmitTimesInUnixFormatWhenSaving + { + get + { + return _emitUnixTimes; + } + set + { + _emitUnixTimes = value; + _metadataChanged = true; + } + } + + + /// + /// The type of timestamp attached to the ZipEntry. + /// + /// + /// + /// This property is valid only for a ZipEntry that was read from a zip archive. + /// It indicates the type of timestamp attached to the entry. + /// + /// + /// + /// + public ZipEntryTimestamp Timestamp + { + get + { + return _timestamp; + } + } + + /// + /// The file attributes for the entry. + /// + /// + /// + /// + /// + /// The attributes in NTFS include + /// ReadOnly, Archive, Hidden, System, and Indexed. When adding a + /// ZipEntry to a ZipFile, these attributes are set implicitly when + /// adding an entry from the filesystem. When adding an entry from a stream + /// or string, the Attributes are not set implicitly. Regardless of the way + /// an entry was added to a ZipFile, you can set the attributes + /// explicitly if you like. + /// + /// + /// + /// When reading a ZipEntry from a ZipFile, the attributes are + /// set according to the data stored in the ZipFile. If you extract the + /// entry from the archive to a filesystem file, DotNetZip will set the + /// attributes on the resulting file accordingly. + /// + /// + /// + /// The attributes can be set explicitly by the application. For example the + /// application may wish to set the FileAttributes.ReadOnly bit for all + /// entries added to an archive, so that on unpack, this attribute will be set + /// on the extracted file. Any changes you make to this property are made + /// permanent only when you call a Save() method on the ZipFile + /// instance that contains the ZipEntry. + /// + /// + /// + /// For example, an application may wish to zip up a directory and set the + /// ReadOnly bit on every file in the archive, so that upon later extraction, + /// the resulting files will be marked as ReadOnly. Not every extraction tool + /// respects these attributes, but if you unpack with DotNetZip, as for + /// example in a self-extracting archive, then the attributes will be set as + /// they are stored in the ZipFile. + /// + /// + /// + /// These attributes may not be interesting or useful if the resulting archive + /// is extracted on a non-Windows platform. How these attributes get used + /// upon extraction depends on the platform and tool used. + /// + /// + /// + /// This property is only partially supported in the Silverlight version + /// of the library: applications can read attributes on entries within + /// ZipFiles. But extracting entries within Silverlight will not set the + /// attributes on the extracted files. + /// + /// + /// + public System.IO.FileAttributes Attributes + { + // workitem 7071 + get { return (System.IO.FileAttributes)_ExternalFileAttrs; } + set + { + _ExternalFileAttrs = (int)value; + // Since the application is explicitly setting the attributes, overwriting + // whatever was there, we will explicitly set the Version made by field. + // workitem 7926 - "version made by" OS should be zero for compat with WinZip + _VersionMadeBy = (0 << 8) + 45; // v4.5 of the spec + _metadataChanged = true; + } + } + + + /// + /// The name of the filesystem file, referred to by the ZipEntry. + /// + /// + /// + /// + /// This property specifies the thing-to-be-zipped on disk, and is set only + /// when the ZipEntry is being created from a filesystem file. If the + /// ZipFile is instantiated by reading an existing .zip archive, then + /// the LocalFileName will be null (Nothing in VB). + /// + /// + /// + /// When it is set, the value of this property may be different than , which is the path used in the archive itself. If you + /// call Zip.AddFile("foop.txt", AlternativeDirectory), then the path + /// used for the ZipEntry within the zip archive will be different + /// than this path. + /// + /// + /// + /// If the entry is being added from a stream, then this is null (Nothing in VB). + /// + /// + /// + /// + internal string LocalFileName + { + get { return _LocalFileName; } + } + + /// + /// The name of the file contained in the ZipEntry. + /// + /// + /// + /// + /// + /// This is the name of the entry in the ZipFile itself. When creating + /// a zip archive, if the ZipEntry has been created from a filesystem + /// file, via a call to or , or a related overload, the value + /// of this property is derived from the name of that file. The + /// FileName property does not include drive letters, and may include a + /// different directory path, depending on the value of the + /// directoryPathInArchive parameter used when adding the entry into + /// the ZipFile. + /// + /// + /// + /// In some cases there is no related filesystem file - for example when a + /// ZipEntry is created using or one of the similar overloads. In this case, the value of + /// this property is derived from the fileName and the directory path passed + /// to that method. + /// + /// + /// + /// When reading a zip file, this property takes the value of the entry name + /// as stored in the zip file. If you extract such an entry, the extracted + /// file will take the name given by this property. + /// + /// + /// + /// Applications can set this property when creating new zip archives or when + /// reading existing archives. When setting this property, the actual value + /// that is set will replace backslashes with forward slashes, in accordance + /// with the Zip + /// specification, for compatibility with Unix(tm) and ... get + /// this.... Amiga! + /// + /// + /// + /// If an application reads a ZipFile via or a related overload, and then explicitly + /// sets the FileName on an entry contained within the ZipFile, and + /// then calls , the application will effectively + /// rename the entry within the zip archive. + /// + /// + /// + /// If an application sets the value of FileName, then calls + /// Extract() on the entry, the entry is extracted to a file using the + /// newly set value as the filename. The FileName value is made + /// permanent in the zip archive only after a call to one of the + /// ZipFile.Save() methods on the ZipFile that contains the + /// ZipEntry. + /// + /// + /// + /// If an application attempts to set the FileName to a value that + /// would result in a duplicate entry in the ZipFile, an exception is + /// thrown. + /// + /// + /// + /// When a ZipEntry is contained within a ZipFile, applications + /// cannot rename the entry within the context of a foreach (For + /// Each in VB) loop, because of the way the ZipFile stores + /// entries. If you need to enumerate through all the entries and rename one + /// or more of them, use ZipFile.EntriesSorted as the + /// collection. See also, ZipFile.GetEnumerator(). + /// + /// + /// + public string FileName + { + get { return _FileNameInArchive; } + set + { + if (_container.ZipFile == null) + throw new ZipException("Cannot rename; this is not supported in ZipOutputStream/ZipInputStream."); + + // rename the entry! + if (String.IsNullOrEmpty(value)) throw new ZipException("The FileName must be non empty and non-null."); + + var filename = ZipEntry.NameInArchive(value, null); + // workitem 8180 + if (_FileNameInArchive == filename) return; // nothing to do + + // workitem 8047 - when renaming, must remove old and then add a new entry + this._container.ZipFile.RemoveEntry(this); + this._container.ZipFile.InternalAddEntry(filename, this); + + _FileNameInArchive = filename; + _container.ZipFile.NotifyEntryChanged(); + _metadataChanged = true; + } + } + + + /// + /// The stream that provides content for the ZipEntry. + /// + /// + /// + /// + /// + /// The application can use this property to set the input stream for an + /// entry on a just-in-time basis. Imagine a scenario where the application + /// creates a ZipFile comprised of content obtained from hundreds of + /// files, via calls to AddFile(). The DotNetZip library opens streams + /// on these files on a just-in-time basis, only when writing the entry out to + /// an external store within the scope of a ZipFile.Save() call. Only + /// one input stream is opened at a time, as each entry is being written out. + /// + /// + /// + /// Now imagine a different application that creates a ZipFile + /// with content obtained from hundreds of streams, added through . Normally the + /// application would supply an open stream to that call. But when large + /// numbers of streams are being added, this can mean many open streams at one + /// time, unnecessarily. + /// + /// + /// + /// To avoid this, call and specify delegates that open and close the stream at + /// the time of Save. + /// + /// + /// + /// + /// Setting the value of this property when the entry was not added from a + /// stream (for example, when the ZipEntry was added with or , or when the entry was added by + /// reading an existing zip archive) will throw an exception. + /// + /// + /// + /// + public Stream InputStream + { + get { return _sourceStream; } + + set + { + if (this._Source != ZipEntrySource.Stream) + throw new ZipException("You must not set the input stream for this entry."); + + _sourceWasJitProvided = true; + _sourceStream = value; + } + } + + + /// + /// A flag indicating whether the InputStream was provided Just-in-time. + /// + /// + /// + /// + /// + /// When creating a zip archive, an application can obtain content for one or + /// more of the ZipEntry instances from streams, using the method. At the time + /// of calling that method, the application can supply null as the value of + /// the stream parameter. By doing so, the application indicates to the + /// library that it will provide a stream for the entry on a just-in-time + /// basis, at the time one of the ZipFile.Save() methods is called and + /// the data for the various entries are being compressed and written out. + /// + /// + /// + /// In this case, the application can set the + /// property, typically within the SaveProgress event (event type: ) for that entry. + /// + /// + /// + /// The application will later want to call Close() and Dispose() on that + /// stream. In the SaveProgress event, when the event type is , the application can + /// do so. This flag indicates that the stream has been provided by the + /// application on a just-in-time basis and that it is the application's + /// responsibility to call Close/Dispose on that stream. + /// + /// + /// + /// + public bool InputStreamWasJitProvided + { + get { return _sourceWasJitProvided; } + } + + + + /// + /// An enum indicating the source of the ZipEntry. + /// + public ZipEntrySource Source + { + get { return _Source; } + } + + + /// + /// The version of the zip engine needed to read the ZipEntry. + /// + /// + /// + /// + /// This is a readonly property, indicating the version of the Zip + /// specification that the extracting tool or library must support to + /// extract the given entry. Generally higher versions indicate newer + /// features. Older zip engines obviously won't know about new features, and + /// won't be able to extract entries that depend on those newer features. + /// + /// + /// + /// + /// value + /// Features + /// + /// + /// + /// 20 + /// a basic Zip Entry, potentially using PKZIP encryption. + /// + /// + /// + /// + /// 45 + /// The ZIP64 extension is used on the entry. + /// + /// + /// + /// + /// 46 + /// File is compressed using BZIP2 compression* + /// + /// + /// + /// 50 + /// File is encrypted using PkWare's DES, 3DES, (broken) RC2 or RC4 + /// + /// + /// + /// 51 + /// File is encrypted using PKWare's AES encryption or corrected RC2 encryption. + /// + /// + /// + /// 52 + /// File is encrypted using corrected RC2-64 encryption** + /// + /// + /// + /// 61 + /// File is encrypted using non-OAEP key wrapping*** + /// + /// + /// + /// 63 + /// File is compressed using LZMA, PPMd+, Blowfish, or Twofish + /// + /// + /// + /// + /// + /// There are other values possible, not listed here. DotNetZip supports + /// regular PKZip encryption, and ZIP64 extensions. DotNetZip cannot extract + /// entries that require a zip engine higher than 45. + /// + /// + /// + /// This value is set upon reading an existing zip file, or after saving a zip + /// archive. + /// + /// + public Int16 VersionNeeded + { + get { return _VersionNeeded; } + } + + /// + /// The comment attached to the ZipEntry. + /// + /// + /// + /// + /// Each entry in a zip file can optionally have a comment associated to + /// it. The comment might be displayed by a zip tool during extraction, for + /// example. + /// + /// + /// + /// By default, the Comment is encoded in IBM437 code page. You can + /// specify an alternative with and + /// . + /// + /// + /// + /// + public string Comment + { + get { return _Comment; } + set + { + _Comment = value; + _metadataChanged = true; + } + } + + + /// + /// Indicates whether the entry requires ZIP64 extensions. + /// + /// + /// + /// + /// + /// This property is null (Nothing in VB) until a Save() method on the + /// containing instance has been called. The property is + /// non-null (HasValue is true) only after a Save() method has + /// been called. + /// + /// + /// + /// After the containing ZipFile has been saved, the Value of this + /// property is true if any of the following three conditions holds: the + /// uncompressed size of the entry is larger than 0xFFFFFFFF; the compressed + /// size of the entry is larger than 0xFFFFFFFF; the relative offset of the + /// entry within the zip archive is larger than 0xFFFFFFFF. These quantities + /// are not known until a Save() is attempted on the zip archive and + /// the compression is applied. + /// + /// + /// + /// If none of the three conditions holds, then the Value is false. + /// + /// + /// + /// A Value of false does not indicate that the entry, as saved in the + /// zip archive, does not use ZIP64. It merely indicates that ZIP64 is + /// not required. An entry may use ZIP64 even when not required if + /// the property on the containing + /// ZipFile instance is set to , or if + /// the property on the containing + /// ZipFile instance is set to + /// and the output stream was not seekable. + /// + /// + /// + /// + public Nullable RequiresZip64 + { + get + { + return _entryRequiresZip64; + } + } + + /// + /// Indicates whether the entry actually used ZIP64 extensions, as it was most + /// recently written to the output file or stream. + /// + /// + /// + /// + /// + /// This Nullable property is null (Nothing in VB) until a Save() + /// method on the containing instance has been + /// called. HasValue is true only after a Save() method has been + /// called. + /// + /// + /// + /// The value of this property for a particular ZipEntry may change + /// over successive calls to Save() methods on the containing ZipFile, + /// even if the file that corresponds to the ZipEntry does not. This + /// may happen if other entries contained in the ZipFile expand, + /// causing the offset for this particular entry to exceed 0xFFFFFFFF. + /// + /// + /// + public Nullable OutputUsedZip64 + { + get { return _OutputUsesZip64; } + } + + + /// + /// The bitfield for the entry as defined in the zip spec. You probably + /// never need to look at this. + /// + /// + /// + /// + /// You probably do not need to concern yourself with the contents of this + /// property, but in case you do: + /// + /// + /// + /// + /// bit + /// meaning + /// + /// + /// + /// 0 + /// set if encryption is used. + /// + /// + /// + /// 1-2 + /// + /// set to determine whether normal, max, fast deflation. DotNetZip library + /// always leaves these bits unset when writing (indicating "normal" + /// deflation"), but can read an entry with any value here. + /// + /// + /// + /// + /// 3 + /// + /// Indicates that the Crc32, Compressed and Uncompressed sizes are zero in the + /// local header. This bit gets set on an entry during writing a zip file, when + /// it is saved to a non-seekable output stream. + /// + /// + /// + /// + /// + /// 4 + /// reserved for "enhanced deflating". This library doesn't do enhanced deflating. + /// + /// + /// + /// 5 + /// set to indicate the zip is compressed patched data. This library doesn't do that. + /// + /// + /// + /// 6 + /// + /// set if PKWare's strong encryption is used (must also set bit 1 if bit 6 is + /// set). This bit is not set if WinZip's AES encryption is set. + /// + /// + /// + /// 7 + /// not used + /// + /// + /// + /// 8 + /// not used + /// + /// + /// + /// 9 + /// not used + /// + /// + /// + /// 10 + /// not used + /// + /// + /// + /// 11 + /// + /// Language encoding flag (EFS). If this bit is set, the filename and comment + /// fields for this file must be encoded using UTF-8. This library currently + /// does not support UTF-8. + /// + /// + /// + /// + /// 12 + /// Reserved by PKWARE for enhanced compression. + /// + /// + /// + /// 13 + /// + /// Used when encrypting the Central Directory to indicate selected data + /// values in the Local Header are masked to hide their actual values. See + /// the section in the Zip + /// specification describing the Strong Encryption Specification for + /// details. + /// + /// + /// + /// + /// 14 + /// Reserved by PKWARE. + /// + /// + /// + /// 15 + /// Reserved by PKWARE. + /// + /// + /// + /// + /// + public Int16 BitField + { + get { return _BitField; } + } + + /// + /// The compression method employed for this ZipEntry. + /// + /// + /// + /// + /// + /// The + /// Zip specification allows a variety of compression methods. This + /// library supports just two: 0x08 = Deflate. 0x00 = Store (no compression), + /// for reading or writing. + /// + /// + /// + /// When reading an entry from an existing zipfile, the value you retrieve + /// here indicates the compression method used on the entry by the original + /// creator of the zip. When writing a zipfile, you can specify either 0x08 + /// (Deflate) or 0x00 (None). If you try setting something else, you will get + /// an exception. + /// + /// + /// + /// You may wish to set CompressionMethod to CompressionMethod.None (0) + /// when zipping already-compressed data like a jpg, png, or mp3 file. + /// This can save time and cpu cycles. + /// + /// + /// + /// When setting this property on a ZipEntry that is read from an + /// existing zip file, calling ZipFile.Save() will cause the new + /// CompressionMethod to be used on the entry in the newly saved zip file. + /// + /// + /// + /// Setting this property may have the side effect of modifying the + /// CompressionLevel property. If you set the CompressionMethod to a + /// value other than None, and CompressionLevel is previously + /// set to None, then CompressionLevel will be set to + /// Default. + /// + /// + /// + /// + /// + /// + /// In this example, the first entry added to the zip archive uses the default + /// behavior - compression is used where it makes sense. The second entry, + /// the MP3 file, is added to the archive without being compressed. + /// + /// using (ZipFile zip = new ZipFile(ZipFileToCreate)) + /// { + /// ZipEntry e1= zip.AddFile(@"notes\Readme.txt"); + /// ZipEntry e2= zip.AddFile(@"music\StopThisTrain.mp3"); + /// e2.CompressionMethod = CompressionMethod.None; + /// zip.Save(); + /// } + /// + /// + /// + /// Using zip As New ZipFile(ZipFileToCreate) + /// zip.AddFile("notes\Readme.txt") + /// Dim e2 as ZipEntry = zip.AddFile("music\StopThisTrain.mp3") + /// e2.CompressionMethod = CompressionMethod.None + /// zip.Save + /// End Using + /// + /// + public CompressionMethod CompressionMethod + { + get { return (CompressionMethod)_CompressionMethod; } + set + { + if (value == (CompressionMethod)_CompressionMethod) return; // nothing to do. + + if (value != CompressionMethod.None && value != CompressionMethod.Deflate +#if BZIP + && value != CompressionMethod.BZip2 +#endif + ) + throw new InvalidOperationException("Unsupported compression method."); + + // If the source is a zip archive and there was encryption on the + // entry, changing the compression method is not supported. + // if (this._Source == ZipEntrySource.ZipFile && _sourceIsEncrypted) + // throw new InvalidOperationException("Cannot change compression method on encrypted entries read from archives."); + + _CompressionMethod = (Int16)value; + + if (_CompressionMethod == (Int16)Ionic.Zip.CompressionMethod.None) + _CompressionLevel = Ionic.Zlib.CompressionLevel.None; + else if (CompressionLevel == Ionic.Zlib.CompressionLevel.None) + _CompressionLevel = Ionic.Zlib.CompressionLevel.Default; + + if (_container.ZipFile != null) _container.ZipFile.NotifyEntryChanged(); + _restreamRequiredOnSave = true; + } + } + + + /// + /// Sets the compression level to be used for the entry when saving the zip + /// archive. This applies only for CompressionMethod = DEFLATE. + /// + /// + /// + /// + /// When using the DEFLATE compression method, Varying the compression + /// level used on entries can affect the size-vs-speed tradeoff when + /// compression and decompressing data streams or files. + /// + /// + /// + /// If you do not set this property, the default compression level is used, + /// which normally gives a good balance of compression efficiency and + /// compression speed. In some tests, using BestCompression can + /// double the time it takes to compress, while delivering just a small + /// increase in compression efficiency. This behavior will vary with the + /// type of data you compress. If you are in doubt, just leave this setting + /// alone, and accept the default. + /// + /// + /// + /// When setting this property on a ZipEntry that is read from an + /// existing zip file, calling ZipFile.Save() will cause the new + /// CompressionLevel to be used on the entry in the newly saved zip file. + /// + /// + /// + /// Setting this property may have the side effect of modifying the + /// CompressionMethod property. If you set the CompressionLevel + /// to a value other than None, CompressionMethod will be set + /// to Deflate, if it was previously None. + /// + /// + /// + /// Setting this property has no effect if the CompressionMethod is something + /// other than Deflate or None. + /// + /// + /// + /// + public Ionic.Zlib.CompressionLevel CompressionLevel + { + get + { + return _CompressionLevel; + } + set + { + if (_CompressionMethod != (short)CompressionMethod.Deflate && + _CompressionMethod != (short)CompressionMethod.None) + return ; // no effect + + if (value == Ionic.Zlib.CompressionLevel.Default && + _CompressionMethod == (short)CompressionMethod.Deflate) return; // nothing to do + _CompressionLevel = value; + + if (value == Ionic.Zlib.CompressionLevel.None && + _CompressionMethod == (short)CompressionMethod.None) + return; // nothing more to do + + if (_CompressionLevel == Ionic.Zlib.CompressionLevel.None) + _CompressionMethod = (short) Ionic.Zip.CompressionMethod.None; + else + _CompressionMethod = (short) Ionic.Zip.CompressionMethod.Deflate; + + if (_container.ZipFile != null) _container.ZipFile.NotifyEntryChanged(); + _restreamRequiredOnSave = true; + } + } + + + + /// + /// The compressed size of the file, in bytes, within the zip archive. + /// + /// + /// + /// When reading a ZipFile, this value is read in from the existing + /// zip file. When creating or updating a ZipFile, the compressed + /// size is computed during compression. Therefore the value on a + /// ZipEntry is valid after a call to Save() (or one of its + /// overloads) in that case. + /// + /// + /// + public Int64 CompressedSize + { + get { return _CompressedSize; } + } + + /// + /// The size of the file, in bytes, before compression, or after extraction. + /// + /// + /// + /// When reading a ZipFile, this value is read in from the existing + /// zip file. When creating or updating a ZipFile, the uncompressed + /// size is computed during compression. Therefore the value on a + /// ZipEntry is valid after a call to Save() (or one of its + /// overloads) in that case. + /// + /// + /// + public Int64 UncompressedSize + { + get { return _UncompressedSize; } + } + + /// + /// The ratio of compressed size to uncompressed size of the ZipEntry. + /// + /// + /// + /// + /// This is a ratio of the compressed size to the uncompressed size of the + /// entry, expressed as a double in the range of 0 to 100+. A value of 100 + /// indicates no compression at all. It could be higher than 100 when the + /// compression algorithm actually inflates the data, as may occur for small + /// files, or uncompressible data that is encrypted. + /// + /// + /// + /// You could format it for presentation to a user via a format string of + /// "{3,5:F0}%" to see it as a percentage. + /// + /// + /// + /// If the size of the original uncompressed file is 0, implying a + /// denominator of 0, the return value will be zero. + /// + /// + /// + /// This property is valid after reading in an existing zip file, or after + /// saving the ZipFile that contains the ZipEntry. You cannot know the + /// effect of a compression transform until you try it. + /// + /// + /// + public Double CompressionRatio + { + get + { + if (UncompressedSize == 0) return 0; + return 100 * (1.0 - (1.0 * CompressedSize) / (1.0 * UncompressedSize)); + } + } + + /// + /// The 32-bit CRC (Cyclic Redundancy Check) on the contents of the ZipEntry. + /// + /// + /// + /// + /// You probably don't need to concern yourself with this. It is used + /// internally by DotNetZip to verify files or streams upon extraction. + /// + /// The value is a 32-bit + /// CRC using 0xEDB88320 for the polynomial. This is the same CRC-32 used in + /// PNG, MPEG-2, and other protocols and formats. It is a read-only property; when + /// creating a Zip archive, the CRC for each entry is set only after a call to + /// Save() on the containing ZipFile. When reading an existing zip file, the value + /// of this property reflects the stored CRC for the entry. + /// + /// + public Int32 Crc + { + get { return _Crc32; } + } + + /// + /// True if the entry is a directory (not a file). + /// This is a readonly property on the entry. + /// + public bool IsDirectory + { + get { return _IsDirectory; } + } + + /// + /// A derived property that is true if the entry uses encryption. + /// + /// + /// + /// + /// This is a readonly property on the entry. When reading a zip file, + /// the value for the ZipEntry is determined by the data read + /// from the zip file. After saving a ZipFile, the value of this + /// property for each ZipEntry indicates whether encryption was + /// actually used (which will have been true if the was set and the property + /// was something other than . + /// + /// + public bool UsesEncryption + { + get { return (_Encryption_FromZipFile != EncryptionAlgorithm.None); } + } + + + /// + /// Set this to specify which encryption algorithm to use for the entry when + /// saving it to a zip archive. + /// + /// + /// + /// + /// + /// Set this property in order to encrypt the entry when the ZipFile is + /// saved. When setting this property, you must also set a on the entry. If you set a value other than on this property and do not set a + /// Password then the entry will not be encrypted. The ZipEntry + /// data is encrypted as the ZipFile is saved, when you call or one of its cousins on the containing + /// ZipFile instance. You do not need to specify the Encryption + /// when extracting entries from an archive. + /// + /// + /// + /// The Zip specification from PKWare defines a set of encryption algorithms, + /// and the data formats for the zip archive that support them, and PKWare + /// supports those algorithms in the tools it produces. Other vendors of tools + /// and libraries, such as WinZip or Xceed, typically support a + /// subset of the algorithms specified by PKWare. These tools can + /// sometimes support additional different encryption algorithms and data + /// formats, not specified by PKWare. The AES Encryption specified and + /// supported by WinZip is the most popular example. This library supports a + /// subset of the complete set of algorithms specified by PKWare and other + /// vendors. + /// + /// + /// + /// There is no common, ubiquitous multi-vendor standard for strong encryption + /// within zip files. There is broad support for so-called "traditional" Zip + /// encryption, sometimes called Zip 2.0 encryption, as specified + /// by PKWare, but this encryption is considered weak and + /// breakable. This library currently supports the Zip 2.0 "weak" encryption, + /// and also a stronger WinZip-compatible AES encryption, using either 128-bit + /// or 256-bit key strength. If you want DotNetZip to support an algorithm + /// that is not currently supported, call the author of this library and maybe + /// we can talk business. + /// + /// + /// + /// The class also has a property. In most cases you will use + /// that property when setting encryption. This property takes + /// precedence over any Encryption set on the ZipFile itself. + /// Typically, you would use the per-entry Encryption when most entries in the + /// zip archive use one encryption algorithm, and a few entries use a + /// different one. If all entries in the zip file use the same Encryption, + /// then it is simpler to just set this property on the ZipFile itself, when + /// creating a zip archive. + /// + /// + /// + /// Some comments on updating archives: If you read a ZipFile, you can + /// modify the Encryption on an encrypted entry: you can remove encryption + /// from an entry that was encrypted; you can encrypt an entry that was not + /// encrypted previously; or, you can change the encryption algorithm. The + /// changes in encryption are not made permanent until you call Save() on the + /// ZipFile. To effect changes in encryption, the entry content is + /// streamed through several transformations, depending on the modification + /// the application has requested. For example if the entry is not encrypted + /// and the application sets Encryption to PkzipWeak, then at + /// the time of Save(), the original entry is read and decompressed, + /// then re-compressed and encrypted. Conversely, if the original entry is + /// encrypted with PkzipWeak encryption, and the application sets the + /// Encryption property to WinZipAes128, then at the time of + /// Save(), the original entry is decrypted via PKZIP encryption and + /// decompressed, then re-compressed and re-encrypted with AES. This all + /// happens automatically within the library, but it can be time-consuming for + /// large entries. + /// + /// + /// + /// Additionally, when updating archives, it is not possible to change the + /// password when changing the encryption algorithm. To change both the + /// algorithm and the password, you need to Save() the zipfile twice. First + /// set the Encryption to None, then call Save(). Then set the + /// Encryption to the new value (not "None"), then call Save() + /// once again. + /// + /// + /// + /// The WinZip AES encryption algorithms are not supported on the .NET Compact + /// Framework. + /// + /// + /// + /// + /// + /// This example creates a zip archive that uses encryption, and then extracts + /// entries from the archive. When creating the zip archive, the ReadMe.txt + /// file is zipped without using a password or encryption. The other file + /// uses encryption. + /// + /// + /// // Create a zip archive with AES Encryption. + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddFile("ReadMe.txt") + /// ZipEntry e1= zip.AddFile("2008-Regional-Sales-Report.pdf"); + /// e1.Encryption= EncryptionAlgorithm.WinZipAes256; + /// e1.Password= "Top.Secret.No.Peeking!"; + /// zip.Save("EncryptedArchive.zip"); + /// } + /// + /// // Extract a zip archive that uses AES Encryption. + /// // You do not need to specify the algorithm during extraction. + /// using (ZipFile zip = ZipFile.Read("EncryptedArchive.zip")) + /// { + /// // Specify the password that is used during extraction, for + /// // all entries that require a password: + /// zip.Password= "Top.Secret.No.Peeking!"; + /// zip.ExtractAll("extractDirectory"); + /// } + /// + /// + /// + /// ' Create a zip that uses Encryption. + /// Using zip As New ZipFile() + /// zip.AddFile("ReadMe.txt") + /// Dim e1 as ZipEntry + /// e1= zip.AddFile("2008-Regional-Sales-Report.pdf") + /// e1.Encryption= EncryptionAlgorithm.WinZipAes256 + /// e1.Password= "Top.Secret.No.Peeking!" + /// zip.Save("EncryptedArchive.zip") + /// End Using + /// + /// ' Extract a zip archive that uses AES Encryption. + /// ' You do not need to specify the algorithm during extraction. + /// Using (zip as ZipFile = ZipFile.Read("EncryptedArchive.zip")) + /// ' Specify the password that is used during extraction, for + /// ' all entries that require a password: + /// zip.Password= "Top.Secret.No.Peeking!" + /// zip.ExtractAll("extractDirectory") + /// End Using + /// + /// + /// + /// + /// + /// Thrown in the setter if EncryptionAlgorithm.Unsupported is specified. + /// + /// + /// ZipEntry.Password + /// ZipFile.Encryption + public EncryptionAlgorithm Encryption + { + get + { + return _Encryption; + } + set + { + if (value == _Encryption) return; // no change + + if (value == EncryptionAlgorithm.Unsupported) + throw new InvalidOperationException("You may not set Encryption to that value."); + + // If the source is a zip archive and there was encryption + // on the entry, this will not work. + //if (this._Source == ZipEntrySource.ZipFile && _sourceIsEncrypted) + // throw new InvalidOperationException("You cannot change the encryption method on encrypted entries read from archives."); + + _Encryption = value; + _restreamRequiredOnSave = true; + if (_container.ZipFile!=null) + _container.ZipFile.NotifyEntryChanged(); + } + } + + + /// + /// The Password to be used when encrypting a ZipEntry upon + /// ZipFile.Save(), or when decrypting an entry upon Extract(). + /// + /// + /// + /// + /// This is a write-only property on the entry. Set this to request that the + /// entry be encrypted when writing the zip archive, or set it to specify the + /// password to be used when extracting an existing entry that is encrypted. + /// + /// + /// + /// The password set here is implicitly used to encrypt the entry during the + /// operation, or to decrypt during the or operation. If you set + /// the Password on a ZipEntry after calling Save(), there is no + /// effect. + /// + /// + /// + /// Consider setting the property when using a + /// password. Answering concerns that the standard password protection + /// supported by all zip tools is weak, WinZip has extended the ZIP + /// specification with a way to use AES Encryption to protect entries in the + /// Zip file. Unlike the "PKZIP 2.0" encryption specified in the PKZIP + /// specification, AES + /// Encryption uses a standard, strong, tested, encryption + /// algorithm. DotNetZip can create zip archives that use WinZip-compatible + /// AES encryption, if you set the property. But, + /// archives created that use AES encryption may not be readable by all other + /// tools and libraries. For example, Windows Explorer cannot read a + /// "compressed folder" (a zip file) that uses AES encryption, though it can + /// read a zip file that uses "PKZIP encryption." + /// + /// + /// + /// The class also has a + /// property. This property takes precedence over any password set on the + /// ZipFile itself. Typically, you would use the per-entry Password when most + /// entries in the zip archive use one password, and a few entries use a + /// different password. If all entries in the zip file use the same password, + /// then it is simpler to just set this property on the ZipFile itself, + /// whether creating a zip archive or extracting a zip archive. + /// + /// + /// + /// Some comments on updating archives: If you read a ZipFile, you + /// cannot modify the password on any encrypted entry, except by extracting + /// the entry with the original password (if any), removing the original entry + /// via , and then adding a new + /// entry with a new Password. + /// + /// + /// + /// For example, suppose you read a ZipFile, and there is an encrypted + /// entry. Setting the Password property on that ZipEntry and then + /// calling Save() on the ZipFile does not update the password + /// on that entry in the archive. Neither is an exception thrown. Instead, + /// what happens during the Save() is the existing entry is copied + /// through to the new zip archive, in its original encrypted form. Upon + /// re-reading that archive, the entry can be decrypted with its original + /// password. + /// + /// + /// + /// If you read a ZipFile, and there is an un-encrypted entry, you can set the + /// Password on the entry and then call Save() on the ZipFile, and get + /// encryption on that entry. + /// + /// + /// + /// + /// + /// + /// This example creates a zip file with two entries, and then extracts the + /// entries from the zip file. When creating the zip file, the two files are + /// added to the zip file using password protection. Each entry uses a + /// different password. During extraction, each file is extracted with the + /// appropriate password. + /// + /// + /// // create a file with encryption + /// using (ZipFile zip = new ZipFile()) + /// { + /// ZipEntry entry; + /// entry= zip.AddFile("Declaration.txt"); + /// entry.Password= "123456!"; + /// entry = zip.AddFile("Report.xls"); + /// entry.Password= "1Secret!"; + /// zip.Save("EncryptedArchive.zip"); + /// } + /// + /// // extract entries that use encryption + /// using (ZipFile zip = ZipFile.Read("EncryptedArchive.zip")) + /// { + /// ZipEntry entry; + /// entry = zip["Declaration.txt"]; + /// entry.Password = "123456!"; + /// entry.Extract("extractDir"); + /// entry = zip["Report.xls"]; + /// entry.Password = "1Secret!"; + /// entry.Extract("extractDir"); + /// } + /// + /// + /// + /// + /// Using zip As New ZipFile + /// Dim entry as ZipEntry + /// entry= zip.AddFile("Declaration.txt") + /// entry.Password= "123456!" + /// entry = zip.AddFile("Report.xls") + /// entry.Password= "1Secret!" + /// zip.Save("EncryptedArchive.zip") + /// End Using + /// + /// + /// ' extract entries that use encryption + /// Using (zip as ZipFile = ZipFile.Read("EncryptedArchive.zip")) + /// Dim entry as ZipEntry + /// entry = zip("Declaration.txt") + /// entry.Password = "123456!" + /// entry.Extract("extractDir") + /// entry = zip("Report.xls") + /// entry.Password = "1Secret!" + /// entry.Extract("extractDir") + /// End Using + /// + /// + /// + /// + /// + /// + /// ZipFile.Password + public string Password + { + set + { + _Password = value; + if (_Password == null) + { + _Encryption = EncryptionAlgorithm.None; + } + else + { + // We're setting a non-null password. + + // For entries obtained from a zip file that are encrypted, we cannot + // simply restream (recompress, re-encrypt) the file data, because we + // need the old password in order to decrypt the data, and then we + // need the new password to encrypt. So, setting the password is + // never going to work on an entry that is stored encrypted in a zipfile. + + // But it is not en error to set the password, obviously: callers will + // set the password in order to Extract encrypted archives. + + // If the source is a zip archive and there was previously no encryption + // on the entry, then we must re-stream the entry in order to encrypt it. + if (this._Source == ZipEntrySource.ZipFile && !_sourceIsEncrypted) + _restreamRequiredOnSave = true; + + if (Encryption == EncryptionAlgorithm.None) + { + _Encryption = EncryptionAlgorithm.PkzipWeak; + } + } + } + private get { return _Password; } + } + + + + internal bool IsChanged + { + get + { + return _restreamRequiredOnSave | _metadataChanged; + } + } + + + /// + /// The action the library should take when extracting a file that already exists. + /// + /// + /// + /// + /// This property affects the behavior of the Extract methods (one of the + /// Extract() or ExtractWithPassword() overloads), when + /// extraction would would overwrite an existing filesystem file. If you do + /// not set this property, the library throws an exception when extracting + /// an entry would overwrite an existing file. + /// + /// + /// + /// This property has no effect when extracting to a stream, or when the file to be + /// extracted does not already exist. + /// + /// + /// + /// + /// + /// + /// This example shows how to set the ExtractExistingFile property in + /// an ExtractProgress event, in response to user input. The + /// ExtractProgress event is invoked if and only if the + /// ExtractExistingFile property was previously set to + /// ExtractExistingFileAction.InvokeExtractProgressEvent. + /// + /// public static void ExtractProgress(object sender, ExtractProgressEventArgs e) + /// { + /// if (e.EventType == ZipProgressEventType.Extracting_BeforeExtractEntry) + /// Console.WriteLine("extract {0} ", e.CurrentEntry.FileName); + /// + /// else if (e.EventType == ZipProgressEventType.Extracting_ExtractEntryWouldOverwrite) + /// { + /// ZipEntry entry = e.CurrentEntry; + /// string response = null; + /// // Ask the user if he wants overwrite the file + /// do + /// { + /// Console.Write("Overwrite {0} in {1} ? (y/n/C) ", entry.FileName, e.ExtractLocation); + /// response = Console.ReadLine(); + /// Console.WriteLine(); + /// + /// } while (response != null && response[0]!='Y' && + /// response[0]!='N' && response[0]!='C'); + /// + /// if (response[0]=='C') + /// e.Cancel = true; + /// else if (response[0]=='Y') + /// entry.ExtractExistingFile = ExtractExistingFileAction.OverwriteSilently; + /// else + /// entry.ExtractExistingFile= ExtractExistingFileAction.DoNotOverwrite; + /// } + /// } + /// + /// + public ExtractExistingFileAction ExtractExistingFile + { + get; + set; + } + + + /// + /// The action to take when an error is encountered while + /// opening or reading files as they are saved into a zip archive. + /// + /// + /// + /// + /// Errors can occur within a call to ZipFile.Save, as the various files contained + /// in a ZipFile are being saved into the zip archive. During the + /// Save, DotNetZip will perform a File.Open on the file + /// associated to the ZipEntry, and then will read the entire contents of + /// the file as it is zipped. Either the open or the Read may fail, because + /// of lock conflicts or other reasons. Using this property, you can + /// specify the action to take when such errors occur. + /// + /// + /// + /// Typically you will NOT set this property on individual ZipEntry + /// instances. Instead, you will set the ZipFile.ZipErrorAction property on + /// the ZipFile instance, before adding any entries to the + /// ZipFile. If you do this, errors encountered on behalf of any of + /// the entries in the ZipFile will be handled the same way. + /// + /// + /// + /// But, if you use a handler, you will want + /// to set this property on the ZipEntry within the handler, to + /// communicate back to DotNetZip what you would like to do with the + /// particular error. + /// + /// + /// + /// + /// + public ZipErrorAction ZipErrorAction + { + get; + set; + } + + + /// + /// Indicates whether the entry was included in the most recent save. + /// + /// + /// An entry can be excluded or skipped from a save if there is an error + /// opening or reading the entry. + /// + /// + public bool IncludedInMostRecentSave + { + get + { + return !_skippedDuringSave; + } + } + + + /// + /// A callback that allows the application to specify the compression to use + /// for a given entry that is about to be added to the zip archive. + /// + /// + /// + /// + /// See + /// + /// + public SetCompressionCallback SetCompression + { + get; + set; + } + + + + /// + /// Set to indicate whether to use UTF-8 encoding for filenames and comments. + /// + /// + /// + /// + /// + /// If this flag is set, the comment and filename for the entry will be + /// encoded with UTF-8, as described in the Zip + /// specification, if necessary. "Necessary" means, the filename or + /// entry comment (if any) cannot be reflexively encoded and decoded using the + /// default code page, IBM437. + /// + /// + /// + /// Setting this flag to true is equivalent to setting to System.Text.Encoding.UTF8. + /// + /// + /// + /// This flag has no effect or relation to the text encoding used within the + /// file itself. + /// + /// + /// + [Obsolete("Beginning with v1.9.1.6 of DotNetZip, this property is obsolete. It will be removed in a future version of the library. Your applications should use AlternateEncoding and AlternateEncodingUsage instead.")] + public bool UseUnicodeAsNecessary + { + get + { + return (AlternateEncoding == System.Text.Encoding.GetEncoding("UTF-8")) && + (AlternateEncodingUsage == ZipOption.AsNecessary); + } + set + { + if (value) + { + AlternateEncoding = System.Text.Encoding.GetEncoding("UTF-8"); + AlternateEncodingUsage = ZipOption.AsNecessary; + + } + else + { + AlternateEncoding = Ionic.Zip.ZipFile.DefaultEncoding; + AlternateEncodingUsage = ZipOption.Never; + } + } + } + + /// + /// The text encoding to use for the FileName and Comment on this ZipEntry, + /// when the default encoding is insufficient. + /// + /// + /// + /// + /// + /// Don't use this property. See . + /// + /// + /// + [Obsolete("This property is obsolete since v1.9.1.6. Use AlternateEncoding and AlternateEncodingUsage instead.", true)] + public System.Text.Encoding ProvisionalAlternateEncoding + { + get; set; + } + + /// + /// Specifies the alternate text encoding used by this ZipEntry + /// + /// + /// + /// The default text encoding used in Zip files for encoding filenames and + /// comments is IBM437, which is something like a superset of ASCII. In + /// cases where this is insufficient, applications can specify an + /// alternate encoding. + /// + /// + /// When creating a zip file, the usage of the alternate encoding is + /// governed by the property. + /// Typically you would set both properties to tell DotNetZip to employ an + /// encoding that is not IBM437 in the zipfile you are creating. + /// + /// + /// Keep in mind that because the ZIP specification states that the only + /// valid encodings to use are IBM437 and UTF-8, if you use something + /// other than that, then zip tools and libraries may not be able to + /// successfully read the zip archive you generate. + /// + /// + /// The zip specification states that applications should presume that + /// IBM437 is in use, except when a special bit is set, which indicates + /// UTF-8. There is no way to specify an arbitrary code page, within the + /// zip file itself. When you create a zip file encoded with gb2312 or + /// ibm861 or anything other than IBM437 or UTF-8, then the application + /// that reads the zip file needs to "know" which code page to use. In + /// some cases, the code page used when reading is chosen implicitly. For + /// example, WinRar uses the ambient code page for the host desktop + /// operating system. The pitfall here is that if you create a zip in + /// Copenhagen and send it to Tokyo, the reader of the zipfile may not be + /// able to decode successfully. + /// + /// + /// + /// This example shows how to create a zipfile encoded with a + /// language-specific encoding: + /// + /// using (var zip = new ZipFile()) + /// { + /// zip.AlternateEnoding = System.Text.Encoding.GetEncoding("ibm861"); + /// zip.AlternateEnodingUsage = ZipOption.Always; + /// zip.AddFileS(arrayOfFiles); + /// zip.Save("Myarchive-Encoded-in-IBM861.zip"); + /// } + /// + /// + /// + public System.Text.Encoding AlternateEncoding + { + get; set; + } + + + /// + /// Describes if and when this instance should apply + /// AlternateEncoding to encode the FileName and Comment, when + /// saving. + /// + /// + public ZipOption AlternateEncodingUsage + { + get; set; + } + + + // /// + // /// The text encoding actually used for this ZipEntry. + // /// + // /// + // /// + // /// + // /// + // /// This read-only property describes the encoding used by the + // /// ZipEntry. If the entry has been read in from an existing ZipFile, + // /// then it may take the value UTF-8, if the entry is coded to specify UTF-8. + // /// If the entry does not specify UTF-8, the typical case, then the encoding + // /// used is whatever the application specified in the call to + // /// ZipFile.Read(). If the application has used one of the overloads of + // /// ZipFile.Read() that does not accept an encoding parameter, then the + // /// encoding used is IBM437, which is the default encoding described in the + // /// ZIP specification. + // /// + // /// + // /// If the entry is being created, then the value of ActualEncoding is taken + // /// according to the logic described in the documentation for . + // /// + // /// + // /// An application might be interested in retrieving this property to see if + // /// an entry read in from a file has used Unicode (UTF-8). + // /// + // /// + // /// + // /// + // public System.Text.Encoding ActualEncoding + // { + // get + // { + // return _actualEncoding; + // } + // } + + + + + internal static string NameInArchive(String filename, string directoryPathInArchive) + { + string result = null; + if (directoryPathInArchive == null) + result = filename; + + else + { + if (String.IsNullOrEmpty(directoryPathInArchive)) + { + result = Path.GetFileName(filename); + } + else + { + // explicitly specify a pathname for this file + result = Path.Combine(directoryPathInArchive, Path.GetFileName(filename)); + } + } + + //result = Path.GetFullPath(result); + result = SharedUtilities.NormalizePathForUseInZipFile(result); + + return result; + } + + // workitem 9073 + internal static ZipEntry CreateFromNothing(String nameInArchive) + { + return Create(nameInArchive, ZipEntrySource.None, null, null); + } + + internal static ZipEntry CreateFromFile(String filename, string nameInArchive) + { + return Create(nameInArchive, ZipEntrySource.FileSystem, filename, null); + } + + internal static ZipEntry CreateForStream(String entryName, Stream s) + { + return Create(entryName, ZipEntrySource.Stream, s, null); + } + + internal static ZipEntry CreateForWriter(String entryName, WriteDelegate d) + { + return Create(entryName, ZipEntrySource.WriteDelegate, d, null); + } + + internal static ZipEntry CreateForJitStreamProvider(string nameInArchive, OpenDelegate opener, CloseDelegate closer) + { + return Create(nameInArchive, ZipEntrySource.JitStream, opener, closer); + } + + internal static ZipEntry CreateForZipOutputStream(string nameInArchive) + { + return Create(nameInArchive, ZipEntrySource.ZipOutputStream, null, null); + } + + + private static ZipEntry Create(string nameInArchive, ZipEntrySource source, Object arg1, Object arg2) + { + if (String.IsNullOrEmpty(nameInArchive)) + throw new Ionic.Zip.ZipException("The entry name must be non-null and non-empty."); + + ZipEntry entry = new ZipEntry(); + + // workitem 7071 + // workitem 7926 - "version made by" OS should be zero for compat with WinZip + entry._VersionMadeBy = (0 << 8) + 45; // indicates the attributes are FAT Attributes, and v4.5 of the spec + entry._Source = source; + entry._Mtime = entry._Atime = entry._Ctime = DateTime.UtcNow; + + if (source == ZipEntrySource.Stream) + { + entry._sourceStream = (arg1 as Stream); // may or may not be null + } + else if (source == ZipEntrySource.WriteDelegate) + { + entry._WriteDelegate = (arg1 as WriteDelegate); // may or may not be null + } + else if (source == ZipEntrySource.JitStream) + { + entry._OpenDelegate = (arg1 as OpenDelegate); // may or may not be null + entry._CloseDelegate = (arg2 as CloseDelegate); // may or may not be null + } + else if (source == ZipEntrySource.ZipOutputStream) + { + } + // workitem 9073 + else if (source == ZipEntrySource.None) + { + // make this a valid value, for later. + entry._Source = ZipEntrySource.FileSystem; + } + else + { + String filename = (arg1 as String); // must not be null + + if (String.IsNullOrEmpty(filename)) + throw new Ionic.Zip.ZipException("The filename must be non-null and non-empty."); + + try + { + // The named file may or may not exist at this time. For + // example, when adding a directory by name. We test existence + // when necessary: when saving the ZipFile, or when getting the + // attributes, and so on. + +#if NETCF + // workitem 6878 + // Ionic.Zip.SharedUtilities.AdjustTime_Win32ToDotNet + entry._Mtime = File.GetLastWriteTime(filename).ToUniversalTime(); + entry._Ctime = File.GetCreationTime(filename).ToUniversalTime(); + entry._Atime = File.GetLastAccessTime(filename).ToUniversalTime(); + + // workitem 7071 + // can only get attributes of files that exist. + if (File.Exists(filename) || Directory.Exists(filename)) + entry._ExternalFileAttrs = (int)NetCfFile.GetAttributes(filename); + +#elif SILVERLIGHT + entry._Mtime = + entry._Ctime = + entry._Atime = System.DateTime.UtcNow; + entry._ExternalFileAttrs = (int)0; +#else + // workitem 6878?? + entry._Mtime = File.GetLastWriteTime(filename).ToUniversalTime(); + entry._Ctime = File.GetCreationTime(filename).ToUniversalTime(); + entry._Atime = File.GetLastAccessTime(filename).ToUniversalTime(); + + // workitem 7071 + // can only get attributes on files that exist. + if (File.Exists(filename) || Directory.Exists(filename)) + entry._ExternalFileAttrs = (int)File.GetAttributes(filename); + +#endif + entry._ntfsTimesAreSet = true; + + entry._LocalFileName = Path.GetFullPath(filename); // workitem 8813 + + } + catch (System.IO.PathTooLongException ptle) + { + // workitem 14035 + var msg = String.Format("The path is too long, filename={0}", + filename); + throw new ZipException(msg, ptle); + } + + } + + entry._LastModified = entry._Mtime; + entry._FileNameInArchive = SharedUtilities.NormalizePathForUseInZipFile(nameInArchive); + // We don't actually slurp in the file data until the caller invokes Write on this entry. + + return entry; + } + + + + + internal void MarkAsDirectory() + { + _IsDirectory = true; + // workitem 6279 + if (!_FileNameInArchive.EndsWith("/")) + _FileNameInArchive += "/"; + } + + + + /// + /// Indicates whether an entry is marked as a text file. Be careful when + /// using on this property. Unless you have a good reason, you should + /// probably ignore this property. + /// + /// + /// + /// + /// The ZIP format includes a provision for specifying whether an entry in + /// the zip archive is a text or binary file. This property exposes that + /// metadata item. Be careful when using this property: It's not clear + /// that this property as a firm meaning, across tools and libraries. + /// + /// + /// + /// To be clear, when reading a zip file, the property value may or may + /// not be set, and its value may or may not be valid. Not all entries + /// that you may think of as "text" entries will be so marked, and entries + /// marked as "text" are not guaranteed in any way to be text entries. + /// Whether the value is set and set correctly depends entirely on the + /// application that produced the zip file. + /// + /// + /// + /// There are many zip tools available, and when creating zip files, some + /// of them "respect" the IsText metadata field, and some of them do not. + /// Unfortunately, even when an application tries to do "the right thing", + /// it's not always clear what "the right thing" is. + /// + /// + /// + /// There's no firm definition of just what it means to be "a text file", + /// and the zip specification does not help in this regard. Twenty years + /// ago, text was ASCII, each byte was less than 127. IsText meant, all + /// bytes in the file were less than 127. These days, it is not the case + /// that all text files have all bytes less than 127. Any unicode file + /// may have bytes that are above 0x7f. The zip specification has nothing + /// to say on this topic. Therefore, it's not clear what IsText really + /// means. + /// + /// + /// + /// This property merely tells a reading application what is stored in the + /// metadata for an entry, without guaranteeing its validity or its + /// meaning. + /// + /// + /// + /// When DotNetZip is used to create a zipfile, it attempts to set this + /// field "correctly." For example, if a file ends in ".txt", this field + /// will be set. Your application may override that default setting. When + /// writing a zip file, you must set the property before calling + /// Save() on the ZipFile. + /// + /// + /// + /// When reading a zip file, a more general way to decide just what kind + /// of file is contained in a particular entry is to use the file type + /// database stored in the operating system. The operating system stores + /// a table that says, a file with .jpg extension is a JPG image file, a + /// file with a .xml extension is an XML document, a file with a .txt is a + /// pure ASCII text document, and so on. To get this information on + /// Windows, you + /// need to read and parse the registry. + /// + /// + /// + /// + /// using (var zip = new ZipFile()) + /// { + /// var e = zip.UpdateFile("Descriptions.mme", ""); + /// e.IsText = true; + /// zip.Save(zipPath); + /// } + /// + /// + /// + /// Using zip As New ZipFile + /// Dim e2 as ZipEntry = zip.AddFile("Descriptions.mme", "") + /// e.IsText= True + /// zip.Save(zipPath) + /// End Using + /// + /// + public bool IsText + { + // workitem 7801 + get { return _IsText; } + set { _IsText = value; } + } + + + + /// Provides a string representation of the instance. + /// a string representation of the instance. + public override String ToString() + { + return String.Format("ZipEntry::{0}", FileName); + } + + + internal Stream ArchiveStream + { + get + { + if (_archiveStream == null) + { + if (_container.ZipFile != null) + { + var zf = _container.ZipFile; + zf.Reset(false); + _archiveStream = zf.StreamForDiskNumber(_diskNumber); + } + else + { + _archiveStream = _container.ZipOutputStream.OutputStream; + } + } + return _archiveStream; + } + } + + + private void SetFdpLoh() + { + // The value for FileDataPosition has not yet been set. + // Therefore, seek to the local header, and figure the start of file data. + // workitem 8098: ok (restore) + long origPosition = this.ArchiveStream.Position; + try + { + this.ArchiveStream.Seek(this._RelativeOffsetOfLocalHeader, SeekOrigin.Begin); + + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + } + catch (System.IO.IOException exc1) + { + string description = String.Format("Exception seeking entry({0}) offset(0x{1:X8}) len(0x{2:X8})", + this.FileName, this._RelativeOffsetOfLocalHeader, + this.ArchiveStream.Length); + throw new BadStateException(description, exc1); + } + + byte[] block = new byte[30]; + this.ArchiveStream.Read(block, 0, block.Length); + + // At this point we could verify the contents read from the local header + // with the contents read from the central header. We could, but don't need to. + // So we won't. + + Int16 filenameLength = (short)(block[26] + block[27] * 256); + Int16 extraFieldLength = (short)(block[28] + block[29] * 256); + + // Console.WriteLine(" pos 0x{0:X8} ({0})", this.ArchiveStream.Position); + // Console.WriteLine(" seek 0x{0:X8} ({0})", filenameLength + extraFieldLength); + + this.ArchiveStream.Seek(filenameLength + extraFieldLength, SeekOrigin.Current); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + + this._LengthOfHeader = 30 + extraFieldLength + filenameLength + + GetLengthOfCryptoHeaderBytes(_Encryption_FromZipFile); + + // Console.WriteLine(" ROLH 0x{0:X8} ({0})", _RelativeOffsetOfLocalHeader); + // Console.WriteLine(" LOH 0x{0:X8} ({0})", _LengthOfHeader); + // workitem 8098: ok (arithmetic) + this.__FileDataPosition = _RelativeOffsetOfLocalHeader + _LengthOfHeader; + // Console.WriteLine(" FDP 0x{0:X8} ({0})", __FileDataPosition); + + // restore file position: + // workitem 8098: ok (restore) + this.ArchiveStream.Seek(origPosition, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(this.ArchiveStream); + } + + + +#if AESCRYPTO + private static int GetKeyStrengthInBits(EncryptionAlgorithm a) + { + if (a == EncryptionAlgorithm.WinZipAes256) return 256; + else if (a == EncryptionAlgorithm.WinZipAes128) return 128; + return -1; + } +#endif + + internal static int GetLengthOfCryptoHeaderBytes(EncryptionAlgorithm a) + { + //if ((_BitField & 0x01) != 0x01) return 0; + if (a == EncryptionAlgorithm.None) return 0; + +#if AESCRYPTO + if (a == EncryptionAlgorithm.WinZipAes128 || + a == EncryptionAlgorithm.WinZipAes256) + { + int KeyStrengthInBits = GetKeyStrengthInBits(a); + int sizeOfSaltAndPv = ((KeyStrengthInBits / 8 / 2) + 2); + return sizeOfSaltAndPv; + } +#endif + if (a == EncryptionAlgorithm.PkzipWeak) + return 12; + throw new ZipException("internal error"); + } + + + internal long FileDataPosition + { + get + { + if (__FileDataPosition == -1) + SetFdpLoh(); + + return __FileDataPosition; + } + } + + private int LengthOfHeader + { + get + { + if (_LengthOfHeader == 0) + SetFdpLoh(); + + return _LengthOfHeader; + } + } + + + + private ZipCrypto _zipCrypto_forExtract; + private ZipCrypto _zipCrypto_forWrite; +#if AESCRYPTO + private WinZipAesCrypto _aesCrypto_forExtract; + private WinZipAesCrypto _aesCrypto_forWrite; + private Int16 _WinZipAesMethod; +#endif + + internal DateTime _LastModified; + private DateTime _Mtime, _Atime, _Ctime; // workitem 6878: NTFS quantities + private bool _ntfsTimesAreSet; + private bool _emitNtfsTimes = true; + private bool _emitUnixTimes; // by default, false + private bool _TrimVolumeFromFullyQualifiedPaths = true; // by default, trim them. + internal string _LocalFileName; + private string _FileNameInArchive; + internal Int16 _VersionNeeded; + internal Int16 _BitField; + internal Int16 _CompressionMethod; + private Int16 _CompressionMethod_FromZipFile; + private Ionic.Zlib.CompressionLevel _CompressionLevel; + internal string _Comment; + private bool _IsDirectory; + private byte[] _CommentBytes; + internal Int64 _CompressedSize; + internal Int64 _CompressedFileDataSize; // CompressedSize less 12 bytes for the encryption header, if any + internal Int64 _UncompressedSize; + internal Int32 _TimeBlob; + private bool _crcCalculated; + internal Int32 _Crc32; + internal byte[] _Extra; + private bool _metadataChanged; + private bool _restreamRequiredOnSave; + private bool _sourceIsEncrypted; + private bool _skippedDuringSave; + private UInt32 _diskNumber; + + private static System.Text.Encoding ibm437 = System.Text.Encoding.GetEncoding("IBM437"); + //private System.Text.Encoding _provisionalAlternateEncoding = System.Text.Encoding.GetEncoding("IBM437"); + private System.Text.Encoding _actualEncoding; + + internal ZipContainer _container; + + private long __FileDataPosition = -1; + private byte[] _EntryHeader; + internal Int64 _RelativeOffsetOfLocalHeader; + private Int64 _future_ROLH; + private Int64 _TotalEntrySize; + private int _LengthOfHeader; + private int _LengthOfTrailer; + internal bool _InputUsesZip64; + private UInt32 _UnsupportedAlgorithmId; + + internal string _Password; + internal ZipEntrySource _Source; + internal EncryptionAlgorithm _Encryption; + internal EncryptionAlgorithm _Encryption_FromZipFile; + internal byte[] _WeakEncryptionHeader; + internal Stream _archiveStream; + private Stream _sourceStream; + private Nullable _sourceStreamOriginalPosition; + private bool _sourceWasJitProvided; + private bool _ioOperationCanceled; + private bool _presumeZip64; + private Nullable _entryRequiresZip64; + private Nullable _OutputUsesZip64; + private bool _IsText; // workitem 7801 + private ZipEntryTimestamp _timestamp; + + private static System.DateTime _unixEpoch = new System.DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc); + private static System.DateTime _win32Epoch = System.DateTime.FromFileTimeUtc(0L); + private static System.DateTime _zeroHour = new System.DateTime(1, 1, 1, 0, 0, 0, DateTimeKind.Utc); + + private WriteDelegate _WriteDelegate; + private OpenDelegate _OpenDelegate; + private CloseDelegate _CloseDelegate; + + + // summary + // The default size of the IO buffer for ZipEntry instances. Currently it is 8192 bytes. + // summary + //public const int IO_BUFFER_SIZE_DEFAULT = 8192; // 0x8000; // 0x4400 + + } + + + + /// + /// An enum that specifies the type of timestamp available on the ZipEntry. + /// + /// + /// + /// + /// + /// The last modified time of a file can be stored in multiple ways in + /// a zip file, and they are not mutually exclusive: + /// + /// + /// + /// + /// In the so-called "DOS" format, which has a 2-second precision. Values + /// are rounded to the nearest even second. For example, if the time on the + /// file is 12:34:43, then it will be stored as 12:34:44. This first value + /// is accessible via the LastModified property. This value is always + /// present in the metadata for each zip entry. In some cases the value is + /// invalid, or zero. + /// + /// + /// + /// In the so-called "Windows" or "NTFS" format, as an 8-byte integer + /// quantity expressed as the number of 1/10 milliseconds (in other words + /// the number of 100 nanosecond units) since January 1, 1601 (UTC). This + /// format is how Windows represents file times. This time is accessible + /// via the ModifiedTime property. + /// + /// + /// + /// In the "Unix" format, a 4-byte quantity specifying the number of seconds since + /// January 1, 1970 UTC. + /// + /// + /// + /// In an older format, now deprecated but still used by some current + /// tools. This format is also a 4-byte quantity specifying the number of + /// seconds since January 1, 1970 UTC. + /// + /// + /// + /// + /// + /// This bit field describes which of the formats were found in a ZipEntry that was read. + /// + /// + /// + [Flags] + public enum ZipEntryTimestamp + { + /// + /// Default value. + /// + None = 0, + + /// + /// A DOS timestamp with 2-second precision. + /// + DOS = 1, + + /// + /// A Windows timestamp with 100-ns precision. + /// + Windows = 2, + + /// + /// A Unix timestamp with 1-second precision. + /// + Unix = 4, + + /// + /// A Unix timestamp with 1-second precision, stored in InfoZip v1 format. This + /// format is outdated and is supported for reading archives only. + /// + InfoZip1 = 8, + } + + + + /// + /// The method of compression to use for a particular ZipEntry. + /// + /// + /// + /// PKWare's + /// ZIP Specification describes a number of distinct + /// cmopression methods that can be used within a zip + /// file. DotNetZip supports a subset of them. + /// + public enum CompressionMethod + { + /// + /// No compression at all. For COM environments, the value is 0 (zero). + /// + None = 0, + + /// + /// DEFLATE compression, as described in IETF RFC + /// 1951. This is the "normal" compression used in zip + /// files. For COM environments, the value is 8. + /// + Deflate = 8, + +#if BZIP + /// + /// BZip2 compression, a compression algorithm developed by Julian Seward. + /// For COM environments, the value is 12. + /// + BZip2 = 12, +#endif + } + + +#if NETCF + internal class NetCfFile + { + public static int SetTimes(string filename, DateTime ctime, DateTime atime, DateTime mtime) + { + IntPtr hFile = (IntPtr) CreateFileCE(filename, + (uint)0x40000000L, // (uint)FileAccess.Write, + (uint)0x00000002L, // (uint)FileShare.Write, + 0, + (uint) 3, // == open existing + (uint)0, // flagsAndAttributes + 0); + + if((int)hFile == -1) + { + // workitem 7944: don't throw on failure to set file times + // throw new ZipException("CreateFileCE Failed"); + return Interop.Marshal.GetLastWin32Error(); + } + + SetFileTime(hFile, + BitConverter.GetBytes(ctime.ToFileTime()), + BitConverter.GetBytes(atime.ToFileTime()), + BitConverter.GetBytes(mtime.ToFileTime())); + + CloseHandle(hFile); + return 0; + } + + + public static int SetLastWriteTime(string filename, DateTime mtime) + { + IntPtr hFile = (IntPtr) CreateFileCE(filename, + (uint)0x40000000L, // (uint)FileAccess.Write, + (uint)0x00000002L, // (uint)FileShare.Write, + 0, + (uint) 3, // == open existing + (uint)0, // flagsAndAttributes + 0); + + if((int)hFile == -1) + { + // workitem 7944: don't throw on failure to set file time + // throw new ZipException(String.Format("CreateFileCE Failed ({0})", + // Interop.Marshal.GetLastWin32Error())); + return Interop.Marshal.GetLastWin32Error(); + } + + SetFileTime(hFile, null, null, + BitConverter.GetBytes(mtime.ToFileTime())); + + CloseHandle(hFile); + return 0; + } + + + [Interop.DllImport("coredll.dll", EntryPoint="CreateFile", SetLastError=true)] + internal static extern int CreateFileCE(string lpFileName, + uint dwDesiredAccess, + uint dwShareMode, + int lpSecurityAttributes, + uint dwCreationDisposition, + uint dwFlagsAndAttributes, + int hTemplateFile); + + + [Interop.DllImport("coredll", EntryPoint="GetFileAttributes", SetLastError=true)] + internal static extern uint GetAttributes(string lpFileName); + + [Interop.DllImport("coredll", EntryPoint="SetFileAttributes", SetLastError=true)] + internal static extern bool SetAttributes(string lpFileName, uint dwFileAttributes); + + [Interop.DllImport("coredll", EntryPoint="SetFileTime", SetLastError=true)] + internal static extern bool SetFileTime(IntPtr hFile, byte[] lpCreationTime, byte[] lpLastAccessTime, byte[] lpLastWriteTime); + + [Interop.DllImport("coredll.dll", SetLastError=true)] + internal static extern bool CloseHandle(IntPtr hObject); + + } +#endif + + + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipEntrySource.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntrySource.cs new file mode 100644 index 00000000..51aa154a --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipEntrySource.cs @@ -0,0 +1,69 @@ +// ZipEntrySource.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-November-19 11:18:42> +// +// ------------------------------------------------------------------ +// + +namespace Ionic.Zip +{ + /// + /// An enum that specifies the source of the ZipEntry. + /// + public enum ZipEntrySource + { + /// + /// Default value. Invalid on a bonafide ZipEntry. + /// + None = 0, + + /// + /// The entry was instantiated by calling AddFile() or another method that + /// added an entry from the filesystem. + /// + FileSystem, + + /// + /// The entry was instantiated via or + /// . + /// + Stream, + + /// + /// The ZipEntry was instantiated by reading a zipfile. + /// + ZipFile, + + /// + /// The content for the ZipEntry will be or was provided by the WriteDelegate. + /// + WriteDelegate, + + /// + /// The content for the ZipEntry will be obtained from the stream dispensed by the OpenDelegate. + /// The entry was instantiated via . + /// + JitStream, + + /// + /// The content for the ZipEntry will be or was obtained from a ZipOutputStream. + /// + ZipOutputStream, + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipErrorAction.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipErrorAction.cs new file mode 100644 index 00000000..c8b862a9 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipErrorAction.cs @@ -0,0 +1,97 @@ +// ZipErrorAction.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-September-01 18:43:20> +// +// ------------------------------------------------------------------ +// +// This module defines the ZipErrorAction enum, which provides +// an action to take when errors occur when opening or reading +// files to be added to a zip file. +// +// ------------------------------------------------------------------ + + +namespace Ionic.Zip +{ + /// + /// An enum providing the options when an error occurs during opening or reading + /// of a file or directory that is being saved to a zip file. + /// + /// + /// + /// + /// This enum describes the actions that the library can take when an error occurs + /// opening or reading a file, as it is being saved into a Zip archive. + /// + /// + /// + /// In some cases an error will occur when DotNetZip tries to open a file to be + /// added to the zip archive. In other cases, an error might occur after the + /// file has been successfully opened, while DotNetZip is reading the file. + /// + /// + /// + /// The first problem might occur when calling AddDirectory() on a directory + /// that contains a Clipper .dbf file; the file is locked by Clipper and + /// cannot be opened by another process. An example of the second problem is + /// the ERROR_LOCK_VIOLATION that results when a file is opened by another + /// process, but not locked, and a range lock has been taken on the file. + /// Microsoft Outlook takes range locks on .PST files. + /// + /// + public enum ZipErrorAction + { + /// + /// Throw an exception when an error occurs while zipping. This is the default + /// behavior. (For COM clients, this is a 0 (zero).) + /// + Throw, + + /// + /// When an error occurs during zipping, for example a file cannot be opened, + /// skip the file causing the error, and continue zipping. (For COM clients, + /// this is a 1.) + /// + Skip, + + /// + /// When an error occurs during zipping, for example a file cannot be opened, + /// retry the operation that caused the error. Be careful with this option. If + /// the error is not temporary, the library will retry forever. (For COM + /// clients, this is a 2.) + /// + Retry, + + /// + /// When an error occurs, invoke the zipError event. The event type used is + /// . A typical use of this option: + /// a GUI application may wish to pop up a dialog to allow the user to view the + /// error that occurred, and choose an appropriate action. After your + /// processing in the error event, if you want to skip the file, set on the + /// ZipProgressEventArgs.CurrentEntry to Skip. If you want the + /// exception to be thrown, set ZipErrorAction on the CurrentEntry + /// to Throw. If you want to cancel the zip, set + /// ZipProgressEventArgs.Cancel to true. Cancelling differs from using + /// Skip in that a cancel will not save any further entries, if there are any. + /// (For COM clients, the value of this enum is a 3.) + /// + InvokeErrorEvent, + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.AddUpdate.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.AddUpdate.cs new file mode 100644 index 00000000..2de1680b --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.AddUpdate.cs @@ -0,0 +1,2163 @@ +// ZipFile.AddUpdate.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-01 16:42:07> +// +// ------------------------------------------------------------------ +// +// This module defines the methods for Adding and Updating entries in +// the ZipFile. +// +// ------------------------------------------------------------------ +// + + +using System; +using System.IO; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + public partial class ZipFile + { + /// + /// Adds an item, either a file or a directory, to a zip file archive. + /// + /// + /// + /// + /// This method is handy if you are adding things to zip archive and don't + /// want to bother distinguishing between directories or files. Any files are + /// added as single entries. A directory added through this method is added + /// recursively: all files and subdirectories contained within the directory + /// are added to the ZipFile. + /// + /// + /// + /// The name of the item may be a relative path or a fully-qualified + /// path. Remember, the items contained in ZipFile instance get written + /// to the disk only when you call or a similar + /// save method. + /// + /// + /// + /// The directory name used for the file within the archive is the same + /// as the directory name (potentially a relative path) specified in the + /// . + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// + /// + /// This method has two overloads. + /// + /// the name of the file or directory to add. + /// + /// The ZipEntry added. + public ZipEntry AddItem(string fileOrDirectoryName) + { + return AddItem(fileOrDirectoryName, null); + } + + + /// + /// Adds an item, either a file or a directory, to a zip file archive, + /// explicitly specifying the directory path to be used in the archive. + /// + /// + /// + /// + /// If adding a directory, the add is recursive on all files and + /// subdirectories contained within it. + /// + /// + /// The name of the item may be a relative path or a fully-qualified path. + /// The item added by this call to the ZipFile is not read from the + /// disk nor written to the zip file archive until the application calls + /// Save() on the ZipFile. + /// + /// + /// + /// This version of the method allows the caller to explicitly specify the + /// directory path to be used in the archive, which would override the + /// "natural" path of the filesystem file. + /// + /// + /// + /// Encryption will be used on the file data if the Password has + /// been set on the ZipFile object, prior to calling this method. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// Thrown if the file or directory passed in does not exist. + /// + /// + /// the name of the file or directory to add. + /// + /// + /// + /// The name of the directory path to use within the zip archive. This path + /// need not refer to an extant directory in the current filesystem. If the + /// files within the zip are later extracted, this is the path used for the + /// extracted file. Passing null (Nothing in VB) will use the + /// path on the fileOrDirectoryName. Passing the empty string ("") will + /// insert the item at the root path within the archive. + /// + /// + /// + /// + /// + /// + /// + /// This example shows how to zip up a set of files into a flat hierarchy, + /// regardless of where in the filesystem the files originated. The resulting + /// zip archive will contain a toplevel directory named "flat", which itself + /// will contain files Readme.txt, MyProposal.docx, and Image1.jpg. A + /// subdirectory under "flat" called SupportFiles will contain all the files + /// in the "c:\SupportFiles" directory on disk. + /// + /// + /// String[] itemnames= { + /// "c:\\fixedContent\\Readme.txt", + /// "MyProposal.docx", + /// "c:\\SupportFiles", // a directory + /// "images\\Image1.jpg" + /// }; + /// + /// try + /// { + /// using (ZipFile zip = new ZipFile()) + /// { + /// for (int i = 1; i < itemnames.Length; i++) + /// { + /// // will add Files or Dirs, recurses and flattens subdirectories + /// zip.AddItem(itemnames[i],"flat"); + /// } + /// zip.Save(ZipToCreate); + /// } + /// } + /// catch (System.Exception ex1) + /// { + /// System.Console.Error.WriteLine("exception: {0}", ex1); + /// } + /// + /// + /// + /// Dim itemnames As String() = _ + /// New String() { "c:\fixedContent\Readme.txt", _ + /// "MyProposal.docx", _ + /// "SupportFiles", _ + /// "images\Image1.jpg" } + /// Try + /// Using zip As New ZipFile + /// Dim i As Integer + /// For i = 1 To itemnames.Length - 1 + /// ' will add Files or Dirs, recursing and flattening subdirectories. + /// zip.AddItem(itemnames(i), "flat") + /// Next i + /// zip.Save(ZipToCreate) + /// End Using + /// Catch ex1 As Exception + /// Console.Error.WriteLine("exception: {0}", ex1.ToString()) + /// End Try + /// + /// + /// The ZipEntry added. + public ZipEntry AddItem(String fileOrDirectoryName, String directoryPathInArchive) + { + if (File.Exists(fileOrDirectoryName)) + return AddFile(fileOrDirectoryName, directoryPathInArchive); + + if (Directory.Exists(fileOrDirectoryName)) + return AddDirectory(fileOrDirectoryName, directoryPathInArchive); + + throw new FileNotFoundException(String.Format("That file or directory ({0}) does not exist!", + fileOrDirectoryName)); + } + + /// + /// Adds a File to a Zip file archive. + /// + /// + /// + /// + /// This call collects metadata for the named file in the filesystem, + /// including the file attributes and the timestamp, and inserts that metadata + /// into the resulting ZipEntry. Only when the application calls Save() on + /// the ZipFile, does DotNetZip read the file from the filesystem and + /// then write the content to the zip file archive. + /// + /// + /// + /// This method will throw an exception if an entry with the same name already + /// exists in the ZipFile. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// In this example, three files are added to a Zip archive. The ReadMe.txt + /// file will be placed in the root of the archive. The .png file will be + /// placed in a folder within the zip called photos\personal. The pdf file + /// will be included into a folder within the zip called Desktop. + /// + /// + /// try + /// { + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddFile("c:\\photos\\personal\\7440-N49th.png"); + /// zip.AddFile("c:\\Desktop\\2008-Regional-Sales-Report.pdf"); + /// zip.AddFile("ReadMe.txt"); + /// + /// zip.Save("Package.zip"); + /// } + /// } + /// catch (System.Exception ex1) + /// { + /// System.Console.Error.WriteLine("exception: " + ex1); + /// } + /// + /// + /// + /// Try + /// Using zip As ZipFile = New ZipFile + /// zip.AddFile("c:\photos\personal\7440-N49th.png") + /// zip.AddFile("c:\Desktop\2008-Regional-Sales-Report.pdf") + /// zip.AddFile("ReadMe.txt") + /// zip.Save("Package.zip") + /// End Using + /// Catch ex1 As Exception + /// Console.Error.WriteLine("exception: {0}", ex1.ToString) + /// End Try + /// + /// + /// + /// This method has two overloads. + /// + /// + /// + /// + /// + /// + /// The name of the file to add. It should refer to a file in the filesystem. + /// The name of the file may be a relative path or a fully-qualified path. + /// + /// The ZipEntry corresponding to the File added. + public ZipEntry AddFile(string fileName) + { + return AddFile(fileName, null); + } + + + + + + /// + /// Adds a File to a Zip file archive, potentially overriding the path to be + /// used within the zip archive. + /// + /// + /// + /// + /// The file added by this call to the ZipFile is not written to the + /// zip file archive until the application calls Save() on the ZipFile. + /// + /// + /// + /// This method will throw an exception if an entry with the same name already + /// exists in the ZipFile. + /// + /// + /// + /// This version of the method allows the caller to explicitly specify the + /// directory path to be used in the archive. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// In this example, three files are added to a Zip archive. The ReadMe.txt + /// file will be placed in the root of the archive. The .png file will be + /// placed in a folder within the zip called images. The pdf file will be + /// included into a folder within the zip called files\docs, and will be + /// encrypted with the given password. + /// + /// + /// try + /// { + /// using (ZipFile zip = new ZipFile()) + /// { + /// // the following entry will be inserted at the root in the archive. + /// zip.AddFile("c:\\datafiles\\ReadMe.txt", ""); + /// // this image file will be inserted into the "images" directory in the archive. + /// zip.AddFile("c:\\photos\\personal\\7440-N49th.png", "images"); + /// // the following will result in a password-protected file called + /// // files\\docs\\2008-Regional-Sales-Report.pdf in the archive. + /// zip.Password = "EncryptMe!"; + /// zip.AddFile("c:\\Desktop\\2008-Regional-Sales-Report.pdf", "files\\docs"); + /// zip.Save("Archive.zip"); + /// } + /// } + /// catch (System.Exception ex1) + /// { + /// System.Console.Error.WriteLine("exception: {0}", ex1); + /// } + /// + /// + /// + /// Try + /// Using zip As ZipFile = New ZipFile + /// ' the following entry will be inserted at the root in the archive. + /// zip.AddFile("c:\datafiles\ReadMe.txt", "") + /// ' this image file will be inserted into the "images" directory in the archive. + /// zip.AddFile("c:\photos\personal\7440-N49th.png", "images") + /// ' the following will result in a password-protected file called + /// ' files\\docs\\2008-Regional-Sales-Report.pdf in the archive. + /// zip.Password = "EncryptMe!" + /// zip.AddFile("c:\Desktop\2008-Regional-Sales-Report.pdf", "files\documents") + /// zip.Save("Archive.zip") + /// End Using + /// Catch ex1 As Exception + /// Console.Error.WriteLine("exception: {0}", ex1) + /// End Try + /// + /// + /// + /// + /// + /// + /// + /// + /// The name of the file to add. The name of the file may be a relative path + /// or a fully-qualified path. + /// + /// + /// + /// Specifies a directory path to use to override any path in the fileName. + /// This path may, or may not, correspond to a real directory in the current + /// filesystem. If the files within the zip are later extracted, this is the + /// path used for the extracted file. Passing null (Nothing in + /// VB) will use the path on the fileName, if any. Passing the empty string + /// ("") will insert the item at the root path within the archive. + /// + /// + /// The ZipEntry corresponding to the file added. + public ZipEntry AddFile(string fileName, String directoryPathInArchive) + { + string nameInArchive = ZipEntry.NameInArchive(fileName, directoryPathInArchive); + ZipEntry ze = ZipEntry.CreateFromFile(fileName, nameInArchive); + if (Verbose) StatusMessageTextWriter.WriteLine("adding {0}...", fileName); + return _InternalAddEntry(ze); + } + + + /// + /// This method removes a collection of entries from the ZipFile. + /// + /// + /// + /// A collection of ZipEntry instances from this zip file to be removed. For + /// example, you can pass in an array of ZipEntry instances; or you can call + /// SelectEntries(), and then add or remove entries from that + /// ICollection<ZipEntry> (ICollection(Of ZipEntry) in VB), and pass + /// that ICollection to this method. + /// + /// + /// + /// + public void RemoveEntries(System.Collections.Generic.ICollection entriesToRemove) + { + if (entriesToRemove == null) + throw new ArgumentNullException("entriesToRemove"); + + foreach (ZipEntry e in entriesToRemove) + { + this.RemoveEntry(e); + } + } + + + /// + /// This method removes a collection of entries from the ZipFile, by name. + /// + /// + /// + /// A collection of strings that refer to names of entries to be removed + /// from the ZipFile. For example, you can pass in an array or a + /// List of Strings that provide the names of entries to be removed. + /// + /// + /// + /// + public void RemoveEntries(System.Collections.Generic.ICollection entriesToRemove) + { + if (entriesToRemove == null) + throw new ArgumentNullException("entriesToRemove"); + + foreach (String e in entriesToRemove) + { + this.RemoveEntry(e); + } + } + + + /// + /// This method adds a set of files to the ZipFile. + /// + /// + /// + /// + /// Use this method to add a set of files to the zip archive, in one call. + /// For example, a list of files received from + /// System.IO.Directory.GetFiles() can be added to a zip archive in one + /// call. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to each + /// ZipEntry added. + /// + /// + /// + /// + /// The collection of names of the files to add. Each string should refer to a + /// file in the filesystem. The name of the file may be a relative path or a + /// fully-qualified path. + /// + /// + /// + /// This example shows how to create a zip file, and add a few files into it. + /// + /// String ZipFileToCreate = "archive1.zip"; + /// String DirectoryToZip = "c:\\reports"; + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Store all files found in the top level directory, into the zip archive. + /// String[] filenames = System.IO.Directory.GetFiles(DirectoryToZip); + /// zip.AddFiles(filenames); + /// zip.Save(ZipFileToCreate); + /// } + /// + /// + /// + /// Dim ZipFileToCreate As String = "archive1.zip" + /// Dim DirectoryToZip As String = "c:\reports" + /// Using zip As ZipFile = New ZipFile + /// ' Store all files found in the top level directory, into the zip archive. + /// Dim filenames As String() = System.IO.Directory.GetFiles(DirectoryToZip) + /// zip.AddFiles(filenames) + /// zip.Save(ZipFileToCreate) + /// End Using + /// + /// + /// + /// + public void AddFiles(System.Collections.Generic.IEnumerable fileNames) + { + this.AddFiles(fileNames, null); + } + + + /// + /// Adds or updates a set of files in the ZipFile. + /// + /// + /// + /// + /// Any files that already exist in the archive are updated. Any files that + /// don't yet exist in the archive are added. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to each + /// ZipEntry added. + /// + /// + /// + /// + /// The collection of names of the files to update. Each string should refer to a file in + /// the filesystem. The name of the file may be a relative path or a fully-qualified path. + /// + /// + public void UpdateFiles(System.Collections.Generic.IEnumerable fileNames) + { + this.UpdateFiles(fileNames, null); + } + + + /// + /// Adds a set of files to the ZipFile, using the + /// specified directory path in the archive. + /// + /// + /// + /// + /// Any directory structure that may be present in the + /// filenames contained in the list is "flattened" in the + /// archive. Each file in the list is added to the archive in + /// the specified top-level directory. + /// + /// + /// + /// For ZipFile properties including , , , , , , and , their respective values at the + /// time of this call will be applied to each ZipEntry added. + /// + /// + /// + /// + /// The names of the files to add. Each string should refer to + /// a file in the filesystem. The name of the file may be a + /// relative path or a fully-qualified path. + /// + /// + /// + /// Specifies a directory path to use to override any path in the file name. + /// Th is path may, or may not, correspond to a real directory in the current + /// filesystem. If the files within the zip are later extracted, this is the + /// path used for the extracted file. Passing null (Nothing in + /// VB) will use the path on each of the fileNames, if any. Passing + /// the empty string ("") will insert the item at the root path within the + /// archive. + /// + /// + /// + public void AddFiles(System.Collections.Generic.IEnumerable fileNames, String directoryPathInArchive) + { + AddFiles(fileNames, false, directoryPathInArchive); + } + + + + /// + /// Adds a set of files to the ZipFile, using the specified directory + /// path in the archive, and preserving the full directory structure in the + /// filenames. + /// + /// + /// + /// + /// If preserveDirHierarchy is true, any directory structure present in the + /// filenames contained in the list is preserved in the archive. On the other + /// hand, if preserveDirHierarchy is false, any directory structure that may + /// be present in the filenames contained in the list is "flattened" in the + /// archive; Each file in the list is added to the archive in the specified + /// top-level directory. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to each + /// ZipEntry added. + /// + /// + /// + /// + /// + /// The names of the files to add. Each string should refer to a file in the + /// filesystem. The name of the file may be a relative path or a + /// fully-qualified path. + /// + /// + /// + /// Specifies a directory path to use to override any path in the file name. + /// This path may, or may not, correspond to a real directory in the current + /// filesystem. If the files within the zip are later extracted, this is the + /// path used for the extracted file. Passing null (Nothing in + /// VB) will use the path on each of the fileNames, if any. Passing + /// the empty string ("") will insert the item at the root path within the + /// archive. + /// + /// + /// + /// whether the entries in the zip archive will reflect the directory + /// hierarchy that is present in the various filenames. For example, if + /// includes two paths, \Animalia\Chordata\Mammalia\Info.txt and + /// \Plantae\Magnoliophyta\Dicotyledon\Info.txt, then calling this method with + /// = false will result in an + /// exception because of a duplicate entry name, while calling this method + /// with = true will result in the + /// full direcory paths being included in the entries added to the ZipFile. + /// + /// + public void AddFiles(System.Collections.Generic.IEnumerable fileNames, + bool preserveDirHierarchy, + String directoryPathInArchive) + { + if (fileNames == null) + throw new ArgumentNullException("fileNames"); + + _addOperationCanceled = false; + OnAddStarted(); + if (preserveDirHierarchy) + { + foreach (var f in fileNames) + { + if (_addOperationCanceled) break; + if (directoryPathInArchive != null) + { + //string s = SharedUtilities.NormalizePath(Path.Combine(directoryPathInArchive, Path.GetDirectoryName(f))); + string s = Path.GetFullPath(Path.Combine(directoryPathInArchive, Path.GetDirectoryName(f))); + this.AddFile(f, s); + } + else + this.AddFile(f, null); + } + } + else + { + foreach (var f in fileNames) + { + if (_addOperationCanceled) break; + this.AddFile(f, directoryPathInArchive); + } + } + if (!_addOperationCanceled) + OnAddCompleted(); + } + + + /// + /// Adds or updates a set of files to the ZipFile, using the specified + /// directory path in the archive. + /// + /// + /// + /// + /// + /// Any files that already exist in the archive are updated. Any files that + /// don't yet exist in the archive are added. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to each + /// ZipEntry added. + /// + /// + /// + /// + /// The names of the files to add or update. Each string should refer to a + /// file in the filesystem. The name of the file may be a relative path or a + /// fully-qualified path. + /// + /// + /// + /// Specifies a directory path to use to override any path in the file name. + /// This path may, or may not, correspond to a real directory in the current + /// filesystem. If the files within the zip are later extracted, this is the + /// path used for the extracted file. Passing null (Nothing in + /// VB) will use the path on each of the fileNames, if any. Passing + /// the empty string ("") will insert the item at the root path within the + /// archive. + /// + /// + /// + public void UpdateFiles(System.Collections.Generic.IEnumerable fileNames, String directoryPathInArchive) + { + if (fileNames == null) + throw new ArgumentNullException("fileNames"); + + OnAddStarted(); + foreach (var f in fileNames) + this.UpdateFile(f, directoryPathInArchive); + OnAddCompleted(); + } + + + + + /// + /// Adds or Updates a File in a Zip file archive. + /// + /// + /// + /// + /// This method adds a file to a zip archive, or, if the file already exists + /// in the zip archive, this method Updates the content of that given filename + /// in the zip archive. The UpdateFile method might more accurately be + /// called "AddOrUpdateFile". + /// + /// + /// + /// Upon success, there is no way for the application to learn whether the file + /// was added versus updated. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// This example shows how to Update an existing entry in a zipfile. The first + /// call to UpdateFile adds the file to the newly-created zip archive. The + /// second call to UpdateFile updates the content for that file in the zip + /// archive. + /// + /// + /// using (ZipFile zip1 = new ZipFile()) + /// { + /// // UpdateFile might more accurately be called "AddOrUpdateFile" + /// zip1.UpdateFile("MyDocuments\\Readme.txt"); + /// zip1.UpdateFile("CustomerList.csv"); + /// zip1.Comment = "This zip archive has been created."; + /// zip1.Save("Content.zip"); + /// } + /// + /// using (ZipFile zip2 = ZipFile.Read("Content.zip")) + /// { + /// zip2.UpdateFile("Updates\\Readme.txt"); + /// zip2.Comment = "This zip archive has been updated: The Readme.txt file has been changed."; + /// zip2.Save(); + /// } + /// + /// + /// + /// Using zip1 As New ZipFile + /// ' UpdateFile might more accurately be called "AddOrUpdateFile" + /// zip1.UpdateFile("MyDocuments\Readme.txt") + /// zip1.UpdateFile("CustomerList.csv") + /// zip1.Comment = "This zip archive has been created." + /// zip1.Save("Content.zip") + /// End Using + /// + /// Using zip2 As ZipFile = ZipFile.Read("Content.zip") + /// zip2.UpdateFile("Updates\Readme.txt") + /// zip2.Comment = "This zip archive has been updated: The Readme.txt file has been changed." + /// zip2.Save + /// End Using + /// + /// + /// + /// + /// + /// + /// + /// + /// The name of the file to add or update. It should refer to a file in the + /// filesystem. The name of the file may be a relative path or a + /// fully-qualified path. + /// + /// + /// + /// The ZipEntry corresponding to the File that was added or updated. + /// + public ZipEntry UpdateFile(string fileName) + { + return UpdateFile(fileName, null); + } + + + + /// + /// Adds or Updates a File in a Zip file archive. + /// + /// + /// + /// + /// This method adds a file to a zip archive, or, if the file already exists + /// in the zip archive, this method Updates the content of that given filename + /// in the zip archive. + /// + /// + /// + /// This version of the method allows the caller to explicitly specify the + /// directory path to be used in the archive. The entry to be added or + /// updated is found by using the specified directory path, combined with the + /// basename of the specified filename. + /// + /// + /// + /// Upon success, there is no way for the application to learn if the file was + /// added versus updated. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// + /// + /// The name of the file to add or update. It should refer to a file in the + /// filesystem. The name of the file may be a relative path or a + /// fully-qualified path. + /// + /// + /// + /// Specifies a directory path to use to override any path in the + /// fileName. This path may, or may not, correspond to a real + /// directory in the current filesystem. If the files within the zip are + /// later extracted, this is the path used for the extracted file. Passing + /// null (Nothing in VB) will use the path on the + /// fileName, if any. Passing the empty string ("") will insert the + /// item at the root path within the archive. + /// + /// + /// + /// The ZipEntry corresponding to the File that was added or updated. + /// + public ZipEntry UpdateFile(string fileName, String directoryPathInArchive) + { + // ideally this would all be transactional! + var key = ZipEntry.NameInArchive(fileName, directoryPathInArchive); + if (this[key] != null) + this.RemoveEntry(key); + return this.AddFile(fileName, directoryPathInArchive); + } + + + + + + /// + /// Add or update a directory in a zip archive. + /// + /// + /// + /// If the specified directory does not exist in the archive, then this method + /// is equivalent to calling AddDirectory(). If the specified + /// directory already exists in the archive, then this method updates any + /// existing entries, and adds any new entries. Any entries that are in the + /// zip archive but not in the specified directory, are left alone. In other + /// words, the contents of the zip file will be a union of the previous + /// contents and the new files. + /// + /// + /// + /// + /// + /// + /// + /// The path to the directory to be added to the zip archive, or updated in + /// the zip archive. + /// + /// + /// + /// The ZipEntry corresponding to the Directory that was added or updated. + /// + public ZipEntry UpdateDirectory(string directoryName) + { + return UpdateDirectory(directoryName, null); + } + + + /// + /// Add or update a directory in the zip archive at the specified root + /// directory in the archive. + /// + /// + /// + /// If the specified directory does not exist in the archive, then this method + /// is equivalent to calling AddDirectory(). If the specified + /// directory already exists in the archive, then this method updates any + /// existing entries, and adds any new entries. Any entries that are in the + /// zip archive but not in the specified directory, are left alone. In other + /// words, the contents of the zip file will be a union of the previous + /// contents and the new files. + /// + /// + /// + /// + /// + /// + /// + /// The path to the directory to be added to the zip archive, or updated + /// in the zip archive. + /// + /// + /// + /// Specifies a directory path to use to override any path in the + /// directoryName. This path may, or may not, correspond to a real + /// directory in the current filesystem. If the files within the zip are + /// later extracted, this is the path used for the extracted file. Passing + /// null (Nothing in VB) will use the path on the + /// directoryName, if any. Passing the empty string ("") will insert + /// the item at the root path within the archive. + /// + /// + /// + /// The ZipEntry corresponding to the Directory that was added or updated. + /// + public ZipEntry UpdateDirectory(string directoryName, String directoryPathInArchive) + { + return this.AddOrUpdateDirectoryImpl(directoryName, directoryPathInArchive, AddOrUpdateAction.AddOrUpdate); + } + + + + + + /// + /// Add or update a file or directory in the zip archive. + /// + /// + /// + /// + /// This is useful when the application is not sure or does not care if the + /// item to be added is a file or directory, and does not know or does not + /// care if the item already exists in the ZipFile. Calling this method + /// is equivalent to calling RemoveEntry() if an entry by the same name + /// already exists, followed calling by AddItem(). + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// + /// + /// the path to the file or directory to be added or updated. + /// + public void UpdateItem(string itemName) + { + UpdateItem(itemName, null); + } + + + /// + /// Add or update a file or directory. + /// + /// + /// + /// + /// This method is useful when the application is not sure or does not care if + /// the item to be added is a file or directory, and does not know or does not + /// care if the item already exists in the ZipFile. Calling this method + /// is equivalent to calling RemoveEntry(), if an entry by that name + /// exists, and then calling AddItem(). + /// + /// + /// + /// This version of the method allows the caller to explicitly specify the + /// directory path to be used for the item being added to the archive. The + /// entry or entries that are added or updated will use the specified + /// DirectoryPathInArchive. Extracting the entry from the archive will + /// result in a file stored in that directory path. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// + /// + /// The path for the File or Directory to be added or updated. + /// + /// + /// Specifies a directory path to use to override any path in the + /// itemName. This path may, or may not, correspond to a real + /// directory in the current filesystem. If the files within the zip are + /// later extracted, this is the path used for the extracted file. Passing + /// null (Nothing in VB) will use the path on the + /// itemName, if any. Passing the empty string ("") will insert the + /// item at the root path within the archive. + /// + public void UpdateItem(string itemName, string directoryPathInArchive) + { + if (File.Exists(itemName)) + UpdateFile(itemName, directoryPathInArchive); + + else if (Directory.Exists(itemName)) + UpdateDirectory(itemName, directoryPathInArchive); + + else + throw new FileNotFoundException(String.Format("That file or directory ({0}) does not exist!", itemName)); + } + + + + + /// + /// Adds a named entry into the zip archive, taking content for the entry + /// from a string. + /// + /// + /// + /// Calling this method creates an entry using the given fileName and + /// directory path within the archive. There is no need for a file by the + /// given name to exist in the filesystem; the name is used within the zip + /// archive only. The content for the entry is encoded using the default text + /// encoding for the machine, or on Silverlight, using UTF-8. + /// + /// + /// + /// The content of the file, should it be extracted from the zip. + /// + /// + /// + /// The name, including any path, to use for the entry within the archive. + /// + /// + /// The ZipEntry added. + /// + /// + /// + /// This example shows how to add an entry to the zipfile, using a string as + /// content for that entry. + /// + /// + /// string Content = "This string will be the content of the Readme.txt file in the zip archive."; + /// using (ZipFile zip1 = new ZipFile()) + /// { + /// zip1.AddFile("MyDocuments\\Resume.doc", "files"); + /// zip1.AddEntry("Readme.txt", Content); + /// zip1.Comment = "This zip file was created at " + System.DateTime.Now.ToString("G"); + /// zip1.Save("Content.zip"); + /// } + /// + /// + /// + /// Public Sub Run() + /// Dim Content As String = "This string will be the content of the Readme.txt file in the zip archive." + /// Using zip1 As ZipFile = New ZipFile + /// zip1.AddEntry("Readme.txt", Content) + /// zip1.AddFile("MyDocuments\Resume.doc", "files") + /// zip1.Comment = ("This zip file was created at " & DateTime.Now.ToString("G")) + /// zip1.Save("Content.zip") + /// End Using + /// End Sub + /// + /// + public ZipEntry AddEntry(string entryName, string content) + { +#if SILVERLIGHT + return AddEntry(entryName, content, System.Text.Encoding.UTF8); +#else + return AddEntry(entryName, content, System.Text.Encoding.Default); +#endif + } + + + + /// + /// Adds a named entry into the zip archive, taking content for the entry + /// from a string, and using the specified text encoding. + /// + /// + /// + /// + /// + /// Calling this method creates an entry using the given fileName and + /// directory path within the archive. There is no need for a file by the + /// given name to exist in the filesystem; the name is used within the zip + /// archive only. + /// + /// + /// + /// The content for the entry, a string value, is encoded using the given + /// text encoding. A BOM (byte-order-mark) is emitted into the file, if the + /// Encoding parameter is set for that. + /// + /// + /// + /// Most Encoding classes support a constructor that accepts a boolean, + /// indicating whether to emit a BOM or not. For example see . + /// + /// + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// + /// The content of the file, should it be extracted from the zip. + /// + /// + /// + /// The text encoding to use when encoding the string. Be aware: This is + /// distinct from the text encoding used to encode the fileName, as specified + /// in . + /// + /// + /// The ZipEntry added. + /// + public ZipEntry AddEntry(string entryName, string content, System.Text.Encoding encoding) + { + // cannot employ a using clause here. We need the stream to + // persist after exit from this method. + var ms = new MemoryStream(); + + // cannot use a using clause here; StreamWriter takes + // ownership of the stream and Disposes it before we are ready. + var sw = new StreamWriter(ms, encoding); + sw.Write(content); + sw.Flush(); + + // reset to allow reading later + ms.Seek(0, SeekOrigin.Begin); + + return AddEntry(entryName, ms); + + // must not dispose the MemoryStream - it will be used later. + } + + + /// + /// Create an entry in the ZipFile using the given Stream + /// as input. The entry will have the given filename. + /// + /// + /// + /// + /// + /// The application should provide an open, readable stream; in this case it + /// will be read during the call to or one of + /// its overloads. + /// + /// + /// + /// The passed stream will be read from its current position. If + /// necessary, callers should set the position in the stream before + /// calling AddEntry(). This might be appropriate when using this method + /// with a MemoryStream, for example. + /// + /// + /// + /// In cases where a large number of streams will be added to the + /// ZipFile, the application may wish to avoid maintaining all of the + /// streams open simultaneously. To handle this situation, the application + /// should use the + /// overload. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// This example adds a single entry to a ZipFile via a Stream. + /// + /// + /// + /// String zipToCreate = "Content.zip"; + /// String fileNameInArchive = "Content-From-Stream.bin"; + /// using (System.IO.Stream streamToRead = MyStreamOpener()) + /// { + /// using (ZipFile zip = new ZipFile()) + /// { + /// ZipEntry entry= zip.AddEntry(fileNameInArchive, streamToRead); + /// zip.AddFile("Readme.txt"); + /// zip.Save(zipToCreate); // the stream is read implicitly here + /// } + /// } + /// + /// + /// + /// Dim zipToCreate As String = "Content.zip" + /// Dim fileNameInArchive As String = "Content-From-Stream.bin" + /// Using streamToRead as System.IO.Stream = MyStreamOpener() + /// Using zip As ZipFile = New ZipFile() + /// Dim entry as ZipEntry = zip.AddEntry(fileNameInArchive, streamToRead) + /// zip.AddFile("Readme.txt") + /// zip.Save(zipToCreate) '' the stream is read implicitly, here + /// End Using + /// End Using + /// + /// + /// + /// + /// + /// + /// The name, including any path, which is shown in the zip file for the added + /// entry. + /// + /// + /// The input stream from which to grab content for the file + /// + /// The ZipEntry added. + public ZipEntry AddEntry(string entryName, Stream stream) + { + ZipEntry ze = ZipEntry.CreateForStream(entryName, stream); + ze.SetEntryTimes(DateTime.Now,DateTime.Now,DateTime.Now); + if (Verbose) StatusMessageTextWriter.WriteLine("adding {0}...", entryName); + return _InternalAddEntry(ze); + } + + + + /// + /// Add a ZipEntry for which content is written directly by the application. + /// + /// + /// + /// + /// When the application needs to write the zip entry data, use this + /// method to add the ZipEntry. For example, in the case that the + /// application wishes to write the XML representation of a DataSet into + /// a ZipEntry, the application can use this method to do so. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// About progress events: When using the WriteDelegate, DotNetZip does + /// not issue any SaveProgress events with EventType = + /// Saving_EntryBytesRead. (This is because it is the + /// application's code that runs in WriteDelegate - there's no way for + /// DotNetZip to know when to issue a EntryBytesRead event.) + /// Applications that want to update a progress bar or similar status + /// indicator should do so from within the WriteDelegate + /// itself. DotNetZip will issue the other SaveProgress events, + /// including + /// Saving_Started, + /// + /// Saving_BeforeWriteEntry, and + /// Saving_AfterWriteEntry. + /// + /// + /// + /// Note: When you use PKZip encryption, it's normally necessary to + /// compute the CRC of the content to be encrypted, before compressing or + /// encrypting it. Therefore, when using PKZip encryption with a + /// WriteDelegate, the WriteDelegate CAN BE called twice: once to compute + /// the CRC, and the second time to potentially compress and + /// encrypt. Surprising, but true. This is because PKWARE specified that + /// the encryption initialization data depends on the CRC. + /// If this happens, for each call of the delegate, your + /// application must stream the same entry data in its entirety. If your + /// application writes different data during the second call, it will + /// result in a corrupt zip file. + /// + /// + /// + /// The double-read behavior happens with all types of entries, not only + /// those that use WriteDelegate. It happens if you add an entry from a + /// filesystem file, or using a string, or a stream, or an opener/closer + /// pair. But in those cases, DotNetZip takes care of reading twice; in + /// the case of the WriteDelegate, the application code gets invoked + /// twice. Be aware. + /// + /// + /// + /// As you can imagine, this can cause performance problems for large + /// streams, and it can lead to correctness problems when you use a + /// WriteDelegate. This is a pretty big pitfall. There are two + /// ways to avoid it. First, and most preferred: don't use PKZIP + /// encryption. If you use the WinZip AES encryption, this problem + /// doesn't occur, because the encryption protocol doesn't require the CRC + /// up front. Second: if you do choose to use PKZIP encryption, write out + /// to a non-seekable stream (like standard output, or the + /// Response.OutputStream in an ASP.NET application). In this case, + /// DotNetZip will use an alternative encryption protocol that does not + /// rely on the CRC of the content. This also implies setting bit 3 in + /// the zip entry, which still presents problems for some zip tools. + /// + /// + /// + /// In the future I may modify DotNetZip to *always* use bit 3 when PKZIP + /// encryption is in use. This seems like a win overall, but there will + /// be some work involved. If you feel strongly about it, visit the + /// DotNetZip forums and vote up the Workitem + /// tracking this issue. + /// + /// + /// + /// + /// the name of the entry to add + /// the delegate which will write the entry content + /// the ZipEntry added + /// + /// + /// + /// This example shows an application filling a DataSet, then saving the + /// contents of that DataSet as XML, into a ZipEntry in a ZipFile, using an + /// anonymous delegate in C#. The DataSet XML is never saved to a disk file. + /// + /// + /// var c1= new System.Data.SqlClient.SqlConnection(connstring1); + /// var da = new System.Data.SqlClient.SqlDataAdapter() + /// { + /// SelectCommand= new System.Data.SqlClient.SqlCommand(strSelect, c1) + /// }; + /// + /// DataSet ds1 = new DataSet(); + /// da.Fill(ds1, "Invoices"); + /// + /// using(Ionic.Zip.ZipFile zip = new Ionic.Zip.ZipFile()) + /// { + /// zip.AddEntry(zipEntryName, (name,stream) => ds1.WriteXml(stream) ); + /// zip.Save(zipFileName); + /// } + /// + /// + /// + /// + /// + /// This example uses an anonymous method in C# as the WriteDelegate to provide + /// the data for the ZipEntry. The example is a bit contrived - the + /// AddFile() method is a simpler way to insert the contents of a file + /// into an entry in a zip file. On the other hand, if there is some sort of + /// processing or transformation of the file contents required before writing, + /// the application could use the WriteDelegate to do it, in this way. + /// + /// + /// using (var input = File.Open(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite )) + /// { + /// using(Ionic.Zip.ZipFile zip = new Ionic.Zip.ZipFile()) + /// { + /// zip.AddEntry(zipEntryName, (name,output) => + /// { + /// byte[] buffer = new byte[BufferSize]; + /// int n; + /// while ((n = input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// // could transform the data here... + /// output.Write(buffer, 0, n); + /// // could update a progress bar here + /// } + /// }); + /// + /// zip.Save(zipFileName); + /// } + /// } + /// + /// + /// + /// + /// + /// This example uses a named delegate in VB to write data for the given + /// ZipEntry (VB9 does not have anonymous delegates). The example here is a bit + /// contrived - a simpler way to add the contents of a file to a ZipEntry is to + /// simply use the appropriate AddFile() method. The key scenario for + /// which the WriteDelegate makes sense is saving a DataSet, in XML + /// format, to the zip file. The DataSet can write XML to a stream, and the + /// WriteDelegate is the perfect place to write into the zip file. There may be + /// other data structures that can write to a stream, but cannot be read as a + /// stream. The WriteDelegate would be appropriate for those cases as + /// well. + /// + /// + /// Private Sub WriteEntry (ByVal name As String, ByVal output As Stream) + /// Using input As FileStream = File.Open(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite) + /// Dim n As Integer = -1 + /// Dim buffer As Byte() = New Byte(BufferSize){} + /// Do While n <> 0 + /// n = input.Read(buffer, 0, buffer.Length) + /// output.Write(buffer, 0, n) + /// Loop + /// End Using + /// End Sub + /// + /// Public Sub Run() + /// Using zip = New ZipFile + /// zip.AddEntry(zipEntryName, New WriteDelegate(AddressOf WriteEntry)) + /// zip.Save(zipFileName) + /// End Using + /// End Sub + /// + /// + public ZipEntry AddEntry(string entryName, WriteDelegate writer) + { + ZipEntry ze = ZipEntry.CreateForWriter(entryName, writer); + if (Verbose) StatusMessageTextWriter.WriteLine("adding {0}...", entryName); + return _InternalAddEntry(ze); + } + + + /// + /// Add an entry, for which the application will provide a stream, + /// just-in-time. + /// + /// + /// + /// + /// In cases where the application wishes to open the stream that holds + /// the content for the ZipEntry, on a just-in-time basis, the application + /// can use this method and provide delegates to open and close the + /// stream. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// This example uses anonymous methods in C# to open and close the + /// source stream for the content for a zip entry. In a real + /// application, the logic for the OpenDelegate would probably be more + /// involved. + /// + /// + /// using(Ionic.Zip.ZipFile zip = new Ionic.Zip.ZipFile()) + /// { + /// zip.AddEntry(zipEntryName, + /// (name) => File.Open(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite ), + /// (name, stream) => stream.Close() + /// ); + /// + /// zip.Save(zipFileName); + /// } + /// + /// + /// + /// + /// + /// + /// This example uses delegates in VB.NET to open and close the + /// the source stream for the content for a zip entry. VB 9.0 lacks + /// support for "Sub" lambda expressions, and so the CloseDelegate must + /// be an actual, named Sub. + /// + /// + /// + /// Function MyStreamOpener(ByVal entryName As String) As Stream + /// '' This simply opens a file. You probably want to do somethinig + /// '' more involved here: open a stream to read from a database, + /// '' open a stream on an HTTP connection, and so on. + /// Return File.OpenRead(entryName) + /// End Function + /// + /// Sub MyStreamCloser(entryName As String, stream As Stream) + /// stream.Close() + /// End Sub + /// + /// Public Sub Run() + /// Dim dirToZip As String = "fodder" + /// Dim zipFileToCreate As String = "Archive.zip" + /// Dim opener As OpenDelegate = AddressOf MyStreamOpener + /// Dim closer As CloseDelegate = AddressOf MyStreamCloser + /// Dim numFilestoAdd As Int32 = 4 + /// Using zip As ZipFile = New ZipFile + /// Dim i As Integer + /// For i = 0 To numFilesToAdd - 1 + /// zip.AddEntry(String.Format("content-{0:000}.txt"), opener, closer) + /// Next i + /// zip.Save(zipFileToCreate) + /// End Using + /// End Sub + /// + /// + /// + /// + /// the name of the entry to add + /// + /// the delegate that will be invoked to open the stream + /// + /// + /// the delegate that will be invoked to close the stream + /// + /// the ZipEntry added + /// + public ZipEntry AddEntry(string entryName, OpenDelegate opener, CloseDelegate closer) + { + ZipEntry ze = ZipEntry.CreateForJitStreamProvider(entryName, opener, closer); + ze.SetEntryTimes(DateTime.Now,DateTime.Now,DateTime.Now); + if (Verbose) StatusMessageTextWriter.WriteLine("adding {0}...", entryName); + return _InternalAddEntry(ze); + } + + + + private ZipEntry _InternalAddEntry(ZipEntry ze) + { + // stamp all the props onto the entry + ze._container = new ZipContainer(this); + ze.CompressionMethod = this.CompressionMethod; + ze.CompressionLevel = this.CompressionLevel; + ze.ExtractExistingFile = this.ExtractExistingFile; + ze.ZipErrorAction = this.ZipErrorAction; + ze.SetCompression = this.SetCompression; + ze.AlternateEncoding = this.AlternateEncoding; + ze.AlternateEncodingUsage = this.AlternateEncodingUsage; + ze.Password = this._Password; + ze.Encryption = this.Encryption; + ze.EmitTimesInWindowsFormatWhenSaving = this._emitNtfsTimes; + ze.EmitTimesInUnixFormatWhenSaving = this._emitUnixTimes; + //string key = DictionaryKeyForEntry(ze); + InternalAddEntry(ze.FileName,ze); + AfterAddEntry(ze); + return ze; + } + + + + + /// + /// Updates the given entry in the ZipFile, using the given + /// string as content for the ZipEntry. + /// + /// + /// + /// + /// + /// Calling this method is equivalent to removing the ZipEntry for + /// the given file name and directory path, if it exists, and then calling + /// . See the documentation for + /// that method for further explanation. The string content is encoded + /// using the default encoding for the machine, or on Silverlight, using + /// UTF-8. This encoding is distinct from the encoding used for the + /// filename itself. See . + /// + /// + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// + /// The content of the file, should it be extracted from the zip. + /// + /// + /// The ZipEntry added. + /// + public ZipEntry UpdateEntry(string entryName, string content) + { +#if SILVERLIGHT + return UpdateEntry(entryName, content, System.Text.Encoding.UTF8); +#else + return UpdateEntry(entryName, content, System.Text.Encoding.Default); +#endif + } + + + /// + /// Updates the given entry in the ZipFile, using the given string as + /// content for the ZipEntry. + /// + /// + /// + /// Calling this method is equivalent to removing the ZipEntry for the + /// given file name and directory path, if it exists, and then calling . See the + /// documentation for that method for further explanation. + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// + /// The content of the file, should it be extracted from the zip. + /// + /// + /// + /// The text encoding to use when encoding the string. Be aware: This is + /// distinct from the text encoding used to encode the filename. See . + /// + /// + /// The ZipEntry added. + /// + public ZipEntry UpdateEntry(string entryName, string content, System.Text.Encoding encoding) + { + RemoveEntryForUpdate(entryName); + return AddEntry(entryName, content, encoding); + } + + + + /// + /// Updates the given entry in the ZipFile, using the given delegate + /// as the source for content for the ZipEntry. + /// + /// + /// + /// Calling this method is equivalent to removing the ZipEntry for the + /// given file name and directory path, if it exists, and then calling . See the + /// documentation for that method for further explanation. + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// the delegate which will write the entry content. + /// + /// The ZipEntry added. + /// + public ZipEntry UpdateEntry(string entryName, WriteDelegate writer) + { + RemoveEntryForUpdate(entryName); + return AddEntry(entryName, writer); + } + + + + /// + /// Updates the given entry in the ZipFile, using the given delegates + /// to open and close the stream that provides the content for the ZipEntry. + /// + /// + /// + /// Calling this method is equivalent to removing the ZipEntry for the + /// given file name and directory path, if it exists, and then calling . See the + /// documentation for that method for further explanation. + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// + /// the delegate that will be invoked to open the stream + /// + /// + /// the delegate that will be invoked to close the stream + /// + /// + /// The ZipEntry added or updated. + /// + public ZipEntry UpdateEntry(string entryName, OpenDelegate opener, CloseDelegate closer) + { + RemoveEntryForUpdate(entryName); + return AddEntry(entryName, opener, closer); + } + + + /// + /// Updates the given entry in the ZipFile, using the given stream as + /// input, and the given filename and given directory Path. + /// + /// + /// + /// + /// Calling the method is equivalent to calling RemoveEntry() if an + /// entry by the same name already exists, and then calling AddEntry() + /// with the given fileName and stream. + /// + /// + /// + /// The stream must be open and readable during the call to + /// ZipFile.Save. You can dispense the stream on a just-in-time basis + /// using the property. Check the + /// documentation of that property for more information. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to the + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// The input stream from which to read file data. + /// The ZipEntry added. + public ZipEntry UpdateEntry(string entryName, Stream stream) + { + RemoveEntryForUpdate(entryName); + return AddEntry(entryName, stream); + } + + + private void RemoveEntryForUpdate(string entryName) + { + if (String.IsNullOrEmpty(entryName)) + throw new ArgumentNullException("entryName"); + + string directoryPathInArchive = null; + if (entryName.IndexOf('\\') != -1) + { + directoryPathInArchive = Path.GetDirectoryName(entryName); + entryName = Path.GetFileName(entryName); + } + var key = ZipEntry.NameInArchive(entryName, directoryPathInArchive); + if (this[key] != null) + this.RemoveEntry(key); + } + + + + + /// + /// Add an entry into the zip archive using the given filename and + /// directory path within the archive, and the given content for the + /// file. No file is created in the filesystem. + /// + /// + /// The data to use for the entry. + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// The ZipEntry added. + public ZipEntry AddEntry(string entryName, byte[] byteContent) + { + if (byteContent == null) throw new ArgumentException("bad argument", "byteContent"); + var ms = new MemoryStream(byteContent); + return AddEntry(entryName, ms); + } + + + /// + /// Updates the given entry in the ZipFile, using the given byte + /// array as content for the entry. + /// + /// + /// + /// Calling this method is equivalent to removing the ZipEntry + /// for the given filename and directory path, if it exists, and then + /// calling . See the + /// documentation for that method for further explanation. + /// + /// + /// + /// The name, including any path, to use within the archive for the entry. + /// + /// + /// The content to use for the ZipEntry. + /// + /// The ZipEntry added. + /// + public ZipEntry UpdateEntry(string entryName, byte[] byteContent) + { + RemoveEntryForUpdate(entryName); + return AddEntry(entryName, byteContent); + } + + +// private string DictionaryKeyForEntry(ZipEntry ze1) +// { +// var filename = SharedUtilities.NormalizePathForUseInZipFile(ze1.FileName); +// return filename; +// } + + + /// + /// Adds the contents of a filesystem directory to a Zip file archive. + /// + /// + /// + /// + /// + /// The name of the directory may be a relative path or a fully-qualified + /// path. Any files within the named directory are added to the archive. Any + /// subdirectories within the named directory are also added to the archive, + /// recursively. + /// + /// + /// + /// Top-level entries in the named directory will appear as top-level entries + /// in the zip archive. Entries in subdirectories in the named directory will + /// result in entries in subdirectories in the zip archive. + /// + /// + /// + /// If you want the entries to appear in a containing directory in the zip + /// archive itself, then you should call the AddDirectory() overload that + /// allows you to explicitly specify a directory path for use in the archive. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to each + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// + /// + /// + /// This method has 2 overloads. + /// + /// The name of the directory to add. + /// The ZipEntry added. + public ZipEntry AddDirectory(string directoryName) + { + return AddDirectory(directoryName, null); + } + + + /// + /// Adds the contents of a filesystem directory to a Zip file archive, + /// overriding the path to be used for entries in the archive. + /// + /// + /// + /// + /// The name of the directory may be a relative path or a fully-qualified + /// path. The add operation is recursive, so that any files or subdirectories + /// within the name directory are also added to the archive. + /// + /// + /// + /// Top-level entries in the named directory will appear as top-level entries + /// in the zip archive. Entries in subdirectories in the named directory will + /// result in entries in subdirectories in the zip archive. + /// + /// + /// + /// For ZipFile properties including , , , , , + /// , and , their + /// respective values at the time of this call will be applied to each + /// ZipEntry added. + /// + /// + /// + /// + /// + /// + /// In this code, calling the ZipUp() method with a value of "c:\reports" for + /// the directory parameter will result in a zip file structure in which all + /// entries are contained in a toplevel "reports" directory. + /// + /// + /// + /// public void ZipUp(string targetZip, string directory) + /// { + /// using (var zip = new ZipFile()) + /// { + /// zip.AddDirectory(directory, System.IO.Path.GetFileName(directory)); + /// zip.Save(targetZip); + /// } + /// } + /// + /// + /// + /// + /// + /// + /// + /// The name of the directory to add. + /// + /// + /// Specifies a directory path to use to override any path in the + /// DirectoryName. This path may, or may not, correspond to a real directory + /// in the current filesystem. If the zip is later extracted, this is the + /// path used for the extracted file or directory. Passing null + /// (Nothing in VB) or the empty string ("") will insert the items at + /// the root path within the archive. + /// + /// + /// The ZipEntry added. + public ZipEntry AddDirectory(string directoryName, string directoryPathInArchive) + { + return AddOrUpdateDirectoryImpl(directoryName, directoryPathInArchive, AddOrUpdateAction.AddOnly); + } + + + /// + /// Creates a directory in the zip archive. + /// + /// + /// + /// + /// + /// Use this when you want to create a directory in the archive but there is + /// no corresponding filesystem representation for that directory. + /// + /// + /// + /// You will probably not need to do this in your code. One of the only times + /// you will want to do this is if you want an empty directory in the zip + /// archive. The reason: if you add a file to a zip archive that is stored + /// within a multi-level directory, all of the directory tree is implicitly + /// created in the zip archive. + /// + /// + /// + /// + /// + /// The name of the directory to create in the archive. + /// + /// The ZipEntry added. + public ZipEntry AddDirectoryByName(string directoryNameInArchive) + { + // workitem 9073 + ZipEntry dir = ZipEntry.CreateFromNothing(directoryNameInArchive); + dir._container = new ZipContainer(this); + dir.MarkAsDirectory(); + dir.AlternateEncoding = this.AlternateEncoding; // workitem 8984 + dir.AlternateEncodingUsage = this.AlternateEncodingUsage; + dir.SetEntryTimes(DateTime.Now,DateTime.Now,DateTime.Now); + dir.EmitTimesInWindowsFormatWhenSaving = _emitNtfsTimes; + dir.EmitTimesInUnixFormatWhenSaving = _emitUnixTimes; + dir._Source = ZipEntrySource.Stream; + //string key = DictionaryKeyForEntry(dir); + InternalAddEntry(dir.FileName,dir); + AfterAddEntry(dir); + return dir; + } + + + + private ZipEntry AddOrUpdateDirectoryImpl(string directoryName, + string rootDirectoryPathInArchive, + AddOrUpdateAction action) + { + if (rootDirectoryPathInArchive == null) + { + rootDirectoryPathInArchive = ""; + } + + return AddOrUpdateDirectoryImpl(directoryName, rootDirectoryPathInArchive, action, true, 0); + } + + + internal void InternalAddEntry(String name, ZipEntry entry) + { + _entries.Add(name, entry); + _zipEntriesAsList = null; + _contentsChanged = true; + } + + + + private ZipEntry AddOrUpdateDirectoryImpl(string directoryName, + string rootDirectoryPathInArchive, + AddOrUpdateAction action, + bool recurse, + int level) + { + if (Verbose) + StatusMessageTextWriter.WriteLine("{0} {1}...", + (action == AddOrUpdateAction.AddOnly) ? "adding" : "Adding or updating", + directoryName); + + if (level == 0) + { + _addOperationCanceled = false; + OnAddStarted(); + } + + // workitem 13371 + if (_addOperationCanceled) + return null; + + string dirForEntries = rootDirectoryPathInArchive; + ZipEntry baseDir = null; + + if (level > 0) + { + int f = directoryName.Length; + for (int i = level; i > 0; i--) + f = directoryName.LastIndexOfAny("/\\".ToCharArray(), f - 1, f - 1); + + dirForEntries = directoryName.Substring(f + 1); + dirForEntries = Path.Combine(rootDirectoryPathInArchive, dirForEntries); + } + + // if not top level, or if the root is non-empty, then explicitly add the directory + if (level > 0 || rootDirectoryPathInArchive != "") + { + baseDir = ZipEntry.CreateFromFile(directoryName, dirForEntries); + baseDir._container = new ZipContainer(this); + baseDir.AlternateEncoding = this.AlternateEncoding; // workitem 6410 + baseDir.AlternateEncodingUsage = this.AlternateEncodingUsage; + baseDir.MarkAsDirectory(); + baseDir.EmitTimesInWindowsFormatWhenSaving = _emitNtfsTimes; + baseDir.EmitTimesInUnixFormatWhenSaving = _emitUnixTimes; + + // add the directory only if it does not exist. + // It's not an error if it already exists. + if (!_entries.ContainsKey(baseDir.FileName)) + { + InternalAddEntry(baseDir.FileName,baseDir); + AfterAddEntry(baseDir); + } + dirForEntries = baseDir.FileName; + } + + if (!_addOperationCanceled) + { + + String[] filenames = Directory.GetFiles(directoryName); + + if (recurse) + { + // add the files: + foreach (String filename in filenames) + { + if (_addOperationCanceled) break; + if (action == AddOrUpdateAction.AddOnly) + AddFile(filename, dirForEntries); + else + UpdateFile(filename, dirForEntries); + } + + if (!_addOperationCanceled) + { + // add the subdirectories: + String[] dirnames = Directory.GetDirectories(directoryName); + foreach (String dir in dirnames) + { + // workitem 8617: Optionally traverse reparse points +#if SILVERLIGHT +#elif NETCF + FileAttributes fileAttrs = (FileAttributes) NetCfFile.GetAttributes(dir); +#else + FileAttributes fileAttrs = System.IO.File.GetAttributes(dir); +#endif + if (this.AddDirectoryWillTraverseReparsePoints +#if !SILVERLIGHT + || ((fileAttrs & FileAttributes.ReparsePoint) == 0) +#endif + ) + AddOrUpdateDirectoryImpl(dir, rootDirectoryPathInArchive, action, recurse, level + 1); + + } + + } + } + } + + if (level == 0) + OnAddCompleted(); + + return baseDir; + } + + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Check.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Check.cs new file mode 100644 index 00000000..6d5499e7 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Check.cs @@ -0,0 +1,352 @@ +// ZipFile.Check.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-31 14:40:50> +// +// ------------------------------------------------------------------ +// +// This module defines the methods for doing Checks on zip files. +// These are not necessary to include in the Reduced or CF +// version of the library. +// +// ------------------------------------------------------------------ +// + + +using System; +using System.IO; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + public partial class ZipFile + { + /// + /// Checks a zip file to see if its directory is consistent. + /// + /// + /// + /// + /// + /// In cases of data error, the directory within a zip file can get out + /// of synch with the entries in the zip file. This method checks the + /// given zip file and returns true if this has occurred. + /// + /// + /// This method may take a long time to run for large zip files. + /// + /// + /// This method is not supported in the Reduced or Compact Framework + /// versions of DotNetZip. + /// + /// + /// + /// Developers using COM can use the ComHelper.CheckZip(String) + /// method. + /// + /// + /// + /// + /// The filename to of the zip file to check. + /// + /// true if the named zip file checks OK. Otherwise, false. + /// + /// + /// + public static bool CheckZip(string zipFileName) + { + return CheckZip(zipFileName, false, null); + } + + + /// + /// Checks a zip file to see if its directory is consistent, + /// and optionally fixes the directory if necessary. + /// + /// + /// + /// + /// + /// In cases of data error, the directory within a zip file can get out of + /// synch with the entries in the zip file. This method checks the given + /// zip file, and returns true if this has occurred. It also optionally + /// fixes the zipfile, saving the fixed copy in Name_Fixed.zip. + /// + /// + /// + /// This method may take a long time to run for large zip files. It + /// will take even longer if the file actually needs to be fixed, and if + /// fixIfNecessary is true. + /// + /// + /// + /// This method is not supported in the Reduced or Compact + /// Framework versions of DotNetZip. + /// + /// + /// + /// + /// The filename to of the zip file to check. + /// + /// If true, the method will fix the zip file if + /// necessary. + /// + /// + /// a TextWriter in which messages generated while checking will be written. + /// + /// + /// true if the named zip is OK; false if the file needs to be fixed. + /// + /// + /// + public static bool CheckZip(string zipFileName, bool fixIfNecessary, + TextWriter writer) + + { + ZipFile zip1 = null, zip2 = null; + bool isOk = true; + try + { + zip1 = new ZipFile(); + zip1.FullScan = true; + zip1.Initialize(zipFileName); + + zip2 = ZipFile.Read(zipFileName); + + foreach (var e1 in zip1) + { + foreach (var e2 in zip2) + { + if (e1.FileName == e2.FileName) + { + if (e1._RelativeOffsetOfLocalHeader != e2._RelativeOffsetOfLocalHeader) + { + isOk = false; + if (writer != null) + writer.WriteLine("{0}: mismatch in RelativeOffsetOfLocalHeader (0x{1:X16} != 0x{2:X16})", + e1.FileName, e1._RelativeOffsetOfLocalHeader, + e2._RelativeOffsetOfLocalHeader); + } + if (e1._CompressedSize != e2._CompressedSize) + { + isOk = false; + if (writer != null) + writer.WriteLine("{0}: mismatch in CompressedSize (0x{1:X16} != 0x{2:X16})", + e1.FileName, e1._CompressedSize, + e2._CompressedSize); + } + if (e1._UncompressedSize != e2._UncompressedSize) + { + isOk = false; + if (writer != null) + writer.WriteLine("{0}: mismatch in UncompressedSize (0x{1:X16} != 0x{2:X16})", + e1.FileName, e1._UncompressedSize, + e2._UncompressedSize); + } + if (e1.CompressionMethod != e2.CompressionMethod) + { + isOk = false; + if (writer != null) + writer.WriteLine("{0}: mismatch in CompressionMethod (0x{1:X4} != 0x{2:X4})", + e1.FileName, e1.CompressionMethod, + e2.CompressionMethod); + } + if (e1.Crc != e2.Crc) + { + isOk = false; + if (writer != null) + writer.WriteLine("{0}: mismatch in Crc32 (0x{1:X4} != 0x{2:X4})", + e1.FileName, e1.Crc, + e2.Crc); + } + + // found a match, so stop the inside loop + break; + } + } + } + + zip2.Dispose(); + zip2 = null; + + if (!isOk && fixIfNecessary) + { + string newFileName = Path.GetFileNameWithoutExtension(zipFileName); + newFileName = System.String.Format("{0}_fixed.zip", newFileName); + zip1.Save(newFileName); + } + } + finally + { + if (zip1 != null) zip1.Dispose(); + if (zip2 != null) zip2.Dispose(); + } + return isOk; + } + + + + /// + /// Rewrite the directory within a zipfile. + /// + /// + /// + /// + /// + /// In cases of data error, the directory in a zip file can get out of + /// synch with the entries in the zip file. This method attempts to fix + /// the zip file if this has occurred. + /// + /// + /// This can take a long time for large zip files. + /// + /// This won't work if the zip file uses a non-standard + /// code page - neither IBM437 nor UTF-8. + /// + /// + /// This method is not supported in the Reduced or Compact Framework + /// versions of DotNetZip. + /// + /// + /// + /// Developers using COM can use the ComHelper.FixZipDirectory(String) + /// method. + /// + /// + /// + /// + /// The filename to of the zip file to fix. + /// + /// + /// + public static void FixZipDirectory(string zipFileName) + { + using (var zip = new ZipFile()) + { + zip.FullScan = true; + zip.Initialize(zipFileName); + zip.Save(zipFileName); + } + } + + + + /// + /// Verify the password on a zip file. + /// + /// + /// + /// + /// Keep in mind that passwords in zipfiles are applied to + /// zip entries, not to the entire zip file. So testing a + /// zipfile for a particular password doesn't work in the + /// general case. On the other hand, it's often the case + /// that a single password will be used on all entries in a + /// zip file. This method works for that case. + /// + /// + /// There is no way to check a password without doing the + /// decryption. So this code decrypts and extracts the given + /// zipfile into + /// + /// + /// + /// The filename to of the zip file to fix. + /// + /// The password to check. + /// + /// a bool indicating whether the password matches. + public static bool CheckZipPassword(string zipFileName, string password) + { + // workitem 13664 + bool success = false; + try + { + using (ZipFile zip1 = ZipFile.Read(zipFileName)) + { + foreach (var e in zip1) + { + if (!e.IsDirectory && e.UsesEncryption) + { + e.ExtractWithPassword(System.IO.Stream.Null, password); + } + } + } + success = true; + } + catch(Ionic.Zip.BadPasswordException) { } + return success; + } + + + /// + /// Provides a human-readable string with information about the ZipFile. + /// + /// + /// + /// + /// The information string contains 10 lines or so, about each ZipEntry, + /// describing whether encryption is in use, the compressed and uncompressed + /// length of the entry, the offset of the entry, and so on. As a result the + /// information string can be very long for zip files that contain many + /// entries. + /// + /// + /// This information is mostly useful for diagnostic purposes. + /// + /// + public string Info + { + get + { + var builder = new System.Text.StringBuilder(); + builder.Append(string.Format(" ZipFile: {0}\n", this.Name)); + if (!string.IsNullOrEmpty(this._Comment)) + { + builder.Append(string.Format(" Comment: {0}\n", this._Comment)); + } + if (this._versionMadeBy != 0) + { + builder.Append(string.Format(" version made by: 0x{0:X4}\n", this._versionMadeBy)); + } + if (this._versionNeededToExtract != 0) + { + builder.Append(string.Format("needed to extract: 0x{0:X4}\n", this._versionNeededToExtract)); + } + + builder.Append(string.Format(" uses ZIP64: {0}\n", this.InputUsesZip64)); + + builder.Append(string.Format(" disk with CD: {0}\n", this._diskNumberWithCd)); + if (this._OffsetOfCentralDirectory == 0xFFFFFFFF) + builder.Append(string.Format(" CD64 offset: 0x{0:X16}\n", this._OffsetOfCentralDirectory64)); + else + builder.Append(string.Format(" CD offset: 0x{0:X8}\n", this._OffsetOfCentralDirectory)); + builder.Append("\n"); + foreach (ZipEntry entry in this._entries.Values) + { + builder.Append(entry.Info); + } + return builder.ToString(); + } + } + + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Events.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Events.cs new file mode 100644 index 00000000..21784741 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Events.cs @@ -0,0 +1,1219 @@ +// ZipFile.Events.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2008, 2009, 2011 Dino Chiesa . +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-09 08:42:35> +// +// ------------------------------------------------------------------ +// +// This module defines the methods for issuing events from the ZipFile class. +// +// ------------------------------------------------------------------ +// + +using System; +using System.IO; + +namespace Ionic.Zip +{ + public partial class ZipFile + { + private string ArchiveNameForEvent + { + get + { + return (_name != null) ? _name : "(stream)"; + } + } + + #region Save + + /// + /// An event handler invoked when a Save() starts, before and after each + /// entry has been written to the archive, when a Save() completes, and + /// during other Save events. + /// + /// + /// + /// + /// Depending on the particular event, different properties on the parameter are set. The following + /// table summarizes the available EventTypes and the conditions under + /// which this event handler is invoked with a + /// SaveProgressEventArgs with the given EventType. + /// + /// + /// + /// + /// value of EntryType + /// Meaning and conditions + /// + /// + /// + /// ZipProgressEventType.Saving_Started + /// Fired when ZipFile.Save() begins. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_BeforeSaveEntry + /// + /// Fired within ZipFile.Save(), just before writing data for each + /// particular entry. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_AfterSaveEntry + /// + /// Fired within ZipFile.Save(), just after having finished writing data + /// for each particular entry. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_Completed + /// Fired when ZipFile.Save() has completed. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_AfterSaveTempArchive + /// + /// Fired after the temporary file has been created. This happens only + /// when saving to a disk file. This event will not be invoked when + /// saving to a stream. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_BeforeRenameTempArchive + /// + /// Fired just before renaming the temporary file to the permanent + /// location. This happens only when saving to a disk file. This event + /// will not be invoked when saving to a stream. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_AfterRenameTempArchive + /// + /// Fired just after renaming the temporary file to the permanent + /// location. This happens only when saving to a disk file. This event + /// will not be invoked when saving to a stream. + /// + /// + /// + /// + /// ZipProgressEventType.Saving_AfterCompileSelfExtractor + /// + /// Fired after a self-extracting archive has finished compiling. This + /// EventType is used only within SaveSelfExtractor(). + /// + /// + /// + /// + /// ZipProgressEventType.Saving_BytesRead + /// + /// Set during the save of a particular entry, to update progress of the + /// Save(). When this EventType is set, the BytesTransferred is the + /// number of bytes that have been read from the source stream. The + /// TotalBytesToTransfer is the number of bytes in the uncompressed + /// file. + /// + /// + /// + /// + /// + /// + /// + /// + /// This example uses an anonymous method to handle the + /// SaveProgress event, by updating a progress bar. + /// + /// + /// progressBar1.Value = 0; + /// progressBar1.Max = listbox1.Items.Count; + /// using (ZipFile zip = new ZipFile()) + /// { + /// // listbox1 contains a list of filenames + /// zip.AddFiles(listbox1.Items); + /// + /// // do the progress bar: + /// zip.SaveProgress += (sender, e) => { + /// if (e.EventType == ZipProgressEventType.Saving_BeforeWriteEntry) { + /// progressBar1.PerformStep(); + /// } + /// }; + /// + /// zip.Save(fs); + /// } + /// + /// + /// + /// + /// This example uses a named method as the + /// SaveProgress event handler, to update the user, in a + /// console-based application. + /// + /// + /// static bool justHadByteUpdate= false; + /// public static void SaveProgress(object sender, SaveProgressEventArgs e) + /// { + /// if (e.EventType == ZipProgressEventType.Saving_Started) + /// Console.WriteLine("Saving: {0}", e.ArchiveName); + /// + /// else if (e.EventType == ZipProgressEventType.Saving_Completed) + /// { + /// justHadByteUpdate= false; + /// Console.WriteLine(); + /// Console.WriteLine("Done: {0}", e.ArchiveName); + /// } + /// + /// else if (e.EventType == ZipProgressEventType.Saving_BeforeWriteEntry) + /// { + /// if (justHadByteUpdate) + /// Console.WriteLine(); + /// Console.WriteLine(" Writing: {0} ({1}/{2})", + /// e.CurrentEntry.FileName, e.EntriesSaved, e.EntriesTotal); + /// justHadByteUpdate= false; + /// } + /// + /// else if (e.EventType == ZipProgressEventType.Saving_EntryBytesRead) + /// { + /// if (justHadByteUpdate) + /// Console.SetCursorPosition(0, Console.CursorTop); + /// Console.Write(" {0}/{1} ({2:N0}%)", e.BytesTransferred, e.TotalBytesToTransfer, + /// e.BytesTransferred / (0.01 * e.TotalBytesToTransfer )); + /// justHadByteUpdate= true; + /// } + /// } + /// + /// public static ZipUp(string targetZip, string directory) + /// { + /// using (var zip = new ZipFile()) { + /// zip.SaveProgress += SaveProgress; + /// zip.AddDirectory(directory); + /// zip.Save(targetZip); + /// } + /// } + /// + /// + /// + /// + /// Public Sub ZipUp(ByVal targetZip As String, ByVal directory As String) + /// Using zip As ZipFile = New ZipFile + /// AddHandler zip.SaveProgress, AddressOf MySaveProgress + /// zip.AddDirectory(directory) + /// zip.Save(targetZip) + /// End Using + /// End Sub + /// + /// Private Shared justHadByteUpdate As Boolean = False + /// + /// Public Shared Sub MySaveProgress(ByVal sender As Object, ByVal e As SaveProgressEventArgs) + /// If (e.EventType Is ZipProgressEventType.Saving_Started) Then + /// Console.WriteLine("Saving: {0}", e.ArchiveName) + /// + /// ElseIf (e.EventType Is ZipProgressEventType.Saving_Completed) Then + /// justHadByteUpdate = False + /// Console.WriteLine + /// Console.WriteLine("Done: {0}", e.ArchiveName) + /// + /// ElseIf (e.EventType Is ZipProgressEventType.Saving_BeforeWriteEntry) Then + /// If justHadByteUpdate Then + /// Console.WriteLine + /// End If + /// Console.WriteLine(" Writing: {0} ({1}/{2})", e.CurrentEntry.FileName, e.EntriesSaved, e.EntriesTotal) + /// justHadByteUpdate = False + /// + /// ElseIf (e.EventType Is ZipProgressEventType.Saving_EntryBytesRead) Then + /// If justHadByteUpdate Then + /// Console.SetCursorPosition(0, Console.CursorTop) + /// End If + /// Console.Write(" {0}/{1} ({2:N0}%)", e.BytesTransferred, _ + /// e.TotalBytesToTransfer, _ + /// (CDbl(e.BytesTransferred) / (0.01 * e.TotalBytesToTransfer))) + /// justHadByteUpdate = True + /// End If + /// End Sub + /// + /// + /// + /// + /// + /// This is a more complete example of using the SaveProgress + /// events in a Windows Forms application, with a + /// Thread object. + /// + /// + /// delegate void SaveEntryProgress(SaveProgressEventArgs e); + /// delegate void ButtonClick(object sender, EventArgs e); + /// + /// public class WorkerOptions + /// { + /// public string ZipName; + /// public string Folder; + /// public string Encoding; + /// public string Comment; + /// public int ZipFlavor; + /// public Zip64Option Zip64; + /// } + /// + /// private int _progress2MaxFactor; + /// private bool _saveCanceled; + /// private long _totalBytesBeforeCompress; + /// private long _totalBytesAfterCompress; + /// private Thread _workerThread; + /// + /// + /// private void btnZipup_Click(object sender, EventArgs e) + /// { + /// KickoffZipup(); + /// } + /// + /// private void btnCancel_Click(object sender, EventArgs e) + /// { + /// if (this.lblStatus.InvokeRequired) + /// { + /// this.lblStatus.Invoke(new ButtonClick(this.btnCancel_Click), new object[] { sender, e }); + /// } + /// else + /// { + /// _saveCanceled = true; + /// lblStatus.Text = "Canceled..."; + /// ResetState(); + /// } + /// } + /// + /// private void KickoffZipup() + /// { + /// _folderName = tbDirName.Text; + /// + /// if (_folderName == null || _folderName == "") return; + /// if (this.tbZipName.Text == null || this.tbZipName.Text == "") return; + /// + /// // check for existence of the zip file: + /// if (System.IO.File.Exists(this.tbZipName.Text)) + /// { + /// var dlgResult = MessageBox.Show(String.Format("The file you have specified ({0}) already exists." + + /// " Do you want to overwrite this file?", this.tbZipName.Text), + /// "Confirmation is Required", MessageBoxButtons.YesNo, MessageBoxIcon.Question); + /// if (dlgResult != DialogResult.Yes) return; + /// System.IO.File.Delete(this.tbZipName.Text); + /// } + /// + /// _saveCanceled = false; + /// _nFilesCompleted = 0; + /// _totalBytesAfterCompress = 0; + /// _totalBytesBeforeCompress = 0; + /// this.btnOk.Enabled = false; + /// this.btnOk.Text = "Zipping..."; + /// this.btnCancel.Enabled = true; + /// lblStatus.Text = "Zipping..."; + /// + /// var options = new WorkerOptions + /// { + /// ZipName = this.tbZipName.Text, + /// Folder = _folderName, + /// Encoding = "ibm437" + /// }; + /// + /// if (this.comboBox1.SelectedIndex != 0) + /// { + /// options.Encoding = this.comboBox1.SelectedItem.ToString(); + /// } + /// + /// if (this.radioFlavorSfxCmd.Checked) + /// options.ZipFlavor = 2; + /// else if (this.radioFlavorSfxGui.Checked) + /// options.ZipFlavor = 1; + /// else options.ZipFlavor = 0; + /// + /// if (this.radioZip64AsNecessary.Checked) + /// options.Zip64 = Zip64Option.AsNecessary; + /// else if (this.radioZip64Always.Checked) + /// options.Zip64 = Zip64Option.Always; + /// else options.Zip64 = Zip64Option.Never; + /// + /// options.Comment = String.Format("Encoding:{0} || Flavor:{1} || ZIP64:{2}\r\nCreated at {3} || {4}\r\n", + /// options.Encoding, + /// FlavorToString(options.ZipFlavor), + /// options.Zip64.ToString(), + /// System.DateTime.Now.ToString("yyyy-MMM-dd HH:mm:ss"), + /// this.Text); + /// + /// if (this.tbComment.Text != TB_COMMENT_NOTE) + /// options.Comment += this.tbComment.Text; + /// + /// _workerThread = new Thread(this.DoSave); + /// _workerThread.Name = "Zip Saver thread"; + /// _workerThread.Start(options); + /// this.Cursor = Cursors.WaitCursor; + /// } + /// + /// + /// private void DoSave(Object p) + /// { + /// WorkerOptions options = p as WorkerOptions; + /// try + /// { + /// using (var zip1 = new ZipFile()) + /// { + /// zip1.ProvisionalAlternateEncoding = System.Text.Encoding.GetEncoding(options.Encoding); + /// zip1.Comment = options.Comment; + /// zip1.AddDirectory(options.Folder); + /// _entriesToZip = zip1.EntryFileNames.Count; + /// SetProgressBars(); + /// zip1.SaveProgress += this.zip1_SaveProgress; + /// + /// zip1.UseZip64WhenSaving = options.Zip64; + /// + /// if (options.ZipFlavor == 1) + /// zip1.SaveSelfExtractor(options.ZipName, SelfExtractorFlavor.WinFormsApplication); + /// else if (options.ZipFlavor == 2) + /// zip1.SaveSelfExtractor(options.ZipName, SelfExtractorFlavor.ConsoleApplication); + /// else + /// zip1.Save(options.ZipName); + /// } + /// } + /// catch (System.Exception exc1) + /// { + /// MessageBox.Show(String.Format("Exception while zipping: {0}", exc1.Message)); + /// btnCancel_Click(null, null); + /// } + /// } + /// + /// + /// + /// void zip1_SaveProgress(object sender, SaveProgressEventArgs e) + /// { + /// switch (e.EventType) + /// { + /// case ZipProgressEventType.Saving_AfterWriteEntry: + /// StepArchiveProgress(e); + /// break; + /// case ZipProgressEventType.Saving_EntryBytesRead: + /// StepEntryProgress(e); + /// break; + /// case ZipProgressEventType.Saving_Completed: + /// SaveCompleted(); + /// break; + /// case ZipProgressEventType.Saving_AfterSaveTempArchive: + /// // this event only occurs when saving an SFX file + /// TempArchiveSaved(); + /// break; + /// } + /// if (_saveCanceled) + /// e.Cancel = true; + /// } + /// + /// + /// + /// private void StepArchiveProgress(SaveProgressEventArgs e) + /// { + /// if (this.progressBar1.InvokeRequired) + /// { + /// this.progressBar1.Invoke(new SaveEntryProgress(this.StepArchiveProgress), new object[] { e }); + /// } + /// else + /// { + /// if (!_saveCanceled) + /// { + /// _nFilesCompleted++; + /// this.progressBar1.PerformStep(); + /// _totalBytesAfterCompress += e.CurrentEntry.CompressedSize; + /// _totalBytesBeforeCompress += e.CurrentEntry.UncompressedSize; + /// + /// // reset the progress bar for the entry: + /// this.progressBar2.Value = this.progressBar2.Maximum = 1; + /// + /// this.Update(); + /// } + /// } + /// } + /// + /// + /// private void StepEntryProgress(SaveProgressEventArgs e) + /// { + /// if (this.progressBar2.InvokeRequired) + /// { + /// this.progressBar2.Invoke(new SaveEntryProgress(this.StepEntryProgress), new object[] { e }); + /// } + /// else + /// { + /// if (!_saveCanceled) + /// { + /// if (this.progressBar2.Maximum == 1) + /// { + /// // reset + /// Int64 max = e.TotalBytesToTransfer; + /// _progress2MaxFactor = 0; + /// while (max > System.Int32.MaxValue) + /// { + /// max /= 2; + /// _progress2MaxFactor++; + /// } + /// this.progressBar2.Maximum = (int)max; + /// lblStatus.Text = String.Format("{0} of {1} files...({2})", + /// _nFilesCompleted + 1, _entriesToZip, e.CurrentEntry.FileName); + /// } + /// + /// int xferred = e.BytesTransferred >> _progress2MaxFactor; + /// + /// this.progressBar2.Value = (xferred >= this.progressBar2.Maximum) + /// ? this.progressBar2.Maximum + /// : xferred; + /// + /// this.Update(); + /// } + /// } + /// } + /// + /// private void SaveCompleted() + /// { + /// if (this.lblStatus.InvokeRequired) + /// { + /// this.lblStatus.Invoke(new MethodInvoker(this.SaveCompleted)); + /// } + /// else + /// { + /// lblStatus.Text = String.Format("Done, Compressed {0} files, {1:N0}% of original.", + /// _nFilesCompleted, (100.00 * _totalBytesAfterCompress) / _totalBytesBeforeCompress); + /// ResetState(); + /// } + /// } + /// + /// private void ResetState() + /// { + /// this.btnCancel.Enabled = false; + /// this.btnOk.Enabled = true; + /// this.btnOk.Text = "Zip it!"; + /// this.progressBar1.Value = 0; + /// this.progressBar2.Value = 0; + /// this.Cursor = Cursors.Default; + /// if (!_workerThread.IsAlive) + /// _workerThread.Join(); + /// } + /// + /// + /// + /// + /// + /// + /// + public event EventHandler SaveProgress; + + + internal bool OnSaveBlock(ZipEntry entry, Int64 bytesXferred, Int64 totalBytesToXfer) + { + EventHandler sp = SaveProgress; + if (sp != null) + { + var e = SaveProgressEventArgs.ByteUpdate(ArchiveNameForEvent, entry, + bytesXferred, totalBytesToXfer); + sp(this, e); + if (e.Cancel) + _saveOperationCanceled = true; + } + return _saveOperationCanceled; + } + + private void OnSaveEntry(int current, ZipEntry entry, bool before) + { + EventHandler sp = SaveProgress; + if (sp != null) + { + var e = new SaveProgressEventArgs(ArchiveNameForEvent, before, _entries.Count, current, entry); + sp(this, e); + if (e.Cancel) + _saveOperationCanceled = true; + } + } + + private void OnSaveEvent(ZipProgressEventType eventFlavor) + { + EventHandler sp = SaveProgress; + if (sp != null) + { + var e = new SaveProgressEventArgs(ArchiveNameForEvent, eventFlavor); + sp(this, e); + if (e.Cancel) + _saveOperationCanceled = true; + } + } + + private void OnSaveStarted() + { + EventHandler sp = SaveProgress; + if (sp != null) + { + var e = SaveProgressEventArgs.Started(ArchiveNameForEvent); + sp(this, e); + if (e.Cancel) + _saveOperationCanceled = true; + } + } + private void OnSaveCompleted() + { + EventHandler sp = SaveProgress; + if (sp != null) + { + var e = SaveProgressEventArgs.Completed(ArchiveNameForEvent); + sp(this, e); + } + } + #endregion + + + #region Read + /// + /// An event handler invoked before, during, and after the reading of a zip archive. + /// + /// + /// + /// + /// Depending on the particular event being signaled, different properties on the + /// parameter are set. The following table + /// summarizes the available EventTypes and the conditions under which this + /// event handler is invoked with a ReadProgressEventArgs with the given EventType. + /// + /// + /// + /// + /// value of EntryType + /// Meaning and conditions + /// + /// + /// + /// ZipProgressEventType.Reading_Started + /// Fired just as ZipFile.Read() begins. Meaningful properties: ArchiveName. + /// + /// + /// + /// + /// ZipProgressEventType.Reading_Completed + /// Fired when ZipFile.Read() has completed. Meaningful properties: ArchiveName. + /// + /// + /// + /// + /// ZipProgressEventType.Reading_ArchiveBytesRead + /// Fired while reading, updates the number of bytes read for the entire archive. + /// Meaningful properties: ArchiveName, CurrentEntry, BytesTransferred, TotalBytesToTransfer. + /// + /// + /// + /// + /// ZipProgressEventType.Reading_BeforeReadEntry + /// Indicates an entry is about to be read from the archive. + /// Meaningful properties: ArchiveName, EntriesTotal. + /// + /// + /// + /// + /// ZipProgressEventType.Reading_AfterReadEntry + /// Indicates an entry has just been read from the archive. + /// Meaningful properties: ArchiveName, EntriesTotal, CurrentEntry. + /// + /// + /// + /// + /// + /// + /// + /// + /// + public event EventHandler ReadProgress; + + private void OnReadStarted() + { + EventHandler rp = ReadProgress; + if (rp != null) + { + var e = ReadProgressEventArgs.Started(ArchiveNameForEvent); + rp(this, e); + } + } + + private void OnReadCompleted() + { + EventHandler rp = ReadProgress; + if (rp != null) + { + var e = ReadProgressEventArgs.Completed(ArchiveNameForEvent); + rp(this, e); + } + } + + internal void OnReadBytes(ZipEntry entry) + { + EventHandler rp = ReadProgress; + if (rp != null) + { + var e = ReadProgressEventArgs.ByteUpdate(ArchiveNameForEvent, + entry, + ReadStream.Position, + LengthOfReadStream); + rp(this, e); + } + } + + internal void OnReadEntry(bool before, ZipEntry entry) + { + EventHandler rp = ReadProgress; + if (rp != null) + { + ReadProgressEventArgs e = (before) + ? ReadProgressEventArgs.Before(ArchiveNameForEvent, _entries.Count) + : ReadProgressEventArgs.After(ArchiveNameForEvent, entry, _entries.Count); + rp(this, e); + } + } + + private Int64 _lengthOfReadStream = -99; + private Int64 LengthOfReadStream + { + get + { + if (_lengthOfReadStream == -99) + { + _lengthOfReadStream = (_ReadStreamIsOurs) + ? SharedUtilities.GetFileLength(_name) + : -1L; + } + return _lengthOfReadStream; + } + } + #endregion + + + #region Extract + /// + /// An event handler invoked before, during, and after extraction of + /// entries in the zip archive. + /// + /// + /// + /// + /// Depending on the particular event, different properties on the parameter are set. The following + /// table summarizes the available EventTypes and the conditions under + /// which this event handler is invoked with a + /// ExtractProgressEventArgs with the given EventType. + /// + /// + /// + /// + /// value of EntryType + /// Meaning and conditions + /// + /// + /// + /// ZipProgressEventType.Extracting_BeforeExtractAll + /// + /// Set when ExtractAll() begins. The ArchiveName, Overwrite, and + /// ExtractLocation properties are meaningful. + /// + /// + /// + /// ZipProgressEventType.Extracting_AfterExtractAll + /// + /// Set when ExtractAll() has completed. The ArchiveName, Overwrite, + /// and ExtractLocation properties are meaningful. + /// + /// + /// + /// + /// ZipProgressEventType.Extracting_BeforeExtractEntry + /// + /// Set when an Extract() on an entry in the ZipFile has begun. + /// Properties that are meaningful: ArchiveName, EntriesTotal, + /// CurrentEntry, Overwrite, ExtractLocation, EntriesExtracted. + /// + /// + /// + /// + /// ZipProgressEventType.Extracting_AfterExtractEntry + /// + /// Set when an Extract() on an entry in the ZipFile has completed. + /// Properties that are meaningful: ArchiveName, EntriesTotal, + /// CurrentEntry, Overwrite, ExtractLocation, EntriesExtracted. + /// + /// + /// + /// + /// ZipProgressEventType.Extracting_EntryBytesWritten + /// + /// Set within a call to Extract() on an entry in the ZipFile, as data + /// is extracted for the entry. Properties that are meaningful: + /// ArchiveName, CurrentEntry, BytesTransferred, TotalBytesToTransfer. + /// + /// + /// + /// + /// ZipProgressEventType.Extracting_ExtractEntryWouldOverwrite + /// + /// Set within a call to Extract() on an entry in the ZipFile, when the + /// extraction would overwrite an existing file. This event type is used + /// only when ExtractExistingFileAction on the ZipFile or + /// ZipEntry is set to InvokeExtractProgressEvent. + /// + /// + /// + /// + /// + /// + /// + /// + /// + /// private static bool justHadByteUpdate = false; + /// public static void ExtractProgress(object sender, ExtractProgressEventArgs e) + /// { + /// if(e.EventType == ZipProgressEventType.Extracting_EntryBytesWritten) + /// { + /// if (justHadByteUpdate) + /// Console.SetCursorPosition(0, Console.CursorTop); + /// + /// Console.Write(" {0}/{1} ({2:N0}%)", e.BytesTransferred, e.TotalBytesToTransfer, + /// e.BytesTransferred / (0.01 * e.TotalBytesToTransfer )); + /// justHadByteUpdate = true; + /// } + /// else if(e.EventType == ZipProgressEventType.Extracting_BeforeExtractEntry) + /// { + /// if (justHadByteUpdate) + /// Console.WriteLine(); + /// Console.WriteLine("Extracting: {0}", e.CurrentEntry.FileName); + /// justHadByteUpdate= false; + /// } + /// } + /// + /// public static ExtractZip(string zipToExtract, string directory) + /// { + /// string TargetDirectory= "extract"; + /// using (var zip = ZipFile.Read(zipToExtract)) { + /// zip.ExtractProgress += ExtractProgress; + /// foreach (var e in zip1) + /// { + /// e.Extract(TargetDirectory, true); + /// } + /// } + /// } + /// + /// + /// + /// Public Shared Sub Main(ByVal args As String()) + /// Dim ZipToUnpack As String = "C1P3SML.zip" + /// Dim TargetDir As String = "ExtractTest_Extract" + /// Console.WriteLine("Extracting file {0} to {1}", ZipToUnpack, TargetDir) + /// Using zip1 As ZipFile = ZipFile.Read(ZipToUnpack) + /// AddHandler zip1.ExtractProgress, AddressOf MyExtractProgress + /// Dim e As ZipEntry + /// For Each e In zip1 + /// e.Extract(TargetDir, True) + /// Next + /// End Using + /// End Sub + /// + /// Private Shared justHadByteUpdate As Boolean = False + /// + /// Public Shared Sub MyExtractProgress(ByVal sender As Object, ByVal e As ExtractProgressEventArgs) + /// If (e.EventType = ZipProgressEventType.Extracting_EntryBytesWritten) Then + /// If ExtractTest.justHadByteUpdate Then + /// Console.SetCursorPosition(0, Console.CursorTop) + /// End If + /// Console.Write(" {0}/{1} ({2:N0}%)", e.BytesTransferred, e.TotalBytesToTransfer, (CDbl(e.BytesTransferred) / (0.01 * e.TotalBytesToTransfer))) + /// ExtractTest.justHadByteUpdate = True + /// ElseIf (e.EventType = ZipProgressEventType.Extracting_BeforeExtractEntry) Then + /// If ExtractTest.justHadByteUpdate Then + /// Console.WriteLine + /// End If + /// Console.WriteLine("Extracting: {0}", e.CurrentEntry.FileName) + /// ExtractTest.justHadByteUpdate = False + /// End If + /// End Sub + /// + /// + /// + /// + /// + /// + public event EventHandler ExtractProgress; + + + + private void OnExtractEntry(int current, bool before, ZipEntry currentEntry, string path) + { + EventHandler ep = ExtractProgress; + if (ep != null) + { + var e = new ExtractProgressEventArgs(ArchiveNameForEvent, before, _entries.Count, current, currentEntry, path); + ep(this, e); + if (e.Cancel) + _extractOperationCanceled = true; + } + } + + + // Can be called from within ZipEntry._ExtractOne. + internal bool OnExtractBlock(ZipEntry entry, Int64 bytesWritten, Int64 totalBytesToWrite) + { + EventHandler ep = ExtractProgress; + if (ep != null) + { + var e = ExtractProgressEventArgs.ByteUpdate(ArchiveNameForEvent, entry, + bytesWritten, totalBytesToWrite); + ep(this, e); + if (e.Cancel) + _extractOperationCanceled = true; + } + return _extractOperationCanceled; + } + + + // Can be called from within ZipEntry.InternalExtract. + internal bool OnSingleEntryExtract(ZipEntry entry, string path, bool before) + { + EventHandler ep = ExtractProgress; + if (ep != null) + { + var e = (before) + ? ExtractProgressEventArgs.BeforeExtractEntry(ArchiveNameForEvent, entry, path) + : ExtractProgressEventArgs.AfterExtractEntry(ArchiveNameForEvent, entry, path); + ep(this, e); + if (e.Cancel) + _extractOperationCanceled = true; + } + return _extractOperationCanceled; + } + + internal bool OnExtractExisting(ZipEntry entry, string path) + { + EventHandler ep = ExtractProgress; + if (ep != null) + { + var e = ExtractProgressEventArgs.ExtractExisting(ArchiveNameForEvent, entry, path); + ep(this, e); + if (e.Cancel) + _extractOperationCanceled = true; + } + return _extractOperationCanceled; + } + + + private void OnExtractAllCompleted(string path) + { + EventHandler ep = ExtractProgress; + if (ep != null) + { + var e = ExtractProgressEventArgs.ExtractAllCompleted(ArchiveNameForEvent, + path ); + ep(this, e); + } + } + + + private void OnExtractAllStarted(string path) + { + EventHandler ep = ExtractProgress; + if (ep != null) + { + var e = ExtractProgressEventArgs.ExtractAllStarted(ArchiveNameForEvent, + path ); + ep(this, e); + } + } + + + #endregion + + + + #region Add + /// + /// An event handler invoked before, during, and after Adding entries to a zip archive. + /// + /// + /// + /// Adding a large number of entries to a zip file can take a long + /// time. For example, when calling on a + /// directory that contains 50,000 files, it could take 3 minutes or so. + /// This event handler allws an application to track the progress of the Add + /// operation, and to optionally cancel a lengthy Add operation. + /// + /// + /// + /// + /// + /// int _numEntriesToAdd= 0; + /// int _numEntriesAdded= 0; + /// void AddProgressHandler(object sender, AddProgressEventArgs e) + /// { + /// switch (e.EventType) + /// { + /// case ZipProgressEventType.Adding_Started: + /// Console.WriteLine("Adding files to the zip..."); + /// break; + /// case ZipProgressEventType.Adding_AfterAddEntry: + /// _numEntriesAdded++; + /// Console.WriteLine(String.Format("Adding file {0}/{1} :: {2}", + /// _numEntriesAdded, _numEntriesToAdd, e.CurrentEntry.FileName)); + /// break; + /// case ZipProgressEventType.Adding_Completed: + /// Console.WriteLine("Added all files"); + /// break; + /// } + /// } + /// + /// void CreateTheZip() + /// { + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddProgress += AddProgressHandler; + /// zip.AddDirectory(System.IO.Path.GetFileName(DirToZip)); + /// zip.Save(ZipFileToCreate); + /// } + /// } + /// + /// + /// + /// + /// + /// Private Sub AddProgressHandler(ByVal sender As Object, ByVal e As AddProgressEventArgs) + /// Select Case e.EventType + /// Case ZipProgressEventType.Adding_Started + /// Console.WriteLine("Adding files to the zip...") + /// Exit Select + /// Case ZipProgressEventType.Adding_AfterAddEntry + /// Console.WriteLine(String.Format("Adding file {0}", e.CurrentEntry.FileName)) + /// Exit Select + /// Case ZipProgressEventType.Adding_Completed + /// Console.WriteLine("Added all files") + /// Exit Select + /// End Select + /// End Sub + /// + /// Sub CreateTheZip() + /// Using zip as ZipFile = New ZipFile + /// AddHandler zip.AddProgress, AddressOf AddProgressHandler + /// zip.AddDirectory(System.IO.Path.GetFileName(DirToZip)) + /// zip.Save(ZipFileToCreate); + /// End Using + /// End Sub + /// + /// + /// + /// + /// + /// + /// + /// + public event EventHandler AddProgress; + + private void OnAddStarted() + { + EventHandler ap = AddProgress; + if (ap != null) + { + var e = AddProgressEventArgs.Started(ArchiveNameForEvent); + ap(this, e); + if (e.Cancel) // workitem 13371 + _addOperationCanceled = true; + } + } + + private void OnAddCompleted() + { + EventHandler ap = AddProgress; + if (ap != null) + { + var e = AddProgressEventArgs.Completed(ArchiveNameForEvent); + ap(this, e); + } + } + + internal void AfterAddEntry(ZipEntry entry) + { + EventHandler ap = AddProgress; + if (ap != null) + { + var e = AddProgressEventArgs.AfterEntry(ArchiveNameForEvent, entry, _entries.Count); + ap(this, e); + if (e.Cancel) // workitem 13371 + _addOperationCanceled = true; + } + } + + #endregion + + + + #region Error + /// + /// An event that is raised when an error occurs during open or read of files + /// while saving a zip archive. + /// + /// + /// + /// + /// Errors can occur as a file is being saved to the zip archive. For + /// example, the File.Open may fail, or a File.Read may fail, because of + /// lock conflicts or other reasons. If you add a handler to this event, + /// you can handle such errors in your own code. If you don't add a + /// handler, the library will throw an exception if it encounters an I/O + /// error during a call to Save(). + /// + /// + /// + /// Setting a handler implicitly sets to + /// ZipErrorAction.InvokeErrorEvent. + /// + /// + /// + /// The handler you add applies to all items that are + /// subsequently added to the ZipFile instance. If you set this + /// property after you have added items to the ZipFile, but before you + /// have called Save(), errors that occur while saving those items + /// will not cause the error handler to be invoked. + /// + /// + /// + /// If you want to handle any errors that occur with any entry in the zip + /// file using the same error handler, then add your error handler once, + /// before adding any entries to the zip archive. + /// + /// + /// + /// In the error handler method, you need to set the property on the + /// ZipErrorEventArgs.CurrentEntry. This communicates back to + /// DotNetZip what you would like to do with this particular error. Within + /// an error handler, if you set the ZipEntry.ZipErrorAction property + /// on the ZipEntry to ZipErrorAction.InvokeErrorEvent or if + /// you don't set it at all, the library will throw the exception. (It is the + /// same as if you had set the ZipEntry.ZipErrorAction property on the + /// ZipEntry to ZipErrorAction.Throw.) If you set the + /// ZipErrorEventArgs.Cancel to true, the entire Save() will be + /// canceled. + /// + /// + /// + /// In the case that you use ZipErrorAction.Skip, implying that + /// you want to skip the entry for which there's been an error, DotNetZip + /// tries to seek backwards in the output stream, and truncate all bytes + /// written on behalf of that particular entry. This works only if the + /// output stream is seekable. It will not work, for example, when using + /// ASPNET's Response.OutputStream. + /// + /// + /// + /// + /// + /// + /// This example shows how to use an event handler to handle + /// errors during save of the zip file. + /// + /// + /// public static void MyZipError(object sender, ZipErrorEventArgs e) + /// { + /// Console.WriteLine("Error saving {0}...", e.FileName); + /// Console.WriteLine(" Exception: {0}", e.exception); + /// ZipEntry entry = e.CurrentEntry; + /// string response = null; + /// // Ask the user whether he wants to skip this error or not + /// do + /// { + /// Console.Write("Retry, Skip, Throw, or Cancel ? (R/S/T/C) "); + /// response = Console.ReadLine(); + /// Console.WriteLine(); + /// + /// } while (response != null && + /// response[0]!='S' && response[0]!='s' && + /// response[0]!='R' && response[0]!='r' && + /// response[0]!='T' && response[0]!='t' && + /// response[0]!='C' && response[0]!='c'); + /// + /// e.Cancel = (response[0]=='C' || response[0]=='c'); + /// + /// if (response[0]=='S' || response[0]=='s') + /// entry.ZipErrorAction = ZipErrorAction.Skip; + /// else if (response[0]=='R' || response[0]=='r') + /// entry.ZipErrorAction = ZipErrorAction.Retry; + /// else if (response[0]=='T' || response[0]=='t') + /// entry.ZipErrorAction = ZipErrorAction.Throw; + /// } + /// + /// public void SaveTheFile() + /// { + /// string directoryToZip = "fodder"; + /// string directoryInArchive = "files"; + /// string zipFileToCreate = "Archive.zip"; + /// using (var zip = new ZipFile()) + /// { + /// // set the event handler before adding any entries + /// zip.ZipError += MyZipError; + /// zip.AddDirectory(directoryToZip, directoryInArchive); + /// zip.Save(zipFileToCreate); + /// } + /// } + /// + /// + /// + /// Private Sub MyZipError(ByVal sender As Object, ByVal e As Ionic.Zip.ZipErrorEventArgs) + /// ' At this point, the application could prompt the user for an action to take. + /// ' But in this case, this application will simply automatically skip the file, in case of error. + /// Console.WriteLine("Zip Error, entry {0}", e.CurrentEntry.FileName) + /// Console.WriteLine(" Exception: {0}", e.exception) + /// ' set the desired ZipErrorAction on the CurrentEntry to communicate that to DotNetZip + /// e.CurrentEntry.ZipErrorAction = Zip.ZipErrorAction.Skip + /// End Sub + /// + /// Public Sub SaveTheFile() + /// Dim directoryToZip As String = "fodder" + /// Dim directoryInArchive As String = "files" + /// Dim zipFileToCreate as String = "Archive.zip" + /// Using zipArchive As ZipFile = New ZipFile + /// ' set the event handler before adding any entries + /// AddHandler zipArchive.ZipError, AddressOf MyZipError + /// zipArchive.AddDirectory(directoryToZip, directoryInArchive) + /// zipArchive.Save(zipFileToCreate) + /// End Using + /// End Sub + /// + /// + /// + /// + /// + public event EventHandler ZipError; + + internal bool OnZipErrorSaving(ZipEntry entry, Exception exc) + { + if (ZipError != null) + { + lock (LOCK) + { + var e = ZipErrorEventArgs.Saving(this.Name, entry, exc); + ZipError(this, e); + if (e.Cancel) + _saveOperationCanceled = true; + } + } + return _saveOperationCanceled; + } + #endregion + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Extract.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Extract.cs new file mode 100644 index 00000000..199d3c2b --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Extract.cs @@ -0,0 +1,298 @@ +// ZipFile.Extract.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-31 14:45:18> +// +// ------------------------------------------------------------------ +// +// This module defines the methods for Extract operations on zip files. +// +// ------------------------------------------------------------------ +// + + +using System; +using System.IO; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + + public partial class ZipFile + { + + /// + /// Extracts all of the items in the zip archive, to the specified path in the + /// filesystem. The path can be relative or fully-qualified. + /// + /// + /// + /// + /// This method will extract all entries in the ZipFile to the + /// specified path. + /// + /// + /// + /// If an extraction of a file from the zip archive would overwrite an + /// existing file in the filesystem, the action taken is dictated by the + /// ExtractExistingFile property, which overrides any setting you may have + /// made on individual ZipEntry instances. By default, if you have not + /// set that property on the ZipFile instance, the entry will not + /// be extracted, the existing file will not be overwritten and an + /// exception will be thrown. To change this, set the property, or use the + /// overload that allows you to + /// specify an ExtractExistingFileAction parameter. + /// + /// + /// + /// The action to take when an extract would overwrite an existing file + /// applies to all entries. If you want to set this on a per-entry basis, + /// then you must use one of the ZipEntry.Extract methods. + /// + /// + /// + /// This method will send verbose output messages to the , if it is set on the ZipFile + /// instance. + /// + /// + /// + /// You may wish to take advantage of the ExtractProgress event. + /// + /// + /// + /// About timestamps: When extracting a file entry from a zip archive, the + /// extracted file gets the last modified time of the entry as stored in + /// the archive. The archive may also store extended file timestamp + /// information, including last accessed and created times. If these are + /// present in the ZipEntry, then the extracted file will also get + /// these times. + /// + /// + /// + /// A Directory entry is somewhat different. It will get the times as + /// described for a file entry, but, if there are file entries in the zip + /// archive that, when extracted, appear in the just-created directory, + /// then when those file entries are extracted, the last modified and last + /// accessed times of the directory will change, as a side effect. The + /// result is that after an extraction of a directory and a number of + /// files within the directory, the last modified and last accessed + /// timestamps on the directory will reflect the time that the last file + /// was extracted into the directory, rather than the time stored in the + /// zip archive for the directory. + /// + /// + /// + /// To compensate, when extracting an archive with ExtractAll, + /// DotNetZip will extract all the file and directory entries as described + /// above, but it will then make a second pass on the directories, and + /// reset the times on the directories to reflect what is stored in the + /// zip archive. + /// + /// + /// + /// This compensation is performed only within the context of an + /// ExtractAll. If you call ZipEntry.Extract on a directory + /// entry, the timestamps on directory in the filesystem will reflect the + /// times stored in the zip. If you then call ZipEntry.Extract on + /// a file entry, which is extracted into the directory, the timestamps on + /// the directory will be updated to the current time. + /// + /// + /// + /// + /// This example extracts all the entries in a zip archive file, to the + /// specified target directory. The extraction will overwrite any + /// existing files silently. + /// + /// + /// String TargetDirectory= "unpack"; + /// using(ZipFile zip= ZipFile.Read(ZipFileToExtract)) + /// { + /// zip.ExtractExistingFile= ExtractExistingFileAction.OverwriteSilently; + /// zip.ExtractAll(TargetDirectory); + /// } + /// + /// + /// + /// Dim TargetDirectory As String = "unpack" + /// Using zip As ZipFile = ZipFile.Read(ZipFileToExtract) + /// zip.ExtractExistingFile= ExtractExistingFileAction.OverwriteSilently + /// zip.ExtractAll(TargetDirectory) + /// End Using + /// + /// + /// + /// + /// + /// + /// + /// The path to which the contents of the zipfile will be extracted. + /// The path can be relative or fully-qualified. + /// + /// + public void ExtractAll(string path) + { + _InternalExtractAll(path, true); + } + + + + /// + /// Extracts all of the items in the zip archive, to the specified path in the + /// filesystem, using the specified behavior when extraction would overwrite an + /// existing file. + /// + /// + /// + /// + /// + /// This method will extract all entries in the ZipFile to the specified + /// path. For an extraction that would overwrite an existing file, the behavior + /// is dictated by , which overrides any + /// setting you may have made on individual ZipEntry instances. + /// + /// + /// + /// The action to take when an extract would overwrite an existing file + /// applies to all entries. If you want to set this on a per-entry basis, + /// then you must use or one of the similar methods. + /// + /// + /// + /// Calling this method is equivalent to setting the property and then calling . + /// + /// + /// + /// This method will send verbose output messages to the + /// , if it is set on the ZipFile instance. + /// + /// + /// + /// + /// This example extracts all the entries in a zip archive file, to the + /// specified target directory. It does not overwrite any existing files. + /// + /// String TargetDirectory= "c:\\unpack"; + /// using(ZipFile zip= ZipFile.Read(ZipFileToExtract)) + /// { + /// zip.ExtractAll(TargetDirectory, ExtractExistingFileAction.DontOverwrite); + /// } + /// + /// + /// + /// Dim TargetDirectory As String = "c:\unpack" + /// Using zip As ZipFile = ZipFile.Read(ZipFileToExtract) + /// zip.ExtractAll(TargetDirectory, ExtractExistingFileAction.DontOverwrite) + /// End Using + /// + /// + /// + /// + /// The path to which the contents of the zipfile will be extracted. + /// The path can be relative or fully-qualified. + /// + /// + /// + /// The action to take if extraction would overwrite an existing file. + /// + /// + public void ExtractAll(string path, ExtractExistingFileAction extractExistingFile) + { + ExtractExistingFile = extractExistingFile; + _InternalExtractAll(path, true); + } + + + private void _InternalExtractAll(string path, bool overrideExtractExistingProperty) + { + bool header = Verbose; + _inExtractAll = true; + try + { + OnExtractAllStarted(path); + + int n = 0; + foreach (ZipEntry e in _entries.Values) + { + if (header) + { + StatusMessageTextWriter.WriteLine("\n{1,-22} {2,-8} {3,4} {4,-8} {0}", + "Name", "Modified", "Size", "Ratio", "Packed"); + StatusMessageTextWriter.WriteLine(new System.String('-', 72)); + header = false; + } + if (Verbose) + { + StatusMessageTextWriter.WriteLine("{1,-22} {2,-8} {3,4:F0}% {4,-8} {0}", + e.FileName, + e.LastModified.ToString("yyyy-MM-dd HH:mm:ss"), + e.UncompressedSize, + e.CompressionRatio, + e.CompressedSize); + if (!String.IsNullOrEmpty(e.Comment)) + StatusMessageTextWriter.WriteLine(" Comment: {0}", e.Comment); + } + e.Password = _Password; // this may be null + OnExtractEntry(n, true, e, path); + if (overrideExtractExistingProperty) + e.ExtractExistingFile = this.ExtractExistingFile; + e.Extract(path); + n++; + OnExtractEntry(n, false, e, path); + if (_extractOperationCanceled) + break; + } + + if (!_extractOperationCanceled) + { + // workitem 8264: + // now, set times on directory entries, again. + // The problem is, extracting a file changes the times on the parent + // directory. So after all files have been extracted, we have to + // run through the directories again. + foreach (ZipEntry e in _entries.Values) + { + // check if it is a directory + if ((e.IsDirectory) || (e.FileName.EndsWith("/"))) + { + string outputFile = (e.FileName.StartsWith("/")) + ? Path.Combine(path, e.FileName.Substring(1)) + : Path.Combine(path, e.FileName); + + e._SetTimes(outputFile, false); + } + } + OnExtractAllCompleted(path); + } + + } + finally + { + + _inExtractAll = false; + } + } + + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Read.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Read.cs new file mode 100644 index 00000000..7411c1a8 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Read.cs @@ -0,0 +1,1110 @@ +// ZipFile.Read.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-05 11:38:59> +// +// ------------------------------------------------------------------ +// +// This module defines the methods for Reading zip files. +// +// ------------------------------------------------------------------ +// + + +using System; +using System.IO; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + /// + /// A class for collecting the various options that can be used when + /// Reading zip files for extraction or update. + /// + /// + /// + /// + /// When reading a zip file, there are several options an + /// application can set, to modify how the file is read, or what + /// the library does while reading. This class collects those + /// options into one container. + /// + /// + /// + /// Pass an instance of the ReadOptions class into the + /// ZipFile.Read() method. + /// + /// + /// . + /// . + /// + public class ReadOptions + { + /// + /// An event handler for Read operations. When opening large zip + /// archives, you may want to display a progress bar or other + /// indicator of status progress while reading. This parameter + /// allows you to specify a ReadProgress Event Handler directly. + /// When you call Read(), the progress event is invoked as + /// necessary. + /// + public EventHandler ReadProgress { get; set; } + + /// + /// The System.IO.TextWriter to use for writing verbose status messages + /// during operations on the zip archive. A console application may wish to + /// pass System.Console.Out to get messages on the Console. A graphical + /// or headless application may wish to capture the messages in a different + /// TextWriter, such as a System.IO.StringWriter. + /// + public TextWriter StatusMessageWriter { get; set; } + + /// + /// The System.Text.Encoding to use when reading in the zip archive. Be + /// careful specifying the encoding. If the value you use here is not the same + /// as the Encoding used when the zip archive was created (possibly by a + /// different archiver) you will get unexpected results and possibly exceptions. + /// + /// + /// + /// + public System.Text.Encoding @Encoding { get; set; } + } + + + public partial class ZipFile + { + /// + /// Reads a zip file archive and returns the instance. + /// + /// + /// + /// + /// The stream is read using the default System.Text.Encoding, which is the + /// IBM437 codepage. + /// + /// + /// + /// + /// Thrown if the ZipFile cannot be read. The implementation of this method + /// relies on System.IO.File.OpenRead, which can throw a variety of exceptions, + /// including specific exceptions if a file is not found, an unauthorized access + /// exception, exceptions for poorly formatted filenames, and so on. + /// + /// + /// + /// The name of the zip archive to open. This can be a fully-qualified or relative + /// pathname. + /// + /// + /// . + /// + /// The instance read from the zip archive. + /// + public static ZipFile Read(string fileName) + { + return ZipFile.Read(fileName, null, null, null); + } + + + /// + /// Reads a zip file archive from the named filesystem file using the + /// specified options. + /// + /// + /// + /// + /// This version of the Read() method allows the caller to pass + /// in a TextWriter an Encoding, via an instance of the + /// ReadOptions class. The ZipFile is read in using the + /// specified encoding for entries where UTF-8 encoding is not + /// explicitly specified. + /// + /// + /// + /// + /// + /// + /// This example shows how to read a zip file using the Big-5 Chinese + /// code page (950), and extract each entry in the zip file, while + /// sending status messages out to the Console. + /// + /// + /// + /// For this code to work as intended, the zipfile must have been + /// created using the big5 code page (CP950). This is typical, for + /// example, when using WinRar on a machine with CP950 set as the + /// default code page. In that case, the names of entries within the + /// Zip archive will be stored in that code page, and reading the zip + /// archive must be done using that code page. If the application did + /// not use the correct code page in ZipFile.Read(), then names of + /// entries within the zip archive would not be correctly retrieved. + /// + /// + /// + /// string zipToExtract = "MyArchive.zip"; + /// string extractDirectory = "extract"; + /// var options = new ReadOptions + /// { + /// StatusMessageWriter = System.Console.Out, + /// Encoding = System.Text.Encoding.GetEncoding(950) + /// }; + /// using (ZipFile zip = ZipFile.Read(zipToExtract, options)) + /// { + /// foreach (ZipEntry e in zip) + /// { + /// e.Extract(extractDirectory); + /// } + /// } + /// + /// + /// + /// + /// Dim zipToExtract as String = "MyArchive.zip" + /// Dim extractDirectory as String = "extract" + /// Dim options as New ReadOptions + /// options.Encoding = System.Text.Encoding.GetEncoding(950) + /// options.StatusMessageWriter = System.Console.Out + /// Using zip As ZipFile = ZipFile.Read(zipToExtract, options) + /// Dim e As ZipEntry + /// For Each e In zip + /// e.Extract(extractDirectory) + /// Next + /// End Using + /// + /// + /// + /// + /// + /// + /// + /// This example shows how to read a zip file using the default + /// code page, to remove entries that have a modified date before a given threshold, + /// sending status messages out to a StringWriter. + /// + /// + /// + /// var options = new ReadOptions + /// { + /// StatusMessageWriter = new System.IO.StringWriter() + /// }; + /// using (ZipFile zip = ZipFile.Read("PackedDocuments.zip", options)) + /// { + /// var Threshold = new DateTime(2007,7,4); + /// // We cannot remove the entry from the list, within the context of + /// // an enumeration of said list. + /// // So we add the doomed entry to a list to be removed later. + /// // pass 1: mark the entries for removal + /// var MarkedEntries = new System.Collections.Generic.List<ZipEntry>(); + /// foreach (ZipEntry e in zip) + /// { + /// if (e.LastModified < Threshold) + /// MarkedEntries.Add(e); + /// } + /// // pass 2: actually remove the entry. + /// foreach (ZipEntry zombie in MarkedEntries) + /// zip.RemoveEntry(zombie); + /// zip.Comment = "This archive has been updated."; + /// zip.Save(); + /// } + /// // can now use contents of sw, eg store in an audit log + /// + /// + /// + /// Dim options as New ReadOptions + /// options.StatusMessageWriter = New System.IO.StringWriter + /// Using zip As ZipFile = ZipFile.Read("PackedDocuments.zip", options) + /// Dim Threshold As New DateTime(2007, 7, 4) + /// ' We cannot remove the entry from the list, within the context of + /// ' an enumeration of said list. + /// ' So we add the doomed entry to a list to be removed later. + /// ' pass 1: mark the entries for removal + /// Dim MarkedEntries As New System.Collections.Generic.List(Of ZipEntry) + /// Dim e As ZipEntry + /// For Each e In zip + /// If (e.LastModified < Threshold) Then + /// MarkedEntries.Add(e) + /// End If + /// Next + /// ' pass 2: actually remove the entry. + /// Dim zombie As ZipEntry + /// For Each zombie In MarkedEntries + /// zip.RemoveEntry(zombie) + /// Next + /// zip.Comment = "This archive has been updated." + /// zip.Save + /// End Using + /// ' can now use contents of sw, eg store in an audit log + /// + /// + /// + /// + /// Thrown if the zipfile cannot be read. The implementation of + /// this method relies on System.IO.File.OpenRead, which + /// can throw a variety of exceptions, including specific + /// exceptions if a file is not found, an unauthorized access + /// exception, exceptions for poorly formatted filenames, and so + /// on. + /// + /// + /// + /// The name of the zip archive to open. + /// This can be a fully-qualified or relative pathname. + /// + /// + /// + /// The set of options to use when reading the zip file. + /// + /// + /// The ZipFile instance read from the zip archive. + /// + /// + /// + public static ZipFile Read(string fileName, + ReadOptions options) + { + if (options == null) + throw new ArgumentNullException("options"); + return Read(fileName, + options.StatusMessageWriter, + options.Encoding, + options.ReadProgress); + } + + /// + /// Reads a zip file archive using the specified text encoding, the specified + /// TextWriter for status messages, and the specified ReadProgress event handler, + /// and returns the instance. + /// + /// + /// + /// The name of the zip archive to open. + /// This can be a fully-qualified or relative pathname. + /// + /// + /// + /// An event handler for Read operations. + /// + /// + /// + /// The System.IO.TextWriter to use for writing verbose status messages + /// during operations on the zip archive. A console application may wish to + /// pass System.Console.Out to get messages on the Console. A graphical + /// or headless application may wish to capture the messages in a different + /// TextWriter, such as a System.IO.StringWriter. + /// + /// + /// + /// The System.Text.Encoding to use when reading in the zip archive. Be + /// careful specifying the encoding. If the value you use here is not the same + /// as the Encoding used when the zip archive was created (possibly by a + /// different archiver) you will get unexpected results and possibly exceptions. + /// + /// + /// The instance read from the zip archive. + /// + private static ZipFile Read(string fileName, + TextWriter statusMessageWriter, + System.Text.Encoding encoding, + EventHandler readProgress) + { + ZipFile zf = new ZipFile(); + zf.AlternateEncoding = encoding ?? DefaultEncoding; + zf.AlternateEncodingUsage = ZipOption.Always; + zf._StatusMessageTextWriter = statusMessageWriter; + zf._name = fileName; + if (readProgress != null) + zf.ReadProgress = readProgress; + + if (zf.Verbose) zf._StatusMessageTextWriter.WriteLine("reading from {0}...", fileName); + + ReadIntoInstance(zf); + zf._fileAlreadyExists = true; + + return zf; + } + + /// + /// Reads a zip archive from a stream. + /// + /// + /// + /// + /// + /// When reading from a file, it's probably easier to just use + /// ZipFile.Read(String, ReadOptions). This + /// overload is useful when when the zip archive content is + /// available from an already-open stream. The stream must be + /// open and readable and seekable when calling this method. The + /// stream is left open when the reading is completed. + /// + /// + /// + /// Using this overload, the stream is read using the default + /// System.Text.Encoding, which is the IBM437 + /// codepage. If you want to specify the encoding to use when + /// reading the zipfile content, see + /// ZipFile.Read(Stream, ReadOptions). This + /// + /// + /// + /// Reading of zip content begins at the current position in the + /// stream. This means if you have a stream that concatenates + /// regular data and zip data, if you position the open, readable + /// stream at the start of the zip data, you will be able to read + /// the zip archive using this constructor, or any of the ZipFile + /// constructors that accept a as + /// input. Some examples of where this might be useful: the zip + /// content is concatenated at the end of a regular EXE file, as + /// some self-extracting archives do. (Note: SFX files produced + /// by DotNetZip do not work this way; they can be read as normal + /// ZIP files). Another example might be a stream being read from + /// a database, where the zip content is embedded within an + /// aggregate stream of data. + /// + /// + /// + /// + /// + /// + /// This example shows how to Read zip content from a stream, and + /// extract one entry into a different stream. In this example, + /// the filename "NameOfEntryInArchive.doc", refers only to the + /// name of the entry within the zip archive. A file by that + /// name is not created in the filesystem. The I/O is done + /// strictly with the given streams. + /// + /// + /// + /// using (ZipFile zip = ZipFile.Read(InputStream)) + /// { + /// zip.Extract("NameOfEntryInArchive.doc", OutputStream); + /// } + /// + /// + /// + /// Using zip as ZipFile = ZipFile.Read(InputStream) + /// zip.Extract("NameOfEntryInArchive.doc", OutputStream) + /// End Using + /// + /// + /// + /// the stream containing the zip data. + /// + /// The ZipFile instance read from the stream + /// + public static ZipFile Read(Stream zipStream) + { + return Read(zipStream, null, null, null); + } + + /// + /// Reads a zip file archive from the given stream using the + /// specified options. + /// + /// + /// + /// + /// + /// When reading from a file, it's probably easier to just use + /// ZipFile.Read(String, ReadOptions). This + /// overload is useful when when the zip archive content is + /// available from an already-open stream. The stream must be + /// open and readable and seekable when calling this method. The + /// stream is left open when the reading is completed. + /// + /// + /// + /// Reading of zip content begins at the current position in the + /// stream. This means if you have a stream that concatenates + /// regular data and zip data, if you position the open, readable + /// stream at the start of the zip data, you will be able to read + /// the zip archive using this constructor, or any of the ZipFile + /// constructors that accept a as + /// input. Some examples of where this might be useful: the zip + /// content is concatenated at the end of a regular EXE file, as + /// some self-extracting archives do. (Note: SFX files produced + /// by DotNetZip do not work this way; they can be read as normal + /// ZIP files). Another example might be a stream being read from + /// a database, where the zip content is embedded within an + /// aggregate stream of data. + /// + /// + /// + /// the stream containing the zip data. + /// + /// + /// The set of options to use when reading the zip file. + /// + /// + /// + /// Thrown if the zip archive cannot be read. + /// + /// + /// The ZipFile instance read from the stream. + /// + /// + /// + public static ZipFile Read(Stream zipStream, ReadOptions options) + { + if (options == null) + throw new ArgumentNullException("options"); + + return Read(zipStream, + options.StatusMessageWriter, + options.Encoding, + options.ReadProgress); + } + + + + /// + /// Reads a zip archive from a stream, using the specified text Encoding, the + /// specified TextWriter for status messages, + /// and the specified ReadProgress event handler. + /// + /// + /// + /// + /// Reading of zip content begins at the current position in the stream. This + /// means if you have a stream that concatenates regular data and zip data, if + /// you position the open, readable stream at the start of the zip data, you + /// will be able to read the zip archive using this constructor, or any of the + /// ZipFile constructors that accept a as + /// input. Some examples of where this might be useful: the zip content is + /// concatenated at the end of a regular EXE file, as some self-extracting + /// archives do. (Note: SFX files produced by DotNetZip do not work this + /// way). Another example might be a stream being read from a database, where + /// the zip content is embedded within an aggregate stream of data. + /// + /// + /// + /// the stream containing the zip data. + /// + /// + /// The System.IO.TextWriter to which verbose status messages are written + /// during operations on the ZipFile. For example, in a console + /// application, System.Console.Out works, and will get a message for each entry + /// added to the ZipFile. If the TextWriter is null, no verbose messages + /// are written. + /// + /// + /// + /// The text encoding to use when reading entries that do not have the UTF-8 + /// encoding bit set. Be careful specifying the encoding. If the value you use + /// here is not the same as the Encoding used when the zip archive was created + /// (possibly by a different archiver) you will get unexpected results and + /// possibly exceptions. See the + /// property for more information. + /// + /// + /// + /// An event handler for Read operations. + /// + /// + /// an instance of ZipFile + private static ZipFile Read(Stream zipStream, + TextWriter statusMessageWriter, + System.Text.Encoding encoding, + EventHandler readProgress) + { + if (zipStream == null) + throw new ArgumentNullException("zipStream"); + + ZipFile zf = new ZipFile(); + zf._StatusMessageTextWriter = statusMessageWriter; + zf._alternateEncoding = encoding ?? ZipFile.DefaultEncoding; + zf._alternateEncodingUsage = ZipOption.Always; + if (readProgress != null) + zf.ReadProgress += readProgress; + zf._readstream = (zipStream.Position == 0L) + ? zipStream + : new OffsetStream(zipStream); + zf._ReadStreamIsOurs = false; + if (zf.Verbose) zf._StatusMessageTextWriter.WriteLine("reading from stream..."); + + ReadIntoInstance(zf); + return zf; + } + + + + private static void ReadIntoInstance(ZipFile zf) + { + Stream s = zf.ReadStream; + try + { + zf._readName = zf._name; // workitem 13915 + if (!s.CanSeek) + { + ReadIntoInstance_Orig(zf); + return; + } + + zf.OnReadStarted(); + + // change for workitem 8098 + //zf._originPosition = s.Position; + + // Try reading the central directory, rather than scanning the file. + + uint datum = ReadFirstFourBytes(s); + + if (datum == ZipConstants.EndOfCentralDirectorySignature) + return; + + + // start at the end of the file... + // seek backwards a bit, then look for the EoCD signature. + int nTries = 0; + bool success = false; + + // The size of the end-of-central-directory-footer plus 2 bytes is 18. + // This implies an archive comment length of 0. We'll add a margin of + // safety and start "in front" of that, when looking for the + // EndOfCentralDirectorySignature + long posn = s.Length - 64; + long maxSeekback = Math.Max(s.Length - 0x4000, 10); + do + { + if (posn < 0) posn = 0; // BOF + s.Seek(posn, SeekOrigin.Begin); + long bytesRead = SharedUtilities.FindSignature(s, (int)ZipConstants.EndOfCentralDirectorySignature); + if (bytesRead != -1) + success = true; + else + { + if (posn==0) break; // started at the BOF and found nothing + nTries++; + // Weird: with NETCF, negative offsets from SeekOrigin.End DO + // NOT WORK. So rather than seek a negative offset, we seek + // from SeekOrigin.Begin using a smaller number. + posn -= (32 * (nTries + 1) * nTries); + } + } + while (!success && posn > maxSeekback); + + if (success) + { + // workitem 8299 + zf._locEndOfCDS = s.Position - 4; + + byte[] block = new byte[16]; + s.Read(block, 0, block.Length); + + zf._diskNumberWithCd = BitConverter.ToUInt16(block, 2); + + if (zf._diskNumberWithCd == 0xFFFF) + throw new ZipException("Spanned archives with more than 65534 segments are not supported at this time."); + + zf._diskNumberWithCd++; // I think the number in the file differs from reality by 1 + + int i = 12; + + uint offset32 = (uint) BitConverter.ToUInt32(block, i); + if (offset32 == 0xFFFFFFFF) + { + Zip64SeekToCentralDirectory(zf); + } + else + { + zf._OffsetOfCentralDirectory = offset32; + // change for workitem 8098 + s.Seek(offset32, SeekOrigin.Begin); + } + + ReadCentralDirectory(zf); + } + else + { + // Could not find the central directory. + // Fallback to the old method. + // workitem 8098: ok + //s.Seek(zf._originPosition, SeekOrigin.Begin); + s.Seek(0L, SeekOrigin.Begin); + ReadIntoInstance_Orig(zf); + } + } + catch (Exception ex1) + { + if (zf._ReadStreamIsOurs && zf._readstream != null) + { + try + { +#if NETCF + zf._readstream.Close(); +#else + zf._readstream.Dispose(); +#endif + zf._readstream = null; + } + finally { } + } + + throw new ZipException("Cannot read that as a ZipFile", ex1); + } + + // the instance has been read in + zf._contentsChanged = false; + } + + + + private static void Zip64SeekToCentralDirectory(ZipFile zf) + { + Stream s = zf.ReadStream; + byte[] block = new byte[16]; + + // seek back to find the ZIP64 EoCD. + // I think this might not work for .NET CF ? + s.Seek(-40, SeekOrigin.Current); + s.Read(block, 0, 16); + + Int64 offset64 = BitConverter.ToInt64(block, 8); + zf._OffsetOfCentralDirectory = 0xFFFFFFFF; + zf._OffsetOfCentralDirectory64 = offset64; + // change for workitem 8098 + s.Seek(offset64, SeekOrigin.Begin); + //zf.SeekFromOrigin(Offset64); + + uint datum = (uint)Ionic.Zip.SharedUtilities.ReadInt(s); + if (datum != ZipConstants.Zip64EndOfCentralDirectoryRecordSignature) + throw new BadReadException(String.Format(" Bad signature (0x{0:X8}) looking for ZIP64 EoCD Record at position 0x{1:X8}", datum, s.Position)); + + s.Read(block, 0, 8); + Int64 Size = BitConverter.ToInt64(block, 0); + + block = new byte[Size]; + s.Read(block, 0, block.Length); + + offset64 = BitConverter.ToInt64(block, 36); + // change for workitem 8098 + s.Seek(offset64, SeekOrigin.Begin); + //zf.SeekFromOrigin(Offset64); + } + + + private static uint ReadFirstFourBytes(Stream s) + { + uint datum = (uint)Ionic.Zip.SharedUtilities.ReadInt(s); + return datum; + } + + + + private static void ReadCentralDirectory(ZipFile zf) + { + // We must have the central directory footer record, in order to properly + // read zip dir entries from the central directory. This because the logic + // knows when to open a spanned file when the volume number for the central + // directory differs from the volume number for the zip entry. The + // _diskNumberWithCd was set when originally finding the offset for the + // start of the Central Directory. + + // workitem 9214 + bool inputUsesZip64 = false; + ZipEntry de; + // in lieu of hashset, use a dictionary + var previouslySeen = new Dictionary(); + while ((de = ZipEntry.ReadDirEntry(zf, previouslySeen)) != null) + { + de.ResetDirEntry(); + zf.OnReadEntry(true, null); + + if (zf.Verbose) + zf.StatusMessageTextWriter.WriteLine("entry {0}", de.FileName); + + zf._entries.Add(de.FileName,de); + + // workitem 9214 + if (de._InputUsesZip64) inputUsesZip64 = true; + previouslySeen.Add(de.FileName, null); // to prevent dupes + } + + // workitem 9214; auto-set the zip64 flag + if (inputUsesZip64) zf.UseZip64WhenSaving = Zip64Option.Always; + + // workitem 8299 + if (zf._locEndOfCDS > 0) + zf.ReadStream.Seek(zf._locEndOfCDS, SeekOrigin.Begin); + + ReadCentralDirectoryFooter(zf); + + if (zf.Verbose && !String.IsNullOrEmpty(zf.Comment)) + zf.StatusMessageTextWriter.WriteLine("Zip file Comment: {0}", zf.Comment); + + // We keep the read stream open after reading. + + if (zf.Verbose) + zf.StatusMessageTextWriter.WriteLine("read in {0} entries.", zf._entries.Count); + + zf.OnReadCompleted(); + } + + + + + // build the TOC by reading each entry in the file. + private static void ReadIntoInstance_Orig(ZipFile zf) + { + zf.OnReadStarted(); + //zf._entries = new System.Collections.Generic.List(); + zf._entries = new System.Collections.Generic.Dictionary(); + + ZipEntry e; + if (zf.Verbose) + if (zf.Name == null) + zf.StatusMessageTextWriter.WriteLine("Reading zip from stream..."); + else + zf.StatusMessageTextWriter.WriteLine("Reading zip {0}...", zf.Name); + + // work item 6647: PK00 (packed to removable disk) + bool firstEntry = true; + ZipContainer zc = new ZipContainer(zf); + while ((e = ZipEntry.ReadEntry(zc, firstEntry)) != null) + { + if (zf.Verbose) + zf.StatusMessageTextWriter.WriteLine(" {0}", e.FileName); + + zf._entries.Add(e.FileName,e); + firstEntry = false; + } + + // read the zipfile's central directory structure here. + // workitem 9912 + // But, because it may be corrupted, ignore errors. + try + { + ZipEntry de; + // in lieu of hashset, use a dictionary + var previouslySeen = new Dictionary(); + while ((de = ZipEntry.ReadDirEntry(zf, previouslySeen)) != null) + { + // Housekeeping: Since ZipFile exposes ZipEntry elements in the enumerator, + // we need to copy the comment that we grab from the ZipDirEntry + // into the ZipEntry, so the application can access the comment. + // Also since ZipEntry is used to Write zip files, we need to copy the + // file attributes to the ZipEntry as appropriate. + ZipEntry e1 = zf._entries[de.FileName]; + if (e1 != null) + { + e1._Comment = de.Comment; + if (de.IsDirectory) e1.MarkAsDirectory(); + } + previouslySeen.Add(de.FileName,null); // to prevent dupes + } + + // workitem 8299 + if (zf._locEndOfCDS > 0) + zf.ReadStream.Seek(zf._locEndOfCDS, SeekOrigin.Begin); + + ReadCentralDirectoryFooter(zf); + + if (zf.Verbose && !String.IsNullOrEmpty(zf.Comment)) + zf.StatusMessageTextWriter.WriteLine("Zip file Comment: {0}", zf.Comment); + } + catch (ZipException) { } + catch (IOException) { } + + zf.OnReadCompleted(); + } + + + + + private static void ReadCentralDirectoryFooter(ZipFile zf) + { + Stream s = zf.ReadStream; + int signature = Ionic.Zip.SharedUtilities.ReadSignature(s); + + byte[] block = null; + int j = 0; + if (signature == ZipConstants.Zip64EndOfCentralDirectoryRecordSignature) + { + // We have a ZIP64 EOCD + // This data block is 4 bytes sig, 8 bytes size, 44 bytes fixed data, + // followed by a variable-sized extension block. We have read the sig already. + // 8 - datasize (64 bits) + // 2 - version made by + // 2 - version needed to extract + // 4 - number of this disk + // 4 - number of the disk with the start of the CD + // 8 - total number of entries in the CD on this disk + // 8 - total number of entries in the CD + // 8 - size of the CD + // 8 - offset of the CD + // ----------------------- + // 52 bytes + + block = new byte[8 + 44]; + s.Read(block, 0, block.Length); + + Int64 DataSize = BitConverter.ToInt64(block, 0); // == 44 + the variable length + + if (DataSize < 44) + throw new ZipException("Bad size in the ZIP64 Central Directory."); + + zf._versionMadeBy = BitConverter.ToUInt16(block, j); + j += 2; + zf._versionNeededToExtract = BitConverter.ToUInt16(block, j); + j += 2; + zf._diskNumberWithCd = BitConverter.ToUInt32(block, j); + j += 2; + + //zf._diskNumberWithCd++; // hack!! + + // read the extended block + block = new byte[DataSize - 44]; + s.Read(block, 0, block.Length); + // discard the result + + signature = Ionic.Zip.SharedUtilities.ReadSignature(s); + if (signature != ZipConstants.Zip64EndOfCentralDirectoryLocatorSignature) + throw new ZipException("Inconsistent metadata in the ZIP64 Central Directory."); + + block = new byte[16]; + s.Read(block, 0, block.Length); + // discard the result + + signature = Ionic.Zip.SharedUtilities.ReadSignature(s); + } + + // Throw if this is not a signature for "end of central directory record" + // This is a sanity check. + if (signature != ZipConstants.EndOfCentralDirectorySignature) + { + s.Seek(-4, SeekOrigin.Current); + throw new BadReadException(String.Format("Bad signature ({0:X8}) at position 0x{1:X8}", + signature, s.Position)); + } + + // read the End-of-Central-Directory-Record + block = new byte[16]; + zf.ReadStream.Read(block, 0, block.Length); + + // off sz data + // ------------------------------------------------------- + // 0 4 end of central dir signature (0x06054b50) + // 4 2 number of this disk + // 6 2 number of the disk with start of the central directory + // 8 2 total number of entries in the central directory on this disk + // 10 2 total number of entries in the central directory + // 12 4 size of the central directory + // 16 4 offset of start of central directory with respect to the starting disk number + // 20 2 ZIP file comment length + // 22 ?? ZIP file comment + + if (zf._diskNumberWithCd == 0) + { + zf._diskNumberWithCd = BitConverter.ToUInt16(block, 2); + //zf._diskNumberWithCd++; // hack!! + } + + // read the comment here + ReadZipFileComment(zf); + } + + + + private static void ReadZipFileComment(ZipFile zf) + { + // read the comment here + byte[] block = new byte[2]; + zf.ReadStream.Read(block, 0, block.Length); + + Int16 commentLength = (short)(block[0] + block[1] * 256); + if (commentLength > 0) + { + block = new byte[commentLength]; + zf.ReadStream.Read(block, 0, block.Length); + + // workitem 10392 - prefer ProvisionalAlternateEncoding, + // first. The fix for workitem 6513 tried to use UTF8 + // only as necessary, but that is impossible to test + // for, in this direction. There's no way to know what + // characters the already-encoded bytes refer + // to. Therefore, must do what the user tells us. + + string s1 = zf.AlternateEncoding.GetString(block, 0, block.Length); + zf.Comment = s1; + } + } + + + // private static bool BlocksAreEqual(byte[] a, byte[] b) + // { + // if (a.Length != b.Length) return false; + // for (int i = 0; i < a.Length; i++) + // { + // if (a[i] != b[i]) return false; + // } + // return true; + // } + + + + /// + /// Checks the given file to see if it appears to be a valid zip file. + /// + /// + /// + /// + /// Calling this method is equivalent to calling with the testExtract parameter set to false. + /// + /// + /// + /// The file to check. + /// true if the file appears to be a zip file. + public static bool IsZipFile(string fileName) + { + return IsZipFile(fileName, false); + } + + + /// + /// Checks a file to see if it is a valid zip file. + /// + /// + /// + /// + /// This method opens the specified zip file, reads in the zip archive, + /// verifying the ZIP metadata as it reads. + /// + /// + /// + /// If everything succeeds, then the method returns true. If anything fails - + /// for example if an incorrect signature or CRC is found, indicating a + /// corrupt file, the the method returns false. This method also returns + /// false for a file that does not exist. + /// + /// + /// + /// If is true, as part of its check, this + /// method reads in the content for each entry, expands it, and checks CRCs. + /// This provides an additional check beyond verifying the zip header and + /// directory data. + /// + /// + /// + /// If is true, and if any of the zip entries + /// are protected with a password, this method will return false. If you want + /// to verify a ZipFile that has entries which are protected with a + /// password, you will need to do that manually. + /// + /// + /// + /// + /// The zip file to check. + /// true if the caller wants to extract each entry. + /// true if the file contains a valid zip file. + public static bool IsZipFile(string fileName, bool testExtract) + { + bool result = false; + try + { + if (!File.Exists(fileName)) return false; + + using (var s = File.Open(fileName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite)) + { + result = IsZipFile(s, testExtract); + } + } + catch (IOException) { } + catch (ZipException) { } + return result; + } + + + /// + /// Checks a stream to see if it contains a valid zip archive. + /// + /// + /// + /// + /// This method reads the zip archive contained in the specified stream, verifying + /// the ZIP metadata as it reads. If testExtract is true, this method also extracts + /// each entry in the archive, dumping all the bits into . + /// + /// + /// + /// If everything succeeds, then the method returns true. If anything fails - + /// for example if an incorrect signature or CRC is found, indicating a corrupt + /// file, the the method returns false. This method also returns false for a + /// file that does not exist. + /// + /// + /// + /// If testExtract is true, this method reads in the content for each + /// entry, expands it, and checks CRCs. This provides an additional check + /// beyond verifying the zip header data. + /// + /// + /// + /// If testExtract is true, and if any of the zip entries are protected + /// with a password, this method will return false. If you want to verify a + /// ZipFile that has entries which are protected with a password, you will need + /// to do that manually. + /// + /// + /// + /// + /// + /// The stream to check. + /// true if the caller wants to extract each entry. + /// true if the stream contains a valid zip archive. + public static bool IsZipFile(Stream stream, bool testExtract) + { + if (stream == null) + throw new ArgumentNullException("stream"); + + bool result = false; + try + { + if (!stream.CanRead) return false; + + var bitBucket = Stream.Null; + + using (ZipFile zip1 = ZipFile.Read(stream, null, null, null)) + { + if (testExtract) + { + foreach (var e in zip1) + { + if (!e.IsDirectory) + { + e.Extract(bitBucket); + } + } + } + } + result = true; + } + catch (IOException) { } + catch (ZipException) { } + return result; + } + + + + + } + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Save.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Save.cs new file mode 100644 index 00000000..ddfaee49 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Save.cs @@ -0,0 +1,964 @@ +// ZipFile.Save.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-05 13:31:23> +// +// ------------------------------------------------------------------ +// +// This module defines the methods for Save operations on zip files. +// +// ------------------------------------------------------------------ +// + + +using System; +using System.IO; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + + public partial class ZipFile + { + + /// + /// Delete file with retry on UnauthorizedAccessException. + /// + /// + /// + /// + /// When calling File.Delete() on a file that has been "recently" + /// created, the call sometimes fails with + /// UnauthorizedAccessException. This method simply retries the Delete 3 + /// times with a sleep between tries. + /// + /// + /// + /// the name of the file to be deleted + private void DeleteFileWithRetry(string filename) + { + bool done = false; + int nRetries = 3; + for (int i=0; i < nRetries && !done; i++) + { + try + { + File.Delete(filename); + done = true; + } + catch (System.UnauthorizedAccessException) + { + Console.WriteLine("************************************************** Retry delete."); + System.Threading.Thread.Sleep(200+i*200); + } + } + } + + + /// + /// Saves the Zip archive to a file, specified by the Name property of the + /// ZipFile. + /// + /// + /// + /// + /// The ZipFile instance is written to storage, typically a zip file + /// in a filesystem, only when the caller calls Save. In the typical + /// case, the Save operation writes the zip content to a temporary file, and + /// then renames the temporary file to the desired name. If necessary, this + /// method will delete a pre-existing file before the rename. + /// + /// + /// + /// The property is specified either explicitly, + /// or implicitly using one of the parameterized ZipFile constructors. For + /// COM Automation clients, the Name property must be set explicitly, + /// because COM Automation clients cannot call parameterized constructors. + /// + /// + /// + /// When using a filesystem file for the Zip output, it is possible to call + /// Save multiple times on the ZipFile instance. With each + /// call the zip content is re-written to the same output file. + /// + /// + /// + /// Data for entries that have been added to the ZipFile instance is + /// written to the output when the Save method is called. This means + /// that the input streams for those entries must be available at the time + /// the application calls Save. If, for example, the application + /// adds entries with AddEntry using a dynamically-allocated + /// MemoryStream, the memory stream must not have been disposed + /// before the call to Save. See the property for more discussion of the + /// availability requirements of the input stream for an entry, and an + /// approach for providing just-in-time stream lifecycle management. + /// + /// + /// + /// + /// + /// + /// + /// Thrown if you haven't specified a location or stream for saving the zip, + /// either in the constructor or by setting the Name property, or if you try + /// to save a regular zip archive to a filename with a .exe extension. + /// + /// + /// + /// Thrown if is non-zero, and the number + /// of segments that would be generated for the spanned zip file during the + /// save operation exceeds 99. If this happens, you need to increase the + /// segment size. + /// + /// + public void Save() + { + try + { + bool thisSaveUsedZip64 = false; + _saveOperationCanceled = false; + _numberOfSegmentsForMostRecentSave = 0; + OnSaveStarted(); + + if (WriteStream == null) + throw new BadStateException("You haven't specified where to save the zip."); + + if (_name != null && _name.EndsWith(".exe") && !_SavingSfx) + throw new BadStateException("You specified an EXE for a plain zip file."); + + // check if modified, before saving. + if (!_contentsChanged) + { + OnSaveCompleted(); + if (Verbose) StatusMessageTextWriter.WriteLine("No save is necessary...."); + return; + } + + Reset(true); + + if (Verbose) StatusMessageTextWriter.WriteLine("saving...."); + + // validate the number of entries + if (_entries.Count >= 0xFFFF && _zip64 == Zip64Option.Never) + throw new ZipException("The number of entries is 65535 or greater. Consider setting the UseZip64WhenSaving property on the ZipFile instance."); + + + // write an entry in the zip for each file + int n = 0; + // workitem 9831 + ICollection c = (SortEntriesBeforeSaving) ? EntriesSorted : Entries; + foreach (ZipEntry e in c) // _entries.Values + { + OnSaveEntry(n, e, true); + e.Write(WriteStream); + if (_saveOperationCanceled) + break; + + n++; + OnSaveEntry(n, e, false); + if (_saveOperationCanceled) + break; + + // Some entries can be skipped during the save. + if (e.IncludedInMostRecentSave) + thisSaveUsedZip64 |= e.OutputUsedZip64.Value; + } + + + + if (_saveOperationCanceled) + return; + + var zss = WriteStream as ZipSegmentedStream; + + _numberOfSegmentsForMostRecentSave = (zss!=null) + ? zss.CurrentSegment + : 1; + + bool directoryNeededZip64 = + ZipOutput.WriteCentralDirectoryStructure + (WriteStream, + c, + _numberOfSegmentsForMostRecentSave, + _zip64, + Comment, + new ZipContainer(this)); + + OnSaveEvent(ZipProgressEventType.Saving_AfterSaveTempArchive); + + _hasBeenSaved = true; + _contentsChanged = false; + + thisSaveUsedZip64 |= directoryNeededZip64; + _OutputUsesZip64 = new Nullable(thisSaveUsedZip64); + + + // do the rename as necessary + if (_name != null && + (_temporaryFileName!=null || zss != null)) + { + // _temporaryFileName may remain null if we are writing to a stream. + // only close the stream if there is a file behind it. +#if NETCF + WriteStream.Close(); +#else + WriteStream.Dispose(); +#endif + if (_saveOperationCanceled) + return; + + if (_fileAlreadyExists && this._readstream != null) + { + // This means we opened and read a zip file. + // If we are now saving to the same file, we need to close the + // orig file, first. + this._readstream.Close(); + this._readstream = null; + // the archiveStream for each entry needs to be null + foreach (var e in c) + { + var zss1 = e._archiveStream as ZipSegmentedStream; + if (zss1 != null) +#if NETCF + zss1.Close(); +#else + zss1.Dispose(); +#endif + e._archiveStream = null; + } + } + + string tmpName = null; + if (File.Exists(_name)) + { + // the steps: + // + // 1. Delete tmpName + // 2. move existing zip to tmpName + // 3. rename (File.Move) working file to name of existing zip + // 4. delete tmpName + // + // This series of steps avoids the exception, + // System.IO.IOException: + // "Cannot create a file when that file already exists." + // + // Cannot just call File.Replace() here because + // there is a possibility that the TEMP volume is different + // that the volume for the final file (c:\ vs d:\). + // So we need to do a Delete+Move pair. + // + // But, when doing the delete, Windows allows a process to + // delete the file, even though it is held open by, say, a + // virus scanner. It gets internally marked as "delete + // pending". The file does not actually get removed from the + // file system, it is still there after the File.Delete + // call. + // + // Therefore, we need to move the existing zip, which may be + // held open, to some other name. Then rename our working + // file to the desired name, then delete (possibly delete + // pending) the "other name". + // + // Ideally this would be transactional. It's possible that the + // delete succeeds and the move fails. Lacking transactions, if + // this kind of failure happens, we're hosed, and this logic will + // throw on the next File.Move(). + // + //File.Delete(_name); + // workitem 10447 +#if NETCF || SILVERLIGHT + tmpName = _name + "." + SharedUtilities.GenerateRandomStringImpl(8,0) + ".tmp"; +#else + tmpName = _name + "." + Path.GetRandomFileName(); +#endif + if (File.Exists(tmpName)) + DeleteFileWithRetry(tmpName); + File.Move(_name, tmpName); + } + + OnSaveEvent(ZipProgressEventType.Saving_BeforeRenameTempArchive); + File.Move((zss != null) ? zss.CurrentTempName : _temporaryFileName, + _name); + + OnSaveEvent(ZipProgressEventType.Saving_AfterRenameTempArchive); + + if (tmpName != null) + { + try + { + // not critical + if (File.Exists(tmpName)) + File.Delete(tmpName); + } + catch + { + // don't care about exceptions here. + } + + } + _fileAlreadyExists = true; + } + + NotifyEntriesSaveComplete(c); + OnSaveCompleted(); + _JustSaved = true; + } + + // workitem 5043 + finally + { + CleanupAfterSaveOperation(); + } + + return; + } + + + + private static void NotifyEntriesSaveComplete(ICollection c) + { + foreach (ZipEntry e in c) + { + e.NotifySaveComplete(); + } + } + + + private void RemoveTempFile() + { + try + { + if (File.Exists(_temporaryFileName)) + { + File.Delete(_temporaryFileName); + } + } + catch (IOException ex1) + { + if (Verbose) + StatusMessageTextWriter.WriteLine("ZipFile::Save: could not delete temp file: {0}.", ex1.Message); + } + } + + + private void CleanupAfterSaveOperation() + { + if (_name != null) + { + // close the stream if there is a file behind it. + if (_writestream != null) + { + try + { + // workitem 7704 +#if NETCF + _writestream.Close(); +#else + _writestream.Dispose(); +#endif + } + catch (System.IO.IOException) { } + } + _writestream = null; + + if (_temporaryFileName != null) + { + RemoveTempFile(); + _temporaryFileName = null; + } + } + } + + + /// + /// Save the file to a new zipfile, with the given name. + /// + /// + /// + /// + /// This method allows the application to explicitly specify the name of the zip + /// file when saving. Use this when creating a new zip file, or when + /// updating a zip archive. + /// + /// + /// + /// An application can also save a zip archive in several places by calling this + /// method multiple times in succession, with different filenames. + /// + /// + /// + /// The ZipFile instance is written to storage, typically a zip file in a + /// filesystem, only when the caller calls Save. The Save operation writes + /// the zip content to a temporary file, and then renames the temporary file + /// to the desired name. If necessary, this method will delete a pre-existing file + /// before the rename. + /// + /// + /// + /// + /// + /// Thrown if you specify a directory for the filename. + /// + /// + /// + /// The name of the zip archive to save to. Existing files will + /// be overwritten with great prejudice. + /// + /// + /// + /// This example shows how to create and Save a zip file. + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddDirectory(@"c:\reports\January"); + /// zip.Save("January.zip"); + /// } + /// + /// + /// + /// Using zip As New ZipFile() + /// zip.AddDirectory("c:\reports\January") + /// zip.Save("January.zip") + /// End Using + /// + /// + /// + /// + /// + /// This example shows how to update a zip file. + /// + /// using (ZipFile zip = ZipFile.Read("ExistingArchive.zip")) + /// { + /// zip.AddFile("NewData.csv"); + /// zip.Save("UpdatedArchive.zip"); + /// } + /// + /// + /// + /// Using zip As ZipFile = ZipFile.Read("ExistingArchive.zip") + /// zip.AddFile("NewData.csv") + /// zip.Save("UpdatedArchive.zip") + /// End Using + /// + /// + /// + public void Save(String fileName) + { + // Check for the case where we are re-saving a zip archive + // that was originally instantiated with a stream. In that case, + // the _name will be null. If so, we set _writestream to null, + // which insures that we'll cons up a new WriteStream (with a filesystem + // file backing it) in the Save() method. + if (_name == null) + _writestream = null; + + else _readName = _name; // workitem 13915 + + _name = fileName; + if (Directory.Exists(_name)) + throw new ZipException("Bad Directory", new System.ArgumentException("That name specifies an existing directory. Please specify a filename.", "fileName")); + _contentsChanged = true; + _fileAlreadyExists = File.Exists(_name); + Save(); + } + + + /// + /// Save the zip archive to the specified stream. + /// + /// + /// + /// + /// The ZipFile instance is written to storage - typically a zip file + /// in a filesystem, but using this overload, the storage can be anything + /// accessible via a writable stream - only when the caller calls Save. + /// + /// + /// + /// Use this method to save the zip content to a stream directly. A common + /// scenario is an ASP.NET application that dynamically generates a zip file + /// and allows the browser to download it. The application can call + /// Save(Response.OutputStream) to write a zipfile directly to the + /// output stream, without creating a zip file on the disk on the ASP.NET + /// server. + /// + /// + /// + /// Be careful when saving a file to a non-seekable stream, including + /// Response.OutputStream. When DotNetZip writes to a non-seekable + /// stream, the zip archive is formatted in such a way that may not be + /// compatible with all zip tools on all platforms. It's a perfectly legal + /// and compliant zip file, but some people have reported problems opening + /// files produced this way using the Mac OS archive utility. + /// + /// + /// + /// + /// + /// + /// This example saves the zipfile content into a MemoryStream, and + /// then gets the array of bytes from that MemoryStream. + /// + /// + /// using (var zip = new Ionic.Zip.ZipFile()) + /// { + /// zip.CompressionLevel= Ionic.Zlib.CompressionLevel.BestCompression; + /// zip.Password = "VerySecret."; + /// zip.Encryption = EncryptionAlgorithm.WinZipAes128; + /// zip.AddFile(sourceFileName); + /// MemoryStream output = new MemoryStream(); + /// zip.Save(output); + /// + /// byte[] zipbytes = output.ToArray(); + /// } + /// + /// + /// + /// + /// + /// This example shows a pitfall you should avoid. DO NOT read + /// from a stream, then try to save to the same stream. DO + /// NOT DO THIS: + /// + /// + /// + /// using (var fs = new FileSteeam(filename, FileMode.Open)) + /// { + /// using (var zip = Ionic.Zip.ZipFile.Read(inputStream)) + /// { + /// zip.AddEntry("Name1.txt", "this is the content"); + /// zip.Save(inputStream); // NO NO NO!! + /// } + /// } + /// + /// + /// + /// Better like this: + /// + /// + /// + /// using (var zip = Ionic.Zip.ZipFile.Read(filename)) + /// { + /// zip.AddEntry("Name1.txt", "this is the content"); + /// zip.Save(); // YES! + /// } + /// + /// + /// + /// + /// + /// The System.IO.Stream to write to. It must be + /// writable. If you created the ZipFile instanct by calling + /// ZipFile.Read(), this stream must not be the same stream + /// you passed to ZipFile.Read(). + /// + public void Save(Stream outputStream) + { + if (outputStream == null) + throw new ArgumentNullException("outputStream"); + if (!outputStream.CanWrite) + throw new ArgumentException("Must be a writable stream.", "outputStream"); + + // if we had a filename to save to, we are now obliterating it. + _name = null; + + _writestream = new CountingStream(outputStream); + + _contentsChanged = true; + _fileAlreadyExists = false; + Save(); + } + + + } + + + + internal static class ZipOutput + { + public static bool WriteCentralDirectoryStructure(Stream s, + ICollection entries, + uint numSegments, + Zip64Option zip64, + String comment, + ZipContainer container) + { + var zss = s as ZipSegmentedStream; + if (zss != null) + zss.ContiguousWrite = true; + + // write to a memory stream in order to keep the + // CDR contiguous + Int64 aLength = 0; + using (var ms = new MemoryStream()) + { + foreach (ZipEntry e in entries) + { + if (e.IncludedInMostRecentSave) + { + // this writes a ZipDirEntry corresponding to the ZipEntry + e.WriteCentralDirectoryEntry(ms); + } + } + var a = ms.ToArray(); + s.Write(a, 0, a.Length); + aLength = a.Length; + } + + + // We need to keep track of the start and + // Finish of the Central Directory Structure. + + // Cannot always use WriteStream.Length or Position; some streams do + // not support these. (eg, ASP.NET Response.OutputStream) In those + // cases we have a CountingStream. + + // Also, we cannot just set Start as s.Position bfore the write, and Finish + // as s.Position after the write. In a split zip, the write may actually + // flip to the next segment. In that case, Start will be zero. But we + // don't know that til after we know the size of the thing to write. So the + // answer is to compute the directory, then ask the ZipSegmentedStream which + // segment that directory would fall in, it it were written. Then, include + // that data into the directory, and finally, write the directory to the + // output stream. + + var output = s as CountingStream; + long Finish = (output != null) ? output.ComputedPosition : s.Position; // BytesWritten + long Start = Finish - aLength; + + // need to know which segment the EOCD record starts in + UInt32 startSegment = (zss != null) + ? zss.CurrentSegment + : 0; + + Int64 SizeOfCentralDirectory = Finish - Start; + + int countOfEntries = CountEntries(entries); + + bool needZip64CentralDirectory = + zip64 == Zip64Option.Always || + countOfEntries >= 0xFFFF || + SizeOfCentralDirectory > 0xFFFFFFFF || + Start > 0xFFFFFFFF; + + byte[] a2 = null; + + // emit ZIP64 extensions as required + if (needZip64CentralDirectory) + { + if (zip64 == Zip64Option.Never) + { +#if NETCF + throw new ZipException("The archive requires a ZIP64 Central Directory. Consider enabling ZIP64 extensions."); +#else + System.Diagnostics.StackFrame sf = new System.Diagnostics.StackFrame(1); + if (sf.GetMethod().DeclaringType == typeof(ZipFile)) + throw new ZipException("The archive requires a ZIP64 Central Directory. Consider setting the ZipFile.UseZip64WhenSaving property."); + else + throw new ZipException("The archive requires a ZIP64 Central Directory. Consider setting the ZipOutputStream.EnableZip64 property."); +#endif + + } + + var a = GenZip64EndOfCentralDirectory(Start, Finish, countOfEntries, numSegments); + a2 = GenCentralDirectoryFooter(Start, Finish, zip64, countOfEntries, comment, container); + if (startSegment != 0) + { + UInt32 thisSegment = zss.ComputeSegment(a.Length + a2.Length); + int i = 16; + // number of this disk + Array.Copy(BitConverter.GetBytes(thisSegment), 0, a, i, 4); + i += 4; + // number of the disk with the start of the central directory + //Array.Copy(BitConverter.GetBytes(startSegment), 0, a, i, 4); + Array.Copy(BitConverter.GetBytes(thisSegment), 0, a, i, 4); + + i = 60; + // offset 60 + // number of the disk with the start of the zip64 eocd + Array.Copy(BitConverter.GetBytes(thisSegment), 0, a, i, 4); + i += 4; + i += 8; + + // offset 72 + // total number of disks + Array.Copy(BitConverter.GetBytes(thisSegment), 0, a, i, 4); + } + s.Write(a, 0, a.Length); + } + else + a2 = GenCentralDirectoryFooter(Start, Finish, zip64, countOfEntries, comment, container); + + + // now, the regular footer + if (startSegment != 0) + { + // The assumption is the central directory is never split across + // segment boundaries. + + UInt16 thisSegment = (UInt16) zss.ComputeSegment(a2.Length); + int i = 4; + // number of this disk + Array.Copy(BitConverter.GetBytes(thisSegment), 0, a2, i, 2); + i += 2; + // number of the disk with the start of the central directory + //Array.Copy(BitConverter.GetBytes((UInt16)startSegment), 0, a2, i, 2); + Array.Copy(BitConverter.GetBytes(thisSegment), 0, a2, i, 2); + i += 2; + } + + s.Write(a2, 0, a2.Length); + + // reset the contiguous write property if necessary + if (zss != null) + zss.ContiguousWrite = false; + + return needZip64CentralDirectory; + } + + + private static System.Text.Encoding GetEncoding(ZipContainer container, string t) + { + switch (container.AlternateEncodingUsage) + { + case ZipOption.Always: + return container.AlternateEncoding; + case ZipOption.Never: + return container.DefaultEncoding; + } + + // AsNecessary is in force + var e = container.DefaultEncoding; + if (t == null) return e; + + var bytes = e.GetBytes(t); + var t2 = e.GetString(bytes,0,bytes.Length); + if (t2.Equals(t)) return e; + return container.AlternateEncoding; + } + + + + private static byte[] GenCentralDirectoryFooter(long StartOfCentralDirectory, + long EndOfCentralDirectory, + Zip64Option zip64, + int entryCount, + string comment, + ZipContainer container) + { + System.Text.Encoding encoding = GetEncoding(container, comment); + int j = 0; + int bufferLength = 22; + byte[] block = null; + Int16 commentLength = 0; + if ((comment != null) && (comment.Length != 0)) + { + block = encoding.GetBytes(comment); + commentLength = (Int16)block.Length; + } + bufferLength += commentLength; + byte[] bytes = new byte[bufferLength]; + + int i = 0; + // signature + byte[] sig = BitConverter.GetBytes(ZipConstants.EndOfCentralDirectorySignature); + Array.Copy(sig, 0, bytes, i, 4); + i+=4; + + // number of this disk + // (this number may change later) + bytes[i++] = 0; + bytes[i++] = 0; + + // number of the disk with the start of the central directory + // (this number may change later) + bytes[i++] = 0; + bytes[i++] = 0; + + // handle ZIP64 extensions for the end-of-central-directory + if (entryCount >= 0xFFFF || zip64 == Zip64Option.Always) + { + // the ZIP64 version. + for (j = 0; j < 4; j++) + bytes[i++] = 0xFF; + } + else + { + // the standard version. + // total number of entries in the central dir on this disk + bytes[i++] = (byte)(entryCount & 0x00FF); + bytes[i++] = (byte)((entryCount & 0xFF00) >> 8); + + // total number of entries in the central directory + bytes[i++] = (byte)(entryCount & 0x00FF); + bytes[i++] = (byte)((entryCount & 0xFF00) >> 8); + } + + // size of the central directory + Int64 SizeOfCentralDirectory = EndOfCentralDirectory - StartOfCentralDirectory; + + if (SizeOfCentralDirectory >= 0xFFFFFFFF || StartOfCentralDirectory >= 0xFFFFFFFF) + { + // The actual data is in the ZIP64 central directory structure + for (j = 0; j < 8; j++) + bytes[i++] = 0xFF; + } + else + { + // size of the central directory (we just get the low 4 bytes) + bytes[i++] = (byte)(SizeOfCentralDirectory & 0x000000FF); + bytes[i++] = (byte)((SizeOfCentralDirectory & 0x0000FF00) >> 8); + bytes[i++] = (byte)((SizeOfCentralDirectory & 0x00FF0000) >> 16); + bytes[i++] = (byte)((SizeOfCentralDirectory & 0xFF000000) >> 24); + + // offset of the start of the central directory (we just get the low 4 bytes) + bytes[i++] = (byte)(StartOfCentralDirectory & 0x000000FF); + bytes[i++] = (byte)((StartOfCentralDirectory & 0x0000FF00) >> 8); + bytes[i++] = (byte)((StartOfCentralDirectory & 0x00FF0000) >> 16); + bytes[i++] = (byte)((StartOfCentralDirectory & 0xFF000000) >> 24); + } + + + // zip archive comment + if ((comment == null) || (comment.Length == 0)) + { + // no comment! + bytes[i++] = (byte)0; + bytes[i++] = (byte)0; + } + else + { + // the size of our buffer defines the max length of the comment we can write + if (commentLength + i + 2 > bytes.Length) commentLength = (Int16)(bytes.Length - i - 2); + bytes[i++] = (byte)(commentLength & 0x00FF); + bytes[i++] = (byte)((commentLength & 0xFF00) >> 8); + + if (commentLength != 0) + { + // now actually write the comment itself into the byte buffer + for (j = 0; (j < commentLength) && (i + j < bytes.Length); j++) + { + bytes[i + j] = block[j]; + } + i += j; + } + } + + // s.Write(bytes, 0, i); + return bytes; + } + + + + private static byte[] GenZip64EndOfCentralDirectory(long StartOfCentralDirectory, + long EndOfCentralDirectory, + int entryCount, + uint numSegments) + { + const int bufferLength = 12 + 44 + 20; + + byte[] bytes = new byte[bufferLength]; + + int i = 0; + // signature + byte[] sig = BitConverter.GetBytes(ZipConstants.Zip64EndOfCentralDirectoryRecordSignature); + Array.Copy(sig, 0, bytes, i, 4); + i+=4; + + // There is a possibility to include "Extensible" data in the zip64 + // end-of-central-dir record. I cannot figure out what it might be used to + // store, so the size of this record is always fixed. Maybe it is used for + // strong encryption data? That is for another day. + long DataSize = 44; + Array.Copy(BitConverter.GetBytes(DataSize), 0, bytes, i, 8); + i += 8; + + // offset 12 + // VersionMadeBy = 45; + bytes[i++] = 45; + bytes[i++] = 0x00; + + // VersionNeededToExtract = 45; + bytes[i++] = 45; + bytes[i++] = 0x00; + + // offset 16 + // number of the disk, and the disk with the start of the central dir. + // (this may change later) + for (int j = 0; j < 8; j++) + bytes[i++] = 0x00; + + // offset 24 + long numberOfEntries = entryCount; + Array.Copy(BitConverter.GetBytes(numberOfEntries), 0, bytes, i, 8); + i += 8; + Array.Copy(BitConverter.GetBytes(numberOfEntries), 0, bytes, i, 8); + i += 8; + + // offset 40 + Int64 SizeofCentraldirectory = EndOfCentralDirectory - StartOfCentralDirectory; + Array.Copy(BitConverter.GetBytes(SizeofCentraldirectory), 0, bytes, i, 8); + i += 8; + Array.Copy(BitConverter.GetBytes(StartOfCentralDirectory), 0, bytes, i, 8); + i += 8; + + // offset 56 + // now, the locator + // signature + sig = BitConverter.GetBytes(ZipConstants.Zip64EndOfCentralDirectoryLocatorSignature); + Array.Copy(sig, 0, bytes, i, 4); + i+=4; + + // offset 60 + // number of the disk with the start of the zip64 eocd + // (this will change later) (it will?) + uint x2 = (numSegments==0)?0:(uint)(numSegments-1); + Array.Copy(BitConverter.GetBytes(x2), 0, bytes, i, 4); + i+=4; + + // offset 64 + // relative offset of the zip64 eocd + Array.Copy(BitConverter.GetBytes(EndOfCentralDirectory), 0, bytes, i, 8); + i += 8; + + // offset 72 + // total number of disks + // (this will change later) + Array.Copy(BitConverter.GetBytes(numSegments), 0, bytes, i, 4); + i+=4; + + return bytes; + } + + + + private static int CountEntries(ICollection _entries) + { + // Cannot just emit _entries.Count, because some of the entries + // may have been skipped. + int count = 0; + foreach (var entry in _entries) + if (entry.IncludedInMostRecentSave) count++; + return count; + } + + + + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.SaveSelfExtractor.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.SaveSelfExtractor.cs new file mode 100644 index 00000000..98e92c7b --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.SaveSelfExtractor.cs @@ -0,0 +1,1100 @@ +// ZipFile.saveSelfExtractor.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2008-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-03 16:42:15> +// +// ------------------------------------------------------------------ +// +// This is a the source module that implements the stuff for saving to a +// self-extracting Zip archive. +// +// ZipFile is set up as a "partial class" - defined in multiple .cs source modules. +// This is one of the source modules for the ZipFile class. +// +// Here's the design: The self-extracting zip file is just a regular managed EXE +// file, with embedded resources. The managed code logic instantiates a ZipFile, and +// then extracts each entry. The embedded resources include the zip archive content, +// as well as the Zip library itself. The latter is required so that self-extracting +// can work on any machine, whether or not it has the DotNetZip library installed on +// it. +// +// What we need to do is create the animal I just described, within a method on the +// ZipFile class. This source module provides that capability. The method is +// SaveSelfExtractor(). +// +// The way the method works: it uses the programmatic interface to the csc.exe +// compiler, Microsoft.CSharp.CSharpCodeProvider, to compile "boilerplate" +// extraction logic into a new assembly. As part of that compile, we embed within +// that assembly the zip archive itself, as well as the Zip library. +// +// Therefore we need to first save to a temporary zip file, then produce the exe. +// +// There are a few twists. +// +// The Visual Studio Project structure is a little weird. There are code files +// that ARE NOT compiled during a normal build of the VS Solution. They are +// marked as embedded resources. These are the various "boilerplate" modules that +// are used in the self-extractor. These modules are: WinFormsSelfExtractorStub.cs +// WinFormsSelfExtractorStub.Designer.cs CommandLineSelfExtractorStub.cs +// PasswordDialog.cs PasswordDialog.Designer.cs +// +// At design time, if you want to modify the way the GUI looks, you have to +// mark those modules to have a "compile" build action. Then tweak em, test, +// etc. Then again mark them as "Embedded resource". +// +// ------------------------------------------------------------------ + +using System; +using System.Reflection; +using System.IO; +using System.Collections.Generic; + + +namespace Ionic.Zip +{ +#if !NO_SFX + /// + /// An enum that provides the different self-extractor flavors + /// + public enum SelfExtractorFlavor + { + /// + /// A self-extracting zip archive that runs from the console or + /// command line. + /// + ConsoleApplication = 0, + + /// + /// A self-extracting zip archive that presents a graphical user + /// interface when it is executed. + /// + WinFormsApplication, + } + + /// + /// The options for generating a self-extracting archive. + /// + public class SelfExtractorSaveOptions + { + /// + /// The type of SFX to create. + /// + public SelfExtractorFlavor Flavor + { + get; + set; + } + + /// + /// The command to run after extraction. + /// + /// + /// + /// + /// This is optional. Leave it empty (null in C# or Nothing in + /// VB) to run no command after extraction. + /// + /// + /// + /// If it is non-empty, the SFX will execute the command specified in this + /// string on the user's machine, and using the extract directory as the + /// working directory for the process, after unpacking the archive. The + /// program to execute can include a path, if you like. If you want to execute + /// a program that accepts arguments, specify the program name, followed by a + /// space, and then the arguments for the program, each separated by a space, + /// just as you would on a normal command line. Example: program.exe arg1 + /// arg2. The string prior to the first space will be taken as the + /// program name, and the string following the first space specifies the + /// arguments to the program. + /// + /// + /// + /// If you want to execute a program that has a space in the name or path of + /// the file, surround the program name in double-quotes. The first character + /// of the command line should be a double-quote character, and there must be + /// a matching double-quote following the end of the program file name. Any + /// optional arguments to the program follow that, separated by + /// spaces. Example: "c:\project files\program name.exe" arg1 arg2. + /// + /// + /// + /// If the flavor of the SFX is SelfExtractorFlavor.ConsoleApplication, + /// then the SFX starts a new process, using this string as the post-extract + /// command line. The SFX waits for the process to exit. The exit code of + /// the post-extract command line is returned as the exit code of the + /// command-line self-extractor exe. A non-zero exit code is typically used to + /// indicated a failure by the program. In the case of an SFX, a non-zero exit + /// code may indicate a failure during extraction, OR, it may indicate a + /// failure of the run-after-extract program if specified, OR, it may indicate + /// the run-after-extract program could not be fuond. There is no way to + /// distinguish these conditions from the calling shell, aside from parsing + /// the output of the SFX. If you have Quiet set to true, you may not + /// see error messages, if a problem occurs. + /// + /// + /// + /// If the flavor of the SFX is + /// SelfExtractorFlavor.WinFormsApplication, then the SFX starts a new + /// process, using this string as the post-extract command line, and using the + /// extract directory as the working directory for the process. The SFX does + /// not wait for the command to complete, and does not check the exit code of + /// the program. If the run-after-extract program cannot be fuond, a message + /// box is displayed indicating that fact. + /// + /// + /// + /// You can specify environment variables within this string, with a format like + /// %NAME%. The value of these variables will be expanded at the time + /// the SFX is run. Example: %WINDIR%\system32\xcopy.exe may expand at + /// runtime to c:\Windows\System32\xcopy.exe. + /// + /// + /// + /// By combining this with the RemoveUnpackedFilesAfterExecute + /// flag, you can create an SFX that extracts itself, runs a file that + /// was extracted, then deletes all the files that were extracted. If + /// you want it to run "invisibly" then set Flavor to + /// SelfExtractorFlavor.ConsoleApplication, and set Quiet + /// to true. The user running such an EXE will see a console window + /// appear, then disappear quickly. You may also want to specify the + /// default extract location, with DefaultExtractDirectory. + /// + /// + /// + /// If you set Flavor to + /// SelfExtractorFlavor.WinFormsApplication, and set Quiet to + /// true, then a GUI with progressbars is displayed, but it is + /// "non-interactive" - it accepts no input from the user. Instead the SFX + /// just automatically unpacks and exits. + /// + /// + /// + public String PostExtractCommandLine + { + get; + set; + } + + /// + /// The default extract directory the user will see when + /// running the self-extracting archive. + /// + /// + /// + /// + /// Passing null (or Nothing in VB) here will cause the Self Extractor to use + /// the the user's personal directory () for the default extract + /// location. + /// + /// + /// + /// This is only a default location. The actual extract location will be + /// settable on the command line when the SFX is executed. + /// + /// + /// + /// You can specify environment variables within this string, + /// with %NAME%. The value of these variables will be + /// expanded at the time the SFX is run. Example: + /// %USERPROFILE%\Documents\unpack may expand at runtime to + /// c:\users\melvin\Documents\unpack. + /// + /// + public String DefaultExtractDirectory + { + get; + set; + } + + /// + /// The name of an .ico file in the filesystem to use for the application icon + /// for the generated SFX. + /// + /// + /// + /// + /// Normally, DotNetZip will embed an "zipped folder" icon into the generated + /// SFX. If you prefer to use a different icon, you can specify it here. It + /// should be a .ico file. This file is passed as the /win32icon + /// option to the csc.exe compiler when constructing the SFX file. + /// + /// + /// + public string IconFile + { + get; + set; + } + + /// + /// Whether the ConsoleApplication SFX will be quiet during extraction. + /// + /// + /// + /// + /// This option affects the way the generated SFX runs. By default it is + /// false. When you set it to true,... + /// + /// + /// + /// + /// Flavor + /// Behavior + /// + /// + /// + /// ConsoleApplication + /// no messages will be emitted during successful + /// operation. Double-clicking the SFX in Windows + /// Explorer or as an attachment in an email will cause a console + /// window to appear briefly, before it disappears. If you run the + /// ConsoleApplication SFX from the cmd.exe prompt, it runs as a + /// normal console app; by default, because it is quiet, it displays + /// no messages to the console. If you pass the -v+ command line + /// argument to the Console SFX when you run it, you will get verbose + /// messages to the console. + /// + /// + /// + /// + /// WinFormsApplication + /// the SFX extracts automatically when the application + /// is launched, with no additional user input. + /// + /// + /// + /// + /// + /// + /// When you set it to false,... + /// + /// + /// + /// + /// Flavor + /// Behavior + /// + /// + /// + /// ConsoleApplication + /// the extractor will emit a + /// message to the console for each entry extracted. + /// + /// When double-clicking to launch the SFX, the console window will + /// remain, and the SFX will emit a message for each file as it + /// extracts. The messages fly by quickly, they won't be easily + /// readable, unless the extracted files are fairly large. + /// + /// + /// + /// + /// + /// WinFormsApplication + /// the SFX presents a forms UI and allows the user to select + /// options before extracting. + /// + /// + /// + /// + /// + /// + public bool Quiet + { + get; + set; + } + + + /// + /// Specify what the self-extractor will do when extracting an entry + /// would overwrite an existing file. + /// + /// + /// + /// The default behavvior is to Throw. + /// + /// + public Ionic.Zip.ExtractExistingFileAction ExtractExistingFile + { + get; + set; + } + + + /// + /// Whether to remove the files that have been unpacked, after executing the + /// PostExtractCommandLine. + /// + /// + /// + /// + /// If true, and if there is a + /// PostExtractCommandLine, and if the command runs successfully, + /// then the files that the SFX unpacked will be removed, afterwards. If + /// the command does not complete successfully (non-zero return code), + /// that is interpreted as a failure, and the extracted files will not be + /// removed. + /// + /// + /// + /// Setting this flag, and setting Flavor to + /// SelfExtractorFlavor.ConsoleApplication, and setting Quiet to + /// true, results in an SFX that extracts itself, runs a file that was + /// extracted, then deletes all the files that were extracted, with no + /// intervention by the user. You may also want to specify the default + /// extract location, with DefaultExtractDirectory. + /// + /// + /// + public bool RemoveUnpackedFilesAfterExecute + { + get; + set; + } + + + /// + /// The file version number to embed into the generated EXE. It will show up, for + /// example, during a mouseover in Windows Explorer. + /// + /// + public Version FileVersion + { + get; + set; + } + + /// + /// The product version to embed into the generated EXE. It will show up, for + /// example, during a mouseover in Windows Explorer. + /// + /// + /// + /// You can use any arbitrary string, but a human-readable version number is + /// recommended. For example "v1.2 alpha" or "v4.2 RC2". If you specify nothing, + /// then there is no product version embedded into the EXE. + /// + /// + public String ProductVersion + { + get; + set; + } + + /// + /// The copyright notice, if any, to embed into the generated EXE. + /// + /// + /// + /// It will show up, for example, while viewing properties of the file in + /// Windows Explorer. You can use any arbitrary string, but typically you + /// want something like "Copyright © Dino Chiesa 2011". + /// + /// + public String Copyright + { + get; + set; + } + + + /// + /// The description to embed into the generated EXE. + /// + /// + /// + /// Use any arbitrary string. This text will be displayed during a + /// mouseover in Windows Explorer. If you specify nothing, then the string + /// "DotNetZip SFX Archive" is embedded into the EXE as the description. + /// + /// + public String Description + { + get; + set; + } + + /// + /// The product name to embed into the generated EXE. + /// + /// + /// + /// Use any arbitrary string. This text will be displayed + /// while viewing properties of the EXE file in + /// Windows Explorer. + /// + /// + public String ProductName + { + get; + set; + } + + /// + /// The title to display in the Window of a GUI SFX, while it extracts. + /// + /// + /// + /// + /// By default the title show in the GUI window of a self-extractor + /// is "DotNetZip Self-extractor (http://DotNetZip.codeplex.com/)". + /// You can change that by setting this property before saving the SFX. + /// + /// + /// + /// This property has an effect only when producing a Self-extractor + /// of flavor SelfExtractorFlavor.WinFormsApplication. + /// + /// + /// + public String SfxExeWindowTitle + { + // workitem 12608 + get; + set; + } + + /// + /// Additional options for the csc.exe compiler, when producing the SFX + /// EXE. + /// + /// + public string AdditionalCompilerSwitches + { + get; set; + } + } + + + + + partial class ZipFile + { + class ExtractorSettings + { + public SelfExtractorFlavor Flavor; + public List ReferencedAssemblies; + public List CopyThroughResources; + public List ResourcesToCompile; + } + + + private static ExtractorSettings[] SettingsList = { + new ExtractorSettings() { + Flavor = SelfExtractorFlavor.WinFormsApplication, + ReferencedAssemblies= new List{ + "System.dll", "System.Windows.Forms.dll", "System.Drawing.dll"}, + CopyThroughResources = new List{ + "Ionic.Zip.WinFormsSelfExtractorStub.resources", + "Ionic.Zip.Forms.PasswordDialog.resources", + "Ionic.Zip.Forms.ZipContentsDialog.resources"}, + ResourcesToCompile = new List{ + "WinFormsSelfExtractorStub.cs", + "WinFormsSelfExtractorStub.Designer.cs", // .Designer.cs? + "PasswordDialog.cs", + "PasswordDialog.Designer.cs", //.Designer.cs" + "ZipContentsDialog.cs", + "ZipContentsDialog.Designer.cs", //.Designer.cs" + "FolderBrowserDialogEx.cs", + } + }, + new ExtractorSettings() { + Flavor = SelfExtractorFlavor.ConsoleApplication, + ReferencedAssemblies= new List { "System.dll", }, + CopyThroughResources = null, + ResourcesToCompile = new List{"CommandLineSelfExtractorStub.cs"} + } + }; + + + + //string _defaultExtractLocation; + //string _postExtractCmdLine; + // string _SetDefaultLocationCode = + // "namespace Ionic.Zip { public partial class WinFormsSelfExtractorStub { partial void _SetDefaultExtractLocation() {" + + // " txtExtractDirectory.Text = \"@@VALUE\"; } }}"; + + + + /// + /// Saves the ZipFile instance to a self-extracting zip archive. + /// + /// + /// + /// + /// + /// The generated exe image will execute on any machine that has the .NET + /// Framework 2.0 installed on it. The generated exe image is also a + /// valid ZIP file, readable with DotNetZip or another Zip library or tool + /// such as WinZip. + /// + /// + /// + /// There are two "flavors" of self-extracting archive. The + /// WinFormsApplication version will pop up a GUI and allow the + /// user to select a target directory into which to extract. There's also + /// a checkbox allowing the user to specify to overwrite existing files, + /// and another checkbox to allow the user to request that Explorer be + /// opened to see the extracted files after extraction. The other flavor + /// is ConsoleApplication. A self-extractor generated with that + /// flavor setting will run from the command line. It accepts command-line + /// options to set the overwrite behavior, and to specify the target + /// extraction directory. + /// + /// + /// + /// There are a few temporary files created during the saving to a + /// self-extracting zip. These files are created in the directory pointed + /// to by , which defaults to . These temporary files are + /// removed upon successful completion of this method. + /// + /// + /// + /// When a user runs the WinForms SFX, the user's personal directory (Environment.SpecialFolder.Personal) + /// will be used as the default extract location. If you want to set the + /// default extract location, you should use the other overload of + /// SaveSelfExtractor()/ The user who runs the SFX will have the + /// opportunity to change the extract directory before extracting. When + /// the user runs the Command-Line SFX, the user must explicitly specify + /// the directory to which to extract. The .NET Framework 2.0 is required + /// on the computer when the self-extracting archive is run. + /// + /// + /// + /// NB: This method is not available in the version of DotNetZip build for + /// the .NET Compact Framework, nor in the "Reduced" DotNetZip library. + /// + /// + /// + /// + /// + /// + /// string DirectoryPath = "c:\\Documents\\Project7"; + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddDirectory(DirectoryPath, System.IO.Path.GetFileName(DirectoryPath)); + /// zip.Comment = "This will be embedded into a self-extracting console-based exe"; + /// zip.SaveSelfExtractor("archive.exe", SelfExtractorFlavor.ConsoleApplication); + /// } + /// + /// + /// Dim DirectoryPath As String = "c:\Documents\Project7" + /// Using zip As New ZipFile() + /// zip.AddDirectory(DirectoryPath, System.IO.Path.GetFileName(DirectoryPath)) + /// zip.Comment = "This will be embedded into a self-extracting console-based exe" + /// zip.SaveSelfExtractor("archive.exe", SelfExtractorFlavor.ConsoleApplication) + /// End Using + /// + /// + /// + /// + /// a pathname, possibly fully qualified, to be created. Typically it + /// will end in an .exe extension. + /// + /// Indicates whether a Winforms or Console self-extractor is + /// desired. + public void SaveSelfExtractor(string exeToGenerate, SelfExtractorFlavor flavor) + { + SelfExtractorSaveOptions options = new SelfExtractorSaveOptions(); + options.Flavor = flavor; + SaveSelfExtractor(exeToGenerate, options); + } + + + + /// + /// Saves the ZipFile instance to a self-extracting zip archive, using + /// the specified save options. + /// + /// + /// + /// + /// This method saves a self extracting archive, using the specified save + /// options. These options include the flavor of the SFX, the default extract + /// directory, the icon file, and so on. See the documentation + /// for for more + /// details. + /// + /// + /// + /// The user who runs the SFX will have the opportunity to change the extract + /// directory before extracting. If at the time of extraction, the specified + /// directory does not exist, the SFX will create the directory before + /// extracting the files. + /// + /// + /// + /// + /// + /// This example saves a WinForms-based self-extracting archive EXE that + /// will use c:\ExtractHere as the default extract location. The C# code + /// shows syntax for .NET 3.0, which uses an object initializer for + /// the SelfExtractorOptions object. + /// + /// string DirectoryPath = "c:\\Documents\\Project7"; + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddDirectory(DirectoryPath, System.IO.Path.GetFileName(DirectoryPath)); + /// zip.Comment = "This will be embedded into a self-extracting WinForms-based exe"; + /// var options = new SelfExtractorOptions + /// { + /// Flavor = SelfExtractorFlavor.WinFormsApplication, + /// DefaultExtractDirectory = "%USERPROFILE%\\ExtractHere", + /// PostExtractCommandLine = ExeToRunAfterExtract, + /// SfxExeWindowTitle = "My Custom Window Title", + /// RemoveUnpackedFilesAfterExecute = true + /// }; + /// zip.SaveSelfExtractor("archive.exe", options); + /// } + /// + /// + /// Dim DirectoryPath As String = "c:\Documents\Project7" + /// Using zip As New ZipFile() + /// zip.AddDirectory(DirectoryPath, System.IO.Path.GetFileName(DirectoryPath)) + /// zip.Comment = "This will be embedded into a self-extracting console-based exe" + /// Dim options As New SelfExtractorOptions() + /// options.Flavor = SelfExtractorFlavor.WinFormsApplication + /// options.DefaultExtractDirectory = "%USERPROFILE%\\ExtractHere" + /// options.PostExtractCommandLine = ExeToRunAfterExtract + /// options.SfxExeWindowTitle = "My Custom Window Title" + /// options.RemoveUnpackedFilesAfterExecute = True + /// zip.SaveSelfExtractor("archive.exe", options) + /// End Using + /// + /// + /// + /// The name of the EXE to generate. + /// provides the options for creating the + /// Self-extracting archive. + public void SaveSelfExtractor(string exeToGenerate, SelfExtractorSaveOptions options) + { + // Save an SFX that is both an EXE and a ZIP. + + // Check for the case where we are re-saving a zip archive + // that was originally instantiated with a stream. In that case, + // the _name will be null. If so, we set _writestream to null, + // which insures that we'll cons up a new WriteStream (with a filesystem + // file backing it) in the Save() method. + if (_name == null) + _writestream = null; + + _SavingSfx = true; + _name = exeToGenerate; + if (Directory.Exists(_name)) + throw new ZipException("Bad Directory", new System.ArgumentException("That name specifies an existing directory. Please specify a filename.", "exeToGenerate")); + _contentsChanged = true; + _fileAlreadyExists = File.Exists(_name); + + _SaveSfxStub(exeToGenerate, options); + + Save(); + _SavingSfx = false; + } + + + + + private static void ExtractResourceToFile(Assembly a, string resourceName, string filename) + { + int n = 0; + byte[] bytes = new byte[1024]; + using (Stream instream = a.GetManifestResourceStream(resourceName)) + { + if (instream == null) + throw new ZipException(String.Format("missing resource '{0}'", resourceName)); + + using (FileStream outstream = File.OpenWrite(filename)) + { + do + { + n = instream.Read(bytes, 0, bytes.Length); + outstream.Write(bytes, 0, n); + } while (n > 0); + } + } + } + + + private void _SaveSfxStub(string exeToGenerate, SelfExtractorSaveOptions options) + { + string nameOfIconFile = null; + string stubExe = null; + string unpackedResourceDir = null; + string tmpDir = null; + try + { + if (File.Exists(exeToGenerate)) + { + if (Verbose) StatusMessageTextWriter.WriteLine("The existing file ({0}) will be overwritten.", exeToGenerate); + } + if (!exeToGenerate.EndsWith(".exe")) + { + if (Verbose) StatusMessageTextWriter.WriteLine("Warning: The generated self-extracting file will not have an .exe extension."); + } + + // workitem 10553 + tmpDir = TempFileFolder ?? Path.GetDirectoryName(exeToGenerate); + stubExe = GenerateTempPathname(tmpDir, "exe"); + + // get the Ionic.Zip assembly + Assembly a1 = typeof(ZipFile).Assembly; + + using (var csharp = new Microsoft.CSharp.CSharpCodeProvider()) + { + // The following is a perfect opportunity for a linq query, but + // I cannot use it. The generated SFX needs to run on .NET 2.0, + // and using LINQ would break that. Here's what it would look + // like: + // + // var settings = (from x in SettingsList + // where x.Flavor == flavor + // select x).First(); + + ExtractorSettings settings = null; + foreach (var x in SettingsList) + { + if (x.Flavor == options.Flavor) + { + settings = x; + break; + } + } + + // sanity check; should never happen + if (settings == null) + throw new BadStateException(String.Format("While saving a Self-Extracting Zip, Cannot find that flavor ({0})?", options.Flavor)); + + // This is the list of referenced assemblies. Ionic.Zip is + // needed here. Also if it is the winforms (gui) extractor, we + // need other referenced assemblies, like + // System.Windows.Forms.dll, etc. + var cp = new System.CodeDom.Compiler.CompilerParameters(); + cp.ReferencedAssemblies.Add(a1.Location); + if (settings.ReferencedAssemblies != null) + foreach (string ra in settings.ReferencedAssemblies) + cp.ReferencedAssemblies.Add(ra); + + cp.GenerateInMemory = false; + cp.GenerateExecutable = true; + cp.IncludeDebugInformation = false; + cp.CompilerOptions = ""; + + Assembly a2 = Assembly.GetExecutingAssembly(); + + // Use this to concatenate all the source code resources into a + // single module. + var sb = new System.Text.StringBuilder(); + + // In case there are compiler errors later, we allocate a source + // file name now. If errors are detected, we'll spool the source + // code as well as the errors (in comments) into that filename, + // and throw an exception with the filename. Makes it easier to + // diagnose. This should be rare; most errors happen only + // during devlpmt of DotNetZip itself, but there are rare + // occasions when they occur in other cases. + string sourceFile = GenerateTempPathname(tmpDir, "cs"); + + + // // debugging: enumerate the resources in this assembly + // Console.WriteLine("Resources in this assembly:"); + // foreach (string rsrc in a2.GetManifestResourceNames()) + // { + // Console.WriteLine(rsrc); + // } + // Console.WriteLine(); + + + // all the source code is embedded in the DLL as a zip file. + using (ZipFile zip = ZipFile.Read(a2.GetManifestResourceStream("Ionic.Zip.Resources.ZippedResources.zip"))) + { + // // debugging: enumerate the files in the embedded zip + // Console.WriteLine("Entries in the embbedded zip:"); + // foreach (ZipEntry entry in zip) + // { + // Console.WriteLine(entry.FileName); + // } + // Console.WriteLine(); + + unpackedResourceDir = GenerateTempPathname(tmpDir, "tmp"); + + if (String.IsNullOrEmpty(options.IconFile)) + { + // Use the ico file that is embedded into the Ionic.Zip + // DLL itself. To do this we must unpack the icon to + // the filesystem, in order to specify it on the cmdline + // of csc.exe. This method will remove the unpacked + // file later. + System.IO.Directory.CreateDirectory(unpackedResourceDir); + ZipEntry e = zip["zippedFile.ico"]; + // Must not extract a readonly file - it will be impossible to + // delete later. + if ((e.Attributes & FileAttributes.ReadOnly) == FileAttributes.ReadOnly) + e.Attributes ^= FileAttributes.ReadOnly; + e.Extract(unpackedResourceDir); + nameOfIconFile = Path.Combine(unpackedResourceDir, "zippedFile.ico"); + cp.CompilerOptions += String.Format("/win32icon:\"{0}\"", nameOfIconFile); + } + else + cp.CompilerOptions += String.Format("/win32icon:\"{0}\"", options.IconFile); + + cp.OutputAssembly = stubExe; + + if (options.Flavor == SelfExtractorFlavor.WinFormsApplication) + cp.CompilerOptions += " /target:winexe"; + + if (!String.IsNullOrEmpty(options.AdditionalCompilerSwitches)) + cp.CompilerOptions += " " + options.AdditionalCompilerSwitches; + + if (String.IsNullOrEmpty(cp.CompilerOptions)) + cp.CompilerOptions = null; + + if ((settings.CopyThroughResources != null) && (settings.CopyThroughResources.Count != 0)) + { + if (!Directory.Exists(unpackedResourceDir)) System.IO.Directory.CreateDirectory(unpackedResourceDir); + foreach (string re in settings.CopyThroughResources) + { + string filename = Path.Combine(unpackedResourceDir, re); + + ExtractResourceToFile(a2, re, filename); + // add the file into the target assembly as an embedded resource + cp.EmbeddedResources.Add(filename); + } + } + + // add the Ionic.Utils.Zip DLL as an embedded resource + cp.EmbeddedResources.Add(a1.Location); + + // file header + sb.Append("// " + Path.GetFileName(sourceFile) + "\n") + .Append("// --------------------------------------------\n//\n") + .Append("// This SFX source file was generated by DotNetZip ") + .Append(ZipFile.LibraryVersion.ToString()) + .Append("\n// at ") + .Append(System.DateTime.Now.ToString("yyyy MMMM dd HH:mm:ss")) + .Append("\n//\n// --------------------------------------------\n\n\n"); + + // assembly attributes + if (!String.IsNullOrEmpty(options.Description)) + sb.Append("[assembly: System.Reflection.AssemblyTitle(\"" + + options.Description.Replace("\"", "") + + "\")]\n"); + else + sb.Append("[assembly: System.Reflection.AssemblyTitle(\"DotNetZip SFX Archive\")]\n"); + + if (!String.IsNullOrEmpty(options.ProductVersion)) + sb.Append("[assembly: System.Reflection.AssemblyInformationalVersion(\"" + + options.ProductVersion.Replace("\"", "") + + "\")]\n"); + + // workitem + string copyright = + (String.IsNullOrEmpty(options.Copyright)) + ? "Extractor: Copyright © Dino Chiesa 2008-2011" + : options.Copyright.Replace("\"", ""); + + if (!String.IsNullOrEmpty(options.ProductName)) + sb.Append("[assembly: System.Reflection.AssemblyProduct(\"") + .Append(options.ProductName.Replace("\"", "")) + .Append("\")]\n"); + else + sb.Append("[assembly: System.Reflection.AssemblyProduct(\"DotNetZip\")]\n"); + + + sb.Append("[assembly: System.Reflection.AssemblyCopyright(\"" + copyright + "\")]\n") + .Append(String.Format("[assembly: System.Reflection.AssemblyVersion(\"{0}\")]\n", ZipFile.LibraryVersion.ToString())); + if (options.FileVersion != null) + sb.Append(String.Format("[assembly: System.Reflection.AssemblyFileVersion(\"{0}\")]\n", + options.FileVersion.ToString())); + + sb.Append("\n\n\n"); + + // Set the default extract location if it is available + string extractLoc = options.DefaultExtractDirectory; + if (extractLoc != null) + { + // remove double-quotes and replace slash with double-slash. + // This, because the value is going to be embedded into a + // cs file as a quoted string, and it needs to be escaped. + extractLoc = extractLoc.Replace("\"", "").Replace("\\", "\\\\"); + } + + string postExCmdLine = options.PostExtractCommandLine; + if (postExCmdLine != null) + { + postExCmdLine = postExCmdLine.Replace("\\", "\\\\"); + postExCmdLine = postExCmdLine.Replace("\"", "\\\""); + } + + + foreach (string rc in settings.ResourcesToCompile) + { + using (Stream s = zip[rc].OpenReader()) + { + if (s == null) + throw new ZipException(String.Format("missing resource '{0}'", rc)); + using (StreamReader sr = new StreamReader(s)) + { + while (sr.Peek() >= 0) + { + string line = sr.ReadLine(); + if (extractLoc != null) + line = line.Replace("@@EXTRACTLOCATION", extractLoc); + + line = line.Replace("@@REMOVE_AFTER_EXECUTE", options.RemoveUnpackedFilesAfterExecute.ToString()); + line = line.Replace("@@QUIET", options.Quiet.ToString()); + if (!String.IsNullOrEmpty(options.SfxExeWindowTitle)) + + line = line.Replace("@@SFX_EXE_WINDOW_TITLE", options.SfxExeWindowTitle); + + line = line.Replace("@@EXTRACT_EXISTING_FILE", ((int)options.ExtractExistingFile).ToString()); + + if (postExCmdLine != null) + line = line.Replace("@@POST_UNPACK_CMD_LINE", postExCmdLine); + + sb.Append(line).Append("\n"); + } + } + sb.Append("\n\n"); + } + } + } + + string LiteralSource = sb.ToString(); + +#if DEBUGSFX + // for debugging only + string sourceModule = GenerateTempPathname(tmpDir, "cs"); + using (StreamWriter sw = File.CreateText(sourceModule)) + { + sw.Write(LiteralSource); + } + Console.WriteLine("source: {0}", sourceModule); +#endif + + var cr = csharp.CompileAssemblyFromSource(cp, LiteralSource); + + + if (cr == null) + throw new SfxGenerationException("Cannot compile the extraction logic!"); + + if (Verbose) + foreach (string output in cr.Output) + StatusMessageTextWriter.WriteLine(output); + + if (cr.Errors.Count != 0) + { + using (TextWriter tw = new StreamWriter(sourceFile)) + { + // first, the source we compiled + tw.Write(LiteralSource); + + // now, append the compile errors + tw.Write("\n\n\n// ------------------------------------------------------------------\n"); + tw.Write("// Errors during compilation: \n//\n"); + string p = Path.GetFileName(sourceFile); + + foreach (System.CodeDom.Compiler.CompilerError error in cr.Errors) + { + tw.Write(String.Format("// {0}({1},{2}): {3} {4}: {5}\n//\n", + p, // 0 + error.Line, // 1 + error.Column, // 2 + error.IsWarning ? "Warning" : "error", // 3 + error.ErrorNumber, // 4 + error.ErrorText)); // 5 + } + } + throw new SfxGenerationException(String.Format("Errors compiling the extraction logic! {0}", sourceFile)); + } + + OnSaveEvent(ZipProgressEventType.Saving_AfterCompileSelfExtractor); + + // Now, copy the resulting EXE image to the _writestream. + // Because this stub exe is being saved first, the effect will be to + // concatenate the exe and the zip data together. + using (System.IO.Stream input = System.IO.File.OpenRead(stubExe)) + { + byte[] buffer = new byte[4000]; + int n = 1; + while (n != 0) + { + n = input.Read(buffer, 0, buffer.Length); + if (n != 0) + WriteStream.Write(buffer, 0, n); + } + } + } + + OnSaveEvent(ZipProgressEventType.Saving_AfterSaveTempArchive); + } + finally + { + try + { + if (Directory.Exists(unpackedResourceDir)) + { + try { Directory.Delete(unpackedResourceDir, true); } + catch (System.IO.IOException exc1) + { + StatusMessageTextWriter.WriteLine("Warning: Exception: {0}", exc1); + } + } + if (File.Exists(stubExe)) + { + try { File.Delete(stubExe); } + catch (System.IO.IOException exc1) + { + StatusMessageTextWriter.WriteLine("Warning: Exception: {0}", exc1); + } + } + } + catch (System.IO.IOException) { } + } + + return; + + } + + + + internal static string GenerateTempPathname(string dir, string extension) + { + string candidate = null; + String AppName = System.Reflection.Assembly.GetExecutingAssembly().GetName().Name; + do + { + // workitem 13475 + string uuid = System.Guid.NewGuid().ToString(); + + string Name = String.Format("{0}-{1}-{2}.{3}", + AppName, System.DateTime.Now.ToString("yyyyMMMdd-HHmmss"), + uuid, extension); + candidate = System.IO.Path.Combine(dir, Name); + } while (System.IO.File.Exists(candidate) || System.IO.Directory.Exists(candidate)); + + // The candidate path does not exist as a file or directory. + // It can now be created, as a file or directory. + return candidate; + } + + } +#endif +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Selector.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Selector.cs new file mode 100644 index 00000000..47339f3e --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.Selector.cs @@ -0,0 +1,1464 @@ +// ZipFile.Selector.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2010 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-06 09:35:58> +// +// ------------------------------------------------------------------ +// +// This module defines methods in the ZipFile class associated to the FileFilter +// capability - selecting files to add into the archive, or selecting entries to +// retrieve from the archive based on criteria including the filename, size, date, or +// attributes. It is something like a "poor man's LINQ". I included it into DotNetZip +// because not everyone has .NET 3.5 yet. When using DotNetZip on .NET 3.5, the LINQ +// query/selection will be superior. +// +// These methods are segregated into a different module to facilitate easy exclusion for +// those people who wish to have a smaller library without this function. +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; +using System.Collections.Generic; + +namespace Ionic.Zip +{ + + partial class ZipFile + { + /// + /// Adds to the ZipFile a set of files from the current working directory on + /// disk, that conform to the specified criteria. + /// + /// + /// + /// + /// This method selects files from the the current working directory matching + /// the specified criteria, and adds them to the ZipFile. + /// + /// + /// + /// Specify the criteria in statements of 3 elements: a noun, an operator, and + /// a value. Consider the string "name != *.doc" . The noun is "name". The + /// operator is "!=", implying "Not Equal". The value is "*.doc". That + /// criterion, in English, says "all files with a name that does not end in + /// the .doc extension." + /// + /// + /// + /// Supported nouns include "name" (or "filename") for the filename; "atime", + /// "mtime", and "ctime" for last access time, last modfied time, and created + /// time of the file, respectively; "attributes" (or "attrs") for the file + /// attributes; "size" (or "length") for the file length (uncompressed), and + /// "type" for the type of object, either a file or a directory. The + /// "attributes", "name" and "type" nouns both support = and != as operators. + /// The "size", "atime", "mtime", and "ctime" nouns support = and !=, and + /// >, >=, <, <= as well. The times are taken to be expressed in + /// local time. + /// + /// + /// + /// Specify values for the file attributes as a string with one or more of the + /// characters H,R,S,A,I,L in any order, implying file attributes of Hidden, + /// ReadOnly, System, Archive, NotContextIndexed, and ReparsePoint (symbolic + /// link) respectively. + /// + /// + /// + /// To specify a time, use YYYY-MM-DD-HH:mm:ss or YYYY/MM/DD-HH:mm:ss as the + /// format. If you omit the HH:mm:ss portion, it is assumed to be 00:00:00 + /// (midnight). + /// + /// + /// + /// The value for a size criterion is expressed in integer quantities of bytes, + /// kilobytes (use k or kb after the number), megabytes (m or mb), or gigabytes + /// (g or gb). + /// + /// + /// + /// The value for a name is a pattern to match against the filename, potentially + /// including wildcards. The pattern follows CMD.exe glob rules: * implies one + /// or more of any character, while ? implies one character. If the name + /// pattern contains any slashes, it is matched to the entire filename, + /// including the path; otherwise, it is matched against only the filename + /// without the path. This means a pattern of "*\*.*" matches all files one + /// directory level deep, while a pattern of "*.*" matches all files in all + /// directories. + /// + /// + /// + /// To specify a name pattern that includes spaces, use single quotes around the + /// pattern. A pattern of "'* *.*'" will match all files that have spaces in + /// the filename. The full criteria string for that would be "name = '* *.*'" . + /// + /// + /// + /// The value for a type criterion is either F (implying a file) or D (implying + /// a directory). + /// + /// + /// + /// Some examples: + /// + /// + /// + /// + /// criteria + /// Files retrieved + /// + /// + /// + /// name != *.xls + /// any file with an extension that is not .xls + /// + /// + /// + /// + /// name = *.mp3 + /// any file with a .mp3 extension. + /// + /// + /// + /// + /// *.mp3 + /// (same as above) any file with a .mp3 extension. + /// + /// + /// + /// + /// attributes = A + /// all files whose attributes include the Archive bit. + /// + /// + /// + /// + /// attributes != H + /// all files whose attributes do not include the Hidden bit. + /// + /// + /// + /// + /// mtime > 2009-01-01 + /// all files with a last modified time after January 1st, 2009. + /// + /// + /// + /// + /// size > 2gb + /// all files whose uncompressed size is greater than 2gb. + /// + /// + /// + /// + /// type = D + /// all directories in the filesystem. + /// + /// + /// + /// + /// + /// You can combine criteria with the conjunctions AND or OR. Using a string + /// like "name = *.txt AND size >= 100k" for the selectionCriteria retrieves + /// entries whose names end in .txt, and whose uncompressed size is greater than + /// or equal to 100 kilobytes. + /// + /// + /// + /// For more complex combinations of criteria, you can use parenthesis to group + /// clauses in the boolean logic. Without parenthesis, the precedence of the + /// criterion atoms is determined by order of appearance. Unlike the C# + /// language, the AND conjunction does not take precendence over the logical OR. + /// This is important only in strings that contain 3 or more criterion atoms. + /// In other words, "name = *.txt and size > 1000 or attributes = H" implies + /// "((name = *.txt AND size > 1000) OR attributes = H)" while "attributes = + /// H OR name = *.txt and size > 1000" evaluates to "((attributes = H OR name + /// = *.txt) AND size > 1000)". When in doubt, use parenthesis. + /// + /// + /// + /// Using time properties requires some extra care. If you want to retrieve all + /// entries that were last updated on 2009 February 14, specify a time range + /// like so:"mtime >= 2009-02-14 AND mtime < 2009-02-15". Read this to + /// say: all files updated after 12:00am on February 14th, until 12:00am on + /// February 15th. You can use the same bracketing approach to specify any time + /// period - a year, a month, a week, and so on. + /// + /// + /// + /// The syntax allows one special case: if you provide a string with no spaces, it is + /// treated as a pattern to match for the filename. Therefore a string like "*.xls" + /// will be equivalent to specifying "name = *.xls". + /// + /// + /// + /// There is no logic in this method that insures that the file inclusion + /// criteria are internally consistent. For example, it's possible to specify + /// criteria that says the file must have a size of less than 100 bytes, as well + /// as a size that is greater than 1000 bytes. Obviously no file will ever + /// satisfy such criteria, but this method does not detect such logical + /// inconsistencies. The caller is responsible for insuring the criteria are + /// sensible. + /// + /// + /// + /// Using this method, the file selection does not recurse into + /// subdirectories, and the full path of the selected files is included in the + /// entries added into the zip archive. If you don't like these behaviors, + /// see the other overloads of this method. + /// + /// + /// + /// + /// This example zips up all *.csv files in the current working directory. + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// // To just match on filename wildcards, + /// // use the shorthand form of the selectionCriteria string. + /// zip.AddSelectedFiles("*.csv"); + /// zip.Save(PathToZipArchive); + /// } + /// + /// + /// Using zip As ZipFile = New ZipFile() + /// zip.AddSelectedFiles("*.csv") + /// zip.Save(PathToZipArchive) + /// End Using + /// + /// + /// + /// The criteria for file selection + public void AddSelectedFiles(String selectionCriteria) + { + this.AddSelectedFiles(selectionCriteria, ".", null, false); + } + + /// + /// Adds to the ZipFile a set of files from the disk that conform to the + /// specified criteria, optionally recursing into subdirectories. + /// + /// + /// + /// + /// This method selects files from the the current working directory matching + /// the specified criteria, and adds them to the ZipFile. If + /// recurseDirectories is true, files are also selected from + /// subdirectories, and the directory structure in the filesystem is + /// reproduced in the zip archive, rooted at the current working directory. + /// + /// + /// + /// Using this method, the full path of the selected files is included in the + /// entries added into the zip archive. If you don't want this behavior, use + /// one of the overloads of this method that allows the specification of a + /// directoryInArchive. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// + /// + /// + /// This example zips up all *.xml files in the current working directory, or any + /// subdirectory, that are larger than 1mb. + /// + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.xml and size > 1024kb", true); + /// zip.Save(PathToZipArchive); + /// } + /// + /// + /// Using zip As ZipFile = New ZipFile() + /// ' Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.xml and size > 1024kb", true) + /// zip.Save(PathToZipArchive) + /// End Using + /// + /// + /// + /// The criteria for file selection + /// + /// + /// If true, the file selection will recurse into subdirectories. + /// + public void AddSelectedFiles(String selectionCriteria, bool recurseDirectories) + { + this.AddSelectedFiles(selectionCriteria, ".", null, recurseDirectories); + } + + /// + /// Adds to the ZipFile a set of files from a specified directory in the + /// filesystem, that conform to the specified criteria. + /// + /// + /// + /// + /// This method selects files that conform to the specified criteria, from the + /// the specified directory on disk, and adds them to the ZipFile. The search + /// does not recurse into subdirectores. + /// + /// + /// + /// Using this method, the full filesystem path of the files on disk is + /// reproduced on the entries added to the zip file. If you don't want this + /// behavior, use one of the other overloads of this method. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// + /// + /// + /// This example zips up all *.xml files larger than 1mb in the directory + /// given by "d:\rawdata". + /// + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.xml and size > 1024kb", "d:\\rawdata"); + /// zip.Save(PathToZipArchive); + /// } + /// + /// + /// + /// Using zip As ZipFile = New ZipFile() + /// ' Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.xml and size > 1024kb", "d:\rawdata) + /// zip.Save(PathToZipArchive) + /// End Using + /// + /// + /// + /// The criteria for file selection + /// + /// + /// The name of the directory on the disk from which to select files. + /// + public void AddSelectedFiles(String selectionCriteria, String directoryOnDisk) + { + this.AddSelectedFiles(selectionCriteria, directoryOnDisk, null, false); + } + + + /// + /// Adds to the ZipFile a set of files from the specified directory on disk, + /// that conform to the specified criteria. + /// + /// + /// + /// + /// + /// This method selects files from the the specified disk directory matching + /// the specified selection criteria, and adds them to the ZipFile. If + /// recurseDirectories is true, files are also selected from + /// subdirectories. + /// + /// + /// + /// The full directory structure in the filesystem is reproduced on the + /// entries added to the zip archive. If you don't want this behavior, use + /// one of the overloads of this method that allows the specification of a + /// directoryInArchive. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// + /// + /// This example zips up all *.csv files in the "files" directory, or any + /// subdirectory, that have been saved since 2009 February 14th. + /// + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.csv and mtime > 2009-02-14", "files", true); + /// zip.Save(PathToZipArchive); + /// } + /// + /// + /// Using zip As ZipFile = New ZipFile() + /// ' Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.csv and mtime > 2009-02-14", "files", true) + /// zip.Save(PathToZipArchive) + /// End Using + /// + /// + /// + /// + /// This example zips up all files in the current working + /// directory, and all its child directories, except those in + /// the excludethis subdirectory. + /// + /// Using Zip As ZipFile = New ZipFile(zipfile) + /// Zip.AddSelectedFfiles("name != 'excludethis\*.*'", datapath, True) + /// Zip.Save() + /// End Using + /// + /// + /// + /// The criteria for file selection + /// + /// + /// The filesystem path from which to select files. + /// + /// + /// + /// If true, the file selection will recurse into subdirectories. + /// + public void AddSelectedFiles(String selectionCriteria, String directoryOnDisk, bool recurseDirectories) + { + this.AddSelectedFiles(selectionCriteria, directoryOnDisk, null, recurseDirectories); + } + + + /// + /// Adds to the ZipFile a selection of files from the specified directory on + /// disk, that conform to the specified criteria, and using a specified root + /// path for entries added to the zip archive. + /// + /// + /// + /// + /// This method selects files from the specified disk directory matching the + /// specified selection criteria, and adds those files to the ZipFile, using + /// the specified directory path in the archive. The search does not recurse + /// into subdirectories. For details on the syntax for the selectionCriteria + /// parameter, see . + /// + /// + /// + /// + /// + /// + /// This example zips up all *.psd files in the "photos" directory that have + /// been saved since 2009 February 14th, and puts them all in a zip file, + /// using the directory name of "content" in the zip archive itself. When the + /// zip archive is unzipped, the folder containing the .psd files will be + /// named "content". + /// + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Use a compound expression in the selectionCriteria string. + /// zip.AddSelectedFiles("name = *.psd and mtime > 2009-02-14", "photos", "content"); + /// zip.Save(PathToZipArchive); + /// } + /// + /// + /// Using zip As ZipFile = New ZipFile + /// zip.AddSelectedFiles("name = *.psd and mtime > 2009-02-14", "photos", "content") + /// zip.Save(PathToZipArchive) + /// End Using + /// + /// + /// + /// + /// The criteria for selection of files to add to the ZipFile. + /// + /// + /// + /// The path to the directory in the filesystem from which to select files. + /// + /// + /// + /// Specifies a directory path to use to in place of the + /// directoryOnDisk. This path may, or may not, correspond to a real + /// directory in the current filesystem. If the files within the zip are + /// later extracted, this is the path used for the extracted file. Passing + /// null (nothing in VB) will use the path on the file name, if any; in other + /// words it would use directoryOnDisk, plus any subdirectory. Passing + /// the empty string ("") will insert the item at the root path within the + /// archive. + /// + public void AddSelectedFiles(String selectionCriteria, + String directoryOnDisk, + String directoryPathInArchive) + { + this.AddSelectedFiles(selectionCriteria, directoryOnDisk, directoryPathInArchive, false); + } + + /// + /// Adds to the ZipFile a selection of files from the specified directory on + /// disk, that conform to the specified criteria, optionally recursing through + /// subdirectories, and using a specified root path for entries added to the + /// zip archive. + /// + /// + /// + /// This method selects files from the specified disk directory that match the + /// specified selection criteria, and adds those files to the ZipFile, using + /// the specified directory path in the archive. If recurseDirectories + /// is true, files are also selected from subdirectories, and the directory + /// structure in the filesystem is reproduced in the zip archive, rooted at + /// the directory specified by directoryOnDisk. For details on the + /// syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// + /// This example zips up all files that are NOT *.pst files, in the current + /// working directory and any subdirectories. + /// + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddSelectedFiles("name != *.pst", SourceDirectory, "backup", true); + /// zip.Save(PathToZipArchive); + /// } + /// + /// + /// Using zip As ZipFile = New ZipFile + /// zip.AddSelectedFiles("name != *.pst", SourceDirectory, "backup", true) + /// zip.Save(PathToZipArchive) + /// End Using + /// + /// + /// + /// + /// The criteria for selection of files to add to the ZipFile. + /// + /// + /// + /// The path to the directory in the filesystem from which to select files. + /// + /// + /// + /// Specifies a directory path to use to in place of the + /// directoryOnDisk. This path may, or may not, correspond to a real + /// directory in the current filesystem. If the files within the zip are + /// later extracted, this is the path used for the extracted file. Passing + /// null (nothing in VB) will use the path on the file name, if any; in other + /// words it would use directoryOnDisk, plus any subdirectory. Passing + /// the empty string ("") will insert the item at the root path within the + /// archive. + /// + /// + /// + /// If true, the method also scans subdirectories for files matching the + /// criteria. + /// + public void AddSelectedFiles(String selectionCriteria, + String directoryOnDisk, + String directoryPathInArchive, + bool recurseDirectories) + { + _AddOrUpdateSelectedFiles(selectionCriteria, + directoryOnDisk, + directoryPathInArchive, + recurseDirectories, + false); + } + + /// + /// Updates the ZipFile with a selection of files from the disk that conform + /// to the specified criteria. + /// + /// + /// + /// This method selects files from the specified disk directory that match the + /// specified selection criteria, and Updates the ZipFile with those + /// files, using the specified directory path in the archive. If + /// recurseDirectories is true, files are also selected from + /// subdirectories, and the directory structure in the filesystem is + /// reproduced in the zip archive, rooted at the directory specified by + /// directoryOnDisk. For details on the syntax for the + /// selectionCriteria parameter, see . + /// + /// + /// + /// The criteria for selection of files to add to the ZipFile. + /// + /// + /// + /// The path to the directory in the filesystem from which to select files. + /// + /// + /// + /// Specifies a directory path to use to in place of the + /// directoryOnDisk. This path may, or may not, correspond to a + /// real directory in the current filesystem. If the files within the zip + /// are later extracted, this is the path used for the extracted file. + /// Passing null (nothing in VB) will use the path on the file name, if + /// any; in other words it would use directoryOnDisk, plus any + /// subdirectory. Passing the empty string ("") will insert the item at + /// the root path within the archive. + /// + /// + /// + /// If true, the method also scans subdirectories for files matching the criteria. + /// + /// + /// + public void UpdateSelectedFiles(String selectionCriteria, + String directoryOnDisk, + String directoryPathInArchive, + bool recurseDirectories) + { + _AddOrUpdateSelectedFiles(selectionCriteria, + directoryOnDisk, + directoryPathInArchive, + recurseDirectories, + true); + } + + + private string EnsureendInSlash(string s) + { + if (s.EndsWith("\\")) return s; + return s + "\\"; + } + + private void _AddOrUpdateSelectedFiles(String selectionCriteria, + String directoryOnDisk, + String directoryPathInArchive, + bool recurseDirectories, + bool wantUpdate) + { + if (directoryOnDisk == null && (Directory.Exists(selectionCriteria))) + { + directoryOnDisk = selectionCriteria; + selectionCriteria = "*.*"; + } + else if (String.IsNullOrEmpty(directoryOnDisk)) + { + directoryOnDisk = "."; + } + + // workitem 9176 + while (directoryOnDisk.EndsWith("\\")) directoryOnDisk = directoryOnDisk.Substring(0, directoryOnDisk.Length - 1); + if (Verbose) StatusMessageTextWriter.WriteLine("adding selection '{0}' from dir '{1}'...", + selectionCriteria, directoryOnDisk); + Ionic.FileSelector ff = new Ionic.FileSelector(selectionCriteria, + AddDirectoryWillTraverseReparsePoints); + var itemsToAdd = ff.SelectFiles(directoryOnDisk, recurseDirectories); + + if (Verbose) StatusMessageTextWriter.WriteLine("found {0} files...", itemsToAdd.Count); + + OnAddStarted(); + + AddOrUpdateAction action = (wantUpdate) ? AddOrUpdateAction.AddOrUpdate : AddOrUpdateAction.AddOnly; + foreach (var item in itemsToAdd) + { + // workitem 10153 + string dirInArchive = (directoryPathInArchive == null) + ? null + // workitem 12260 + : ReplaceLeadingDirectory(Path.GetDirectoryName(item), + directoryOnDisk, + directoryPathInArchive); + + if (File.Exists(item)) + { + if (wantUpdate) + this.UpdateFile(item, dirInArchive); + else + this.AddFile(item, dirInArchive); + } + else + { + // this adds "just" the directory, without recursing to the contained files + AddOrUpdateDirectoryImpl(item, dirInArchive, action, false, 0); + } + } + + OnAddCompleted(); + } + + + // workitem 12260 + private static string ReplaceLeadingDirectory(string original, + string pattern, + string replacement) + { + string upperString = original.ToUpper(); + string upperPattern = pattern.ToUpper(); + int p1 = upperString.IndexOf(upperPattern); + if (p1 != 0) return original; + return replacement + original.Substring(upperPattern.Length); + } + +#if NOT + private static string ReplaceEx(string original, + string pattern, + string replacement) + { + int count, position0, position1; + count = position0 = position1 = 0; + string upperString = original.ToUpper(); + string upperPattern = pattern.ToUpper(); + int inc = (original.Length/pattern.Length) * + (replacement.Length-pattern.Length); + char [] chars = new char[original.Length + Math.Max(0, inc)]; + while( (position1 = upperString.IndexOf(upperPattern, + position0)) != -1 ) + { + for ( int i=position0 ; i < position1 ; ++i ) + chars[count++] = original[i]; + for ( int i=0 ; i < replacement.Length ; ++i ) + chars[count++] = replacement[i]; + position0 = position1+pattern.Length; + } + if ( position0 == 0 ) return original; + for ( int i=position0 ; i < original.Length ; ++i ) + chars[count++] = original[i]; + return new string(chars, 0, count); + } +#endif + + /// + /// Retrieve entries from the zipfile by specified criteria. + /// + /// + /// + /// + /// This method allows callers to retrieve the collection of entries from the zipfile + /// that fit the specified criteria. The criteria are described in a string format, and + /// can include patterns for the filename; constraints on the size of the entry; + /// constraints on the last modified, created, or last accessed time for the file + /// described by the entry; or the attributes of the entry. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// This method is intended for use with a ZipFile that has been read from storage. + /// When creating a new ZipFile, this method will work only after the ZipArchive has + /// been Saved to the disk (the ZipFile class subsequently and implicitly reads the Zip + /// archive from storage.) Calling SelectEntries on a ZipFile that has not yet been + /// saved will deliver undefined results. + /// + /// + /// + /// + /// Thrown if selectionCriteria has an invalid syntax. + /// + /// + /// + /// This example selects all the PhotoShop files from within an archive, and extracts them + /// to the current working directory. + /// + /// using (ZipFile zip1 = ZipFile.Read(ZipFileName)) + /// { + /// var PhotoShopFiles = zip1.SelectEntries("*.psd"); + /// foreach (ZipEntry psd in PhotoShopFiles) + /// { + /// psd.Extract(); + /// } + /// } + /// + /// + /// Using zip1 As ZipFile = ZipFile.Read(ZipFileName) + /// Dim PhotoShopFiles as ICollection(Of ZipEntry) + /// PhotoShopFiles = zip1.SelectEntries("*.psd") + /// Dim psd As ZipEntry + /// For Each psd In PhotoShopFiles + /// psd.Extract + /// Next + /// End Using + /// + /// + /// the string that specifies which entries to select + /// a collection of ZipEntry objects that conform to the inclusion spec + public ICollection SelectEntries(String selectionCriteria) + { + Ionic.FileSelector ff = new Ionic.FileSelector(selectionCriteria, + AddDirectoryWillTraverseReparsePoints); + return ff.SelectEntries(this); + } + + + /// + /// Retrieve entries from the zipfile by specified criteria. + /// + /// + /// + /// + /// This method allows callers to retrieve the collection of entries from the zipfile + /// that fit the specified criteria. The criteria are described in a string format, and + /// can include patterns for the filename; constraints on the size of the entry; + /// constraints on the last modified, created, or last accessed time for the file + /// described by the entry; or the attributes of the entry. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// This method is intended for use with a ZipFile that has been read from storage. + /// When creating a new ZipFile, this method will work only after the ZipArchive has + /// been Saved to the disk (the ZipFile class subsequently and implicitly reads the Zip + /// archive from storage.) Calling SelectEntries on a ZipFile that has not yet been + /// saved will deliver undefined results. + /// + /// + /// + /// + /// Thrown if selectionCriteria has an invalid syntax. + /// + /// + /// + /// + /// using (ZipFile zip1 = ZipFile.Read(ZipFileName)) + /// { + /// var UpdatedPhotoShopFiles = zip1.SelectEntries("*.psd", "UpdatedFiles"); + /// foreach (ZipEntry e in UpdatedPhotoShopFiles) + /// { + /// // prompt for extract here + /// if (WantExtract(e.FileName)) + /// e.Extract(); + /// } + /// } + /// + /// + /// Using zip1 As ZipFile = ZipFile.Read(ZipFileName) + /// Dim UpdatedPhotoShopFiles As ICollection(Of ZipEntry) = zip1.SelectEntries("*.psd", "UpdatedFiles") + /// Dim e As ZipEntry + /// For Each e In UpdatedPhotoShopFiles + /// ' prompt for extract here + /// If Me.WantExtract(e.FileName) Then + /// e.Extract + /// End If + /// Next + /// End Using + /// + /// + /// the string that specifies which entries to select + /// + /// + /// the directory in the archive from which to select entries. If null, then + /// all directories in the archive are used. + /// + /// + /// a collection of ZipEntry objects that conform to the inclusion spec + public ICollection SelectEntries(String selectionCriteria, string directoryPathInArchive) + { + Ionic.FileSelector ff = new Ionic.FileSelector(selectionCriteria, + AddDirectoryWillTraverseReparsePoints); + return ff.SelectEntries(this, directoryPathInArchive); + } + + + + /// + /// Remove entries from the zipfile by specified criteria. + /// + /// + /// + /// + /// This method allows callers to remove the collection of entries from the zipfile + /// that fit the specified criteria. The criteria are described in a string format, and + /// can include patterns for the filename; constraints on the size of the entry; + /// constraints on the last modified, created, or last accessed time for the file + /// described by the entry; or the attributes of the entry. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// This method is intended for use with a ZipFile that has been read from storage. + /// When creating a new ZipFile, this method will work only after the ZipArchive has + /// been Saved to the disk (the ZipFile class subsequently and implicitly reads the Zip + /// archive from storage.) Calling SelectEntries on a ZipFile that has not yet been + /// saved will deliver undefined results. + /// + /// + /// + /// + /// Thrown if selectionCriteria has an invalid syntax. + /// + /// + /// + /// This example removes all entries in a zip file that were modified prior to January 1st, 2008. + /// + /// using (ZipFile zip1 = ZipFile.Read(ZipFileName)) + /// { + /// // remove all entries from prior to Jan 1, 2008 + /// zip1.RemoveEntries("mtime < 2008-01-01"); + /// // don't forget to save the archive! + /// zip1.Save(); + /// } + /// + /// + /// Using zip As ZipFile = ZipFile.Read(ZipFileName) + /// ' remove all entries from prior to Jan 1, 2008 + /// zip1.RemoveEntries("mtime < 2008-01-01") + /// ' do not forget to save the archive! + /// zip1.Save + /// End Using + /// + /// + /// the string that specifies which entries to select + /// the number of entries removed + public int RemoveSelectedEntries(String selectionCriteria) + { + var selection = this.SelectEntries(selectionCriteria); + this.RemoveEntries(selection); + return selection.Count; + } + + + /// + /// Remove entries from the zipfile by specified criteria, and within the specified + /// path in the archive. + /// + /// + /// + /// + /// This method allows callers to remove the collection of entries from the zipfile + /// that fit the specified criteria. The criteria are described in a string format, and + /// can include patterns for the filename; constraints on the size of the entry; + /// constraints on the last modified, created, or last accessed time for the file + /// described by the entry; or the attributes of the entry. + /// + /// + /// + /// For details on the syntax for the selectionCriteria parameter, see . + /// + /// + /// + /// This method is intended for use with a ZipFile that has been read from storage. + /// When creating a new ZipFile, this method will work only after the ZipArchive has + /// been Saved to the disk (the ZipFile class subsequently and implicitly reads the Zip + /// archive from storage.) Calling SelectEntries on a ZipFile that has not yet been + /// saved will deliver undefined results. + /// + /// + /// + /// + /// Thrown if selectionCriteria has an invalid syntax. + /// + /// + /// + /// + /// using (ZipFile zip1 = ZipFile.Read(ZipFileName)) + /// { + /// // remove all entries from prior to Jan 1, 2008 + /// zip1.RemoveEntries("mtime < 2008-01-01", "documents"); + /// // a call to ZipFile.Save will make the modifications permanent + /// zip1.Save(); + /// } + /// + /// + /// Using zip As ZipFile = ZipFile.Read(ZipFileName) + /// ' remove all entries from prior to Jan 1, 2008 + /// zip1.RemoveEntries("mtime < 2008-01-01", "documents") + /// ' a call to ZipFile.Save will make the modifications permanent + /// zip1.Save + /// End Using + /// + /// + /// + /// the string that specifies which entries to select + /// + /// the directory in the archive from which to select entries. If null, then + /// all directories in the archive are used. + /// + /// the number of entries removed + public int RemoveSelectedEntries(String selectionCriteria, string directoryPathInArchive) + { + var selection = this.SelectEntries(selectionCriteria, directoryPathInArchive); + this.RemoveEntries(selection); + return selection.Count; + } + + + /// + /// Selects and Extracts a set of Entries from the ZipFile. + /// + /// + /// + /// + /// The entries are extracted into the current working directory. + /// + /// + /// + /// If any of the files to be extracted already exist, then the action taken is as + /// specified in the property on the + /// corresponding ZipEntry instance. By default, the action taken in this case is to + /// throw an exception. + /// + /// + /// + /// For information on the syntax of the selectionCriteria string, + /// see . + /// + /// + /// + /// + /// This example shows how extract all XML files modified after 15 January 2009. + /// + /// using (ZipFile zip = ZipFile.Read(zipArchiveName)) + /// { + /// zip.ExtractSelectedEntries("name = *.xml and mtime > 2009-01-15"); + /// } + /// + /// + /// the selection criteria for entries to extract. + /// + /// + public void ExtractSelectedEntries(String selectionCriteria) + { + foreach (ZipEntry e in SelectEntries(selectionCriteria)) + { + e.Password = _Password; // possibly null + e.Extract(); + } + } + + + /// + /// Selects and Extracts a set of Entries from the ZipFile. + /// + /// + /// + /// + /// The entries are extracted into the current working directory. When extraction would would + /// overwrite an existing filesystem file, the action taken is as specified in the + /// parameter. + /// + /// + /// + /// For information on the syntax of the string describing the entry selection criteria, + /// see . + /// + /// + /// + /// + /// This example shows how extract all XML files modified after 15 January 2009, + /// overwriting any existing files. + /// + /// using (ZipFile zip = ZipFile.Read(zipArchiveName)) + /// { + /// zip.ExtractSelectedEntries("name = *.xml and mtime > 2009-01-15", + /// ExtractExistingFileAction.OverwriteSilently); + /// } + /// + /// + /// + /// the selection criteria for entries to extract. + /// + /// + /// The action to take if extraction would overwrite an existing file. + /// + public void ExtractSelectedEntries(String selectionCriteria, ExtractExistingFileAction extractExistingFile) + { + foreach (ZipEntry e in SelectEntries(selectionCriteria)) + { + e.Password = _Password; // possibly null + e.Extract(extractExistingFile); + } + } + + + /// + /// Selects and Extracts a set of Entries from the ZipFile. + /// + /// + /// + /// + /// The entries are selected from the specified directory within the archive, and then + /// extracted into the current working directory. + /// + /// + /// + /// If any of the files to be extracted already exist, then the action taken is as + /// specified in the property on the + /// corresponding ZipEntry instance. By default, the action taken in this case is to + /// throw an exception. + /// + /// + /// + /// For information on the syntax of the string describing the entry selection criteria, + /// see . + /// + /// + /// + /// + /// This example shows how extract all XML files modified after 15 January 2009, + /// and writes them to the "unpack" directory. + /// + /// using (ZipFile zip = ZipFile.Read(zipArchiveName)) + /// { + /// zip.ExtractSelectedEntries("name = *.xml and mtime > 2009-01-15","unpack"); + /// } + /// + /// + /// + /// the selection criteria for entries to extract. + /// + /// + /// the directory in the archive from which to select entries. If null, then + /// all directories in the archive are used. + /// + /// + /// + public void ExtractSelectedEntries(String selectionCriteria, String directoryPathInArchive) + { + foreach (ZipEntry e in SelectEntries(selectionCriteria, directoryPathInArchive)) + { + e.Password = _Password; // possibly null + e.Extract(); + } + } + + + /// + /// Selects and Extracts a set of Entries from the ZipFile. + /// + /// + /// + /// + /// The entries are extracted into the specified directory. If any of the files to be + /// extracted already exist, an exception will be thrown. + /// + /// + /// For information on the syntax of the string describing the entry selection criteria, + /// see . + /// + /// + /// + /// the selection criteria for entries to extract. + /// + /// + /// the directory in the archive from which to select entries. If null, then + /// all directories in the archive are used. + /// + /// + /// + /// the directory on the disk into which to extract. It will be created + /// if it does not exist. + /// + public void ExtractSelectedEntries(String selectionCriteria, string directoryInArchive, string extractDirectory) + { + foreach (ZipEntry e in SelectEntries(selectionCriteria, directoryInArchive)) + { + e.Password = _Password; // possibly null + e.Extract(extractDirectory); + } + } + + + /// + /// Selects and Extracts a set of Entries from the ZipFile. + /// + /// + /// + /// + /// The entries are extracted into the specified directory. When extraction would would + /// overwrite an existing filesystem file, the action taken is as specified in the + /// parameter. + /// + /// + /// + /// For information on the syntax of the string describing the entry selection criteria, + /// see . + /// + /// + /// + /// + /// This example shows how extract all files with an XML extension or with a size larger than 100,000 bytes, + /// and puts them in the unpack directory. For any files that already exist in + /// that destination directory, they will not be overwritten. + /// + /// using (ZipFile zip = ZipFile.Read(zipArchiveName)) + /// { + /// zip.ExtractSelectedEntries("name = *.xml or size > 100000", + /// null, + /// "unpack", + /// ExtractExistingFileAction.DontOverwrite); + /// } + /// + /// + /// + /// the selection criteria for entries to extract. + /// + /// + /// The directory on the disk into which to extract. It will be created if it does not exist. + /// + /// + /// + /// The directory in the archive from which to select entries. If null, then + /// all directories in the archive are used. + /// + /// + /// + /// The action to take if extraction would overwrite an existing file. + /// + /// + public void ExtractSelectedEntries(String selectionCriteria, string directoryPathInArchive, string extractDirectory, ExtractExistingFileAction extractExistingFile) + { + foreach (ZipEntry e in SelectEntries(selectionCriteria, directoryPathInArchive)) + { + e.Password = _Password; // possibly null + e.Extract(extractDirectory, extractExistingFile); + } + } + + } + +} + + + +namespace Ionic +{ + internal abstract partial class SelectionCriterion + { + internal abstract bool Evaluate(Ionic.Zip.ZipEntry entry); + } + + + internal partial class NameCriterion : SelectionCriterion + { + internal override bool Evaluate(Ionic.Zip.ZipEntry entry) + { + // swap forward slashes in the entry.FileName for backslashes + string transformedFileName = entry.FileName.Replace("/", "\\"); + + return _Evaluate(transformedFileName); + } + } + + + internal partial class SizeCriterion : SelectionCriterion + { + internal override bool Evaluate(Ionic.Zip.ZipEntry entry) + { + return _Evaluate(entry.UncompressedSize); + } + } + + internal partial class TimeCriterion : SelectionCriterion + { + internal override bool Evaluate(Ionic.Zip.ZipEntry entry) + { + DateTime x; + switch (Which) + { + case WhichTime.atime: + x = entry.AccessedTime; + break; + case WhichTime.mtime: + x = entry.ModifiedTime; + break; + case WhichTime.ctime: + x = entry.CreationTime; + break; + default: throw new ArgumentException("??time"); + } + return _Evaluate(x); + } + } + + + internal partial class TypeCriterion : SelectionCriterion + { + internal override bool Evaluate(Ionic.Zip.ZipEntry entry) + { + bool result = (ObjectType == 'D') + ? entry.IsDirectory + : !entry.IsDirectory; + + if (Operator != ComparisonOperator.EqualTo) + result = !result; + return result; + } + } + +#if !SILVERLIGHT + internal partial class AttributesCriterion : SelectionCriterion + { + internal override bool Evaluate(Ionic.Zip.ZipEntry entry) + { + FileAttributes fileAttrs = entry.Attributes; + return _Evaluate(fileAttrs); + } + } +#endif + + internal partial class CompoundCriterion : SelectionCriterion + { + internal override bool Evaluate(Ionic.Zip.ZipEntry entry) + { + bool result = Left.Evaluate(entry); + switch (Conjunction) + { + case LogicalConjunction.AND: + if (result) + result = Right.Evaluate(entry); + break; + case LogicalConjunction.OR: + if (!result) + result = Right.Evaluate(entry); + break; + case LogicalConjunction.XOR: + result ^= Right.Evaluate(entry); + break; + } + return result; + } + } + + + + public partial class FileSelector + { + private bool Evaluate(Ionic.Zip.ZipEntry entry) + { + bool result = _Criterion.Evaluate(entry); + return result; + } + + /// + /// Retrieve the ZipEntry items in the ZipFile that conform to the specified criteria. + /// + /// + /// + /// + /// This method applies the criteria set in the FileSelector instance (as described in + /// the ) to the specified ZipFile. Using this + /// method, for example, you can retrieve all entries from the given ZipFile that + /// have filenames ending in .txt. + /// + /// + /// + /// Normally, applications would not call this method directly. This method is used + /// by the ZipFile class. + /// + /// + /// + /// Using the appropriate SelectionCriteria, you can retrieve entries based on size, + /// time, and attributes. See for a + /// description of the syntax of the SelectionCriteria string. + /// + /// + /// + /// + /// The ZipFile from which to retrieve entries. + /// + /// a collection of ZipEntry objects that conform to the criteria. + public ICollection SelectEntries(Ionic.Zip.ZipFile zip) + { + if (zip == null) + throw new ArgumentNullException("zip"); + + var list = new List(); + + foreach (Ionic.Zip.ZipEntry e in zip) + { + if (this.Evaluate(e)) + list.Add(e); + } + + return list; + } + + + /// + /// Retrieve the ZipEntry items in the ZipFile that conform to the specified criteria. + /// + /// + /// + /// + /// This method applies the criteria set in the FileSelector instance (as described in + /// the ) to the specified ZipFile. Using this + /// method, for example, you can retrieve all entries from the given ZipFile that + /// have filenames ending in .txt. + /// + /// + /// + /// Normally, applications would not call this method directly. This method is used + /// by the ZipFile class. + /// + /// + /// + /// This overload allows the selection of ZipEntry instances from the ZipFile to be restricted + /// to entries contained within a particular directory in the ZipFile. + /// + /// + /// + /// Using the appropriate SelectionCriteria, you can retrieve entries based on size, + /// time, and attributes. See for a + /// description of the syntax of the SelectionCriteria string. + /// + /// + /// + /// + /// The ZipFile from which to retrieve entries. + /// + /// + /// the directory in the archive from which to select entries. If null, then + /// all directories in the archive are used. + /// + /// + /// a collection of ZipEntry objects that conform to the criteria. + public ICollection SelectEntries(Ionic.Zip.ZipFile zip, string directoryPathInArchive) + { + if (zip == null) + throw new ArgumentNullException("zip"); + + var list = new List(); + // workitem 8559 + string slashSwapped = (directoryPathInArchive == null) ? null : directoryPathInArchive.Replace("/", "\\"); + // workitem 9174 + if (slashSwapped != null) + { + while (slashSwapped.EndsWith("\\")) + slashSwapped = slashSwapped.Substring(0, slashSwapped.Length - 1); + } + foreach (Ionic.Zip.ZipEntry e in zip) + { + if (directoryPathInArchive == null || (Path.GetDirectoryName(e.FileName) == directoryPathInArchive) + || (Path.GetDirectoryName(e.FileName) == slashSwapped)) // workitem 8559 + if (this.Evaluate(e)) + list.Add(e); + } + + return list; + } + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.cs new file mode 100644 index 00000000..d1b12fce --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.cs @@ -0,0 +1,3910 @@ +// ZipFile.cs +// +// Copyright (c) 2006-2010 Dino Chiesa +// All rights reserved. +// +// This module is part of DotNetZip, a zipfile class library. +// The class library reads and writes zip files, according to the format +// described by PKware, at: +// http://www.pkware.com/business_and_developers/developer/popups/appnote.txt +// +// +// There are other Zip class libraries available. +// +// - it is possible to read and write zip files within .NET via the J# runtime. +// But some people don't like to install the extra DLL, which is no longer +// supported by MS. And also, the J# libraries don't support advanced zip +// features, like ZIP64, spanned archives, or AES encryption. +// +// - There are third-party GPL and LGPL libraries available. Some people don't +// like the license, and some of them don't support all the ZIP features, like AES. +// +// - Finally, there are commercial tools (From ComponentOne, XCeed, etc). But +// some people don't want to incur the cost. +// +// This alternative implementation is **not** GPL licensed. It is free of cost, and +// does not require J#. It does require .NET 2.0. It balances a good set of +// features, with ease of use and speed of performance. +// +// This code is released under the Microsoft Public License . +// See the License.txt for details. +// +// +// NB: This implementation originally relied on the +// System.IO.Compression.DeflateStream base class in the .NET Framework +// v2.0 base class library, but now includes a managed-code port of Zlib. +// +// Thu, 08 Oct 2009 17:04 +// + + +using System; +using System.IO; +using System.Collections.Generic; +using Interop = System.Runtime.InteropServices; + + +namespace Ionic.Zip +{ + /// + /// The ZipFile type represents a zip archive file. + /// + /// + /// + /// + /// This is the main type in the DotNetZip class library. This class reads and + /// writes zip files, as defined in the specification + /// for zip files described by PKWare. The compression for this + /// implementation is provided by a managed-code version of Zlib, included with + /// DotNetZip in the classes in the Ionic.Zlib namespace. + /// + /// + /// + /// This class provides a general purpose zip file capability. Use it to read, + /// create, or update zip files. When you want to create zip files using a + /// Stream type to write the zip file, you may want to consider the class. + /// + /// + /// + /// Both the ZipOutputStream class and the ZipFile class can + /// be used to create zip files. Both of them support many of the common zip + /// features, including Unicode, different compression methods and levels, + /// and ZIP64. They provide very similar performance when creating zip + /// files. + /// + /// + /// + /// The ZipFile class is generally easier to use than + /// ZipOutputStream and should be considered a higher-level interface. For + /// example, when creating a zip file via calls to the PutNextEntry() and + /// Write() methods on the ZipOutputStream class, the caller is + /// responsible for opening the file, reading the bytes from the file, writing + /// those bytes into the ZipOutputStream, setting the attributes on the + /// ZipEntry, and setting the created, last modified, and last accessed + /// timestamps on the zip entry. All of these things are done automatically by a + /// call to ZipFile.AddFile(). + /// For this reason, the ZipOutputStream is generally recommended for use + /// only when your application emits arbitrary data, not necessarily data from a + /// filesystem file, directly into a zip file, and does so using a Stream + /// metaphor. + /// + /// + /// + /// Aside from the differences in programming model, there are other + /// differences in capability between the two classes. + /// + /// + /// + /// + /// ZipFile can be used to read and extract zip files, in addition to + /// creating zip files. ZipOutputStream cannot read zip files. If you want + /// to use a stream to read zip files, check out the class. + /// + /// + /// + /// ZipOutputStream does not support the creation of segmented or spanned + /// zip files. + /// + /// + /// + /// ZipOutputStream cannot produce a self-extracting archive. + /// + /// + /// + /// + /// Be aware that the ZipFile class implements the interface. In order for ZipFile to + /// produce a valid zip file, you use use it within a using clause (Using + /// in VB), or call the Dispose() method explicitly. See the examples + /// for how to employ a using clause. + /// + /// + /// + [Interop.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d00005")] + [Interop.ComVisible(true)] +#if !NETCF + [Interop.ClassInterface(Interop.ClassInterfaceType.AutoDispatch)] +#endif + public partial class ZipFile : + System.Collections.IEnumerable, + System.Collections.Generic.IEnumerable, + IDisposable + { + + #region public properties + + /// + /// Indicates whether to perform a full scan of the zip file when reading it. + /// + /// + /// + /// + /// + /// You almost never want to use this property. + /// + /// + /// + /// When reading a zip file, if this flag is true (True in + /// VB), the entire zip archive will be scanned and searched for entries. + /// For large archives, this can take a very, long time. The much more + /// efficient default behavior is to read the zip directory, which is + /// stored at the end of the zip file. But, in some cases the directory is + /// corrupted and you need to perform a full scan of the zip file to + /// determine the contents of the zip file. This property lets you do + /// that, when necessary. + /// + /// + /// + /// This flag is effective only when calling . Normally you would read a ZipFile with the + /// static ZipFile.Read + /// method. But you can't set the FullScan property on the + /// ZipFile instance when you use a static factory method like + /// ZipFile.Read. + /// + /// + /// + /// + /// + /// + /// This example shows how to read a zip file using the full scan approach, + /// and then save it, thereby producing a corrected zip file. + /// + /// + /// using (var zip = new ZipFile()) + /// { + /// zip.FullScan = true; + /// zip.Initialize(zipFileName); + /// zip.Save(newName); + /// } + /// + /// + /// + /// Using zip As New ZipFile + /// zip.FullScan = True + /// zip.Initialize(zipFileName) + /// zip.Save(newName) + /// End Using + /// + /// + /// + public bool FullScan + { + get; + set; + } + + + /// + /// Whether to sort the ZipEntries before saving the file. + /// + /// + /// + /// The default is false. If you have a large number of zip entries, the sort + /// alone can consume significant time. + /// + /// + /// + /// + /// using (var zip = new ZipFile()) + /// { + /// zip.AddFiles(filesToAdd); + /// zip.SortEntriesBeforeSaving = true; + /// zip.Save(name); + /// } + /// + /// + /// + /// Using zip As New ZipFile + /// zip.AddFiles(filesToAdd) + /// zip.SortEntriesBeforeSaving = True + /// zip.Save(name) + /// End Using + /// + /// + /// + public bool SortEntriesBeforeSaving + { + get; + set; + } + + + + /// + /// Indicates whether NTFS Reparse Points, like junctions, should be + /// traversed during calls to AddDirectory(). + /// + /// + /// + /// By default, calls to AddDirectory() will traverse NTFS reparse + /// points, like mounted volumes, and directory junctions. An example + /// of a junction is the "My Music" directory in Windows Vista. In some + /// cases you may not want DotNetZip to traverse those directories. In + /// that case, set this property to false. + /// + /// + /// + /// + /// using (var zip = new ZipFile()) + /// { + /// zip.AddDirectoryWillTraverseReparsePoints = false; + /// zip.AddDirectory(dirToZip,"fodder"); + /// zip.Save(zipFileToCreate); + /// } + /// + /// + public bool AddDirectoryWillTraverseReparsePoints { get; set; } + + + /// + /// Size of the IO buffer used while saving. + /// + /// + /// + /// + /// + /// First, let me say that you really don't need to bother with this. It is + /// here to allow for optimizations that you probably won't make! It will work + /// fine if you don't set or get this property at all. Ok? + /// + /// + /// + /// Now that we have that out of the way, the fine print: This + /// property affects the size of the buffer that is used for I/O for each + /// entry contained in the zip file. When a file is read in to be compressed, + /// it uses a buffer given by the size here. When you update a zip file, the + /// data for unmodified entries is copied from the first zip file to the + /// other, through a buffer given by the size here. + /// + /// + /// + /// Changing the buffer size affects a few things: first, for larger buffer + /// sizes, the memory used by the ZipFile, obviously, will be larger + /// during I/O operations. This may make operations faster for very much + /// larger files. Last, for any given entry, when you use a larger buffer + /// there will be fewer progress events during I/O operations, because there's + /// one progress event generated for each time the buffer is filled and then + /// emptied. + /// + /// + /// + /// The default buffer size is 8k. Increasing the buffer size may speed + /// things up as you compress larger files. But there are no hard-and-fast + /// rules here, eh? You won't know til you test it. And there will be a + /// limit where ever larger buffers actually slow things down. So as I said + /// in the beginning, it's probably best if you don't set or get this property + /// at all. + /// + /// + /// + /// + /// + /// This example shows how you might set a large buffer size for efficiency when + /// dealing with zip entries that are larger than 1gb. + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.SaveProgress += this.zip1_SaveProgress; + /// zip.AddDirectory(directoryToZip, ""); + /// zip.UseZip64WhenSaving = Zip64Option.Always; + /// zip.BufferSize = 65536*8; // 65536 * 8 = 512k + /// zip.Save(ZipFileToCreate); + /// } + /// + /// + + public int BufferSize + { + get { return _BufferSize; } + set { _BufferSize = value; } + } + + /// + /// Size of the work buffer to use for the ZLIB codec during compression. + /// + /// + /// + /// + /// When doing ZLIB or Deflate compression, the library fills a buffer, + /// then passes it to the compressor for compression. Then the library + /// reads out the compressed bytes. This happens repeatedly until there + /// is no more uncompressed data to compress. This property sets the + /// size of the buffer that will be used for chunk-wise compression. In + /// order for the setting to take effect, your application needs to set + /// this property before calling one of the ZipFile.Save() + /// overloads. + /// + /// + /// Setting this affects the performance and memory efficiency of + /// compression and decompression. For larger files, setting this to a + /// larger size may improve compression performance, but the exact + /// numbers vary depending on available memory, the size of the streams + /// you are compressing, and a bunch of other variables. I don't have + /// good firm recommendations on how to set it. You'll have to test it + /// yourself. Or just leave it alone and accept the default. + /// + /// + public int CodecBufferSize + { + get; + set; + } + + /// + /// Indicates whether extracted files should keep their paths as + /// stored in the zip archive. + /// + /// + /// + /// + /// This property affects Extraction. It is not used when creating zip + /// archives. + /// + /// + /// + /// With this property set to false, the default, extracting entries + /// from a zip file will create files in the filesystem that have the full + /// path associated to the entry within the zip file. With this property set + /// to true, extracting entries from the zip file results in files + /// with no path: the folders are "flattened." + /// + /// + /// + /// An example: suppose the zip file contains entries /directory1/file1.txt and + /// /directory2/file2.txt. With FlattenFoldersOnExtract set to false, + /// the files created will be \directory1\file1.txt and \directory2\file2.txt. + /// With the property set to true, the files created are file1.txt and file2.txt. + /// + /// + /// + public bool FlattenFoldersOnExtract + { + get; + set; + } + + + /// + /// The compression strategy to use for all entries. + /// + /// + /// + /// Set the Strategy used by the ZLIB-compatible compressor, when + /// compressing entries using the DEFLATE method. Different compression + /// strategies work better on different sorts of data. The strategy + /// parameter can affect the compression ratio and the speed of + /// compression but not the correctness of the compresssion. For more + /// information see Ionic.Zlib.CompressionStrategy. + /// + public Ionic.Zlib.CompressionStrategy Strategy + { + get { return _Strategy; } + set { _Strategy = value; } + } + + + /// + /// The name of the ZipFile, on disk. + /// + /// + /// + /// + /// + /// When the ZipFile instance was created by reading an archive using + /// one of the ZipFile.Read methods, this property represents the name + /// of the zip file that was read. When the ZipFile instance was + /// created by using the no-argument constructor, this value is null + /// (Nothing in VB). + /// + /// + /// + /// If you use the no-argument constructor, and you then explicitly set this + /// property, when you call , this name will + /// specify the name of the zip file created. Doing so is equivalent to + /// calling . When instantiating a + /// ZipFile by reading from a stream or byte array, the Name + /// property remains null. When saving to a stream, the Name + /// property is implicitly set to null. + /// + /// + public string Name + { + get { return _name; } + set { _name = value; } + } + + + /// + /// Sets the compression level to be used for entries subsequently added to + /// the zip archive. + /// + /// + /// + /// + /// Varying the compression level used on entries can affect the + /// size-vs-speed tradeoff when compression and decompressing data streams + /// or files. + /// + /// + /// + /// As with some other properties on the ZipFile class, like , , and , setting this property on a ZipFile + /// instance will cause the specified CompressionLevel to be used on all + /// items that are subsequently added to the + /// ZipFile instance. If you set this property after you have added + /// items to the ZipFile, but before you have called Save(), + /// those items will not use the specified compression level. + /// + /// + /// + /// If you do not set this property, the default compression level is used, + /// which normally gives a good balance of compression efficiency and + /// compression speed. In some tests, using BestCompression can + /// double the time it takes to compress, while delivering just a small + /// increase in compression efficiency. This behavior will vary with the + /// type of data you compress. If you are in doubt, just leave this setting + /// alone, and accept the default. + /// + /// + public Ionic.Zlib.CompressionLevel CompressionLevel + { + get; + set; + } + + /// + /// The compression method for the zipfile. + /// + /// + /// + /// By default, the compression method is CompressionMethod.Deflate. + /// + /// + /// + public Ionic.Zip.CompressionMethod CompressionMethod + { + get + { + return _compressionMethod; + } + set + { + _compressionMethod = value; + } + } + + + + /// + /// A comment attached to the zip archive. + /// + /// + /// + /// + /// + /// This property is read/write. It allows the application to specify a + /// comment for the ZipFile, or read the comment for the + /// ZipFile. After setting this property, changes are only made + /// permanent when you call a Save() method. + /// + /// + /// + /// According to PKWARE's + /// zip specification, the comment is not encrypted, even if there is a + /// password set on the zip file. + /// + /// + /// + /// The specification does not describe how to indicate the encoding used + /// on a comment string. Many "compliant" zip tools and libraries use + /// IBM437 as the code page for comments; DotNetZip, too, follows that + /// practice. On the other hand, there are situations where you want a + /// Comment to be encoded with something else, for example using code page + /// 950 "Big-5 Chinese". To fill that need, DotNetZip will encode the + /// comment following the same procedure it follows for encoding + /// filenames: (a) if is + /// Never, it uses the default encoding (IBM437). (b) if is Always, it always uses the + /// alternate encoding (). (c) if is AsNecessary, it uses the + /// alternate encoding only if the default encoding is not sufficient for + /// encoding the comment - in other words if decoding the result does not + /// produce the original string. This decision is taken at the time of + /// the call to ZipFile.Save(). + /// + /// + /// + /// When creating a zip archive using this library, it is possible to change + /// the value of between each + /// entry you add, and between adding entries and the call to + /// Save(). Don't do this. It will likely result in a zip file that is + /// not readable by any tool or application. For best interoperability, leave + /// alone, or specify it only + /// once, before adding any entries to the ZipFile instance. + /// + /// + /// + public string Comment + { + get { return _Comment; } + set + { + _Comment = value; + _contentsChanged = true; + } + } + + + + + /// + /// Specifies whether the Creation, Access, and Modified times for entries + /// added to the zip file will be emitted in “Windows format” + /// when the zip archive is saved. + /// + /// + /// + /// + /// An application creating a zip archive can use this flag to explicitly + /// specify that the file times for the entries should or should not be stored + /// in the zip archive in the format used by Windows. By default this flag is + /// true, meaning the Windows-format times are stored in the zip + /// archive. + /// + /// + /// + /// When adding an entry from a file or directory, the Creation (), Access (), and Modified () times for the given entry are + /// automatically set from the filesystem values. When adding an entry from a + /// stream or string, all three values are implicitly set to + /// DateTime.Now. Applications can also explicitly set those times by + /// calling . + /// + /// + /// + /// PKWARE's + /// zip specification describes multiple ways to format these times in a + /// zip file. One is the format Windows applications normally use: 100ns ticks + /// since January 1, 1601 UTC. The other is a format Unix applications typically + /// use: seconds since January 1, 1970 UTC. Each format can be stored in an + /// "extra field" in the zip entry when saving the zip archive. The former + /// uses an extra field with a Header Id of 0x000A, while the latter uses a + /// header ID of 0x5455, although you probably don't need to know that. + /// + /// + /// + /// Not all tools and libraries can interpret these fields. Windows + /// compressed folders is one that can read the Windows Format timestamps, + /// while I believe the Infozip + /// tools can read the Unix format timestamps. Some tools and libraries + /// may be able to read only one or the other. DotNetZip can read or write + /// times in either or both formats. + /// + /// + /// + /// The times stored are taken from , , and . + /// + /// + /// + /// The value set here applies to all entries subsequently added to the + /// ZipFile. + /// + /// + /// + /// This property is not mutually exclusive of the property. It is possible and + /// legal and valid to produce a zip file that contains timestamps encoded in + /// the Unix format as well as in the Windows format, in addition to the LastModified time attached to each + /// entry in the archive, a time that is always stored in "DOS format". And, + /// notwithstanding the names PKWare uses for these time formats, any of them + /// can be read and written by any computer, on any operating system. But, + /// there are no guarantees that a program running on Mac or Linux will + /// gracefully handle a zip file with "Windows" formatted times, or that an + /// application that does not use DotNetZip but runs on Windows will be able to + /// handle file times in Unix format. + /// + /// + /// + /// When in doubt, test. Sorry, I haven't got a complete list of tools and + /// which sort of timestamps they can use and will tolerate. If you get any + /// good information and would like to pass it on, please do so and I will + /// include that information in this documentation. + /// + /// + /// + /// + /// This example shows how to save a zip file that contains file timestamps + /// in a format normally used by Unix. + /// + /// using (var zip = new ZipFile()) + /// { + /// // produce a zip file the Mac will like + /// zip.EmitTimesInWindowsFormatWhenSaving = false; + /// zip.EmitTimesInUnixFormatWhenSaving = true; + /// zip.AddDirectory(directoryToZip, "files"); + /// zip.Save(outputFile); + /// } + /// + /// + /// + /// Using zip As New ZipFile + /// '' produce a zip file the Mac will like + /// zip.EmitTimesInWindowsFormatWhenSaving = False + /// zip.EmitTimesInUnixFormatWhenSaving = True + /// zip.AddDirectory(directoryToZip, "files") + /// zip.Save(outputFile) + /// End Using + /// + /// + /// + /// + /// + public bool EmitTimesInWindowsFormatWhenSaving + { + get + { + return _emitNtfsTimes; + } + set + { + _emitNtfsTimes = value; + } + } + + + /// + /// Specifies whether the Creation, Access, and Modified times + /// for entries added to the zip file will be emitted in "Unix(tm) + /// format" when the zip archive is saved. + /// + /// + /// + /// + /// An application creating a zip archive can use this flag to explicitly + /// specify that the file times for the entries should or should not be stored + /// in the zip archive in the format used by Unix. By default this flag is + /// false, meaning the Unix-format times are not stored in the zip + /// archive. + /// + /// + /// + /// When adding an entry from a file or directory, the Creation (), Access (), and Modified () times for the given entry are + /// automatically set from the filesystem values. When adding an entry from a + /// stream or string, all three values are implicitly set to DateTime.Now. + /// Applications can also explicitly set those times by calling . + /// + /// + /// + /// PKWARE's + /// zip specification describes multiple ways to format these times in a + /// zip file. One is the format Windows applications normally use: 100ns ticks + /// since January 1, 1601 UTC. The other is a format Unix applications + /// typically use: seconds since January 1, 1970 UTC. Each format can be + /// stored in an "extra field" in the zip entry when saving the zip + /// archive. The former uses an extra field with a Header Id of 0x000A, while + /// the latter uses a header ID of 0x5455, although you probably don't need to + /// know that. + /// + /// + /// + /// Not all tools and libraries can interpret these fields. Windows + /// compressed folders is one that can read the Windows Format timestamps, + /// while I believe the Infozip + /// tools can read the Unix format timestamps. Some tools and libraries may be + /// able to read only one or the other. DotNetZip can read or write times in + /// either or both formats. + /// + /// + /// + /// The times stored are taken from , , and . + /// + /// + /// + /// This property is not mutually exclusive of the property. It is possible and + /// legal and valid to produce a zip file that contains timestamps encoded in + /// the Unix format as well as in the Windows format, in addition to the LastModified time attached to each + /// entry in the zip archive, a time that is always stored in "DOS + /// format". And, notwithstanding the names PKWare uses for these time + /// formats, any of them can be read and written by any computer, on any + /// operating system. But, there are no guarantees that a program running on + /// Mac or Linux will gracefully handle a zip file with "Windows" formatted + /// times, or that an application that does not use DotNetZip but runs on + /// Windows will be able to handle file times in Unix format. + /// + /// + /// + /// When in doubt, test. Sorry, I haven't got a complete list of tools and + /// which sort of timestamps they can use and will tolerate. If you get any + /// good information and would like to pass it on, please do so and I will + /// include that information in this documentation. + /// + /// + /// + /// + /// + public bool EmitTimesInUnixFormatWhenSaving + { + get + { + return _emitUnixTimes; + } + set + { + _emitUnixTimes = value; + } + } + + + + /// + /// Indicates whether verbose output is sent to the during AddXxx() and + /// ReadXxx() operations. + /// + /// + /// + /// This is a synthetic property. It returns true if the is non-null. + /// + internal bool Verbose + { + get { return (_StatusMessageTextWriter != null); } + } + + + /// + /// Returns true if an entry by the given name exists in the ZipFile. + /// + /// + /// the name of the entry to find + /// true if an entry with the given name exists; otherwise false. + /// + public bool ContainsEntry(string name) + { + // workitem 12534 + return _entries.ContainsKey(SharedUtilities.NormalizePathForUseInZipFile(name)); + } + + + + /// + /// Indicates whether to perform case-sensitive matching on the filename when + /// retrieving entries in the zipfile via the string-based indexer. + /// + /// + /// + /// The default value is false, which means don't do case-sensitive + /// matching. In other words, retrieving zip["ReadMe.Txt"] is the same as + /// zip["readme.txt"]. It really makes sense to set this to true only + /// if you are not running on Windows, which has case-insensitive + /// filenames. But since this library is not built for non-Windows platforms, + /// in most cases you should just leave this property alone. + /// + public bool CaseSensitiveRetrieval + { + get + { + return _CaseSensitiveRetrieval; + } + + set + { + // workitem 9868 + if (value != _CaseSensitiveRetrieval) + { + _CaseSensitiveRetrieval = value; + _initEntriesDictionary(); + } + } + } + + + /// + /// Indicates whether to encode entry filenames and entry comments using Unicode + /// (UTF-8). + /// + /// + /// + /// + /// The + /// PKWare zip specification provides for encoding file names and file + /// comments in either the IBM437 code page, or in UTF-8. This flag selects + /// the encoding according to that specification. By default, this flag is + /// false, and filenames and comments are encoded into the zip file in the + /// IBM437 codepage. Setting this flag to true will specify that filenames + /// and comments that cannot be encoded with IBM437 will be encoded with + /// UTF-8. + /// + /// + /// + /// Zip files created with strict adherence to the PKWare specification with + /// respect to UTF-8 encoding can contain entries with filenames containing + /// any combination of Unicode characters, including the full range of + /// characters from Chinese, Latin, Hebrew, Greek, Cyrillic, and many other + /// alphabets. However, because at this time, the UTF-8 portion of the PKWare + /// specification is not broadly supported by other zip libraries and + /// utilities, such zip files may not be readable by your favorite zip tool or + /// archiver. In other words, interoperability will decrease if you set this + /// flag to true. + /// + /// + /// + /// In particular, Zip files created with strict adherence to the PKWare + /// specification with respect to UTF-8 encoding will not work well with + /// Explorer in Windows XP or Windows Vista, because Windows compressed + /// folders, as far as I know, do not support UTF-8 in zip files. Vista can + /// read the zip files, but shows the filenames incorrectly. Unpacking from + /// Windows Vista Explorer will result in filenames that have rubbish + /// characters in place of the high-order UTF-8 bytes. + /// + /// + /// + /// Also, zip files that use UTF-8 encoding will not work well with Java + /// applications that use the java.util.zip classes, as of v5.0 of the Java + /// runtime. The Java runtime does not correctly implement the PKWare + /// specification in this regard. + /// + /// + /// + /// As a result, we have the unfortunate situation that "correct" behavior by + /// the DotNetZip library with regard to Unicode encoding of filenames during + /// zip creation will result in zip files that are readable by strictly + /// compliant and current tools (for example the most recent release of the + /// commercial WinZip tool); but these zip files will not be readable by + /// various other tools or libraries, including Windows Explorer. + /// + /// + /// + /// The DotNetZip library can read and write zip files with UTF8-encoded + /// entries, according to the PKware spec. If you use DotNetZip for both + /// creating and reading the zip file, and you use UTF-8, there will be no + /// loss of information in the filenames. For example, using a self-extractor + /// created by this library will allow you to unpack files correctly with no + /// loss of information in the filenames. + /// + /// + /// + /// If you do not set this flag, it will remain false. If this flag is false, + /// your ZipFile will encode all filenames and comments using the + /// IBM437 codepage. This can cause "loss of information" on some filenames, + /// but the resulting zipfile will be more interoperable with other + /// utilities. As an example of the loss of information, diacritics can be + /// lost. The o-tilde character will be down-coded to plain o. The c with a + /// cedilla (Unicode 0xE7) used in Portugese will be downcoded to a c. + /// Likewise, the O-stroke character (Unicode 248), used in Danish and + /// Norwegian, will be down-coded to plain o. Chinese characters cannot be + /// represented in codepage IBM437; when using the default encoding, Chinese + /// characters in filenames will be represented as ?. These are all examples + /// of "information loss". + /// + /// + /// + /// The loss of information associated to the use of the IBM437 encoding is + /// inconvenient, and can also lead to runtime errors. For example, using + /// IBM437, any sequence of 4 Chinese characters will be encoded as ????. If + /// your application creates a ZipFile, then adds two files, each with + /// names of four Chinese characters each, this will result in a duplicate + /// filename exception. In the case where you add a single file with a name + /// containing four Chinese characters, calling Extract() on the entry that + /// has question marks in the filename will result in an exception, because + /// the question mark is not legal for use within filenames on Windows. These + /// are just a few examples of the problems associated to loss of information. + /// + /// + /// + /// This flag is independent of the encoding of the content within the entries + /// in the zip file. Think of the zip file as a container - it supports an + /// encoding. Within the container are other "containers" - the file entries + /// themselves. The encoding within those entries is independent of the + /// encoding of the zip archive container for those entries. + /// + /// + /// + /// Rather than specify the encoding in a binary fashion using this flag, an + /// application can specify an arbitrary encoding via the property. Setting the encoding + /// explicitly when creating zip archives will result in non-compliant zip + /// files that, curiously, are fairly interoperable. The challenge is, the + /// PKWare specification does not provide for a way to specify that an entry + /// in a zip archive uses a code page that is neither IBM437 nor UTF-8. + /// Therefore if you set the encoding explicitly when creating a zip archive, + /// you must take care upon reading the zip archive to use the same code page. + /// If you get it wrong, the behavior is undefined and may result in incorrect + /// filenames, exceptions, stomach upset, hair loss, and acne. + /// + /// + /// + [Obsolete("Beginning with v1.9.1.6 of DotNetZip, this property is obsolete. It will be removed in a future version of the library. Your applications should use AlternateEncoding and AlternateEncodingUsage instead.")] + public bool UseUnicodeAsNecessary + { + get + { + return (_alternateEncoding == System.Text.Encoding.GetEncoding("UTF-8")) && + (_alternateEncodingUsage == ZipOption.AsNecessary); + } + set + { + if (value) + { + _alternateEncoding = System.Text.Encoding.GetEncoding("UTF-8"); + _alternateEncodingUsage = ZipOption.AsNecessary; + + } + else + { + _alternateEncoding = Ionic.Zip.ZipFile.DefaultEncoding; + _alternateEncodingUsage = ZipOption.Never; + } + } + } + + + /// + /// Specify whether to use ZIP64 extensions when saving a zip archive. + /// + /// + /// + /// + /// + /// When creating a zip file, the default value for the property is . is + /// safest, in the sense that you will not get an Exception if a pre-ZIP64 + /// limit is exceeded. + /// + /// + /// + /// You may set the property at any time before calling Save(). + /// + /// + /// + /// When reading a zip file via the Zipfile.Read() method, DotNetZip + /// will properly read ZIP64-endowed zip archives, regardless of the value of + /// this property. DotNetZip will always read ZIP64 archives. This property + /// governs only whether DotNetZip will write them. Therefore, when updating + /// archives, be careful about setting this property after reading an archive + /// that may use ZIP64 extensions. + /// + /// + /// + /// An interesting question is, if you have set this property to + /// AsNecessary, and then successfully saved, does the resulting + /// archive use ZIP64 extensions or not? To learn this, check the property, after calling Save(). + /// + /// + /// + /// Have you thought about + /// donating? + /// + /// + /// + /// + public Zip64Option UseZip64WhenSaving + { + get + { + return _zip64; + } + set + { + _zip64 = value; + } + } + + + + /// + /// Indicates whether the archive requires ZIP64 extensions. + /// + /// + /// + /// + /// + /// This property is null (or Nothing in VB) if the archive has + /// not been saved, and there are fewer than 65334 ZipEntry items + /// contained in the archive. + /// + /// + /// + /// The Value is true if any of the following four conditions holds: + /// the uncompressed size of any entry is larger than 0xFFFFFFFF; the + /// compressed size of any entry is larger than 0xFFFFFFFF; the relative + /// offset of any entry within the zip archive is larger than 0xFFFFFFFF; or + /// there are more than 65534 entries in the archive. (0xFFFFFFFF = + /// 4,294,967,295). The result may not be known until a Save() is attempted + /// on the zip archive. The Value of this + /// property may be set only AFTER one of the Save() methods has been called. + /// + /// + /// + /// If none of the four conditions holds, and the archive has been saved, then + /// the Value is false. + /// + /// + /// + /// A Value of false does not indicate that the zip archive, as saved, + /// does not use ZIP64. It merely indicates that ZIP64 is not required. An + /// archive may use ZIP64 even when not required if the property is set to , or if the property is set to and the output stream was not + /// seekable. Use the property to determine if + /// the most recent Save() method resulted in an archive that utilized + /// the ZIP64 extensions. + /// + /// + /// + /// + /// + public Nullable RequiresZip64 + { + get + { + if (_entries.Count > 65534) + return new Nullable(true); + + // If the ZipFile has not been saved or if the contents have changed, then + // it is not known if ZIP64 is required. + if (!_hasBeenSaved || _contentsChanged) return null; + + // Whether ZIP64 is required is knowable. + foreach (ZipEntry e in _entries.Values) + { + if (e.RequiresZip64.Value) return new Nullable(true); + } + + return new Nullable(false); + } + } + + + /// + /// Indicates whether the most recent Save() operation used ZIP64 extensions. + /// + /// + /// + /// + /// The use of ZIP64 extensions within an archive is not always necessary, and + /// for interoperability concerns, it may be desired to NOT use ZIP64 if + /// possible. The property can be + /// set to use ZIP64 extensions only when necessary. In those cases, + /// Sometimes applications want to know whether a Save() actually used ZIP64 + /// extensions. Applications can query this read-only property to learn + /// whether ZIP64 has been used in a just-saved ZipFile. + /// + /// + /// + /// The value is null (or Nothing in VB) if the archive has not + /// been saved. + /// + /// + /// + /// Non-null values (HasValue is true) indicate whether ZIP64 + /// extensions were used during the most recent Save() operation. The + /// ZIP64 extensions may have been used as required by any particular entry + /// because of its uncompressed or compressed size, or because the archive is + /// larger than 4294967295 bytes, or because there are more than 65534 entries + /// in the archive, or because the UseZip64WhenSaving property was set + /// to , or because the + /// UseZip64WhenSaving property was set to and the output stream was not seekable. + /// The value of this property does not indicate the reason the ZIP64 + /// extensions were used. + /// + /// + /// + /// + /// + public Nullable OutputUsedZip64 + { + get + { + return _OutputUsesZip64; + } + } + + + /// + /// Indicates whether the most recent Read() operation read a zip file that uses + /// ZIP64 extensions. + /// + /// + /// + /// This property will return null (Nothing in VB) if you've added an entry after reading + /// the zip file. + /// + public Nullable InputUsesZip64 + { + get + { + if (_entries.Count > 65534) + return true; + + foreach (ZipEntry e in this) + { + // if any entry was added after reading the zip file, then the result is null + if (e.Source != ZipEntrySource.ZipFile) return null; + + // if any entry read from the zip used zip64, then the result is true + if (e._InputUsesZip64) return true; + } + return false; + } + } + + + /// + /// The text encoding to use when writing new entries to the ZipFile, + /// for those entries that cannot be encoded with the default (IBM437) + /// encoding; or, the text encoding that was used when reading the entries + /// from the ZipFile. + /// + /// + /// + /// + /// In its + /// zip specification, PKWare describes two options for encoding + /// filenames and comments: using IBM437 or UTF-8. But, some archiving tools + /// or libraries do not follow the specification, and instead encode + /// characters using the system default code page. For example, WinRAR when + /// run on a machine in Shanghai may encode filenames with the Big-5 Chinese + /// (950) code page. This behavior is contrary to the Zip specification, but + /// it occurs anyway. + /// + /// + /// + /// When using DotNetZip to write zip archives that will be read by one of + /// these other archivers, set this property to specify the code page to use + /// when encoding the and for each ZipEntry in the zip file, for + /// values that cannot be encoded with the default codepage for zip files, + /// IBM437. This is why this property is "provisional". In all cases, IBM437 + /// is used where possible, in other words, where no loss of data would + /// result. It is possible, therefore, to have a given entry with a + /// Comment encoded in IBM437 and a FileName encoded with the + /// specified "provisional" codepage. + /// + /// + /// + /// Be aware that a zip file created after you've explicitly set the property to a value other than + /// IBM437 may not be compliant to the PKWare specification, and may not be + /// readable by compliant archivers. On the other hand, many (most?) + /// archivers are non-compliant and can read zip files created in arbitrary + /// code pages. The trick is to use or specify the proper codepage when + /// reading the zip. + /// + /// + /// + /// When creating a zip archive using this library, it is possible to change + /// the value of between each + /// entry you add, and between adding entries and the call to + /// Save(). Don't do this. It will likely result in a zipfile that is + /// not readable. For best interoperability, either leave alone, or specify it only once, + /// before adding any entries to the ZipFile instance. There is one + /// exception to this recommendation, described later. + /// + /// + /// + /// When using an arbitrary, non-UTF8 code page for encoding, there is no + /// standard way for the creator application - whether DotNetZip, WinZip, + /// WinRar, or something else - to formally specify in the zip file which + /// codepage has been used for the entries. As a result, readers of zip files + /// are not able to inspect the zip file and determine the codepage that was + /// used for the entries contained within it. It is left to the application + /// or user to determine the necessary codepage when reading zip files encoded + /// this way. In other words, if you explicitly specify the codepage when you + /// create the zipfile, you must explicitly specify the same codepage when + /// reading the zipfile. + /// + /// + /// + /// The way you specify the code page to use when reading a zip file varies + /// depending on the tool or library you use to read the zip. In DotNetZip, + /// you use a ZipFile.Read() method that accepts an encoding parameter. It + /// isn't possible with Windows Explorer, as far as I know, to specify an + /// explicit codepage to use when reading a zip. If you use an incorrect + /// codepage when reading a zipfile, you will get entries with filenames that + /// are incorrect, and the incorrect filenames may even contain characters + /// that are not legal for use within filenames in Windows. Extracting entries + /// with illegal characters in the filenames will lead to exceptions. It's too + /// bad, but this is just the way things are with code pages in zip + /// files. Caveat Emptor. + /// + /// + /// + /// Example: Suppose you create a zipfile that contains entries with + /// filenames that have Danish characters. If you use equal to "iso-8859-1" (cp 28591), + /// the filenames will be correctly encoded in the zip. But, to read that + /// zipfile correctly, you have to specify the same codepage at the time you + /// read it. If try to read that zip file with Windows Explorer or another + /// application that is not flexible with respect to the codepage used to + /// decode filenames in zipfiles, you will get a filename like "Inf°.txt". + /// + /// + /// + /// When using DotNetZip to read a zip archive, and the zip archive uses an + /// arbitrary code page, you must specify the encoding to use before or when + /// the Zipfile is READ. This means you must use a ZipFile.Read() + /// method that allows you to specify a System.Text.Encoding parameter. Setting + /// the ProvisionalAlternateEncoding property after your application has read in + /// the zip archive will not affect the entry names of entries that have already + /// been read in. + /// + /// + /// + /// And now, the exception to the rule described above. One strategy for + /// specifying the code page for a given zip file is to describe the code page + /// in a human-readable form in the Zip comment. For example, the comment may + /// read "Entries in this archive are encoded in the Big5 code page". For + /// maximum interoperability, the zip comment in this case should be encoded + /// in the default, IBM437 code page. In this case, the zip comment is + /// encoded using a different page than the filenames. To do this, Specify + /// ProvisionalAlternateEncoding to your desired region-specific code + /// page, once before adding any entries, and then reset + /// ProvisionalAlternateEncoding to IBM437 before setting the property and calling Save(). + /// + /// + /// + /// + /// This example shows how to read a zip file using the Big-5 Chinese code page + /// (950), and extract each entry in the zip file. For this code to work as + /// desired, the Zipfile must have been created using the big5 code page + /// (CP950). This is typical, for example, when using WinRar on a machine with + /// CP950 set as the default code page. In that case, the names of entries + /// within the Zip archive will be stored in that code page, and reading the zip + /// archive must be done using that code page. If the application did not use + /// the correct code page in ZipFile.Read(), then names of entries within the + /// zip archive would not be correctly retrieved. + /// + /// using (var zip = ZipFile.Read(zipFileName, System.Text.Encoding.GetEncoding("big5"))) + /// { + /// // retrieve and extract an entry using a name encoded with CP950 + /// zip[MyDesiredEntry].Extract("unpack"); + /// } + /// + /// + /// + /// Using zip As ZipFile = ZipFile.Read(ZipToExtract, System.Text.Encoding.GetEncoding("big5")) + /// ' retrieve and extract an entry using a name encoded with CP950 + /// zip(MyDesiredEntry).Extract("unpack") + /// End Using + /// + /// + /// + /// DefaultEncoding + [Obsolete("use AlternateEncoding instead.")] + public System.Text.Encoding ProvisionalAlternateEncoding + { + get + { + if (_alternateEncodingUsage == ZipOption.AsNecessary) + return _alternateEncoding; + return null; + } + set + { + _alternateEncoding = value; + _alternateEncodingUsage = ZipOption.AsNecessary; + } + } + + + /// + /// A Text Encoding to use when encoding the filenames and comments for + /// all the ZipEntry items, during a ZipFile.Save() operation. + /// + /// + /// + /// Whether the encoding specified here is used during the save depends + /// on . + /// + /// + public System.Text.Encoding AlternateEncoding + { + get + { + return _alternateEncoding; + } + set + { + _alternateEncoding = value; + } + } + + + /// + /// A flag that tells if and when this instance should apply + /// AlternateEncoding to encode the filenames and comments associated to + /// of ZipEntry objects contained within this instance. + /// + public ZipOption AlternateEncodingUsage + { + get + { + return _alternateEncodingUsage; + } + set + { + _alternateEncodingUsage = value; + } + } + + + /// + /// The default text encoding used in zip archives. It is numeric 437, also + /// known as IBM437. + /// + /// + public static System.Text.Encoding DefaultEncoding + { + get + { + return _defaultEncoding; + } + } + + + /// + /// Gets or sets the TextWriter to which status messages are delivered + /// for the instance. + /// + /// + /// + /// If the TextWriter is set to a non-null value, then verbose output is sent + /// to the TextWriter during Add, Read, Save and + /// Extract operations. Typically, console applications might use + /// Console.Out and graphical or headless applications might use a + /// System.IO.StringWriter. The output of this is suitable for viewing + /// by humans. + /// + /// + /// + /// + /// In this example, a console application instantiates a ZipFile, then + /// sets the StatusMessageTextWriter to Console.Out. At that + /// point, all verbose status messages for that ZipFile are sent to the + /// console. + /// + /// + /// + /// using (ZipFile zip= ZipFile.Read(FilePath)) + /// { + /// zip.StatusMessageTextWriter= System.Console.Out; + /// // messages are sent to the console during extraction + /// zip.ExtractAll(); + /// } + /// + /// + /// + /// Using zip As ZipFile = ZipFile.Read(FilePath) + /// zip.StatusMessageTextWriter= System.Console.Out + /// 'Status Messages will be sent to the console during extraction + /// zip.ExtractAll() + /// End Using + /// + /// + /// + /// In this example, a Windows Forms application instantiates a + /// ZipFile, then sets the StatusMessageTextWriter to a + /// StringWriter. At that point, all verbose status messages for that + /// ZipFile are sent to the StringWriter. + /// + /// + /// + /// var sw = new System.IO.StringWriter(); + /// using (ZipFile zip= ZipFile.Read(FilePath)) + /// { + /// zip.StatusMessageTextWriter= sw; + /// zip.ExtractAll(); + /// } + /// Console.WriteLine("{0}", sw.ToString()); + /// + /// + /// + /// Dim sw as New System.IO.StringWriter + /// Using zip As ZipFile = ZipFile.Read(FilePath) + /// zip.StatusMessageTextWriter= sw + /// zip.ExtractAll() + /// End Using + /// 'Status Messages are now available in sw + /// + /// + /// + public TextWriter StatusMessageTextWriter + { + get { return _StatusMessageTextWriter; } + set { _StatusMessageTextWriter = value; } + } + + + + + /// + /// Gets or sets the name for the folder to store the temporary file + /// this library writes when saving a zip archive. + /// + /// + /// + /// + /// This library will create a temporary file when saving a Zip archive to a + /// file. This file is written when calling one of the Save() methods + /// that does not save to a stream, or one of the SaveSelfExtractor() + /// methods. + /// + /// + /// + /// By default, the library will create the temporary file in the directory + /// specified for the file itself, via the property or via + /// the method. + /// + /// + /// + /// Setting this property allows applications to override this default + /// behavior, so that the library will create the temporary file in the + /// specified folder. For example, to have the library create the temporary + /// file in the current working directory, regardless where the ZipFile + /// is saved, specfy ".". To revert to the default behavior, set this + /// property to null (Nothing in VB). + /// + /// + /// + /// When setting the property to a non-null value, the folder specified must + /// exist; if it does not an exception is thrown. The application should have + /// write and delete permissions on the folder. The permissions are not + /// explicitly checked ahead of time; if the application does not have the + /// appropriate rights, an exception will be thrown at the time Save() + /// is called. + /// + /// + /// + /// There is no temporary file created when reading a zip archive. When + /// saving to a Stream, there is no temporary file created. For example, if + /// the application is an ASP.NET application and calls Save() + /// specifying the Response.OutputStream as the output stream, there is + /// no temporary file created. + /// + /// + /// + /// + /// Thrown when setting the property if the directory does not exist. + /// + /// + public String TempFileFolder + { + get { return _TempFileFolder; } + + set + { + _TempFileFolder = value; + if (value == null) return; + + if (!Directory.Exists(value)) + throw new FileNotFoundException(String.Format("That directory ({0}) does not exist.", value)); + + } + } + + /// + /// Sets the password to be used on the ZipFile instance. + /// + /// + /// + /// + /// + /// When writing a zip archive, this password is applied to the entries, not + /// to the zip archive itself. It applies to any ZipEntry subsequently + /// added to the ZipFile, using one of the AddFile, + /// AddDirectory, AddEntry, or AddItem methods, etc. + /// When reading a zip archive, this property applies to any entry + /// subsequently extracted from the ZipFile using one of the Extract + /// methods on the ZipFile class. + /// + /// + /// + /// When writing a zip archive, keep this in mind: though the password is set + /// on the ZipFile object, according to the Zip spec, the "directory" of the + /// archive - in other words the list of entries or files contained in the archive - is + /// not encrypted with the password, or protected in any way. If you set the + /// Password property, the password actually applies to individual entries + /// that are added to the archive, subsequent to the setting of this property. + /// The list of filenames in the archive that is eventually created will + /// appear in clear text, but the contents of the individual files are + /// encrypted. This is how Zip encryption works. + /// + /// + /// + /// One simple way around this limitation is to simply double-wrap sensitive + /// filenames: Store the files in a zip file, and then store that zip file + /// within a second, "outer" zip file. If you apply a password to the outer + /// zip file, then readers will be able to see that the outer zip file + /// contains an inner zip file. But readers will not be able to read the + /// directory or file list of the inner zip file. + /// + /// + /// + /// If you set the password on the ZipFile, and then add a set of files + /// to the archive, then each entry is encrypted with that password. You may + /// also want to change the password between adding different entries. If you + /// set the password, add an entry, then set the password to null + /// (Nothing in VB), and add another entry, the first entry is + /// encrypted and the second is not. If you call AddFile(), then set + /// the Password property, then call ZipFile.Save, the file + /// added will not be password-protected, and no warning will be generated. + /// + /// + /// + /// When setting the Password, you may also want to explicitly set the property, to specify how to encrypt the entries added + /// to the ZipFile. If you set the Password to a non-null value and do not + /// set , then PKZip 2.0 ("Weak") encryption is used. + /// This encryption is relatively weak but is very interoperable. If you set + /// the password to a null value (Nothing in VB), Encryption is + /// reset to None. + /// + /// + /// + /// All of the preceding applies to writing zip archives, in other words when + /// you use one of the Save methods. To use this property when reading or an + /// existing ZipFile, do the following: set the Password property on the + /// ZipFile, then call one of the Extract() overloads on the . In this case, the entry is extracted using the + /// Password that is specified on the ZipFile instance. If you + /// have not set the Password property, then the password is + /// null, and the entry is extracted with no password. + /// + /// + /// + /// If you set the Password property on the ZipFile, then call + /// Extract() an entry that has not been encrypted with a password, the + /// password is not used for that entry, and the ZipEntry is extracted + /// as normal. In other words, the password is used only if necessary. + /// + /// + /// + /// The class also has a Password property. It takes precedence + /// over this property on the ZipFile. Typically, you would use the + /// per-entry Password when most entries in the zip archive use one password, + /// and a few entries use a different password. If all entries in the zip + /// file use the same password, then it is simpler to just set this property + /// on the ZipFile itself, whether creating a zip archive or extracting + /// a zip archive. + /// + /// + /// + /// + /// + /// + /// This example creates a zip file, using password protection for the + /// entries, and then extracts the entries from the zip file. When creating + /// the zip file, the Readme.txt file is not protected with a password, but + /// the other two are password-protected as they are saved. During extraction, + /// each file is extracted with the appropriate password. + /// + /// + /// // create a file with encryption + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddFile("ReadMe.txt"); + /// zip.Password= "!Secret1"; + /// zip.AddFile("MapToTheSite-7440-N49th.png"); + /// zip.AddFile("2008-Regional-Sales-Report.pdf"); + /// zip.Save("EncryptedArchive.zip"); + /// } + /// + /// // extract entries that use encryption + /// using (ZipFile zip = ZipFile.Read("EncryptedArchive.zip")) + /// { + /// zip.Password= "!Secret1"; + /// zip.ExtractAll("extractDir"); + /// } + /// + /// + /// + /// + /// Using zip As New ZipFile + /// zip.AddFile("ReadMe.txt") + /// zip.Password = "123456!" + /// zip.AddFile("MapToTheSite-7440-N49th.png") + /// zip.Password= "!Secret1"; + /// zip.AddFile("2008-Regional-Sales-Report.pdf") + /// zip.Save("EncryptedArchive.zip") + /// End Using + /// + /// + /// ' extract entries that use encryption + /// Using (zip as ZipFile = ZipFile.Read("EncryptedArchive.zip")) + /// zip.Password= "!Secret1" + /// zip.ExtractAll("extractDir") + /// End Using + /// + /// + /// + /// + /// + /// ZipFile.Encryption + /// ZipEntry.Password + public String Password + { + set + { + _Password = value; + if (_Password == null) + { + Encryption = EncryptionAlgorithm.None; + } + else if (Encryption == EncryptionAlgorithm.None) + { + Encryption = EncryptionAlgorithm.PkzipWeak; + } + } + private get + { + return _Password; + } + } + + + + + + /// + /// The action the library should take when extracting a file that already + /// exists. + /// + /// + /// + /// + /// This property affects the behavior of the Extract methods (one of the + /// Extract() or ExtractWithPassword() overloads), when + /// extraction would would overwrite an existing filesystem file. If you do + /// not set this property, the library throws an exception when extracting an + /// entry would overwrite an existing file. + /// + /// + /// + /// This property has no effect when extracting to a stream, or when the file + /// to be extracted does not already exist. + /// + /// + /// + public ExtractExistingFileAction ExtractExistingFile + { + get; + set; + } + + + /// + /// The action the library should take when an error is encountered while + /// opening or reading files as they are saved into a zip archive. + /// + /// + /// + /// + /// Errors can occur as a file is being saved to the zip archive. For + /// example, the File.Open may fail, or a File.Read may fail, because of + /// lock conflicts or other reasons. + /// + /// + /// + /// The first problem might occur after having called AddDirectory() on a + /// directory that contains a Clipper .dbf file; the file is locked by + /// Clipper and cannot be opened for read by another process. An example of + /// the second problem might occur when trying to zip a .pst file that is in + /// use by Microsoft Outlook. Outlook locks a range on the file, which allows + /// other processes to open the file, but not read it in its entirety. + /// + /// + /// + /// This property tells DotNetZip what you would like to do in the case of + /// these errors. The primary options are: ZipErrorAction.Throw to + /// throw an exception (this is the default behavior if you don't set this + /// property); ZipErrorAction.Skip to Skip the file for which there + /// was an error and continue saving; ZipErrorAction.Retry to Retry + /// the entry that caused the problem; or + /// ZipErrorAction.InvokeErrorEvent to invoke an event handler. + /// + /// + /// + /// This property is implicitly set to ZipErrorAction.InvokeErrorEvent + /// if you add a handler to the event. If you set + /// this property to something other than + /// ZipErrorAction.InvokeErrorEvent, then the ZipError + /// event is implicitly cleared. What it means is you can set one or the + /// other (or neither), depending on what you want, but you never need to set + /// both. + /// + /// + /// + /// As with some other properties on the ZipFile class, like , , and , setting this property on a ZipFile + /// instance will cause the specified ZipErrorAction to be used on all + /// items that are subsequently added to the + /// ZipFile instance. If you set this property after you have added + /// items to the ZipFile, but before you have called Save(), + /// those items will not use the specified error handling action. + /// + /// + /// + /// If you want to handle any errors that occur with any entry in the zip + /// file in the same way, then set this property once, before adding any + /// entries to the zip archive. + /// + /// + /// + /// If you set this property to ZipErrorAction.Skip and you'd like to + /// learn which files may have been skipped after a Save(), you can + /// set the on the ZipFile before + /// calling Save(). A message will be emitted into that writer for + /// each skipped file, if any. + /// + /// + /// + /// + /// + /// This example shows how to tell DotNetZip to skip any files for which an + /// error is generated during the Save(). + /// + /// Public Sub SaveZipFile() + /// Dim SourceFolder As String = "fodder" + /// Dim DestFile As String = "eHandler.zip" + /// Dim sw as New StringWriter + /// Using zipArchive As ZipFile = New ZipFile + /// ' Tell DotNetZip to skip any files for which it encounters an error + /// zipArchive.ZipErrorAction = ZipErrorAction.Skip + /// zipArchive.StatusMessageTextWriter = sw + /// zipArchive.AddDirectory(SourceFolder) + /// zipArchive.Save(DestFile) + /// End Using + /// ' examine sw here to see any messages + /// End Sub + /// + /// + /// + /// + /// + /// + + public ZipErrorAction ZipErrorAction + { + get + { + if (ZipError != null) + _zipErrorAction = ZipErrorAction.InvokeErrorEvent; + return _zipErrorAction; + } + set + { + _zipErrorAction = value; + if (_zipErrorAction != ZipErrorAction.InvokeErrorEvent && ZipError != null) + ZipError = null; + } + } + + + /// + /// The Encryption to use for entries added to the ZipFile. + /// + /// + /// + /// + /// Set this when creating a zip archive, or when updating a zip archive. The + /// specified Encryption is applied to the entries subsequently added to the + /// ZipFile instance. Applications do not need to set the + /// Encryption property when reading or extracting a zip archive. + /// + /// + /// + /// If you set this to something other than EncryptionAlgorithm.None, you + /// will also need to set the . + /// + /// + /// + /// As with some other properties on the ZipFile class, like and , setting this + /// property on a ZipFile instance will cause the specified + /// EncryptionAlgorithm to be used on all items + /// that are subsequently added to the ZipFile instance. In other + /// words, if you set this property after you have added items to the + /// ZipFile, but before you have called Save(), those items will + /// not be encrypted or protected with a password in the resulting zip + /// archive. To get a zip archive with encrypted entries, set this property, + /// along with the property, before calling + /// AddFile, AddItem, or AddDirectory (etc.) on the + /// ZipFile instance. + /// + /// + /// + /// If you read a ZipFile, you can modify the Encryption on an + /// encrypted entry, only by setting the Encryption property on the + /// ZipEntry itself. Setting the Encryption property on the + /// ZipFile, once it has been created via a call to + /// ZipFile.Read(), does not affect entries that were previously read. + /// + /// + /// + /// For example, suppose you read a ZipFile, and there is an encrypted + /// entry. Setting the Encryption property on that ZipFile and + /// then calling Save() on the ZipFile does not update the + /// Encryption used for the entries in the archive. Neither is an + /// exception thrown. Instead, what happens during the Save() is that + /// all previously existing entries are copied through to the new zip archive, + /// with whatever encryption and password that was used when originally + /// creating the zip archive. Upon re-reading that archive, to extract + /// entries, applications should use the original password or passwords, if + /// any. + /// + /// + /// + /// Suppose an application reads a ZipFile, and there is an encrypted + /// entry. Setting the Encryption property on that ZipFile and + /// then adding new entries (via AddFile(), AddEntry(), etc) + /// and then calling Save() on the ZipFile does not update the + /// Encryption on any of the entries that had previously been in the + /// ZipFile. The Encryption property applies only to the + /// newly-added entries. + /// + /// + /// + /// + /// + /// + /// This example creates a zip archive that uses encryption, and then extracts + /// entries from the archive. When creating the zip archive, the ReadMe.txt + /// file is zipped without using a password or encryption. The other files + /// use encryption. + /// + /// + /// + /// // Create a zip archive with AES Encryption. + /// using (ZipFile zip = new ZipFile()) + /// { + /// zip.AddFile("ReadMe.txt"); + /// zip.Encryption= EncryptionAlgorithm.WinZipAes256; + /// zip.Password= "Top.Secret.No.Peeking!"; + /// zip.AddFile("7440-N49th.png"); + /// zip.AddFile("2008-Regional-Sales-Report.pdf"); + /// zip.Save("EncryptedArchive.zip"); + /// } + /// + /// // Extract a zip archive that uses AES Encryption. + /// // You do not need to specify the algorithm during extraction. + /// using (ZipFile zip = ZipFile.Read("EncryptedArchive.zip")) + /// { + /// zip.Password= "Top.Secret.No.Peeking!"; + /// zip.ExtractAll("extractDirectory"); + /// } + /// + /// + /// + /// ' Create a zip that uses Encryption. + /// Using zip As New ZipFile() + /// zip.Encryption= EncryptionAlgorithm.WinZipAes256 + /// zip.Password= "Top.Secret.No.Peeking!" + /// zip.AddFile("ReadMe.txt") + /// zip.AddFile("7440-N49th.png") + /// zip.AddFile("2008-Regional-Sales-Report.pdf") + /// zip.Save("EncryptedArchive.zip") + /// End Using + /// + /// ' Extract a zip archive that uses AES Encryption. + /// ' You do not need to specify the algorithm during extraction. + /// Using (zip as ZipFile = ZipFile.Read("EncryptedArchive.zip")) + /// zip.Password= "Top.Secret.No.Peeking!" + /// zip.ExtractAll("extractDirectory") + /// End Using + /// + /// + /// + /// + /// ZipFile.Password + /// ZipEntry.Encryption + public EncryptionAlgorithm Encryption + { + get + { + return _Encryption; + } + set + { + if (value == EncryptionAlgorithm.Unsupported) + throw new InvalidOperationException("You may not set Encryption to that value."); + _Encryption = value; + } + } + + + + /// + /// A callback that allows the application to specify the compression level + /// to use for entries subsequently added to the zip archive. + /// + /// + /// + /// + /// + /// With this callback, the DotNetZip library allows the application to + /// determine whether compression will be used, at the time of the + /// Save. This may be useful if the application wants to favor + /// speed over size, and wants to defer the decision until the time of + /// Save. + /// + /// + /// + /// Typically applications set the property on + /// the ZipFile or on each ZipEntry to determine the level of + /// compression used. This is done at the time the entry is added to the + /// ZipFile. Setting the property to + /// Ionic.Zlib.CompressionLevel.None means no compression will be used. + /// + /// + /// + /// This callback allows the application to defer the decision on the + /// CompressionLevel to use, until the time of the call to + /// ZipFile.Save(). The callback is invoked once per ZipEntry, + /// at the time the data for the entry is being written out as part of a + /// Save() operation. The application can use whatever criteria it + /// likes in determining the level to return. For example, an application may + /// wish that no .mp3 files should be compressed, because they are already + /// compressed and the extra compression is not worth the CPU time incurred, + /// and so can return None for all .mp3 entries. + /// + /// + /// + /// The library determines whether compression will be attempted for an entry + /// this way: If the entry is a zero length file, or a directory, no + /// compression is used. Otherwise, if this callback is set, it is invoked + /// and the CompressionLevel is set to the return value. If this + /// callback has not been set, then the previously set value for + /// CompressionLevel is used. + /// + /// + /// + public SetCompressionCallback SetCompression + { + get; + set; + } + + + /// + /// The maximum size of an output segment, when saving a split Zip file. + /// + /// + /// + /// Set this to a non-zero value before calling or to specify that the ZipFile should be saved as a + /// split archive, also sometimes called a spanned archive. Some also + /// call them multi-file archives. + /// + /// + /// + /// A split zip archive is saved in a set of discrete filesystem files, + /// rather than in a single file. This is handy when transmitting the + /// archive in email or some other mechanism that has a limit to the size of + /// each file. The first file in a split archive will be named + /// basename.z01, the second will be named basename.z02, and + /// so on. The final file is named basename.zip. According to the zip + /// specification from PKWare, the minimum value is 65536, for a 64k segment + /// size. The maximum number of segments allows in a split archive is 99. + /// + /// + /// + /// The value of this property determines the maximum size of a split + /// segment when writing a split archive. For example, suppose you have a + /// ZipFile that would save to a single file of 200k. If you set the + /// MaxOutputSegmentSize to 65536 before calling Save(), you + /// will get four distinct output files. On the other hand if you set this + /// property to 256k, then you will get a single-file archive for that + /// ZipFile. + /// + /// + /// + /// The size of each split output file will be as large as possible, up to + /// the maximum size set here. The zip specification requires that some data + /// fields in a zip archive may not span a split boundary, and an output + /// segment may be smaller than the maximum if necessary to avoid that + /// problem. Also, obviously the final segment of the archive may be smaller + /// than the maximum segment size. Segments will never be larger than the + /// value set with this property. + /// + /// + /// + /// You can save a split Zip file only when saving to a regular filesystem + /// file. It's not possible to save a split zip file as a self-extracting + /// archive, nor is it possible to save a split zip file to a stream. When + /// saving to a SFX or to a Stream, this property is ignored. + /// + /// + /// + /// About interoperability: Split or spanned zip files produced by DotNetZip + /// can be read by WinZip or PKZip, and vice-versa. Segmented zip files may + /// not be readable by other tools, if those other tools don't support zip + /// spanning or splitting. When in doubt, test. I don't believe Windows + /// Explorer can extract a split archive. + /// + /// + /// + /// This property has no effect when reading a split archive. You can read + /// a split archive in the normal way with DotNetZip. + /// + /// + /// + /// When saving a zip file, if you want a regular zip file rather than a + /// split zip file, don't set this property, or set it to Zero. + /// + /// + /// + /// If you read a split archive, with and + /// then subsequently call ZipFile.Save(), unless you set this + /// property before calling Save(), you will get a normal, + /// single-file archive. + /// + /// + /// + /// + public Int32 MaxOutputSegmentSize + { + get + { + return _maxOutputSegmentSize; + } + set + { + if (value < 65536 && value != 0) + throw new ZipException("The minimum acceptable segment size is 65536."); + _maxOutputSegmentSize = value; + } + } + + + /// + /// Returns the number of segments used in the most recent Save() operation. + /// + /// + /// + /// This is normally zero, unless you have set the property. If you have set , and then you save a file, after the call to + /// Save() completes, you can read this value to learn the number of segments that + /// were created. + /// + /// + /// If you call Save("Archive.zip"), and it creates 5 segments, then you + /// will have filesystem files named Archive.z01, Archive.z02, Archive.z03, + /// Archive.z04, and Archive.zip, and the value of this property will be 5. + /// + /// + /// + public Int32 NumberOfSegmentsForMostRecentSave + { + get + { + return unchecked((Int32)_numberOfSegmentsForMostRecentSave + 1); + } + } + + +#if !NETCF + /// + /// The size threshold for an entry, above which a parallel deflate is used. + /// + /// + /// + /// + /// + /// DotNetZip will use multiple threads to compress any ZipEntry, + /// if the entry is larger than the given size. Zero means "always + /// use parallel deflate", while -1 means "never use parallel + /// deflate". The default value for this property is 512k. Aside + /// from the special values of 0 and 1, the minimum value is 65536. + /// + /// + /// + /// If the entry size cannot be known before compression, as with a + /// read-forward stream, then Parallel deflate will never be + /// performed, unless the value of this property is zero. + /// + /// + /// + /// A parallel deflate operations will speed up the compression of + /// large files, on computers with multiple CPUs or multiple CPU + /// cores. For files above 1mb, on a dual core or dual-cpu (2p) + /// machine, the time required to compress the file can be 70% of the + /// single-threaded deflate. For very large files on 4p machines the + /// compression can be done in 30% of the normal time. The downside + /// is that parallel deflate consumes extra memory during the deflate, + /// and the deflation is not as effective. + /// + /// + /// + /// Parallel deflate tends to yield slightly less compression when + /// compared to as single-threaded deflate; this is because the original + /// data stream is split into multiple independent buffers, each of which + /// is compressed in parallel. But because they are treated + /// independently, there is no opportunity to share compression + /// dictionaries. For that reason, a deflated stream may be slightly + /// larger when compressed using parallel deflate, as compared to a + /// traditional single-threaded deflate. Sometimes the increase over the + /// normal deflate is as much as 5% of the total compressed size. For + /// larger files it can be as small as 0.1%. + /// + /// + /// + /// Multi-threaded compression does not give as much an advantage when + /// using Encryption. This is primarily because encryption tends to slow + /// down the entire pipeline. Also, multi-threaded compression gives less + /// of an advantage when using lower compression levels, for example . You may have to + /// perform some tests to determine the best approach for your situation. + /// + /// + /// + /// + /// + /// + public long ParallelDeflateThreshold + { + set + { + if ((value != 0) && (value != -1) && (value < 64 * 1024)) + throw new ArgumentOutOfRangeException("ParallelDeflateThreshold should be -1, 0, or > 65536"); + _ParallelDeflateThreshold = value; + } + get + { + return _ParallelDeflateThreshold; + } + } + + /// + /// The maximum number of buffer pairs to use when performing + /// parallel compression. + /// + /// + /// + /// + /// This property sets an upper limit on the number of memory + /// buffer pairs to create when performing parallel + /// compression. The implementation of the parallel + /// compression stream allocates multiple buffers to + /// facilitate parallel compression. As each buffer fills up, + /// the stream uses + /// ThreadPool.QueueUserWorkItem() to compress those + /// buffers in a background threadpool thread. After a buffer + /// is compressed, it is re-ordered and written to the output + /// stream. + /// + /// + /// + /// A higher number of buffer pairs enables a higher degree of + /// parallelism, which tends to increase the speed of compression on + /// multi-cpu computers. On the other hand, a higher number of buffer + /// pairs also implies a larger memory consumption, more active worker + /// threads, and a higher cpu utilization for any compression. This + /// property enables the application to limit its memory consumption and + /// CPU utilization behavior depending on requirements. + /// + /// + /// + /// For each compression "task" that occurs in parallel, there are 2 + /// buffers allocated: one for input and one for output. This property + /// sets a limit for the number of pairs. The total amount of storage + /// space allocated for buffering will then be (N*S*2), where N is the + /// number of buffer pairs, S is the size of each buffer (). By default, DotNetZip allocates 4 buffer + /// pairs per CPU core, so if your machine has 4 cores, and you retain + /// the default buffer size of 128k, then the + /// ParallelDeflateOutputStream will use 4 * 4 * 2 * 128kb of buffer + /// memory in total, or 4mb, in blocks of 128kb. If you then set this + /// property to 8, then the number will be 8 * 2 * 128kb of buffer + /// memory, or 2mb. + /// + /// + /// + /// CPU utilization will also go up with additional buffers, because a + /// larger number of buffer pairs allows a larger number of background + /// threads to compress in parallel. If you find that parallel + /// compression is consuming too much memory or CPU, you can adjust this + /// value downward. + /// + /// + /// + /// The default value is 16. Different values may deliver better or + /// worse results, depending on your priorities and the dynamic + /// performance characteristics of your storage and compute resources. + /// + /// + /// + /// This property is not the number of buffer pairs to use; it is an + /// upper limit. An illustration: Suppose you have an application that + /// uses the default value of this property (which is 16), and it runs + /// on a machine with 2 CPU cores. In that case, DotNetZip will allocate + /// 4 buffer pairs per CPU core, for a total of 8 pairs. The upper + /// limit specified by this property has no effect. + /// + /// + /// + /// The application can set this value at any time + /// before calling ZipFile.Save(). + /// + /// + /// + /// + /// + public int ParallelDeflateMaxBufferPairs + { + get + { + return _maxBufferPairs; + } + set + { + if (value < 4) + throw new ArgumentOutOfRangeException("ParallelDeflateMaxBufferPairs", + "Value must be 4 or greater."); + _maxBufferPairs = value; + } + } +#endif + + + /// Provides a string representation of the instance. + /// a string representation of the instance. + public override String ToString() + { + return String.Format("ZipFile::{0}", Name); + } + + + /// + /// Returns the version number on the DotNetZip assembly. + /// + /// + /// + /// + /// This property is exposed as a convenience. Callers could also get the + /// version value by retrieving GetName().Version on the + /// System.Reflection.Assembly object pointing to the DotNetZip + /// assembly. But sometimes it is not clear which assembly is being loaded. + /// This property makes it clear. + /// + /// + /// This static property is primarily useful for diagnostic purposes. + /// + /// + public static System.Version LibraryVersion + { + get + { + return System.Reflection.Assembly.GetExecutingAssembly().GetName().Version; + } + } + + internal void NotifyEntryChanged() + { + _contentsChanged = true; + } + + + internal Stream StreamForDiskNumber(uint diskNumber) + { + if (diskNumber + 1 == this._diskNumberWithCd || + (diskNumber == 0 && this._diskNumberWithCd == 0)) + { + //return (this.ReadStream as FileStream); + return this.ReadStream; + } + return ZipSegmentedStream.ForReading(this._readName ?? this._name, + diskNumber, _diskNumberWithCd); + } + + + + // called by ZipEntry in ZipEntry.Extract(), when there is no stream set for the + // ZipEntry. + internal void Reset(bool whileSaving) + { + if (_JustSaved) + { + // read in the just-saved zip archive + using (ZipFile x = new ZipFile()) + { + // workitem 10735 + x._readName = x._name = whileSaving + ? (this._readName ?? this._name) + : this._name; + x.AlternateEncoding = this.AlternateEncoding; + x.AlternateEncodingUsage = this.AlternateEncodingUsage; + ReadIntoInstance(x); + // copy the contents of the entries. + // cannot just replace the entries - the app may be holding them + foreach (ZipEntry e1 in x) + { + foreach (ZipEntry e2 in this) + { + if (e1.FileName == e2.FileName) + { + e2.CopyMetaData(e1); + break; + } + } + } + } + _JustSaved = false; + } + } + + + #endregion + + #region Constructors + + /// + /// Creates a new ZipFile instance, using the specified filename. + /// + /// + /// + /// + /// Applications can use this constructor to create a new ZipFile for writing, + /// or to slurp in an existing zip archive for read and update purposes. + /// + /// + /// + /// To create a new zip archive, an application can call this constructor, + /// passing the name of a file that does not exist. The name may be a fully + /// qualified path. Then the application can add directories or files to the + /// ZipFile via AddDirectory(), AddFile(), AddItem() + /// and then write the zip archive to the disk by calling Save(). The + /// zip file is not actually opened and written to the disk until the + /// application calls ZipFile.Save(). At that point the new zip file + /// with the given name is created. + /// + /// + /// + /// If you won't know the name of the Zipfile until the time you call + /// ZipFile.Save(), or if you plan to save to a stream (which has no + /// name), then you should use the no-argument constructor. + /// + /// + /// + /// The application can also call this constructor to read an existing zip + /// archive. passing the name of a valid zip file that does exist. But, it's + /// better form to use the static method, + /// passing the name of the zip file, because using ZipFile.Read() in + /// your code communicates very clearly what you are doing. In either case, + /// the file is then read into the ZipFile instance. The app can then + /// enumerate the entries or can modify the zip file, for example adding + /// entries, removing entries, changing comments, and so on. + /// + /// + /// + /// One advantage to this parameterized constructor: it allows applications to + /// use the same code to add items to a zip archive, regardless of whether the + /// zip file exists. + /// + /// + /// + /// Instances of the ZipFile class are not multi-thread safe. You may + /// not party on a single instance with multiple threads. You may have + /// multiple threads that each use a distinct ZipFile instance, or you + /// can synchronize multi-thread access to a single instance. + /// + /// + /// + /// By the way, since DotNetZip is so easy to use, don't you think you should + /// donate $5 or $10? + /// + /// + /// + /// + /// + /// Thrown if name refers to an existing file that is not a valid zip file. + /// + /// + /// + /// This example shows how to create a zipfile, and add a few files into it. + /// + /// String ZipFileToCreate = "archive1.zip"; + /// String DirectoryToZip = "c:\\reports"; + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Store all files found in the top level directory, into the zip archive. + /// String[] filenames = System.IO.Directory.GetFiles(DirectoryToZip); + /// zip.AddFiles(filenames, "files"); + /// zip.Save(ZipFileToCreate); + /// } + /// + /// + /// + /// Dim ZipFileToCreate As String = "archive1.zip" + /// Dim DirectoryToZip As String = "c:\reports" + /// Using zip As ZipFile = New ZipFile() + /// Dim filenames As String() = System.IO.Directory.GetFiles(DirectoryToZip) + /// zip.AddFiles(filenames, "files") + /// zip.Save(ZipFileToCreate) + /// End Using + /// + /// + /// + /// The filename to use for the new zip archive. + /// + public ZipFile(string fileName) + { + try + { + _InitInstance(fileName, null); + } + catch (Exception e1) + { + throw new ZipException(String.Format("Could not read {0} as a zip file", fileName), e1); + } + } + + + /// + /// Creates a new ZipFile instance, using the specified name for the + /// filename, and the specified Encoding. + /// + /// + /// + /// + /// See the documentation on the ZipFile + /// constructor that accepts a single string argument for basic + /// information on all the ZipFile constructors. + /// + /// + /// + /// The Encoding is used as the default alternate encoding for entries with + /// filenames or comments that cannot be encoded with the IBM437 code page. + /// This is equivalent to setting the property on the ZipFile + /// instance after construction. + /// + /// + /// + /// Instances of the ZipFile class are not multi-thread safe. You may + /// not party on a single instance with multiple threads. You may have + /// multiple threads that each use a distinct ZipFile instance, or you + /// can synchronize multi-thread access to a single instance. + /// + /// + /// + /// + /// + /// Thrown if name refers to an existing file that is not a valid zip file. + /// + /// + /// The filename to use for the new zip archive. + /// The Encoding is used as the default alternate + /// encoding for entries with filenames or comments that cannot be encoded + /// with the IBM437 code page. + public ZipFile(string fileName, System.Text.Encoding encoding) + { + try + { + AlternateEncoding = encoding; + AlternateEncodingUsage = ZipOption.Always; + _InitInstance(fileName, null); + } + catch (Exception e1) + { + throw new ZipException(String.Format("{0} is not a valid zip file", fileName), e1); + } + } + + + + /// + /// Create a zip file, without specifying a target filename or stream to save to. + /// + /// + /// + /// + /// See the documentation on the ZipFile + /// constructor that accepts a single string argument for basic + /// information on all the ZipFile constructors. + /// + /// + /// + /// After instantiating with this constructor and adding entries to the + /// archive, the application should call or + /// to save to a file or a + /// stream, respectively. The application can also set the + /// property and then call the no-argument method. (This + /// is the preferred approach for applications that use the library through + /// COM interop.) If you call the no-argument method + /// without having set the Name of the ZipFile, either through + /// the parameterized constructor or through the explicit property , the + /// Save() will throw, because there is no place to save the file. + /// + /// + /// Instances of the ZipFile class are not multi-thread safe. You may + /// have multiple threads that each use a distinct ZipFile instance, or + /// you can synchronize multi-thread access to a single instance. + /// + /// + /// + /// + /// This example creates a Zip archive called Backup.zip, containing all the files + /// in the directory DirectoryToZip. Files within subdirectories are not zipped up. + /// + /// using (ZipFile zip = new ZipFile()) + /// { + /// // Store all files found in the top level directory, into the zip archive. + /// // note: this code does not recurse subdirectories! + /// String[] filenames = System.IO.Directory.GetFiles(DirectoryToZip); + /// zip.AddFiles(filenames, "files"); + /// zip.Save("Backup.zip"); + /// } + /// + /// + /// + /// Using zip As New ZipFile + /// ' Store all files found in the top level directory, into the zip archive. + /// ' note: this code does not recurse subdirectories! + /// Dim filenames As String() = System.IO.Directory.GetFiles(DirectoryToZip) + /// zip.AddFiles(filenames, "files") + /// zip.Save("Backup.zip") + /// End Using + /// + /// + public ZipFile() + { + _InitInstance(null, null); + } + + + /// + /// Create a zip file, specifying a text Encoding, but without specifying a + /// target filename or stream to save to. + /// + /// + /// + /// + /// See the documentation on the ZipFile + /// constructor that accepts a single string argument for basic + /// information on all the ZipFile constructors. + /// + /// + /// + /// + /// + /// The Encoding is used as the default alternate encoding for entries with + /// filenames or comments that cannot be encoded with the IBM437 code page. + /// + public ZipFile(System.Text.Encoding encoding) + { + AlternateEncoding = encoding; + AlternateEncodingUsage = ZipOption.Always; + _InitInstance(null, null); + } + + + /// + /// Creates a new ZipFile instance, using the specified name for the + /// filename, and the specified status message writer. + /// + /// + /// + /// + /// See the documentation on the ZipFile + /// constructor that accepts a single string argument for basic + /// information on all the ZipFile constructors. + /// + /// + /// + /// This version of the constructor allows the caller to pass in a TextWriter, + /// to which verbose messages will be written during extraction or creation of + /// the zip archive. A console application may wish to pass + /// System.Console.Out to get messages on the Console. A graphical or headless + /// application may wish to capture the messages in a different + /// TextWriter, for example, a StringWriter, and then display + /// the messages in a TextBox, or generate an audit log of ZipFile operations. + /// + /// + /// + /// To encrypt the data for the files added to the ZipFile instance, + /// set the Password property after creating the ZipFile instance. + /// + /// + /// + /// Instances of the ZipFile class are not multi-thread safe. You may + /// not party on a single instance with multiple threads. You may have + /// multiple threads that each use a distinct ZipFile instance, or you + /// can synchronize multi-thread access to a single instance. + /// + /// + /// + /// + /// + /// Thrown if name refers to an existing file that is not a valid zip file. + /// + /// + /// + /// + /// using (ZipFile zip = new ZipFile("Backup.zip", Console.Out)) + /// { + /// // Store all files found in the top level directory, into the zip archive. + /// // note: this code does not recurse subdirectories! + /// // Status messages will be written to Console.Out + /// String[] filenames = System.IO.Directory.GetFiles(DirectoryToZip); + /// zip.AddFiles(filenames); + /// zip.Save(); + /// } + /// + /// + /// + /// Using zip As New ZipFile("Backup.zip", Console.Out) + /// ' Store all files found in the top level directory, into the zip archive. + /// ' note: this code does not recurse subdirectories! + /// ' Status messages will be written to Console.Out + /// Dim filenames As String() = System.IO.Directory.GetFiles(DirectoryToZip) + /// zip.AddFiles(filenames) + /// zip.Save() + /// End Using + /// + /// + /// + /// The filename to use for the new zip archive. + /// A TextWriter to use for writing + /// verbose status messages. + public ZipFile(string fileName, TextWriter statusMessageWriter) + { + try + { + _InitInstance(fileName, statusMessageWriter); + } + catch (Exception e1) + { + throw new ZipException(String.Format("{0} is not a valid zip file", fileName), e1); + } + } + + + /// + /// Creates a new ZipFile instance, using the specified name for the + /// filename, the specified status message writer, and the specified Encoding. + /// + /// + /// + /// + /// This constructor works like the ZipFile + /// constructor that accepts a single string argument. See that + /// reference for detail on what this constructor does. + /// + /// + /// + /// This version of the constructor allows the caller to pass in a + /// TextWriter, and an Encoding. The TextWriter will collect + /// verbose messages that are generated by the library during extraction or + /// creation of the zip archive. A console application may wish to pass + /// System.Console.Out to get messages on the Console. A graphical or + /// headless application may wish to capture the messages in a different + /// TextWriter, for example, a StringWriter, and then display + /// the messages in a TextBox, or generate an audit log of + /// ZipFile operations. + /// + /// + /// + /// The Encoding is used as the default alternate encoding for entries + /// with filenames or comments that cannot be encoded with the IBM437 code + /// page. This is a equivalent to setting the property on the ZipFile + /// instance after construction. + /// + /// + /// + /// To encrypt the data for the files added to the ZipFile instance, + /// set the Password property after creating the ZipFile + /// instance. + /// + /// + /// + /// Instances of the ZipFile class are not multi-thread safe. You may + /// not party on a single instance with multiple threads. You may have + /// multiple threads that each use a distinct ZipFile instance, or you + /// can synchronize multi-thread access to a single instance. + /// + /// + /// + /// + /// + /// Thrown if fileName refers to an existing file that is not a valid zip file. + /// + /// + /// The filename to use for the new zip archive. + /// A TextWriter to use for writing verbose + /// status messages. + /// + /// The Encoding is used as the default alternate encoding for entries with + /// filenames or comments that cannot be encoded with the IBM437 code page. + /// + public ZipFile(string fileName, TextWriter statusMessageWriter, + System.Text.Encoding encoding) + { + try + { + AlternateEncoding = encoding; + AlternateEncodingUsage = ZipOption.Always; + _InitInstance(fileName, statusMessageWriter); + } + catch (Exception e1) + { + throw new ZipException(String.Format("{0} is not a valid zip file", fileName), e1); + } + } + + + + + /// + /// Initialize a ZipFile instance by reading in a zip file. + /// + /// + /// + /// + /// + /// This method is primarily useful from COM Automation environments, when + /// reading or extracting zip files. In COM, it is not possible to invoke + /// parameterized constructors for a class. A COM Automation application can + /// update a zip file by using the default (no argument) + /// constructor, then calling Initialize() to read the contents + /// of an on-disk zip archive into the ZipFile instance. + /// + /// + /// + /// .NET applications are encouraged to use the ZipFile.Read() methods + /// for better clarity. + /// + /// + /// + /// the name of the existing zip file to read in. + public void Initialize(string fileName) + { + try + { + _InitInstance(fileName, null); + } + catch (Exception e1) + { + throw new ZipException(String.Format("{0} is not a valid zip file", fileName), e1); + } + } + + + + private void _initEntriesDictionary() + { + // workitem 9868 + StringComparer sc = (CaseSensitiveRetrieval) ? StringComparer.Ordinal : StringComparer.OrdinalIgnoreCase; + _entries = (_entries == null) + ? new Dictionary(sc) + : new Dictionary(_entries, sc); + } + + + private void _InitInstance(string zipFileName, TextWriter statusMessageWriter) + { + // create a new zipfile + _name = zipFileName; + _StatusMessageTextWriter = statusMessageWriter; + _contentsChanged = true; + AddDirectoryWillTraverseReparsePoints = true; // workitem 8617 + CompressionLevel = Ionic.Zlib.CompressionLevel.Default; +#if !NETCF + ParallelDeflateThreshold = 512 * 1024; +#endif + // workitem 7685, 9868 + _initEntriesDictionary(); + + if (File.Exists(_name)) + { + if (FullScan) + ReadIntoInstance_Orig(this); + else + ReadIntoInstance(this); + this._fileAlreadyExists = true; + } + + return; + } + #endregion + + + + #region Indexers and Collections + + private List ZipEntriesAsList + { + get + { + if (_zipEntriesAsList == null) + _zipEntriesAsList = new List(_entries.Values); + return _zipEntriesAsList; + } + } + + /// + /// This is an integer indexer into the Zip archive. + /// + /// + /// + /// + /// This property is read-only. + /// + /// + /// + /// Internally, the ZipEntry instances that belong to the + /// ZipFile are stored in a Dictionary. When you use this + /// indexer the first time, it creates a read-only + /// List<ZipEntry> from the Dictionary.Values Collection. + /// If at any time you modify the set of entries in the ZipFile, + /// either by adding an entry, removing an entry, or renaming an + /// entry, a new List will be created, and the numeric indexes for the + /// remaining entries may be different. + /// + /// + /// + /// This means you cannot rename any ZipEntry from + /// inside an enumeration of the zip file. + /// + /// + /// + /// The index value. + /// + /// + /// + /// + /// + /// The ZipEntry within the Zip archive at the specified index. If the + /// entry does not exist in the archive, this indexer throws. + /// + /// + public ZipEntry this[int ix] + { + // workitem 6402 + get + { + return ZipEntriesAsList[ix]; + } + } + + + /// + /// This is a name-based indexer into the Zip archive. + /// + /// + /// + /// + /// This property is read-only. + /// + /// + /// + /// The property on the ZipFile + /// determines whether retrieval via this indexer is done via case-sensitive + /// comparisons. By default, retrieval is not case sensitive. This makes + /// sense on Windows, in which filesystems are not case sensitive. + /// + /// + /// + /// Regardless of case-sensitivity, it is not always the case that + /// this[value].FileName == value. In other words, the FileName + /// property of the ZipEntry retrieved with this indexer, may or may + /// not be equal to the index value. + /// + /// + /// + /// This is because DotNetZip performs a normalization of filenames passed to + /// this indexer, before attempting to retrieve the item. That normalization + /// includes: removal of a volume letter and colon, swapping backward slashes + /// for forward slashes. So, zip["dir1\\entry1.txt"].FileName == + /// "dir1/entry.txt". + /// + /// + /// + /// Directory entries in the zip file may be retrieved via this indexer only + /// with names that have a trailing slash. DotNetZip automatically appends a + /// trailing slash to the names of any directory entries added to a zip. + /// + /// + /// + /// + /// + /// This example extracts only the entries in a zip file that are .txt files. + /// + /// using (ZipFile zip = ZipFile.Read("PackedDocuments.zip")) + /// { + /// foreach (string s1 in zip.EntryFilenames) + /// { + /// if (s1.EndsWith(".txt")) + /// zip[s1].Extract("textfiles"); + /// } + /// } + /// + /// + /// Using zip As ZipFile = ZipFile.Read("PackedDocuments.zip") + /// Dim s1 As String + /// For Each s1 In zip.EntryFilenames + /// If s1.EndsWith(".txt") Then + /// zip(s1).Extract("textfiles") + /// End If + /// Next + /// End Using + /// + /// + /// + /// + /// + /// Thrown if the caller attempts to assign a non-null value to the indexer. + /// + /// + /// + /// The name of the file, including any directory path, to retrieve from the + /// zip. The filename match is not case-sensitive by default; you can use the + /// property to change this behavior. The + /// pathname can use forward-slashes or backward slashes. + /// + /// + /// + /// The ZipEntry within the Zip archive, given by the specified + /// filename. If the named entry does not exist in the archive, this indexer + /// returns null (Nothing in VB). + /// + /// + public ZipEntry this[String fileName] + { + get + { + var key = SharedUtilities.NormalizePathForUseInZipFile(fileName); + if (_entries.ContainsKey(key)) + return _entries[key]; + // workitem 11056 + key = key.Replace("/", "\\"); + if (_entries.ContainsKey(key)) + return _entries[key]; + return null; + +#if MESSY + foreach (ZipEntry e in _entries.Values) + { + if (this.CaseSensitiveRetrieval) + { + // check for the file match with a case-sensitive comparison. + if (e.FileName == fileName) return e; + // also check for equivalence + if (fileName.Replace("\\", "/") == e.FileName) return e; + if (e.FileName.Replace("\\", "/") == fileName) return e; + + // check for a difference only in trailing slash + if (e.FileName.EndsWith("/")) + { + var fileNameNoSlash = e.FileName.Trim("/".ToCharArray()); + if (fileNameNoSlash == fileName) return e; + // also check for equivalence + if (fileName.Replace("\\", "/") == fileNameNoSlash) return e; + if (fileNameNoSlash.Replace("\\", "/") == fileName) return e; + } + + } + else + { + // check for the file match in a case-insensitive manner. + if (String.Compare(e.FileName, fileName, StringComparison.CurrentCultureIgnoreCase) == 0) return e; + // also check for equivalence + if (String.Compare(fileName.Replace("\\", "/"), e.FileName, StringComparison.CurrentCultureIgnoreCase) == 0) return e; + if (String.Compare(e.FileName.Replace("\\", "/"), fileName, StringComparison.CurrentCultureIgnoreCase) == 0) return e; + + // check for a difference only in trailing slash + if (e.FileName.EndsWith("/")) + { + var fileNameNoSlash = e.FileName.Trim("/".ToCharArray()); + + if (String.Compare(fileNameNoSlash, fileName, StringComparison.CurrentCultureIgnoreCase) == 0) return e; + // also check for equivalence + if (String.Compare(fileName.Replace("\\", "/"), fileNameNoSlash, StringComparison.CurrentCultureIgnoreCase) == 0) return e; + if (String.Compare(fileNameNoSlash.Replace("\\", "/"), fileName, StringComparison.CurrentCultureIgnoreCase) == 0) return e; + + } + + } + + } + return null; + +#endif + } + } + + + /// + /// The list of filenames for the entries contained within the zip archive. + /// + /// + /// + /// According to the ZIP specification, the names of the entries use forward + /// slashes in pathnames. If you are scanning through the list, you may have + /// to swap forward slashes for backslashes. + /// + /// + /// + /// + /// + /// This example shows one way to test if a filename is already contained + /// within a zip archive. + /// + /// String zipFileToRead= "PackedDocuments.zip"; + /// string candidate = "DatedMaterial.xps"; + /// using (ZipFile zip = new ZipFile(zipFileToRead)) + /// { + /// if (zip.EntryFilenames.Contains(candidate)) + /// Console.WriteLine("The file '{0}' exists in the zip archive '{1}'", + /// candidate, + /// zipFileName); + /// else + /// Console.WriteLine("The file, '{0}', does not exist in the zip archive '{1}'", + /// candidate, + /// zipFileName); + /// Console.WriteLine(); + /// } + /// + /// + /// Dim zipFileToRead As String = "PackedDocuments.zip" + /// Dim candidate As String = "DatedMaterial.xps" + /// Using zip As ZipFile.Read(ZipFileToRead) + /// If zip.EntryFilenames.Contains(candidate) Then + /// Console.WriteLine("The file '{0}' exists in the zip archive '{1}'", _ + /// candidate, _ + /// zipFileName) + /// Else + /// Console.WriteLine("The file, '{0}', does not exist in the zip archive '{1}'", _ + /// candidate, _ + /// zipFileName) + /// End If + /// Console.WriteLine + /// End Using + /// + /// + /// + /// + /// The list of strings for the filenames contained within the Zip archive. + /// + /// + public System.Collections.Generic.ICollection EntryFileNames + { + get + { + return _entries.Keys; + } + } + + + /// + /// Returns the readonly collection of entries in the Zip archive. + /// + /// + /// + /// + /// + /// If there are no entries in the current ZipFile, the value returned is a + /// non-null zero-element collection. If there are entries in the zip file, + /// the elements are returned in no particular order. + /// + /// + /// This is the implied enumerator on the ZipFile class. If you use a + /// ZipFile instance in a context that expects an enumerator, you will + /// get this collection. + /// + /// + /// + public System.Collections.Generic.ICollection Entries + { + get + { + return _entries.Values; + } + } + + + /// + /// Returns a readonly collection of entries in the Zip archive, sorted by FileName. + /// + /// + /// + /// If there are no entries in the current ZipFile, the value returned + /// is a non-null zero-element collection. If there are entries in the zip + /// file, the elements are returned sorted by the name of the entry. + /// + /// + /// + /// + /// This example fills a Windows Forms ListView with the entries in a zip file. + /// + /// + /// using (ZipFile zip = ZipFile.Read(zipFile)) + /// { + /// foreach (ZipEntry entry in zip.EntriesSorted) + /// { + /// ListViewItem item = new ListViewItem(n.ToString()); + /// n++; + /// string[] subitems = new string[] { + /// entry.FileName.Replace("/","\\"), + /// entry.LastModified.ToString("yyyy-MM-dd HH:mm:ss"), + /// entry.UncompressedSize.ToString(), + /// String.Format("{0,5:F0}%", entry.CompressionRatio), + /// entry.CompressedSize.ToString(), + /// (entry.UsesEncryption) ? "Y" : "N", + /// String.Format("{0:X8}", entry.Crc)}; + /// + /// foreach (String s in subitems) + /// { + /// ListViewItem.ListViewSubItem subitem = new ListViewItem.ListViewSubItem(); + /// subitem.Text = s; + /// item.SubItems.Add(subitem); + /// } + /// + /// this.listView1.Items.Add(item); + /// } + /// } + /// + /// + /// + /// + public System.Collections.Generic.ICollection EntriesSorted + { + get + { + var coll = new System.Collections.Generic.List(); + foreach (var e in this.Entries) + { + coll.Add(e); + } + StringComparison sc = (CaseSensitiveRetrieval) ? StringComparison.Ordinal : StringComparison.OrdinalIgnoreCase; + + coll.Sort((x, y) => { return String.Compare(x.FileName, y.FileName, sc); }); + return coll.AsReadOnly(); + } + } + + + /// + /// Returns the number of entries in the Zip archive. + /// + public int Count + { + get + { + return _entries.Count; + } + } + + + + /// + /// Removes the given ZipEntry from the zip archive. + /// + /// + /// + /// + /// After calling RemoveEntry, the application must call Save to + /// make the changes permanent. + /// + /// + /// + /// + /// Thrown if the specified ZipEntry does not exist in the ZipFile. + /// + /// + /// + /// In this example, all entries in the zip archive dating from before + /// December 31st, 2007, are removed from the archive. This is actually much + /// easier if you use the RemoveSelectedEntries method. But I needed an + /// example for RemoveEntry, so here it is. + /// + /// String ZipFileToRead = "ArchiveToModify.zip"; + /// System.DateTime Threshold = new System.DateTime(2007,12,31); + /// using (ZipFile zip = ZipFile.Read(ZipFileToRead)) + /// { + /// var EntriesToRemove = new System.Collections.Generic.List<ZipEntry>(); + /// foreach (ZipEntry e in zip) + /// { + /// if (e.LastModified < Threshold) + /// { + /// // We cannot remove the entry from the list, within the context of + /// // an enumeration of said list. + /// // So we add the doomed entry to a list to be removed later. + /// EntriesToRemove.Add(e); + /// } + /// } + /// + /// // actually remove the doomed entries. + /// foreach (ZipEntry zombie in EntriesToRemove) + /// zip.RemoveEntry(zombie); + /// + /// zip.Comment= String.Format("This zip archive was updated at {0}.", + /// System.DateTime.Now.ToString("G")); + /// + /// // save with a different name + /// zip.Save("Archive-Updated.zip"); + /// } + /// + /// + /// + /// Dim ZipFileToRead As String = "ArchiveToModify.zip" + /// Dim Threshold As New DateTime(2007, 12, 31) + /// Using zip As ZipFile = ZipFile.Read(ZipFileToRead) + /// Dim EntriesToRemove As New System.Collections.Generic.List(Of ZipEntry) + /// Dim e As ZipEntry + /// For Each e In zip + /// If (e.LastModified < Threshold) Then + /// ' We cannot remove the entry from the list, within the context of + /// ' an enumeration of said list. + /// ' So we add the doomed entry to a list to be removed later. + /// EntriesToRemove.Add(e) + /// End If + /// Next + /// + /// ' actually remove the doomed entries. + /// Dim zombie As ZipEntry + /// For Each zombie In EntriesToRemove + /// zip.RemoveEntry(zombie) + /// Next + /// zip.Comment = String.Format("This zip archive was updated at {0}.", DateTime.Now.ToString("G")) + /// 'save as a different name + /// zip.Save("Archive-Updated.zip") + /// End Using + /// + /// + /// + /// + /// The ZipEntry to remove from the zip. + /// + /// + /// + /// + public void RemoveEntry(ZipEntry entry) + { + //if (!_entries.Values.Contains(entry)) + // throw new ArgumentException("The entry you specified does not exist in the zip archive."); + if (entry == null) + throw new ArgumentNullException("entry"); + + _entries.Remove(SharedUtilities.NormalizePathForUseInZipFile(entry.FileName)); + _zipEntriesAsList = null; + +#if NOTNEEDED + if (_direntries != null) + { + bool FoundAndRemovedDirEntry = false; + foreach (ZipDirEntry de1 in _direntries) + { + if (entry.FileName == de1.FileName) + { + _direntries.Remove(de1); + FoundAndRemovedDirEntry = true; + break; + } + } + + if (!FoundAndRemovedDirEntry) + throw new BadStateException("The entry to be removed was not found in the directory."); + } +#endif + _contentsChanged = true; + } + + + + + /// + /// Removes the ZipEntry with the given filename from the zip archive. + /// + /// + /// + /// + /// After calling RemoveEntry, the application must call Save to + /// make the changes permanent. + /// + /// + /// + /// + /// + /// Thrown if the ZipFile is not updatable. + /// + /// + /// + /// Thrown if a ZipEntry with the specified filename does not exist in + /// the ZipFile. + /// + /// + /// + /// + /// This example shows one way to remove an entry with a given filename from + /// an existing zip archive. + /// + /// + /// String zipFileToRead= "PackedDocuments.zip"; + /// string candidate = "DatedMaterial.xps"; + /// using (ZipFile zip = ZipFile.Read(zipFileToRead)) + /// { + /// if (zip.EntryFilenames.Contains(candidate)) + /// { + /// zip.RemoveEntry(candidate); + /// zip.Comment= String.Format("The file '{0}' has been removed from this archive.", + /// Candidate); + /// zip.Save(); + /// } + /// } + /// + /// + /// Dim zipFileToRead As String = "PackedDocuments.zip" + /// Dim candidate As String = "DatedMaterial.xps" + /// Using zip As ZipFile = ZipFile.Read(zipFileToRead) + /// If zip.EntryFilenames.Contains(candidate) Then + /// zip.RemoveEntry(candidate) + /// zip.Comment = String.Format("The file '{0}' has been removed from this archive.", Candidate) + /// zip.Save + /// End If + /// End Using + /// + /// + /// + /// + /// The name of the file, including any directory path, to remove from the zip. + /// The filename match is not case-sensitive by default; you can use the + /// CaseSensitiveRetrieval property to change this behavior. The + /// pathname can use forward-slashes or backward slashes. + /// + /// + public void RemoveEntry(String fileName) + { + string modifiedName = ZipEntry.NameInArchive(fileName, null); + ZipEntry e = this[modifiedName]; + if (e == null) + throw new ArgumentException("The entry you specified was not found in the zip archive."); + + RemoveEntry(e); + } + + + #endregion + + #region Destructors and Disposers + + // /// + // /// This is the class Destructor, which gets called implicitly when the instance + // /// is destroyed. Because the ZipFile type implements IDisposable, this + // /// method calls Dispose(false). + // /// + // ~ZipFile() + // { + // // call Dispose with false. Since we're in the + // // destructor call, the managed resources will be + // // disposed of anyways. + // Dispose(false); + // } + + /// + /// Closes the read and write streams associated + /// to the ZipFile, if necessary. + /// + /// + /// + /// The Dispose() method is generally employed implicitly, via a using(..) {..} + /// statement. (Using...End Using in VB) If you do not employ a using + /// statement, insure that your application calls Dispose() explicitly. For + /// example, in a Powershell application, or an application that uses the COM + /// interop interface, you must call Dispose() explicitly. + /// + /// + /// + /// This example extracts an entry selected by name, from the Zip file to the + /// Console. + /// + /// using (ZipFile zip = ZipFile.Read(zipfile)) + /// { + /// foreach (ZipEntry e in zip) + /// { + /// if (WantThisEntry(e.FileName)) + /// zip.Extract(e.FileName, Console.OpenStandardOutput()); + /// } + /// } // Dispose() is called implicitly here. + /// + /// + /// + /// Using zip As ZipFile = ZipFile.Read(zipfile) + /// Dim e As ZipEntry + /// For Each e In zip + /// If WantThisEntry(e.FileName) Then + /// zip.Extract(e.FileName, Console.OpenStandardOutput()) + /// End If + /// Next + /// End Using ' Dispose is implicity called here + /// + /// + public void Dispose() + { + // dispose of the managed and unmanaged resources + Dispose(true); + + // tell the GC that the Finalize process no longer needs + // to be run for this object. + GC.SuppressFinalize(this); + } + + /// + /// Disposes any managed resources, if the flag is set, then marks the + /// instance disposed. This method is typically not called explicitly from + /// application code. + /// + /// + /// + /// Applications should call the no-arg Dispose method. + /// + /// + /// + /// indicates whether the method should dispose streams or not. + /// + protected virtual void Dispose(bool disposeManagedResources) + { + if (!this._disposed) + { + if (disposeManagedResources) + { + // dispose managed resources + if (_ReadStreamIsOurs) + { + if (_readstream != null) + { + // workitem 7704 +#if NETCF + _readstream.Close(); +#else + _readstream.Dispose(); +#endif + _readstream = null; + } + } + // only dispose the writestream if there is a backing file + if ((_temporaryFileName != null) && (_name != null)) + if (_writestream != null) + { + // workitem 7704 +#if NETCF + _writestream.Close(); +#else + _writestream.Dispose(); +#endif + _writestream = null; + } + +#if !NETCF + // workitem 10030 + if (this.ParallelDeflater != null) + { + this.ParallelDeflater.Dispose(); + this.ParallelDeflater = null; + } +#endif + } + this._disposed = true; + } + } + #endregion + + + #region private properties + + internal Stream ReadStream + { + get + { + if (_readstream == null) + { + if (_readName != null || _name !=null) + { + _readstream = File.Open(_readName ?? _name, + FileMode.Open, + FileAccess.Read, + FileShare.Read | FileShare.Write); + _ReadStreamIsOurs = true; + } + } + return _readstream; + } + } + + + + private Stream WriteStream + { + // workitem 9763 + get + { + if (_writestream != null) return _writestream; + if (_name == null) return _writestream; + + if (_maxOutputSegmentSize != 0) + { + _writestream = ZipSegmentedStream.ForWriting(this._name, _maxOutputSegmentSize); + return _writestream; + } + + SharedUtilities.CreateAndOpenUniqueTempFile(TempFileFolder ?? Path.GetDirectoryName(_name), + out _writestream, + out _temporaryFileName); + return _writestream; + } + set + { + if (value != null) + throw new ZipException("Cannot set the stream to a non-null value."); + _writestream = null; + } + } + #endregion + + #region private fields + private TextWriter _StatusMessageTextWriter; + private bool _CaseSensitiveRetrieval; + private Stream _readstream; + private Stream _writestream; + private UInt16 _versionMadeBy; + private UInt16 _versionNeededToExtract; + private UInt32 _diskNumberWithCd; + private Int32 _maxOutputSegmentSize; + private UInt32 _numberOfSegmentsForMostRecentSave; + private ZipErrorAction _zipErrorAction; + private bool _disposed; + //private System.Collections.Generic.List _entries; + private System.Collections.Generic.Dictionary _entries; + private List _zipEntriesAsList; + private string _name; + private string _readName; + private string _Comment; + internal string _Password; + private bool _emitNtfsTimes = true; + private bool _emitUnixTimes; + private Ionic.Zlib.CompressionStrategy _Strategy = Ionic.Zlib.CompressionStrategy.Default; + private Ionic.Zip.CompressionMethod _compressionMethod = Ionic.Zip.CompressionMethod.Deflate; + private bool _fileAlreadyExists; + private string _temporaryFileName; + private bool _contentsChanged; + private bool _hasBeenSaved; + private String _TempFileFolder; + private bool _ReadStreamIsOurs = true; + private object LOCK = new object(); + private bool _saveOperationCanceled; + private bool _extractOperationCanceled; + private bool _addOperationCanceled; + private EncryptionAlgorithm _Encryption; + private bool _JustSaved; + private long _locEndOfCDS = -1; + private uint _OffsetOfCentralDirectory; + private Int64 _OffsetOfCentralDirectory64; + private Nullable _OutputUsesZip64; + internal bool _inExtractAll; + private System.Text.Encoding _alternateEncoding = System.Text.Encoding.GetEncoding("IBM437"); // UTF-8 + private ZipOption _alternateEncodingUsage = ZipOption.Never; + private static System.Text.Encoding _defaultEncoding = System.Text.Encoding.GetEncoding("IBM437"); + + private int _BufferSize = BufferSizeDefault; + +#if !NETCF + internal Ionic.Zlib.ParallelDeflateOutputStream ParallelDeflater; + private long _ParallelDeflateThreshold; + private int _maxBufferPairs = 16; +#endif + + internal Zip64Option _zip64 = Zip64Option.Default; +#pragma warning disable 649 + private bool _SavingSfx; +#pragma warning restore 649 + + /// + /// Default size of the buffer used for IO. + /// + public static readonly int BufferSizeDefault = 32768; + + #endregion + } + + /// + /// Options for using ZIP64 extensions when saving zip archives. + /// + /// + /// + /// + /// + /// Designed many years ago, the original zip + /// specification from PKWARE allowed for 32-bit quantities for the + /// compressed and uncompressed sizes of zip entries, as well as a 32-bit quantity + /// for specifying the length of the zip archive itself, and a maximum of 65535 + /// entries. These limits are now regularly exceeded in many backup and archival + /// scenarios. Recently, PKWare added extensions to the original zip spec, called + /// "ZIP64 extensions", to raise those limitations. This property governs whether + /// DotNetZip will use those extensions when writing zip archives. The use of + /// these extensions is optional and explicit in DotNetZip because, despite the + /// status of ZIP64 as a bona fide standard, many other zip tools and libraries do + /// not support ZIP64, and therefore a zip file with ZIP64 extensions may be + /// unreadable by some of those other tools. + /// + /// + /// + /// Set this property to to always use ZIP64 + /// extensions when saving, regardless of whether your zip archive needs it. + /// Suppose you add 5 files, each under 100k, to a ZipFile. If you specify Always + /// for this flag, you will get a ZIP64 archive, though the archive does not need + /// to use ZIP64 because none of the original zip limits had been exceeded. + /// + /// + /// + /// Set this property to to tell the DotNetZip + /// library to never use ZIP64 extensions. This is useful for maximum + /// compatibility and interoperability, at the expense of the capability of + /// handling large files or large archives. NB: Windows Explorer in Windows XP + /// and Windows Vista cannot currently extract files from a zip64 archive, so if + /// you want to guarantee that a zip archive produced by this library will work in + /// Windows Explorer, use Never. If you set this property to , and your application creates a zip that would + /// exceed one of the Zip limits, the library will throw an exception while saving + /// the zip file. + /// + /// + /// + /// Set this property to to tell the + /// DotNetZip library to use the ZIP64 extensions when required by the + /// entry. After the file is compressed, the original and compressed sizes are + /// checked, and if they exceed the limits described above, then zip64 can be + /// used. That is the general idea, but there is an additional wrinkle when saving + /// to a non-seekable device, like the ASP.NET Response.OutputStream, or + /// Console.Out. When using non-seekable streams for output, the entry + /// header - which indicates whether zip64 is in use - is emitted before it is + /// known if zip64 is necessary. It is only after all entries have been saved + /// that it can be known if ZIP64 will be required. On seekable output streams, + /// after saving all entries, the library can seek backward and re-emit the zip + /// file header to be consistent with the actual ZIP64 requirement. But using a + /// non-seekable output stream, the library cannot seek backward, so the header + /// can never be changed. In other words, the archive's use of ZIP64 extensions is + /// not alterable after the header is emitted. Therefore, when saving to + /// non-seekable streams, using is the same + /// as using : it will always produce a zip + /// archive that uses ZIP64 extensions. + /// + /// + /// + public enum Zip64Option + { + /// + /// The default behavior, which is "Never". + /// (For COM clients, this is a 0 (zero).) + /// + Default = 0, + /// + /// Do not use ZIP64 extensions when writing zip archives. + /// (For COM clients, this is a 0 (zero).) + /// + Never = 0, + /// + /// Use ZIP64 extensions when writing zip archives, as necessary. + /// For example, when a single entry exceeds 0xFFFFFFFF in size, or when the archive as a whole + /// exceeds 0xFFFFFFFF in size, or when there are more than 65535 entries in an archive. + /// (For COM clients, this is a 1.) + /// + AsNecessary = 1, + /// + /// Always use ZIP64 extensions when writing zip archives, even when unnecessary. + /// (For COM clients, this is a 2.) + /// + Always + } + + + /// + /// An enum representing the values on a three-way toggle switch + /// for various options in the library. This might be used to + /// specify whether to employ a particular text encoding, or to use + /// ZIP64 extensions, or some other option. + /// + public enum ZipOption + { + /// + /// The default behavior. This is the same as "Never". + /// (For COM clients, this is a 0 (zero).) + /// + Default = 0, + /// + /// Never use the associated option. + /// (For COM clients, this is a 0 (zero).) + /// + Never = 0, + /// + /// Use the associated behavior "as necessary." + /// (For COM clients, this is a 1.) + /// + AsNecessary = 1, + /// + /// Use the associated behavior Always, whether necessary or not. + /// (For COM clients, this is a 2.) + /// + Always + } + + + enum AddOrUpdateAction + { + AddOnly = 0, + AddOrUpdate + } + +} + + + +// ================================================================== +// +// Information on the ZIP format: +// +// From +// http://www.pkware.com/documents/casestudies/APPNOTE.TXT +// +// Overall .ZIP file format: +// +// [local file header 1] +// [file data 1] +// [data descriptor 1] ** sometimes +// . +// . +// . +// [local file header n] +// [file data n] +// [data descriptor n] ** sometimes +// [archive decryption header] +// [archive extra data record] +// [central directory] +// [zip64 end of central directory record] +// [zip64 end of central directory locator] +// [end of central directory record] +// +// Local File Header format: +// local file header signature ... 4 bytes (0x04034b50) +// version needed to extract ..... 2 bytes +// general purpose bit field ..... 2 bytes +// compression method ............ 2 bytes +// last mod file time ............ 2 bytes +// last mod file date............. 2 bytes +// crc-32 ........................ 4 bytes +// compressed size................ 4 bytes +// uncompressed size.............. 4 bytes +// file name length............... 2 bytes +// extra field length ............ 2 bytes +// file name varies +// extra field varies +// +// +// Data descriptor: (used only when bit 3 of the general purpose bitfield is set) +// (although, I have found zip files where bit 3 is not set, yet this descriptor is present!) +// local file header signature 4 bytes (0x08074b50) ** sometimes!!! Not always +// crc-32 4 bytes +// compressed size 4 bytes +// uncompressed size 4 bytes +// +// +// Central directory structure: +// +// [file header 1] +// . +// . +// . +// [file header n] +// [digital signature] +// +// +// File header: (This is a ZipDirEntry) +// central file header signature 4 bytes (0x02014b50) +// version made by 2 bytes +// version needed to extract 2 bytes +// general purpose bit flag 2 bytes +// compression method 2 bytes +// last mod file time 2 bytes +// last mod file date 2 bytes +// crc-32 4 bytes +// compressed size 4 bytes +// uncompressed size 4 bytes +// file name length 2 bytes +// extra field length 2 bytes +// file comment length 2 bytes +// disk number start 2 bytes +// internal file attributes ** 2 bytes +// external file attributes *** 4 bytes +// relative offset of local header 4 bytes +// file name (variable size) +// extra field (variable size) +// file comment (variable size) +// +// ** The internal file attributes, near as I can tell, +// uses 0x01 for a file and a 0x00 for a directory. +// +// ***The external file attributes follows the MS-DOS file attribute byte, described here: +// at http://support.microsoft.com/kb/q125019/ +// 0x0010 => directory +// 0x0020 => file +// +// +// End of central directory record: +// +// end of central dir signature 4 bytes (0x06054b50) +// number of this disk 2 bytes +// number of the disk with the +// start of the central directory 2 bytes +// total number of entries in the +// central directory on this disk 2 bytes +// total number of entries in +// the central directory 2 bytes +// size of the central directory 4 bytes +// offset of start of central +// directory with respect to +// the starting disk number 4 bytes +// .ZIP file comment length 2 bytes +// .ZIP file comment (variable size) +// +// date and time are packed values, as MSDOS did them +// time: bits 0-4 : seconds (divided by 2) +// 5-10: minute +// 11-15: hour +// date bits 0-4 : day +// 5-8: month +// 9-15 year (since 1980) +// +// see http://msdn.microsoft.com/en-us/library/ms724274(VS.85).aspx + diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.x-IEnumerable.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.x-IEnumerable.cs new file mode 100644 index 00000000..e8178d94 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipFile.x-IEnumerable.cs @@ -0,0 +1,154 @@ +// ZipFile.x-IEnumerable.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2006, 2007, 2008, 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-December-26 15:13:26> +// +// ------------------------------------------------------------------ +// +// This module defines smoe methods for IEnumerable support. It is +// particularly important for COM to have these things in a separate module. +// +// ------------------------------------------------------------------ + + +namespace Ionic.Zip +{ + + // For some weird reason, the method with the DispId(-4) attribute, which is used as + // the _NewEnum() method, and which is required to get enumeration to work from COM + // environments like VBScript and Javascript (etc) must be the LAST MEMBER in the + // source. In the event of Partial classes, it needs to be the last member defined + // in the last source module. The source modules are ordered alphabetically by + // filename. Not sure why this is true. In any case, we put the enumeration stuff + // here in this oddly-named module, for this reason. + // + + + + public partial class ZipFile + { + + + + + /// + /// Generic IEnumerator support, for use of a ZipFile in an enumeration. + /// + /// + /// + /// You probably do not want to call GetEnumerator explicitly. Instead + /// it is implicitly called when you use a loop in C#, or a + /// For Each loop in VB.NET. + /// + /// + /// + /// This example reads a zipfile of a given name, then enumerates the + /// entries in that zip file, and displays the information about each + /// entry on the Console. + /// + /// using (ZipFile zip = ZipFile.Read(zipfile)) + /// { + /// bool header = true; + /// foreach (ZipEntry e in zip) + /// { + /// if (header) + /// { + /// System.Console.WriteLine("Zipfile: {0}", zip.Name); + /// System.Console.WriteLine("Version Needed: 0x{0:X2}", e.VersionNeeded); + /// System.Console.WriteLine("BitField: 0x{0:X2}", e.BitField); + /// System.Console.WriteLine("Compression Method: 0x{0:X2}", e.CompressionMethod); + /// System.Console.WriteLine("\n{1,-22} {2,-6} {3,4} {4,-8} {0}", + /// "Filename", "Modified", "Size", "Ratio", "Packed"); + /// System.Console.WriteLine(new System.String('-', 72)); + /// header = false; + /// } + /// + /// System.Console.WriteLine("{1,-22} {2,-6} {3,4:F0}% {4,-8} {0}", + /// e.FileName, + /// e.LastModified.ToString("yyyy-MM-dd HH:mm:ss"), + /// e.UncompressedSize, + /// e.CompressionRatio, + /// e.CompressedSize); + /// + /// e.Extract(); + /// } + /// } + /// + /// + /// + /// Dim ZipFileToExtract As String = "c:\foo.zip" + /// Using zip As ZipFile = ZipFile.Read(ZipFileToExtract) + /// Dim header As Boolean = True + /// Dim e As ZipEntry + /// For Each e In zip + /// If header Then + /// Console.WriteLine("Zipfile: {0}", zip.Name) + /// Console.WriteLine("Version Needed: 0x{0:X2}", e.VersionNeeded) + /// Console.WriteLine("BitField: 0x{0:X2}", e.BitField) + /// Console.WriteLine("Compression Method: 0x{0:X2}", e.CompressionMethod) + /// Console.WriteLine(ChrW(10) & "{1,-22} {2,-6} {3,4} {4,-8} {0}", _ + /// "Filename", "Modified", "Size", "Ratio", "Packed" ) + /// Console.WriteLine(New String("-"c, 72)) + /// header = False + /// End If + /// Console.WriteLine("{1,-22} {2,-6} {3,4:F0}% {4,-8} {0}", _ + /// e.FileName, _ + /// e.LastModified.ToString("yyyy-MM-dd HH:mm:ss"), _ + /// e.UncompressedSize, _ + /// e.CompressionRatio, _ + /// e.CompressedSize ) + /// e.Extract + /// Next + /// End Using + /// + /// + /// + /// A generic enumerator suitable for use within a foreach loop. + public System.Collections.Generic.IEnumerator GetEnumerator() + { + foreach (ZipEntry e in _entries.Values) + yield return e; + } + + System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator() + { + return GetEnumerator(); + } + + + /// + /// An IEnumerator, for use of a ZipFile in a foreach construct. + /// + /// + /// + /// This method is included for COM support. An application generally does not call + /// this method directly. It is called implicitly by COM clients when enumerating + /// the entries in the ZipFile instance. In VBScript, this is done with a For Each + /// statement. In Javascript, this is done with new Enumerator(zipfile). + /// + /// + /// + /// The IEnumerator over the entries in the ZipFile. + /// + [System.Runtime.InteropServices.DispId(-4)] + public System.Collections.IEnumerator GetNewEnum() // the name of this method is not significant + { + return GetEnumerator(); + } + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipInputStream.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipInputStream.cs new file mode 100644 index 00000000..9fa143b7 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipInputStream.cs @@ -0,0 +1,827 @@ +// ZipInputStream.cs +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2010 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-31 14:48:30> +// +// ------------------------------------------------------------------ +// +// This module defines the ZipInputStream class, which is a stream metaphor for +// reading zip files. This class does not depend on Ionic.Zip.ZipFile, but rather +// stands alongside it as an alternative "container" for ZipEntry, when reading zips. +// +// It adds one interesting method to the normal "stream" interface: GetNextEntry. +// +// ------------------------------------------------------------------ +// + +using System; +using System.Threading; +using System.Collections.Generic; +using System.IO; +using Ionic.Zip; + +namespace Ionic.Zip +{ + /// + /// Provides a stream metaphor for reading zip files. + /// + /// + /// + /// + /// This class provides an alternative programming model for reading zip files to + /// the one enabled by the class. Use this when reading zip + /// files, as an alternative to the class, when you would + /// like to use a Stream class to read the file. + /// + /// + /// + /// Some application designs require a readable stream for input. This stream can + /// be used to read a zip file, and extract entries. + /// + /// + /// + /// Both the ZipInputStream class and the ZipFile class can be used + /// to read and extract zip files. Both of them support many of the common zip + /// features, including Unicode, different compression levels, and ZIP64. The + /// programming models differ. For example, when extracting entries via calls to + /// the GetNextEntry() and Read() methods on the + /// ZipInputStream class, the caller is responsible for creating the file, + /// writing the bytes into the file, setting the attributes on the file, and + /// setting the created, last modified, and last accessed timestamps on the + /// file. All of these things are done automatically by a call to ZipEntry.Extract(). For this reason, the + /// ZipInputStream is generally recommended for when your application wants + /// to extract the data, without storing that data into a file. + /// + /// + /// + /// Aside from the obvious differences in programming model, there are some + /// differences in capability between the ZipFile class and the + /// ZipInputStream class. + /// + /// + /// + /// + /// ZipFile can be used to create or update zip files, or read and + /// extract zip files. ZipInputStream can be used only to read and + /// extract zip files. If you want to use a stream to create zip files, check + /// out the . + /// + /// + /// + /// ZipInputStream cannot read segmented or spanned + /// zip files. + /// + /// + /// + /// ZipInputStream will not read Zip file comments. + /// + /// + /// + /// When reading larger files, ZipInputStream will always underperform + /// ZipFile. This is because the ZipInputStream does a full scan on the + /// zip file, while the ZipFile class reads the central directory of the + /// zip file. + /// + /// + /// + /// + /// + public class ZipInputStream : Stream + { + /// + /// Create a ZipInputStream, wrapping it around an existing stream. + /// + /// + /// + /// + /// + /// While the class is generally easier + /// to use, this class provides an alternative to those + /// applications that want to read from a zipfile directly, + /// using a . + /// + /// + /// + /// Both the ZipInputStream class and the ZipFile class can be used + /// to read and extract zip files. Both of them support many of the common zip + /// features, including Unicode, different compression levels, and ZIP64. The + /// programming models differ. For example, when extracting entries via calls to + /// the GetNextEntry() and Read() methods on the + /// ZipInputStream class, the caller is responsible for creating the file, + /// writing the bytes into the file, setting the attributes on the file, and + /// setting the created, last modified, and last accessed timestamps on the + /// file. All of these things are done automatically by a call to ZipEntry.Extract(). For this reason, the + /// ZipInputStream is generally recommended for when your application wants + /// to extract the data, without storing that data into a file. + /// + /// + /// + /// Aside from the obvious differences in programming model, there are some + /// differences in capability between the ZipFile class and the + /// ZipInputStream class. + /// + /// + /// + /// + /// ZipFile can be used to create or update zip files, or read and extract + /// zip files. ZipInputStream can be used only to read and extract zip + /// files. If you want to use a stream to create zip files, check out the . + /// + /// + /// + /// ZipInputStream cannot read segmented or spanned + /// zip files. + /// + /// + /// + /// ZipInputStream will not read Zip file comments. + /// + /// + /// + /// When reading larger files, ZipInputStream will always underperform + /// ZipFile. This is because the ZipInputStream does a full scan on the + /// zip file, while the ZipFile class reads the central directory of the + /// zip file. + /// + /// + /// + /// + /// + /// + /// + /// The stream to read. It must be readable. This stream will be closed at + /// the time the ZipInputStream is closed. + /// + /// + /// + /// + /// This example shows how to read a zip file, and extract entries, using the + /// ZipInputStream class. + /// + /// + /// private void Unzip() + /// { + /// byte[] buffer= new byte[2048]; + /// int n; + /// using (var raw = File.Open(inputFileName, FileMode.Open, FileAccess.Read)) + /// { + /// using (var input= new ZipInputStream(raw)) + /// { + /// ZipEntry e; + /// while (( e = input.GetNextEntry()) != null) + /// { + /// if (e.IsDirectory) continue; + /// string outputPath = Path.Combine(extractDir, e.FileName); + /// using (var output = File.Open(outputPath, FileMode.Create, FileAccess.ReadWrite)) + /// { + /// while ((n= input.Read(buffer, 0, buffer.Length)) > 0) + /// { + /// output.Write(buffer,0,n); + /// } + /// } + /// } + /// } + /// } + /// } + /// + /// + /// + /// Private Sub UnZip() + /// Dim inputFileName As String = "MyArchive.zip" + /// Dim extractDir As String = "extract" + /// Dim buffer As Byte() = New Byte(2048) {} + /// Using raw As FileStream = File.Open(inputFileName, FileMode.Open, FileAccess.Read) + /// Using input As ZipInputStream = New ZipInputStream(raw) + /// Dim e As ZipEntry + /// Do While (Not e = input.GetNextEntry Is Nothing) + /// If Not e.IsDirectory Then + /// Using output As FileStream = File.Open(Path.Combine(extractDir, e.FileName), _ + /// FileMode.Create, FileAccess.ReadWrite) + /// Dim n As Integer + /// Do While (n = input.Read(buffer, 0, buffer.Length) > 0) + /// output.Write(buffer, 0, n) + /// Loop + /// End Using + /// End If + /// Loop + /// End Using + /// End Using + /// End Sub + /// + /// + public ZipInputStream(Stream stream) : this (stream, false) { } + + + + /// + /// Create a ZipInputStream, given the name of an existing zip file. + /// + /// + /// + /// + /// + /// This constructor opens a FileStream for the given zipfile, and + /// wraps a ZipInputStream around that. See the documentation for the + /// constructor for full details. + /// + /// + /// + /// While the class is generally easier + /// to use, this class provides an alternative to those + /// applications that want to read from a zipfile directly, + /// using a . + /// + /// + /// + /// + /// + /// The name of the filesystem file to read. + /// + /// + /// + /// + /// This example shows how to read a zip file, and extract entries, using the + /// ZipInputStream class. + /// + /// + /// private void Unzip() + /// { + /// byte[] buffer= new byte[2048]; + /// int n; + /// using (var input= new ZipInputStream(inputFileName)) + /// { + /// ZipEntry e; + /// while (( e = input.GetNextEntry()) != null) + /// { + /// if (e.IsDirectory) continue; + /// string outputPath = Path.Combine(extractDir, e.FileName); + /// using (var output = File.Open(outputPath, FileMode.Create, FileAccess.ReadWrite)) + /// { + /// while ((n= input.Read(buffer, 0, buffer.Length)) > 0) + /// { + /// output.Write(buffer,0,n); + /// } + /// } + /// } + /// } + /// } + /// + /// + /// + /// Private Sub UnZip() + /// Dim inputFileName As String = "MyArchive.zip" + /// Dim extractDir As String = "extract" + /// Dim buffer As Byte() = New Byte(2048) {} + /// Using input As ZipInputStream = New ZipInputStream(inputFileName) + /// Dim e As ZipEntry + /// Do While (Not e = input.GetNextEntry Is Nothing) + /// If Not e.IsDirectory Then + /// Using output As FileStream = File.Open(Path.Combine(extractDir, e.FileName), _ + /// FileMode.Create, FileAccess.ReadWrite) + /// Dim n As Integer + /// Do While (n = input.Read(buffer, 0, buffer.Length) > 0) + /// output.Write(buffer, 0, n) + /// Loop + /// End Using + /// End If + /// Loop + /// End Using + /// End Sub + /// + /// + public ZipInputStream(String fileName) + { + Stream stream = File.Open(fileName, FileMode.Open, FileAccess.Read, FileShare.Read ); + _Init(stream, false, fileName); + } + + + /// + /// Create a ZipInputStream, explicitly specifying whether to + /// keep the underlying stream open. + /// + /// + /// + /// See the documentation for the ZipInputStream(Stream) + /// constructor for a discussion of the class, and an example of how to use the class. + /// + /// + /// + /// The stream to read from. It must be readable. + /// + /// + /// + /// true if the application would like the stream + /// to remain open after the ZipInputStream has been closed. + /// + public ZipInputStream(Stream stream, bool leaveOpen) + { + _Init(stream, leaveOpen, null); + } + + private void _Init(Stream stream, bool leaveOpen, string name) + { + _inputStream = stream; + if (!_inputStream.CanRead) + throw new ZipException("The stream must be readable."); + _container= new ZipContainer(this); + _provisionalAlternateEncoding = System.Text.Encoding.GetEncoding("IBM437"); + _leaveUnderlyingStreamOpen = leaveOpen; + _findRequired= true; + _name = name ?? "(stream)"; + } + + + /// Provides a string representation of the instance. + /// + /// + /// This can be useful for debugging purposes. + /// + /// + /// a string representation of the instance. + public override String ToString() + { + return String.Format ("ZipInputStream::{0}(leaveOpen({1})))", _name, _leaveUnderlyingStreamOpen); + } + + + /// + /// The text encoding to use when reading entries into the zip archive, for + /// those entries whose filenames or comments cannot be encoded with the + /// default (IBM437) encoding. + /// + /// + /// + /// + /// In its + /// zip specification, PKWare describes two options for encoding + /// filenames and comments: using IBM437 or UTF-8. But, some archiving tools + /// or libraries do not follow the specification, and instead encode + /// characters using the system default code page. For example, WinRAR when + /// run on a machine in Shanghai may encode filenames with the Big-5 Chinese + /// (950) code page. This behavior is contrary to the Zip specification, but + /// it occurs anyway. + /// + /// + /// + /// When using DotNetZip to read zip archives that use something other than + /// UTF-8 or IBM437, set this property to specify the code page to use when + /// reading encoded filenames and comments for each ZipEntry in the zip + /// file. + /// + /// + /// + /// This property is "provisional". When the entry in the zip archive is not + /// explicitly marked as using UTF-8, then IBM437 is used to decode filenames + /// and comments. If a loss of data would result from using IBM436 - + /// specifically when encoding and decoding is not reflexive - the codepage + /// specified here is used. It is possible, therefore, to have a given entry + /// with a Comment encoded in IBM437 and a FileName encoded with + /// the specified "provisional" codepage. + /// + /// + /// + /// When a zip file uses an arbitrary, non-UTF8 code page for encoding, there + /// is no standard way for the reader application - whether DotNetZip, WinZip, + /// WinRar, or something else - to know which codepage has been used for the + /// entries. Readers of zip files are not able to inspect the zip file and + /// determine the codepage that was used for the entries contained within it. + /// It is left to the application or user to determine the necessary codepage + /// when reading zip files encoded this way. If you use an incorrect codepage + /// when reading a zipfile, you will get entries with filenames that are + /// incorrect, and the incorrect filenames may even contain characters that + /// are not legal for use within filenames in Windows. Extracting entries with + /// illegal characters in the filenames will lead to exceptions. It's too bad, + /// but this is just the way things are with code pages in zip files. Caveat + /// Emptor. + /// + /// + /// + public System.Text.Encoding ProvisionalAlternateEncoding + { + get + { + return _provisionalAlternateEncoding; + } + set + { + _provisionalAlternateEncoding = value; + } + } + + + /// + /// Size of the work buffer to use for the ZLIB codec during decompression. + /// + /// + /// + /// Setting this affects the performance and memory efficiency of compression + /// and decompression. For larger files, setting this to a larger size may + /// improve performance, but the exact numbers vary depending on available + /// memory, and a bunch of other variables. I don't have good firm + /// recommendations on how to set it. You'll have to test it yourself. Or + /// just leave it alone and accept the default. + /// + public int CodecBufferSize + { + get; + set; + } + + + /// + /// Sets the password to be used on the ZipInputStream instance. + /// + /// + /// + /// + /// + /// When reading a zip archive, this password is used to read and decrypt the + /// entries that are encrypted within the zip file. When entries within a zip + /// file use different passwords, set the appropriate password for the entry + /// before the first call to Read() for each entry. + /// + /// + /// + /// When reading an entry that is not encrypted, the value of this property is + /// ignored. + /// + /// + /// + /// + /// + /// + /// This example uses the ZipInputStream to read and extract entries from a + /// zip file, using a potentially different password for each entry. + /// + /// + /// byte[] buffer= new byte[2048]; + /// int n; + /// using (var raw = File.Open(_inputFileName, FileMode.Open, FileAccess.Read )) + /// { + /// using (var input= new ZipInputStream(raw)) + /// { + /// ZipEntry e; + /// while (( e = input.GetNextEntry()) != null) + /// { + /// input.Password = PasswordForEntry(e.FileName); + /// if (e.IsDirectory) continue; + /// string outputPath = Path.Combine(_extractDir, e.FileName); + /// using (var output = File.Open(outputPath, FileMode.Create, FileAccess.ReadWrite)) + /// { + /// while ((n= input.Read(buffer,0,buffer.Length)) > 0) + /// { + /// output.Write(buffer,0,n); + /// } + /// } + /// } + /// } + /// } + /// + /// + /// + public String Password + { + set + { + if (_closed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + _Password = value; + } + } + + + private void SetupStream() + { + // Seek to the correct posn in the file, and open a + // stream that can be read. + _crcStream= _currentEntry.InternalOpenReader(_Password); + _LeftToRead = _crcStream.Length; + _needSetup = false; + } + + + + internal Stream ReadStream + { + get + { + return _inputStream; + } + } + + + /// + /// Read the data from the stream into the buffer. + /// + /// + /// + /// + /// The data for the zipentry will be decrypted and uncompressed, as + /// necessary, before being copied into the buffer. + /// + /// + /// + /// You must set the property before calling + /// Read() the first time for an encrypted entry. To determine if an + /// entry is encrypted and requires a password, check the ZipEntry.Encryption property. + /// + /// + /// + /// The buffer to hold the data read from the stream. + /// the offset within the buffer to copy the first byte read. + /// the number of bytes to read. + /// the number of bytes read, after decryption and decompression. + public override int Read(byte[] buffer, int offset, int count) + { + if (_closed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + + if (_needSetup) + SetupStream(); + + if (_LeftToRead == 0) return 0; + + int len = (_LeftToRead > count) ? count : (int)_LeftToRead; + int n = _crcStream.Read(buffer, offset, len); + + _LeftToRead -= n; + + if (_LeftToRead == 0) + { + int CrcResult = _crcStream.Crc; + _currentEntry.VerifyCrcAfterExtract(CrcResult); + _inputStream.Seek(_endOfEntry, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_inputStream); + } + + return n; + } + + + + /// + /// Read the next entry from the zip file. + /// + /// + /// + /// + /// Call this method just before calling , + /// to position the pointer in the zip file to the next entry that can be + /// read. Subsequent calls to Read(), will decrypt and decompress the + /// data in the zip file, until Read() returns 0. + /// + /// + /// + /// Each time you call GetNextEntry(), the pointer in the wrapped + /// stream is moved to the next entry in the zip file. If you call , and thus re-position the pointer within + /// the file, you will need to call GetNextEntry() again, to insure + /// that the file pointer is positioned at the beginning of a zip entry. + /// + /// + /// + /// This method returns the ZipEntry. Using a stream approach, you will + /// read the raw bytes for an entry in a zip file via calls to Read(). + /// Alternatively, you can extract an entry into a file, or a stream, by + /// calling , or one of its siblings. + /// + /// + /// + /// + /// + /// The ZipEntry read. Returns null (or Nothing in VB) if there are no more + /// entries in the zip file. + /// + /// + public ZipEntry GetNextEntry() + { + if (_findRequired) + { + // find the next signature + long d = SharedUtilities.FindSignature(_inputStream, ZipConstants.ZipEntrySignature); + if (d == -1) return null; + // back up 4 bytes: ReadEntry assumes the file pointer is positioned before the entry signature + _inputStream.Seek(-4, SeekOrigin.Current); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_inputStream); + } + // workitem 10923 + else if (_firstEntry) + { + // we've already read one entry. + // Seek to the end of it. + _inputStream.Seek(_endOfEntry, SeekOrigin.Begin); + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_inputStream); + } + + _currentEntry = ZipEntry.ReadEntry(_container, !_firstEntry); + // ReadEntry leaves the file position after all the entry + // data and the optional bit-3 data descriptpr. This is + // where the next entry would normally start. + _endOfEntry = _inputStream.Position; + _firstEntry = true; + _needSetup = true; + _findRequired= false; + return _currentEntry; + } + + + /// + /// Dispose the stream. + /// + /// + /// + /// + /// This method disposes the ZipInputStream. It may also close the + /// underlying stream, depending on which constructor was used. + /// + /// + /// + /// Typically the application will call Dispose() implicitly, via + /// a using statement in C#, or a Using statement in VB. + /// + /// + /// + /// Application code won't call this code directly. This method may + /// be invoked in two distinct scenarios. If disposing == true, the + /// method has been called directly or indirectly by a user's code, + /// for example via the public Dispose() method. In this case, both + /// managed and unmanaged resources can be referenced and disposed. + /// If disposing == false, the method has been called by the runtime + /// from inside the object finalizer and this method should not + /// reference other objects; in that case only unmanaged resources + /// must be referenced or disposed. + /// + /// + /// + /// + /// true if the Dispose method was invoked by user code. + /// + protected override void Dispose(bool disposing) + { + if (_closed) return; + + if (disposing) // not called from finalizer + { + // When ZipInputStream is used within a using clause, and an + // exception is thrown, Close() is invoked. But we don't want to + // try to write anything in that case. Eventually the exception + // will be propagated to the application. + if (_exceptionPending) return; + + if (!_leaveUnderlyingStreamOpen) + { +#if NETCF + _inputStream.Close(); +#else + _inputStream.Dispose(); +#endif + } + } + _closed= true; + } + + + /// + /// Always returns true. + /// + public override bool CanRead { get { return true; }} + + /// + /// Returns the value of CanSeek for the underlying (wrapped) stream. + /// + public override bool CanSeek { get { return _inputStream.CanSeek; } } + + /// + /// Always returns false. + /// + public override bool CanWrite { get { return false; } } + + /// + /// Returns the length of the underlying stream. + /// + public override long Length { get { return _inputStream.Length; }} + + /// + /// Gets or sets the position of the underlying stream. + /// + /// + /// Setting the position is equivalent to calling Seek(value, SeekOrigin.Begin). + /// + public override long Position + { + get { return _inputStream.Position;} + set { Seek(value, SeekOrigin.Begin); } + } + + /// + /// This is a no-op. + /// + public override void Flush() + { + throw new NotSupportedException("Flush"); + } + + + /// + /// This method always throws a NotSupportedException. + /// + /// ignored + /// ignored + /// ignored + public override void Write(byte[] buffer, int offset, int count) + { + throw new NotSupportedException("Write"); + } + + + /// + /// This method seeks in the underlying stream. + /// + /// + /// + /// + /// Call this method if you want to seek around within the zip file for random access. + /// + /// + /// + /// Applications can intermix calls to Seek() with calls to . After a call to Seek(), + /// GetNextEntry() will get the next ZipEntry that falls after + /// the current position in the input stream. You're on your own for finding + /// out just where to seek in the stream, to get to the various entries. + /// + /// + /// + /// + /// the offset point to seek to + /// the reference point from which to seek + /// The new position + public override long Seek(long offset, SeekOrigin origin) + { + _findRequired= true; + var x = _inputStream.Seek(offset, origin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_inputStream); + return x; + } + + /// + /// This method always throws a NotSupportedException. + /// + /// ignored + public override void SetLength(long value) + { + throw new NotSupportedException(); + } + + + private Stream _inputStream; + private System.Text.Encoding _provisionalAlternateEncoding; + private ZipEntry _currentEntry; + private bool _firstEntry; + private bool _needSetup; + private ZipContainer _container; + private Ionic.Crc.CrcCalculatorStream _crcStream; + private Int64 _LeftToRead; + internal String _Password; + private Int64 _endOfEntry; + private string _name; + + private bool _leaveUnderlyingStreamOpen; + private bool _closed; + private bool _findRequired; + private bool _exceptionPending; + } + + + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipOutputStream.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipOutputStream.cs new file mode 100644 index 00000000..97d1f9cb --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipOutputStream.cs @@ -0,0 +1,1817 @@ +// ZipOutputStream.cs +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-28 06:34:30> +// +// ------------------------------------------------------------------ +// +// This module defines the ZipOutputStream class, which is a stream metaphor for +// generating zip files. This class does not depend on Ionic.Zip.ZipFile, but rather +// stands alongside it as an alternative "container" for ZipEntry. It replicates a +// subset of the properties, including these: +// +// - Comment +// - Encryption +// - Password +// - CodecBufferSize +// - CompressionLevel +// - CompressionMethod +// - EnableZip64 (UseZip64WhenSaving) +// - IgnoreCase (!CaseSensitiveRetrieval) +// +// It adds these novel methods: +// +// - PutNextEntry +// +// +// ------------------------------------------------------------------ +// + +using System; +using System.Threading; +using System.Collections.Generic; +using System.IO; +using Ionic.Zip; + +namespace Ionic.Zip +{ + /// + /// Provides a stream metaphor for generating zip files. + /// + /// + /// + /// + /// This class writes zip files, as defined in the specification + /// for zip files described by PKWare. The compression for this + /// implementation is provided by a managed-code version of Zlib, included with + /// DotNetZip in the classes in the Ionic.Zlib namespace. + /// + /// + /// + /// This class provides an alternative programming model to the one enabled by the + /// class. Use this when creating zip files, as an + /// alternative to the class, when you would like to use a + /// Stream type to write the zip file. + /// + /// + /// + /// Both the ZipOutputStream class and the ZipFile class can be used + /// to create zip files. Both of them support many of the common zip features, + /// including Unicode, different compression levels, and ZIP64. They provide + /// very similar performance when creating zip files. + /// + /// + /// + /// The ZipFile class is generally easier to use than + /// ZipOutputStream and should be considered a higher-level interface. For + /// example, when creating a zip file via calls to the PutNextEntry() and + /// Write() methods on the ZipOutputStream class, the caller is + /// responsible for opening the file, reading the bytes from the file, writing + /// those bytes into the ZipOutputStream, setting the attributes on the + /// ZipEntry, and setting the created, last modified, and last accessed + /// timestamps on the zip entry. All of these things are done automatically by a + /// call to ZipFile.AddFile(). + /// For this reason, the ZipOutputStream is generally recommended for use + /// only when your application emits arbitrary data, not necessarily data from a + /// filesystem file, directly into a zip file, and does so using a Stream + /// metaphor. + /// + /// + /// + /// Aside from the differences in programming model, there are other + /// differences in capability between the two classes. + /// + /// + /// + /// + /// ZipFile can be used to read and extract zip files, in addition to + /// creating zip files. ZipOutputStream cannot read zip files. If you want + /// to use a stream to read zip files, check out the class. + /// + /// + /// + /// ZipOutputStream does not support the creation of segmented or spanned + /// zip files. + /// + /// + /// + /// ZipOutputStream cannot produce a self-extracting archive. + /// + /// + /// + /// + /// Be aware that the ZipOutputStream class implements the interface. In order for + /// ZipOutputStream to produce a valid zip file, you use use it within + /// a using clause (Using in VB), or call the Dispose() method + /// explicitly. See the examples for how to employ a using clause. + /// + /// + /// + /// Also, a note regarding compression performance: On the desktop .NET + /// Framework, DotNetZip can use a multi-threaded compression implementation + /// that provides significant speed increases on large files, over 300k or so, + /// at the cost of increased memory use at runtime. (The output of the + /// compression is almost exactly the same size). But, the multi-threaded + /// approach incurs a performance hit on smaller files. There's no way for the + /// ZipOutputStream to know whether parallel compression will be beneficial, + /// because the ZipOutputStream does not know how much data you will write + /// through the stream. You may wish to set the property to zero, if you are compressing + /// large files through ZipOutputStream. This will cause parallel + /// compression to be used, always. + /// + /// + public class ZipOutputStream : Stream + { + /// + /// Create a ZipOutputStream, wrapping an existing stream. + /// + /// + /// + /// + /// The class is generally easier to use when creating + /// zip files. The ZipOutputStream offers a different metaphor for creating a + /// zip file, based on the class. + /// + /// + /// + /// + /// + /// The stream to wrap. It must be writable. This stream will be closed at + /// the time the ZipOutputStream is closed. + /// + /// + /// + /// + /// This example shows how to create a zip file, using the + /// ZipOutputStream class. + /// + /// + /// private void Zipup() + /// { + /// if (filesToZip.Count == 0) + /// { + /// System.Console.WriteLine("Nothing to do."); + /// return; + /// } + /// + /// using (var raw = File.Open(_outputFileName, FileMode.Create, FileAccess.ReadWrite )) + /// { + /// using (var output= new ZipOutputStream(raw)) + /// { + /// output.Password = "VerySecret!"; + /// output.Encryption = EncryptionAlgorithm.WinZipAes256; + /// + /// foreach (string inputFileName in filesToZip) + /// { + /// System.Console.WriteLine("file: {0}", inputFileName); + /// + /// output.PutNextEntry(inputFileName); + /// using (var input = File.Open(inputFileName, FileMode.Open, FileAccess.Read, FileShare.Read | FileShare.Write )) + /// { + /// byte[] buffer= new byte[2048]; + /// int n; + /// while ((n= input.Read(buffer,0,buffer.Length)) > 0) + /// { + /// output.Write(buffer,0,n); + /// } + /// } + /// } + /// } + /// } + /// } + /// + /// + /// + /// Private Sub Zipup() + /// Dim outputFileName As String = "XmlData.zip" + /// Dim filesToZip As String() = Directory.GetFiles(".", "*.xml") + /// If (filesToZip.Length = 0) Then + /// Console.WriteLine("Nothing to do.") + /// Else + /// Using raw As FileStream = File.Open(outputFileName, FileMode.Create, FileAccess.ReadWrite) + /// Using output As ZipOutputStream = New ZipOutputStream(raw) + /// output.Password = "VerySecret!" + /// output.Encryption = EncryptionAlgorithm.WinZipAes256 + /// Dim inputFileName As String + /// For Each inputFileName In filesToZip + /// Console.WriteLine("file: {0}", inputFileName) + /// output.PutNextEntry(inputFileName) + /// Using input As FileStream = File.Open(inputFileName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite) + /// Dim n As Integer + /// Dim buffer As Byte() = New Byte(2048) {} + /// Do While (n = input.Read(buffer, 0, buffer.Length) > 0) + /// output.Write(buffer, 0, n) + /// Loop + /// End Using + /// Next + /// End Using + /// End Using + /// End If + /// End Sub + /// + /// + public ZipOutputStream(Stream stream) : this(stream, false) { } + + + /// + /// Create a ZipOutputStream that writes to a filesystem file. + /// + /// + /// + /// The class is generally easier to use when creating + /// zip files. The ZipOutputStream offers a different metaphor for creating a + /// zip file, based on the class. + /// + /// + /// + /// The name of the zip file to create. + /// + /// + /// + /// + /// This example shows how to create a zip file, using the + /// ZipOutputStream class. + /// + /// + /// private void Zipup() + /// { + /// if (filesToZip.Count == 0) + /// { + /// System.Console.WriteLine("Nothing to do."); + /// return; + /// } + /// + /// using (var output= new ZipOutputStream(outputFileName)) + /// { + /// output.Password = "VerySecret!"; + /// output.Encryption = EncryptionAlgorithm.WinZipAes256; + /// + /// foreach (string inputFileName in filesToZip) + /// { + /// System.Console.WriteLine("file: {0}", inputFileName); + /// + /// output.PutNextEntry(inputFileName); + /// using (var input = File.Open(inputFileName, FileMode.Open, FileAccess.Read, + /// FileShare.Read | FileShare.Write )) + /// { + /// byte[] buffer= new byte[2048]; + /// int n; + /// while ((n= input.Read(buffer,0,buffer.Length)) > 0) + /// { + /// output.Write(buffer,0,n); + /// } + /// } + /// } + /// } + /// } + /// + /// + /// + /// Private Sub Zipup() + /// Dim outputFileName As String = "XmlData.zip" + /// Dim filesToZip As String() = Directory.GetFiles(".", "*.xml") + /// If (filesToZip.Length = 0) Then + /// Console.WriteLine("Nothing to do.") + /// Else + /// Using output As ZipOutputStream = New ZipOutputStream(outputFileName) + /// output.Password = "VerySecret!" + /// output.Encryption = EncryptionAlgorithm.WinZipAes256 + /// Dim inputFileName As String + /// For Each inputFileName In filesToZip + /// Console.WriteLine("file: {0}", inputFileName) + /// output.PutNextEntry(inputFileName) + /// Using input As FileStream = File.Open(inputFileName, FileMode.Open, FileAccess.Read, FileShare.ReadWrite) + /// Dim n As Integer + /// Dim buffer As Byte() = New Byte(2048) {} + /// Do While (n = input.Read(buffer, 0, buffer.Length) > 0) + /// output.Write(buffer, 0, n) + /// Loop + /// End Using + /// Next + /// End Using + /// End If + /// End Sub + /// + /// + public ZipOutputStream(String fileName) + { + Stream stream = File.Open(fileName, FileMode.Create, FileAccess.ReadWrite, FileShare.None); + _Init(stream, false, fileName); + } + + + /// + /// Create a ZipOutputStream. + /// + /// + /// + /// See the documentation for the ZipOutputStream(Stream) + /// constructor for an example. + /// + /// + /// + /// The stream to wrap. It must be writable. + /// + /// + /// + /// true if the application would like the stream + /// to remain open after the ZipOutputStream has been closed. + /// + public ZipOutputStream(Stream stream, bool leaveOpen) + { + _Init(stream, leaveOpen, null); + } + + private void _Init(Stream stream, bool leaveOpen, string name) + { + // workitem 9307 + _outputStream = stream.CanRead ? stream : new CountingStream(stream); + CompressionLevel = Ionic.Zlib.CompressionLevel.Default; + CompressionMethod = Ionic.Zip.CompressionMethod.Deflate; + _encryption = EncryptionAlgorithm.None; + _entriesWritten = new Dictionary(StringComparer.Ordinal); + _zip64 = Zip64Option.Never; + _leaveUnderlyingStreamOpen = leaveOpen; + Strategy = Ionic.Zlib.CompressionStrategy.Default; + _name = name ?? "(stream)"; +#if !NETCF + ParallelDeflateThreshold = -1L; +#endif + } + + + /// Provides a string representation of the instance. + /// + /// + /// This can be useful for debugging purposes. + /// + /// + /// a string representation of the instance. + public override String ToString() + { + return String.Format ("ZipOutputStream::{0}(leaveOpen({1})))", _name, _leaveUnderlyingStreamOpen); + } + + + /// + /// Sets the password to be used on the ZipOutputStream instance. + /// + /// + /// + /// + /// + /// When writing a zip archive, this password is applied to the entries, not + /// to the zip archive itself. It applies to any ZipEntry subsequently + /// written to the ZipOutputStream. + /// + /// + /// + /// Using a password does not encrypt or protect the "directory" of the + /// archive - the list of entries contained in the archive. If you set the + /// Password property, the password actually applies to individual + /// entries that are added to the archive, subsequent to the setting of this + /// property. The list of filenames in the archive that is eventually created + /// will appear in clear text, but the contents of the individual files are + /// encrypted. This is how Zip encryption works. + /// + /// + /// + /// If you set this property, and then add a set of entries to the archive via + /// calls to PutNextEntry, then each entry is encrypted with that + /// password. You may also want to change the password between adding + /// different entries. If you set the password, add an entry, then set the + /// password to null (Nothing in VB), and add another entry, the + /// first entry is encrypted and the second is not. + /// + /// + /// + /// When setting the Password, you may also want to explicitly set the property, to specify how to encrypt the entries added + /// to the ZipFile. If you set the Password to a non-null value and do not + /// set , then PKZip 2.0 ("Weak") encryption is used. + /// This encryption is relatively weak but is very interoperable. If + /// you set the password to a null value (Nothing in VB), + /// Encryption is reset to None. + /// + /// + /// + /// Special case: if you wrap a ZipOutputStream around a non-seekable stream, + /// and use encryption, and emit an entry of zero bytes, the Close() or + /// PutNextEntry() following the entry will throw an exception. + /// + /// + /// + public String Password + { + set + { + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + + _password = value; + if (_password == null) + { + _encryption = EncryptionAlgorithm.None; + } + else if (_encryption == EncryptionAlgorithm.None) + { + _encryption = EncryptionAlgorithm.PkzipWeak; + } + } + } + + + /// + /// The Encryption to use for entries added to the ZipOutputStream. + /// + /// + /// + /// + /// The specified Encryption is applied to the entries subsequently + /// written to the ZipOutputStream instance. + /// + /// + /// + /// If you set this to something other than + /// EncryptionAlgorithm.None, you will also need to set the + /// to a non-null, non-empty value in + /// order to actually get encryption on the entry. + /// + /// + /// + /// + /// ZipOutputStream.Password + /// ZipEntry.Encryption + public EncryptionAlgorithm Encryption + { + get + { + return _encryption; + } + set + { + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + if (value == EncryptionAlgorithm.Unsupported) + { + _exceptionPending = true; + throw new InvalidOperationException("You may not set Encryption to that value."); + } + _encryption = value; + } + } + + + /// + /// Size of the work buffer to use for the ZLIB codec during compression. + /// + /// + /// + /// Setting this may affect performance. For larger files, setting this to a + /// larger size may improve performance, but I'm not sure. Sorry, I don't + /// currently have good recommendations on how to set it. You can test it if + /// you like. + /// + public int CodecBufferSize + { + get; + set; + } + + + /// + /// The compression strategy to use for all entries. + /// + /// + /// + /// Set the Strategy used by the ZLIB-compatible compressor, when compressing + /// data for the entries in the zip archive. Different compression strategies + /// work better on different sorts of data. The strategy parameter can affect + /// the compression ratio and the speed of compression but not the correctness + /// of the compresssion. For more information see . + /// + public Ionic.Zlib.CompressionStrategy Strategy + { + get; + set; + } + + + /// + /// The type of timestamp attached to the ZipEntry. + /// + /// + /// + /// Set this in order to specify the kind of timestamp that should be emitted + /// into the zip file for each entry. + /// + public ZipEntryTimestamp Timestamp + { + get + { + return _timestamp; + } + set + { + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + _timestamp = value; + } + } + + + /// + /// Sets the compression level to be used for entries subsequently added to + /// the zip archive. + /// + /// + /// + /// + /// Varying the compression level used on entries can affect the + /// size-vs-speed tradeoff when compression and decompressing data streams + /// or files. + /// + /// + /// + /// As with some other properties on the ZipOutputStream class, like , and , + /// setting this property on a ZipOutputStream + /// instance will cause the specified CompressionLevel to be used on all + /// items that are subsequently added to the + /// ZipOutputStream instance. + /// + /// + /// + /// If you do not set this property, the default compression level is used, + /// which normally gives a good balance of compression efficiency and + /// compression speed. In some tests, using BestCompression can + /// double the time it takes to compress, while delivering just a small + /// increase in compression efficiency. This behavior will vary with the + /// type of data you compress. If you are in doubt, just leave this setting + /// alone, and accept the default. + /// + /// + public Ionic.Zlib.CompressionLevel CompressionLevel + { + get; + set; + } + + /// + /// The compression method used on each entry added to the ZipOutputStream. + /// + public Ionic.Zip.CompressionMethod CompressionMethod + { + get; + set; + } + + + /// + /// A comment attached to the zip archive. + /// + /// + /// + /// + /// + /// The application sets this property to specify a comment to be embedded + /// into the generated zip archive. + /// + /// + /// + /// According to PKWARE's + /// zip specification, the comment is not encrypted, even if there is a + /// password set on the zip file. + /// + /// + /// + /// The specification does not describe how to indicate the encoding used + /// on a comment string. Many "compliant" zip tools and libraries use + /// IBM437 as the code page for comments; DotNetZip, too, follows that + /// practice. On the other hand, there are situations where you want a + /// Comment to be encoded with something else, for example using code page + /// 950 "Big-5 Chinese". To fill that need, DotNetZip will encode the + /// comment following the same procedure it follows for encoding + /// filenames: (a) if is + /// Never, it uses the default encoding (IBM437). (b) if is Always, it always uses the + /// alternate encoding (). (c) if is AsNecessary, it uses the + /// alternate encoding only if the default encoding is not sufficient for + /// encoding the comment - in other words if decoding the result does not + /// produce the original string. This decision is taken at the time of + /// the call to ZipFile.Save(). + /// + /// + /// + public string Comment + { + get { return _comment; } + set + { + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + _comment = value; + } + } + + + + /// + /// Specify whether to use ZIP64 extensions when saving a zip archive. + /// + /// + /// + /// + /// The default value for the property is . is + /// safest, in the sense that you will not get an Exception if a + /// pre-ZIP64 limit is exceeded. + /// + /// + /// + /// You must set this property before calling Write(). + /// + /// + /// + public Zip64Option EnableZip64 + { + get + { + return _zip64; + } + set + { + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + _zip64 = value; + } + } + + + /// + /// Indicates whether ZIP64 extensions were used when saving the zip archive. + /// + /// + /// + /// The value is defined only after the ZipOutputStream has been closed. + /// + public bool OutputUsedZip64 + { + get + { + return _anyEntriesUsedZip64 || _directoryNeededZip64; + } + } + + + /// + /// Whether the ZipOutputStream should use case-insensitive comparisons when + /// checking for uniqueness of zip entries. + /// + /// + /// + /// + /// Though the zip specification doesn't prohibit zipfiles with duplicate + /// entries, Sane zip files have no duplicates, and the DotNetZip library + /// cannot create zip files with duplicate entries. If an application attempts + /// to call with a name that duplicates one + /// already used within the archive, the library will throw an Exception. + /// + /// + /// This property allows the application to specify whether the + /// ZipOutputStream instance considers ordinal case when checking for + /// uniqueness of zip entries. + /// + /// + public bool IgnoreCase + { + get + { + return !_DontIgnoreCase; + } + + set + { + _DontIgnoreCase = !value; + } + + } + + + /// + /// Indicates whether to encode entry filenames and entry comments using + /// Unicode (UTF-8). + /// + /// + /// + /// + /// The + /// PKWare zip specification provides for encoding file names and file + /// comments in either the IBM437 code page, or in UTF-8. This flag selects + /// the encoding according to that specification. By default, this flag is + /// false, and filenames and comments are encoded into the zip file in the + /// IBM437 codepage. Setting this flag to true will specify that filenames + /// and comments that cannot be encoded with IBM437 will be encoded with + /// UTF-8. + /// + /// + /// + /// Zip files created with strict adherence to the PKWare specification with + /// respect to UTF-8 encoding can contain entries with filenames containing + /// any combination of Unicode characters, including the full range of + /// characters from Chinese, Latin, Hebrew, Greek, Cyrillic, and many other + /// alphabets. However, because at this time, the UTF-8 portion of the PKWare + /// specification is not broadly supported by other zip libraries and + /// utilities, such zip files may not be readable by your favorite zip tool or + /// archiver. In other words, interoperability will decrease if you set this + /// flag to true. + /// + /// + /// + /// In particular, Zip files created with strict adherence to the PKWare + /// specification with respect to UTF-8 encoding will not work well with + /// Explorer in Windows XP or Windows Vista, because Windows compressed + /// folders, as far as I know, do not support UTF-8 in zip files. Vista can + /// read the zip files, but shows the filenames incorrectly. Unpacking from + /// Windows Vista Explorer will result in filenames that have rubbish + /// characters in place of the high-order UTF-8 bytes. + /// + /// + /// + /// Also, zip files that use UTF-8 encoding will not work well with Java + /// applications that use the java.util.zip classes, as of v5.0 of the Java + /// runtime. The Java runtime does not correctly implement the PKWare + /// specification in this regard. + /// + /// + /// + /// As a result, we have the unfortunate situation that "correct" behavior by + /// the DotNetZip library with regard to Unicode encoding of filenames during + /// zip creation will result in zip files that are readable by strictly + /// compliant and current tools (for example the most recent release of the + /// commercial WinZip tool); but these zip files will not be readable by + /// various other tools or libraries, including Windows Explorer. + /// + /// + /// + /// The DotNetZip library can read and write zip files with UTF8-encoded + /// entries, according to the PKware spec. If you use DotNetZip for both + /// creating and reading the zip file, and you use UTF-8, there will be no + /// loss of information in the filenames. For example, using a self-extractor + /// created by this library will allow you to unpack files correctly with no + /// loss of information in the filenames. + /// + /// + /// + /// If you do not set this flag, it will remain false. If this flag is false, + /// the ZipOutputStream will encode all filenames and comments using + /// the IBM437 codepage. This can cause "loss of information" on some + /// filenames, but the resulting zipfile will be more interoperable with other + /// utilities. As an example of the loss of information, diacritics can be + /// lost. The o-tilde character will be down-coded to plain o. The c with a + /// cedilla (Unicode 0xE7) used in Portugese will be downcoded to a c. + /// Likewise, the O-stroke character (Unicode 248), used in Danish and + /// Norwegian, will be down-coded to plain o. Chinese characters cannot be + /// represented in codepage IBM437; when using the default encoding, Chinese + /// characters in filenames will be represented as ?. These are all examples + /// of "information loss". + /// + /// + /// + /// The loss of information associated to the use of the IBM437 encoding is + /// inconvenient, and can also lead to runtime errors. For example, using + /// IBM437, any sequence of 4 Chinese characters will be encoded as ????. If + /// your application creates a ZipOutputStream, does not set the + /// encoding, then adds two files, each with names of four Chinese characters + /// each, this will result in a duplicate filename exception. In the case + /// where you add a single file with a name containing four Chinese + /// characters, the zipfile will save properly, but extracting that file + /// later, with any zip tool, will result in an error, because the question + /// mark is not legal for use within filenames on Windows. These are just a + /// few examples of the problems associated to loss of information. + /// + /// + /// + /// This flag is independent of the encoding of the content within the entries + /// in the zip file. Think of the zip file as a container - it supports an + /// encoding. Within the container are other "containers" - the file entries + /// themselves. The encoding within those entries is independent of the + /// encoding of the zip archive container for those entries. + /// + /// + /// + /// Rather than specify the encoding in a binary fashion using this flag, an + /// application can specify an arbitrary encoding via the property. Setting the encoding + /// explicitly when creating zip archives will result in non-compliant zip + /// files that, curiously, are fairly interoperable. The challenge is, the + /// PKWare specification does not provide for a way to specify that an entry + /// in a zip archive uses a code page that is neither IBM437 nor UTF-8. + /// Therefore if you set the encoding explicitly when creating a zip archive, + /// you must take care upon reading the zip archive to use the same code page. + /// If you get it wrong, the behavior is undefined and may result in incorrect + /// filenames, exceptions, stomach upset, hair loss, and acne. + /// + /// + /// + [Obsolete("Beginning with v1.9.1.6 of DotNetZip, this property is obsolete. It will be removed in a future version of the library. Use AlternateEncoding and AlternateEncodingUsage instead.")] + public bool UseUnicodeAsNecessary + { + get + { + return (_alternateEncoding == System.Text.Encoding.UTF8) && + (AlternateEncodingUsage == ZipOption.AsNecessary); + } + set + { + if (value) + { + _alternateEncoding = System.Text.Encoding.UTF8; + _alternateEncodingUsage = ZipOption.AsNecessary; + + } + else + { + _alternateEncoding = Ionic.Zip.ZipOutputStream.DefaultEncoding; + _alternateEncodingUsage = ZipOption.Never; + } + } + } + + + /// + /// The text encoding to use when emitting entries into the zip archive, for + /// those entries whose filenames or comments cannot be encoded with the + /// default (IBM437) encoding. + /// + /// + /// + /// + /// In its + /// zip specification, PKWare describes two options for encoding + /// filenames and comments: using IBM437 or UTF-8. But, some archiving tools + /// or libraries do not follow the specification, and instead encode + /// characters using the system default code page. For example, WinRAR when + /// run on a machine in Shanghai may encode filenames with the Big-5 Chinese + /// (950) code page. This behavior is contrary to the Zip specification, but + /// it occurs anyway. + /// + /// + /// + /// When using DotNetZip to write zip archives that will be read by one of + /// these other archivers, set this property to specify the code page to use + /// when encoding the and for each ZipEntry in the zip file, for + /// values that cannot be encoded with the default codepage for zip files, + /// IBM437. This is why this property is "provisional". In all cases, IBM437 + /// is used where possible, in other words, where no loss of data would + /// result. It is possible, therefore, to have a given entry with a + /// Comment encoded in IBM437 and a FileName encoded with the + /// specified "provisional" codepage. + /// + /// + /// + /// Be aware that a zip file created after you've explicitly set the + /// ProvisionalAlternateEncoding property to a value other than + /// IBM437 may not be compliant to the PKWare specification, and may not be + /// readable by compliant archivers. On the other hand, many (most?) + /// archivers are non-compliant and can read zip files created in arbitrary + /// code pages. The trick is to use or specify the proper codepage when + /// reading the zip. + /// + /// + /// + /// When creating a zip archive using this library, it is possible to change + /// the value of ProvisionalAlternateEncoding between each entry you + /// add, and between adding entries and the call to Close(). Don't do + /// this. It will likely result in a zipfile that is not readable. For best + /// interoperability, either leave ProvisionalAlternateEncoding + /// alone, or specify it only once, before adding any entries to the + /// ZipOutputStream instance. There is one exception to this + /// recommendation, described later. + /// + /// + /// + /// When using an arbitrary, non-UTF8 code page for encoding, there is no + /// standard way for the creator application - whether DotNetZip, WinZip, + /// WinRar, or something else - to formally specify in the zip file which + /// codepage has been used for the entries. As a result, readers of zip files + /// are not able to inspect the zip file and determine the codepage that was + /// used for the entries contained within it. It is left to the application + /// or user to determine the necessary codepage when reading zip files encoded + /// this way. If you use an incorrect codepage when reading a zipfile, you + /// will get entries with filenames that are incorrect, and the incorrect + /// filenames may even contain characters that are not legal for use within + /// filenames in Windows. Extracting entries with illegal characters in the + /// filenames will lead to exceptions. It's too bad, but this is just the way + /// things are with code pages in zip files. Caveat Emptor. + /// + /// + /// + /// One possible approach for specifying the code page for a given zip file is + /// to describe the code page in a human-readable form in the Zip comment. For + /// example, the comment may read "Entries in this archive are encoded in the + /// Big5 code page". For maximum interoperability, the zip comment in this + /// case should be encoded in the default, IBM437 code page. In this case, + /// the zip comment is encoded using a different page than the filenames. To + /// do this, Specify ProvisionalAlternateEncoding to your desired + /// region-specific code page, once before adding any entries, and then set + /// the property and reset + /// ProvisionalAlternateEncoding to IBM437 before calling Close(). + /// + /// + [Obsolete("use AlternateEncoding and AlternateEncodingUsage instead.")] + public System.Text.Encoding ProvisionalAlternateEncoding + { + get + { + if (_alternateEncodingUsage == ZipOption.AsNecessary) + return _alternateEncoding; + return null; + } + set + { + _alternateEncoding = value; + _alternateEncodingUsage = ZipOption.AsNecessary; + } + } + + /// + /// A Text Encoding to use when encoding the filenames and comments for + /// all the ZipEntry items, during a ZipFile.Save() operation. + /// + /// + /// + /// Whether the encoding specified here is used during the save depends + /// on . + /// + /// + public System.Text.Encoding AlternateEncoding + { + get + { + return _alternateEncoding; + } + set + { + _alternateEncoding = value; + } + } + + /// + /// A flag that tells if and when this instance should apply + /// AlternateEncoding to encode the filenames and comments associated to + /// of ZipEntry objects contained within this instance. + /// + public ZipOption AlternateEncodingUsage + { + get + { + return _alternateEncodingUsage; + } + set + { + _alternateEncodingUsage = value; + } + } + + /// + /// The default text encoding used in zip archives. It is numeric 437, also + /// known as IBM437. + /// + /// + public static System.Text.Encoding DefaultEncoding + { + get + { + return System.Text.Encoding.GetEncoding("IBM437"); + } + } + + +#if !NETCF + /// + /// The size threshold for an entry, above which a parallel deflate is used. + /// + /// + /// + /// + /// + /// DotNetZip will use multiple threads to compress any ZipEntry, when + /// the CompressionMethod is Deflate, and if the entry is + /// larger than the given size. Zero means "always use parallel + /// deflate", while -1 means "never use parallel deflate". + /// + /// + /// + /// If the entry size cannot be known before compression, as with any entry + /// added via a ZipOutputStream, then Parallel deflate will never be + /// performed, unless the value of this property is zero. + /// + /// + /// + /// A parallel deflate operations will speed up the compression of + /// large files, on computers with multiple CPUs or multiple CPU + /// cores. For files above 1mb, on a dual core or dual-cpu (2p) + /// machine, the time required to compress the file can be 70% of the + /// single-threaded deflate. For very large files on 4p machines the + /// compression can be done in 30% of the normal time. The downside + /// is that parallel deflate consumes extra memory during the deflate, + /// and the deflation is slightly less effective. + /// + /// + /// + /// Parallel deflate tends to not be as effective as single-threaded deflate + /// because the original data stream is split into multiple independent + /// buffers, each of which is compressed in parallel. But because they are + /// treated independently, there is no opportunity to share compression + /// dictionaries, and additional framing bytes must be added to the output + /// stream. For that reason, a deflated stream may be slightly larger when + /// compressed using parallel deflate, as compared to a traditional + /// single-threaded deflate. For files of about 512k, the increase over the + /// normal deflate is as much as 5% of the total compressed size. For larger + /// files, the difference can be as small as 0.1%. + /// + /// + /// + /// Multi-threaded compression does not give as much an advantage when using + /// Encryption. This is primarily because encryption tends to slow down + /// the entire pipeline. Also, multi-threaded compression gives less of an + /// advantage when using lower compression levels, for example . You may have to perform + /// some tests to determine the best approach for your situation. + /// + /// + /// + /// The default value for this property is -1, which means parallel + /// compression will not be performed unless you set it to zero. + /// + /// + /// + public long ParallelDeflateThreshold + { + set + { + if ((value != 0) && (value != -1) && (value < 64 * 1024)) + throw new ArgumentOutOfRangeException("value must be greater than 64k, or 0, or -1"); + _ParallelDeflateThreshold = value; + } + get + { + return _ParallelDeflateThreshold; + } + } + + + /// + /// The maximum number of buffer pairs to use when performing + /// parallel compression. + /// + /// + /// + /// + /// This property sets an upper limit on the number of memory + /// buffer pairs to create when performing parallel + /// compression. The implementation of the parallel + /// compression stream allocates multiple buffers to + /// facilitate parallel compression. As each buffer fills up, + /// the stream uses + /// ThreadPool.QueueUserWorkItem() to compress those + /// buffers in a background threadpool thread. After a buffer + /// is compressed, it is re-ordered and written to the output + /// stream. + /// + /// + /// + /// A higher number of buffer pairs enables a higher degree of + /// parallelism, which tends to increase the speed of compression on + /// multi-cpu computers. On the other hand, a higher number of buffer + /// pairs also implies a larger memory consumption, more active worker + /// threads, and a higher cpu utilization for any compression. This + /// property enables the application to limit its memory consumption and + /// CPU utilization behavior depending on requirements. + /// + /// + /// + /// For each compression "task" that occurs in parallel, there are 2 + /// buffers allocated: one for input and one for output. This property + /// sets a limit for the number of pairs. The total amount of storage + /// space allocated for buffering will then be (N*S*2), where N is the + /// number of buffer pairs, S is the size of each buffer (). By default, DotNetZip allocates 4 buffer + /// pairs per CPU core, so if your machine has 4 cores, and you retain + /// the default buffer size of 128k, then the + /// ParallelDeflateOutputStream will use 4 * 4 * 2 * 128kb of buffer + /// memory in total, or 4mb, in blocks of 128kb. If you then set this + /// property to 8, then the number will be 8 * 2 * 128kb of buffer + /// memory, or 2mb. + /// + /// + /// + /// CPU utilization will also go up with additional buffers, because a + /// larger number of buffer pairs allows a larger number of background + /// threads to compress in parallel. If you find that parallel + /// compression is consuming too much memory or CPU, you can adjust this + /// value downward. + /// + /// + /// + /// The default value is 16. Different values may deliver better or + /// worse results, depending on your priorities and the dynamic + /// performance characteristics of your storage and compute resources. + /// + /// + /// + /// This property is not the number of buffer pairs to use; it is an + /// upper limit. An illustration: Suppose you have an application that + /// uses the default value of this property (which is 16), and it runs + /// on a machine with 2 CPU cores. In that case, DotNetZip will allocate + /// 4 buffer pairs per CPU core, for a total of 8 pairs. The upper + /// limit specified by this property has no effect. + /// + /// + /// + /// The application can set this value at any time, but it is + /// effective only if set before calling + /// ZipOutputStream.Write() for the first time. + /// + /// + /// + /// + /// + public int ParallelDeflateMaxBufferPairs + { + get + { + return _maxBufferPairs; + } + set + { + if (value < 4) + throw new ArgumentOutOfRangeException("ParallelDeflateMaxBufferPairs", + "Value must be 4 or greater."); + _maxBufferPairs = value; + } + } +#endif + + + private void InsureUniqueEntry(ZipEntry ze1) + { + if (_entriesWritten.ContainsKey(ze1.FileName)) + { + _exceptionPending = true; + throw new ArgumentException(String.Format("The entry '{0}' already exists in the zip archive.", ze1.FileName)); + } + } + + + internal Stream OutputStream + { + get + { + return _outputStream; + } + } + + internal String Name + { + get + { + return _name; + } + } + + /// + /// Returns true if an entry by the given name has already been written + /// to the ZipOutputStream. + /// + /// + /// + /// The name of the entry to scan for. + /// + /// + /// + /// true if an entry by the given name has already been written. + /// + public bool ContainsEntry(string name) + { + return _entriesWritten.ContainsKey(SharedUtilities.NormalizePathForUseInZipFile(name)); + } + + + /// + /// Write the data from the buffer to the stream. + /// + /// + /// + /// As the application writes data into this stream, the data may be + /// compressed and encrypted before being written out to the underlying + /// stream, depending on the settings of the + /// and the properties. + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + + if (buffer==null) + { + _exceptionPending = true; + throw new System.ArgumentNullException("buffer"); + } + + if (_currentEntry == null) + { + _exceptionPending = true; + throw new System.InvalidOperationException("You must call PutNextEntry() before calling Write()."); + } + + if (_currentEntry.IsDirectory) + { + _exceptionPending = true; + throw new System.InvalidOperationException("You cannot Write() data for an entry that is a directory."); + } + + if (_needToWriteEntryHeader) + _InitiateCurrentEntry(false); + + if (count != 0) + _entryOutputStream.Write(buffer, offset, count); + } + + + + /// + /// Specify the name of the next entry that will be written to the zip file. + /// + /// + /// + /// + /// Call this method just before calling , to + /// specify the name of the entry that the next set of bytes written to + /// the ZipOutputStream belongs to. All subsequent calls to Write, + /// until the next call to PutNextEntry, + /// will be inserted into the named entry in the zip file. + /// + /// + /// + /// If the used in PutNextEntry() ends in + /// a slash, then the entry added is marked as a directory. Because directory + /// entries do not contain data, a call to Write(), before an + /// intervening additional call to PutNextEntry(), will throw an + /// exception. + /// + /// + /// + /// If you don't call Write() between two calls to + /// PutNextEntry(), the first entry is inserted into the zip file as a + /// file of zero size. This may be what you want. + /// + /// + /// + /// Because PutNextEntry() closes out the prior entry, if any, this + /// method may throw if there is a problem with the prior entry. + /// + /// + /// + /// This method returns the ZipEntry. You can modify public properties + /// on the ZipEntry, such as , , and so on, until the first call to + /// ZipOutputStream.Write(), or until the next call to + /// PutNextEntry(). If you modify the ZipEntry after + /// having called Write(), you may get a runtime exception, or you may + /// silently get an invalid zip archive. + /// + /// + /// + /// + /// + /// + /// This example shows how to create a zip file, using the + /// ZipOutputStream class. + /// + /// + /// private void Zipup() + /// { + /// using (FileStream fs raw = File.Open(_outputFileName, FileMode.Create, FileAccess.ReadWrite )) + /// { + /// using (var output= new ZipOutputStream(fs)) + /// { + /// output.Password = "VerySecret!"; + /// output.Encryption = EncryptionAlgorithm.WinZipAes256; + /// output.PutNextEntry("entry1.txt"); + /// byte[] buffer= System.Text.Encoding.ASCII.GetBytes("This is the content for entry #1."); + /// output.Write(buffer,0,buffer.Length); + /// output.PutNextEntry("entry2.txt"); // this will be zero length + /// output.PutNextEntry("entry3.txt"); + /// buffer= System.Text.Encoding.ASCII.GetBytes("This is the content for entry #3."); + /// output.Write(buffer,0,buffer.Length); + /// } + /// } + /// } + /// + /// + /// + /// + /// The name of the entry to be added, including any path to be used + /// within the zip file. + /// + /// + /// + /// The ZipEntry created. + /// + /// + public ZipEntry PutNextEntry(String entryName) + { + if (String.IsNullOrEmpty(entryName)) + throw new ArgumentNullException("entryName"); + + if (_disposed) + { + _exceptionPending = true; + throw new System.InvalidOperationException("The stream has been closed."); + } + + _FinishCurrentEntry(); + _currentEntry = ZipEntry.CreateForZipOutputStream(entryName); + _currentEntry._container = new ZipContainer(this); + _currentEntry._BitField |= 0x0008; // workitem 8932 + _currentEntry.SetEntryTimes(DateTime.Now, DateTime.Now, DateTime.Now); + _currentEntry.CompressionLevel = this.CompressionLevel; + _currentEntry.CompressionMethod = this.CompressionMethod; + _currentEntry.Password = _password; // workitem 13909 + _currentEntry.Encryption = this.Encryption; + // workitem 12634 + _currentEntry.AlternateEncoding = this.AlternateEncoding; + _currentEntry.AlternateEncodingUsage = this.AlternateEncodingUsage; + + if (entryName.EndsWith("/")) _currentEntry.MarkAsDirectory(); + + _currentEntry.EmitTimesInWindowsFormatWhenSaving = ((_timestamp & ZipEntryTimestamp.Windows) != 0); + _currentEntry.EmitTimesInUnixFormatWhenSaving = ((_timestamp & ZipEntryTimestamp.Unix) != 0); + InsureUniqueEntry(_currentEntry); + _needToWriteEntryHeader = true; + + return _currentEntry; + } + + + + private void _InitiateCurrentEntry(bool finishing) + { + // If finishing==true, this means we're initiating the entry at the time of + // Close() or PutNextEntry(). If this happens, it means no data was written + // for the entry - Write() was never called. (The usual case us to call + // _InitiateCurrentEntry(bool) from within Write().) If finishing==true, + // the entry could be either a zero-byte file or a directory. + + _entriesWritten.Add(_currentEntry.FileName,_currentEntry); + _entryCount++; // could use _entriesWritten.Count, but I don't want to incur + // the cost. + + if (_entryCount > 65534 && _zip64 == Zip64Option.Never) + { + _exceptionPending = true; + throw new System.InvalidOperationException("Too many entries. Consider setting ZipOutputStream.EnableZip64."); + } + + // Write out the header. + // + // If finishing, and encryption is in use, then we don't want to emit the + // normal encryption header. Signal that with a cycle=99 to turn off + // encryption for zero-byte entries or directories. + // + // If finishing, then we know the stream length is zero. Else, unknown + // stream length. Passing stream length == 0 allows an optimization so as + // not to setup an encryption or deflation stream, when stream length is + // zero. + + _currentEntry.WriteHeader(_outputStream, finishing ? 99 : 0); + _currentEntry.StoreRelativeOffset(); + + if (!_currentEntry.IsDirectory) + { + _currentEntry.WriteSecurityMetadata(_outputStream); + _currentEntry.PrepOutputStream(_outputStream, + finishing ? 0 : -1, + out _outputCounter, + out _encryptor, + out _deflater, + out _entryOutputStream); + } + _needToWriteEntryHeader = false; + } + + + + private void _FinishCurrentEntry() + { + if (_currentEntry != null) + { + if (_needToWriteEntryHeader) + _InitiateCurrentEntry(true); // an empty entry - no writes + + _currentEntry.FinishOutputStream(_outputStream, _outputCounter, _encryptor, _deflater, _entryOutputStream); + _currentEntry.PostProcessOutput(_outputStream); + // workitem 12964 + if (_currentEntry.OutputUsedZip64!=null) + _anyEntriesUsedZip64 |= _currentEntry.OutputUsedZip64.Value; + + // reset all the streams + _outputCounter = null; _encryptor = _deflater = null; _entryOutputStream = null; + } + } + + + + /// + /// Dispose the stream + /// + /// + /// + /// + /// This method writes the Zip Central directory, then closes the stream. The + /// application must call Dispose() (or Close) in order to produce a valid zip file. + /// + /// + /// + /// Typically the application will call Dispose() implicitly, via a using + /// statement in C#, or a Using statement in VB. + /// + /// + /// + /// + /// set this to true, always. + protected override void Dispose(bool disposing) + { + if (_disposed) return; + + if (disposing) // not called from finalizer + { + // handle pending exceptions + if (!_exceptionPending) + { + _FinishCurrentEntry(); + _directoryNeededZip64 = ZipOutput.WriteCentralDirectoryStructure(_outputStream, + _entriesWritten.Values, + 1, // _numberOfSegmentsForMostRecentSave, + _zip64, + Comment, + new ZipContainer(this)); + Stream wrappedStream = null; + CountingStream cs = _outputStream as CountingStream; + if (cs != null) + { + wrappedStream = cs.WrappedStream; +#if NETCF + cs.Close(); +#else + cs.Dispose(); +#endif + } + else + { + wrappedStream = _outputStream; + } + + if (!_leaveUnderlyingStreamOpen) + { +#if NETCF + wrappedStream.Close(); +#else + wrappedStream.Dispose(); +#endif + } + _outputStream = null; + } + } + _disposed = true; + } + + + + /// + /// Always returns false. + /// + public override bool CanRead { get { return false; } } + + /// + /// Always returns false. + /// + public override bool CanSeek { get { return false; } } + + /// + /// Always returns true. + /// + public override bool CanWrite { get { return true; } } + + /// + /// Always returns a NotSupportedException. + /// + public override long Length { get { throw new NotSupportedException(); } } + + /// + /// Setting this property always returns a NotSupportedException. Getting it + /// returns the value of the Position on the underlying stream. + /// + public override long Position + { + get { return _outputStream.Position; } + set { throw new NotSupportedException(); } + } + + /// + /// This is a no-op. + /// + public override void Flush() { } + + /// + /// This method always throws a NotSupportedException. + /// + /// ignored + /// ignored + /// ignored + /// nothing + public override int Read(byte[] buffer, int offset, int count) + { + throw new NotSupportedException("Read"); + } + + /// + /// This method always throws a NotSupportedException. + /// + /// ignored + /// ignored + /// nothing + public override long Seek(long offset, SeekOrigin origin) + { + throw new NotSupportedException("Seek"); + } + + /// + /// This method always throws a NotSupportedException. + /// + /// ignored + public override void SetLength(long value) + { + throw new NotSupportedException(); + } + + + private EncryptionAlgorithm _encryption; + private ZipEntryTimestamp _timestamp; + internal String _password; + private String _comment; + private Stream _outputStream; + private ZipEntry _currentEntry; + internal Zip64Option _zip64; + private Dictionary _entriesWritten; + private int _entryCount; + private ZipOption _alternateEncodingUsage = ZipOption.Never; + private System.Text.Encoding _alternateEncoding + = System.Text.Encoding.GetEncoding("IBM437"); // default = IBM437 + + private bool _leaveUnderlyingStreamOpen; + private bool _disposed; + private bool _exceptionPending; // **see note below + private bool _anyEntriesUsedZip64, _directoryNeededZip64; + private CountingStream _outputCounter; + private Stream _encryptor; + private Stream _deflater; + private Ionic.Crc.CrcCalculatorStream _entryOutputStream; + private bool _needToWriteEntryHeader; + private string _name; + private bool _DontIgnoreCase; +#if !NETCF + internal Ionic.Zlib.ParallelDeflateOutputStream ParallelDeflater; + private long _ParallelDeflateThreshold; + private int _maxBufferPairs = 16; +#endif + + // **Note regarding exceptions: + + // When ZipOutputStream is employed within a using clause, which + // is the typical scenario, and an exception is thrown within + // the scope of the using, Close()/Dispose() is invoked + // implicitly before processing the initial exception. In that + // case, _exceptionPending is true, and we don't want to try to + // write anything in the Close/Dispose logic. Doing so can + // cause additional exceptions that mask the original one. So, + // the _exceptionPending flag is used to track that, and to + // allow the original exception to be propagated to the + // application without extra "noise." + + } + + + + internal class ZipContainer + { + private ZipFile _zf; + private ZipOutputStream _zos; + private ZipInputStream _zis; + + public ZipContainer(Object o) + { + _zf = (o as ZipFile); + _zos = (o as ZipOutputStream); + _zis = (o as ZipInputStream); + } + + public ZipFile ZipFile + { + get { return _zf; } + } + + public ZipOutputStream ZipOutputStream + { + get { return _zos; } + } + + public string Name + { + get + { + if (_zf != null) return _zf.Name; + if (_zis != null) throw new NotSupportedException(); + return _zos.Name; + } + } + + public string Password + { + get + { + if (_zf != null) return _zf._Password; + if (_zis != null) return _zis._Password; + return _zos._password; + } + } + + public Zip64Option Zip64 + { + get + { + if (_zf != null) return _zf._zip64; + if (_zis != null) throw new NotSupportedException(); + return _zos._zip64; + } + } + + public int BufferSize + { + get + { + if (_zf != null) return _zf.BufferSize; + if (_zis != null) throw new NotSupportedException(); + return 0; + } + } + +#if !NETCF + public Ionic.Zlib.ParallelDeflateOutputStream ParallelDeflater + { + get + { + if (_zf != null) return _zf.ParallelDeflater; + if (_zis != null) return null; + return _zos.ParallelDeflater; + } + set + { + if (_zf != null) _zf.ParallelDeflater = value; + else if (_zos != null) _zos.ParallelDeflater = value; + } + } + + public long ParallelDeflateThreshold + { + get + { + if (_zf != null) return _zf.ParallelDeflateThreshold; + return _zos.ParallelDeflateThreshold; + } + } + public int ParallelDeflateMaxBufferPairs + { + get + { + if (_zf != null) return _zf.ParallelDeflateMaxBufferPairs; + return _zos.ParallelDeflateMaxBufferPairs; + } + } +#endif + + public int CodecBufferSize + { + get + { + if (_zf != null) return _zf.CodecBufferSize; + if (_zis != null) return _zis.CodecBufferSize; + return _zos.CodecBufferSize; + } + } + + public Ionic.Zlib.CompressionStrategy Strategy + { + get + { + if (_zf != null) return _zf.Strategy; + return _zos.Strategy; + } + } + + public Zip64Option UseZip64WhenSaving + { + get + { + if (_zf != null) return _zf.UseZip64WhenSaving; + return _zos.EnableZip64; + } + } + + public System.Text.Encoding AlternateEncoding + { + get + { + if (_zf != null) return _zf.AlternateEncoding; + if (_zos!=null) return _zos.AlternateEncoding; + return null; + } + } + public System.Text.Encoding DefaultEncoding + { + get + { + if (_zf != null) return ZipFile.DefaultEncoding; + if (_zos!=null) return ZipOutputStream.DefaultEncoding; + return null; + } + } + public ZipOption AlternateEncodingUsage + { + get + { + if (_zf != null) return _zf.AlternateEncodingUsage; + if (_zos!=null) return _zos.AlternateEncodingUsage; + return ZipOption.Never; // n/a + } + } + + public Stream ReadStream + { + get + { + if (_zf != null) return _zf.ReadStream; + return _zis.ReadStream; + } + } + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zip/ZipSegmentedStream.cs b/Resources/Libraries/DotNetZip/Source/Zip/ZipSegmentedStream.cs new file mode 100644 index 00000000..bb27b12d --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zip/ZipSegmentedStream.cs @@ -0,0 +1,571 @@ +// ZipSegmentedStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-13 22:25:45> +// +// ------------------------------------------------------------------ +// +// This module defines logic for zip streams that span disk files. +// +// ------------------------------------------------------------------ + + +using System; +using System.Collections.Generic; +using System.IO; + +namespace Ionic.Zip +{ + internal class ZipSegmentedStream : System.IO.Stream + { + enum RwMode + { + None = 0, + ReadOnly = 1, + Write = 2, + //Update = 3 + } + + private RwMode rwMode; + private bool _exceptionPending; // **see note below + private string _baseName; + private string _baseDir; + //private bool _isDisposed; + private string _currentName; + private string _currentTempName; + private uint _currentDiskNumber; + private uint _maxDiskNumber; + private int _maxSegmentSize; + private System.IO.Stream _innerStream; + + // **Note regarding exceptions: + // + // When ZipSegmentedStream is employed within a using clause, + // which is the typical scenario, and an exception is thrown + // within the scope of the using, Dispose() is invoked + // implicitly before processing the initial exception. If that + // happens, this class sets _exceptionPending to true, and then + // within the Dispose(bool), takes special action as + // appropriate. Need to be careful: any additional exceptions + // will mask the original one. + + private ZipSegmentedStream() : base() + { + _exceptionPending = false; + } + + public static ZipSegmentedStream ForReading(string name, + uint initialDiskNumber, + uint maxDiskNumber) + { + ZipSegmentedStream zss = new ZipSegmentedStream() + { + rwMode = RwMode.ReadOnly, + CurrentSegment = initialDiskNumber, + _maxDiskNumber = maxDiskNumber, + _baseName = name, + }; + + // Console.WriteLine("ZSS: ForReading ({0})", + // Path.GetFileName(zss.CurrentName)); + + zss._SetReadStream(); + + return zss; + } + + + public static ZipSegmentedStream ForWriting(string name, int maxSegmentSize) + { + ZipSegmentedStream zss = new ZipSegmentedStream() + { + rwMode = RwMode.Write, + CurrentSegment = 0, + _baseName = name, + _maxSegmentSize = maxSegmentSize, + _baseDir = Path.GetDirectoryName(name) + }; + + // workitem 9522 + if (zss._baseDir=="") zss._baseDir="."; + + zss._SetWriteStream(0); + + // Console.WriteLine("ZSS: ForWriting ({0})", + // Path.GetFileName(zss.CurrentName)); + + return zss; + } + + + /// + /// Sort-of like a factory method, ForUpdate is used only when + /// the application needs to update the zip entry metadata for + /// a segmented zip file, when the starting segment is earlier + /// than the ending segment, for a particular entry. + /// + /// + /// + /// The update is always contiguous, never rolls over. As a + /// result, this method doesn't need to return a ZSS; it can + /// simply return a FileStream. That's why it's "sort of" + /// like a Factory method. + /// + /// + /// Caller must Close/Dispose the stream object returned by + /// this method. + /// + /// + public static Stream ForUpdate(string name, uint diskNumber) + { + if (diskNumber >= 99) + throw new ArgumentOutOfRangeException("diskNumber"); + + string fname = + String.Format("{0}.z{1:D2}", + Path.Combine(Path.GetDirectoryName(name), + Path.GetFileNameWithoutExtension(name)), + diskNumber + 1); + + // Console.WriteLine("ZSS: ForUpdate ({0})", + // Path.GetFileName(fname)); + + // This class assumes that the update will not expand the + // size of the segment. Update is used only for an in-place + // update of zip metadata. It never will try to write beyond + // the end of a segment. + + return File.Open(fname, + FileMode.Open, + FileAccess.ReadWrite, + FileShare.None); + } + + public bool ContiguousWrite + { + get; + set; + } + + + public UInt32 CurrentSegment + { + get + { + return _currentDiskNumber; + } + private set + { + _currentDiskNumber = value; + _currentName = null; // it will get updated next time referenced + } + } + + /// + /// Name of the filesystem file corresponding to the current segment. + /// + /// + /// + /// The name is not always the name currently being used in the + /// filesystem. When rwMode is RwMode.Write, the filesystem file has a + /// temporary name until the stream is closed or until the next segment is + /// started. + /// + /// + public String CurrentName + { + get + { + if (_currentName==null) + _currentName = _NameForSegment(CurrentSegment); + + return _currentName; + } + } + + + public String CurrentTempName + { + get + { + return _currentTempName; + } + } + + private string _NameForSegment(uint diskNumber) + { + if (diskNumber >= 99) + { + _exceptionPending = true; + throw new OverflowException("The number of zip segments would exceed 99."); + } + + return String.Format("{0}.z{1:D2}", + Path.Combine(Path.GetDirectoryName(_baseName), + Path.GetFileNameWithoutExtension(_baseName)), + diskNumber + 1); + } + + + // Returns the segment that WILL be current if writing + // a block of the given length. + // This isn't exactly true. It could roll over beyond + // this number. + public UInt32 ComputeSegment(int length) + { + if (_innerStream.Position + length > _maxSegmentSize) + // the block will go AT LEAST into the next segment + return CurrentSegment + 1; + + // it will fit in the current segment + return CurrentSegment; + } + + + public override String ToString() + { + return String.Format("{0}[{1}][{2}], pos=0x{3:X})", + "ZipSegmentedStream", CurrentName, + rwMode.ToString(), + this.Position); + } + + + private void _SetReadStream() + { + if (_innerStream != null) + { +#if NETCF + _innerStream.Close(); +#else + _innerStream.Dispose(); +#endif + } + + if (CurrentSegment + 1 == _maxDiskNumber) + _currentName = _baseName; + + // Console.WriteLine("ZSS: SRS ({0})", + // Path.GetFileName(CurrentName)); + + _innerStream = File.OpenRead(CurrentName); + } + + + /// + /// Read from the stream + /// + /// the buffer to read + /// the offset at which to start + /// the number of bytes to read + /// the number of bytes actually read + public override int Read(byte[] buffer, int offset, int count) + { + if (rwMode != RwMode.ReadOnly) + { + _exceptionPending = true; + throw new InvalidOperationException("Stream Error: Cannot Read."); + } + + int r = _innerStream.Read(buffer, offset, count); + int r1 = r; + + while (r1 != count) + { + if (_innerStream.Position != _innerStream.Length) + { + _exceptionPending = true; + throw new ZipException(String.Format("Read error in file {0}", CurrentName)); + + } + + if (CurrentSegment + 1 == _maxDiskNumber) + return r; // no more to read + + CurrentSegment++; + _SetReadStream(); + offset += r1; + count -= r1; + r1 = _innerStream.Read(buffer, offset, count); + r += r1; + } + return r; + } + + + + private void _SetWriteStream(uint increment) + { + if (_innerStream != null) + { +#if NETCF + _innerStream.Close(); +#else + _innerStream.Dispose(); +#endif + if (File.Exists(CurrentName)) + File.Delete(CurrentName); + File.Move(_currentTempName, CurrentName); + // Console.WriteLine("ZSS: SWS close ({0})", + // Path.GetFileName(CurrentName)); + } + + if (increment > 0) + CurrentSegment += increment; + + SharedUtilities.CreateAndOpenUniqueTempFile(_baseDir, + out _innerStream, + out _currentTempName); + + // Console.WriteLine("ZSS: SWS open ({0})", + // Path.GetFileName(_currentTempName)); + + if (CurrentSegment == 0) + _innerStream.Write(BitConverter.GetBytes(ZipConstants.SplitArchiveSignature), 0, 4); + } + + + /// + /// Write to the stream. + /// + /// the buffer from which to write + /// the offset at which to start writing + /// the number of bytes to write + public override void Write(byte[] buffer, int offset, int count) + { + if (rwMode != RwMode.Write) + { + _exceptionPending = true; + throw new InvalidOperationException("Stream Error: Cannot Write."); + } + + + if (ContiguousWrite) + { + // enough space for a contiguous write? + if (_innerStream.Position + count > _maxSegmentSize) + _SetWriteStream(1); + } + else + { + while (_innerStream.Position + count > _maxSegmentSize) + { + int c = unchecked(_maxSegmentSize - (int)_innerStream.Position); + _innerStream.Write(buffer, offset, c); + _SetWriteStream(1); + count -= c; + offset += c; + } + } + + _innerStream.Write(buffer, offset, count); + } + + + public long TruncateBackward(uint diskNumber, long offset) + { + // Console.WriteLine("***ZSS.Trunc to disk {0}", diskNumber); + // Console.WriteLine("***ZSS.Trunc: current disk {0}", CurrentSegment); + if (diskNumber >= 99) + throw new ArgumentOutOfRangeException("diskNumber"); + + if (rwMode != RwMode.Write) + { + _exceptionPending = true; + throw new ZipException("bad state."); + } + + // Seek back in the segmented stream to a (maybe) prior segment. + + // Check if it is the same segment. If it is, very simple. + if (diskNumber == CurrentSegment) + { + var x =_innerStream.Seek(offset, SeekOrigin.Begin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_innerStream); + return x; + } + + // Seeking back to a prior segment. + // The current segment and any intervening segments must be removed. + // First, close the current segment, and then remove it. + if (_innerStream != null) + { +#if NETCF + _innerStream.Close(); +#else + _innerStream.Dispose(); +#endif + if (File.Exists(_currentTempName)) + File.Delete(_currentTempName); + } + + // Now, remove intervening segments. + for (uint j= CurrentSegment-1; j > diskNumber; j--) + { + string s = _NameForSegment(j); + // Console.WriteLine("***ZSS.Trunc: removing file {0}", s); + if (File.Exists(s)) + File.Delete(s); + } + + // now, open the desired segment. It must exist. + CurrentSegment = diskNumber; + + // get a new temp file, try 3 times: + for (int i = 0; i < 3; i++) + { + try + { + _currentTempName = SharedUtilities.InternalGetTempFileName(); + // move the .z0x file back to a temp name + File.Move(CurrentName, _currentTempName); + break; // workitem 12403 + } + catch(IOException) + { + if (i == 2) throw; + } + } + + // open it + _innerStream = new FileStream(_currentTempName, FileMode.Open); + + var r = _innerStream.Seek(offset, SeekOrigin.Begin); + + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_innerStream); + + return r; + } + + + + public override bool CanRead + { + get + { + return (rwMode == RwMode.ReadOnly && + (_innerStream != null) && + _innerStream.CanRead); + } + } + + + public override bool CanSeek + { + get + { + return (_innerStream != null) && + _innerStream.CanSeek; + } + } + + + public override bool CanWrite + { + get + { + return (rwMode == RwMode.Write) && + (_innerStream != null) && + _innerStream.CanWrite; + } + } + + public override void Flush() + { + _innerStream.Flush(); + } + + public override long Length + { + get + { + return _innerStream.Length; + } + } + + public override long Position + { + get { return _innerStream.Position; } + set { _innerStream.Position = value; } + } + + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + var x = _innerStream.Seek(offset, origin); + // workitem 10178 + Ionic.Zip.SharedUtilities.Workaround_Ladybug318918(_innerStream); + return x; + } + + public override void SetLength(long value) + { + if (rwMode != RwMode.Write) + { + _exceptionPending = true; + throw new InvalidOperationException(); + } + _innerStream.SetLength(value); + } + + + protected override void Dispose(bool disposing) + { + // this gets called by Stream.Close() + + // if (_isDisposed) return; + // _isDisposed = true; + //Console.WriteLine("Dispose (mode={0})\n", rwMode.ToString()); + + try + { + if (_innerStream != null) + { +#if NETCF + _innerStream.Close(); +#else + _innerStream.Dispose(); +#endif + //_innerStream = null; + if (rwMode == RwMode.Write) + { + if (_exceptionPending) + { + // possibly could try to clean up all the + // temp files created so far... + } + else + { + // // move the final temp file to the .zNN name + // if (File.Exists(CurrentName)) + // File.Delete(CurrentName); + // if (File.Exists(_currentTempName)) + // File.Move(_currentTempName, CurrentName); + } + } + } + } + finally + { + base.Dispose(disposing); + } + } + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/Deflate.cs b/Resources/Libraries/DotNetZip/Source/Zlib/Deflate.cs new file mode 100644 index 00000000..be401b8d --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/Deflate.cs @@ -0,0 +1,1879 @@ +// Deflate.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-03 19:52:15> +// +// ------------------------------------------------------------------ +// +// This module defines logic for handling the Deflate or compression. +// +// This code is based on multiple sources: +// - the original zlib v1.2.3 source, which is Copyright (C) 1995-2005 Jean-loup Gailly. +// - the original jzlib, which is Copyright (c) 2000-2003 ymnk, JCraft,Inc. +// +// However, this code is significantly different from both. +// The object model is not the same, and many of the behaviors are different. +// +// In keeping with the license for these other works, the copyrights for +// jzlib and zlib are here. +// +// ----------------------------------------------------------------------- +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// This program is based on zlib-1.1.3; credit to authors +// Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) +// and contributors of zlib. +// +// ----------------------------------------------------------------------- + + +using System; + +namespace Ionic.Zlib +{ + + internal enum BlockState + { + NeedMore = 0, // block not completed, need more input or more output + BlockDone, // block flush performed + FinishStarted, // finish started, need only more output at next deflate + FinishDone // finish done, accept no more input or output + } + + internal enum DeflateFlavor + { + Store, + Fast, + Slow + } + + internal sealed class DeflateManager + { + private static readonly int MEM_LEVEL_MAX = 9; + private static readonly int MEM_LEVEL_DEFAULT = 8; + + internal delegate BlockState CompressFunc(FlushType flush); + + internal class Config + { + // Use a faster search when the previous match is longer than this + internal int GoodLength; // reduce lazy search above this match length + + // Attempt to find a better match only when the current match is + // strictly smaller than this value. This mechanism is used only for + // compression levels >= 4. For levels 1,2,3: MaxLazy is actually + // MaxInsertLength. (See DeflateFast) + + internal int MaxLazy; // do not perform lazy search above this match length + + internal int NiceLength; // quit search above this match length + + // To speed up deflation, hash chains are never searched beyond this + // length. A higher limit improves compression ratio but degrades the speed. + + internal int MaxChainLength; + + internal DeflateFlavor Flavor; + + private Config(int goodLength, int maxLazy, int niceLength, int maxChainLength, DeflateFlavor flavor) + { + this.GoodLength = goodLength; + this.MaxLazy = maxLazy; + this.NiceLength = niceLength; + this.MaxChainLength = maxChainLength; + this.Flavor = flavor; + } + + public static Config Lookup(CompressionLevel level) + { + return Table[(int)level]; + } + + + static Config() + { + Table = new Config[] { + new Config(0, 0, 0, 0, DeflateFlavor.Store), + new Config(4, 4, 8, 4, DeflateFlavor.Fast), + new Config(4, 5, 16, 8, DeflateFlavor.Fast), + new Config(4, 6, 32, 32, DeflateFlavor.Fast), + + new Config(4, 4, 16, 16, DeflateFlavor.Slow), + new Config(8, 16, 32, 32, DeflateFlavor.Slow), + new Config(8, 16, 128, 128, DeflateFlavor.Slow), + new Config(8, 32, 128, 256, DeflateFlavor.Slow), + new Config(32, 128, 258, 1024, DeflateFlavor.Slow), + new Config(32, 258, 258, 4096, DeflateFlavor.Slow), + }; + } + + private static readonly Config[] Table; + } + + + private CompressFunc DeflateFunction; + + private static readonly System.String[] _ErrorMessage = new System.String[] + { + "need dictionary", + "stream end", + "", + "file error", + "stream error", + "data error", + "insufficient memory", + "buffer error", + "incompatible version", + "" + }; + + // preset dictionary flag in zlib header + private static readonly int PRESET_DICT = 0x20; + + private static readonly int INIT_STATE = 42; + private static readonly int BUSY_STATE = 113; + private static readonly int FINISH_STATE = 666; + + // The deflate compression method + private static readonly int Z_DEFLATED = 8; + + private static readonly int STORED_BLOCK = 0; + private static readonly int STATIC_TREES = 1; + private static readonly int DYN_TREES = 2; + + // The three kinds of block type + private static readonly int Z_BINARY = 0; + private static readonly int Z_ASCII = 1; + private static readonly int Z_UNKNOWN = 2; + + private static readonly int Buf_size = 8 * 2; + + private static readonly int MIN_MATCH = 3; + private static readonly int MAX_MATCH = 258; + + private static readonly int MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1); + + private static readonly int HEAP_SIZE = (2 * InternalConstants.L_CODES + 1); + + private static readonly int END_BLOCK = 256; + + internal ZlibCodec _codec; // the zlib encoder/decoder + internal int status; // as the name implies + internal byte[] pending; // output still pending - waiting to be compressed + internal int nextPending; // index of next pending byte to output to the stream + internal int pendingCount; // number of bytes in the pending buffer + + internal sbyte data_type; // UNKNOWN, BINARY or ASCII + internal int last_flush; // value of flush param for previous deflate call + + internal int w_size; // LZ77 window size (32K by default) + internal int w_bits; // log2(w_size) (8..16) + internal int w_mask; // w_size - 1 + + //internal byte[] dictionary; + internal byte[] window; + + // Sliding window. Input bytes are read into the second half of the window, + // and move to the first half later to keep a dictionary of at least wSize + // bytes. With this organization, matches are limited to a distance of + // wSize-MAX_MATCH bytes, but this ensures that IO is always + // performed with a length multiple of the block size. + // + // To do: use the user input buffer as sliding window. + + internal int window_size; + // Actual size of window: 2*wSize, except when the user input buffer + // is directly used as sliding window. + + internal short[] prev; + // Link to older string with same hash index. To limit the size of this + // array to 64K, this link is maintained only for the last 32K strings. + // An index in this array is thus a window index modulo 32K. + + internal short[] head; // Heads of the hash chains or NIL. + + internal int ins_h; // hash index of string to be inserted + internal int hash_size; // number of elements in hash table + internal int hash_bits; // log2(hash_size) + internal int hash_mask; // hash_size-1 + + // Number of bits by which ins_h must be shifted at each input + // step. It must be such that after MIN_MATCH steps, the oldest + // byte no longer takes part in the hash key, that is: + // hash_shift * MIN_MATCH >= hash_bits + internal int hash_shift; + + // Window position at the beginning of the current output block. Gets + // negative when the window is moved backwards. + + internal int block_start; + + Config config; + internal int match_length; // length of best match + internal int prev_match; // previous match + internal int match_available; // set if previous match exists + internal int strstart; // start of string to insert into.....???? + internal int match_start; // start of matching string + internal int lookahead; // number of valid bytes ahead in window + + // Length of the best match at previous step. Matches not greater than this + // are discarded. This is used in the lazy match evaluation. + internal int prev_length; + + // Insert new strings in the hash table only if the match length is not + // greater than this length. This saves time but degrades compression. + // max_insert_length is used only for compression levels <= 3. + + internal CompressionLevel compressionLevel; // compression level (1..9) + internal CompressionStrategy compressionStrategy; // favor or force Huffman coding + + + internal short[] dyn_ltree; // literal and length tree + internal short[] dyn_dtree; // distance tree + internal short[] bl_tree; // Huffman tree for bit lengths + + internal Tree treeLiterals = new Tree(); // desc for literal tree + internal Tree treeDistances = new Tree(); // desc for distance tree + internal Tree treeBitLengths = new Tree(); // desc for bit length tree + + // number of codes at each bit length for an optimal tree + internal short[] bl_count = new short[InternalConstants.MAX_BITS + 1]; + + // heap used to build the Huffman trees + internal int[] heap = new int[2 * InternalConstants.L_CODES + 1]; + + internal int heap_len; // number of elements in the heap + internal int heap_max; // element of largest frequency + + // The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used. + // The same heap array is used to build all trees. + + // Depth of each subtree used as tie breaker for trees of equal frequency + internal sbyte[] depth = new sbyte[2 * InternalConstants.L_CODES + 1]; + + internal int _lengthOffset; // index for literals or lengths + + + // Size of match buffer for literals/lengths. There are 4 reasons for + // limiting lit_bufsize to 64K: + // - frequencies can be kept in 16 bit counters + // - if compression is not successful for the first block, all input + // data is still in the window so we can still emit a stored block even + // when input comes from standard input. (This can also be done for + // all blocks if lit_bufsize is not greater than 32K.) + // - if compression is not successful for a file smaller than 64K, we can + // even emit a stored file instead of a stored block (saving 5 bytes). + // This is applicable only for zip (not gzip or zlib). + // - creating new Huffman trees less frequently may not provide fast + // adaptation to changes in the input data statistics. (Take for + // example a binary file with poorly compressible code followed by + // a highly compressible string table.) Smaller buffer sizes give + // fast adaptation but have of course the overhead of transmitting + // trees more frequently. + + internal int lit_bufsize; + + internal int last_lit; // running index in l_buf + + // Buffer for distances. To simplify the code, d_buf and l_buf have + // the same number of elements. To use different lengths, an extra flag + // array would be necessary. + + internal int _distanceOffset; // index into pending; points to distance data?? + + internal int opt_len; // bit length of current block with optimal trees + internal int static_len; // bit length of current block with static trees + internal int matches; // number of string matches in current block + internal int last_eob_len; // bit length of EOB code for last block + + // Output buffer. bits are inserted starting at the bottom (least + // significant bits). + internal short bi_buf; + + // Number of valid bits in bi_buf. All bits above the last valid bit + // are always zero. + internal int bi_valid; + + + internal DeflateManager() + { + dyn_ltree = new short[HEAP_SIZE * 2]; + dyn_dtree = new short[(2 * InternalConstants.D_CODES + 1) * 2]; // distance tree + bl_tree = new short[(2 * InternalConstants.BL_CODES + 1) * 2]; // Huffman tree for bit lengths + } + + + // lm_init + private void _InitializeLazyMatch() + { + window_size = 2 * w_size; + + // clear the hash - workitem 9063 + Array.Clear(head, 0, hash_size); + //for (int i = 0; i < hash_size; i++) head[i] = 0; + + config = Config.Lookup(compressionLevel); + SetDeflater(); + + strstart = 0; + block_start = 0; + lookahead = 0; + match_length = prev_length = MIN_MATCH - 1; + match_available = 0; + ins_h = 0; + } + + // Initialize the tree data structures for a new zlib stream. + private void _InitializeTreeData() + { + treeLiterals.dyn_tree = dyn_ltree; + treeLiterals.staticTree = StaticTree.Literals; + + treeDistances.dyn_tree = dyn_dtree; + treeDistances.staticTree = StaticTree.Distances; + + treeBitLengths.dyn_tree = bl_tree; + treeBitLengths.staticTree = StaticTree.BitLengths; + + bi_buf = 0; + bi_valid = 0; + last_eob_len = 8; // enough lookahead for inflate + + // Initialize the first block of the first file: + _InitializeBlocks(); + } + + internal void _InitializeBlocks() + { + // Initialize the trees. + for (int i = 0; i < InternalConstants.L_CODES; i++) + dyn_ltree[i * 2] = 0; + for (int i = 0; i < InternalConstants.D_CODES; i++) + dyn_dtree[i * 2] = 0; + for (int i = 0; i < InternalConstants.BL_CODES; i++) + bl_tree[i * 2] = 0; + + dyn_ltree[END_BLOCK * 2] = 1; + opt_len = static_len = 0; + last_lit = matches = 0; + } + + // Restore the heap property by moving down the tree starting at node k, + // exchanging a node with the smallest of its two sons if necessary, stopping + // when the heap property is re-established (each father smaller than its + // two sons). + internal void pqdownheap(short[] tree, int k) + { + int v = heap[k]; + int j = k << 1; // left son of k + while (j <= heap_len) + { + // Set j to the smallest of the two sons: + if (j < heap_len && _IsSmaller(tree, heap[j + 1], heap[j], depth)) + { + j++; + } + // Exit if v is smaller than both sons + if (_IsSmaller(tree, v, heap[j], depth)) + break; + + // Exchange v with the smallest son + heap[k] = heap[j]; k = j; + // And continue down the tree, setting j to the left son of k + j <<= 1; + } + heap[k] = v; + } + + internal static bool _IsSmaller(short[] tree, int n, int m, sbyte[] depth) + { + short tn2 = tree[n * 2]; + short tm2 = tree[m * 2]; + return (tn2 < tm2 || (tn2 == tm2 && depth[n] <= depth[m])); + } + + + // Scan a literal or distance tree to determine the frequencies of the codes + // in the bit length tree. + internal void scan_tree(short[] tree, int max_code) + { + int n; // iterates over all tree elements + int prevlen = -1; // last emitted length + int curlen; // length of current code + int nextlen = (int)tree[0 * 2 + 1]; // length of next code + int count = 0; // repeat count of the current code + int max_count = 7; // max repeat count + int min_count = 4; // min repeat count + + if (nextlen == 0) + { + max_count = 138; min_count = 3; + } + tree[(max_code + 1) * 2 + 1] = (short)0x7fff; // guard //?? + + for (n = 0; n <= max_code; n++) + { + curlen = nextlen; nextlen = (int)tree[(n + 1) * 2 + 1]; + if (++count < max_count && curlen == nextlen) + { + continue; + } + else if (count < min_count) + { + bl_tree[curlen * 2] = (short)(bl_tree[curlen * 2] + count); + } + else if (curlen != 0) + { + if (curlen != prevlen) + bl_tree[curlen * 2]++; + bl_tree[InternalConstants.REP_3_6 * 2]++; + } + else if (count <= 10) + { + bl_tree[InternalConstants.REPZ_3_10 * 2]++; + } + else + { + bl_tree[InternalConstants.REPZ_11_138 * 2]++; + } + count = 0; prevlen = curlen; + if (nextlen == 0) + { + max_count = 138; min_count = 3; + } + else if (curlen == nextlen) + { + max_count = 6; min_count = 3; + } + else + { + max_count = 7; min_count = 4; + } + } + } + + // Construct the Huffman tree for the bit lengths and return the index in + // bl_order of the last bit length code to send. + internal int build_bl_tree() + { + int max_blindex; // index of last bit length code of non zero freq + + // Determine the bit length frequencies for literal and distance trees + scan_tree(dyn_ltree, treeLiterals.max_code); + scan_tree(dyn_dtree, treeDistances.max_code); + + // Build the bit length tree: + treeBitLengths.build_tree(this); + // opt_len now includes the length of the tree representations, except + // the lengths of the bit lengths codes and the 5+5+4 bits for the counts. + + // Determine the number of bit length codes to send. The pkzip format + // requires that at least 4 bit length codes be sent. (appnote.txt says + // 3 but the actual value used is 4.) + for (max_blindex = InternalConstants.BL_CODES - 1; max_blindex >= 3; max_blindex--) + { + if (bl_tree[Tree.bl_order[max_blindex] * 2 + 1] != 0) + break; + } + // Update opt_len to include the bit length tree and counts + opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4; + + return max_blindex; + } + + + // Send the header for a block using dynamic Huffman trees: the counts, the + // lengths of the bit length codes, the literal tree and the distance tree. + // IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4. + internal void send_all_trees(int lcodes, int dcodes, int blcodes) + { + int rank; // index in bl_order + + send_bits(lcodes - 257, 5); // not +255 as stated in appnote.txt + send_bits(dcodes - 1, 5); + send_bits(blcodes - 4, 4); // not -3 as stated in appnote.txt + for (rank = 0; rank < blcodes; rank++) + { + send_bits(bl_tree[Tree.bl_order[rank] * 2 + 1], 3); + } + send_tree(dyn_ltree, lcodes - 1); // literal tree + send_tree(dyn_dtree, dcodes - 1); // distance tree + } + + // Send a literal or distance tree in compressed form, using the codes in + // bl_tree. + internal void send_tree(short[] tree, int max_code) + { + int n; // iterates over all tree elements + int prevlen = -1; // last emitted length + int curlen; // length of current code + int nextlen = tree[0 * 2 + 1]; // length of next code + int count = 0; // repeat count of the current code + int max_count = 7; // max repeat count + int min_count = 4; // min repeat count + + if (nextlen == 0) + { + max_count = 138; min_count = 3; + } + + for (n = 0; n <= max_code; n++) + { + curlen = nextlen; nextlen = tree[(n + 1) * 2 + 1]; + if (++count < max_count && curlen == nextlen) + { + continue; + } + else if (count < min_count) + { + do + { + send_code(curlen, bl_tree); + } + while (--count != 0); + } + else if (curlen != 0) + { + if (curlen != prevlen) + { + send_code(curlen, bl_tree); count--; + } + send_code(InternalConstants.REP_3_6, bl_tree); + send_bits(count - 3, 2); + } + else if (count <= 10) + { + send_code(InternalConstants.REPZ_3_10, bl_tree); + send_bits(count - 3, 3); + } + else + { + send_code(InternalConstants.REPZ_11_138, bl_tree); + send_bits(count - 11, 7); + } + count = 0; prevlen = curlen; + if (nextlen == 0) + { + max_count = 138; min_count = 3; + } + else if (curlen == nextlen) + { + max_count = 6; min_count = 3; + } + else + { + max_count = 7; min_count = 4; + } + } + } + + // Output a block of bytes on the stream. + // IN assertion: there is enough room in pending_buf. + private void put_bytes(byte[] p, int start, int len) + { + Array.Copy(p, start, pending, pendingCount, len); + pendingCount += len; + } + +#if NOTNEEDED + private void put_byte(byte c) + { + pending[pendingCount++] = c; + } + internal void put_short(int b) + { + unchecked + { + pending[pendingCount++] = (byte)b; + pending[pendingCount++] = (byte)(b >> 8); + } + } + internal void putShortMSB(int b) + { + unchecked + { + pending[pendingCount++] = (byte)(b >> 8); + pending[pendingCount++] = (byte)b; + } + } +#endif + + internal void send_code(int c, short[] tree) + { + int c2 = c * 2; + send_bits((tree[c2] & 0xffff), (tree[c2 + 1] & 0xffff)); + } + + internal void send_bits(int value, int length) + { + int len = length; + unchecked + { + if (bi_valid > (int)Buf_size - len) + { + //int val = value; + // bi_buf |= (val << bi_valid); + + bi_buf |= (short)((value << bi_valid) & 0xffff); + //put_short(bi_buf); + pending[pendingCount++] = (byte)bi_buf; + pending[pendingCount++] = (byte)(bi_buf >> 8); + + + bi_buf = (short)((uint)value >> (Buf_size - bi_valid)); + bi_valid += len - Buf_size; + } + else + { + // bi_buf |= (value) << bi_valid; + bi_buf |= (short)((value << bi_valid) & 0xffff); + bi_valid += len; + } + } + } + + // Send one empty static block to give enough lookahead for inflate. + // This takes 10 bits, of which 7 may remain in the bit buffer. + // The current inflate code requires 9 bits of lookahead. If the + // last two codes for the previous block (real code plus EOB) were coded + // on 5 bits or less, inflate may have only 5+3 bits of lookahead to decode + // the last real code. In this case we send two empty static blocks instead + // of one. (There are no problems if the previous block is stored or fixed.) + // To simplify the code, we assume the worst case of last real code encoded + // on one bit only. + internal void _tr_align() + { + send_bits(STATIC_TREES << 1, 3); + send_code(END_BLOCK, StaticTree.lengthAndLiteralsTreeCodes); + + bi_flush(); + + // Of the 10 bits for the empty block, we have already sent + // (10 - bi_valid) bits. The lookahead for the last real code (before + // the EOB of the previous block) was thus at least one plus the length + // of the EOB plus what we have just sent of the empty static block. + if (1 + last_eob_len + 10 - bi_valid < 9) + { + send_bits(STATIC_TREES << 1, 3); + send_code(END_BLOCK, StaticTree.lengthAndLiteralsTreeCodes); + bi_flush(); + } + last_eob_len = 7; + } + + + // Save the match info and tally the frequency counts. Return true if + // the current block must be flushed. + internal bool _tr_tally(int dist, int lc) + { + pending[_distanceOffset + last_lit * 2] = unchecked((byte) ( (uint)dist >> 8 ) ); + pending[_distanceOffset + last_lit * 2 + 1] = unchecked((byte)dist); + pending[_lengthOffset + last_lit] = unchecked((byte)lc); + last_lit++; + + if (dist == 0) + { + // lc is the unmatched char + dyn_ltree[lc * 2]++; + } + else + { + matches++; + // Here, lc is the match length - MIN_MATCH + dist--; // dist = match distance - 1 + dyn_ltree[(Tree.LengthCode[lc] + InternalConstants.LITERALS + 1) * 2]++; + dyn_dtree[Tree.DistanceCode(dist) * 2]++; + } + + if ((last_lit & 0x1fff) == 0 && (int)compressionLevel > 2) + { + // Compute an upper bound for the compressed length + int out_length = last_lit << 3; + int in_length = strstart - block_start; + int dcode; + for (dcode = 0; dcode < InternalConstants.D_CODES; dcode++) + { + out_length = (int)(out_length + (int)dyn_dtree[dcode * 2] * (5L + Tree.ExtraDistanceBits[dcode])); + } + out_length >>= 3; + if ((matches < (last_lit / 2)) && out_length < in_length / 2) + return true; + } + + return (last_lit == lit_bufsize - 1) || (last_lit == lit_bufsize); + // dinoch - wraparound? + // We avoid equality with lit_bufsize because of wraparound at 64K + // on 16 bit machines and because stored blocks are restricted to + // 64K-1 bytes. + } + + + + // Send the block data compressed using the given Huffman trees + internal void send_compressed_block(short[] ltree, short[] dtree) + { + int distance; // distance of matched string + int lc; // match length or unmatched char (if dist == 0) + int lx = 0; // running index in l_buf + int code; // the code to send + int extra; // number of extra bits to send + + if (last_lit != 0) + { + do + { + int ix = _distanceOffset + lx * 2; + distance = ((pending[ix] << 8) & 0xff00) | + (pending[ix + 1] & 0xff); + lc = (pending[_lengthOffset + lx]) & 0xff; + lx++; + + if (distance == 0) + { + send_code(lc, ltree); // send a literal byte + } + else + { + // literal or match pair + // Here, lc is the match length - MIN_MATCH + code = Tree.LengthCode[lc]; + + // send the length code + send_code(code + InternalConstants.LITERALS + 1, ltree); + extra = Tree.ExtraLengthBits[code]; + if (extra != 0) + { + // send the extra length bits + lc -= Tree.LengthBase[code]; + send_bits(lc, extra); + } + distance--; // dist is now the match distance - 1 + code = Tree.DistanceCode(distance); + + // send the distance code + send_code(code, dtree); + + extra = Tree.ExtraDistanceBits[code]; + if (extra != 0) + { + // send the extra distance bits + distance -= Tree.DistanceBase[code]; + send_bits(distance, extra); + } + } + + // Check that the overlay between pending and d_buf+l_buf is ok: + } + while (lx < last_lit); + } + + send_code(END_BLOCK, ltree); + last_eob_len = ltree[END_BLOCK * 2 + 1]; + } + + + + // Set the data type to ASCII or BINARY, using a crude approximation: + // binary if more than 20% of the bytes are <= 6 or >= 128, ascii otherwise. + // IN assertion: the fields freq of dyn_ltree are set and the total of all + // frequencies does not exceed 64K (to fit in an int on 16 bit machines). + internal void set_data_type() + { + int n = 0; + int ascii_freq = 0; + int bin_freq = 0; + while (n < 7) + { + bin_freq += dyn_ltree[n * 2]; n++; + } + while (n < 128) + { + ascii_freq += dyn_ltree[n * 2]; n++; + } + while (n < InternalConstants.LITERALS) + { + bin_freq += dyn_ltree[n * 2]; n++; + } + data_type = (sbyte)(bin_freq > (ascii_freq >> 2) ? Z_BINARY : Z_ASCII); + } + + + + // Flush the bit buffer, keeping at most 7 bits in it. + internal void bi_flush() + { + if (bi_valid == 16) + { + pending[pendingCount++] = (byte)bi_buf; + pending[pendingCount++] = (byte)(bi_buf >> 8); + bi_buf = 0; + bi_valid = 0; + } + else if (bi_valid >= 8) + { + //put_byte((byte)bi_buf); + pending[pendingCount++] = (byte)bi_buf; + bi_buf >>= 8; + bi_valid -= 8; + } + } + + // Flush the bit buffer and align the output on a byte boundary + internal void bi_windup() + { + if (bi_valid > 8) + { + pending[pendingCount++] = (byte)bi_buf; + pending[pendingCount++] = (byte)(bi_buf >> 8); + } + else if (bi_valid > 0) + { + //put_byte((byte)bi_buf); + pending[pendingCount++] = (byte)bi_buf; + } + bi_buf = 0; + bi_valid = 0; + } + + // Copy a stored block, storing first the length and its + // one's complement if requested. + internal void copy_block(int buf, int len, bool header) + { + bi_windup(); // align on byte boundary + last_eob_len = 8; // enough lookahead for inflate + + if (header) + unchecked + { + //put_short((short)len); + pending[pendingCount++] = (byte)len; + pending[pendingCount++] = (byte)(len >> 8); + //put_short((short)~len); + pending[pendingCount++] = (byte)~len; + pending[pendingCount++] = (byte)(~len >> 8); + } + + put_bytes(window, buf, len); + } + + internal void flush_block_only(bool eof) + { + _tr_flush_block(block_start >= 0 ? block_start : -1, strstart - block_start, eof); + block_start = strstart; + _codec.flush_pending(); + } + + // Copy without compression as much as possible from the input stream, return + // the current block state. + // This function does not insert new strings in the dictionary since + // uncompressible data is probably not useful. This function is used + // only for the level=0 compression option. + // NOTE: this function should be optimized to avoid extra copying from + // window to pending_buf. + internal BlockState DeflateNone(FlushType flush) + { + // Stored blocks are limited to 0xffff bytes, pending is limited + // to pending_buf_size, and each stored block has a 5 byte header: + + int max_block_size = 0xffff; + int max_start; + + if (max_block_size > pending.Length - 5) + { + max_block_size = pending.Length - 5; + } + + // Copy as much as possible from input to output: + while (true) + { + // Fill the window as much as possible: + if (lookahead <= 1) + { + _fillWindow(); + if (lookahead == 0 && flush == FlushType.None) + return BlockState.NeedMore; + if (lookahead == 0) + break; // flush the current block + } + + strstart += lookahead; + lookahead = 0; + + // Emit a stored block if pending will be full: + max_start = block_start + max_block_size; + if (strstart == 0 || strstart >= max_start) + { + // strstart == 0 is possible when wraparound on 16-bit machine + lookahead = (int)(strstart - max_start); + strstart = (int)max_start; + + flush_block_only(false); + if (_codec.AvailableBytesOut == 0) + return BlockState.NeedMore; + } + + // Flush if we may have to slide, otherwise block_start may become + // negative and the data will be gone: + if (strstart - block_start >= w_size - MIN_LOOKAHEAD) + { + flush_block_only(false); + if (_codec.AvailableBytesOut == 0) + return BlockState.NeedMore; + } + } + + flush_block_only(flush == FlushType.Finish); + if (_codec.AvailableBytesOut == 0) + return (flush == FlushType.Finish) ? BlockState.FinishStarted : BlockState.NeedMore; + + return flush == FlushType.Finish ? BlockState.FinishDone : BlockState.BlockDone; + } + + + // Send a stored block + internal void _tr_stored_block(int buf, int stored_len, bool eof) + { + send_bits((STORED_BLOCK << 1) + (eof ? 1 : 0), 3); // send block type + copy_block(buf, stored_len, true); // with header + } + + // Determine the best encoding for the current block: dynamic trees, static + // trees or store, and output the encoded block to the zip file. + internal void _tr_flush_block(int buf, int stored_len, bool eof) + { + int opt_lenb, static_lenb; // opt_len and static_len in bytes + int max_blindex = 0; // index of last bit length code of non zero freq + + // Build the Huffman trees unless a stored block is forced + if (compressionLevel > 0) + { + // Check if the file is ascii or binary + if (data_type == Z_UNKNOWN) + set_data_type(); + + // Construct the literal and distance trees + treeLiterals.build_tree(this); + + treeDistances.build_tree(this); + + // At this point, opt_len and static_len are the total bit lengths of + // the compressed block data, excluding the tree representations. + + // Build the bit length tree for the above two trees, and get the index + // in bl_order of the last bit length code to send. + max_blindex = build_bl_tree(); + + // Determine the best encoding. Compute first the block length in bytes + opt_lenb = (opt_len + 3 + 7) >> 3; + static_lenb = (static_len + 3 + 7) >> 3; + + if (static_lenb <= opt_lenb) + opt_lenb = static_lenb; + } + else + { + opt_lenb = static_lenb = stored_len + 5; // force a stored block + } + + if (stored_len + 4 <= opt_lenb && buf != -1) + { + // 4: two words for the lengths + // The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE. + // Otherwise we can't have processed more than WSIZE input bytes since + // the last block flush, because compression would have been + // successful. If LIT_BUFSIZE <= WSIZE, it is never too late to + // transform a block into a stored block. + _tr_stored_block(buf, stored_len, eof); + } + else if (static_lenb == opt_lenb) + { + send_bits((STATIC_TREES << 1) + (eof ? 1 : 0), 3); + send_compressed_block(StaticTree.lengthAndLiteralsTreeCodes, StaticTree.distTreeCodes); + } + else + { + send_bits((DYN_TREES << 1) + (eof ? 1 : 0), 3); + send_all_trees(treeLiterals.max_code + 1, treeDistances.max_code + 1, max_blindex + 1); + send_compressed_block(dyn_ltree, dyn_dtree); + } + + // The above check is made mod 2^32, for files larger than 512 MB + // and uLong implemented on 32 bits. + + _InitializeBlocks(); + + if (eof) + { + bi_windup(); + } + } + + // Fill the window when the lookahead becomes insufficient. + // Updates strstart and lookahead. + // + // IN assertion: lookahead < MIN_LOOKAHEAD + // OUT assertions: strstart <= window_size-MIN_LOOKAHEAD + // At least one byte has been read, or avail_in == 0; reads are + // performed for at least two bytes (required for the zip translate_eol + // option -- not supported here). + private void _fillWindow() + { + int n, m; + int p; + int more; // Amount of free space at the end of the window. + + do + { + more = (window_size - lookahead - strstart); + + // Deal with !@#$% 64K limit: + if (more == 0 && strstart == 0 && lookahead == 0) + { + more = w_size; + } + else if (more == -1) + { + // Very unlikely, but possible on 16 bit machine if strstart == 0 + // and lookahead == 1 (input done one byte at time) + more--; + + // If the window is almost full and there is insufficient lookahead, + // move the upper half to the lower one to make room in the upper half. + } + else if (strstart >= w_size + w_size - MIN_LOOKAHEAD) + { + Array.Copy(window, w_size, window, 0, w_size); + match_start -= w_size; + strstart -= w_size; // we now have strstart >= MAX_DIST + block_start -= w_size; + + // Slide the hash table (could be avoided with 32 bit values + // at the expense of memory usage). We slide even when level == 0 + // to keep the hash table consistent if we switch back to level > 0 + // later. (Using level 0 permanently is not an optimal usage of + // zlib, so we don't care about this pathological case.) + + n = hash_size; + p = n; + do + { + m = (head[--p] & 0xffff); + head[p] = (short)((m >= w_size) ? (m - w_size) : 0); + } + while (--n != 0); + + n = w_size; + p = n; + do + { + m = (prev[--p] & 0xffff); + prev[p] = (short)((m >= w_size) ? (m - w_size) : 0); + // If n is not on any hash chain, prev[n] is garbage but + // its value will never be used. + } + while (--n != 0); + more += w_size; + } + + if (_codec.AvailableBytesIn == 0) + return; + + // If there was no sliding: + // strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 && + // more == window_size - lookahead - strstart + // => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1) + // => more >= window_size - 2*WSIZE + 2 + // In the BIG_MEM or MMAP case (not yet supported), + // window_size == input_size + MIN_LOOKAHEAD && + // strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD. + // Otherwise, window_size == 2*WSIZE so more >= 2. + // If there was sliding, more >= WSIZE. So in all cases, more >= 2. + + n = _codec.read_buf(window, strstart + lookahead, more); + lookahead += n; + + // Initialize the hash value now that we have some input: + if (lookahead >= MIN_MATCH) + { + ins_h = window[strstart] & 0xff; + ins_h = (((ins_h) << hash_shift) ^ (window[strstart + 1] & 0xff)) & hash_mask; + } + // If the whole input has less than MIN_MATCH bytes, ins_h is garbage, + // but this is not important since only literal bytes will be emitted. + } + while (lookahead < MIN_LOOKAHEAD && _codec.AvailableBytesIn != 0); + } + + // Compress as much as possible from the input stream, return the current + // block state. + // This function does not perform lazy evaluation of matches and inserts + // new strings in the dictionary only for unmatched strings or for short + // matches. It is used only for the fast compression options. + internal BlockState DeflateFast(FlushType flush) + { + // short hash_head = 0; // head of the hash chain + int hash_head = 0; // head of the hash chain + bool bflush; // set if current block must be flushed + + while (true) + { + // Make sure that we always have enough lookahead, except + // at the end of the input file. We need MAX_MATCH bytes + // for the next match, plus MIN_MATCH bytes to insert the + // string following the next match. + if (lookahead < MIN_LOOKAHEAD) + { + _fillWindow(); + if (lookahead < MIN_LOOKAHEAD && flush == FlushType.None) + { + return BlockState.NeedMore; + } + if (lookahead == 0) + break; // flush the current block + } + + // Insert the string window[strstart .. strstart+2] in the + // dictionary, and set hash_head to the head of the hash chain: + if (lookahead >= MIN_MATCH) + { + ins_h = (((ins_h) << hash_shift) ^ (window[(strstart) + (MIN_MATCH - 1)] & 0xff)) & hash_mask; + + // prev[strstart&w_mask]=hash_head=head[ins_h]; + hash_head = (head[ins_h] & 0xffff); + prev[strstart & w_mask] = head[ins_h]; + head[ins_h] = unchecked((short)strstart); + } + + // Find the longest match, discarding those <= prev_length. + // At this point we have always match_length < MIN_MATCH + + if (hash_head != 0L && ((strstart - hash_head) & 0xffff) <= w_size - MIN_LOOKAHEAD) + { + // To simplify the code, we prevent matches with the string + // of window index 0 (in particular we have to avoid a match + // of the string with itself at the start of the input file). + if (compressionStrategy != CompressionStrategy.HuffmanOnly) + { + match_length = longest_match(hash_head); + } + // longest_match() sets match_start + } + if (match_length >= MIN_MATCH) + { + // check_match(strstart, match_start, match_length); + + bflush = _tr_tally(strstart - match_start, match_length - MIN_MATCH); + + lookahead -= match_length; + + // Insert new strings in the hash table only if the match length + // is not too large. This saves time but degrades compression. + if (match_length <= config.MaxLazy && lookahead >= MIN_MATCH) + { + match_length--; // string at strstart already in hash table + do + { + strstart++; + + ins_h = ((ins_h << hash_shift) ^ (window[(strstart) + (MIN_MATCH - 1)] & 0xff)) & hash_mask; + // prev[strstart&w_mask]=hash_head=head[ins_h]; + hash_head = (head[ins_h] & 0xffff); + prev[strstart & w_mask] = head[ins_h]; + head[ins_h] = unchecked((short)strstart); + + // strstart never exceeds WSIZE-MAX_MATCH, so there are + // always MIN_MATCH bytes ahead. + } + while (--match_length != 0); + strstart++; + } + else + { + strstart += match_length; + match_length = 0; + ins_h = window[strstart] & 0xff; + + ins_h = (((ins_h) << hash_shift) ^ (window[strstart + 1] & 0xff)) & hash_mask; + // If lookahead < MIN_MATCH, ins_h is garbage, but it does not + // matter since it will be recomputed at next deflate call. + } + } + else + { + // No match, output a literal byte + + bflush = _tr_tally(0, window[strstart] & 0xff); + lookahead--; + strstart++; + } + if (bflush) + { + flush_block_only(false); + if (_codec.AvailableBytesOut == 0) + return BlockState.NeedMore; + } + } + + flush_block_only(flush == FlushType.Finish); + if (_codec.AvailableBytesOut == 0) + { + if (flush == FlushType.Finish) + return BlockState.FinishStarted; + else + return BlockState.NeedMore; + } + return flush == FlushType.Finish ? BlockState.FinishDone : BlockState.BlockDone; + } + + // Same as above, but achieves better compression. We use a lazy + // evaluation for matches: a match is finally adopted only if there is + // no better match at the next window position. + internal BlockState DeflateSlow(FlushType flush) + { + // short hash_head = 0; // head of hash chain + int hash_head = 0; // head of hash chain + bool bflush; // set if current block must be flushed + + // Process the input block. + while (true) + { + // Make sure that we always have enough lookahead, except + // at the end of the input file. We need MAX_MATCH bytes + // for the next match, plus MIN_MATCH bytes to insert the + // string following the next match. + + if (lookahead < MIN_LOOKAHEAD) + { + _fillWindow(); + if (lookahead < MIN_LOOKAHEAD && flush == FlushType.None) + return BlockState.NeedMore; + + if (lookahead == 0) + break; // flush the current block + } + + // Insert the string window[strstart .. strstart+2] in the + // dictionary, and set hash_head to the head of the hash chain: + + if (lookahead >= MIN_MATCH) + { + ins_h = (((ins_h) << hash_shift) ^ (window[(strstart) + (MIN_MATCH - 1)] & 0xff)) & hash_mask; + // prev[strstart&w_mask]=hash_head=head[ins_h]; + hash_head = (head[ins_h] & 0xffff); + prev[strstart & w_mask] = head[ins_h]; + head[ins_h] = unchecked((short)strstart); + } + + // Find the longest match, discarding those <= prev_length. + prev_length = match_length; + prev_match = match_start; + match_length = MIN_MATCH - 1; + + if (hash_head != 0 && prev_length < config.MaxLazy && + ((strstart - hash_head) & 0xffff) <= w_size - MIN_LOOKAHEAD) + { + // To simplify the code, we prevent matches with the string + // of window index 0 (in particular we have to avoid a match + // of the string with itself at the start of the input file). + + if (compressionStrategy != CompressionStrategy.HuffmanOnly) + { + match_length = longest_match(hash_head); + } + // longest_match() sets match_start + + if (match_length <= 5 && (compressionStrategy == CompressionStrategy.Filtered || + (match_length == MIN_MATCH && strstart - match_start > 4096))) + { + + // If prev_match is also MIN_MATCH, match_start is garbage + // but we will ignore the current match anyway. + match_length = MIN_MATCH - 1; + } + } + + // If there was a match at the previous step and the current + // match is not better, output the previous match: + if (prev_length >= MIN_MATCH && match_length <= prev_length) + { + int max_insert = strstart + lookahead - MIN_MATCH; + // Do not insert strings in hash table beyond this. + + // check_match(strstart-1, prev_match, prev_length); + + bflush = _tr_tally(strstart - 1 - prev_match, prev_length - MIN_MATCH); + + // Insert in hash table all strings up to the end of the match. + // strstart-1 and strstart are already inserted. If there is not + // enough lookahead, the last two strings are not inserted in + // the hash table. + lookahead -= (prev_length - 1); + prev_length -= 2; + do + { + if (++strstart <= max_insert) + { + ins_h = (((ins_h) << hash_shift) ^ (window[(strstart) + (MIN_MATCH - 1)] & 0xff)) & hash_mask; + //prev[strstart&w_mask]=hash_head=head[ins_h]; + hash_head = (head[ins_h] & 0xffff); + prev[strstart & w_mask] = head[ins_h]; + head[ins_h] = unchecked((short)strstart); + } + } + while (--prev_length != 0); + match_available = 0; + match_length = MIN_MATCH - 1; + strstart++; + + if (bflush) + { + flush_block_only(false); + if (_codec.AvailableBytesOut == 0) + return BlockState.NeedMore; + } + } + else if (match_available != 0) + { + + // If there was no match at the previous position, output a + // single literal. If there was a match but the current match + // is longer, truncate the previous match to a single literal. + + bflush = _tr_tally(0, window[strstart - 1] & 0xff); + + if (bflush) + { + flush_block_only(false); + } + strstart++; + lookahead--; + if (_codec.AvailableBytesOut == 0) + return BlockState.NeedMore; + } + else + { + // There is no previous match to compare with, wait for + // the next step to decide. + + match_available = 1; + strstart++; + lookahead--; + } + } + + if (match_available != 0) + { + bflush = _tr_tally(0, window[strstart - 1] & 0xff); + match_available = 0; + } + flush_block_only(flush == FlushType.Finish); + + if (_codec.AvailableBytesOut == 0) + { + if (flush == FlushType.Finish) + return BlockState.FinishStarted; + else + return BlockState.NeedMore; + } + + return flush == FlushType.Finish ? BlockState.FinishDone : BlockState.BlockDone; + } + + + internal int longest_match(int cur_match) + { + int chain_length = config.MaxChainLength; // max hash chain length + int scan = strstart; // current string + int match; // matched string + int len; // length of current match + int best_len = prev_length; // best match length so far + int limit = strstart > (w_size - MIN_LOOKAHEAD) ? strstart - (w_size - MIN_LOOKAHEAD) : 0; + + int niceLength = config.NiceLength; + + // Stop when cur_match becomes <= limit. To simplify the code, + // we prevent matches with the string of window index 0. + + int wmask = w_mask; + + int strend = strstart + MAX_MATCH; + byte scan_end1 = window[scan + best_len - 1]; + byte scan_end = window[scan + best_len]; + + // The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16. + // It is easy to get rid of this optimization if necessary. + + // Do not waste too much time if we already have a good match: + if (prev_length >= config.GoodLength) + { + chain_length >>= 2; + } + + // Do not look for matches beyond the end of the input. This is necessary + // to make deflate deterministic. + if (niceLength > lookahead) + niceLength = lookahead; + + do + { + match = cur_match; + + // Skip to next match if the match length cannot increase + // or if the match length is less than 2: + if (window[match + best_len] != scan_end || + window[match + best_len - 1] != scan_end1 || + window[match] != window[scan] || + window[++match] != window[scan + 1]) + continue; + + // The check at best_len-1 can be removed because it will be made + // again later. (This heuristic is not always a win.) + // It is not necessary to compare scan[2] and match[2] since they + // are always equal when the other bytes match, given that + // the hash keys are equal and that HASH_BITS >= 8. + scan += 2; match++; + + // We check for insufficient lookahead only every 8th comparison; + // the 256th check will be made at strstart+258. + do + { + } + while (window[++scan] == window[++match] && + window[++scan] == window[++match] && + window[++scan] == window[++match] && + window[++scan] == window[++match] && + window[++scan] == window[++match] && + window[++scan] == window[++match] && + window[++scan] == window[++match] && + window[++scan] == window[++match] && scan < strend); + + len = MAX_MATCH - (int)(strend - scan); + scan = strend - MAX_MATCH; + + if (len > best_len) + { + match_start = cur_match; + best_len = len; + if (len >= niceLength) + break; + scan_end1 = window[scan + best_len - 1]; + scan_end = window[scan + best_len]; + } + } + while ((cur_match = (prev[cur_match & wmask] & 0xffff)) > limit && --chain_length != 0); + + if (best_len <= lookahead) + return best_len; + return lookahead; + } + + + private bool Rfc1950BytesEmitted = false; + private bool _WantRfc1950HeaderBytes = true; + internal bool WantRfc1950HeaderBytes + { + get { return _WantRfc1950HeaderBytes; } + set { _WantRfc1950HeaderBytes = value; } + } + + + internal int Initialize(ZlibCodec codec, CompressionLevel level) + { + return Initialize(codec, level, ZlibConstants.WindowBitsMax); + } + + internal int Initialize(ZlibCodec codec, CompressionLevel level, int bits) + { + return Initialize(codec, level, bits, MEM_LEVEL_DEFAULT, CompressionStrategy.Default); + } + + internal int Initialize(ZlibCodec codec, CompressionLevel level, int bits, CompressionStrategy compressionStrategy) + { + return Initialize(codec, level, bits, MEM_LEVEL_DEFAULT, compressionStrategy); + } + + internal int Initialize(ZlibCodec codec, CompressionLevel level, int windowBits, int memLevel, CompressionStrategy strategy) + { + _codec = codec; + _codec.Message = null; + + // validation + if (windowBits < 9 || windowBits > 15) + throw new ZlibException("windowBits must be in the range 9..15."); + + if (memLevel < 1 || memLevel > MEM_LEVEL_MAX) + throw new ZlibException(String.Format("memLevel must be in the range 1.. {0}", MEM_LEVEL_MAX)); + + _codec.dstate = this; + + w_bits = windowBits; + w_size = 1 << w_bits; + w_mask = w_size - 1; + + hash_bits = memLevel + 7; + hash_size = 1 << hash_bits; + hash_mask = hash_size - 1; + hash_shift = ((hash_bits + MIN_MATCH - 1) / MIN_MATCH); + + window = new byte[w_size * 2]; + prev = new short[w_size]; + head = new short[hash_size]; + + // for memLevel==8, this will be 16384, 16k + lit_bufsize = 1 << (memLevel + 6); + + // Use a single array as the buffer for data pending compression, + // the output distance codes, and the output length codes (aka tree). + // orig comment: This works just fine since the average + // output size for (length,distance) codes is <= 24 bits. + pending = new byte[lit_bufsize * 4]; + _distanceOffset = lit_bufsize; + _lengthOffset = (1 + 2) * lit_bufsize; + + // So, for memLevel 8, the length of the pending buffer is 65536. 64k. + // The first 16k are pending bytes. + // The middle slice, of 32k, is used for distance codes. + // The final 16k are length codes. + + this.compressionLevel = level; + this.compressionStrategy = strategy; + + Reset(); + return ZlibConstants.Z_OK; + } + + + internal void Reset() + { + _codec.TotalBytesIn = _codec.TotalBytesOut = 0; + _codec.Message = null; + //strm.data_type = Z_UNKNOWN; + + pendingCount = 0; + nextPending = 0; + + Rfc1950BytesEmitted = false; + + status = (WantRfc1950HeaderBytes) ? INIT_STATE : BUSY_STATE; + _codec._Adler32 = Adler.Adler32(0, null, 0, 0); + + last_flush = (int)FlushType.None; + + _InitializeTreeData(); + _InitializeLazyMatch(); + } + + + internal int End() + { + if (status != INIT_STATE && status != BUSY_STATE && status != FINISH_STATE) + { + return ZlibConstants.Z_STREAM_ERROR; + } + // Deallocate in reverse order of allocations: + pending = null; + head = null; + prev = null; + window = null; + // free + // dstate=null; + return status == BUSY_STATE ? ZlibConstants.Z_DATA_ERROR : ZlibConstants.Z_OK; + } + + + private void SetDeflater() + { + switch (config.Flavor) + { + case DeflateFlavor.Store: + DeflateFunction = DeflateNone; + break; + case DeflateFlavor.Fast: + DeflateFunction = DeflateFast; + break; + case DeflateFlavor.Slow: + DeflateFunction = DeflateSlow; + break; + } + } + + + internal int SetParams(CompressionLevel level, CompressionStrategy strategy) + { + int result = ZlibConstants.Z_OK; + + if (compressionLevel != level) + { + Config newConfig = Config.Lookup(level); + + // change in the deflate flavor (Fast vs slow vs none)? + if (newConfig.Flavor != config.Flavor && _codec.TotalBytesIn != 0) + { + // Flush the last buffer: + result = _codec.Deflate(FlushType.Partial); + } + + compressionLevel = level; + config = newConfig; + SetDeflater(); + } + + // no need to flush with change in strategy? Really? + compressionStrategy = strategy; + + return result; + } + + + internal int SetDictionary(byte[] dictionary) + { + int length = dictionary.Length; + int index = 0; + + if (dictionary == null || status != INIT_STATE) + throw new ZlibException("Stream error."); + + _codec._Adler32 = Adler.Adler32(_codec._Adler32, dictionary, 0, dictionary.Length); + + if (length < MIN_MATCH) + return ZlibConstants.Z_OK; + if (length > w_size - MIN_LOOKAHEAD) + { + length = w_size - MIN_LOOKAHEAD; + index = dictionary.Length - length; // use the tail of the dictionary + } + Array.Copy(dictionary, index, window, 0, length); + strstart = length; + block_start = length; + + // Insert all strings in the hash table (except for the last two bytes). + // s->lookahead stays null, so s->ins_h will be recomputed at the next + // call of fill_window. + + ins_h = window[0] & 0xff; + ins_h = (((ins_h) << hash_shift) ^ (window[1] & 0xff)) & hash_mask; + + for (int n = 0; n <= length - MIN_MATCH; n++) + { + ins_h = (((ins_h) << hash_shift) ^ (window[(n) + (MIN_MATCH - 1)] & 0xff)) & hash_mask; + prev[n & w_mask] = head[ins_h]; + head[ins_h] = (short)n; + } + return ZlibConstants.Z_OK; + } + + + + internal int Deflate(FlushType flush) + { + int old_flush; + + if (_codec.OutputBuffer == null || + (_codec.InputBuffer == null && _codec.AvailableBytesIn != 0) || + (status == FINISH_STATE && flush != FlushType.Finish)) + { + _codec.Message = _ErrorMessage[ZlibConstants.Z_NEED_DICT - (ZlibConstants.Z_STREAM_ERROR)]; + throw new ZlibException(String.Format("Something is fishy. [{0}]", _codec.Message)); + } + if (_codec.AvailableBytesOut == 0) + { + _codec.Message = _ErrorMessage[ZlibConstants.Z_NEED_DICT - (ZlibConstants.Z_BUF_ERROR)]; + throw new ZlibException("OutputBuffer is full (AvailableBytesOut == 0)"); + } + + old_flush = last_flush; + last_flush = (int)flush; + + // Write the zlib (rfc1950) header bytes + if (status == INIT_STATE) + { + int header = (Z_DEFLATED + ((w_bits - 8) << 4)) << 8; + int level_flags = (((int)compressionLevel - 1) & 0xff) >> 1; + + if (level_flags > 3) + level_flags = 3; + header |= (level_flags << 6); + if (strstart != 0) + header |= PRESET_DICT; + header += 31 - (header % 31); + + status = BUSY_STATE; + //putShortMSB(header); + unchecked + { + pending[pendingCount++] = (byte)(header >> 8); + pending[pendingCount++] = (byte)header; + } + // Save the adler32 of the preset dictionary: + if (strstart != 0) + { + pending[pendingCount++] = (byte)((_codec._Adler32 & 0xFF000000) >> 24); + pending[pendingCount++] = (byte)((_codec._Adler32 & 0x00FF0000) >> 16); + pending[pendingCount++] = (byte)((_codec._Adler32 & 0x0000FF00) >> 8); + pending[pendingCount++] = (byte)(_codec._Adler32 & 0x000000FF); + } + _codec._Adler32 = Adler.Adler32(0, null, 0, 0); + } + + // Flush as much pending output as possible + if (pendingCount != 0) + { + _codec.flush_pending(); + if (_codec.AvailableBytesOut == 0) + { + //System.out.println(" avail_out==0"); + // Since avail_out is 0, deflate will be called again with + // more output space, but possibly with both pending and + // avail_in equal to zero. There won't be anything to do, + // but this is not an error situation so make sure we + // return OK instead of BUF_ERROR at next call of deflate: + last_flush = -1; + return ZlibConstants.Z_OK; + } + + // Make sure there is something to do and avoid duplicate consecutive + // flushes. For repeated and useless calls with Z_FINISH, we keep + // returning Z_STREAM_END instead of Z_BUFF_ERROR. + } + else if (_codec.AvailableBytesIn == 0 && + (int)flush <= old_flush && + flush != FlushType.Finish) + { + // workitem 8557 + // + // Not sure why this needs to be an error. pendingCount == 0, which + // means there's nothing to deflate. And the caller has not asked + // for a FlushType.Finish, but... that seems very non-fatal. We + // can just say "OK" and do nothing. + + // _codec.Message = z_errmsg[ZlibConstants.Z_NEED_DICT - (ZlibConstants.Z_BUF_ERROR)]; + // throw new ZlibException("AvailableBytesIn == 0 && flush<=old_flush && flush != FlushType.Finish"); + + return ZlibConstants.Z_OK; + } + + // User must not provide more input after the first FINISH: + if (status == FINISH_STATE && _codec.AvailableBytesIn != 0) + { + _codec.Message = _ErrorMessage[ZlibConstants.Z_NEED_DICT - (ZlibConstants.Z_BUF_ERROR)]; + throw new ZlibException("status == FINISH_STATE && _codec.AvailableBytesIn != 0"); + } + + // Start a new block or continue the current one. + if (_codec.AvailableBytesIn != 0 || lookahead != 0 || (flush != FlushType.None && status != FINISH_STATE)) + { + BlockState bstate = DeflateFunction(flush); + + if (bstate == BlockState.FinishStarted || bstate == BlockState.FinishDone) + { + status = FINISH_STATE; + } + if (bstate == BlockState.NeedMore || bstate == BlockState.FinishStarted) + { + if (_codec.AvailableBytesOut == 0) + { + last_flush = -1; // avoid BUF_ERROR next call, see above + } + return ZlibConstants.Z_OK; + // If flush != Z_NO_FLUSH && avail_out == 0, the next call + // of deflate should use the same flush parameter to make sure + // that the flush is complete. So we don't have to output an + // empty block here, this will be done at next call. This also + // ensures that for a very small output buffer, we emit at most + // one empty block. + } + + if (bstate == BlockState.BlockDone) + { + if (flush == FlushType.Partial) + { + _tr_align(); + } + else + { + // FlushType.Full or FlushType.Sync + _tr_stored_block(0, 0, false); + // For a full flush, this empty block will be recognized + // as a special marker by inflate_sync(). + if (flush == FlushType.Full) + { + // clear hash (forget the history) + for (int i = 0; i < hash_size; i++) + head[i] = 0; + } + } + _codec.flush_pending(); + if (_codec.AvailableBytesOut == 0) + { + last_flush = -1; // avoid BUF_ERROR at next call, see above + return ZlibConstants.Z_OK; + } + } + } + + if (flush != FlushType.Finish) + return ZlibConstants.Z_OK; + + if (!WantRfc1950HeaderBytes || Rfc1950BytesEmitted) + return ZlibConstants.Z_STREAM_END; + + // Write the zlib trailer (adler32) + pending[pendingCount++] = (byte)((_codec._Adler32 & 0xFF000000) >> 24); + pending[pendingCount++] = (byte)((_codec._Adler32 & 0x00FF0000) >> 16); + pending[pendingCount++] = (byte)((_codec._Adler32 & 0x0000FF00) >> 8); + pending[pendingCount++] = (byte)(_codec._Adler32 & 0x000000FF); + //putShortMSB((int)(SharedUtils.URShift(_codec._Adler32, 16))); + //putShortMSB((int)(_codec._Adler32 & 0xffff)); + + _codec.flush_pending(); + + // If avail_out is zero, the application will call deflate again + // to flush the rest. + + Rfc1950BytesEmitted = true; // write the trailer only once! + + return pendingCount != 0 ? ZlibConstants.Z_OK : ZlibConstants.Z_STREAM_END; + } + + } +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/DeflateStream.cs b/Resources/Libraries/DotNetZip/Source/Zlib/DeflateStream.cs new file mode 100644 index 00000000..45e972b2 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/DeflateStream.cs @@ -0,0 +1,740 @@ +// DeflateStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2010 Dino Chiesa. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-31 14:48:11> +// +// ------------------------------------------------------------------ +// +// This module defines the DeflateStream class, which can be used as a replacement for +// the System.IO.Compression.DeflateStream class in the .NET BCL. +// +// ------------------------------------------------------------------ + + +using System; + +namespace Ionic.Zlib +{ + /// + /// A class for compressing and decompressing streams using the Deflate algorithm. + /// + /// + /// + /// + /// + /// The DeflateStream is a Decorator on a . It adds DEFLATE compression or decompression to any + /// stream. + /// + /// + /// + /// Using this stream, applications can compress or decompress data via stream + /// Read and Write operations. Either compresssion or decompression + /// can occur through either reading or writing. The compression format used is + /// DEFLATE, which is documented in IETF RFC 1951, "DEFLATE + /// Compressed Data Format Specification version 1.3.". + /// + /// + /// + /// This class is similar to , except that + /// ZlibStream adds the RFC + /// 1950 - ZLIB framing bytes to a compressed stream when compressing, or + /// expects the RFC1950 framing bytes when decompressing. The DeflateStream + /// does not. + /// + /// + /// + /// + /// + /// + public class DeflateStream : System.IO.Stream + { + internal ZlibBaseStream _baseStream; + internal System.IO.Stream _innerStream; + bool _disposed; + + /// + /// Create a DeflateStream using the specified CompressionMode. + /// + /// + /// + /// When mode is CompressionMode.Compress, the DeflateStream will use + /// the default compression level. The "captive" stream will be closed when + /// the DeflateStream is closed. + /// + /// + /// + /// This example uses a DeflateStream to compress data from a file, and writes + /// the compressed data to another file. + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(fileToCompress + ".deflated")) + /// { + /// using (Stream compressor = new DeflateStream(raw, CompressionMode.Compress)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(fileToCompress & ".deflated") + /// Using compressor As Stream = New DeflateStream(raw, CompressionMode.Compress) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// The stream which will be read or written. + /// Indicates whether the DeflateStream will compress or decompress. + public DeflateStream(System.IO.Stream stream, CompressionMode mode) + : this(stream, mode, CompressionLevel.Default, false) + { + } + + /// + /// Create a DeflateStream using the specified CompressionMode and the specified CompressionLevel. + /// + /// + /// + /// + /// + /// When mode is CompressionMode.Decompress, the level parameter is + /// ignored. The "captive" stream will be closed when the DeflateStream is + /// closed. + /// + /// + /// + /// + /// + /// + /// This example uses a DeflateStream to compress data from a file, and writes + /// the compressed data to another file. + /// + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(fileToCompress + ".deflated")) + /// { + /// using (Stream compressor = new DeflateStream(raw, + /// CompressionMode.Compress, + /// CompressionLevel.BestCompression)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n= -1; + /// while (n != 0) + /// { + /// if (n > 0) + /// compressor.Write(buffer, 0, n); + /// n= input.Read(buffer, 0, buffer.Length); + /// } + /// } + /// } + /// } + /// + /// + /// + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(fileToCompress & ".deflated") + /// Using compressor As Stream = New DeflateStream(raw, CompressionMode.Compress, CompressionLevel.BestCompression) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// The stream to be read or written while deflating or inflating. + /// Indicates whether the DeflateStream will compress or decompress. + /// A tuning knob to trade speed for effectiveness. + public DeflateStream(System.IO.Stream stream, CompressionMode mode, CompressionLevel level) + : this(stream, mode, level, false) + { + } + + /// + /// Create a DeflateStream using the specified + /// CompressionMode, and explicitly specify whether the + /// stream should be left open after Deflation or Inflation. + /// + /// + /// + /// + /// + /// This constructor allows the application to request that the captive stream + /// remain open after the deflation or inflation occurs. By default, after + /// Close() is called on the stream, the captive stream is also + /// closed. In some cases this is not desired, for example if the stream is a + /// memory stream that will be re-read after compression. Specify true for + /// the parameter to leave the stream open. + /// + /// + /// + /// The DeflateStream will use the default compression level. + /// + /// + /// + /// See the other overloads of this constructor for example code. + /// + /// + /// + /// + /// The stream which will be read or written. This is called the + /// "captive" stream in other places in this documentation. + /// + /// + /// + /// Indicates whether the DeflateStream will compress or decompress. + /// + /// + /// true if the application would like the stream to + /// remain open after inflation/deflation. + public DeflateStream(System.IO.Stream stream, CompressionMode mode, bool leaveOpen) + : this(stream, mode, CompressionLevel.Default, leaveOpen) + { + } + + /// + /// Create a DeflateStream using the specified CompressionMode + /// and the specified CompressionLevel, and explicitly specify whether + /// the stream should be left open after Deflation or Inflation. + /// + /// + /// + /// + /// + /// When mode is CompressionMode.Decompress, the level parameter is ignored. + /// + /// + /// + /// This constructor allows the application to request that the captive stream + /// remain open after the deflation or inflation occurs. By default, after + /// Close() is called on the stream, the captive stream is also + /// closed. In some cases this is not desired, for example if the stream is a + /// that will be re-read after + /// compression. Specify true for the parameter + /// to leave the stream open. + /// + /// + /// + /// + /// + /// + /// This example shows how to use a DeflateStream to compress data from + /// a file, and store the compressed data into another file. + /// + /// + /// using (var output = System.IO.File.Create(fileToCompress + ".deflated")) + /// { + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (Stream compressor = new DeflateStream(output, CompressionMode.Compress, CompressionLevel.BestCompression, true)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n= -1; + /// while (n != 0) + /// { + /// if (n > 0) + /// compressor.Write(buffer, 0, n); + /// n= input.Read(buffer, 0, buffer.Length); + /// } + /// } + /// } + /// // can write additional data to the output stream here + /// } + /// + /// + /// + /// Using output As FileStream = File.Create(fileToCompress & ".deflated") + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using compressor As Stream = New DeflateStream(output, CompressionMode.Compress, CompressionLevel.BestCompression, True) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// ' can write additional data to the output stream here. + /// End Using + /// + /// + /// The stream which will be read or written. + /// Indicates whether the DeflateStream will compress or decompress. + /// true if the application would like the stream to remain open after inflation/deflation. + /// A tuning knob to trade speed for effectiveness. + public DeflateStream(System.IO.Stream stream, CompressionMode mode, CompressionLevel level, bool leaveOpen) + { + _innerStream = stream; + _baseStream = new ZlibBaseStream(stream, mode, level, ZlibStreamFlavor.DEFLATE, leaveOpen); + } + + #region Zlib properties + + /// + /// This property sets the flush behavior on the stream. + /// + /// See the ZLIB documentation for the meaning of the flush behavior. + /// + virtual public FlushType FlushMode + { + get { return (this._baseStream._flushMode); } + set + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + this._baseStream._flushMode = value; + } + } + + /// + /// The size of the working buffer for the compression codec. + /// + /// + /// + /// + /// The working buffer is used for all stream operations. The default size is + /// 1024 bytes. The minimum size is 128 bytes. You may get better performance + /// with a larger buffer. Then again, you might not. You would have to test + /// it. + /// + /// + /// + /// Set this before the first call to Read() or Write() on the + /// stream. If you try to set it afterwards, it will throw. + /// + /// + public int BufferSize + { + get + { + return this._baseStream._bufferSize; + } + set + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + if (this._baseStream._workingBuffer != null) + throw new ZlibException("The working buffer is already set."); + if (value < ZlibConstants.WorkingBufferSizeMin) + throw new ZlibException(String.Format("Don't be silly. {0} bytes?? Use a bigger buffer, at least {1}.", value, ZlibConstants.WorkingBufferSizeMin)); + this._baseStream._bufferSize = value; + } + } + + /// + /// The ZLIB strategy to be used during compression. + /// + /// + /// + /// By tweaking this parameter, you may be able to optimize the compression for + /// data with particular characteristics. + /// + public CompressionStrategy Strategy + { + get + { + return this._baseStream.Strategy; + } + set + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + this._baseStream.Strategy = value; + } + } + + /// Returns the total number of bytes input so far. + virtual public long TotalIn + { + get + { + return this._baseStream._z.TotalBytesIn; + } + } + + /// Returns the total number of bytes output so far. + virtual public long TotalOut + { + get + { + return this._baseStream._z.TotalBytesOut; + } + } + + #endregion + + #region System.IO.Stream methods + /// + /// Dispose the stream. + /// + /// + /// + /// This may or may not result in a Close() call on the captive + /// stream. See the constructors that have a leaveOpen parameter + /// for more information. + /// + /// + /// Application code won't call this code directly. This method may be + /// invoked in two distinct scenarios. If disposing == true, the method + /// has been called directly or indirectly by a user's code, for example + /// via the public Dispose() method. In this case, both managed and + /// unmanaged resources can be referenced and disposed. If disposing == + /// false, the method has been called by the runtime from inside the + /// object finalizer and this method should not reference other objects; + /// in that case only unmanaged resources must be referenced or + /// disposed. + /// + /// + /// + /// true if the Dispose method was invoked by user code. + /// + protected override void Dispose(bool disposing) + { + try + { + if (!_disposed) + { + if (disposing && (this._baseStream != null)) + this._baseStream.Close(); + _disposed = true; + } + } + finally + { + base.Dispose(disposing); + } + } + + + + /// + /// Indicates whether the stream can be read. + /// + /// + /// The return value depends on whether the captive stream supports reading. + /// + public override bool CanRead + { + get + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + return _baseStream._stream.CanRead; + } + } + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + + /// + /// Indicates whether the stream can be written. + /// + /// + /// The return value depends on whether the captive stream supports writing. + /// + public override bool CanWrite + { + get + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + return _baseStream._stream.CanWrite; + } + } + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + _baseStream.Flush(); + } + + /// + /// Reading this property always throws a . + /// + public override long Length + { + get { throw new NotImplementedException(); } + } + + /// + /// The position of the stream pointer. + /// + /// + /// + /// Setting this property always throws a . Reading will return the total bytes + /// written out, if used in writing, or the total bytes read in, if used in + /// reading. The count may refer to compressed bytes or uncompressed bytes, + /// depending on how you've used the stream. + /// + public override long Position + { + get + { + if (this._baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Writer) + return this._baseStream._z.TotalBytesOut; + if (this._baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Reader) + return this._baseStream._z.TotalBytesIn; + return 0; + } + set { throw new NotImplementedException(); } + } + + /// + /// Read data from the stream. + /// + /// + /// + /// + /// If you wish to use the DeflateStream to compress data while + /// reading, you can create a DeflateStream with + /// CompressionMode.Compress, providing an uncompressed data stream. + /// Then call Read() on that DeflateStream, and the data read will be + /// compressed as you read. If you wish to use the DeflateStream to + /// decompress data while reading, you can create a DeflateStream with + /// CompressionMode.Decompress, providing a readable compressed data + /// stream. Then call Read() on that DeflateStream, and the data read + /// will be decompressed as you read. + /// + /// + /// + /// A DeflateStream can be used for Read() or Write(), but not both. + /// + /// + /// + /// The buffer into which the read data should be placed. + /// the offset within that data array to put the first byte read. + /// the number of bytes to read. + /// the number of bytes actually read + public override int Read(byte[] buffer, int offset, int count) + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + return _baseStream.Read(buffer, offset, count); + } + + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + /// this is irrelevant, since it will always throw! + /// irrelevant! + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// this is irrelevant, since it will always throw! + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + /// + /// Write data to the stream. + /// + /// + /// + /// + /// If you wish to use the DeflateStream to compress data while + /// writing, you can create a DeflateStream with + /// CompressionMode.Compress, and a writable output stream. Then call + /// Write() on that DeflateStream, providing uncompressed data + /// as input. The data sent to the output stream will be the compressed form + /// of the data written. If you wish to use the DeflateStream to + /// decompress data while writing, you can create a DeflateStream with + /// CompressionMode.Decompress, and a writable output stream. Then + /// call Write() on that stream, providing previously compressed + /// data. The data sent to the output stream will be the decompressed form of + /// the data written. + /// + /// + /// + /// A DeflateStream can be used for Read() or Write(), + /// but not both. + /// + /// + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + if (_disposed) throw new ObjectDisposedException("DeflateStream"); + _baseStream.Write(buffer, offset, count); + } + #endregion + + + + + /// + /// Compress a string into a byte array using DEFLATE (RFC 1951). + /// + /// + /// + /// Uncompress it with . + /// + /// + /// DeflateStream.UncompressString(byte[]) + /// DeflateStream.CompressBuffer(byte[]) + /// GZipStream.CompressString(string) + /// ZlibStream.CompressString(string) + /// + /// + /// A string to compress. The string will first be encoded + /// using UTF8, then compressed. + /// + /// + /// The string in compressed form + public static byte[] CompressString(String s) + { + using (var ms = new System.IO.MemoryStream()) + { + System.IO.Stream compressor = + new DeflateStream(ms, CompressionMode.Compress, CompressionLevel.BestCompression); + ZlibBaseStream.CompressString(s, compressor); + return ms.ToArray(); + } + } + + + /// + /// Compress a byte array into a new byte array using DEFLATE. + /// + /// + /// + /// Uncompress it with . + /// + /// + /// DeflateStream.CompressString(string) + /// DeflateStream.UncompressBuffer(byte[]) + /// GZipStream.CompressBuffer(byte[]) + /// ZlibStream.CompressBuffer(byte[]) + /// + /// + /// A buffer to compress. + /// + /// + /// The data in compressed form + public static byte[] CompressBuffer(byte[] b) + { + using (var ms = new System.IO.MemoryStream()) + { + System.IO.Stream compressor = + new DeflateStream( ms, CompressionMode.Compress, CompressionLevel.BestCompression ); + + ZlibBaseStream.CompressBuffer(b, compressor); + return ms.ToArray(); + } + } + + + /// + /// Uncompress a DEFLATE'd byte array into a single string. + /// + /// + /// DeflateStream.CompressString(String) + /// DeflateStream.UncompressBuffer(byte[]) + /// GZipStream.UncompressString(byte[]) + /// ZlibStream.UncompressString(byte[]) + /// + /// + /// A buffer containing DEFLATE-compressed data. + /// + /// + /// The uncompressed string + public static String UncompressString(byte[] compressed) + { + using (var input = new System.IO.MemoryStream(compressed)) + { + System.IO.Stream decompressor = + new DeflateStream(input, CompressionMode.Decompress); + + return ZlibBaseStream.UncompressString(compressed, decompressor); + } + } + + + /// + /// Uncompress a DEFLATE'd byte array into a byte array. + /// + /// + /// DeflateStream.CompressBuffer(byte[]) + /// DeflateStream.UncompressString(byte[]) + /// GZipStream.UncompressBuffer(byte[]) + /// ZlibStream.UncompressBuffer(byte[]) + /// + /// + /// A buffer containing data that has been compressed with DEFLATE. + /// + /// + /// The data in uncompressed form + public static byte[] UncompressBuffer(byte[] compressed) + { + using (var input = new System.IO.MemoryStream(compressed)) + { + System.IO.Stream decompressor = + new DeflateStream( input, CompressionMode.Decompress ); + + return ZlibBaseStream.UncompressBuffer(compressed, decompressor); + } + } + + } + +} + diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/GZipStream.cs b/Resources/Libraries/DotNetZip/Source/Zlib/GZipStream.cs new file mode 100644 index 00000000..297065cb --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/GZipStream.cs @@ -0,0 +1,1029 @@ +// GZipStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-11 21:42:34> +// +// ------------------------------------------------------------------ +// +// This module defines the GZipStream class, which can be used as a replacement for +// the System.IO.Compression.GZipStream class in the .NET BCL. NB: The design is not +// completely OO clean: there is some intelligence in the ZlibBaseStream that reads the +// GZip header. +// +// ------------------------------------------------------------------ + + +using System; +using System.IO; + +namespace Ionic.Zlib +{ + /// + /// A class for compressing and decompressing GZIP streams. + /// + /// + /// + /// + /// The GZipStream is a Decorator on a + /// . It adds GZIP compression or decompression to any + /// stream. + /// + /// + /// + /// Like the System.IO.Compression.GZipStream in the .NET Base Class Library, the + /// Ionic.Zlib.GZipStream can compress while writing, or decompress while + /// reading, but not vice versa. The compression method used is GZIP, which is + /// documented in IETF RFC + /// 1952, "GZIP file format specification version 4.3". + /// + /// + /// A GZipStream can be used to decompress data (through Read()) or + /// to compress data (through Write()), but not both. + /// + /// + /// + /// If you wish to use the GZipStream to compress data, you must wrap it + /// around a write-able stream. As you call Write() on the GZipStream, the + /// data will be compressed into the GZIP format. If you want to decompress data, + /// you must wrap the GZipStream around a readable stream that contains an + /// IETF RFC 1952-compliant stream. The data will be decompressed as you call + /// Read() on the GZipStream. + /// + /// + /// + /// Though the GZIP format allows data from multiple files to be concatenated + /// together, this stream handles only a single segment of GZIP format, typically + /// representing a single file. + /// + /// + /// + /// This class is similar to and . + /// ZlibStream handles RFC1950-compliant streams. + /// handles RFC1951-compliant streams. This class handles RFC1952-compliant streams. + /// + /// + /// + /// + /// + /// + public class GZipStream : System.IO.Stream + { + // GZip format + // source: http://tools.ietf.org/html/rfc1952 + // + // header id: 2 bytes 1F 8B + // compress method 1 byte 8= DEFLATE (none other supported) + // flag 1 byte bitfield (See below) + // mtime 4 bytes time_t (seconds since jan 1, 1970 UTC of the file. + // xflg 1 byte 2 = max compress used , 4 = max speed (can be ignored) + // OS 1 byte OS for originating archive. set to 0xFF in compression. + // extra field length 2 bytes optional - only if FEXTRA is set. + // extra field varies + // filename varies optional - if FNAME is set. zero terminated. ISO-8859-1. + // file comment varies optional - if FCOMMENT is set. zero terminated. ISO-8859-1. + // crc16 1 byte optional - present only if FHCRC bit is set + // compressed data varies + // CRC32 4 bytes + // isize 4 bytes data size modulo 2^32 + // + // FLG (FLaGs) + // bit 0 FTEXT - indicates file is ASCII text (can be safely ignored) + // bit 1 FHCRC - there is a CRC16 for the header immediately following the header + // bit 2 FEXTRA - extra fields are present + // bit 3 FNAME - the zero-terminated filename is present. encoding; ISO-8859-1. + // bit 4 FCOMMENT - a zero-terminated file comment is present. encoding: ISO-8859-1 + // bit 5 reserved + // bit 6 reserved + // bit 7 reserved + // + // On consumption: + // Extra field is a bunch of nonsense and can be safely ignored. + // Header CRC and OS, likewise. + // + // on generation: + // all optional fields get 0, except for the OS, which gets 255. + // + + + + /// + /// The comment on the GZIP stream. + /// + /// + /// + /// + /// The GZIP format allows for each file to optionally have an associated + /// comment stored with the file. The comment is encoded with the ISO-8859-1 + /// code page. To include a comment in a GZIP stream you create, set this + /// property before calling Write() for the first time on the + /// GZipStream. + /// + /// + /// + /// When using GZipStream to decompress, you can retrieve this property + /// after the first call to Read(). If no comment has been set in the + /// GZIP bytestream, the Comment property will return null + /// (Nothing in VB). + /// + /// + public String Comment + { + get + { + return _Comment; + } + set + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + _Comment = value; + } + } + + /// + /// The FileName for the GZIP stream. + /// + /// + /// + /// + /// + /// The GZIP format optionally allows each file to have an associated + /// filename. When compressing data (through Write()), set this + /// FileName before calling Write() the first time on the GZipStream. + /// The actual filename is encoded into the GZIP bytestream with the + /// ISO-8859-1 code page, according to RFC 1952. It is the application's + /// responsibility to insure that the FileName can be encoded and decoded + /// correctly with this code page. + /// + /// + /// + /// When decompressing (through Read()), you can retrieve this value + /// any time after the first Read(). In the case where there was no filename + /// encoded into the GZIP bytestream, the property will return null (Nothing + /// in VB). + /// + /// + public String FileName + { + get { return _FileName; } + set + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + _FileName = value; + if (_FileName == null) return; + if (_FileName.IndexOf("/") != -1) + { + _FileName = _FileName.Replace("/", "\\"); + } + if (_FileName.EndsWith("\\")) + throw new Exception("Illegal filename"); + if (_FileName.IndexOf("\\") != -1) + { + // trim any leading path + _FileName = Path.GetFileName(_FileName); + } + } + } + + /// + /// The last modified time for the GZIP stream. + /// + /// + /// + /// GZIP allows the storage of a last modified time with each GZIP entry. + /// When compressing data, you can set this before the first call to + /// Write(). When decompressing, you can retrieve this value any time + /// after the first call to Read(). + /// + public DateTime? LastModified; + + /// + /// The CRC on the GZIP stream. + /// + /// + /// This is used for internal error checking. You probably don't need to look at this property. + /// + public int Crc32 { get { return _Crc32; } } + + private int _headerByteCount; + internal ZlibBaseStream _baseStream; + bool _disposed; + bool _firstReadDone; + string _FileName; + string _Comment; + int _Crc32; + + + /// + /// Create a GZipStream using the specified CompressionMode. + /// + /// + /// + /// + /// When mode is CompressionMode.Compress, the GZipStream will use the + /// default compression level. + /// + /// + /// + /// As noted in the class documentation, the CompressionMode (Compress + /// or Decompress) also establishes the "direction" of the stream. A + /// GZipStream with CompressionMode.Compress works only through + /// Write(). A GZipStream with + /// CompressionMode.Decompress works only through Read(). + /// + /// + /// + /// + /// + /// This example shows how to use a GZipStream to compress data. + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(outputFile)) + /// { + /// using (Stream compressor = new GZipStream(raw, CompressionMode.Compress)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// Dim outputFile As String = (fileToCompress & ".compressed") + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(outputFile) + /// Using compressor As Stream = New GZipStream(raw, CompressionMode.Compress) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// + /// + /// This example shows how to use a GZipStream to uncompress a file. + /// + /// private void GunZipFile(string filename) + /// { + /// if (!filename.EndsWith(".gz)) + /// throw new ArgumentException("filename"); + /// var DecompressedFile = filename.Substring(0,filename.Length-3); + /// byte[] working = new byte[WORKING_BUFFER_SIZE]; + /// int n= 1; + /// using (System.IO.Stream input = System.IO.File.OpenRead(filename)) + /// { + /// using (Stream decompressor= new Ionic.Zlib.GZipStream(input, CompressionMode.Decompress, true)) + /// { + /// using (var output = System.IO.File.Create(DecompressedFile)) + /// { + /// while (n !=0) + /// { + /// n= decompressor.Read(working, 0, working.Length); + /// if (n > 0) + /// { + /// output.Write(working, 0, n); + /// } + /// } + /// } + /// } + /// } + /// } + /// + /// + /// + /// Private Sub GunZipFile(ByVal filename as String) + /// If Not (filename.EndsWith(".gz)) Then + /// Throw New ArgumentException("filename") + /// End If + /// Dim DecompressedFile as String = filename.Substring(0,filename.Length-3) + /// Dim working(WORKING_BUFFER_SIZE) as Byte + /// Dim n As Integer = 1 + /// Using input As Stream = File.OpenRead(filename) + /// Using decompressor As Stream = new Ionic.Zlib.GZipStream(input, CompressionMode.Decompress, True) + /// Using output As Stream = File.Create(UncompressedFile) + /// Do + /// n= decompressor.Read(working, 0, working.Length) + /// If n > 0 Then + /// output.Write(working, 0, n) + /// End IF + /// Loop While (n > 0) + /// End Using + /// End Using + /// End Using + /// End Sub + /// + /// + /// + /// The stream which will be read or written. + /// Indicates whether the GZipStream will compress or decompress. + public GZipStream(Stream stream, CompressionMode mode) + : this(stream, mode, CompressionLevel.Default, false) + { + } + + /// + /// Create a GZipStream using the specified CompressionMode and + /// the specified CompressionLevel. + /// + /// + /// + /// + /// The CompressionMode (Compress or Decompress) also establishes the + /// "direction" of the stream. A GZipStream with + /// CompressionMode.Compress works only through Write(). A + /// GZipStream with CompressionMode.Decompress works only + /// through Read(). + /// + /// + /// + /// + /// + /// + /// This example shows how to use a GZipStream to compress a file into a .gz file. + /// + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(fileToCompress + ".gz")) + /// { + /// using (Stream compressor = new GZipStream(raw, + /// CompressionMode.Compress, + /// CompressionLevel.BestCompression)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(fileToCompress & ".gz") + /// Using compressor As Stream = New GZipStream(raw, CompressionMode.Compress, CompressionLevel.BestCompression) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// The stream to be read or written while deflating or inflating. + /// Indicates whether the GZipStream will compress or decompress. + /// A tuning knob to trade speed for effectiveness. + public GZipStream(Stream stream, CompressionMode mode, CompressionLevel level) + : this(stream, mode, level, false) + { + } + + /// + /// Create a GZipStream using the specified CompressionMode, and + /// explicitly specify whether the stream should be left open after Deflation + /// or Inflation. + /// + /// + /// + /// + /// This constructor allows the application to request that the captive stream + /// remain open after the deflation or inflation occurs. By default, after + /// Close() is called on the stream, the captive stream is also + /// closed. In some cases this is not desired, for example if the stream is a + /// memory stream that will be re-read after compressed data has been written + /// to it. Specify true for the parameter to leave + /// the stream open. + /// + /// + /// + /// The (Compress or Decompress) also + /// establishes the "direction" of the stream. A GZipStream with + /// CompressionMode.Compress works only through Write(). A GZipStream + /// with CompressionMode.Decompress works only through Read(). + /// + /// + /// + /// The GZipStream will use the default compression level. If you want + /// to specify the compression level, see . + /// + /// + /// + /// See the other overloads of this constructor for example code. + /// + /// + /// + /// + /// + /// The stream which will be read or written. This is called the "captive" + /// stream in other places in this documentation. + /// + /// + /// Indicates whether the GZipStream will compress or decompress. + /// + /// + /// + /// true if the application would like the base stream to remain open after + /// inflation/deflation. + /// + public GZipStream(Stream stream, CompressionMode mode, bool leaveOpen) + : this(stream, mode, CompressionLevel.Default, leaveOpen) + { + } + + /// + /// Create a GZipStream using the specified CompressionMode and the + /// specified CompressionLevel, and explicitly specify whether the + /// stream should be left open after Deflation or Inflation. + /// + /// + /// + /// + /// + /// This constructor allows the application to request that the captive stream + /// remain open after the deflation or inflation occurs. By default, after + /// Close() is called on the stream, the captive stream is also + /// closed. In some cases this is not desired, for example if the stream is a + /// memory stream that will be re-read after compressed data has been written + /// to it. Specify true for the parameter to + /// leave the stream open. + /// + /// + /// + /// As noted in the class documentation, the CompressionMode (Compress + /// or Decompress) also establishes the "direction" of the stream. A + /// GZipStream with CompressionMode.Compress works only through + /// Write(). A GZipStream with CompressionMode.Decompress works only + /// through Read(). + /// + /// + /// + /// + /// + /// This example shows how to use a GZipStream to compress data. + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(outputFile)) + /// { + /// using (Stream compressor = new GZipStream(raw, CompressionMode.Compress, CompressionLevel.BestCompression, true)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// Dim outputFile As String = (fileToCompress & ".compressed") + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(outputFile) + /// Using compressor As Stream = New GZipStream(raw, CompressionMode.Compress, CompressionLevel.BestCompression, True) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// The stream which will be read or written. + /// Indicates whether the GZipStream will compress or decompress. + /// true if the application would like the stream to remain open after inflation/deflation. + /// A tuning knob to trade speed for effectiveness. + public GZipStream(Stream stream, CompressionMode mode, CompressionLevel level, bool leaveOpen) + { + _baseStream = new ZlibBaseStream(stream, mode, level, ZlibStreamFlavor.GZIP, leaveOpen); + } + + #region Zlib properties + + /// + /// This property sets the flush behavior on the stream. + /// + virtual public FlushType FlushMode + { + get { return (this._baseStream._flushMode); } + set { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + this._baseStream._flushMode = value; + } + } + + /// + /// The size of the working buffer for the compression codec. + /// + /// + /// + /// + /// The working buffer is used for all stream operations. The default size is + /// 1024 bytes. The minimum size is 128 bytes. You may get better performance + /// with a larger buffer. Then again, you might not. You would have to test + /// it. + /// + /// + /// + /// Set this before the first call to Read() or Write() on the + /// stream. If you try to set it afterwards, it will throw. + /// + /// + public int BufferSize + { + get + { + return this._baseStream._bufferSize; + } + set + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + if (this._baseStream._workingBuffer != null) + throw new ZlibException("The working buffer is already set."); + if (value < ZlibConstants.WorkingBufferSizeMin) + throw new ZlibException(String.Format("Don't be silly. {0} bytes?? Use a bigger buffer, at least {1}.", value, ZlibConstants.WorkingBufferSizeMin)); + this._baseStream._bufferSize = value; + } + } + + + /// Returns the total number of bytes input so far. + virtual public long TotalIn + { + get + { + return this._baseStream._z.TotalBytesIn; + } + } + + /// Returns the total number of bytes output so far. + virtual public long TotalOut + { + get + { + return this._baseStream._z.TotalBytesOut; + } + } + + #endregion + + #region Stream methods + + /// + /// Dispose the stream. + /// + /// + /// + /// This may or may not result in a Close() call on the captive + /// stream. See the constructors that have a leaveOpen parameter + /// for more information. + /// + /// + /// This method may be invoked in two distinct scenarios. If disposing + /// == true, the method has been called directly or indirectly by a + /// user's code, for example via the public Dispose() method. In this + /// case, both managed and unmanaged resources can be referenced and + /// disposed. If disposing == false, the method has been called by the + /// runtime from inside the object finalizer and this method should not + /// reference other objects; in that case only unmanaged resources must + /// be referenced or disposed. + /// + /// + /// + /// indicates whether the Dispose method was invoked by user code. + /// + protected override void Dispose(bool disposing) + { + try + { + if (!_disposed) + { + if (disposing && (this._baseStream != null)) + { + this._baseStream.Close(); + this._Crc32 = _baseStream.Crc32; + } + _disposed = true; + } + } + finally + { + base.Dispose(disposing); + } + } + + + /// + /// Indicates whether the stream can be read. + /// + /// + /// The return value depends on whether the captive stream supports reading. + /// + public override bool CanRead + { + get + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + return _baseStream._stream.CanRead; + } + } + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + + /// + /// Indicates whether the stream can be written. + /// + /// + /// The return value depends on whether the captive stream supports writing. + /// + public override bool CanWrite + { + get + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + return _baseStream._stream.CanWrite; + } + } + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + _baseStream.Flush(); + } + + /// + /// Reading this property always throws a . + /// + public override long Length + { + get { throw new NotImplementedException(); } + } + + /// + /// The position of the stream pointer. + /// + /// + /// + /// Setting this property always throws a . Reading will return the total bytes + /// written out, if used in writing, or the total bytes read in, if used in + /// reading. The count may refer to compressed bytes or uncompressed bytes, + /// depending on how you've used the stream. + /// + public override long Position + { + get + { + if (this._baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Writer) + return this._baseStream._z.TotalBytesOut + _headerByteCount; + if (this._baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Reader) + return this._baseStream._z.TotalBytesIn + this._baseStream._gzipHeaderByteCount; + return 0; + } + + set { throw new NotImplementedException(); } + } + + /// + /// Read and decompress data from the source stream. + /// + /// + /// + /// With a GZipStream, decompression is done through reading. + /// + /// + /// + /// + /// byte[] working = new byte[WORKING_BUFFER_SIZE]; + /// using (System.IO.Stream input = System.IO.File.OpenRead(_CompressedFile)) + /// { + /// using (Stream decompressor= new Ionic.Zlib.GZipStream(input, CompressionMode.Decompress, true)) + /// { + /// using (var output = System.IO.File.Create(_DecompressedFile)) + /// { + /// int n; + /// while ((n= decompressor.Read(working, 0, working.Length)) !=0) + /// { + /// output.Write(working, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// The buffer into which the decompressed data should be placed. + /// the offset within that data array to put the first byte read. + /// the number of bytes to read. + /// the number of bytes actually read + public override int Read(byte[] buffer, int offset, int count) + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + int n = _baseStream.Read(buffer, offset, count); + + // Console.WriteLine("GZipStream::Read(buffer, off({0}), c({1}) = {2}", offset, count, n); + // Console.WriteLine( Util.FormatByteArray(buffer, offset, n) ); + + if (!_firstReadDone) + { + _firstReadDone = true; + FileName = _baseStream._GzipFileName; + Comment = _baseStream._GzipComment; + } + return n; + } + + + + /// + /// Calling this method always throws a . + /// + /// irrelevant; it will always throw! + /// irrelevant; it will always throw! + /// irrelevant! + public override long Seek(long offset, SeekOrigin origin) + { + throw new NotImplementedException(); + } + + /// + /// Calling this method always throws a . + /// + /// irrelevant; this method will always throw! + public override void SetLength(long value) + { + throw new NotImplementedException(); + } + + /// + /// Write data to the stream. + /// + /// + /// + /// + /// If you wish to use the GZipStream to compress data while writing, + /// you can create a GZipStream with CompressionMode.Compress, and a + /// writable output stream. Then call Write() on that GZipStream, + /// providing uncompressed data as input. The data sent to the output stream + /// will be the compressed form of the data written. + /// + /// + /// + /// A GZipStream can be used for Read() or Write(), but not + /// both. Writing implies compression. Reading implies decompression. + /// + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + if (_disposed) throw new ObjectDisposedException("GZipStream"); + if (_baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Undefined) + { + //Console.WriteLine("GZipStream: First write"); + if (_baseStream._wantCompress) + { + // first write in compression, therefore, emit the GZIP header + _headerByteCount = EmitHeader(); + } + else + { + throw new InvalidOperationException(); + } + } + + _baseStream.Write(buffer, offset, count); + } + #endregion + + + internal static readonly System.DateTime _unixEpoch = new System.DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc); + internal static readonly System.Text.Encoding iso8859dash1 = System.Text.Encoding.GetEncoding("iso-8859-1"); + + + private int EmitHeader() + { + byte[] commentBytes = (Comment == null) ? null : iso8859dash1.GetBytes(Comment); + byte[] filenameBytes = (FileName == null) ? null : iso8859dash1.GetBytes(FileName); + + int cbLength = (Comment == null) ? 0 : commentBytes.Length + 1; + int fnLength = (FileName == null) ? 0 : filenameBytes.Length + 1; + + int bufferLength = 10 + cbLength + fnLength; + byte[] header = new byte[bufferLength]; + int i = 0; + // ID + header[i++] = 0x1F; + header[i++] = 0x8B; + + // compression method + header[i++] = 8; + byte flag = 0; + if (Comment != null) + flag ^= 0x10; + if (FileName != null) + flag ^= 0x8; + + // flag + header[i++] = flag; + + // mtime + if (!LastModified.HasValue) LastModified = DateTime.Now; + System.TimeSpan delta = LastModified.Value - _unixEpoch; + Int32 timet = (Int32)delta.TotalSeconds; + Array.Copy(BitConverter.GetBytes(timet), 0, header, i, 4); + i += 4; + + // xflg + header[i++] = 0; // this field is totally useless + // OS + header[i++] = 0xFF; // 0xFF == unspecified + + // extra field length - only if FEXTRA is set, which it is not. + //header[i++]= 0; + //header[i++]= 0; + + // filename + if (fnLength != 0) + { + Array.Copy(filenameBytes, 0, header, i, fnLength - 1); + i += fnLength - 1; + header[i++] = 0; // terminate + } + + // comment + if (cbLength != 0) + { + Array.Copy(commentBytes, 0, header, i, cbLength - 1); + i += cbLength - 1; + header[i++] = 0; // terminate + } + + _baseStream._stream.Write(header, 0, header.Length); + + return header.Length; // bytes written + } + + + + /// + /// Compress a string into a byte array using GZip. + /// + /// + /// + /// Uncompress it with . + /// + /// + /// + /// + /// + /// + /// A string to compress. The string will first be encoded + /// using UTF8, then compressed. + /// + /// + /// The string in compressed form + public static byte[] CompressString(String s) + { + using (var ms = new MemoryStream()) + { + System.IO.Stream compressor = + new GZipStream(ms, CompressionMode.Compress, CompressionLevel.BestCompression); + ZlibBaseStream.CompressString(s, compressor); + return ms.ToArray(); + } + } + + + /// + /// Compress a byte array into a new byte array using GZip. + /// + /// + /// + /// Uncompress it with . + /// + /// + /// + /// + /// + /// + /// A buffer to compress. + /// + /// + /// The data in compressed form + public static byte[] CompressBuffer(byte[] b) + { + using (var ms = new MemoryStream()) + { + System.IO.Stream compressor = + new GZipStream( ms, CompressionMode.Compress, CompressionLevel.BestCompression ); + + ZlibBaseStream.CompressBuffer(b, compressor); + return ms.ToArray(); + } + } + + + /// + /// Uncompress a GZip'ed byte array into a single string. + /// + /// + /// + /// + /// + /// + /// A buffer containing GZIP-compressed data. + /// + /// + /// The uncompressed string + public static String UncompressString(byte[] compressed) + { + using (var input = new MemoryStream(compressed)) + { + Stream decompressor = new GZipStream(input, CompressionMode.Decompress); + return ZlibBaseStream.UncompressString(compressed, decompressor); + } + } + + + /// + /// Uncompress a GZip'ed byte array into a byte array. + /// + /// + /// + /// + /// + /// + /// A buffer containing data that has been compressed with GZip. + /// + /// + /// The data in uncompressed form + public static byte[] UncompressBuffer(byte[] compressed) + { + using (var input = new System.IO.MemoryStream(compressed)) + { + System.IO.Stream decompressor = + new GZipStream( input, CompressionMode.Decompress ); + + return ZlibBaseStream.UncompressBuffer(compressed, decompressor); + } + } + + + } +} diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/InfTree.cs b/Resources/Libraries/DotNetZip/Source/Zlib/InfTree.cs new file mode 100644 index 00000000..ffc5bb6f --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/InfTree.cs @@ -0,0 +1,436 @@ +// Inftree.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-October-28 12:43:54> +// +// ------------------------------------------------------------------ +// +// This module defines classes used in decompression. This code is derived +// from the jzlib implementation of zlib. In keeping with the license for jzlib, +// the copyright to that code is below. +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// This program is based on zlib-1.1.3; credit to authors +// Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) +// and contributors of zlib. +// +// ----------------------------------------------------------------------- + + + +using System; +namespace Ionic.Zlib +{ + + sealed class InfTree + { + + private const int MANY = 1440; + + private const int Z_OK = 0; + private const int Z_STREAM_END = 1; + private const int Z_NEED_DICT = 2; + private const int Z_ERRNO = - 1; + private const int Z_STREAM_ERROR = - 2; + private const int Z_DATA_ERROR = - 3; + private const int Z_MEM_ERROR = - 4; + private const int Z_BUF_ERROR = - 5; + private const int Z_VERSION_ERROR = - 6; + + internal const int fixed_bl = 9; + internal const int fixed_bd = 5; + + //UPGRADE_NOTE: Final was removed from the declaration of 'fixed_tl'. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1003'" + internal static readonly int[] fixed_tl = new int[]{96, 7, 256, 0, 8, 80, 0, 8, 16, 84, 8, 115, 82, 7, 31, 0, 8, 112, 0, 8, 48, 0, 9, 192, 80, 7, 10, 0, 8, 96, 0, 8, 32, 0, 9, 160, 0, 8, 0, 0, 8, 128, 0, 8, 64, 0, 9, 224, 80, 7, 6, 0, 8, 88, 0, 8, 24, 0, 9, 144, 83, 7, 59, 0, 8, 120, 0, 8, 56, 0, 9, 208, 81, 7, 17, 0, 8, 104, 0, 8, 40, 0, 9, 176, 0, 8, 8, 0, 8, 136, 0, 8, 72, 0, 9, 240, 80, 7, 4, 0, 8, 84, 0, 8, 20, 85, 8, 227, 83, 7, 43, 0, 8, 116, 0, 8, 52, 0, 9, 200, 81, 7, 13, 0, 8, 100, 0, 8, 36, 0, 9, 168, 0, 8, 4, 0, 8, 132, 0, 8, 68, 0, 9, 232, 80, 7, 8, 0, 8, 92, 0, 8, 28, 0, 9, 152, 84, 7, 83, 0, 8, 124, 0, 8, 60, 0, 9, 216, 82, 7, 23, 0, 8, 108, 0, 8, 44, 0, 9, 184, 0, 8, 12, 0, 8, 140, 0, 8, 76, 0, 9, 248, 80, 7, 3, 0, 8, 82, 0, 8, 18, 85, 8, 163, 83, 7, 35, 0, 8, 114, 0, 8, 50, 0, 9, 196, 81, 7, 11, 0, 8, 98, 0, 8, 34, 0, 9, 164, 0, 8, 2, 0, 8, 130, 0, 8, 66, 0, 9, 228, 80, 7, 7, 0, 8, 90, 0, 8, 26, 0, 9, 148, 84, 7, 67, 0, 8, 122, 0, 8, 58, 0, 9, 212, 82, 7, 19, 0, 8, 106, 0, 8, 42, 0, 9, 180, 0, 8, 10, 0, 8, 138, 0, 8, 74, 0, 9, 244, 80, 7, 5, 0, 8, 86, 0, 8, 22, 192, 8, 0, 83, 7, 51, 0, 8, 118, 0, 8, 54, 0, 9, 204, 81, 7, 15, 0, 8, 102, 0, 8, 38, 0, 9, 172, 0, 8, 6, 0, 8, 134, 0, 8, 70, 0, 9, 236, 80, 7, 9, 0, 8, 94, 0, 8, 30, 0, 9, 156, 84, 7, 99, 0, 8, 126, 0, 8, 62, 0, 9, 220, 82, 7, 27, 0, 8, 110, 0, 8, 46, 0, 9, 188, 0, 8, 14, 0, 8, 142, 0, 8, 78, 0, 9, 252, 96, 7, 256, 0, 8, 81, 0, 8, 17, 85, 8, 131, 82, 7, 31, 0, 8, 113, 0, 8, 49, 0, 9, 194, 80, 7, 10, 0, 8, 97, 0, 8, 33, 0, 9, 162, 0, 8, 1, 0, 8, 129, 0, 8, 65, 0, 9, 226, 80, 7, 6, 0, 8, 89, 0, 8, 25, 0, 9, 146, 83, 7, 59, 0, 8, 121, 0, 8, 57, 0, 9, 210, 81, 7, 17, 0, 8, 105, 0, 8, 41, 0, 9, 178, 0, 8, 9, 0, 8, 137, 0, 8, 73, 0, 9, 242, 80, 7, 4, 0, 8, 85, 0, 8, 21, 80, 8, 258, 83, 7, 43, 0, 8, 117, 0, 8, 53, 0, 9, 202, 81, 7, 13, 0, 8, 101, 0, 8, 37, 0, 9, 170, 0, 8, 5, 0, 8, 133, 0, 8, 69, 0, 9, 234, 80, 7, 8, 0, 8, 93, 0, 8, 29, 0, 9, 154, 84, 7, 83, 0, 8, 125, 0, 8, 61, 0, 9, 218, 82, 7, 23, 0, 8, 109, 0, 8, 45, 0, 9, 186, + 0, 8, 13, 0, 8, 141, 0, 8, 77, 0, 9, 250, 80, 7, 3, 0, 8, 83, 0, 8, 19, 85, 8, 195, 83, 7, 35, 0, 8, 115, 0, 8, 51, 0, 9, 198, 81, 7, 11, 0, 8, 99, 0, 8, 35, 0, 9, 166, 0, 8, 3, 0, 8, 131, 0, 8, 67, 0, 9, 230, 80, 7, 7, 0, 8, 91, 0, 8, 27, 0, 9, 150, 84, 7, 67, 0, 8, 123, 0, 8, 59, 0, 9, 214, 82, 7, 19, 0, 8, 107, 0, 8, 43, 0, 9, 182, 0, 8, 11, 0, 8, 139, 0, 8, 75, 0, 9, 246, 80, 7, 5, 0, 8, 87, 0, 8, 23, 192, 8, 0, 83, 7, 51, 0, 8, 119, 0, 8, 55, 0, 9, 206, 81, 7, 15, 0, 8, 103, 0, 8, 39, 0, 9, 174, 0, 8, 7, 0, 8, 135, 0, 8, 71, 0, 9, 238, 80, 7, 9, 0, 8, 95, 0, 8, 31, 0, 9, 158, 84, 7, 99, 0, 8, 127, 0, 8, 63, 0, 9, 222, 82, 7, 27, 0, 8, 111, 0, 8, 47, 0, 9, 190, 0, 8, 15, 0, 8, 143, 0, 8, 79, 0, 9, 254, 96, 7, 256, 0, 8, 80, 0, 8, 16, 84, 8, 115, 82, 7, 31, 0, 8, 112, 0, 8, 48, 0, 9, 193, 80, 7, 10, 0, 8, 96, 0, 8, 32, 0, 9, 161, 0, 8, 0, 0, 8, 128, 0, 8, 64, 0, 9, 225, 80, 7, 6, 0, 8, 88, 0, 8, 24, 0, 9, 145, 83, 7, 59, 0, 8, 120, 0, 8, 56, 0, 9, 209, 81, 7, 17, 0, 8, 104, 0, 8, 40, 0, 9, 177, 0, 8, 8, 0, 8, 136, 0, 8, 72, 0, 9, 241, 80, 7, 4, 0, 8, 84, 0, 8, 20, 85, 8, 227, 83, 7, 43, 0, 8, 116, 0, 8, 52, 0, 9, 201, 81, 7, 13, 0, 8, 100, 0, 8, 36, 0, 9, 169, 0, 8, 4, 0, 8, 132, 0, 8, 68, 0, 9, 233, 80, 7, 8, 0, 8, 92, 0, 8, 28, 0, 9, 153, 84, 7, 83, 0, 8, 124, 0, 8, 60, 0, 9, 217, 82, 7, 23, 0, 8, 108, 0, 8, 44, 0, 9, 185, 0, 8, 12, 0, 8, 140, 0, 8, 76, 0, 9, 249, 80, 7, 3, 0, 8, 82, 0, 8, 18, 85, 8, 163, 83, 7, 35, 0, 8, 114, 0, 8, 50, 0, 9, 197, 81, 7, 11, 0, 8, 98, 0, 8, 34, 0, 9, 165, 0, 8, 2, 0, 8, 130, 0, 8, 66, 0, 9, 229, 80, 7, 7, 0, 8, 90, 0, 8, 26, 0, 9, 149, 84, 7, 67, 0, 8, 122, 0, 8, 58, 0, 9, 213, 82, 7, 19, 0, 8, 106, 0, 8, 42, 0, 9, 181, 0, 8, 10, 0, 8, 138, 0, 8, 74, 0, 9, 245, 80, 7, 5, 0, 8, 86, 0, 8, 22, 192, 8, 0, 83, 7, 51, 0, 8, 118, 0, 8, 54, 0, 9, 205, 81, 7, 15, 0, 8, 102, 0, 8, 38, 0, 9, 173, 0, 8, 6, 0, 8, 134, 0, 8, 70, 0, 9, 237, 80, 7, 9, 0, 8, 94, 0, 8, 30, 0, 9, 157, 84, 7, 99, 0, 8, 126, 0, 8, 62, 0, 9, 221, 82, 7, 27, 0, 8, 110, 0, 8, 46, 0, 9, 189, 0, 8, + 14, 0, 8, 142, 0, 8, 78, 0, 9, 253, 96, 7, 256, 0, 8, 81, 0, 8, 17, 85, 8, 131, 82, 7, 31, 0, 8, 113, 0, 8, 49, 0, 9, 195, 80, 7, 10, 0, 8, 97, 0, 8, 33, 0, 9, 163, 0, 8, 1, 0, 8, 129, 0, 8, 65, 0, 9, 227, 80, 7, 6, 0, 8, 89, 0, 8, 25, 0, 9, 147, 83, 7, 59, 0, 8, 121, 0, 8, 57, 0, 9, 211, 81, 7, 17, 0, 8, 105, 0, 8, 41, 0, 9, 179, 0, 8, 9, 0, 8, 137, 0, 8, 73, 0, 9, 243, 80, 7, 4, 0, 8, 85, 0, 8, 21, 80, 8, 258, 83, 7, 43, 0, 8, 117, 0, 8, 53, 0, 9, 203, 81, 7, 13, 0, 8, 101, 0, 8, 37, 0, 9, 171, 0, 8, 5, 0, 8, 133, 0, 8, 69, 0, 9, 235, 80, 7, 8, 0, 8, 93, 0, 8, 29, 0, 9, 155, 84, 7, 83, 0, 8, 125, 0, 8, 61, 0, 9, 219, 82, 7, 23, 0, 8, 109, 0, 8, 45, 0, 9, 187, 0, 8, 13, 0, 8, 141, 0, 8, 77, 0, 9, 251, 80, 7, 3, 0, 8, 83, 0, 8, 19, 85, 8, 195, 83, 7, 35, 0, 8, 115, 0, 8, 51, 0, 9, 199, 81, 7, 11, 0, 8, 99, 0, 8, 35, 0, 9, 167, 0, 8, 3, 0, 8, 131, 0, 8, 67, 0, 9, 231, 80, 7, 7, 0, 8, 91, 0, 8, 27, 0, 9, 151, 84, 7, 67, 0, 8, 123, 0, 8, 59, 0, 9, 215, 82, 7, 19, 0, 8, 107, 0, 8, 43, 0, 9, 183, 0, 8, 11, 0, 8, 139, 0, 8, 75, 0, 9, 247, 80, 7, 5, 0, 8, 87, 0, 8, 23, 192, 8, 0, 83, 7, 51, 0, 8, 119, 0, 8, 55, 0, 9, 207, 81, 7, 15, 0, 8, 103, 0, 8, 39, 0, 9, 175, 0, 8, 7, 0, 8, 135, 0, 8, 71, 0, 9, 239, 80, 7, 9, 0, 8, 95, 0, 8, 31, 0, 9, 159, 84, 7, 99, 0, 8, 127, 0, 8, 63, 0, 9, 223, 82, 7, 27, 0, 8, 111, 0, 8, 47, 0, 9, 191, 0, 8, 15, 0, 8, 143, 0, 8, 79, 0, 9, 255}; + //UPGRADE_NOTE: Final was removed from the declaration of 'fixed_td'. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1003'" + internal static readonly int[] fixed_td = new int[]{80, 5, 1, 87, 5, 257, 83, 5, 17, 91, 5, 4097, 81, 5, 5, 89, 5, 1025, 85, 5, 65, 93, 5, 16385, 80, 5, 3, 88, 5, 513, 84, 5, 33, 92, 5, 8193, 82, 5, 9, 90, 5, 2049, 86, 5, 129, 192, 5, 24577, 80, 5, 2, 87, 5, 385, 83, 5, 25, 91, 5, 6145, 81, 5, 7, 89, 5, 1537, 85, 5, 97, 93, 5, 24577, 80, 5, 4, 88, 5, 769, 84, 5, 49, 92, 5, 12289, 82, 5, 13, 90, 5, 3073, 86, 5, 193, 192, 5, 24577}; + + // Tables for deflate from PKZIP's appnote.txt. + //UPGRADE_NOTE: Final was removed from the declaration of 'cplens'. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1003'" + internal static readonly int[] cplens = new int[]{3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; + + // see note #13 above about 258 + //UPGRADE_NOTE: Final was removed from the declaration of 'cplext'. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1003'" + internal static readonly int[] cplext = new int[]{0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 112, 112}; + + //UPGRADE_NOTE: Final was removed from the declaration of 'cpdist'. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1003'" + internal static readonly int[] cpdist = new int[]{1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577}; + + //UPGRADE_NOTE: Final was removed from the declaration of 'cpdext'. "ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?index='!DefaultContextWindowIndex'&keyword='jlca1003'" + internal static readonly int[] cpdext = new int[]{0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13}; + + // If BMAX needs to be larger than 16, then h and x[] should be uLong. + internal const int BMAX = 15; // maximum bit length of any code + + internal int[] hn = null; // hufts used in space + internal int[] v = null; // work area for huft_build + internal int[] c = null; // bit length count table + internal int[] r = null; // table entry for structure assignment + internal int[] u = null; // table stack + internal int[] x = null; // bit offsets, then code stack + + private int huft_build(int[] b, int bindex, int n, int s, int[] d, int[] e, int[] t, int[] m, int[] hp, int[] hn, int[] v) + { + // Given a list of code lengths and a maximum table size, make a set of + // tables to decode that set of codes. Return Z_OK on success, Z_BUF_ERROR + // if the given code set is incomplete (the tables are still built in this + // case), Z_DATA_ERROR if the input is invalid (an over-subscribed set of + // lengths), or Z_MEM_ERROR if not enough memory. + + int a; // counter for codes of length k + int f; // i repeats in table every f entries + int g; // maximum code length + int h; // table level + int i; // counter, current code + int j; // counter + int k; // number of bits in current code + int l; // bits per table (returned in m) + int mask; // (1 << w) - 1, to avoid cc -O bug on HP + int p; // pointer into c[], b[], or v[] + int q; // points to current table + int w; // bits before this table == (l * h) + int xp; // pointer into x + int y; // number of dummy codes added + int z; // number of entries in current table + + // Generate counts for each bit length + + p = 0; i = n; + do + { + c[b[bindex + p]]++; p++; i--; // assume all entries <= BMAX + } + while (i != 0); + + if (c[0] == n) + { + // null input--all zero length codes + t[0] = - 1; + m[0] = 0; + return Z_OK; + } + + // Find minimum and maximum length, bound *m by those + l = m[0]; + for (j = 1; j <= BMAX; j++) + if (c[j] != 0) + break; + k = j; // minimum code length + if (l < j) + { + l = j; + } + for (i = BMAX; i != 0; i--) + { + if (c[i] != 0) + break; + } + g = i; // maximum code length + if (l > i) + { + l = i; + } + m[0] = l; + + // Adjust last length count to fill out codes, if needed + for (y = 1 << j; j < i; j++, y <<= 1) + { + if ((y -= c[j]) < 0) + { + return Z_DATA_ERROR; + } + } + if ((y -= c[i]) < 0) + { + return Z_DATA_ERROR; + } + c[i] += y; + + // Generate starting offsets into the value table for each length + x[1] = j = 0; + p = 1; xp = 2; + while (--i != 0) + { + // note that i == g from above + x[xp] = (j += c[p]); + xp++; + p++; + } + + // Make a table of values in order of bit lengths + i = 0; p = 0; + do + { + if ((j = b[bindex + p]) != 0) + { + v[x[j]++] = i; + } + p++; + } + while (++i < n); + n = x[g]; // set n to length of v + + // Generate the Huffman codes and for each, make the table entries + x[0] = i = 0; // first Huffman code is zero + p = 0; // grab values in bit order + h = - 1; // no tables yet--level -1 + w = - l; // bits decoded == (l * h) + u[0] = 0; // just to keep compilers happy + q = 0; // ditto + z = 0; // ditto + + // go through the bit lengths (k already is bits in shortest code) + for (; k <= g; k++) + { + a = c[k]; + while (a-- != 0) + { + // here i is the Huffman code of length k bits for value *p + // make tables up to required level + while (k > w + l) + { + h++; + w += l; // previous table always l bits + // compute minimum size table less than or equal to l bits + z = g - w; + z = (z > l)?l:z; // table size upper limit + if ((f = 1 << (j = k - w)) > a + 1) + { + // try a k-w bit table + // too few codes for k-w bit table + f -= (a + 1); // deduct codes from patterns left + xp = k; + if (j < z) + { + while (++j < z) + { + // try smaller tables up to z bits + if ((f <<= 1) <= c[++xp]) + break; // enough codes to use up j bits + f -= c[xp]; // else deduct codes from patterns + } + } + } + z = 1 << j; // table entries for j-bit table + + // allocate new table + if (hn[0] + z > MANY) + { + // (note: doesn't matter for fixed) + return Z_DATA_ERROR; // overflow of MANY + } + u[h] = q = hn[0]; // DEBUG + hn[0] += z; + + // connect to last table, if there is one + if (h != 0) + { + x[h] = i; // save pattern for backing up + r[0] = (sbyte) j; // bits in this table + r[1] = (sbyte) l; // bits to dump before this table + j = SharedUtils.URShift(i, (w - l)); + r[2] = (int) (q - u[h - 1] - j); // offset to this table + Array.Copy(r, 0, hp, (u[h - 1] + j) * 3, 3); // connect to last table + } + else + { + t[0] = q; // first table is returned result + } + } + + // set up table entry in r + r[1] = (sbyte) (k - w); + if (p >= n) + { + r[0] = 128 + 64; // out of values--invalid code + } + else if (v[p] < s) + { + r[0] = (sbyte) (v[p] < 256?0:32 + 64); // 256 is end-of-block + r[2] = v[p++]; // simple code is just the value + } + else + { + r[0] = (sbyte) (e[v[p] - s] + 16 + 64); // non-simple--look up in lists + r[2] = d[v[p++] - s]; + } + + // fill code-like entries with r + f = 1 << (k - w); + for (j = SharedUtils.URShift(i, w); j < z; j += f) + { + Array.Copy(r, 0, hp, (q + j) * 3, 3); + } + + // backwards increment the k-bit code i + for (j = 1 << (k - 1); (i & j) != 0; j = SharedUtils.URShift(j, 1)) + { + i ^= j; + } + i ^= j; + + // backup over finished tables + mask = (1 << w) - 1; // needed on HP, cc -O bug + while ((i & mask) != x[h]) + { + h--; // don't need to update q + w -= l; + mask = (1 << w) - 1; + } + } + } + // Return Z_BUF_ERROR if we were given an incomplete table + return y != 0 && g != 1?Z_BUF_ERROR:Z_OK; + } + + internal int inflate_trees_bits(int[] c, int[] bb, int[] tb, int[] hp, ZlibCodec z) + { + int result; + initWorkArea(19); + hn[0] = 0; + result = huft_build(c, 0, 19, 19, null, null, tb, bb, hp, hn, v); + + if (result == Z_DATA_ERROR) + { + z.Message = "oversubscribed dynamic bit lengths tree"; + } + else if (result == Z_BUF_ERROR || bb[0] == 0) + { + z.Message = "incomplete dynamic bit lengths tree"; + result = Z_DATA_ERROR; + } + return result; + } + + internal int inflate_trees_dynamic(int nl, int nd, int[] c, int[] bl, int[] bd, int[] tl, int[] td, int[] hp, ZlibCodec z) + { + int result; + + // build literal/length tree + initWorkArea(288); + hn[0] = 0; + result = huft_build(c, 0, nl, 257, cplens, cplext, tl, bl, hp, hn, v); + if (result != Z_OK || bl[0] == 0) + { + if (result == Z_DATA_ERROR) + { + z.Message = "oversubscribed literal/length tree"; + } + else if (result != Z_MEM_ERROR) + { + z.Message = "incomplete literal/length tree"; + result = Z_DATA_ERROR; + } + return result; + } + + // build distance tree + initWorkArea(288); + result = huft_build(c, nl, nd, 0, cpdist, cpdext, td, bd, hp, hn, v); + + if (result != Z_OK || (bd[0] == 0 && nl > 257)) + { + if (result == Z_DATA_ERROR) + { + z.Message = "oversubscribed distance tree"; + } + else if (result == Z_BUF_ERROR) + { + z.Message = "incomplete distance tree"; + result = Z_DATA_ERROR; + } + else if (result != Z_MEM_ERROR) + { + z.Message = "empty distance tree with lengths"; + result = Z_DATA_ERROR; + } + return result; + } + + return Z_OK; + } + + internal static int inflate_trees_fixed(int[] bl, int[] bd, int[][] tl, int[][] td, ZlibCodec z) + { + bl[0] = fixed_bl; + bd[0] = fixed_bd; + tl[0] = fixed_tl; + td[0] = fixed_td; + return Z_OK; + } + + private void initWorkArea(int vsize) + { + if (hn == null) + { + hn = new int[1]; + v = new int[vsize]; + c = new int[BMAX + 1]; + r = new int[3]; + u = new int[BMAX]; + x = new int[BMAX + 1]; + } + else + { + if (v.Length < vsize) + { + v = new int[vsize]; + } + Array.Clear(v,0,vsize); + Array.Clear(c,0,BMAX+1); + r[0]=0; r[1]=0; r[2]=0; + // for(int i=0; i +// +// ------------------------------------------------------------------ +// +// This module defines classes for decompression. This code is derived +// from the jzlib implementation of zlib, but significantly modified. +// The object model is not the same, and many of the behaviors are +// different. Nonetheless, in keeping with the license for jzlib, I am +// reproducing the copyright to that code here. +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// This program is based on zlib-1.1.3; credit to authors +// Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) +// and contributors of zlib. +// +// ----------------------------------------------------------------------- + + +using System; +namespace Ionic.Zlib +{ + sealed class InflateBlocks + { + private const int MANY = 1440; + + // Table for deflate from PKZIP's appnote.txt. + internal static readonly int[] border = new int[] + { 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 }; + + private enum InflateBlockMode + { + TYPE = 0, // get type bits (3, including end bit) + LENS = 1, // get lengths for stored + STORED = 2, // processing stored block + TABLE = 3, // get table lengths + BTREE = 4, // get bit lengths tree for a dynamic block + DTREE = 5, // get length, distance trees for a dynamic block + CODES = 6, // processing fixed or dynamic block + DRY = 7, // output remaining window bytes + DONE = 8, // finished last block, done + BAD = 9, // ot a data error--stuck here + } + + private InflateBlockMode mode; // current inflate_block mode + + internal int left; // if STORED, bytes left to copy + + internal int table; // table lengths (14 bits) + internal int index; // index into blens (or border) + internal int[] blens; // bit lengths of codes + internal int[] bb = new int[1]; // bit length tree depth + internal int[] tb = new int[1]; // bit length decoding tree + + internal InflateCodes codes = new InflateCodes(); // if CODES, current state + + internal int last; // true if this block is the last block + + internal ZlibCodec _codec; // pointer back to this zlib stream + + // mode independent information + internal int bitk; // bits in bit buffer + internal int bitb; // bit buffer + internal int[] hufts; // single malloc for tree space + internal byte[] window; // sliding window + internal int end; // one byte after sliding window + internal int readAt; // window read pointer + internal int writeAt; // window write pointer + internal System.Object checkfn; // check function + internal uint check; // check on output + + internal InfTree inftree = new InfTree(); + + internal InflateBlocks(ZlibCodec codec, System.Object checkfn, int w) + { + _codec = codec; + hufts = new int[MANY * 3]; + window = new byte[w]; + end = w; + this.checkfn = checkfn; + mode = InflateBlockMode.TYPE; + Reset(); + } + + internal uint Reset() + { + uint oldCheck = check; + mode = InflateBlockMode.TYPE; + bitk = 0; + bitb = 0; + readAt = writeAt = 0; + + if (checkfn != null) + _codec._Adler32 = check = Adler.Adler32(0, null, 0, 0); + return oldCheck; + } + + + internal int Process(int r) + { + int t; // temporary storage + int b; // bit buffer + int k; // bits in bit buffer + int p; // input data pointer + int n; // bytes available there + int q; // output window write pointer + int m; // bytes to end of window or read pointer + + // copy input/output information to locals (UPDATE macro restores) + + p = _codec.NextIn; + n = _codec.AvailableBytesIn; + b = bitb; + k = bitk; + + q = writeAt; + m = (int)(q < readAt ? readAt - q - 1 : end - q); + + + // process input based on current state + while (true) + { + switch (mode) + { + case InflateBlockMode.TYPE: + + while (k < (3)) + { + if (n != 0) + { + r = ZlibConstants.Z_OK; + } + else + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + n--; + b |= (_codec.InputBuffer[p++] & 0xff) << k; + k += 8; + } + t = (int)(b & 7); + last = t & 1; + + switch ((uint)t >> 1) + { + case 0: // stored + b >>= 3; k -= (3); + t = k & 7; // go to byte boundary + b >>= t; k -= t; + mode = InflateBlockMode.LENS; // get length of stored block + break; + + case 1: // fixed + int[] bl = new int[1]; + int[] bd = new int[1]; + int[][] tl = new int[1][]; + int[][] td = new int[1][]; + InfTree.inflate_trees_fixed(bl, bd, tl, td, _codec); + codes.Init(bl[0], bd[0], tl[0], 0, td[0], 0); + b >>= 3; k -= 3; + mode = InflateBlockMode.CODES; + break; + + case 2: // dynamic + b >>= 3; k -= 3; + mode = InflateBlockMode.TABLE; + break; + + case 3: // illegal + b >>= 3; k -= 3; + mode = InflateBlockMode.BAD; + _codec.Message = "invalid block type"; + r = ZlibConstants.Z_DATA_ERROR; + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + break; + + case InflateBlockMode.LENS: + + while (k < (32)) + { + if (n != 0) + { + r = ZlibConstants.Z_OK; + } + else + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + ; + n--; + b |= (_codec.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + if ( ( ((~b)>>16) & 0xffff) != (b & 0xffff)) + { + mode = InflateBlockMode.BAD; + _codec.Message = "invalid stored block lengths"; + r = ZlibConstants.Z_DATA_ERROR; + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + left = (b & 0xffff); + b = k = 0; // dump bits + mode = left != 0 ? InflateBlockMode.STORED : (last != 0 ? InflateBlockMode.DRY : InflateBlockMode.TYPE); + break; + + case InflateBlockMode.STORED: + if (n == 0) + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + if (m == 0) + { + if (q == end && readAt != 0) + { + q = 0; m = (int)(q < readAt ? readAt - q - 1 : end - q); + } + if (m == 0) + { + writeAt = q; + r = Flush(r); + q = writeAt; m = (int)(q < readAt ? readAt - q - 1 : end - q); + if (q == end && readAt != 0) + { + q = 0; m = (int)(q < readAt ? readAt - q - 1 : end - q); + } + if (m == 0) + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + } + } + r = ZlibConstants.Z_OK; + + t = left; + if (t > n) + t = n; + if (t > m) + t = m; + Array.Copy(_codec.InputBuffer, p, window, q, t); + p += t; n -= t; + q += t; m -= t; + if ((left -= t) != 0) + break; + mode = last != 0 ? InflateBlockMode.DRY : InflateBlockMode.TYPE; + break; + + case InflateBlockMode.TABLE: + + while (k < (14)) + { + if (n != 0) + { + r = ZlibConstants.Z_OK; + } + else + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + n--; + b |= (_codec.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + table = t = (b & 0x3fff); + if ((t & 0x1f) > 29 || ((t >> 5) & 0x1f) > 29) + { + mode = InflateBlockMode.BAD; + _codec.Message = "too many length or distance symbols"; + r = ZlibConstants.Z_DATA_ERROR; + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + t = 258 + (t & 0x1f) + ((t >> 5) & 0x1f); + if (blens == null || blens.Length < t) + { + blens = new int[t]; + } + else + { + Array.Clear(blens, 0, t); + // for (int i = 0; i < t; i++) + // { + // blens[i] = 0; + // } + } + + b >>= 14; + k -= 14; + + + index = 0; + mode = InflateBlockMode.BTREE; + goto case InflateBlockMode.BTREE; + + case InflateBlockMode.BTREE: + while (index < 4 + (table >> 10)) + { + while (k < (3)) + { + if (n != 0) + { + r = ZlibConstants.Z_OK; + } + else + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + n--; + b |= (_codec.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + blens[border[index++]] = b & 7; + + b >>= 3; k -= 3; + } + + while (index < 19) + { + blens[border[index++]] = 0; + } + + bb[0] = 7; + t = inftree.inflate_trees_bits(blens, bb, tb, hufts, _codec); + if (t != ZlibConstants.Z_OK) + { + r = t; + if (r == ZlibConstants.Z_DATA_ERROR) + { + blens = null; + mode = InflateBlockMode.BAD; + } + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + index = 0; + mode = InflateBlockMode.DTREE; + goto case InflateBlockMode.DTREE; + + case InflateBlockMode.DTREE: + while (true) + { + t = table; + if (!(index < 258 + (t & 0x1f) + ((t >> 5) & 0x1f))) + { + break; + } + + int i, j, c; + + t = bb[0]; + + while (k < t) + { + if (n != 0) + { + r = ZlibConstants.Z_OK; + } + else + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + n--; + b |= (_codec.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + t = hufts[(tb[0] + (b & InternalInflateConstants.InflateMask[t])) * 3 + 1]; + c = hufts[(tb[0] + (b & InternalInflateConstants.InflateMask[t])) * 3 + 2]; + + if (c < 16) + { + b >>= t; k -= t; + blens[index++] = c; + } + else + { + // c == 16..18 + i = c == 18 ? 7 : c - 14; + j = c == 18 ? 11 : 3; + + while (k < (t + i)) + { + if (n != 0) + { + r = ZlibConstants.Z_OK; + } + else + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + n--; + b |= (_codec.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + b >>= t; k -= t; + + j += (b & InternalInflateConstants.InflateMask[i]); + + b >>= i; k -= i; + + i = index; + t = table; + if (i + j > 258 + (t & 0x1f) + ((t >> 5) & 0x1f) || (c == 16 && i < 1)) + { + blens = null; + mode = InflateBlockMode.BAD; + _codec.Message = "invalid bit length repeat"; + r = ZlibConstants.Z_DATA_ERROR; + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + + c = (c == 16) ? blens[i-1] : 0; + do + { + blens[i++] = c; + } + while (--j != 0); + index = i; + } + } + + tb[0] = -1; + { + int[] bl = new int[] { 9 }; // must be <= 9 for lookahead assumptions + int[] bd = new int[] { 6 }; // must be <= 9 for lookahead assumptions + int[] tl = new int[1]; + int[] td = new int[1]; + + t = table; + t = inftree.inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f), blens, bl, bd, tl, td, hufts, _codec); + + if (t != ZlibConstants.Z_OK) + { + if (t == ZlibConstants.Z_DATA_ERROR) + { + blens = null; + mode = InflateBlockMode.BAD; + } + r = t; + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + codes.Init(bl[0], bd[0], hufts, tl[0], hufts, td[0]); + } + mode = InflateBlockMode.CODES; + goto case InflateBlockMode.CODES; + + case InflateBlockMode.CODES: + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + + r = codes.Process(this, r); + if (r != ZlibConstants.Z_STREAM_END) + { + return Flush(r); + } + + r = ZlibConstants.Z_OK; + p = _codec.NextIn; + n = _codec.AvailableBytesIn; + b = bitb; + k = bitk; + q = writeAt; + m = (int)(q < readAt ? readAt - q - 1 : end - q); + + if (last == 0) + { + mode = InflateBlockMode.TYPE; + break; + } + mode = InflateBlockMode.DRY; + goto case InflateBlockMode.DRY; + + case InflateBlockMode.DRY: + writeAt = q; + r = Flush(r); + q = writeAt; m = (int)(q < readAt ? readAt - q - 1 : end - q); + if (readAt != writeAt) + { + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + mode = InflateBlockMode.DONE; + goto case InflateBlockMode.DONE; + + case InflateBlockMode.DONE: + r = ZlibConstants.Z_STREAM_END; + bitb = b; + bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + + case InflateBlockMode.BAD: + r = ZlibConstants.Z_DATA_ERROR; + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + + + default: + r = ZlibConstants.Z_STREAM_ERROR; + + bitb = b; bitk = k; + _codec.AvailableBytesIn = n; + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + writeAt = q; + return Flush(r); + } + } + } + + + internal void Free() + { + Reset(); + window = null; + hufts = null; + } + + internal void SetDictionary(byte[] d, int start, int n) + { + Array.Copy(d, start, window, 0, n); + readAt = writeAt = n; + } + + // Returns true if inflate is currently at the end of a block generated + // by Z_SYNC_FLUSH or Z_FULL_FLUSH. + internal int SyncPoint() + { + return mode == InflateBlockMode.LENS ? 1 : 0; + } + + // copy as much as possible from the sliding window to the output area + internal int Flush(int r) + { + int nBytes; + + for (int pass=0; pass < 2; pass++) + { + if (pass==0) + { + // compute number of bytes to copy as far as end of window + nBytes = (int)((readAt <= writeAt ? writeAt : end) - readAt); + } + else + { + // compute bytes to copy + nBytes = writeAt - readAt; + } + + // workitem 8870 + if (nBytes == 0) + { + if (r == ZlibConstants.Z_BUF_ERROR) + r = ZlibConstants.Z_OK; + return r; + } + + if (nBytes > _codec.AvailableBytesOut) + nBytes = _codec.AvailableBytesOut; + + if (nBytes != 0 && r == ZlibConstants.Z_BUF_ERROR) + r = ZlibConstants.Z_OK; + + // update counters + _codec.AvailableBytesOut -= nBytes; + _codec.TotalBytesOut += nBytes; + + // update check information + if (checkfn != null) + _codec._Adler32 = check = Adler.Adler32(check, window, readAt, nBytes); + + // copy as far as end of window + Array.Copy(window, readAt, _codec.OutputBuffer, _codec.NextOut, nBytes); + _codec.NextOut += nBytes; + readAt += nBytes; + + // see if more to copy at beginning of window + if (readAt == end && pass == 0) + { + // wrap pointers + readAt = 0; + if (writeAt == end) + writeAt = 0; + } + else pass++; + } + + // done + return r; + } + } + + + internal static class InternalInflateConstants + { + // And'ing with mask[n] masks the lower n bits + internal static readonly int[] InflateMask = new int[] { + 0x00000000, 0x00000001, 0x00000003, 0x00000007, + 0x0000000f, 0x0000001f, 0x0000003f, 0x0000007f, + 0x000000ff, 0x000001ff, 0x000003ff, 0x000007ff, + 0x00000fff, 0x00001fff, 0x00003fff, 0x00007fff, 0x0000ffff }; + } + + + sealed class InflateCodes + { + // waiting for "i:"=input, + // "o:"=output, + // "x:"=nothing + private const int START = 0; // x: set up for LEN + private const int LEN = 1; // i: get length/literal/eob next + private const int LENEXT = 2; // i: getting length extra (have base) + private const int DIST = 3; // i: get distance next + private const int DISTEXT = 4; // i: getting distance extra + private const int COPY = 5; // o: copying bytes in window, waiting for space + private const int LIT = 6; // o: got literal, waiting for output space + private const int WASH = 7; // o: got eob, possibly still output waiting + private const int END = 8; // x: got eob and all data flushed + private const int BADCODE = 9; // x: got error + + internal int mode; // current inflate_codes mode + + // mode dependent information + internal int len; + + internal int[] tree; // pointer into tree + internal int tree_index = 0; + internal int need; // bits needed + + internal int lit; + + // if EXT or COPY, where and how much + internal int bitsToGet; // bits to get for extra + internal int dist; // distance back to copy from + + internal byte lbits; // ltree bits decoded per branch + internal byte dbits; // dtree bits decoder per branch + internal int[] ltree; // literal/length/eob tree + internal int ltree_index; // literal/length/eob tree + internal int[] dtree; // distance tree + internal int dtree_index; // distance tree + + internal InflateCodes() + { + } + + internal void Init(int bl, int bd, int[] tl, int tl_index, int[] td, int td_index) + { + mode = START; + lbits = (byte)bl; + dbits = (byte)bd; + ltree = tl; + ltree_index = tl_index; + dtree = td; + dtree_index = td_index; + tree = null; + } + + internal int Process(InflateBlocks blocks, int r) + { + int j; // temporary storage + int tindex; // temporary pointer + int e; // extra bits or operation + int b = 0; // bit buffer + int k = 0; // bits in bit buffer + int p = 0; // input data pointer + int n; // bytes available there + int q; // output window write pointer + int m; // bytes to end of window or read pointer + int f; // pointer to copy strings from + + ZlibCodec z = blocks._codec; + + // copy input/output information to locals (UPDATE macro restores) + p = z.NextIn; + n = z.AvailableBytesIn; + b = blocks.bitb; + k = blocks.bitk; + q = blocks.writeAt; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + + // process input and output based on current state + while (true) + { + switch (mode) + { + // waiting for "i:"=input, "o:"=output, "x:"=nothing + case START: // x: set up for LEN + if (m >= 258 && n >= 10) + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; + z.TotalBytesIn += p - z.NextIn; + z.NextIn = p; + blocks.writeAt = q; + r = InflateFast(lbits, dbits, ltree, ltree_index, dtree, dtree_index, blocks, z); + + p = z.NextIn; + n = z.AvailableBytesIn; + b = blocks.bitb; + k = blocks.bitk; + q = blocks.writeAt; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + + if (r != ZlibConstants.Z_OK) + { + mode = (r == ZlibConstants.Z_STREAM_END) ? WASH : BADCODE; + break; + } + } + need = lbits; + tree = ltree; + tree_index = ltree_index; + + mode = LEN; + goto case LEN; + + case LEN: // i: get length/literal/eob next + j = need; + + while (k < j) + { + if (n != 0) + r = ZlibConstants.Z_OK; + else + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; + z.TotalBytesIn += p - z.NextIn; + z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + n--; + b |= (z.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + tindex = (tree_index + (b & InternalInflateConstants.InflateMask[j])) * 3; + + b >>= (tree[tindex + 1]); + k -= (tree[tindex + 1]); + + e = tree[tindex]; + + if (e == 0) + { + // literal + lit = tree[tindex + 2]; + mode = LIT; + break; + } + if ((e & 16) != 0) + { + // length + bitsToGet = e & 15; + len = tree[tindex + 2]; + mode = LENEXT; + break; + } + if ((e & 64) == 0) + { + // next table + need = e; + tree_index = tindex / 3 + tree[tindex + 2]; + break; + } + if ((e & 32) != 0) + { + // end of block + mode = WASH; + break; + } + mode = BADCODE; // invalid code + z.Message = "invalid literal/length code"; + r = ZlibConstants.Z_DATA_ERROR; + + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; + z.TotalBytesIn += p - z.NextIn; + z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + + + case LENEXT: // i: getting length extra (have base) + j = bitsToGet; + + while (k < j) + { + if (n != 0) + r = ZlibConstants.Z_OK; + else + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + n--; b |= (z.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + len += (b & InternalInflateConstants.InflateMask[j]); + + b >>= j; + k -= j; + + need = dbits; + tree = dtree; + tree_index = dtree_index; + mode = DIST; + goto case DIST; + + case DIST: // i: get distance next + j = need; + + while (k < j) + { + if (n != 0) + r = ZlibConstants.Z_OK; + else + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + n--; b |= (z.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + tindex = (tree_index + (b & InternalInflateConstants.InflateMask[j])) * 3; + + b >>= tree[tindex + 1]; + k -= tree[tindex + 1]; + + e = (tree[tindex]); + if ((e & 0x10) != 0) + { + // distance + bitsToGet = e & 15; + dist = tree[tindex + 2]; + mode = DISTEXT; + break; + } + if ((e & 64) == 0) + { + // next table + need = e; + tree_index = tindex / 3 + tree[tindex + 2]; + break; + } + mode = BADCODE; // invalid code + z.Message = "invalid distance code"; + r = ZlibConstants.Z_DATA_ERROR; + + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + + + case DISTEXT: // i: getting distance extra + j = bitsToGet; + + while (k < j) + { + if (n != 0) + r = ZlibConstants.Z_OK; + else + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + n--; b |= (z.InputBuffer[p++] & 0xff) << k; + k += 8; + } + + dist += (b & InternalInflateConstants.InflateMask[j]); + + b >>= j; + k -= j; + + mode = COPY; + goto case COPY; + + case COPY: // o: copying bytes in window, waiting for space + f = q - dist; + while (f < 0) + { + // modulo window size-"while" instead + f += blocks.end; // of "if" handles invalid distances + } + while (len != 0) + { + if (m == 0) + { + if (q == blocks.end && blocks.readAt != 0) + { + q = 0; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + } + if (m == 0) + { + blocks.writeAt = q; r = blocks.Flush(r); + q = blocks.writeAt; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + + if (q == blocks.end && blocks.readAt != 0) + { + q = 0; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + } + + if (m == 0) + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; + z.TotalBytesIn += p - z.NextIn; + z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + } + } + + blocks.window[q++] = blocks.window[f++]; m--; + + if (f == blocks.end) + f = 0; + len--; + } + mode = START; + break; + + case LIT: // o: got literal, waiting for output space + if (m == 0) + { + if (q == blocks.end && blocks.readAt != 0) + { + q = 0; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + } + if (m == 0) + { + blocks.writeAt = q; r = blocks.Flush(r); + q = blocks.writeAt; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + + if (q == blocks.end && blocks.readAt != 0) + { + q = 0; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + } + if (m == 0) + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + } + } + r = ZlibConstants.Z_OK; + + blocks.window[q++] = (byte)lit; m--; + + mode = START; + break; + + case WASH: // o: got eob, possibly more output + if (k > 7) + { + // return unused byte, if any + k -= 8; + n++; + p--; // can always return one + } + + blocks.writeAt = q; r = blocks.Flush(r); + q = blocks.writeAt; m = q < blocks.readAt ? blocks.readAt - q - 1 : blocks.end - q; + + if (blocks.readAt != blocks.writeAt) + { + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + mode = END; + goto case END; + + case END: + r = ZlibConstants.Z_STREAM_END; + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + + case BADCODE: // x: got error + + r = ZlibConstants.Z_DATA_ERROR; + + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + + default: + r = ZlibConstants.Z_STREAM_ERROR; + + blocks.bitb = b; blocks.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + blocks.writeAt = q; + return blocks.Flush(r); + } + } + } + + + // Called with number of bytes left to write in window at least 258 + // (the maximum string length) and number of input bytes available + // at least ten. The ten bytes are six bytes for the longest length/ + // distance pair plus four bytes for overloading the bit buffer. + + internal int InflateFast(int bl, int bd, int[] tl, int tl_index, int[] td, int td_index, InflateBlocks s, ZlibCodec z) + { + int t; // temporary pointer + int[] tp; // temporary pointer + int tp_index; // temporary pointer + int e; // extra bits or operation + int b; // bit buffer + int k; // bits in bit buffer + int p; // input data pointer + int n; // bytes available there + int q; // output window write pointer + int m; // bytes to end of window or read pointer + int ml; // mask for literal/length tree + int md; // mask for distance tree + int c; // bytes to copy + int d; // distance back to copy from + int r; // copy source pointer + + int tp_index_t_3; // (tp_index+t)*3 + + // load input, output, bit values + p = z.NextIn; n = z.AvailableBytesIn; b = s.bitb; k = s.bitk; + q = s.writeAt; m = q < s.readAt ? s.readAt - q - 1 : s.end - q; + + // initialize masks + ml = InternalInflateConstants.InflateMask[bl]; + md = InternalInflateConstants.InflateMask[bd]; + + // do until not enough input or output space for fast loop + do + { + // assume called with m >= 258 && n >= 10 + // get literal/length code + while (k < (20)) + { + // max bits for literal/length code + n--; + b |= (z.InputBuffer[p++] & 0xff) << k; k += 8; + } + + t = b & ml; + tp = tl; + tp_index = tl_index; + tp_index_t_3 = (tp_index + t) * 3; + if ((e = tp[tp_index_t_3]) == 0) + { + b >>= (tp[tp_index_t_3 + 1]); k -= (tp[tp_index_t_3 + 1]); + + s.window[q++] = (byte)tp[tp_index_t_3 + 2]; + m--; + continue; + } + do + { + + b >>= (tp[tp_index_t_3 + 1]); k -= (tp[tp_index_t_3 + 1]); + + if ((e & 16) != 0) + { + e &= 15; + c = tp[tp_index_t_3 + 2] + ((int)b & InternalInflateConstants.InflateMask[e]); + + b >>= e; k -= e; + + // decode distance base of block to copy + while (k < 15) + { + // max bits for distance code + n--; + b |= (z.InputBuffer[p++] & 0xff) << k; k += 8; + } + + t = b & md; + tp = td; + tp_index = td_index; + tp_index_t_3 = (tp_index + t) * 3; + e = tp[tp_index_t_3]; + + do + { + + b >>= (tp[tp_index_t_3 + 1]); k -= (tp[tp_index_t_3 + 1]); + + if ((e & 16) != 0) + { + // get extra bits to add to distance base + e &= 15; + while (k < e) + { + // get extra bits (up to 13) + n--; + b |= (z.InputBuffer[p++] & 0xff) << k; k += 8; + } + + d = tp[tp_index_t_3 + 2] + (b & InternalInflateConstants.InflateMask[e]); + + b >>= e; k -= e; + + // do the copy + m -= c; + if (q >= d) + { + // offset before dest + // just copy + r = q - d; + if (q - r > 0 && 2 > (q - r)) + { + s.window[q++] = s.window[r++]; // minimum count is three, + s.window[q++] = s.window[r++]; // so unroll loop a little + c -= 2; + } + else + { + Array.Copy(s.window, r, s.window, q, 2); + q += 2; r += 2; c -= 2; + } + } + else + { + // else offset after destination + r = q - d; + do + { + r += s.end; // force pointer in window + } + while (r < 0); // covers invalid distances + e = s.end - r; + if (c > e) + { + // if source crosses, + c -= e; // wrapped copy + if (q - r > 0 && e > (q - r)) + { + do + { + s.window[q++] = s.window[r++]; + } + while (--e != 0); + } + else + { + Array.Copy(s.window, r, s.window, q, e); + q += e; r += e; e = 0; + } + r = 0; // copy rest from start of window + } + } + + // copy all or what's left + if (q - r > 0 && c > (q - r)) + { + do + { + s.window[q++] = s.window[r++]; + } + while (--c != 0); + } + else + { + Array.Copy(s.window, r, s.window, q, c); + q += c; r += c; c = 0; + } + break; + } + else if ((e & 64) == 0) + { + t += tp[tp_index_t_3 + 2]; + t += (b & InternalInflateConstants.InflateMask[e]); + tp_index_t_3 = (tp_index + t) * 3; + e = tp[tp_index_t_3]; + } + else + { + z.Message = "invalid distance code"; + + c = z.AvailableBytesIn - n; c = (k >> 3) < c ? k >> 3 : c; n += c; p -= c; k -= (c << 3); + + s.bitb = b; s.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + s.writeAt = q; + + return ZlibConstants.Z_DATA_ERROR; + } + } + while (true); + break; + } + + if ((e & 64) == 0) + { + t += tp[tp_index_t_3 + 2]; + t += (b & InternalInflateConstants.InflateMask[e]); + tp_index_t_3 = (tp_index + t) * 3; + if ((e = tp[tp_index_t_3]) == 0) + { + b >>= (tp[tp_index_t_3 + 1]); k -= (tp[tp_index_t_3 + 1]); + s.window[q++] = (byte)tp[tp_index_t_3 + 2]; + m--; + break; + } + } + else if ((e & 32) != 0) + { + c = z.AvailableBytesIn - n; c = (k >> 3) < c ? k >> 3 : c; n += c; p -= c; k -= (c << 3); + + s.bitb = b; s.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + s.writeAt = q; + + return ZlibConstants.Z_STREAM_END; + } + else + { + z.Message = "invalid literal/length code"; + + c = z.AvailableBytesIn - n; c = (k >> 3) < c ? k >> 3 : c; n += c; p -= c; k -= (c << 3); + + s.bitb = b; s.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + s.writeAt = q; + + return ZlibConstants.Z_DATA_ERROR; + } + } + while (true); + } + while (m >= 258 && n >= 10); + + // not enough input or output--restore pointers and return + c = z.AvailableBytesIn - n; c = (k >> 3) < c ? k >> 3 : c; n += c; p -= c; k -= (c << 3); + + s.bitb = b; s.bitk = k; + z.AvailableBytesIn = n; z.TotalBytesIn += p - z.NextIn; z.NextIn = p; + s.writeAt = q; + + return ZlibConstants.Z_OK; + } + } + + + internal sealed class InflateManager + { + // preset dictionary flag in zlib header + private const int PRESET_DICT = 0x20; + + private const int Z_DEFLATED = 8; + + private enum InflateManagerMode + { + METHOD = 0, // waiting for method byte + FLAG = 1, // waiting for flag byte + DICT4 = 2, // four dictionary check bytes to go + DICT3 = 3, // three dictionary check bytes to go + DICT2 = 4, // two dictionary check bytes to go + DICT1 = 5, // one dictionary check byte to go + DICT0 = 6, // waiting for inflateSetDictionary + BLOCKS = 7, // decompressing blocks + CHECK4 = 8, // four check bytes to go + CHECK3 = 9, // three check bytes to go + CHECK2 = 10, // two check bytes to go + CHECK1 = 11, // one check byte to go + DONE = 12, // finished check, done + BAD = 13, // got an error--stay here + } + + private InflateManagerMode mode; // current inflate mode + internal ZlibCodec _codec; // pointer back to this zlib stream + + // mode dependent information + internal int method; // if FLAGS, method byte + + // if CHECK, check values to compare + internal uint computedCheck; // computed check value + internal uint expectedCheck; // stream check value + + // if BAD, inflateSync's marker bytes count + internal int marker; + + // mode independent information + //internal int nowrap; // flag for no wrapper + private bool _handleRfc1950HeaderBytes = true; + internal bool HandleRfc1950HeaderBytes + { + get { return _handleRfc1950HeaderBytes; } + set { _handleRfc1950HeaderBytes = value; } + } + internal int wbits; // log2(window size) (8..15, defaults to 15) + + internal InflateBlocks blocks; // current inflate_blocks state + + public InflateManager() { } + + public InflateManager(bool expectRfc1950HeaderBytes) + { + _handleRfc1950HeaderBytes = expectRfc1950HeaderBytes; + } + + internal int Reset() + { + _codec.TotalBytesIn = _codec.TotalBytesOut = 0; + _codec.Message = null; + mode = HandleRfc1950HeaderBytes ? InflateManagerMode.METHOD : InflateManagerMode.BLOCKS; + blocks.Reset(); + return ZlibConstants.Z_OK; + } + + internal int End() + { + if (blocks != null) + blocks.Free(); + blocks = null; + return ZlibConstants.Z_OK; + } + + internal int Initialize(ZlibCodec codec, int w) + { + _codec = codec; + _codec.Message = null; + blocks = null; + + // handle undocumented nowrap option (no zlib header or check) + //nowrap = 0; + //if (w < 0) + //{ + // w = - w; + // nowrap = 1; + //} + + // set window size + if (w < 8 || w > 15) + { + End(); + throw new ZlibException("Bad window size."); + + //return ZlibConstants.Z_STREAM_ERROR; + } + wbits = w; + + blocks = new InflateBlocks(codec, + HandleRfc1950HeaderBytes ? this : null, + 1 << w); + + // reset state + Reset(); + return ZlibConstants.Z_OK; + } + + + internal int Inflate(FlushType flush) + { + int b; + + if (_codec.InputBuffer == null) + throw new ZlibException("InputBuffer is null. "); + +// int f = (flush == FlushType.Finish) +// ? ZlibConstants.Z_BUF_ERROR +// : ZlibConstants.Z_OK; + + // workitem 8870 + int f = ZlibConstants.Z_OK; + int r = ZlibConstants.Z_BUF_ERROR; + + while (true) + { + switch (mode) + { + case InflateManagerMode.METHOD: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + if (((method = _codec.InputBuffer[_codec.NextIn++]) & 0xf) != Z_DEFLATED) + { + mode = InflateManagerMode.BAD; + _codec.Message = String.Format("unknown compression method (0x{0:X2})", method); + marker = 5; // can't try inflateSync + break; + } + if ((method >> 4) + 8 > wbits) + { + mode = InflateManagerMode.BAD; + _codec.Message = String.Format("invalid window size ({0})", (method >> 4) + 8); + marker = 5; // can't try inflateSync + break; + } + mode = InflateManagerMode.FLAG; + break; + + + case InflateManagerMode.FLAG: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + b = (_codec.InputBuffer[_codec.NextIn++]) & 0xff; + + if ((((method << 8) + b) % 31) != 0) + { + mode = InflateManagerMode.BAD; + _codec.Message = "incorrect header check"; + marker = 5; // can't try inflateSync + break; + } + + mode = ((b & PRESET_DICT) == 0) + ? InflateManagerMode.BLOCKS + : InflateManagerMode.DICT4; + break; + + case InflateManagerMode.DICT4: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + expectedCheck = (uint)((_codec.InputBuffer[_codec.NextIn++] << 24) & 0xff000000); + mode = InflateManagerMode.DICT3; + break; + + case InflateManagerMode.DICT3: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + expectedCheck += (uint)((_codec.InputBuffer[_codec.NextIn++] << 16) & 0x00ff0000); + mode = InflateManagerMode.DICT2; + break; + + case InflateManagerMode.DICT2: + + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + expectedCheck += (uint)((_codec.InputBuffer[_codec.NextIn++] << 8) & 0x0000ff00); + mode = InflateManagerMode.DICT1; + break; + + + case InflateManagerMode.DICT1: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; _codec.TotalBytesIn++; + expectedCheck += (uint)(_codec.InputBuffer[_codec.NextIn++] & 0x000000ff); + _codec._Adler32 = expectedCheck; + mode = InflateManagerMode.DICT0; + return ZlibConstants.Z_NEED_DICT; + + + case InflateManagerMode.DICT0: + mode = InflateManagerMode.BAD; + _codec.Message = "need dictionary"; + marker = 0; // can try inflateSync + return ZlibConstants.Z_STREAM_ERROR; + + + case InflateManagerMode.BLOCKS: + r = blocks.Process(r); + if (r == ZlibConstants.Z_DATA_ERROR) + { + mode = InflateManagerMode.BAD; + marker = 0; // can try inflateSync + break; + } + + if (r == ZlibConstants.Z_OK) r = f; + + if (r != ZlibConstants.Z_STREAM_END) + return r; + + r = f; + computedCheck = blocks.Reset(); + if (!HandleRfc1950HeaderBytes) + { + mode = InflateManagerMode.DONE; + return ZlibConstants.Z_STREAM_END; + } + mode = InflateManagerMode.CHECK4; + break; + + case InflateManagerMode.CHECK4: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + expectedCheck = (uint)((_codec.InputBuffer[_codec.NextIn++] << 24) & 0xff000000); + mode = InflateManagerMode.CHECK3; + break; + + case InflateManagerMode.CHECK3: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; _codec.TotalBytesIn++; + expectedCheck += (uint)((_codec.InputBuffer[_codec.NextIn++] << 16) & 0x00ff0000); + mode = InflateManagerMode.CHECK2; + break; + + case InflateManagerMode.CHECK2: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; + _codec.TotalBytesIn++; + expectedCheck += (uint)((_codec.InputBuffer[_codec.NextIn++] << 8) & 0x0000ff00); + mode = InflateManagerMode.CHECK1; + break; + + case InflateManagerMode.CHECK1: + if (_codec.AvailableBytesIn == 0) return r; + r = f; + _codec.AvailableBytesIn--; _codec.TotalBytesIn++; + expectedCheck += (uint)(_codec.InputBuffer[_codec.NextIn++] & 0x000000ff); + if (computedCheck != expectedCheck) + { + mode = InflateManagerMode.BAD; + _codec.Message = "incorrect data check"; + marker = 5; // can't try inflateSync + break; + } + mode = InflateManagerMode.DONE; + return ZlibConstants.Z_STREAM_END; + + case InflateManagerMode.DONE: + return ZlibConstants.Z_STREAM_END; + + case InflateManagerMode.BAD: + throw new ZlibException(String.Format("Bad state ({0})", _codec.Message)); + + default: + throw new ZlibException("Stream error."); + + } + } + } + + + + internal int SetDictionary(byte[] dictionary) + { + int index = 0; + int length = dictionary.Length; + if (mode != InflateManagerMode.DICT0) + throw new ZlibException("Stream error."); + + if (Adler.Adler32(1, dictionary, 0, dictionary.Length) != _codec._Adler32) + { + return ZlibConstants.Z_DATA_ERROR; + } + + _codec._Adler32 = Adler.Adler32(0, null, 0, 0); + + if (length >= (1 << wbits)) + { + length = (1 << wbits) - 1; + index = dictionary.Length - length; + } + blocks.SetDictionary(dictionary, index, length); + mode = InflateManagerMode.BLOCKS; + return ZlibConstants.Z_OK; + } + + + private static readonly byte[] mark = new byte[] { 0, 0, 0xff, 0xff }; + + internal int Sync() + { + int n; // number of bytes to look at + int p; // pointer to bytes + int m; // number of marker bytes found in a row + long r, w; // temporaries to save total_in and total_out + + // set up + if (mode != InflateManagerMode.BAD) + { + mode = InflateManagerMode.BAD; + marker = 0; + } + if ((n = _codec.AvailableBytesIn) == 0) + return ZlibConstants.Z_BUF_ERROR; + p = _codec.NextIn; + m = marker; + + // search + while (n != 0 && m < 4) + { + if (_codec.InputBuffer[p] == mark[m]) + { + m++; + } + else if (_codec.InputBuffer[p] != 0) + { + m = 0; + } + else + { + m = 4 - m; + } + p++; n--; + } + + // restore + _codec.TotalBytesIn += p - _codec.NextIn; + _codec.NextIn = p; + _codec.AvailableBytesIn = n; + marker = m; + + // return no joy or set up to restart on a new block + if (m != 4) + { + return ZlibConstants.Z_DATA_ERROR; + } + r = _codec.TotalBytesIn; + w = _codec.TotalBytesOut; + Reset(); + _codec.TotalBytesIn = r; + _codec.TotalBytesOut = w; + mode = InflateManagerMode.BLOCKS; + return ZlibConstants.Z_OK; + } + + + // Returns true if inflate is currently at the end of a block generated + // by Z_SYNC_FLUSH or Z_FULL_FLUSH. This function is used by one PPP + // implementation to provide an additional safety check. PPP uses Z_SYNC_FLUSH + // but removes the length bytes of the resulting empty stored block. When + // decompressing, PPP checks that at the end of input packet, inflate is + // waiting for these length bytes. + internal int SyncPoint(ZlibCodec z) + { + return blocks.SyncPoint(); + } + } +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/ParallelDeflateOutputStream.cs b/Resources/Libraries/DotNetZip/Source/Zlib/ParallelDeflateOutputStream.cs new file mode 100644 index 00000000..8373983f --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/ParallelDeflateOutputStream.cs @@ -0,0 +1,1386 @@ +//#define Trace + +// ParallelDeflateOutputStream.cs +// ------------------------------------------------------------------ +// +// A DeflateStream that does compression only, it uses a +// divide-and-conquer approach with multiple threads to exploit multiple +// CPUs for the DEFLATE computation. +// +// last saved: <2011-July-31 14:49:40> +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 by Dino Chiesa +// All rights reserved! +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ + +using System; +using System.Collections.Generic; +using System.Threading; +using Ionic.Zlib; +using System.IO; + + +namespace Ionic.Zlib +{ + internal class WorkItem + { + public byte[] buffer; + public byte[] compressed; + public int crc; + public int index; + public int ordinal; + public int inputBytesAvailable; + public int compressedBytesAvailable; + public ZlibCodec compressor; + + public WorkItem(int size, + Ionic.Zlib.CompressionLevel compressLevel, + CompressionStrategy strategy, + int ix) + { + this.buffer= new byte[size]; + // alloc 5 bytes overhead for every block (margin of safety= 2) + int n = size + ((size / 32768)+1) * 5 * 2; + this.compressed = new byte[n]; + this.compressor = new ZlibCodec(); + this.compressor.InitializeDeflate(compressLevel, false); + this.compressor.OutputBuffer = this.compressed; + this.compressor.InputBuffer = this.buffer; + this.index = ix; + } + } + + /// + /// A class for compressing streams using the + /// Deflate algorithm with multiple threads. + /// + /// + /// + /// + /// This class performs DEFLATE compression through writing. For + /// more information on the Deflate algorithm, see IETF RFC 1951, + /// "DEFLATE Compressed Data Format Specification version 1.3." + /// + /// + /// + /// This class is similar to , except + /// that this class is for compression only, and this implementation uses an + /// approach that employs multiple worker threads to perform the DEFLATE. On + /// a multi-cpu or multi-core computer, the performance of this class can be + /// significantly higher than the single-threaded DeflateStream, particularly + /// for larger streams. How large? Anything over 10mb is a good candidate + /// for parallel compression. + /// + /// + /// + /// The tradeoff is that this class uses more memory and more CPU than the + /// vanilla DeflateStream, and also is less efficient as a compressor. For + /// large files the size of the compressed data stream can be less than 1% + /// larger than the size of a compressed data stream from the vanialla + /// DeflateStream. For smaller files the difference can be larger. The + /// difference will also be larger if you set the BufferSize to be lower than + /// the default value. Your mileage may vary. Finally, for small files, the + /// ParallelDeflateOutputStream can be much slower than the vanilla + /// DeflateStream, because of the overhead associated to using the thread + /// pool. + /// + /// + /// + /// + public class ParallelDeflateOutputStream : System.IO.Stream + { + + private static readonly int IO_BUFFER_SIZE_DEFAULT = 64 * 1024; // 128k + private static readonly int BufferPairsPerCore = 4; + + private System.Collections.Generic.List _pool; + private bool _leaveOpen; + private bool emitting; + private System.IO.Stream _outStream; + private int _maxBufferPairs; + private int _bufferSize = IO_BUFFER_SIZE_DEFAULT; + private AutoResetEvent _newlyCompressedBlob; + //private ManualResetEvent _writingDone; + //private ManualResetEvent _sessionReset; + private object _outputLock = new object(); + private bool _isClosed; + private bool _firstWriteDone; + private int _currentlyFilling; + private int _lastFilled; + private int _lastWritten; + private int _latestCompressed; + private int _Crc32; + private Ionic.Crc.CRC32 _runningCrc; + private object _latestLock = new object(); + private System.Collections.Generic.Queue _toWrite; + private System.Collections.Generic.Queue _toFill; + private Int64 _totalBytesProcessed; + private Ionic.Zlib.CompressionLevel _compressLevel; + private volatile Exception _pendingException; + private bool _handlingException; + private object _eLock = new Object(); // protects _pendingException + + // This bitfield is used only when Trace is defined. + //private TraceBits _DesiredTrace = TraceBits.Write | TraceBits.WriteBegin | + //TraceBits.WriteDone | TraceBits.Lifecycle | TraceBits.Fill | TraceBits.Flush | + //TraceBits.Session; + + //private TraceBits _DesiredTrace = TraceBits.WriteBegin | TraceBits.WriteDone | TraceBits.Synch | TraceBits.Lifecycle | TraceBits.Session ; + + private TraceBits _DesiredTrace = + TraceBits.Session | + TraceBits.Compress | + TraceBits.WriteTake | + TraceBits.WriteEnter | + TraceBits.EmitEnter | + TraceBits.EmitDone | + TraceBits.EmitLock | + TraceBits.EmitSkip | + TraceBits.EmitBegin; + + /// + /// Create a ParallelDeflateOutputStream. + /// + /// + /// + /// + /// This stream compresses data written into it via the DEFLATE + /// algorithm (see RFC 1951), and writes out the compressed byte stream. + /// + /// + /// + /// The instance will use the default compression level, the default + /// buffer sizes and the default number of threads and buffers per + /// thread. + /// + /// + /// + /// This class is similar to , + /// except that this implementation uses an approach that employs + /// multiple worker threads to perform the DEFLATE. On a multi-cpu or + /// multi-core computer, the performance of this class can be + /// significantly higher than the single-threaded DeflateStream, + /// particularly for larger streams. How large? Anything over 10mb is + /// a good candidate for parallel compression. + /// + /// + /// + /// + /// + /// + /// This example shows how to use a ParallelDeflateOutputStream to compress + /// data. It reads a file, compresses it, and writes the compressed data to + /// a second, output file. + /// + /// + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n= -1; + /// String outputFile = fileToCompress + ".compressed"; + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(outputFile)) + /// { + /// using (Stream compressor = new ParallelDeflateOutputStream(raw)) + /// { + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Dim outputFile As String = (fileToCompress & ".compressed") + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(outputFile) + /// Using compressor As Stream = New ParallelDeflateOutputStream(raw) + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// The stream to which compressed data will be written. + public ParallelDeflateOutputStream(System.IO.Stream stream) + : this(stream, CompressionLevel.Default, CompressionStrategy.Default, false) + { + } + + /// + /// Create a ParallelDeflateOutputStream using the specified CompressionLevel. + /// + /// + /// See the + /// constructor for example code. + /// + /// The stream to which compressed data will be written. + /// A tuning knob to trade speed for effectiveness. + public ParallelDeflateOutputStream(System.IO.Stream stream, CompressionLevel level) + : this(stream, level, CompressionStrategy.Default, false) + { + } + + /// + /// Create a ParallelDeflateOutputStream and specify whether to leave the captive stream open + /// when the ParallelDeflateOutputStream is closed. + /// + /// + /// See the + /// constructor for example code. + /// + /// The stream to which compressed data will be written. + /// + /// true if the application would like the stream to remain open after inflation/deflation. + /// + public ParallelDeflateOutputStream(System.IO.Stream stream, bool leaveOpen) + : this(stream, CompressionLevel.Default, CompressionStrategy.Default, leaveOpen) + { + } + + /// + /// Create a ParallelDeflateOutputStream and specify whether to leave the captive stream open + /// when the ParallelDeflateOutputStream is closed. + /// + /// + /// See the + /// constructor for example code. + /// + /// The stream to which compressed data will be written. + /// A tuning knob to trade speed for effectiveness. + /// + /// true if the application would like the stream to remain open after inflation/deflation. + /// + public ParallelDeflateOutputStream(System.IO.Stream stream, CompressionLevel level, bool leaveOpen) + : this(stream, CompressionLevel.Default, CompressionStrategy.Default, leaveOpen) + { + } + + /// + /// Create a ParallelDeflateOutputStream using the specified + /// CompressionLevel and CompressionStrategy, and specifying whether to + /// leave the captive stream open when the ParallelDeflateOutputStream is + /// closed. + /// + /// + /// See the + /// constructor for example code. + /// + /// The stream to which compressed data will be written. + /// A tuning knob to trade speed for effectiveness. + /// + /// By tweaking this parameter, you may be able to optimize the compression for + /// data with particular characteristics. + /// + /// + /// true if the application would like the stream to remain open after inflation/deflation. + /// + public ParallelDeflateOutputStream(System.IO.Stream stream, + CompressionLevel level, + CompressionStrategy strategy, + bool leaveOpen) + { + TraceOutput(TraceBits.Lifecycle | TraceBits.Session, "-------------------------------------------------------"); + TraceOutput(TraceBits.Lifecycle | TraceBits.Session, "Create {0:X8}", this.GetHashCode()); + _outStream = stream; + _compressLevel= level; + Strategy = strategy; + _leaveOpen = leaveOpen; + this.MaxBufferPairs = 16; // default + } + + + /// + /// The ZLIB strategy to be used during compression. + /// + /// + public CompressionStrategy Strategy + { + get; + private set; + } + + /// + /// The maximum number of buffer pairs to use. + /// + /// + /// + /// + /// This property sets an upper limit on the number of memory buffer + /// pairs to create. The implementation of this stream allocates + /// multiple buffers to facilitate parallel compression. As each buffer + /// fills up, this stream uses + /// ThreadPool.QueueUserWorkItem() + /// to compress those buffers in a background threadpool thread. After a + /// buffer is compressed, it is re-ordered and written to the output + /// stream. + /// + /// + /// + /// A higher number of buffer pairs enables a higher degree of + /// parallelism, which tends to increase the speed of compression on + /// multi-cpu computers. On the other hand, a higher number of buffer + /// pairs also implies a larger memory consumption, more active worker + /// threads, and a higher cpu utilization for any compression. This + /// property enables the application to limit its memory consumption and + /// CPU utilization behavior depending on requirements. + /// + /// + /// + /// For each compression "task" that occurs in parallel, there are 2 + /// buffers allocated: one for input and one for output. This property + /// sets a limit for the number of pairs. The total amount of storage + /// space allocated for buffering will then be (N*S*2), where N is the + /// number of buffer pairs, S is the size of each buffer (). By default, DotNetZip allocates 4 buffer + /// pairs per CPU core, so if your machine has 4 cores, and you retain + /// the default buffer size of 128k, then the + /// ParallelDeflateOutputStream will use 4 * 4 * 2 * 128kb of buffer + /// memory in total, or 4mb, in blocks of 128kb. If you then set this + /// property to 8, then the number will be 8 * 2 * 128kb of buffer + /// memory, or 2mb. + /// + /// + /// + /// CPU utilization will also go up with additional buffers, because a + /// larger number of buffer pairs allows a larger number of background + /// threads to compress in parallel. If you find that parallel + /// compression is consuming too much memory or CPU, you can adjust this + /// value downward. + /// + /// + /// + /// The default value is 16. Different values may deliver better or + /// worse results, depending on your priorities and the dynamic + /// performance characteristics of your storage and compute resources. + /// + /// + /// + /// This property is not the number of buffer pairs to use; it is an + /// upper limit. An illustration: Suppose you have an application that + /// uses the default value of this property (which is 16), and it runs + /// on a machine with 2 CPU cores. In that case, DotNetZip will allocate + /// 4 buffer pairs per CPU core, for a total of 8 pairs. The upper + /// limit specified by this property has no effect. + /// + /// + /// + /// The application can set this value at any time, but it is effective + /// only before the first call to Write(), which is when the buffers are + /// allocated. + /// + /// + public int MaxBufferPairs + { + get + { + return _maxBufferPairs; + } + set + { + if (value < 4) + throw new ArgumentException("MaxBufferPairs", + "Value must be 4 or greater."); + _maxBufferPairs = value; + } + } + + /// + /// The size of the buffers used by the compressor threads. + /// + /// + /// + /// + /// The default buffer size is 128k. The application can set this value + /// at any time, but it is effective only before the first Write(). + /// + /// + /// + /// Larger buffer sizes implies larger memory consumption but allows + /// more efficient compression. Using smaller buffer sizes consumes less + /// memory but may result in less effective compression. For example, + /// using the default buffer size of 128k, the compression delivered is + /// within 1% of the compression delivered by the single-threaded . On the other hand, using a + /// BufferSize of 8k can result in a compressed data stream that is 5% + /// larger than that delivered by the single-threaded + /// DeflateStream. Excessively small buffer sizes can also cause + /// the speed of the ParallelDeflateOutputStream to drop, because of + /// larger thread scheduling overhead dealing with many many small + /// buffers. + /// + /// + /// + /// The total amount of storage space allocated for buffering will be + /// (N*S*2), where N is the number of buffer pairs, and S is the size of + /// each buffer (this property). There are 2 buffers used by the + /// compressor, one for input and one for output. By default, DotNetZip + /// allocates 4 buffer pairs per CPU core, so if your machine has 4 + /// cores, then the number of buffer pairs used will be 16. If you + /// accept the default value of this property, 128k, then the + /// ParallelDeflateOutputStream will use 16 * 2 * 128kb of buffer memory + /// in total, or 4mb, in blocks of 128kb. If you set this property to + /// 64kb, then the number will be 16 * 2 * 64kb of buffer memory, or + /// 2mb. + /// + /// + /// + public int BufferSize + { + get { return _bufferSize;} + set + { + if (value < 1024) + throw new ArgumentOutOfRangeException("BufferSize", + "BufferSize must be greater than 1024 bytes"); + _bufferSize = value; + } + } + + /// + /// The CRC32 for the data that was written out, prior to compression. + /// + /// + /// This value is meaningful only after a call to Close(). + /// + public int Crc32 { get { return _Crc32; } } + + + /// + /// The total number of uncompressed bytes processed by the ParallelDeflateOutputStream. + /// + /// + /// This value is meaningful only after a call to Close(). + /// + public Int64 BytesProcessed { get { return _totalBytesProcessed; } } + + + private void _InitializePoolOfWorkItems() + { + _toWrite = new Queue(); + _toFill = new Queue(); + _pool = new System.Collections.Generic.List(); + int nTasks = BufferPairsPerCore * Environment.ProcessorCount; + nTasks = Math.Min(nTasks, _maxBufferPairs); + for(int i=0; i < nTasks; i++) + { + _pool.Add(new WorkItem(_bufferSize, _compressLevel, Strategy, i)); + _toFill.Enqueue(i); + } + + _newlyCompressedBlob = new AutoResetEvent(false); + _runningCrc = new Ionic.Crc.CRC32(); + _currentlyFilling = -1; + _lastFilled = -1; + _lastWritten = -1; + _latestCompressed = -1; + } + + + + + /// + /// Write data to the stream. + /// + /// + /// + /// + /// + /// To use the ParallelDeflateOutputStream to compress data, create a + /// ParallelDeflateOutputStream with CompressionMode.Compress, passing a + /// writable output stream. Then call Write() on that + /// ParallelDeflateOutputStream, providing uncompressed data as input. The + /// data sent to the output stream will be the compressed form of the data + /// written. + /// + /// + /// + /// To decompress data, use the class. + /// + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + bool mustWait = false; + + // This method does this: + // 0. handles any pending exceptions + // 1. write any buffers that are ready to be written, + // 2. fills a work buffer; when full, flip state to 'Filled', + // 3. if more data to be written, goto step 1 + + if (_isClosed) + throw new InvalidOperationException(); + + // dispense any exceptions that occurred on the BG threads + if (_pendingException != null) + { + _handlingException = true; + var pe = _pendingException; + _pendingException = null; + throw pe; + } + + if (count == 0) return; + + if (!_firstWriteDone) + { + // Want to do this on first Write, first session, and not in the + // constructor. We want to allow MaxBufferPairs to + // change after construction, but before first Write. + _InitializePoolOfWorkItems(); + _firstWriteDone = true; + } + + + do + { + // may need to make buffers available + EmitPendingBuffers(false, mustWait); + + mustWait = false; + // use current buffer, or get a new buffer to fill + int ix = -1; + if (_currentlyFilling >= 0) + { + ix = _currentlyFilling; + TraceOutput(TraceBits.WriteTake, + "Write notake wi({0}) lf({1})", + ix, + _lastFilled); + } + else + { + TraceOutput(TraceBits.WriteTake, "Write take?"); + if (_toFill.Count == 0) + { + // no available buffers, so... need to emit + // compressed buffers. + mustWait = true; + continue; + } + + ix = _toFill.Dequeue(); + TraceOutput(TraceBits.WriteTake, + "Write take wi({0}) lf({1})", + ix, + _lastFilled); + ++_lastFilled; // TODO: consider rollover? + } + + WorkItem workitem = _pool[ix]; + + int limit = ((workitem.buffer.Length - workitem.inputBytesAvailable) > count) + ? count + : (workitem.buffer.Length - workitem.inputBytesAvailable); + + workitem.ordinal = _lastFilled; + + TraceOutput(TraceBits.Write, + "Write lock wi({0}) ord({1}) iba({2})", + workitem.index, + workitem.ordinal, + workitem.inputBytesAvailable + ); + + // copy from the provided buffer to our workitem, starting at + // the tail end of whatever data we might have in there currently. + Buffer.BlockCopy(buffer, + offset, + workitem.buffer, + workitem.inputBytesAvailable, + limit); + + count -= limit; + offset += limit; + workitem.inputBytesAvailable += limit; + if (workitem.inputBytesAvailable == workitem.buffer.Length) + { + // No need for interlocked.increment: the Write() + // method is documented as not multi-thread safe, so + // we can assume Write() calls come in from only one + // thread. + TraceOutput(TraceBits.Write, + "Write QUWI wi({0}) ord({1}) iba({2}) nf({3})", + workitem.index, + workitem.ordinal, + workitem.inputBytesAvailable ); + + if (!ThreadPool.QueueUserWorkItem( _DeflateOne, workitem )) + throw new Exception("Cannot enqueue workitem"); + + _currentlyFilling = -1; // will get a new buffer next time + } + else + _currentlyFilling = ix; + + if (count > 0) + TraceOutput(TraceBits.WriteEnter, "Write more"); + } + while (count > 0); // until no more to write + + TraceOutput(TraceBits.WriteEnter, "Write exit"); + return; + } + + + + private void _FlushFinish() + { + // After writing a series of compressed buffers, each one closed + // with Flush.Sync, we now write the final one as Flush.Finish, + // and then stop. + byte[] buffer = new byte[128]; + var compressor = new ZlibCodec(); + int rc = compressor.InitializeDeflate(_compressLevel, false); + compressor.InputBuffer = null; + compressor.NextIn = 0; + compressor.AvailableBytesIn = 0; + compressor.OutputBuffer = buffer; + compressor.NextOut = 0; + compressor.AvailableBytesOut = buffer.Length; + rc = compressor.Deflate(FlushType.Finish); + + if (rc != ZlibConstants.Z_STREAM_END && rc != ZlibConstants.Z_OK) + throw new Exception("deflating: " + compressor.Message); + + if (buffer.Length - compressor.AvailableBytesOut > 0) + { + TraceOutput(TraceBits.EmitBegin, + "Emit begin flush bytes({0})", + buffer.Length - compressor.AvailableBytesOut); + + _outStream.Write(buffer, 0, buffer.Length - compressor.AvailableBytesOut); + + TraceOutput(TraceBits.EmitDone, + "Emit done flush"); + } + + compressor.EndDeflate(); + + _Crc32 = _runningCrc.Crc32Result; + } + + + private void _Flush(bool lastInput) + { + if (_isClosed) + throw new InvalidOperationException(); + + if (emitting) return; + + // compress any partial buffer + if (_currentlyFilling >= 0) + { + WorkItem workitem = _pool[_currentlyFilling]; + _DeflateOne(workitem); + _currentlyFilling = -1; // get a new buffer next Write() + } + + if (lastInput) + { + EmitPendingBuffers(true, false); + _FlushFinish(); + } + else + { + EmitPendingBuffers(false, false); + } + } + + + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (_pendingException != null) + { + _handlingException = true; + var pe = _pendingException; + _pendingException = null; + throw pe; + } + if (_handlingException) + return; + + _Flush(false); + } + + + /// + /// Close the stream. + /// + /// + /// You must call Close on the stream to guarantee that all of the data written in has + /// been compressed, and the compressed data has been written out. + /// + public override void Close() + { + TraceOutput(TraceBits.Session, "Close {0:X8}", this.GetHashCode()); + + if (_pendingException != null) + { + _handlingException = true; + var pe = _pendingException; + _pendingException = null; + throw pe; + } + + if (_handlingException) + return; + + if (_isClosed) return; + + _Flush(true); + + if (!_leaveOpen) + _outStream.Close(); + + _isClosed= true; + } + + + + // workitem 10030 - implement a new Dispose method + + /// Dispose the object + /// + /// + /// Because ParallelDeflateOutputStream is IDisposable, the + /// application must call this method when finished using the instance. + /// + /// + /// This method is generally called implicitly upon exit from + /// a using scope in C# (Using in VB). + /// + /// + new public void Dispose() + { + TraceOutput(TraceBits.Lifecycle, "Dispose {0:X8}", this.GetHashCode()); + Close(); + _pool = null; + Dispose(true); + } + + + + /// The Dispose method + /// + /// indicates whether the Dispose method was invoked by user code. + /// + protected override void Dispose(bool disposing) + { + base.Dispose(disposing); + } + + + /// + /// Resets the stream for use with another stream. + /// + /// + /// Because the ParallelDeflateOutputStream is expensive to create, it + /// has been designed so that it can be recycled and re-used. You have + /// to call Close() on the stream first, then you can call Reset() on + /// it, to use it again on another stream. + /// + /// + /// + /// The new output stream for this era. + /// + /// + /// + /// + /// ParallelDeflateOutputStream deflater = null; + /// foreach (var inputFile in listOfFiles) + /// { + /// string outputFile = inputFile + ".compressed"; + /// using (System.IO.Stream input = System.IO.File.OpenRead(inputFile)) + /// { + /// using (var outStream = System.IO.File.Create(outputFile)) + /// { + /// if (deflater == null) + /// deflater = new ParallelDeflateOutputStream(outStream, + /// CompressionLevel.Best, + /// CompressionStrategy.Default, + /// true); + /// deflater.Reset(outStream); + /// + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// deflater.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + public void Reset(Stream stream) + { + TraceOutput(TraceBits.Session, "-------------------------------------------------------"); + TraceOutput(TraceBits.Session, "Reset {0:X8} firstDone({1})", this.GetHashCode(), _firstWriteDone); + + if (!_firstWriteDone) return; + + // reset all status + _toWrite.Clear(); + _toFill.Clear(); + foreach (var workitem in _pool) + { + _toFill.Enqueue(workitem.index); + workitem.ordinal = -1; + } + + _firstWriteDone = false; + _totalBytesProcessed = 0L; + _runningCrc = new Ionic.Crc.CRC32(); + _isClosed= false; + _currentlyFilling = -1; + _lastFilled = -1; + _lastWritten = -1; + _latestCompressed = -1; + _outStream = stream; + } + + + + + private void EmitPendingBuffers(bool doAll, bool mustWait) + { + // When combining parallel deflation with a ZipSegmentedStream, it's + // possible for the ZSS to throw from within this method. In that + // case, Close/Dispose will be called on this stream, if this stream + // is employed within a using or try/finally pair as required. But + // this stream is unaware of the pending exception, so the Close() + // method invokes this method AGAIN. This can lead to a deadlock. + // Therefore, failfast if re-entering. + + if (emitting) return; + emitting = true; + if (doAll || mustWait) + _newlyCompressedBlob.WaitOne(); + + do + { + int firstSkip = -1; + int millisecondsToWait = doAll ? 200 : (mustWait ? -1 : 0); + int nextToWrite = -1; + + do + { + if (Monitor.TryEnter(_toWrite, millisecondsToWait)) + { + nextToWrite = -1; + try + { + if (_toWrite.Count > 0) + nextToWrite = _toWrite.Dequeue(); + } + finally + { + Monitor.Exit(_toWrite); + } + + if (nextToWrite >= 0) + { + WorkItem workitem = _pool[nextToWrite]; + if (workitem.ordinal != _lastWritten + 1) + { + // out of order. requeue and try again. + TraceOutput(TraceBits.EmitSkip, + "Emit skip wi({0}) ord({1}) lw({2}) fs({3})", + workitem.index, + workitem.ordinal, + _lastWritten, + firstSkip); + + lock(_toWrite) + { + _toWrite.Enqueue(nextToWrite); + } + + if (firstSkip == nextToWrite) + { + // We went around the list once. + // None of the items in the list is the one we want. + // Now wait for a compressor to signal again. + _newlyCompressedBlob.WaitOne(); + firstSkip = -1; + } + else if (firstSkip == -1) + firstSkip = nextToWrite; + + continue; + } + + firstSkip = -1; + + TraceOutput(TraceBits.EmitBegin, + "Emit begin wi({0}) ord({1}) cba({2})", + workitem.index, + workitem.ordinal, + workitem.compressedBytesAvailable); + + _outStream.Write(workitem.compressed, 0, workitem.compressedBytesAvailable); + _runningCrc.Combine(workitem.crc, workitem.inputBytesAvailable); + _totalBytesProcessed += workitem.inputBytesAvailable; + workitem.inputBytesAvailable = 0; + + TraceOutput(TraceBits.EmitDone, + "Emit done wi({0}) ord({1}) cba({2}) mtw({3})", + workitem.index, + workitem.ordinal, + workitem.compressedBytesAvailable, + millisecondsToWait); + + _lastWritten = workitem.ordinal; + _toFill.Enqueue(workitem.index); + + // don't wait next time through + if (millisecondsToWait == -1) millisecondsToWait = 0; + } + } + else + nextToWrite = -1; + + } while (nextToWrite >= 0); + + } while (doAll && (_lastWritten != _latestCompressed)); + + emitting = false; + } + + + +#if OLD + private void _PerpetualWriterMethod(object state) + { + TraceOutput(TraceBits.WriterThread, "_PerpetualWriterMethod START"); + + try + { + do + { + // wait for the next session + TraceOutput(TraceBits.Synch | TraceBits.WriterThread, "Synch _sessionReset.WaitOne(begin) PWM"); + _sessionReset.WaitOne(); + TraceOutput(TraceBits.Synch | TraceBits.WriterThread, "Synch _sessionReset.WaitOne(done) PWM"); + + if (_isDisposed) break; + + TraceOutput(TraceBits.Synch | TraceBits.WriterThread, "Synch _sessionReset.Reset() PWM"); + _sessionReset.Reset(); + + // repeatedly write buffers as they become ready + WorkItem workitem = null; + Ionic.Zlib.CRC32 c= new Ionic.Zlib.CRC32(); + do + { + workitem = _pool[_nextToWrite % _pc]; + lock(workitem) + { + if (_noMoreInputForThisSegment) + TraceOutput(TraceBits.Write, + "Write drain wi({0}) stat({1}) canuse({2}) cba({3})", + workitem.index, + workitem.status, + (workitem.status == (int)WorkItem.Status.Compressed), + workitem.compressedBytesAvailable); + + do + { + if (workitem.status == (int)WorkItem.Status.Compressed) + { + TraceOutput(TraceBits.WriteBegin, + "Write begin wi({0}) stat({1}) cba({2})", + workitem.index, + workitem.status, + workitem.compressedBytesAvailable); + + workitem.status = (int)WorkItem.Status.Writing; + _outStream.Write(workitem.compressed, 0, workitem.compressedBytesAvailable); + c.Combine(workitem.crc, workitem.inputBytesAvailable); + _totalBytesProcessed += workitem.inputBytesAvailable; + _nextToWrite++; + workitem.inputBytesAvailable= 0; + workitem.status = (int)WorkItem.Status.Done; + + TraceOutput(TraceBits.WriteDone, + "Write done wi({0}) stat({1}) cba({2})", + workitem.index, + workitem.status, + workitem.compressedBytesAvailable); + + + Monitor.Pulse(workitem); + break; + } + else + { + int wcycles = 0; + // I've locked a workitem I cannot use. + // Therefore, wake someone else up, and then release the lock. + while (workitem.status != (int)WorkItem.Status.Compressed) + { + TraceOutput(TraceBits.WriteWait, + "Write waiting wi({0}) stat({1}) nw({2}) nf({3}) nomore({4})", + workitem.index, + workitem.status, + _nextToWrite, _nextToFill, + _noMoreInputForThisSegment ); + + if (_noMoreInputForThisSegment && _nextToWrite == _nextToFill) + break; + + wcycles++; + + // wake up someone else + Monitor.Pulse(workitem); + // release and wait + Monitor.Wait(workitem); + + if (workitem.status == (int)WorkItem.Status.Compressed) + TraceOutput(TraceBits.WriteWait, + "Write A-OK wi({0}) stat({1}) iba({2}) cba({3}) cyc({4})", + workitem.index, + workitem.status, + workitem.inputBytesAvailable, + workitem.compressedBytesAvailable, + wcycles); + } + + if (_noMoreInputForThisSegment && _nextToWrite == _nextToFill) + break; + + } + } + while (true); + } + + if (_noMoreInputForThisSegment) + TraceOutput(TraceBits.Write, + "Write nomore nw({0}) nf({1}) break({2})", + _nextToWrite, _nextToFill, (_nextToWrite == _nextToFill)); + + if (_noMoreInputForThisSegment && _nextToWrite == _nextToFill) + break; + + } while (true); + + + // Finish: + // After writing a series of buffers, closing each one with + // Flush.Sync, we now write the final one as Flush.Finish, and + // then stop. + byte[] buffer = new byte[128]; + ZlibCodec compressor = new ZlibCodec(); + int rc = compressor.InitializeDeflate(_compressLevel, false); + compressor.InputBuffer = null; + compressor.NextIn = 0; + compressor.AvailableBytesIn = 0; + compressor.OutputBuffer = buffer; + compressor.NextOut = 0; + compressor.AvailableBytesOut = buffer.Length; + rc = compressor.Deflate(FlushType.Finish); + + if (rc != ZlibConstants.Z_STREAM_END && rc != ZlibConstants.Z_OK) + throw new Exception("deflating: " + compressor.Message); + + if (buffer.Length - compressor.AvailableBytesOut > 0) + { + TraceOutput(TraceBits.WriteBegin, + "Write begin flush bytes({0})", + buffer.Length - compressor.AvailableBytesOut); + + _outStream.Write(buffer, 0, buffer.Length - compressor.AvailableBytesOut); + + TraceOutput(TraceBits.WriteBegin, + "Write done flush"); + } + + compressor.EndDeflate(); + + _Crc32 = c.Crc32Result; + + // signal that writing is complete: + TraceOutput(TraceBits.Synch, "Synch _writingDone.Set() PWM"); + _writingDone.Set(); + } + while (true); + } + catch (System.Exception exc1) + { + lock(_eLock) + { + // expose the exception to the main thread + if (_pendingException!=null) + _pendingException = exc1; + } + } + + TraceOutput(TraceBits.WriterThread, "_PerpetualWriterMethod FINIS"); + } +#endif + + + + + private void _DeflateOne(Object wi) + { + // compress one buffer + WorkItem workitem = (WorkItem) wi; + try + { + int myItem = workitem.index; + Ionic.Crc.CRC32 crc = new Ionic.Crc.CRC32(); + + // calc CRC on the buffer + crc.SlurpBlock(workitem.buffer, 0, workitem.inputBytesAvailable); + + // deflate it + DeflateOneSegment(workitem); + + // update status + workitem.crc = crc.Crc32Result; + TraceOutput(TraceBits.Compress, + "Compress wi({0}) ord({1}) len({2})", + workitem.index, + workitem.ordinal, + workitem.compressedBytesAvailable + ); + + lock(_latestLock) + { + if (workitem.ordinal > _latestCompressed) + _latestCompressed = workitem.ordinal; + } + lock (_toWrite) + { + _toWrite.Enqueue(workitem.index); + } + _newlyCompressedBlob.Set(); + } + catch (System.Exception exc1) + { + lock(_eLock) + { + // expose the exception to the main thread + if (_pendingException!=null) + _pendingException = exc1; + } + } + } + + + + + private bool DeflateOneSegment(WorkItem workitem) + { + ZlibCodec compressor = workitem.compressor; + int rc= 0; + compressor.ResetDeflate(); + compressor.NextIn = 0; + + compressor.AvailableBytesIn = workitem.inputBytesAvailable; + + // step 1: deflate the buffer + compressor.NextOut = 0; + compressor.AvailableBytesOut = workitem.compressed.Length; + do + { + compressor.Deflate(FlushType.None); + } + while (compressor.AvailableBytesIn > 0 || compressor.AvailableBytesOut == 0); + + // step 2: flush (sync) + rc = compressor.Deflate(FlushType.Sync); + + workitem.compressedBytesAvailable= (int) compressor.TotalBytesOut; + return true; + } + + + [System.Diagnostics.ConditionalAttribute("Trace")] + private void TraceOutput(TraceBits bits, string format, params object[] varParams) + { + if ((bits & _DesiredTrace) != 0) + { + lock(_outputLock) + { + int tid = Thread.CurrentThread.GetHashCode(); +#if !SILVERLIGHT + Console.ForegroundColor = (ConsoleColor) (tid % 8 + 8); +#endif + Console.Write("{0:000} PDOS ", tid); + Console.WriteLine(format, varParams); +#if !SILVERLIGHT + Console.ResetColor(); +#endif + } + } + } + + + // used only when Trace is defined + [Flags] + enum TraceBits : uint + { + None = 0, + NotUsed1 = 1, + EmitLock = 2, + EmitEnter = 4, // enter _EmitPending + EmitBegin = 8, // begin to write out + EmitDone = 16, // done writing out + EmitSkip = 32, // writer skipping a workitem + EmitAll = 58, // All Emit flags + Flush = 64, + Lifecycle = 128, // constructor/disposer + Session = 256, // Close/Reset + Synch = 512, // thread synchronization + Instance = 1024, // instance settings + Compress = 2048, // compress task + Write = 4096, // filling buffers, when caller invokes Write() + WriteEnter = 8192, // upon entry to Write() + WriteTake = 16384, // on _toFill.Take() + All = 0xffffffff, + } + + + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + + /// + /// Indicates whether the stream supports Read operations. + /// + /// + /// Always returns false. + /// + public override bool CanRead + { + get {return false;} + } + + /// + /// Indicates whether the stream supports Write operations. + /// + /// + /// Returns true if the provided stream is writable. + /// + public override bool CanWrite + { + get { return _outStream.CanWrite; } + } + + /// + /// Reading this property always throws a NotSupportedException. + /// + public override long Length + { + get { throw new NotSupportedException(); } + } + + /// + /// Returns the current position of the output stream. + /// + /// + /// + /// Because the output gets written by a background thread, + /// the value may change asynchronously. Setting this + /// property always throws a NotSupportedException. + /// + /// + public override long Position + { + get { return _outStream.Position; } + set { throw new NotSupportedException(); } + } + + /// + /// This method always throws a NotSupportedException. + /// + /// + /// The buffer into which data would be read, IF THIS METHOD + /// ACTUALLY DID ANYTHING. + /// + /// + /// The offset within that data array at which to insert the + /// data that is read, IF THIS METHOD ACTUALLY DID + /// ANYTHING. + /// + /// + /// The number of bytes to write, IF THIS METHOD ACTUALLY DID + /// ANYTHING. + /// + /// nothing. + public override int Read(byte[] buffer, int offset, int count) + { + throw new NotSupportedException(); + } + + /// + /// This method always throws a NotSupportedException. + /// + /// + /// The offset to seek to.... + /// IF THIS METHOD ACTUALLY DID ANYTHING. + /// + /// + /// The reference specifying how to apply the offset.... IF + /// THIS METHOD ACTUALLY DID ANYTHING. + /// + /// nothing. It always throws. + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotSupportedException(); + } + + /// + /// This method always throws a NotSupportedException. + /// + /// + /// The new value for the stream length.... IF + /// THIS METHOD ACTUALLY DID ANYTHING. + /// + public override void SetLength(long value) + { + throw new NotSupportedException(); + } + + } + +} + + diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/Tree.cs b/Resources/Libraries/DotNetZip/Source/Zlib/Tree.cs new file mode 100644 index 00000000..954872aa --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/Tree.cs @@ -0,0 +1,423 @@ +// Tree.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-October-28 13:29:50> +// +// ------------------------------------------------------------------ +// +// This module defines classes for zlib compression and +// decompression. This code is derived from the jzlib implementation of +// zlib. In keeping with the license for jzlib, the copyright to that +// code is below. +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// This program is based on zlib-1.1.3; credit to authors +// Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) +// and contributors of zlib. +// +// ----------------------------------------------------------------------- + + +using System; + +namespace Ionic.Zlib +{ + sealed class Tree + { + private static readonly int HEAP_SIZE = (2 * InternalConstants.L_CODES + 1); + + // extra bits for each length code + internal static readonly int[] ExtraLengthBits = new int[] + { + 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, + 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0 + }; + + // extra bits for each distance code + internal static readonly int[] ExtraDistanceBits = new int[] + { + 0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, + 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13 + }; + + // extra bits for each bit length code + internal static readonly int[] extra_blbits = new int[]{0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7}; + + internal static readonly sbyte[] bl_order = new sbyte[]{16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; + + + // The lengths of the bit length codes are sent in order of decreasing + // probability, to avoid transmitting the lengths for unused bit + // length codes. + + internal const int Buf_size = 8 * 2; + + // see definition of array dist_code below + //internal const int DIST_CODE_LEN = 512; + + private static readonly sbyte[] _dist_code = new sbyte[] + { + 0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, + 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, + 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, + 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, + 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, + 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, + 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, + 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, + 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, + 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, + 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, + 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, + 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, + 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, + 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, + 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, + 0, 0, 16, 17, 18, 18, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, + 22, 22, 22, 22, 22, 22, 22, 22, 23, 23, 23, 23, 23, 23, 23, 23, + 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, + 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, + 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, + 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, + 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, + 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, + 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, + 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, + 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, + 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, + 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, + 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, + 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, + 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29 + }; + + internal static readonly sbyte[] LengthCode = new sbyte[] + { + 0, 1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 9, 10, 10, 11, 11, + 12, 12, 12, 12, 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, + 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, + 18, 18, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19, 19, 19, 19, 19, + 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, + 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, + 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, + 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, + 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, + 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, + 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, + 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, 25, + 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, + 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, + 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, + 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 28 + }; + + + internal static readonly int[] LengthBase = new int[] + { + 0, 1, 2, 3, 4, 5, 6, 7, 8, 10, 12, 14, 16, 20, 24, 28, + 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 0 + }; + + + internal static readonly int[] DistanceBase = new int[] + { + 0, 1, 2, 3, 4, 6, 8, 12, 16, 24, 32, 48, 64, 96, 128, 192, + 256, 384, 512, 768, 1024, 1536, 2048, 3072, 4096, 6144, 8192, 12288, 16384, 24576 + }; + + + /// + /// Map from a distance to a distance code. + /// + /// + /// No side effects. _dist_code[256] and _dist_code[257] are never used. + /// + internal static int DistanceCode(int dist) + { + return (dist < 256) + ? _dist_code[dist] + : _dist_code[256 + SharedUtils.URShift(dist, 7)]; + } + + internal short[] dyn_tree; // the dynamic tree + internal int max_code; // largest code with non zero frequency + internal StaticTree staticTree; // the corresponding static tree + + // Compute the optimal bit lengths for a tree and update the total bit length + // for the current block. + // IN assertion: the fields freq and dad are set, heap[heap_max] and + // above are the tree nodes sorted by increasing frequency. + // OUT assertions: the field len is set to the optimal bit length, the + // array bl_count contains the frequencies for each bit length. + // The length opt_len is updated; static_len is also updated if stree is + // not null. + internal void gen_bitlen(DeflateManager s) + { + short[] tree = dyn_tree; + short[] stree = staticTree.treeCodes; + int[] extra = staticTree.extraBits; + int base_Renamed = staticTree.extraBase; + int max_length = staticTree.maxLength; + int h; // heap index + int n, m; // iterate over the tree elements + int bits; // bit length + int xbits; // extra bits + short f; // frequency + int overflow = 0; // number of elements with bit length too large + + for (bits = 0; bits <= InternalConstants.MAX_BITS; bits++) + s.bl_count[bits] = 0; + + // In a first pass, compute the optimal bit lengths (which may + // overflow in the case of the bit length tree). + tree[s.heap[s.heap_max] * 2 + 1] = 0; // root of the heap + + for (h = s.heap_max + 1; h < HEAP_SIZE; h++) + { + n = s.heap[h]; + bits = tree[tree[n * 2 + 1] * 2 + 1] + 1; + if (bits > max_length) + { + bits = max_length; overflow++; + } + tree[n * 2 + 1] = (short) bits; + // We overwrite tree[n*2+1] which is no longer needed + + if (n > max_code) + continue; // not a leaf node + + s.bl_count[bits]++; + xbits = 0; + if (n >= base_Renamed) + xbits = extra[n - base_Renamed]; + f = tree[n * 2]; + s.opt_len += f * (bits + xbits); + if (stree != null) + s.static_len += f * (stree[n * 2 + 1] + xbits); + } + if (overflow == 0) + return ; + + // This happens for example on obj2 and pic of the Calgary corpus + // Find the first bit length which could increase: + do + { + bits = max_length - 1; + while (s.bl_count[bits] == 0) + bits--; + s.bl_count[bits]--; // move one leaf down the tree + s.bl_count[bits + 1] = (short) (s.bl_count[bits + 1] + 2); // move one overflow item as its brother + s.bl_count[max_length]--; + // The brother of the overflow item also moves one step up, + // but this does not affect bl_count[max_length] + overflow -= 2; + } + while (overflow > 0); + + for (bits = max_length; bits != 0; bits--) + { + n = s.bl_count[bits]; + while (n != 0) + { + m = s.heap[--h]; + if (m > max_code) + continue; + if (tree[m * 2 + 1] != bits) + { + s.opt_len = (int) (s.opt_len + ((long) bits - (long) tree[m * 2 + 1]) * (long) tree[m * 2]); + tree[m * 2 + 1] = (short) bits; + } + n--; + } + } + } + + // Construct one Huffman tree and assigns the code bit strings and lengths. + // Update the total bit length for the current block. + // IN assertion: the field freq is set for all tree elements. + // OUT assertions: the fields len and code are set to the optimal bit length + // and corresponding code. The length opt_len is updated; static_len is + // also updated if stree is not null. The field max_code is set. + internal void build_tree(DeflateManager s) + { + short[] tree = dyn_tree; + short[] stree = staticTree.treeCodes; + int elems = staticTree.elems; + int n, m; // iterate over heap elements + int max_code = -1; // largest code with non zero frequency + int node; // new node being created + + // Construct the initial heap, with least frequent element in + // heap[1]. The sons of heap[n] are heap[2*n] and heap[2*n+1]. + // heap[0] is not used. + s.heap_len = 0; + s.heap_max = HEAP_SIZE; + + for (n = 0; n < elems; n++) + { + if (tree[n * 2] != 0) + { + s.heap[++s.heap_len] = max_code = n; + s.depth[n] = 0; + } + else + { + tree[n * 2 + 1] = 0; + } + } + + // The pkzip format requires that at least one distance code exists, + // and that at least one bit should be sent even if there is only one + // possible code. So to avoid special checks later on we force at least + // two codes of non zero frequency. + while (s.heap_len < 2) + { + node = s.heap[++s.heap_len] = (max_code < 2?++max_code:0); + tree[node * 2] = 1; + s.depth[node] = 0; + s.opt_len--; + if (stree != null) + s.static_len -= stree[node * 2 + 1]; + // node is 0 or 1 so it does not have extra bits + } + this.max_code = max_code; + + // The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree, + // establish sub-heaps of increasing lengths: + + for (n = s.heap_len / 2; n >= 1; n--) + s.pqdownheap(tree, n); + + // Construct the Huffman tree by repeatedly combining the least two + // frequent nodes. + + node = elems; // next internal node of the tree + do + { + // n = node of least frequency + n = s.heap[1]; + s.heap[1] = s.heap[s.heap_len--]; + s.pqdownheap(tree, 1); + m = s.heap[1]; // m = node of next least frequency + + s.heap[--s.heap_max] = n; // keep the nodes sorted by frequency + s.heap[--s.heap_max] = m; + + // Create a new node father of n and m + tree[node * 2] = unchecked((short) (tree[n * 2] + tree[m * 2])); + s.depth[node] = (sbyte) (System.Math.Max((byte) s.depth[n], (byte) s.depth[m]) + 1); + tree[n * 2 + 1] = tree[m * 2 + 1] = (short) node; + + // and insert the new node in the heap + s.heap[1] = node++; + s.pqdownheap(tree, 1); + } + while (s.heap_len >= 2); + + s.heap[--s.heap_max] = s.heap[1]; + + // At this point, the fields freq and dad are set. We can now + // generate the bit lengths. + + gen_bitlen(s); + + // The field len is now set, we can generate the bit codes + gen_codes(tree, max_code, s.bl_count); + } + + // Generate the codes for a given tree and bit counts (which need not be + // optimal). + // IN assertion: the array bl_count contains the bit length statistics for + // the given tree and the field len is set for all tree elements. + // OUT assertion: the field code is set for all tree elements of non + // zero code length. + internal static void gen_codes(short[] tree, int max_code, short[] bl_count) + { + short[] next_code = new short[InternalConstants.MAX_BITS + 1]; // next code value for each bit length + short code = 0; // running code value + int bits; // bit index + int n; // code index + + // The distribution counts are first used to generate the code values + // without bit reversal. + for (bits = 1; bits <= InternalConstants.MAX_BITS; bits++) + unchecked { + next_code[bits] = code = (short) ((code + bl_count[bits - 1]) << 1); + } + + // Check that the bit counts in bl_count are consistent. The last code + // must be all ones. + //Assert (code + bl_count[MAX_BITS]-1 == (1<>= 1; //SharedUtils.URShift(code, 1); + res <<= 1; + } + while (--len > 0); + return res >> 1; + } + } +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/Zlib.cs b/Resources/Libraries/DotNetZip/Source/Zlib/Zlib.cs new file mode 100644 index 00000000..6c51b1aa --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/Zlib.cs @@ -0,0 +1,546 @@ +// Zlib.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009-2011 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// Last Saved: <2011-August-03 19:52:28> +// +// ------------------------------------------------------------------ +// +// This module defines classes for ZLIB compression and +// decompression. This code is derived from the jzlib implementation of +// zlib, but significantly modified. The object model is not the same, +// and many of the behaviors are new or different. Nonetheless, in +// keeping with the license for jzlib, the copyright to that code is +// included below. +// +// ------------------------------------------------------------------ +// +// The following notice applies to jzlib: +// +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// jzlib is based on zlib-1.1.3. +// +// The following notice applies to zlib: +// +// ----------------------------------------------------------------------- +// +// Copyright (C) 1995-2004 Jean-loup Gailly and Mark Adler +// +// The ZLIB software is provided 'as-is', without any express or implied +// warranty. In no event will the authors be held liable for any damages +// arising from the use of this software. +// +// Permission is granted to anyone to use this software for any purpose, +// including commercial applications, and to alter it and redistribute it +// freely, subject to the following restrictions: +// +// 1. The origin of this software must not be misrepresented; you must not +// claim that you wrote the original software. If you use this software +// in a product, an acknowledgment in the product documentation would be +// appreciated but is not required. +// 2. Altered source versions must be plainly marked as such, and must not be +// misrepresented as being the original software. +// 3. This notice may not be removed or altered from any source distribution. +// +// Jean-loup Gailly jloup@gzip.org +// Mark Adler madler@alumni.caltech.edu +// +// ----------------------------------------------------------------------- + + + +using System; +using Interop=System.Runtime.InteropServices; + +namespace Ionic.Zlib +{ + + /// + /// Describes how to flush the current deflate operation. + /// + /// + /// The different FlushType values are useful when using a Deflate in a streaming application. + /// + public enum FlushType + { + /// No flush at all. + None = 0, + + /// Closes the current block, but doesn't flush it to + /// the output. Used internally only in hypothetical + /// scenarios. This was supposed to be removed by Zlib, but it is + /// still in use in some edge cases. + /// + Partial, + + /// + /// Use this during compression to specify that all pending output should be + /// flushed to the output buffer and the output should be aligned on a byte + /// boundary. You might use this in a streaming communication scenario, so that + /// the decompressor can get all input data available so far. When using this + /// with a ZlibCodec, AvailableBytesIn will be zero after the call if + /// enough output space has been provided before the call. Flushing will + /// degrade compression and so it should be used only when necessary. + /// + Sync, + + /// + /// Use this during compression to specify that all output should be flushed, as + /// with FlushType.Sync, but also, the compression state should be reset + /// so that decompression can restart from this point if previous compressed + /// data has been damaged or if random access is desired. Using + /// FlushType.Full too often can significantly degrade the compression. + /// + Full, + + /// Signals the end of the compression/decompression stream. + Finish, + } + + + /// + /// The compression level to be used when using a DeflateStream or ZlibStream with CompressionMode.Compress. + /// + public enum CompressionLevel + { + /// + /// None means that the data will be simply stored, with no change at all. + /// If you are producing ZIPs for use on Mac OSX, be aware that archives produced with CompressionLevel.None + /// cannot be opened with the default zip reader. Use a different CompressionLevel. + /// + None= 0, + /// + /// Same as None. + /// + Level0 = 0, + + /// + /// The fastest but least effective compression. + /// + BestSpeed = 1, + + /// + /// A synonym for BestSpeed. + /// + Level1 = 1, + + /// + /// A little slower, but better, than level 1. + /// + Level2 = 2, + + /// + /// A little slower, but better, than level 2. + /// + Level3 = 3, + + /// + /// A little slower, but better, than level 3. + /// + Level4 = 4, + + /// + /// A little slower than level 4, but with better compression. + /// + Level5 = 5, + + /// + /// The default compression level, with a good balance of speed and compression efficiency. + /// + Default = 6, + /// + /// A synonym for Default. + /// + Level6 = 6, + + /// + /// Pretty good compression! + /// + Level7 = 7, + + /// + /// Better compression than Level7! + /// + Level8 = 8, + + /// + /// The "best" compression, where best means greatest reduction in size of the input data stream. + /// This is also the slowest compression. + /// + BestCompression = 9, + + /// + /// A synonym for BestCompression. + /// + Level9 = 9, + } + + /// + /// Describes options for how the compression algorithm is executed. Different strategies + /// work better on different sorts of data. The strategy parameter can affect the compression + /// ratio and the speed of compression but not the correctness of the compresssion. + /// + public enum CompressionStrategy + { + /// + /// The default strategy is probably the best for normal data. + /// + Default = 0, + + /// + /// The Filtered strategy is intended to be used most effectively with data produced by a + /// filter or predictor. By this definition, filtered data consists mostly of small + /// values with a somewhat random distribution. In this case, the compression algorithm + /// is tuned to compress them better. The effect of Filtered is to force more Huffman + /// coding and less string matching; it is a half-step between Default and HuffmanOnly. + /// + Filtered = 1, + + /// + /// Using HuffmanOnly will force the compressor to do Huffman encoding only, with no + /// string matching. + /// + HuffmanOnly = 2, + } + + + /// + /// An enum to specify the direction of transcoding - whether to compress or decompress. + /// + public enum CompressionMode + { + /// + /// Used to specify that the stream should compress the data. + /// + Compress= 0, + /// + /// Used to specify that the stream should decompress the data. + /// + Decompress = 1, + } + + + /// + /// A general purpose exception class for exceptions in the Zlib library. + /// + [Interop.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d0000E")] + public class ZlibException : System.Exception + { + /// + /// The ZlibException class captures exception information generated + /// by the Zlib library. + /// + public ZlibException() + : base() + { + } + + /// + /// This ctor collects a message attached to the exception. + /// + /// the message for the exception. + public ZlibException(System.String s) + : base(s) + { + } + } + + + internal class SharedUtils + { + /// + /// Performs an unsigned bitwise right shift with the specified number + /// + /// Number to operate on + /// Ammount of bits to shift + /// The resulting number from the shift operation + public static int URShift(int number, int bits) + { + return (int)((uint)number >> bits); + } + +#if NOT + /// + /// Performs an unsigned bitwise right shift with the specified number + /// + /// Number to operate on + /// Ammount of bits to shift + /// The resulting number from the shift operation + public static long URShift(long number, int bits) + { + return (long) ((UInt64)number >> bits); + } +#endif + + /// + /// Reads a number of characters from the current source TextReader and writes + /// the data to the target array at the specified index. + /// + /// + /// The source TextReader to read from + /// Contains the array of characteres read from the source TextReader. + /// The starting index of the target array. + /// The maximum number of characters to read from the source TextReader. + /// + /// + /// The number of characters read. The number will be less than or equal to + /// count depending on the data available in the source TextReader. Returns -1 + /// if the end of the stream is reached. + /// + public static System.Int32 ReadInput(System.IO.TextReader sourceTextReader, byte[] target, int start, int count) + { + // Returns 0 bytes if not enough space in target + if (target.Length == 0) return 0; + + char[] charArray = new char[target.Length]; + int bytesRead = sourceTextReader.Read(charArray, start, count); + + // Returns -1 if EOF + if (bytesRead == 0) return -1; + + for (int index = start; index < start + bytesRead; index++) + target[index] = (byte)charArray[index]; + + return bytesRead; + } + + + internal static byte[] ToByteArray(System.String sourceString) + { + return System.Text.UTF8Encoding.UTF8.GetBytes(sourceString); + } + + + internal static char[] ToCharArray(byte[] byteArray) + { + return System.Text.UTF8Encoding.UTF8.GetChars(byteArray); + } + } + + internal static class InternalConstants + { + internal static readonly int MAX_BITS = 15; + internal static readonly int BL_CODES = 19; + internal static readonly int D_CODES = 30; + internal static readonly int LITERALS = 256; + internal static readonly int LENGTH_CODES = 29; + internal static readonly int L_CODES = (LITERALS + 1 + LENGTH_CODES); + + // Bit length codes must not exceed MAX_BL_BITS bits + internal static readonly int MAX_BL_BITS = 7; + + // repeat previous bit length 3-6 times (2 bits of repeat count) + internal static readonly int REP_3_6 = 16; + + // repeat a zero length 3-10 times (3 bits of repeat count) + internal static readonly int REPZ_3_10 = 17; + + // repeat a zero length 11-138 times (7 bits of repeat count) + internal static readonly int REPZ_11_138 = 18; + + } + + internal sealed class StaticTree + { + internal static readonly short[] lengthAndLiteralsTreeCodes = new short[] { + 12, 8, 140, 8, 76, 8, 204, 8, 44, 8, 172, 8, 108, 8, 236, 8, + 28, 8, 156, 8, 92, 8, 220, 8, 60, 8, 188, 8, 124, 8, 252, 8, + 2, 8, 130, 8, 66, 8, 194, 8, 34, 8, 162, 8, 98, 8, 226, 8, + 18, 8, 146, 8, 82, 8, 210, 8, 50, 8, 178, 8, 114, 8, 242, 8, + 10, 8, 138, 8, 74, 8, 202, 8, 42, 8, 170, 8, 106, 8, 234, 8, + 26, 8, 154, 8, 90, 8, 218, 8, 58, 8, 186, 8, 122, 8, 250, 8, + 6, 8, 134, 8, 70, 8, 198, 8, 38, 8, 166, 8, 102, 8, 230, 8, + 22, 8, 150, 8, 86, 8, 214, 8, 54, 8, 182, 8, 118, 8, 246, 8, + 14, 8, 142, 8, 78, 8, 206, 8, 46, 8, 174, 8, 110, 8, 238, 8, + 30, 8, 158, 8, 94, 8, 222, 8, 62, 8, 190, 8, 126, 8, 254, 8, + 1, 8, 129, 8, 65, 8, 193, 8, 33, 8, 161, 8, 97, 8, 225, 8, + 17, 8, 145, 8, 81, 8, 209, 8, 49, 8, 177, 8, 113, 8, 241, 8, + 9, 8, 137, 8, 73, 8, 201, 8, 41, 8, 169, 8, 105, 8, 233, 8, + 25, 8, 153, 8, 89, 8, 217, 8, 57, 8, 185, 8, 121, 8, 249, 8, + 5, 8, 133, 8, 69, 8, 197, 8, 37, 8, 165, 8, 101, 8, 229, 8, + 21, 8, 149, 8, 85, 8, 213, 8, 53, 8, 181, 8, 117, 8, 245, 8, + 13, 8, 141, 8, 77, 8, 205, 8, 45, 8, 173, 8, 109, 8, 237, 8, + 29, 8, 157, 8, 93, 8, 221, 8, 61, 8, 189, 8, 125, 8, 253, 8, + 19, 9, 275, 9, 147, 9, 403, 9, 83, 9, 339, 9, 211, 9, 467, 9, + 51, 9, 307, 9, 179, 9, 435, 9, 115, 9, 371, 9, 243, 9, 499, 9, + 11, 9, 267, 9, 139, 9, 395, 9, 75, 9, 331, 9, 203, 9, 459, 9, + 43, 9, 299, 9, 171, 9, 427, 9, 107, 9, 363, 9, 235, 9, 491, 9, + 27, 9, 283, 9, 155, 9, 411, 9, 91, 9, 347, 9, 219, 9, 475, 9, + 59, 9, 315, 9, 187, 9, 443, 9, 123, 9, 379, 9, 251, 9, 507, 9, + 7, 9, 263, 9, 135, 9, 391, 9, 71, 9, 327, 9, 199, 9, 455, 9, + 39, 9, 295, 9, 167, 9, 423, 9, 103, 9, 359, 9, 231, 9, 487, 9, + 23, 9, 279, 9, 151, 9, 407, 9, 87, 9, 343, 9, 215, 9, 471, 9, + 55, 9, 311, 9, 183, 9, 439, 9, 119, 9, 375, 9, 247, 9, 503, 9, + 15, 9, 271, 9, 143, 9, 399, 9, 79, 9, 335, 9, 207, 9, 463, 9, + 47, 9, 303, 9, 175, 9, 431, 9, 111, 9, 367, 9, 239, 9, 495, 9, + 31, 9, 287, 9, 159, 9, 415, 9, 95, 9, 351, 9, 223, 9, 479, 9, + 63, 9, 319, 9, 191, 9, 447, 9, 127, 9, 383, 9, 255, 9, 511, 9, + 0, 7, 64, 7, 32, 7, 96, 7, 16, 7, 80, 7, 48, 7, 112, 7, + 8, 7, 72, 7, 40, 7, 104, 7, 24, 7, 88, 7, 56, 7, 120, 7, + 4, 7, 68, 7, 36, 7, 100, 7, 20, 7, 84, 7, 52, 7, 116, 7, + 3, 8, 131, 8, 67, 8, 195, 8, 35, 8, 163, 8, 99, 8, 227, 8 + }; + + internal static readonly short[] distTreeCodes = new short[] { + 0, 5, 16, 5, 8, 5, 24, 5, 4, 5, 20, 5, 12, 5, 28, 5, + 2, 5, 18, 5, 10, 5, 26, 5, 6, 5, 22, 5, 14, 5, 30, 5, + 1, 5, 17, 5, 9, 5, 25, 5, 5, 5, 21, 5, 13, 5, 29, 5, + 3, 5, 19, 5, 11, 5, 27, 5, 7, 5, 23, 5 }; + + internal static readonly StaticTree Literals; + internal static readonly StaticTree Distances; + internal static readonly StaticTree BitLengths; + + internal short[] treeCodes; // static tree or null + internal int[] extraBits; // extra bits for each code or null + internal int extraBase; // base index for extra_bits + internal int elems; // max number of elements in the tree + internal int maxLength; // max bit length for the codes + + private StaticTree(short[] treeCodes, int[] extraBits, int extraBase, int elems, int maxLength) + { + this.treeCodes = treeCodes; + this.extraBits = extraBits; + this.extraBase = extraBase; + this.elems = elems; + this.maxLength = maxLength; + } + static StaticTree() + { + Literals = new StaticTree(lengthAndLiteralsTreeCodes, Tree.ExtraLengthBits, InternalConstants.LITERALS + 1, InternalConstants.L_CODES, InternalConstants.MAX_BITS); + Distances = new StaticTree(distTreeCodes, Tree.ExtraDistanceBits, 0, InternalConstants.D_CODES, InternalConstants.MAX_BITS); + BitLengths = new StaticTree(null, Tree.extra_blbits, 0, InternalConstants.BL_CODES, InternalConstants.MAX_BL_BITS); + } + } + + + + /// + /// Computes an Adler-32 checksum. + /// + /// + /// The Adler checksum is similar to a CRC checksum, but faster to compute, though less + /// reliable. It is used in producing RFC1950 compressed streams. The Adler checksum + /// is a required part of the "ZLIB" standard. Applications will almost never need to + /// use this class directly. + /// + /// + /// + public sealed class Adler + { + // largest prime smaller than 65536 + private static readonly uint BASE = 65521; + // NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 + private static readonly int NMAX = 5552; + + +#pragma warning disable 3001 +#pragma warning disable 3002 + + /// + /// Calculates the Adler32 checksum. + /// + /// + /// + /// This is used within ZLIB. You probably don't need to use this directly. + /// + /// + /// + /// To compute an Adler32 checksum on a byte array: + /// + /// var adler = Adler.Adler32(0, null, 0, 0); + /// adler = Adler.Adler32(adler, buffer, index, length); + /// + /// + public static uint Adler32(uint adler, byte[] buf, int index, int len) + { + if (buf == null) + return 1; + + uint s1 = (uint) (adler & 0xffff); + uint s2 = (uint) ((adler >> 16) & 0xffff); + + while (len > 0) + { + int k = len < NMAX ? len : NMAX; + len -= k; + while (k >= 16) + { + //s1 += (buf[index++] & 0xff); s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + s1 += buf[index++]; s2 += s1; + k -= 16; + } + if (k != 0) + { + do + { + s1 += buf[index++]; + s2 += s1; + } + while (--k != 0); + } + s1 %= BASE; + s2 %= BASE; + } + return (uint)((s2 << 16) | s1); + } +#pragma warning restore 3001 +#pragma warning restore 3002 + + } + +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/ZlibBaseStream.cs b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibBaseStream.cs new file mode 100644 index 00000000..8243eeca --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibBaseStream.cs @@ -0,0 +1,627 @@ +// ZlibBaseStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-August-06 21:22:38> +// +// ------------------------------------------------------------------ +// +// This module defines the ZlibBaseStream class, which is an intnernal +// base class for DeflateStream, ZlibStream and GZipStream. +// +// ------------------------------------------------------------------ + +using System; +using System.IO; + +namespace Ionic.Zlib +{ + + internal enum ZlibStreamFlavor { ZLIB = 1950, DEFLATE = 1951, GZIP = 1952 } + + internal class ZlibBaseStream : System.IO.Stream + { + protected internal ZlibCodec _z = null; // deferred init... new ZlibCodec(); + + protected internal StreamMode _streamMode = StreamMode.Undefined; + protected internal FlushType _flushMode; + protected internal ZlibStreamFlavor _flavor; + protected internal CompressionMode _compressionMode; + protected internal CompressionLevel _level; + protected internal bool _leaveOpen; + protected internal byte[] _workingBuffer; + protected internal int _bufferSize = ZlibConstants.WorkingBufferSizeDefault; + protected internal byte[] _buf1 = new byte[1]; + + protected internal System.IO.Stream _stream; + protected internal CompressionStrategy Strategy = CompressionStrategy.Default; + + // workitem 7159 + Ionic.Crc.CRC32 crc; + protected internal string _GzipFileName; + protected internal string _GzipComment; + protected internal DateTime _GzipMtime; + protected internal int _gzipHeaderByteCount; + + internal int Crc32 { get { if (crc == null) return 0; return crc.Crc32Result; } } + + public ZlibBaseStream(System.IO.Stream stream, + CompressionMode compressionMode, + CompressionLevel level, + ZlibStreamFlavor flavor, + bool leaveOpen) + : base() + { + this._flushMode = FlushType.None; + //this._workingBuffer = new byte[WORKING_BUFFER_SIZE_DEFAULT]; + this._stream = stream; + this._leaveOpen = leaveOpen; + this._compressionMode = compressionMode; + this._flavor = flavor; + this._level = level; + // workitem 7159 + if (flavor == ZlibStreamFlavor.GZIP) + { + this.crc = new Ionic.Crc.CRC32(); + } + } + + + protected internal bool _wantCompress + { + get + { + return (this._compressionMode == CompressionMode.Compress); + } + } + + private ZlibCodec z + { + get + { + if (_z == null) + { + bool wantRfc1950Header = (this._flavor == ZlibStreamFlavor.ZLIB); + _z = new ZlibCodec(); + if (this._compressionMode == CompressionMode.Decompress) + { + _z.InitializeInflate(wantRfc1950Header); + } + else + { + _z.Strategy = Strategy; + _z.InitializeDeflate(this._level, wantRfc1950Header); + } + } + return _z; + } + } + + + + private byte[] workingBuffer + { + get + { + if (_workingBuffer == null) + _workingBuffer = new byte[_bufferSize]; + return _workingBuffer; + } + } + + + + public override void Write(System.Byte[] buffer, int offset, int count) + { + // workitem 7159 + // calculate the CRC on the unccompressed data (before writing) + if (crc != null) + crc.SlurpBlock(buffer, offset, count); + + if (_streamMode == StreamMode.Undefined) + _streamMode = StreamMode.Writer; + else if (_streamMode != StreamMode.Writer) + throw new ZlibException("Cannot Write after Reading."); + + if (count == 0) + return; + + // first reference of z property will initialize the private var _z + z.InputBuffer = buffer; + _z.NextIn = offset; + _z.AvailableBytesIn = count; + bool done = false; + do + { + _z.OutputBuffer = workingBuffer; + _z.NextOut = 0; + _z.AvailableBytesOut = _workingBuffer.Length; + int rc = (_wantCompress) + ? _z.Deflate(_flushMode) + : _z.Inflate(_flushMode); + if (rc != ZlibConstants.Z_OK && rc != ZlibConstants.Z_STREAM_END) + throw new ZlibException((_wantCompress ? "de" : "in") + "flating: " + _z.Message); + + //if (_workingBuffer.Length - _z.AvailableBytesOut > 0) + _stream.Write(_workingBuffer, 0, _workingBuffer.Length - _z.AvailableBytesOut); + + done = _z.AvailableBytesIn == 0 && _z.AvailableBytesOut != 0; + + // If GZIP and de-compress, we're done when 8 bytes remain. + if (_flavor == ZlibStreamFlavor.GZIP && !_wantCompress) + done = (_z.AvailableBytesIn == 8 && _z.AvailableBytesOut != 0); + + } + while (!done); + } + + + + private void finish() + { + if (_z == null) return; + + if (_streamMode == StreamMode.Writer) + { + bool done = false; + do + { + _z.OutputBuffer = workingBuffer; + _z.NextOut = 0; + _z.AvailableBytesOut = _workingBuffer.Length; + int rc = (_wantCompress) + ? _z.Deflate(FlushType.Finish) + : _z.Inflate(FlushType.Finish); + + if (rc != ZlibConstants.Z_STREAM_END && rc != ZlibConstants.Z_OK) + { + string verb = (_wantCompress ? "de" : "in") + "flating"; + if (_z.Message == null) + throw new ZlibException(String.Format("{0}: (rc = {1})", verb, rc)); + else + throw new ZlibException(verb + ": " + _z.Message); + } + + if (_workingBuffer.Length - _z.AvailableBytesOut > 0) + { + _stream.Write(_workingBuffer, 0, _workingBuffer.Length - _z.AvailableBytesOut); + } + + done = _z.AvailableBytesIn == 0 && _z.AvailableBytesOut != 0; + // If GZIP and de-compress, we're done when 8 bytes remain. + if (_flavor == ZlibStreamFlavor.GZIP && !_wantCompress) + done = (_z.AvailableBytesIn == 8 && _z.AvailableBytesOut != 0); + + } + while (!done); + + Flush(); + + // workitem 7159 + if (_flavor == ZlibStreamFlavor.GZIP) + { + if (_wantCompress) + { + // Emit the GZIP trailer: CRC32 and size mod 2^32 + int c1 = crc.Crc32Result; + _stream.Write(BitConverter.GetBytes(c1), 0, 4); + int c2 = (Int32)(crc.TotalBytesRead & 0x00000000FFFFFFFF); + _stream.Write(BitConverter.GetBytes(c2), 0, 4); + } + else + { + throw new ZlibException("Writing with decompression is not supported."); + } + } + } + // workitem 7159 + else if (_streamMode == StreamMode.Reader) + { + if (_flavor == ZlibStreamFlavor.GZIP) + { + if (!_wantCompress) + { + // workitem 8501: handle edge case (decompress empty stream) + if (_z.TotalBytesOut == 0L) + return; + + // Read and potentially verify the GZIP trailer: + // CRC32 and size mod 2^32 + byte[] trailer = new byte[8]; + + // workitems 8679 & 12554 + if (_z.AvailableBytesIn < 8) + { + // Make sure we have read to the end of the stream + Array.Copy(_z.InputBuffer, _z.NextIn, trailer, 0, _z.AvailableBytesIn); + int bytesNeeded = 8 - _z.AvailableBytesIn; + int bytesRead = _stream.Read(trailer, + _z.AvailableBytesIn, + bytesNeeded); + if (bytesNeeded != bytesRead) + { + throw new ZlibException(String.Format("Missing or incomplete GZIP trailer. Expected 8 bytes, got {0}.", + _z.AvailableBytesIn + bytesRead)); + } + } + else + { + Array.Copy(_z.InputBuffer, _z.NextIn, trailer, 0, trailer.Length); + } + + Int32 crc32_expected = BitConverter.ToInt32(trailer, 0); + Int32 crc32_actual = crc.Crc32Result; + Int32 isize_expected = BitConverter.ToInt32(trailer, 4); + Int32 isize_actual = (Int32)(_z.TotalBytesOut & 0x00000000FFFFFFFF); + + if (crc32_actual != crc32_expected) + throw new ZlibException(String.Format("Bad CRC32 in GZIP trailer. (actual({0:X8})!=expected({1:X8}))", crc32_actual, crc32_expected)); + + if (isize_actual != isize_expected) + throw new ZlibException(String.Format("Bad size in GZIP trailer. (actual({0})!=expected({1}))", isize_actual, isize_expected)); + + } + else + { + throw new ZlibException("Reading with compression is not supported."); + } + } + } + } + + + private void end() + { + if (z == null) + return; + if (_wantCompress) + { + _z.EndDeflate(); + } + else + { + _z.EndInflate(); + } + _z = null; + } + + + public override void Close() + { + if (_stream == null) return; + try + { + finish(); + } + finally + { + end(); + if (!_leaveOpen) _stream.Close(); + _stream = null; + } + } + + public override void Flush() + { + _stream.Flush(); + } + + public override System.Int64 Seek(System.Int64 offset, System.IO.SeekOrigin origin) + { + throw new NotImplementedException(); + //_outStream.Seek(offset, origin); + } + public override void SetLength(System.Int64 value) + { + _stream.SetLength(value); + } + + +#if NOT + public int Read() + { + if (Read(_buf1, 0, 1) == 0) + return 0; + // calculate CRC after reading + if (crc!=null) + crc.SlurpBlock(_buf1,0,1); + return (_buf1[0] & 0xFF); + } +#endif + + private bool nomoreinput = false; + + + + private string ReadZeroTerminatedString() + { + var list = new System.Collections.Generic.List(); + bool done = false; + do + { + // workitem 7740 + int n = _stream.Read(_buf1, 0, 1); + if (n != 1) + throw new ZlibException("Unexpected EOF reading GZIP header."); + else + { + if (_buf1[0] == 0) + done = true; + else + list.Add(_buf1[0]); + } + } while (!done); + byte[] a = list.ToArray(); + return GZipStream.iso8859dash1.GetString(a, 0, a.Length); + } + + + private int _ReadAndValidateGzipHeader() + { + int totalBytesRead = 0; + // read the header on the first read + byte[] header = new byte[10]; + int n = _stream.Read(header, 0, header.Length); + + // workitem 8501: handle edge case (decompress empty stream) + if (n == 0) + return 0; + + if (n != 10) + throw new ZlibException("Not a valid GZIP stream."); + + if (header[0] != 0x1F || header[1] != 0x8B || header[2] != 8) + throw new ZlibException("Bad GZIP header."); + + Int32 timet = BitConverter.ToInt32(header, 4); + _GzipMtime = GZipStream._unixEpoch.AddSeconds(timet); + totalBytesRead += n; + if ((header[3] & 0x04) == 0x04) + { + // read and discard extra field + n = _stream.Read(header, 0, 2); // 2-byte length field + totalBytesRead += n; + + Int16 extraLength = (Int16)(header[0] + header[1] * 256); + byte[] extra = new byte[extraLength]; + n = _stream.Read(extra, 0, extra.Length); + if (n != extraLength) + throw new ZlibException("Unexpected end-of-file reading GZIP header."); + totalBytesRead += n; + } + if ((header[3] & 0x08) == 0x08) + _GzipFileName = ReadZeroTerminatedString(); + if ((header[3] & 0x10) == 0x010) + _GzipComment = ReadZeroTerminatedString(); + if ((header[3] & 0x02) == 0x02) + Read(_buf1, 0, 1); // CRC16, ignore + + return totalBytesRead; + } + + + + public override System.Int32 Read(System.Byte[] buffer, System.Int32 offset, System.Int32 count) + { + // According to MS documentation, any implementation of the IO.Stream.Read function must: + // (a) throw an exception if offset & count reference an invalid part of the buffer, + // or if count < 0, or if buffer is null + // (b) return 0 only upon EOF, or if count = 0 + // (c) if not EOF, then return at least 1 byte, up to bytes + + if (_streamMode == StreamMode.Undefined) + { + if (!this._stream.CanRead) throw new ZlibException("The stream is not readable."); + // for the first read, set up some controls. + _streamMode = StreamMode.Reader; + // (The first reference to _z goes through the private accessor which + // may initialize it.) + z.AvailableBytesIn = 0; + if (_flavor == ZlibStreamFlavor.GZIP) + { + _gzipHeaderByteCount = _ReadAndValidateGzipHeader(); + // workitem 8501: handle edge case (decompress empty stream) + if (_gzipHeaderByteCount == 0) + return 0; + } + } + + if (_streamMode != StreamMode.Reader) + throw new ZlibException("Cannot Read after Writing."); + + if (count == 0) return 0; + if (nomoreinput && _wantCompress) return 0; // workitem 8557 + if (buffer == null) throw new ArgumentNullException("buffer"); + if (count < 0) throw new ArgumentOutOfRangeException("count"); + if (offset < buffer.GetLowerBound(0)) throw new ArgumentOutOfRangeException("offset"); + if ((offset + count) > buffer.GetLength(0)) throw new ArgumentOutOfRangeException("count"); + + int rc = 0; + + // set up the output of the deflate/inflate codec: + _z.OutputBuffer = buffer; + _z.NextOut = offset; + _z.AvailableBytesOut = count; + + // This is necessary in case _workingBuffer has been resized. (new byte[]) + // (The first reference to _workingBuffer goes through the private accessor which + // may initialize it.) + _z.InputBuffer = workingBuffer; + + do + { + // need data in _workingBuffer in order to deflate/inflate. Here, we check if we have any. + if ((_z.AvailableBytesIn == 0) && (!nomoreinput)) + { + // No data available, so try to Read data from the captive stream. + _z.NextIn = 0; + _z.AvailableBytesIn = _stream.Read(_workingBuffer, 0, _workingBuffer.Length); + if (_z.AvailableBytesIn == 0) + nomoreinput = true; + + } + // we have data in InputBuffer; now compress or decompress as appropriate + rc = (_wantCompress) + ? _z.Deflate(_flushMode) + : _z.Inflate(_flushMode); + + if (nomoreinput && (rc == ZlibConstants.Z_BUF_ERROR)) + return 0; + + if (rc != ZlibConstants.Z_OK && rc != ZlibConstants.Z_STREAM_END) + throw new ZlibException(String.Format("{0}flating: rc={1} msg={2}", (_wantCompress ? "de" : "in"), rc, _z.Message)); + + if ((nomoreinput || rc == ZlibConstants.Z_STREAM_END) && (_z.AvailableBytesOut == count)) + break; // nothing more to read + } + //while (_z.AvailableBytesOut == count && rc == ZlibConstants.Z_OK); + while (_z.AvailableBytesOut > 0 && !nomoreinput && rc == ZlibConstants.Z_OK); + + + // workitem 8557 + // is there more room in output? + if (_z.AvailableBytesOut > 0) + { + if (rc == ZlibConstants.Z_OK && _z.AvailableBytesIn == 0) + { + // deferred + } + + // are we completely done reading? + if (nomoreinput) + { + // and in compression? + if (_wantCompress) + { + // no more input data available; therefore we flush to + // try to complete the read + rc = _z.Deflate(FlushType.Finish); + + if (rc != ZlibConstants.Z_OK && rc != ZlibConstants.Z_STREAM_END) + throw new ZlibException(String.Format("Deflating: rc={0} msg={1}", rc, _z.Message)); + } + } + } + + + rc = (count - _z.AvailableBytesOut); + + // calculate CRC after reading + if (crc != null) + crc.SlurpBlock(buffer, offset, rc); + + return rc; + } + + + + public override System.Boolean CanRead + { + get { return this._stream.CanRead; } + } + + public override System.Boolean CanSeek + { + get { return this._stream.CanSeek; } + } + + public override System.Boolean CanWrite + { + get { return this._stream.CanWrite; } + } + + public override System.Int64 Length + { + get { return _stream.Length; } + } + + public override long Position + { + get { throw new NotImplementedException(); } + set { throw new NotImplementedException(); } + } + + internal enum StreamMode + { + Writer, + Reader, + Undefined, + } + + + public static void CompressString(String s, Stream compressor) + { + byte[] uncompressed = System.Text.Encoding.UTF8.GetBytes(s); + using (compressor) + { + compressor.Write(uncompressed, 0, uncompressed.Length); + } + } + + public static void CompressBuffer(byte[] b, Stream compressor) + { + // workitem 8460 + using (compressor) + { + compressor.Write(b, 0, b.Length); + } + } + + public static String UncompressString(byte[] compressed, Stream decompressor) + { + // workitem 8460 + byte[] working = new byte[1024]; + var encoding = System.Text.Encoding.UTF8; + using (var output = new MemoryStream()) + { + using (decompressor) + { + int n; + while ((n = decompressor.Read(working, 0, working.Length)) != 0) + { + output.Write(working, 0, n); + } + } + + // reset to allow read from start + output.Seek(0, SeekOrigin.Begin); + var sr = new StreamReader(output, encoding); + return sr.ReadToEnd(); + } + } + + public static byte[] UncompressBuffer(byte[] compressed, Stream decompressor) + { + // workitem 8460 + byte[] working = new byte[1024]; + using (var output = new MemoryStream()) + { + using (decompressor) + { + int n; + while ((n = decompressor.Read(working, 0, working.Length)) != 0) + { + output.Write(working, 0, n); + } + } + return output.ToArray(); + } + } + + } + + +} diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/ZlibCodec.cs b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibCodec.cs new file mode 100644 index 00000000..813d2481 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibCodec.cs @@ -0,0 +1,717 @@ +// ZlibCodec.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-November-03 15:40:51> +// +// ------------------------------------------------------------------ +// +// This module defines a Codec for ZLIB compression and +// decompression. This code extends code that was based the jzlib +// implementation of zlib, but this code is completely novel. The codec +// class is new, and encapsulates some behaviors that are new, and some +// that were present in other classes in the jzlib code base. In +// keeping with the license for jzlib, the copyright to the jzlib code +// is included below. +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// This program is based on zlib-1.1.3; credit to authors +// Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) +// and contributors of zlib. +// +// ----------------------------------------------------------------------- + + +using System; +using Interop=System.Runtime.InteropServices; + +namespace Ionic.Zlib +{ + /// + /// Encoder and Decoder for ZLIB and DEFLATE (IETF RFC1950 and RFC1951). + /// + /// + /// + /// This class compresses and decompresses data according to the Deflate algorithm + /// and optionally, the ZLIB format, as documented in RFC 1950 - ZLIB and RFC 1951 - DEFLATE. + /// + [Interop.GuidAttribute("ebc25cf6-9120-4283-b972-0e5520d0000D")] + [Interop.ComVisible(true)] +#if !NETCF + [Interop.ClassInterface(Interop.ClassInterfaceType.AutoDispatch)] +#endif + sealed public class ZlibCodec + { + /// + /// The buffer from which data is taken. + /// + public byte[] InputBuffer; + + /// + /// An index into the InputBuffer array, indicating where to start reading. + /// + public int NextIn; + + /// + /// The number of bytes available in the InputBuffer, starting at NextIn. + /// + /// + /// Generally you should set this to InputBuffer.Length before the first Inflate() or Deflate() call. + /// The class will update this number as calls to Inflate/Deflate are made. + /// + public int AvailableBytesIn; + + /// + /// Total number of bytes read so far, through all calls to Inflate()/Deflate(). + /// + public long TotalBytesIn; + + /// + /// Buffer to store output data. + /// + public byte[] OutputBuffer; + + /// + /// An index into the OutputBuffer array, indicating where to start writing. + /// + public int NextOut; + + /// + /// The number of bytes available in the OutputBuffer, starting at NextOut. + /// + /// + /// Generally you should set this to OutputBuffer.Length before the first Inflate() or Deflate() call. + /// The class will update this number as calls to Inflate/Deflate are made. + /// + public int AvailableBytesOut; + + /// + /// Total number of bytes written to the output so far, through all calls to Inflate()/Deflate(). + /// + public long TotalBytesOut; + + /// + /// used for diagnostics, when something goes wrong! + /// + public System.String Message; + + internal DeflateManager dstate; + internal InflateManager istate; + + internal uint _Adler32; + + /// + /// The compression level to use in this codec. Useful only in compression mode. + /// + public CompressionLevel CompressLevel = CompressionLevel.Default; + + /// + /// The number of Window Bits to use. + /// + /// + /// This gauges the size of the sliding window, and hence the + /// compression effectiveness as well as memory consumption. It's best to just leave this + /// setting alone if you don't know what it is. The maximum value is 15 bits, which implies + /// a 32k window. + /// + public int WindowBits = ZlibConstants.WindowBitsDefault; + + /// + /// The compression strategy to use. + /// + /// + /// This is only effective in compression. The theory offered by ZLIB is that different + /// strategies could potentially produce significant differences in compression behavior + /// for different data sets. Unfortunately I don't have any good recommendations for how + /// to set it differently. When I tested changing the strategy I got minimally different + /// compression performance. It's best to leave this property alone if you don't have a + /// good feel for it. Or, you may want to produce a test harness that runs through the + /// different strategy options and evaluates them on different file types. If you do that, + /// let me know your results. + /// + public CompressionStrategy Strategy = CompressionStrategy.Default; + + + /// + /// The Adler32 checksum on the data transferred through the codec so far. You probably don't need to look at this. + /// + public int Adler32 { get { return (int)_Adler32; } } + + + /// + /// Create a ZlibCodec. + /// + /// + /// If you use this default constructor, you will later have to explicitly call + /// InitializeInflate() or InitializeDeflate() before using the ZlibCodec to compress + /// or decompress. + /// + public ZlibCodec() { } + + /// + /// Create a ZlibCodec that either compresses or decompresses. + /// + /// + /// Indicates whether the codec should compress (deflate) or decompress (inflate). + /// + public ZlibCodec(CompressionMode mode) + { + if (mode == CompressionMode.Compress) + { + int rc = InitializeDeflate(); + if (rc != ZlibConstants.Z_OK) throw new ZlibException("Cannot initialize for deflate."); + } + else if (mode == CompressionMode.Decompress) + { + int rc = InitializeInflate(); + if (rc != ZlibConstants.Z_OK) throw new ZlibException("Cannot initialize for inflate."); + } + else throw new ZlibException("Invalid ZlibStreamFlavor."); + } + + /// + /// Initialize the inflation state. + /// + /// + /// It is not necessary to call this before using the ZlibCodec to inflate data; + /// It is implicitly called when you call the constructor. + /// + /// Z_OK if everything goes well. + public int InitializeInflate() + { + return InitializeInflate(this.WindowBits); + } + + /// + /// Initialize the inflation state with an explicit flag to + /// govern the handling of RFC1950 header bytes. + /// + /// + /// + /// By default, the ZLIB header defined in RFC 1950 is expected. If + /// you want to read a zlib stream you should specify true for + /// expectRfc1950Header. If you have a deflate stream, you will want to specify + /// false. It is only necessary to invoke this initializer explicitly if you + /// want to specify false. + /// + /// + /// whether to expect an RFC1950 header byte + /// pair when reading the stream of data to be inflated. + /// + /// Z_OK if everything goes well. + public int InitializeInflate(bool expectRfc1950Header) + { + return InitializeInflate(this.WindowBits, expectRfc1950Header); + } + + /// + /// Initialize the ZlibCodec for inflation, with the specified number of window bits. + /// + /// The number of window bits to use. If you need to ask what that is, + /// then you shouldn't be calling this initializer. + /// Z_OK if all goes well. + public int InitializeInflate(int windowBits) + { + this.WindowBits = windowBits; + return InitializeInflate(windowBits, true); + } + + /// + /// Initialize the inflation state with an explicit flag to govern the handling of + /// RFC1950 header bytes. + /// + /// + /// + /// If you want to read a zlib stream you should specify true for + /// expectRfc1950Header. In this case, the library will expect to find a ZLIB + /// header, as defined in RFC + /// 1950, in the compressed stream. If you will be reading a DEFLATE or + /// GZIP stream, which does not have such a header, you will want to specify + /// false. + /// + /// + /// whether to expect an RFC1950 header byte pair when reading + /// the stream of data to be inflated. + /// The number of window bits to use. If you need to ask what that is, + /// then you shouldn't be calling this initializer. + /// Z_OK if everything goes well. + public int InitializeInflate(int windowBits, bool expectRfc1950Header) + { + this.WindowBits = windowBits; + if (dstate != null) throw new ZlibException("You may not call InitializeInflate() after calling InitializeDeflate()."); + istate = new InflateManager(expectRfc1950Header); + return istate.Initialize(this, windowBits); + } + + /// + /// Inflate the data in the InputBuffer, placing the result in the OutputBuffer. + /// + /// + /// You must have set InputBuffer and OutputBuffer, NextIn and NextOut, and AvailableBytesIn and + /// AvailableBytesOut before calling this method. + /// + /// + /// + /// private void InflateBuffer() + /// { + /// int bufferSize = 1024; + /// byte[] buffer = new byte[bufferSize]; + /// ZlibCodec decompressor = new ZlibCodec(); + /// + /// Console.WriteLine("\n============================================"); + /// Console.WriteLine("Size of Buffer to Inflate: {0} bytes.", CompressedBytes.Length); + /// MemoryStream ms = new MemoryStream(DecompressedBytes); + /// + /// int rc = decompressor.InitializeInflate(); + /// + /// decompressor.InputBuffer = CompressedBytes; + /// decompressor.NextIn = 0; + /// decompressor.AvailableBytesIn = CompressedBytes.Length; + /// + /// decompressor.OutputBuffer = buffer; + /// + /// // pass 1: inflate + /// do + /// { + /// decompressor.NextOut = 0; + /// decompressor.AvailableBytesOut = buffer.Length; + /// rc = decompressor.Inflate(FlushType.None); + /// + /// if (rc != ZlibConstants.Z_OK && rc != ZlibConstants.Z_STREAM_END) + /// throw new Exception("inflating: " + decompressor.Message); + /// + /// ms.Write(decompressor.OutputBuffer, 0, buffer.Length - decompressor.AvailableBytesOut); + /// } + /// while (decompressor.AvailableBytesIn > 0 || decompressor.AvailableBytesOut == 0); + /// + /// // pass 2: finish and flush + /// do + /// { + /// decompressor.NextOut = 0; + /// decompressor.AvailableBytesOut = buffer.Length; + /// rc = decompressor.Inflate(FlushType.Finish); + /// + /// if (rc != ZlibConstants.Z_STREAM_END && rc != ZlibConstants.Z_OK) + /// throw new Exception("inflating: " + decompressor.Message); + /// + /// if (buffer.Length - decompressor.AvailableBytesOut > 0) + /// ms.Write(buffer, 0, buffer.Length - decompressor.AvailableBytesOut); + /// } + /// while (decompressor.AvailableBytesIn > 0 || decompressor.AvailableBytesOut == 0); + /// + /// decompressor.EndInflate(); + /// } + /// + /// + /// + /// The flush to use when inflating. + /// Z_OK if everything goes well. + public int Inflate(FlushType flush) + { + if (istate == null) + throw new ZlibException("No Inflate State!"); + return istate.Inflate(flush); + } + + + /// + /// Ends an inflation session. + /// + /// + /// Call this after successively calling Inflate(). This will cause all buffers to be flushed. + /// After calling this you cannot call Inflate() without a intervening call to one of the + /// InitializeInflate() overloads. + /// + /// Z_OK if everything goes well. + public int EndInflate() + { + if (istate == null) + throw new ZlibException("No Inflate State!"); + int ret = istate.End(); + istate = null; + return ret; + } + + /// + /// I don't know what this does! + /// + /// Z_OK if everything goes well. + public int SyncInflate() + { + if (istate == null) + throw new ZlibException("No Inflate State!"); + return istate.Sync(); + } + + /// + /// Initialize the ZlibCodec for deflation operation. + /// + /// + /// The codec will use the MAX window bits and the default level of compression. + /// + /// + /// + /// int bufferSize = 40000; + /// byte[] CompressedBytes = new byte[bufferSize]; + /// byte[] DecompressedBytes = new byte[bufferSize]; + /// + /// ZlibCodec compressor = new ZlibCodec(); + /// + /// compressor.InitializeDeflate(CompressionLevel.Default); + /// + /// compressor.InputBuffer = System.Text.ASCIIEncoding.ASCII.GetBytes(TextToCompress); + /// compressor.NextIn = 0; + /// compressor.AvailableBytesIn = compressor.InputBuffer.Length; + /// + /// compressor.OutputBuffer = CompressedBytes; + /// compressor.NextOut = 0; + /// compressor.AvailableBytesOut = CompressedBytes.Length; + /// + /// while (compressor.TotalBytesIn != TextToCompress.Length && compressor.TotalBytesOut < bufferSize) + /// { + /// compressor.Deflate(FlushType.None); + /// } + /// + /// while (true) + /// { + /// int rc= compressor.Deflate(FlushType.Finish); + /// if (rc == ZlibConstants.Z_STREAM_END) break; + /// } + /// + /// compressor.EndDeflate(); + /// + /// + /// + /// Z_OK if all goes well. You generally don't need to check the return code. + public int InitializeDeflate() + { + return _InternalInitializeDeflate(true); + } + + /// + /// Initialize the ZlibCodec for deflation operation, using the specified CompressionLevel. + /// + /// + /// The codec will use the maximum window bits (15) and the specified + /// CompressionLevel. It will emit a ZLIB stream as it compresses. + /// + /// The compression level for the codec. + /// Z_OK if all goes well. + public int InitializeDeflate(CompressionLevel level) + { + this.CompressLevel = level; + return _InternalInitializeDeflate(true); + } + + + /// + /// Initialize the ZlibCodec for deflation operation, using the specified CompressionLevel, + /// and the explicit flag governing whether to emit an RFC1950 header byte pair. + /// + /// + /// The codec will use the maximum window bits (15) and the specified CompressionLevel. + /// If you want to generate a zlib stream, you should specify true for + /// wantRfc1950Header. In this case, the library will emit a ZLIB + /// header, as defined in RFC + /// 1950, in the compressed stream. + /// + /// The compression level for the codec. + /// whether to emit an initial RFC1950 byte pair in the compressed stream. + /// Z_OK if all goes well. + public int InitializeDeflate(CompressionLevel level, bool wantRfc1950Header) + { + this.CompressLevel = level; + return _InternalInitializeDeflate(wantRfc1950Header); + } + + + /// + /// Initialize the ZlibCodec for deflation operation, using the specified CompressionLevel, + /// and the specified number of window bits. + /// + /// + /// The codec will use the specified number of window bits and the specified CompressionLevel. + /// + /// The compression level for the codec. + /// the number of window bits to use. If you don't know what this means, don't use this method. + /// Z_OK if all goes well. + public int InitializeDeflate(CompressionLevel level, int bits) + { + this.CompressLevel = level; + this.WindowBits = bits; + return _InternalInitializeDeflate(true); + } + + /// + /// Initialize the ZlibCodec for deflation operation, using the specified + /// CompressionLevel, the specified number of window bits, and the explicit flag + /// governing whether to emit an RFC1950 header byte pair. + /// + /// + /// The compression level for the codec. + /// whether to emit an initial RFC1950 byte pair in the compressed stream. + /// the number of window bits to use. If you don't know what this means, don't use this method. + /// Z_OK if all goes well. + public int InitializeDeflate(CompressionLevel level, int bits, bool wantRfc1950Header) + { + this.CompressLevel = level; + this.WindowBits = bits; + return _InternalInitializeDeflate(wantRfc1950Header); + } + + private int _InternalInitializeDeflate(bool wantRfc1950Header) + { + if (istate != null) throw new ZlibException("You may not call InitializeDeflate() after calling InitializeInflate()."); + dstate = new DeflateManager(); + dstate.WantRfc1950HeaderBytes = wantRfc1950Header; + + return dstate.Initialize(this, this.CompressLevel, this.WindowBits, this.Strategy); + } + + /// + /// Deflate one batch of data. + /// + /// + /// You must have set InputBuffer and OutputBuffer before calling this method. + /// + /// + /// + /// private void DeflateBuffer(CompressionLevel level) + /// { + /// int bufferSize = 1024; + /// byte[] buffer = new byte[bufferSize]; + /// ZlibCodec compressor = new ZlibCodec(); + /// + /// Console.WriteLine("\n============================================"); + /// Console.WriteLine("Size of Buffer to Deflate: {0} bytes.", UncompressedBytes.Length); + /// MemoryStream ms = new MemoryStream(); + /// + /// int rc = compressor.InitializeDeflate(level); + /// + /// compressor.InputBuffer = UncompressedBytes; + /// compressor.NextIn = 0; + /// compressor.AvailableBytesIn = UncompressedBytes.Length; + /// + /// compressor.OutputBuffer = buffer; + /// + /// // pass 1: deflate + /// do + /// { + /// compressor.NextOut = 0; + /// compressor.AvailableBytesOut = buffer.Length; + /// rc = compressor.Deflate(FlushType.None); + /// + /// if (rc != ZlibConstants.Z_OK && rc != ZlibConstants.Z_STREAM_END) + /// throw new Exception("deflating: " + compressor.Message); + /// + /// ms.Write(compressor.OutputBuffer, 0, buffer.Length - compressor.AvailableBytesOut); + /// } + /// while (compressor.AvailableBytesIn > 0 || compressor.AvailableBytesOut == 0); + /// + /// // pass 2: finish and flush + /// do + /// { + /// compressor.NextOut = 0; + /// compressor.AvailableBytesOut = buffer.Length; + /// rc = compressor.Deflate(FlushType.Finish); + /// + /// if (rc != ZlibConstants.Z_STREAM_END && rc != ZlibConstants.Z_OK) + /// throw new Exception("deflating: " + compressor.Message); + /// + /// if (buffer.Length - compressor.AvailableBytesOut > 0) + /// ms.Write(buffer, 0, buffer.Length - compressor.AvailableBytesOut); + /// } + /// while (compressor.AvailableBytesIn > 0 || compressor.AvailableBytesOut == 0); + /// + /// compressor.EndDeflate(); + /// + /// ms.Seek(0, SeekOrigin.Begin); + /// CompressedBytes = new byte[compressor.TotalBytesOut]; + /// ms.Read(CompressedBytes, 0, CompressedBytes.Length); + /// } + /// + /// + /// whether to flush all data as you deflate. Generally you will want to + /// use Z_NO_FLUSH here, in a series of calls to Deflate(), and then call EndDeflate() to + /// flush everything. + /// + /// Z_OK if all goes well. + public int Deflate(FlushType flush) + { + if (dstate == null) + throw new ZlibException("No Deflate State!"); + return dstate.Deflate(flush); + } + + /// + /// End a deflation session. + /// + /// + /// Call this after making a series of one or more calls to Deflate(). All buffers are flushed. + /// + /// Z_OK if all goes well. + public int EndDeflate() + { + if (dstate == null) + throw new ZlibException("No Deflate State!"); + // TODO: dinoch Tue, 03 Nov 2009 15:39 (test this) + //int ret = dstate.End(); + dstate = null; + return ZlibConstants.Z_OK; //ret; + } + + /// + /// Reset a codec for another deflation session. + /// + /// + /// Call this to reset the deflation state. For example if a thread is deflating + /// non-consecutive blocks, you can call Reset() after the Deflate(Sync) of the first + /// block and before the next Deflate(None) of the second block. + /// + /// Z_OK if all goes well. + public void ResetDeflate() + { + if (dstate == null) + throw new ZlibException("No Deflate State!"); + dstate.Reset(); + } + + + /// + /// Set the CompressionStrategy and CompressionLevel for a deflation session. + /// + /// the level of compression to use. + /// the strategy to use for compression. + /// Z_OK if all goes well. + public int SetDeflateParams(CompressionLevel level, CompressionStrategy strategy) + { + if (dstate == null) + throw new ZlibException("No Deflate State!"); + return dstate.SetParams(level, strategy); + } + + + /// + /// Set the dictionary to be used for either Inflation or Deflation. + /// + /// The dictionary bytes to use. + /// Z_OK if all goes well. + public int SetDictionary(byte[] dictionary) + { + if (istate != null) + return istate.SetDictionary(dictionary); + + if (dstate != null) + return dstate.SetDictionary(dictionary); + + throw new ZlibException("No Inflate or Deflate state!"); + } + + // Flush as much pending output as possible. All deflate() output goes + // through this function so some applications may wish to modify it + // to avoid allocating a large strm->next_out buffer and copying into it. + // (See also read_buf()). + internal void flush_pending() + { + int len = dstate.pendingCount; + + if (len > AvailableBytesOut) + len = AvailableBytesOut; + if (len == 0) + return; + + if (dstate.pending.Length <= dstate.nextPending || + OutputBuffer.Length <= NextOut || + dstate.pending.Length < (dstate.nextPending + len) || + OutputBuffer.Length < (NextOut + len)) + { + throw new ZlibException(String.Format("Invalid State. (pending.Length={0}, pendingCount={1})", + dstate.pending.Length, dstate.pendingCount)); + } + + Array.Copy(dstate.pending, dstate.nextPending, OutputBuffer, NextOut, len); + + NextOut += len; + dstate.nextPending += len; + TotalBytesOut += len; + AvailableBytesOut -= len; + dstate.pendingCount -= len; + if (dstate.pendingCount == 0) + { + dstate.nextPending = 0; + } + } + + // Read a new buffer from the current input stream, update the adler32 + // and total number of bytes read. All deflate() input goes through + // this function so some applications may wish to modify it to avoid + // allocating a large strm->next_in buffer and copying from it. + // (See also flush_pending()). + internal int read_buf(byte[] buf, int start, int size) + { + int len = AvailableBytesIn; + + if (len > size) + len = size; + if (len == 0) + return 0; + + AvailableBytesIn -= len; + + if (dstate.WantRfc1950HeaderBytes) + { + _Adler32 = Adler.Adler32(_Adler32, InputBuffer, NextIn, len); + } + Array.Copy(InputBuffer, NextIn, buf, start, len); + NextIn += len; + TotalBytesIn += len; + return len; + } + + } +} \ No newline at end of file diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/ZlibConstants.cs b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibConstants.cs new file mode 100644 index 00000000..7952ce20 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibConstants.cs @@ -0,0 +1,128 @@ +// ZlibConstants.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2009-November-03 18:50:19> +// +// ------------------------------------------------------------------ +// +// This module defines constants used by the zlib class library. This +// code is derived from the jzlib implementation of zlib, but +// significantly modified. In keeping with the license for jzlib, the +// copyright to that code is included here. +// +// ------------------------------------------------------------------ +// +// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved. +// +// Redistribution and use in source and binary forms, with or without +// modification, are permitted provided that the following conditions are met: +// +// 1. Redistributions of source code must retain the above copyright notice, +// this list of conditions and the following disclaimer. +// +// 2. Redistributions in binary form must reproduce the above copyright +// notice, this list of conditions and the following disclaimer in +// the documentation and/or other materials provided with the distribution. +// +// 3. The names of the authors may not be used to endorse or promote products +// derived from this software without specific prior written permission. +// +// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, +// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND +// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT, +// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT, +// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, +// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF +// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING +// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, +// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +// +// ----------------------------------------------------------------------- +// +// This program is based on zlib-1.1.3; credit to authors +// Jean-loup Gailly(jloup@gzip.org) and Mark Adler(madler@alumni.caltech.edu) +// and contributors of zlib. +// +// ----------------------------------------------------------------------- + + +using System; + +namespace Ionic.Zlib +{ + /// + /// A bunch of constants used in the Zlib interface. + /// + public static class ZlibConstants + { + /// + /// The maximum number of window bits for the Deflate algorithm. + /// + public const int WindowBitsMax = 15; // 32K LZ77 window + + /// + /// The default number of window bits for the Deflate algorithm. + /// + public const int WindowBitsDefault = WindowBitsMax; + + /// + /// indicates everything is A-OK + /// + public const int Z_OK = 0; + + /// + /// Indicates that the last operation reached the end of the stream. + /// + public const int Z_STREAM_END = 1; + + /// + /// The operation ended in need of a dictionary. + /// + public const int Z_NEED_DICT = 2; + + /// + /// There was an error with the stream - not enough data, not open and readable, etc. + /// + public const int Z_STREAM_ERROR = -2; + + /// + /// There was an error with the data - not enough data, bad data, etc. + /// + public const int Z_DATA_ERROR = -3; + + /// + /// There was an error with the working buffer. + /// + public const int Z_BUF_ERROR = -5; + + /// + /// The size of the working buffer used in the ZlibCodec class. Defaults to 8192 bytes. + /// +#if NETCF + public const int WorkingBufferSizeDefault = 8192; +#else + public const int WorkingBufferSizeDefault = 16384; +#endif + /// + /// The minimum size of the working buffer used in the ZlibCodec class. Currently it is 128 bytes. + /// + public const int WorkingBufferSizeMin = 1024; + } + +} + diff --git a/Resources/Libraries/DotNetZip/Source/Zlib/ZlibStream.cs b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibStream.cs new file mode 100644 index 00000000..57b308c0 --- /dev/null +++ b/Resources/Libraries/DotNetZip/Source/Zlib/ZlibStream.cs @@ -0,0 +1,725 @@ +// ZlibStream.cs +// ------------------------------------------------------------------ +// +// Copyright (c) 2009 Dino Chiesa and Microsoft Corporation. +// All rights reserved. +// +// This code module is part of DotNetZip, a zipfile class library. +// +// ------------------------------------------------------------------ +// +// This code is licensed under the Microsoft Public License. +// See the file License.txt for the license details. +// More info on: http://dotnetzip.codeplex.com +// +// ------------------------------------------------------------------ +// +// last saved (in emacs): +// Time-stamp: <2011-July-31 14:53:33> +// +// ------------------------------------------------------------------ +// +// This module defines the ZlibStream class, which is similar in idea to +// the System.IO.Compression.DeflateStream and +// System.IO.Compression.GZipStream classes in the .NET BCL. +// +// ------------------------------------------------------------------ + +using System; +using System.IO; + +namespace Ionic.Zlib +{ + + /// + /// Represents a Zlib stream for compression or decompression. + /// + /// + /// + /// + /// The ZlibStream is a Decorator on a . It adds ZLIB compression or decompression to any + /// stream. + /// + /// + /// Using this stream, applications can compress or decompress data via + /// stream Read() and Write() operations. Either compresssion or + /// decompression can occur through either reading or writing. The compression + /// format used is ZLIB, which is documented in IETF RFC 1950, "ZLIB Compressed + /// Data Format Specification version 3.3". This implementation of ZLIB always uses + /// DEFLATE as the compression method. (see IETF RFC 1951, "DEFLATE + /// Compressed Data Format Specification version 1.3.") + /// + /// + /// The ZLIB format allows for varying compression methods, window sizes, and dictionaries. + /// This implementation always uses the DEFLATE compression method, a preset dictionary, + /// and 15 window bits by default. + /// + /// + /// + /// This class is similar to , except that it adds the + /// RFC1950 header and trailer bytes to a compressed stream when compressing, or expects + /// the RFC1950 header and trailer bytes when decompressing. It is also similar to the + /// . + /// + /// + /// + /// + public class ZlibStream : System.IO.Stream + { + internal ZlibBaseStream _baseStream; + bool _disposed; + + /// + /// Create a ZlibStream using the specified CompressionMode. + /// + /// + /// + /// + /// When mode is CompressionMode.Compress, the ZlibStream + /// will use the default compression level. The "captive" stream will be + /// closed when the ZlibStream is closed. + /// + /// + /// + /// + /// + /// This example uses a ZlibStream to compress a file, and writes the + /// compressed data to another file. + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(fileToCompress + ".zlib")) + /// { + /// using (Stream compressor = new ZlibStream(raw, CompressionMode.Compress)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(fileToCompress & ".zlib") + /// Using compressor As Stream = New ZlibStream(raw, CompressionMode.Compress) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// + /// The stream which will be read or written. + /// Indicates whether the ZlibStream will compress or decompress. + public ZlibStream(System.IO.Stream stream, CompressionMode mode) + : this(stream, mode, CompressionLevel.Default, false) + { + } + + /// + /// Create a ZlibStream using the specified CompressionMode and + /// the specified CompressionLevel. + /// + /// + /// + /// + /// + /// When mode is CompressionMode.Decompress, the level parameter is ignored. + /// The "captive" stream will be closed when the ZlibStream is closed. + /// + /// + /// + /// + /// + /// This example uses a ZlibStream to compress data from a file, and writes the + /// compressed data to another file. + /// + /// + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (var raw = System.IO.File.Create(fileToCompress + ".zlib")) + /// { + /// using (Stream compressor = new ZlibStream(raw, + /// CompressionMode.Compress, + /// CompressionLevel.BestCompression)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// } + /// + /// + /// + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using raw As FileStream = File.Create(fileToCompress & ".zlib") + /// Using compressor As Stream = New ZlibStream(raw, CompressionMode.Compress, CompressionLevel.BestCompression) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// End Using + /// + /// + /// + /// The stream to be read or written while deflating or inflating. + /// Indicates whether the ZlibStream will compress or decompress. + /// A tuning knob to trade speed for effectiveness. + public ZlibStream(System.IO.Stream stream, CompressionMode mode, CompressionLevel level) + : this(stream, mode, level, false) + { + } + + /// + /// Create a ZlibStream using the specified CompressionMode, and + /// explicitly specify whether the captive stream should be left open after + /// Deflation or Inflation. + /// + /// + /// + /// + /// + /// When mode is CompressionMode.Compress, the ZlibStream will use + /// the default compression level. + /// + /// + /// + /// This constructor allows the application to request that the captive stream + /// remain open after the deflation or inflation occurs. By default, after + /// Close() is called on the stream, the captive stream is also + /// closed. In some cases this is not desired, for example if the stream is a + /// that will be re-read after + /// compression. Specify true for the parameter to leave the stream + /// open. + /// + /// + /// + /// See the other overloads of this constructor for example code. + /// + /// + /// + /// + /// The stream which will be read or written. This is called the + /// "captive" stream in other places in this documentation. + /// Indicates whether the ZlibStream will compress or decompress. + /// true if the application would like the stream to remain + /// open after inflation/deflation. + public ZlibStream(System.IO.Stream stream, CompressionMode mode, bool leaveOpen) + : this(stream, mode, CompressionLevel.Default, leaveOpen) + { + } + + /// + /// Create a ZlibStream using the specified CompressionMode + /// and the specified CompressionLevel, and explicitly specify + /// whether the stream should be left open after Deflation or Inflation. + /// + /// + /// + /// + /// + /// This constructor allows the application to request that the captive + /// stream remain open after the deflation or inflation occurs. By + /// default, after Close() is called on the stream, the captive + /// stream is also closed. In some cases this is not desired, for example + /// if the stream is a that will be + /// re-read after compression. Specify true for the parameter to leave the stream open. + /// + /// + /// + /// When mode is CompressionMode.Decompress, the level parameter is + /// ignored. + /// + /// + /// + /// + /// + /// + /// This example shows how to use a ZlibStream to compress the data from a file, + /// and store the result into another file. The filestream remains open to allow + /// additional data to be written to it. + /// + /// + /// using (var output = System.IO.File.Create(fileToCompress + ".zlib")) + /// { + /// using (System.IO.Stream input = System.IO.File.OpenRead(fileToCompress)) + /// { + /// using (Stream compressor = new ZlibStream(output, CompressionMode.Compress, CompressionLevel.BestCompression, true)) + /// { + /// byte[] buffer = new byte[WORKING_BUFFER_SIZE]; + /// int n; + /// while ((n= input.Read(buffer, 0, buffer.Length)) != 0) + /// { + /// compressor.Write(buffer, 0, n); + /// } + /// } + /// } + /// // can write additional data to the output stream here + /// } + /// + /// + /// Using output As FileStream = File.Create(fileToCompress & ".zlib") + /// Using input As Stream = File.OpenRead(fileToCompress) + /// Using compressor As Stream = New ZlibStream(output, CompressionMode.Compress, CompressionLevel.BestCompression, True) + /// Dim buffer As Byte() = New Byte(4096) {} + /// Dim n As Integer = -1 + /// Do While (n <> 0) + /// If (n > 0) Then + /// compressor.Write(buffer, 0, n) + /// End If + /// n = input.Read(buffer, 0, buffer.Length) + /// Loop + /// End Using + /// End Using + /// ' can write additional data to the output stream here. + /// End Using + /// + /// + /// + /// The stream which will be read or written. + /// + /// Indicates whether the ZlibStream will compress or decompress. + /// + /// + /// true if the application would like the stream to remain open after + /// inflation/deflation. + /// + /// + /// + /// A tuning knob to trade speed for effectiveness. This parameter is + /// effective only when mode is CompressionMode.Compress. + /// + public ZlibStream(System.IO.Stream stream, CompressionMode mode, CompressionLevel level, bool leaveOpen) + { + _baseStream = new ZlibBaseStream(stream, mode, level, ZlibStreamFlavor.ZLIB, leaveOpen); + } + + #region Zlib properties + + /// + /// This property sets the flush behavior on the stream. + /// Sorry, though, not sure exactly how to describe all the various settings. + /// + virtual public FlushType FlushMode + { + get { return (this._baseStream._flushMode); } + set + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + this._baseStream._flushMode = value; + } + } + + /// + /// The size of the working buffer for the compression codec. + /// + /// + /// + /// + /// The working buffer is used for all stream operations. The default size is + /// 1024 bytes. The minimum size is 128 bytes. You may get better performance + /// with a larger buffer. Then again, you might not. You would have to test + /// it. + /// + /// + /// + /// Set this before the first call to Read() or Write() on the + /// stream. If you try to set it afterwards, it will throw. + /// + /// + public int BufferSize + { + get + { + return this._baseStream._bufferSize; + } + set + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + if (this._baseStream._workingBuffer != null) + throw new ZlibException("The working buffer is already set."); + if (value < ZlibConstants.WorkingBufferSizeMin) + throw new ZlibException(String.Format("Don't be silly. {0} bytes?? Use a bigger buffer, at least {1}.", value, ZlibConstants.WorkingBufferSizeMin)); + this._baseStream._bufferSize = value; + } + } + + /// Returns the total number of bytes input so far. + virtual public long TotalIn + { + get { return this._baseStream._z.TotalBytesIn; } + } + + /// Returns the total number of bytes output so far. + virtual public long TotalOut + { + get { return this._baseStream._z.TotalBytesOut; } + } + + #endregion + + #region System.IO.Stream methods + + /// + /// Dispose the stream. + /// + /// + /// + /// This may or may not result in a Close() call on the captive + /// stream. See the constructors that have a leaveOpen parameter + /// for more information. + /// + /// + /// This method may be invoked in two distinct scenarios. If disposing + /// == true, the method has been called directly or indirectly by a + /// user's code, for example via the public Dispose() method. In this + /// case, both managed and unmanaged resources can be referenced and + /// disposed. If disposing == false, the method has been called by the + /// runtime from inside the object finalizer and this method should not + /// reference other objects; in that case only unmanaged resources must + /// be referenced or disposed. + /// + /// + /// + /// indicates whether the Dispose method was invoked by user code. + /// + protected override void Dispose(bool disposing) + { + try + { + if (!_disposed) + { + if (disposing && (this._baseStream != null)) + this._baseStream.Close(); + _disposed = true; + } + } + finally + { + base.Dispose(disposing); + } + } + + + /// + /// Indicates whether the stream can be read. + /// + /// + /// The return value depends on whether the captive stream supports reading. + /// + public override bool CanRead + { + get + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + return _baseStream._stream.CanRead; + } + } + + /// + /// Indicates whether the stream supports Seek operations. + /// + /// + /// Always returns false. + /// + public override bool CanSeek + { + get { return false; } + } + + /// + /// Indicates whether the stream can be written. + /// + /// + /// The return value depends on whether the captive stream supports writing. + /// + public override bool CanWrite + { + get + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + return _baseStream._stream.CanWrite; + } + } + + /// + /// Flush the stream. + /// + public override void Flush() + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + _baseStream.Flush(); + } + + /// + /// Reading this property always throws a . + /// + public override long Length + { + get { throw new NotSupportedException(); } + } + + /// + /// The position of the stream pointer. + /// + /// + /// + /// Setting this property always throws a . Reading will return the total bytes + /// written out, if used in writing, or the total bytes read in, if used in + /// reading. The count may refer to compressed bytes or uncompressed bytes, + /// depending on how you've used the stream. + /// + public override long Position + { + get + { + if (this._baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Writer) + return this._baseStream._z.TotalBytesOut; + if (this._baseStream._streamMode == Ionic.Zlib.ZlibBaseStream.StreamMode.Reader) + return this._baseStream._z.TotalBytesIn; + return 0; + } + + set { throw new NotSupportedException(); } + } + + /// + /// Read data from the stream. + /// + /// + /// + /// + /// + /// If you wish to use the ZlibStream to compress data while reading, + /// you can create a ZlibStream with CompressionMode.Compress, + /// providing an uncompressed data stream. Then call Read() on that + /// ZlibStream, and the data read will be compressed. If you wish to + /// use the ZlibStream to decompress data while reading, you can create + /// a ZlibStream with CompressionMode.Decompress, providing a + /// readable compressed data stream. Then call Read() on that + /// ZlibStream, and the data will be decompressed as it is read. + /// + /// + /// + /// A ZlibStream can be used for Read() or Write(), but + /// not both. + /// + /// + /// + /// + /// + /// The buffer into which the read data should be placed. + /// + /// + /// the offset within that data array to put the first byte read. + /// + /// the number of bytes to read. + /// + /// the number of bytes read + public override int Read(byte[] buffer, int offset, int count) + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + return _baseStream.Read(buffer, offset, count); + } + + /// + /// Calling this method always throws a . + /// + /// + /// The offset to seek to.... + /// IF THIS METHOD ACTUALLY DID ANYTHING. + /// + /// + /// The reference specifying how to apply the offset.... IF + /// THIS METHOD ACTUALLY DID ANYTHING. + /// + /// + /// nothing. This method always throws. + public override long Seek(long offset, System.IO.SeekOrigin origin) + { + throw new NotSupportedException(); + } + + /// + /// Calling this method always throws a . + /// + /// + /// The new value for the stream length.... IF + /// THIS METHOD ACTUALLY DID ANYTHING. + /// + public override void SetLength(long value) + { + throw new NotSupportedException(); + } + + /// + /// Write data to the stream. + /// + /// + /// + /// + /// + /// If you wish to use the ZlibStream to compress data while writing, + /// you can create a ZlibStream with CompressionMode.Compress, + /// and a writable output stream. Then call Write() on that + /// ZlibStream, providing uncompressed data as input. The data sent to + /// the output stream will be the compressed form of the data written. If you + /// wish to use the ZlibStream to decompress data while writing, you + /// can create a ZlibStream with CompressionMode.Decompress, and a + /// writable output stream. Then call Write() on that stream, + /// providing previously compressed data. The data sent to the output stream + /// will be the decompressed form of the data written. + /// + /// + /// + /// A ZlibStream can be used for Read() or Write(), but not both. + /// + /// + /// The buffer holding data to write to the stream. + /// the offset within that data array to find the first byte to write. + /// the number of bytes to write. + public override void Write(byte[] buffer, int offset, int count) + { + if (_disposed) throw new ObjectDisposedException("ZlibStream"); + _baseStream.Write(buffer, offset, count); + } + #endregion + + + /// + /// Compress a string into a byte array using ZLIB. + /// + /// + /// + /// Uncompress it with . + /// + /// + /// + /// + /// + /// + /// + /// A string to compress. The string will first be encoded + /// using UTF8, then compressed. + /// + /// + /// The string in compressed form + public static byte[] CompressString(String s) + { + using (var ms = new MemoryStream()) + { + Stream compressor = + new ZlibStream(ms, CompressionMode.Compress, CompressionLevel.BestCompression); + ZlibBaseStream.CompressString(s, compressor); + return ms.ToArray(); + } + } + + + /// + /// Compress a byte array into a new byte array using ZLIB. + /// + /// + /// + /// Uncompress it with . + /// + /// + /// + /// + /// + /// + /// A buffer to compress. + /// + /// + /// The data in compressed form + public static byte[] CompressBuffer(byte[] b) + { + using (var ms = new MemoryStream()) + { + Stream compressor = + new ZlibStream( ms, CompressionMode.Compress, CompressionLevel.BestCompression ); + + ZlibBaseStream.CompressBuffer(b, compressor); + return ms.ToArray(); + } + } + + + /// + /// Uncompress a ZLIB-compressed byte array into a single string. + /// + /// + /// + /// + /// + /// + /// A buffer containing ZLIB-compressed data. + /// + /// + /// The uncompressed string + public static String UncompressString(byte[] compressed) + { + using (var input = new MemoryStream(compressed)) + { + Stream decompressor = + new ZlibStream(input, CompressionMode.Decompress); + + return ZlibBaseStream.UncompressString(compressed, decompressor); + } + } + + + /// + /// Uncompress a ZLIB-compressed byte array into a byte array. + /// + /// + /// + /// + /// + /// + /// A buffer containing ZLIB-compressed data. + /// + /// + /// The data in uncompressed form + public static byte[] UncompressBuffer(byte[] compressed) + { + using (var input = new MemoryStream(compressed)) + { + Stream decompressor = + new ZlibStream( input, CompressionMode.Decompress ); + + return ZlibBaseStream.UncompressBuffer(compressed, decompressor); + } + } + + } + + +} \ No newline at end of file diff --git a/Resources/Libraries/FJ.Core/FJ.Core.dll b/Resources/Libraries/FJ.Core/FJ.Core.dll new file mode 100644 index 0000000000000000000000000000000000000000..b2a88282849648737be345f57a81bb9776dbdc70 GIT binary patch literal 55808 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Μ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

ci&VZ3`R5tou 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≥>*Tz)lCyFX@e~dD6!?N|9U$Chc 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 + + + BitMiracle.LibTiff.NET + + + +

+ Regenerated line info.
+ Possible values for .CLEANFAXDATA tag. +
+ + + + No errors detected. + + + + + Receiver regenerated lines. + + + + + Uncorrected errors exist. + + + + + Color curve accuracy.
+ Possible values for .COLORRESPONSEUNIT tag. +
+
+ + + Tenths of a unit. + + + + + Hundredths of a unit. + + + + + Thousandths of a unit. + + + + + Ten-thousandths of a unit. + + + + + Hundred-thousandths. + + + + + Compression scheme.
+ Possible values for .COMPRESSION tag. +
+
+ + + Dump mode. + + + + + CCITT modified Huffman RLE. + + + + + CCITT Group 3 fax encoding. + + + + + CCITT T.4 (TIFF 6 name for CCITT Group 3 fax encoding). + + + + + CCITT Group 4 fax encoding. + + + + + CCITT T.6 (TIFF 6 name for CCITT Group 4 fax encoding). + + + + + Lempel-Ziv & Welch. + + + + + Original JPEG / Old-style JPEG (6.0). + + + + + JPEG DCT compression. Introduced post TIFF rev 6.0. + + + + + NeXT 2-bit RLE. + + + + + CCITT RLE. + + + + + Macintosh RLE. + + + + + ThunderScan RLE. + + + + + IT8 CT w/padding. Reserved for ANSI IT8 TIFF/IT. + + + + + IT8 Linework RLE. Reserved for ANSI IT8 TIFF/IT. + + + + + IT8 Monochrome picture. Reserved for ANSI IT8 TIFF/IT. + + + + + IT8 Binary line art. Reserved for ANSI IT8 TIFF/IT. + + + + + Pixar companded 10bit LZW. Reserved for Pixar. + + + + + Pixar companded 11bit ZIP. Reserved for Pixar. + + + + + Deflate compression. + + + + + Deflate compression, as recognized by Adobe. + + + +
+ Kodak DCS encoding. + Reserved for Oceana Matrix (dev@oceana.com). + + + + + ISO JBIG. + + + + + SGI Log Luminance RLE. + + + + + SGI Log 24-bit packed. + + + + + Leadtools JPEG2000. + + + + + Information about extra samples.
+ Possible values for .EXTRASAMPLES tag. +
+
+ + + Unspecified data. + + + + + Associated alpha data. + + + + + Unassociated alpha data. + + + + + Group 3/4 format control.
+ Possible values for .FAXMODE tag. +
+
+ + + Default, include RTC. + + + + + No RTC at end of data. + + + + + No EOL code at end of row. + + + + + Byte align row. + + + + + Word align row. + + + + + TIFF Class F. + + + + + Field bits (flags) for tags. + + + + + This value is used as a base (starting) value for codec-private tags. + + + + + This value is used to signify custom tags. + + + + + This value is used to signify tags that are to be processed + but otherwise ignored.
+ This permits antiquated tags to be quietly read and discarded. Note that + a bit is allocated for ignored tags; this is understood by the + directory reading logic which uses this fact to avoid special-case handling. +
+
+ + + Last usable value for field bit. All tags values should be less than this value. + + + + + This value is used to signify pseudo-tags.
+ Pseudo-tags don't normally need field bits since they are not + written to an output file (by definition). The library also has + express logic to always query a codec for a pseudo-tag so allocating + a field bit for one is a waste. If codec wants to promote the notion + of a pseudo-tag being set or unset then it can do using + internal state flags without polluting the field bit space defined + for real tags. +
+
+ + + Holds a value of a Tiff tag. + + + + + Retrieves value converted to byte array. + + Value converted to byte array. + + + + Retrieves value converted to byte. + + The value converted to byte. + + + + Retrieves value converted to array of bytes. + + Value converted to array of bytes. + + + + Retrieves value converted to double. + + The value converted to double. + + + + Retrieves value converted to array of double values. + + Value converted to array of double values. + + + + Retrieves value converted to float. + + The value converted to float. + + + + Retrieves value converted to array of float values. + + Value converted to array of float values. + + + + Retrieves value converted to int. + + The value converted to int. + + + + Retrieves value converted to array of int values. + + Value converted to array of int values. + + + + Retrieves value converted to short. + + The value converted to short. + + + + Retrieves value converted to array of short values. + + Value converted to array of short values. + + + + Retrieves value converted to string. + + + A that represents this instance. + + + + + Retrieves value converted to uint. + + The value converted to uint. + + + + Retrieves value converted to array of uint values. + + Value converted to array of uint values. + + + + Retrieves value converted to ushort. + + The value converted to ushort. + + + + Retrieves value converted to array of ushort values. + + Value converted to array of ushort values. + + + + Gets the value. + + + + + Subfile data descriptor.
+ Possible values for .SUBFILETYPE tag. +
+
+ + + Reduced resolution version. + + + + + One page of many. + + + + + Transparency mask. + + + + + Data order within a byte.
+ Possible values for .FILLORDER tag. +
+
+ + + Most significant -> least. + + + + + Least significant -> most. + + + + + Gray scale curve accuracy.
+ Possible values for .GRAYRESPONSEUNIT tag. +
+
+ + + Tenths of a unit. + + + + + Hundredths of a unit. + + + + + Thousandths of a unit. + + + + + Ten-thousandths of a unit. + + + + + Hundred-thousandths. + + + + + Options for CCITT Group 3/4 fax encoding.
+ Possible values for .GROUP3OPTIONS / TiffTag.T4OPTIONS and + TiffTag.GROUP4OPTIONS / TiffTag.T6OPTIONS tags. +
+
+ + + Unknown (uninitialized). + + + + + 2-dimensional coding. + + + + + Data not compressed. + + + + + Fill to byte boundary. + + + + + Inks in separated image.
+ Possible values for .INKSET tag. +
+
+ + + Cyan-magenta-yellow-black color. + + + + + Multi-ink or hi-fi color. + + + + + Auto RGB<=>YCbCr convert.
+ Possible values for .JPEGCOLORMODE tag. +
+
+ + + No conversion (default). + + + + + Do auto conversion. + + + + + JPEG processing algorithm.
+ Possible values for .JPEGPROC tag. +
+
+ + + Baseline sequential. + + + + + Huffman coded lossless. + + + + + Jpeg Tables Mode.
+ Possible values for .JPEGTABLESMODE tag. +
+
+ + + None. + + + + + Include quantization tables. + + + + + Include Huffman tables. + + + + + Kind of data in subfile.
+ Possible values for .OSUBFILETYPE tag. +
+
+ + + Full resolution image data. + + + + + Reduced size image data. + + + + + One page of many. + + + + + Image orientation.
+ Possible values for .ORIENTATION tag. +
+
+ + + Row 0 top, Column 0 lhs. + + + + + Row 0 top, Column 0 rhs. + + + + + Row 0 bottom, Column 0 rhs. + + + + + Row 0 bottom, Column 0 lhs. + + + + + Row 0 lhs, Column 0 top. + + + + + Row 0 rhs, Column 0 top. + + + + + Row 0 rhs, Column 0 bottom. + + + + + Row 0 lhs, Column 0 bottom. + + + + + Photometric interpretation.
+ Possible values for .PHOTOMETRIC tag. +
+
+ + + Min value is white. + + + + + Min value is black. + + + + + RGB color model. + + + + + Color map indexed. + + + + + [obsoleted by TIFF rev. 6.0] Holdout mask. + + + + + Color separations. + + + + + CCIR 601. + + + + + 1976 CIE L*a*b*. + + + + + ICC L*a*b*. Introduced post TIFF rev 6.0 by Adobe TIFF Technote 4. + + + + + ITU L*a*b*. + + + + + CIE Log2(L). + + + + + CIE Log2(L) (u',v'). + + + + + Storage organization.
+ Possible values for .PLANARCONFIG tag. +
+
+ + + Unknown (uninitialized). + + + + + Single image plane. + + + + + Separate planes of data. + + + + + Prediction scheme w/ LZW.
+ Possible values for .PREDICTOR tag. +
+
+ + + No prediction scheme used. + + + + + Horizontal differencing. + + + + + Floating point predictor. + + + + + Units of resolutions.
+ Possible values for .RESOLUTIONUNIT tag. +
+
+ + + No meaningful units. + + + + + English. + + + + + Metric. + + + + + Data sample format.
+ Possible values for .SAMPLEFORMAT tag. +
+
+ + + Unsigned integer data + + + + + Signed integer data + + + + + IEEE floating point data + + + + + Untyped data + + + + + Complex signed int + + + + + Complex ieee floating + + + + + Thresholding used on data.
+ Possible values for .THRESHHOLDING tag. +
+
+ + + B&W art scan. + + + + + Dithered scan. + + + + + Usually Floyd-Steinberg. + + + + + Tag Image File Format (TIFF) + + + + + Gets the version of the library's assembly. + + + + + Converts a byte buffer into array of 32-bit values. + + The byte buffer. + The zero-based offset in at + which to begin converting bytes. + The number of bytes to convert. + The array of 32-bit values. + + + + Converts a byte buffer into array of 16-bit values. + + The byte buffer. + The zero-based offset in at + which to begin converting bytes. + The number of bytes to convert. + The array of 16-bit values. + + + + Writes the current state of the TIFF directory into the file to make what is currently + in the file/stream readable. + + + true if the current directory was rewritten successfully; + otherwise, false + + + + Checks whether the specified (x, y, z, plane) coordinates are within the bounds of + the image. + + The x-coordinate. + The y-coordinate. + The z-coordinate. + The sample plane. + + true if the specified coordinates are within the bounds of the image; + otherwise, false. + + + + Returns the custom client data associated with this . + + The custom client data associated with this . + + + + Initializes new instance of class and opens a stream with TIFF data + for reading or writing. + + The name for the new instance of class. + The open mode. Specifies if the file is to be opened for + reading ("r"), writing ("w"), or appending ("a") and, optionally, whether to override + certain default aspects of library operation (see remarks for + method for the list of the mode flags). + Some client data. This data is passed as parameter to every + method of the object specified by the + parameter. + An instance of the class to use for + reading, writing and seeking of TIFF data. + The new instance of class if stream is successfully + opened; otherwise, null. + + + + Closes a previously opened TIFF file. + + + + + Compares specified number of elements in two arrays. + + The first array to compare. + The second array to compare. + The number of elements to compare. + + The difference between compared elements or 0 if all elements are equal. + + + + + Computes which strip contains the specified coordinates (row, plane). + + The row. + The sample plane. + The number of the strip that contains the specified coordinates. + + + + Computes which tile contains the specified coordinates (x, y, z, plane). + + The x-coordinate. + The y-coordinate. + The z-coordinate. + The sample plane. + The number of the tile that contains the specified coordinates. + + + + Creates a new directory within file/stream. + + + + + Gets the zero-based index of the current directory. + + The zero-based index of the current directory. + + + + Retrieves the file/stream offset of the current directory. + + The file/stream offset of the current directory. + + + + Gets the current row that is being read or written. + + The current row that is being read or written. + + + + Gets the current strip that is being read or written. + + The current strip that is being read or written. + + + + Gets the current tile that is being read or written. + + The current tile that is being read or written. + + + + Gets the number of bytes occupied by the item of given type. + + The type. + The number of bytes occupied by the or 0 if unknown + data type is supplied. + + + + Computes the number of rows for a reasonable-sized strip according to the current + settings of the , + and tags and any compression-specific requirements. + + The esimated value (may be zero). + The number of rows for a reasonable-sized strip according to the current + tag settings and compression-specific requirements. + + + + Computes the pixel width and height of a reasonable-sized tile suitable for setting + up the and tags. + + The proposed tile width upon the call / tile width to use + after the call. + The proposed tile height upon the call / tile height to use + after the call. + + + + Frees and releases all resources allocated by this . + + + + + Invokes the library-wide error handling methods to (normally) write an error message + to the . + + An instance of the class. Can be null. + The method where an error is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Invokes the library-wide error handling methods to (normally) write an error message + to the . + + The method where an error is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Invokes the library-wide error handling methods to (normally) write an error message + to the . + + An instance of the class. Can be null. + The client data to be passed to error handler. + The method where an error is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Invokes the library-wide error handling methods to (normally) write an error message + to the . + + The client data to be passed to error handler. + The method where an error is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Retrieves field information for the tag with specified name. + + The name of the tag to retrieve field information for. + The field information for specified tag or null if + the field information wasn't found. + + + + Retrieves field information for the specified tag. + + The tag to retrieve field information for. + The field information for specified tag or null if + the field information wasn't found. + + + + Gets the name of the file or ID string for this . + + The name of the file or ID string for this . + + + + Retrieves the codec registered for the specified compression scheme. + + The compression scheme. + The codec registered for the specified compression scheme or null + if there is no codec registered for the given scheme. + + + + Retrieves field information for the specified tag. + + The tag to retrieve field information for. + The tiff data type to use us additional filter. + The field information for specified tag with specified type or null if + the field information wasn't found. + + + + Retrieves field information for the tag with specified name. + + The name of the tag to retrieve field information for. + The tiff data type to use us additional filter. + The field information for specified tag with specified type or null if + the field information wasn't found. + + + + Flushes pending writes to an open TIFF file. + + + true if succeeded; otherwise, false + + + + Flushes any pending image data for the specified file to be written out. + + + true if succeeded; otherwise, false + + + + Releases storage associated with current directory. + + + + + Gets the A component from ABGR value returned by + ReadRGBAImage. + + The ABGR value. + The A component from ABGR value. + + + + Gets the B component from ABGR value returned by + ReadRGBAImage. + + The ABGR value. + The B component from ABGR value. + + + + Retrieves a bit reversal table. + + if set to true then bit reversal table will be + retrieved; otherwise, the table that do not reverse bit values will be retrieved. + The bit reversal table. + + + + Gets the extra information with specified name associated with this . + + Name of the extra information to retrieve. + The extra information with specified name associated with + this or null if extra information with specified + name was not found. + + + + Retrieves an array of configured codecs, both built-in and registered by user. + + An array of configured codecs. + + + + Gets the value(s) of a tag in an open TIFF file. + + The tag. + The value(s) of a tag in an open TIFF file as array of + objects or null if there is no such tag set. + + + + Gets the value(s) of a tag in an open TIFF file or default value(s) of a tag if a tag + is not defined in the current directory and it has a default value(s). + + The tag. + + The value(s) of a tag in an open TIFF file as array of + objects or null if there is no such tag set and + tag has no default value. + + + + + Gets the G component from ABGR value returned by + ReadRGBAImage. + + The ABGR value. + The G component from ABGR value. + + + + Gets the mode with which the underlying file or stream was opened. + + The mode with which the underlying file or stream was opened. + + + + Gets the R component from ABGR value returned by + ReadRGBAImage. + + The ABGR value. + The R component from ABGR value. + + + + Gets the tiff stream. + + The tiff stream. + + + + Gets the number of elements in the custom tag list. + + The number of elements in the custom tag list. + + + + Retrieves the custom tag with specified index. + + The zero-based index of a custom tag to retrieve. + The custom tag with specified index. + + + + Gets the currently used tag methods. + + The currently used tag methods. + + + + Gets the library version string. + + The library version string. + + + + Converts array of 32-bit values into array of bytes. + + The array of 32-bit values. + The zero-based offset in at + which to begin converting bytes. + The number of 32-bit values to convert. + The byte array to store converted values at. + The zero-based offset in at + which to begin storing converted values. + + + + Gets the value indicating whether given image data was written in big-endian order. + + + true if given image data was written in big-endian order; otherwise, false. + + + + + Gets the value indicating whether the image data was in a different byte-order than + the host computer. + + + true if the image data was in a different byte-order than the host + computer or false if the TIFF file/stream and local host byte-orders are the + same. + + + + Checks whether library has working codec for the specific compression scheme. + + The scheme to check. + + true if the codec is configured and working; otherwise, false. + + + + + Gets the value indicating whether the image data is being returned in MSB-to-LSB + bit order. + + + true if the data is being returned in MSB-to-LSB bit order (i.e with bit 0 as + the most significant bit); otherwise, false. + + + + + Gets the value indicating whether the image data of this has a + tiled organization. + + + true if the image data of this has a tiled organization or + false if the image data of this is organized in strips. + + + + + Gets the value indicating whether the image data returned through the read interface + methods is being up-sampled. + + + true if the data is returned up-sampled; otherwise, false. + + + + + Returns an indication of whether the current directory is the last directory + in the file. + + + true if current directory is the last directory in the file; + otherwise, false. + + + + Merges given field information to existing one. + + The array of objects. + The number of items to use from the array. + + + + Gets the number of directories in a file. + + The number of directories in a file. + + + + Retrives the number of strips in the image. + + The number of strips in the image. + + + + Retrives the number of tiles in the image. + + The number of tiles in the image. + + + + Initializes new instance of class and opens a TIFF file for + reading or writing. + + The name of the file to open. + The open mode. Specifies if the file is to be opened for + reading ("r"), writing ("w"), or appending ("a") and, optionally, whether to override + certain default aspects of library operation (see remarks). + The new instance of class if specified file is + successfully opened; otherwise, null. + + + + Prints formatted description of the contents of the current directory to the + specified stream. + + The stream. + + + + Prints formatted description of the contents of the current directory to the + specified stream using specified print (formatting) options. + + The stream. + The print (formatting) options. + + + + Calculates the size in bytes of a complete decoded and packed raster scanline. + + The size in bytes of a complete decoded and packed raster scanline. + + + + Computes the number of bytes in a raw (i.e. not decoded) strip. + + The zero-based index of a strip. + The number of bytes in a raw strip. + + + + Computes the number of bytes in a raw (i.e. not decoded) tile. + + The zero-based index of a tile. + The number of bytes in a raw tile. + + + + Sets up the data buffer used to read raw (encoded) data from a file. + + The data buffer. + The buffer size. + + + + Reads a custom directory from the arbitrary offset within file/stream. + + The directory offset. + The array of objects to merge to + existing field information. + The number of items to use from + the array. + + true if a custom directory was read successfully; + otherwise, false + + + + Reads the contents of the next TIFF directory in an open TIFF file/stream and makes + it the current directory. + + + true if directory was successfully read; otherwise, false if an + error was encountered, or if there are no more directories to be read. + + + + Reads a strip of data from an open TIFF file/stream, decompresses it and places + specified amount of decompressed bytes into the user supplied buffer. + + The zero-based index of the strip to read. + The buffer to place decompressed strip bytes to. + The zero-based byte offset in buffer at which to begin storing + decompressed strip bytes. + The maximum number of decompressed strip bytes to be stored + to buffer. + The actual number of bytes of data that were placed in buffer or -1 if an + error was encountered. + + + + Reads a tile of data from an open TIFF file/stream, decompresses it and places + specified amount of decompressed bytes into the user supplied buffer. + + The zero-based index of the tile to read. + The buffer to place decompressed tile bytes to. + The zero-based byte offset in buffer at which to begin storing + decompressed tile bytes. + The maximum number of decompressed tile bytes to be stored + to buffer. + The actual number of bytes of data that were placed in buffer or -1 if an + error was encountered. + + + + Reads an EXIF directory from the given offset within file/stream. + + The directory offset. + + true if an EXIF directory was read successfully; + otherwise, false + + + + Reads the undecoded contents of a strip of data from an open TIFF file/stream and + places specified amount of read bytes into the user supplied buffer. + + The zero-based index of the strip to read. + The buffer to place read bytes to. + The zero-based byte offset in buffer at which to begin storing + read bytes. + The maximum number of read bytes to be stored to buffer. + The actual number of bytes of data that were placed in buffer or -1 if an + error was encountered. + + + + Reads the undecoded contents of a tile of data from an open TIFF file/stream and places + specified amount of read bytes into the user supplied buffer. + + The zero-based index of the tile to read. + The buffer to place read tile bytes to. + The zero-based byte offset in buffer at which to begin storing + read tile bytes. + The maximum number of read tile bytes to be stored to buffer. + The actual number of bytes of data that were placed in buffer or -1 if an + error was encountered. + + + + Reads the image and decodes it into RGBA format raster. + + The raster width. + The raster height. + The raster (the buffer to place decoded image data to). + + true if the image was successfully read and converted; otherwise, + false is returned if an error was encountered. + + + + Reads the image and decodes it into RGBA format raster. + + The raster width. + The raster height. + The raster (the buffer to place decoded image data to). + if set to true then an error will terminate the + operation; otherwise method will continue processing data until all the possible data + in the image have been requested. + + true if the image was successfully read and converted; otherwise, false + is returned if an error was encountered and stopOnError is false. + + + + + Reads the image and decodes it into RGBA format raster using specified raster origin. + + The raster width. + The raster height. + The raster (the buffer to place decoded image data to). + The raster origin position. + + true if the image was successfully read and converted; otherwise, false + is returned if an error was encountered. + + + + + Reads the image and decodes it into RGBA format raster using specified raster origin. + + The raster width. + The raster height. + The raster (the buffer to place decoded image data to). + The raster origin position. + if set to true then an error will terminate the + operation; otherwise method will continue processing data until all the possible data + in the image have been requested. + + true if the image was successfully read and converted; otherwise, false + is returned if an error was encountered and stopOnError is false. + + + + + Reads a whole strip of a strip-based image, decodes it and converts it to RGBA format. + + The row. + The RGBA raster. + + true if the strip was successfully read and converted; otherwise, + false + + + + Reads a whole tile of a tile-based image, decodes it and converts it to RGBA format. + + The column. + The row. + The RGBA raster. + + true if the strip was successfully read and converted; otherwise, + false + + + + Reads and decodes a scanline of data from an open TIFF file/stream. + + The buffer to place read and decoded image data to. + The zero-based index of scanline (row) to read. + + true if image data were read and decoded successfully; otherwise, false + + + + Reads and decodes a scanline of data from an open TIFF file/stream. + + The buffer to place read and decoded image data to. + The zero-based index of scanline (row) to read. + The zero-based index of the sample plane. + + true if image data were read and decoded successfully; otherwise, false + + + + Reads and decodes a scanline of data from an open TIFF file/stream. + + The buffer to place read and decoded image data to. + The zero-based byte offset in at which + to begin storing read and decoded bytes. + The zero-based index of scanline (row) to read. + The zero-based index of the sample plane. + + true if image data were read and decoded successfully; otherwise, false + + + + Reads and decodes a tile of data from an open TIFF file/stream. + + The buffer to place read and decoded image data to. + The zero-based byte offset in at which + to begin storing read and decoded bytes. + The x-coordinate of the pixel within a tile to be read and decoded. + The y-coordinate of the pixel within a tile to be read and decoded. + The z-coordinate of the pixel within a tile to be read and decoded. + The zero-based index of the sample plane. + The number of bytes in the decoded tile or -1 if an error occurred. + + + + Allocates new byte array of specified size and copies data from the existing to + the new array. + + The existing array. + The number of elements in new array. + + The new byte array of specified size with data from the existing array. + + + + + Allocates new integer array of specified size and copies data from the existing to + the new array. + + The existing array. + The number of elements in new array. + + The new integer array of specified size with data from the existing array. + + + + + Adds specified codec to a list of registered codec. + + The codec to register. + + + + Replaces specified number of bytes in with the + equivalent bit-reversed bytes. + + The buffer to replace bytes in. + The number of bytes to process. + + + + Replaces specified number of bytes in with the + equivalent bit-reversed bytes starting at specified offset. + + The buffer to replace bytes in. + The zero-based offset in at + which to begin processing bytes. + The number of bytes to process. + + + + Rewrites the contents of the current directory to the file and setup to create a new + subfile (page) in the same file. + + + true if the current directory was rewritten successfully; + otherwise, false + + + + Check the image to see if it can be converted to RGBA format. + + The error message (if any) gets placed here. + + true if the image can be converted to RGBA format; otherwise, + false is returned and contains the reason why it + is being rejected. + + + + Calculates the size in bytes of a row of data as it would be returned in a call to + , or as it would be + expected in a call to . + + The size in bytes of a row of data. + + + + Asscociates a custom data with this . + + The data to associate. + The previously associated data. + + + + Associates extra information with this . + + The information to associate with this . + The name (label) of the information. + + + + Sets the directory with specified number as the current directory. + + The zero-based number of the directory to set as the + current directory. + + true if the specified directory was set as current successfully; + otherwise, false + + + + Sets an instance of the class as custom library-wide + error and warning handler. + + An instance of the class + to set as custom library-wide error and warning handler. + + Previous error handler or null if there was no error handler set. + + + + + Sets the value(s) of a tag in a TIFF file/stream open for writing. + + The tag. + The tag value(s). + + true if tag value(s) were set successfully; otherwise, false. + + + + Sets the new ID string for this . + + The ID string for this . + The previous file name or ID string for this . + + + + Sets the new mode for the underlying file or stream. + + The new mode for the underlying file or stream. + The previous mode with which the underlying file or stream was opened. + + + + Sets the directory at specified file/stream offset as the current directory. + + The offset from the beginnig of the file/stream to the directory + to set as the current directory. + + true if the directory at specified file offset was set as current + successfully; otherwise, false + + + + Sets the tag extender method. + + The tag extender method. + Previous tag extender method. + + + + Sets the new tag methods to use. + + Tag methods. + The previously used tag methods. + + + + Setups the strips. + + + true if setup successfully; otherwise, false + + + + Sets the current write offset. + + The write offset. + + + + Converts array of 16-bit values into array of bytes. + + The array of 16-bit values. + The zero-based offset in at + which to begin converting bytes. + The number of 16-bit values to convert. + The byte array to store converted values at. + The zero-based offset in at + which to begin storing converted values. + + + + Computes the number of bytes in a row-aligned strip. + + The number of bytes in a row-aligned strip + + + + Swaps the bytes in specified number of values in the array of double-precision + floating-point numbers. + + The array to swap bytes in. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of double-precision + floating-point numbers starting at specified offset. + + The array to swap bytes in. + The zero-based offset in at + which to begin swapping bytes. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of 32-bit items. + + The array to swap bytes in. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of 32-bit items + starting at specified offset. + + The array to swap bytes in. + The zero-based offset in at + which to begin swapping bytes. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of 16-bit items. + + The array to swap bytes in. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of 16-bit items starting at + specified offset. + + The array to swap bytes in. + The zero-based offset in at + which to begin swapping bytes. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of triples (24-bit items). + + The array to swap bytes in. + The number of items to swap bytes in. + + + + Swaps the bytes in specified number of values in the array of triples (24-bit items) + starting at specified offset. + + The array to swap bytes in. + The zero-based offset in at + which to begin swapping bytes. + The number of items to swap bytes in. + + + + Swaps the bytes in a single double-precision floating-point number. + + The value to swap bytes in. + + + + Swaps the bytes in a single 32-bit item. + + The value to swap bytes in. + + + + Swaps the bytes in a single 16-bit item. + + The value to swap bytes in. + + + + Compute the number of bytes in each row of a tile. + + The number of bytes in each row of a tile. + + + + Compute the number of bytes in a row-aligned tile. + + The number of bytes in a row-aligned tile. + + + + Unlinks the specified directory from the directory chain. + + The zero-based number of the directory to unlink. + + true if directory was unlinked successfully; otherwise, false. + + + + Removes specified codec from a list of registered codecs. + + The codec to remove from a list of registered codecs. + + + + Computes the number of bytes in a row-aligned strip with specified number of rows. + + The number of rows in a strip. + + The number of bytes in a row-aligned strip with specified number of rows. + + + + Computes the number of bytes in a row-aligned tile with specified number of rows. + + The number of rows in a tile. + + The number of bytes in a row-aligned tile with specified number of rows. + + + + Invokes the library-wide warning handling methods to (normally) write a warning message + to the . + + An instance of the class. Can be null. + The method in which a warning is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Invokes the library-wide warning handling methods to (normally) write a warning message + to the . + + The method in which a warning is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Invokes the library-wide warning handling methods to (normally) write a warning message + to the and passes client data to the warning handler. + + An instance of the class. Can be null. + The client data to be passed to warning handler. + The method in which a warning is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Invokes the library-wide warning handling methods to (normally) write a warning message + to the and passes client data to the warning handler. + + The client data to be passed to warning handler. + The method in which a warning is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Sets up the data buffer used to write raw (encoded) data to a file. + + The data buffer. + The buffer size. + + + + Verifies that file/stream is writable and that the directory information is + setup properly. + + If set to true then ability to write tiles will be verified; + otherwise, ability to write strips will be verified. + The name of the calling method. + + true if file/stream is writeable and the directory information is + setup properly; otherwise, false + + + + Writes the contents of the current directory to the file and setup to create a new + subfile (page) in the same file. + + + true if the current directory was written successfully; + otherwise, false + + + + Encodes and writes a strip of data to an open TIFF file/stream. + + The zero-based index of the strip to write. + The buffer with image data to be encoded and written. + The maximum number of strip bytes to be read from + . + + The number of encoded and written bytes or -1 if an error occurred. + + + + + Encodes and writes a strip of data to an open TIFF file/stream. + + The zero-based index of the strip to write. + The buffer with image data to be encoded and written. + The zero-based byte offset in at which + to begin reading bytes to be encoded and written. + The maximum number of strip bytes to be read from + . + The number of encoded and written bytes or -1 if an error occurred. + + + + Encodes and writes a tile of data to an open TIFF file/stream. + + The zero-based index of the tile to write. + The buffer with image data to be encoded and written. + The maximum number of tile bytes to be read from + . + + The number of encoded and written bytes or -1 if an error occurred. + + + + + Encodes and writes a tile of data to an open TIFF file/stream. + + The zero-based index of the tile to write. + The buffer with image data to be encoded and written. + The zero-based byte offset in at which + to begin reading bytes to be encoded and written. + The maximum number of tile bytes to be read from + . + The number of encoded and written bytes or -1 if an error occurred. + + + + Writes a strip of raw data to an open TIFF file/stream. + + The zero-based index of the strip to write. + The buffer with raw image data to be written. + The maximum number of strip bytes to be read from + . + + The number of written bytes or -1 if an error occurred. + + + + + Writes a strip of raw data to an open TIFF file/stream. + + The zero-based index of the strip to write. + The buffer with raw image data to be written. + The zero-based byte offset in at which + to begin reading bytes to be written. + The maximum number of strip bytes to be read from + . + The number of written bytes or -1 if an error occurred. + + + + Writes a tile of raw data to an open TIFF file/stream. + + The zero-based index of the tile to write. + The buffer with raw image data to be written. + The maximum number of tile bytes to be read from + . + + The number of written bytes or -1 if an error occurred. + + + + + Writes a tile of raw data to an open TIFF file/stream. + + The zero-based index of the tile to write. + The buffer with raw image data to be written. + The zero-based byte offset in at which + to begin reading bytes to be written. + The maximum number of tile bytes to be read from + . + The number of written bytes or -1 if an error occurred. + + + + Encodes and writes a scanline of data to an open TIFF file/stream. + + The buffer with image data to be encoded and written. + The zero-based index of scanline (row) to place encoded data at. + + true if image data were encoded and written successfully; otherwise, false + + + + Encodes and writes a scanline of data to an open TIFF file/stream. + + The buffer with image data to be encoded and written. + The zero-based index of scanline (row) to place encoded data at. + The zero-based index of the sample plane. + + true if image data were encoded and written successfully; otherwise, false + + + + Encodes and writes a scanline of data to an open TIFF file/stream. + + The buffer with image data to be encoded and written. + The zero-based byte offset in at which + to begin reading bytes. + The zero-based index of scanline (row) to place encoded data at. + The zero-based index of the sample plane. + + true if image data were encoded and written successfully; otherwise, false + + + + Encodes and writes a tile of data to an open TIFF file/stream. + + The buffer with image data to be encoded and written. + The x-coordinate of the pixel within a tile to be encoded and written. + The y-coordinate of the pixel within a tile to be encoded and written. + The z-coordinate of the pixel within a tile to be encoded and written. + The zero-based index of the sample plane. + + The number of encoded and written bytes or -1 if an error occurred. + + + + + Encodes and writes a tile of data to an open TIFF file/stream. + + The buffer with image data to be encoded and written. + The zero-based byte offset in at which + to begin reading bytes to be encoded and written. + The x-coordinate of the pixel within a tile to be encoded and written. + The y-coordinate of the pixel within a tile to be encoded and written. + The z-coordinate of the pixel within a tile to be encoded and written. + The zero-based index of the sample plane. + The number of encoded and written bytes or -1 if an error occurred. + + + + Delegate for a method used to image decoded spans. + + The buffer to place decoded image data to. + The zero-based byte offset in at + which to begin storing decoded bytes. + The array of black and white run lengths (white then black). + The zero-based offset in array at + which current row's run begins. + The zero-based offset in array at + which next row's run begins. + The width in pixels of the row. + + + + Delegate for LibTiff.Net extender method + + An instance of the class. + + + + Base class for all codecs within the library. + + + + + Initializes a new instance of the class. + + An instance of class. + The compression scheme for the codec. + The name of the codec. + + + + Gets a value indicating whether this codec can decode data. + + + + + Gets a value indicating whether this codec can encode data. + + + + + Cleanups the state of the codec. + + + + + Flushes any internal data buffers and terminates current operation. + + + + + Decodes one row of image data. + + The buffer to place decoded image data to. + The zero-based byte offset in at + which to begin storing decoded bytes. + The number of decoded bytes that should be placed + to . + The zero-based sample plane index. + + true if image data was decoded successfully; otherwise, false. + + + + + Decodes one strip of image data. + + The buffer to place decoded image data to. + The zero-based byte offset in at + which to begin storing decoded bytes. + The number of decoded bytes that should be placed + to . + The zero-based sample plane index. + + true if image data was decoded successfully; otherwise, false. + + + + + Decodes one tile of image data. + + The buffer to place decoded image data to. + The zero-based byte offset in at + which to begin storing decoded bytes. + The number of decoded bytes that should be placed + to . + The zero-based sample plane index. + + true if image data was decoded successfully; otherwise, false. + + + + + Calculates and/or constrains a strip size. + + The proposed strip size (may be zero or negative). + A strip size to use. + + + + Calculate and/or constrains a tile size + + The proposed tile width upon the call / tile width to use after the call. + The proposed tile height upon the call / tile height to use after the call. + + + + Encodes one row of image data. + + The buffer with image data to be encoded. + The zero-based byte offset in at + which to begin read image data. + The maximum number of encoded bytes that can be placed + to . + The zero-based sample plane index. + + true if image data was encoded successfully; otherwise, false. + + + + + Encodes one strip of image data. + + The buffer with image data to be encoded. + The zero-based byte offset in at + which to begin read image data. + The maximum number of encoded bytes that can be placed + to . + The zero-based sample plane index. + + true if image data was encoded successfully; otherwise, false. + + + + + Encodes one tile of image data. + + The buffer with image data to be encoded. + The zero-based byte offset in at + which to begin read image data. + The maximum number of encoded bytes that can be placed + to . + The zero-based sample plane index. + + true if image data was encoded successfully; otherwise, false. + + + + + Initializes this instance. + + + true if initialized successfully + + + + Codec name. + + + + + Compression scheme this codec impelements. + + + + + An instance of . + + + + + Performs any actions after encoding required by the codec. + + + true if all post-encode actions succeeded; otherwise, false + + + + Prepares the decoder part of the codec for a decoding. + + The zero-based sample plane index. + + true if this codec successfully prepared its decoder part and ready + to decode data; otherwise, false. + + + + Prepares the encoder part of the codec for a encoding. + + The zero-based sample plane index. + + true if this codec successfully prepared its encoder part and ready + to encode data; otherwise, false. + + + + Seeks the specified row in the strip being processed. + + The row to seek. + + true if specified row was successfully found; otherwise, false + + + + Setups the decoder part of the codec. + + + true if this codec successfully setup its decoder part and can decode data; + otherwise, false. + + + + + Setups the encoder part of the codec. + + + true if this codec successfully setup its encoder part and can encode data; + otherwise, false. + + + + + Default error handler implementation. + + + + Initializes a new instance of the class + + + + Handles an error by writing it text to the . + + An instance of the class. Can be null. + The method where an error is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Handles an error by writing it text to the . + + An instance of the class. Can be null. + A client data. + The method where an error is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Handles a warning by writing it text to the . + + An instance of the class. Can be null. + The method where a warning is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Handles a warning by writing it text to the . + + An instance of the class. Can be null. + A client data. + The method where a warning is detected. + A composite format string (see Remarks). + An object array that contains zero or more objects to format. + + + + Represents a TIFF field information. + + + + + Initializes a new instance of the class. + + The tag to describe. + The number of values to read when reading field information or + one of , and . + The number of values to write when writing field information + or one of , and . + The type of the field value. + Index of the bit to use in "Set Fields Vector" when this instance + is merged into field info collection. Take a look at class. + If true, then it is permissible to set the tag's value even + after writing has commenced. + If true, then number of value elements should be passed to + method as second parameter (right after tag type AND + before value itself). + The name (description) of the tag this instance describes. + + + + Index of the bit to use in "Set Fields Vector" when this instance + is merged into field info collection. Take a look at class. + + + + + The name (or description) of the tag this instance describes. + + + + + If true, then it is permissible to set the tag's value even after writing has commenced. + + + + + If true, then number of value elements should be passed to + method as second parameter (right after tag type AND before values itself). + + + + + Number of values to read when reading field information or + one of , and . + + + + + marker for SamplesPerPixel-bound tags + + + + + The tag described by this instance. + + + + + Returns a that represents this instance. + + + A that represents this instance. + + + + + Type of the field values. + + + + + marker for variable length tags + + + + + marker for integer variable length tags + + + + + Number of values to write when writing field information or + one of , and . + + + + + Flags that can be passed to + method to control printing of data structures that are potentially very large. + + + + + no extra info + + + + + strips/tiles info + + + + + color/gray response curves + + + + + colormap + + + + + JPEG Q matrices + + + + + JPEG AC tables + + + + + JPEG DC tables + + + + + RGBA-style image support. Provides methods for decoding images into RGBA (or other) format. + + + + + Gets the type of alpha data present. + + + + + Gets the image bits per sample count. + + + + + Creates new instance of the class. + + + The instance of the class used to retrieve + image data. + + + if set to true then an error will terminate the conversion; otherwise "get" + methods will continue processing data until all the possible data in the image have + been requested. + + The error message (if any) gets placed here. + + New instance of the class if the image specified + by can be converted to RGBA format; otherwise, null is + returned and contains the reason why it is being + rejected. + + + + + Gets or sets the "get" method (the method that is called to produce RGBA raster). + + + + + Reads the underlaying TIFF image and decodes it into RGBA format raster. + + The raster (the buffer to place decoded image data to). + The zero-based byte offset in at which + to begin storing decoded bytes. + The raster width. + The raster height. + + true if the image was successfully read and decoded; otherwise, + false. + + + + Gets the image height. + + + + + Gets a value indicating whether image data has contiguous (packed) or separated samples. + + + + + Gets the image orientation. + + + + + Gets the photometric interpretation of the image data. + + + + + Gets or sets the "put" method (the method that is called to pack pixel data in the + raster) used when converting contiguously packed samples. + + + + + Gets or sets the "put" method (the method that is called to pack pixel data in the + raster) used when converting separated samples. + + + + + Gets or sets the requested orientation. + + + + + Gets the image samples per pixel count. + + + + + Gets the image width. + + + + + Delegate for "get" method (the method that is called to produce RGBA raster). + + An instance of the class. + The raster (the buffer to place decoded image data to). + The zero-based byte offset in at which + to begin storing decoded bytes. + The raster width. + The raster height. + + true if the image was successfully read and decoded; otherwise, + false. + + + + Delegate for "put" method (the method that is called to pack pixel data in the raster) + used when converting contiguously packed samples. + + An instance of the class. + The raster (the buffer to place decoded image data to). + The zero-based byte offset in at + which to begin storing decoded bytes. + The value that should be added to + after each row processed. + The x-coordinate of the first pixel in block of pixels to be decoded. + The y-coordinate of the first pixel in block of pixels to be decoded. + The block width. + The block height. + The buffer with image data. + The zero-based byte offset in at + which to begin reading image bytes. + The value that should be added to + after each row processed. + + + + Delegate for "put" method (the method that is called to pack pixel data in the raster) + used when converting separated samples. + + An instance of the class. + The raster (the buffer to place decoded image data to). + The zero-based byte offset in at + which to begin storing decoded bytes. + The value that should be added to + after each row processed. + The x-coordinate of the first pixel in block of pixels to be decoded. + The y-coordinate of the first pixel in block of pixels to be decoded. + The block width. + The block height. + The buffer with image data. + The zero-based byte offset in at + which to begin reading image bytes that constitute first sample plane. + The zero-based byte offset in at + which to begin reading image bytes that constitute second sample plane. + The zero-based byte offset in at + which to begin reading image bytes that constitute third sample plane. + The zero-based byte offset in at + which to begin reading image bytes that constitute fourth sample plane. + The value that should be added to , + , and + after each row processed. + + + + A stream used by the library for TIFF reading and writing. + + + + Initializes a new instance of the class + + + + Closes the current stream. + + A client data (by default, an underlying stream). + + + + Reads a sequence of bytes from the stream and advances the position within the stream + by the number of bytes read. + + A client data (by default, an underlying stream). + An array of bytes. When this method returns, the + contains the specified byte array with the values between + and ( + - 1) + replaced by the bytes read from the current source. + The zero-based byte offset in at which + to begin storing the data read from the current stream. + The maximum number of bytes to be read from the current stream. + The total number of bytes read into the . This can + be less than the number of bytes requested if that many bytes are not currently + available, or zero (0) if the end of the stream has been reached. + + + + Sets the position within the current stream. + + A client data (by default, an underlying stream). + A byte offset relative to the parameter. + A value of type indicating the + reference point used to obtain the new position. + The new position within the current stream. + + + + Gets the length in bytes of the stream. + + A client data (by default, an underlying stream). + The length of the stream in bytes. + + + + Writes a sequence of bytes to the current stream and advances the current position + within this stream by the number of bytes written. + + A client data (by default, an underlying stream). + An array of bytes. This method copies + bytes from to the current stream. + The zero-based byte offset in at which + to begin copying bytes to the current stream. + The number of bytes to be written to the current stream. + + + + TIFF tag definitions. + + + + + Tag placeholder + + + + + Subfile data descriptor. + For the list of possible values, see . + + + + + [obsoleted by TIFF rev. 5.0]
+ Kind of data in subfile. For the list of possible values, see . +
+
+ + + Image width in pixels. + + + + + Image height in pixels. + + + + + Bits per channel (sample). + + + + + Data compression technique. + For the list of possible values, see . + + + + + Photometric interpretation. + For the list of possible values, see . + + + + + [obsoleted by TIFF rev. 5.0]
+ Thresholding used on data. For the list of possible values, see . +
+
+ + + [obsoleted by TIFF rev. 5.0]
+ Dithering matrix width. +
+
+ + + [obsoleted by TIFF rev. 5.0]
+ Dithering matrix height. +
+
+ + + Data order within a byte. + For the list of possible values, see . + + + + + Name of document which holds for image. + + + + + Information about image. + + + + + Scanner manufacturer name. + + + + + Scanner model name/number. + + + + + Offsets to data strips. + + + + + [obsoleted by TIFF rev. 5.0]
+ Image orientation. For the list of possible values, see . +
+
+ + + Samples per pixel. + + + + + Rows per strip of data. + + + + + Bytes counts for strips. + + + + + [obsoleted by TIFF rev. 5.0]
+ Minimum sample value. +
+
+ + + [obsoleted by TIFF rev. 5.0]
+ Maximum sample value. +
+
+ + + Pixels/resolution in x. + + + + + Pixels/resolution in y. + + + + + Storage organization. + For the list of possible values, see . + + + + + Page name image is from. + + + + + X page offset of image lhs. + + + + + Y page offset of image lhs. + + + + + [obsoleted by TIFF rev. 5.0]
+ Byte offset to free block. +
+
+ + + [obsoleted by TIFF rev. 5.0]
+ Sizes of free blocks. +
+
+ + + [obsoleted by TIFF rev. 6.0]
+ Gray scale curve accuracy. + For the list of possible values, see . +
+
+ + + [obsoleted by TIFF rev. 6.0]
+ Gray scale response curve. +
+
+ + + Options for CCITT Group 3 fax encoding. 32 flag bits. + For the list of possible values, see . + + + + + TIFF 6.0 proper name alias for GROUP3OPTIONS. + + + + + Options for CCITT Group 4 fax encoding. 32 flag bits. + For the list of possible values, see . + + + + + TIFF 6.0 proper name alias for GROUP4OPTIONS. + + + + + Units of resolutions. + For the list of possible values, see . + + + + + Page numbers of multi-page. + + + + + [obsoleted by TIFF rev. 6.0]
+ Color curve accuracy. + For the list of possible values, see . +
+
+ + + Colorimetry info. + + + + + Name & release. + + + + + Creation date and time. + + + + + Creator of image. + + + + + Machine where created. + + + + + Prediction scheme w/ LZW. + For the list of possible values, see . + + + + + Image white point. + + + + + Primary chromaticities. + + + + + RGB map for pallette image. + + + + + Highlight + shadow info. + + + + + Tile width in pixels. + + + + + Tile height in pixels. + + + + + Offsets to data tiles. + + + + + Byte counts for tiles. + + + + + Lines with wrong pixel count. + + + + + Regenerated line info. + For the list of possible values, see . + + + + + Max consecutive bad lines. + + + + + Subimage descriptors. + + + + + Inks in separated image. + For the list of possible values, see . + + + + + ASCII names of inks. + + + + + Number of inks. + + + + + 0% and 100% dot codes. + + + + + Separation target. + + + + + Information about extra samples. + For the list of possible values, see . + + + + + Data sample format. + For the list of possible values, see . + + + + + Variable MinSampleValue. + + + + + Variable MaxSampleValue. + + + + + ClipPath. Introduced post TIFF rev 6.0 by Adobe TIFF technote 2. + + + + + XClipPathUnits. Introduced post TIFF rev 6.0 by Adobe TIFF technote 2. + + + + + YClipPathUnits. Introduced post TIFF rev 6.0 by Adobe TIFF technote 2. + + + + + Indexed. Introduced post TIFF rev 6.0 by Adobe TIFF Technote 3. + + + + + JPEG table stream. Introduced post TIFF rev 6.0. + + + + + OPI Proxy. Introduced post TIFF rev 6.0 by Adobe TIFF technote. + + + + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ JPEG processing algorithm. + For the list of possible values, see . +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ Pointer to SOI marker. +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ JFIF stream length +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ Restart interval length. +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ Lossless proc predictor. +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ Lossless point transform. +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ Q matrice offsets. +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ DCT table offsets. +
+
+ + + [obsoleted by Technical Note #2 which specifies a revised JPEG-in-TIFF scheme]
+ AC coefficient offsets. +
+
+ + + RGB -> YCbCr transform. + + + + + YCbCr subsampling factors. + + + + + Subsample positioning. + For the list of possible values, see . + + + + + Colorimetry info. + + + + + XML packet. Introduced post TIFF rev 6.0 by Adobe XMP Specification, January 2004. + + + + + OPI ImageID. Introduced post TIFF rev 6.0 by Adobe TIFF technote. + + + + + Image reference points. Private tag registered to Island Graphics. + + + + + Region-xform tack point. Private tag registered to Island Graphics. + + + + + Warp quadrilateral. Private tag registered to Island Graphics. + + + + + Affine transformation matrix. Private tag registered to Island Graphics. + + + + + [obsoleted by TIFF rev. 6.0]
+ Use EXTRASAMPLE tag. Private tag registered to SGI. +
+
+ + + [obsoleted by TIFF rev. 6.0]
+ Use SAMPLEFORMAT tag. Private tag registered to SGI. +
+
+ + + Z depth of image. Private tag registered to SGI. + + + + + Z depth/data tile. Private tag registered to SGI. + + + + + Full image size in X. This tag is set when an image has been cropped out of a larger + image. It reflect width of the original uncropped image. The XPOSITION tag can be used + to determine the position of the smaller image in the larger one. + Private tag registered to Pixar. + + + + + Full image size in Y. This tag is set when an image has been cropped out of a larger + image. It reflect height of the original uncropped image. The YPOSITION can be used + to determine the position of the smaller image in the larger one. + Private tag registered to Pixar. + + + + + Texture map format. Used to identify special image modes and data used by Pixar's + texture formats. Private tag registered to Pixar. + + + + + S&T wrap modes. Used to identify special image modes and data used by Pixar's + texture formats. Private tag registered to Pixar. + + + + + Cotan(fov) for env. maps. Used to identify special image modes and data used by + Pixar's texture formats. Private tag registered to Pixar. + + + + + Used to identify special image modes and data used by Pixar's texture formats. + Private tag registered to Pixar. + + + + + Used to identify special image modes and data used by Pixar's texture formats. + Private tag registered to Pixar. + + + + + Device serial number. Private tag registered to Eastman Kodak. + + + + + Copyright string. This tag is listed in the TIFF rev. 6.0 w/ unknown ownership. + + + + + IPTC TAG from RichTIFF specifications. + + + + + Site name. Reserved for ANSI IT8 TIFF/IT. + + + + + Color seq. [RGB, CMYK, etc]. Reserved for ANSI IT8 TIFF/IT. + + + + + DDES Header. Reserved for ANSI IT8 TIFF/IT. + + + + + Raster scanline padding. Reserved for ANSI IT8 TIFF/IT. + + + + + The number of bits in short run. Reserved for ANSI IT8 TIFF/IT. + + + + + The number of bits in long run. Reserved for ANSI IT8 TIFF/IT. + + + + + LW colortable. Reserved for ANSI IT8 TIFF/IT. + + + + + BP/BL image color switch. Reserved for ANSI IT8 TIFF/IT. + + + + + BP/BL bg color switch. Reserved for ANSI IT8 TIFF/IT. + + + + + BP/BL image color value. Reserved for ANSI IT8 TIFF/IT. + + + + + BP/BL bg color value. Reserved for ANSI IT8 TIFF/IT. + + + + + MP pixel intensity value. Reserved for ANSI IT8 TIFF/IT. + + + + + HC transparency switch. Reserved for ANSI IT8 TIFF/IT. + + + + + Color characterization table. Reserved for ANSI IT8 TIFF/IT. + + + + + HC usage indicator. Reserved for ANSI IT8 TIFF/IT. + + + + + Trapping indicator (untrapped = 0, trapped = 1). Reserved for ANSI IT8 TIFF/IT. + + + + + CMYK color equivalents. + + + + + Sequence Frame Count. Private tag registered to Texas Instruments. + + + + + Private tag registered to Adobe for PhotoShop. + + + + + Pointer to EXIF private directory. This tag is documented in EXIF specification. + + + + + ICC profile data. ?? Private tag registered to Adobe. ?? + + + + + JBIG options. Private tag registered to Pixel Magic. + + + + + Pointer to GPS private directory. This tag is documented in EXIF specification. + + + + + Encoded Class 2 ses. params. Private tag registered to SGI. + + + + + Received SubAddr string. Private tag registered to SGI. + + + + + Receive time (secs). Private tag registered to SGI. + + + + + Encoded fax ses. params, Table 2/T.30. Private tag registered to SGI. + + + + + Sample value to Nits. Private tag registered to SGI. + + + + + Private tag registered to FedEx. + + + + + Pointer to Interoperability private directory. + This tag is documented in EXIF specification. + + + + + DNG version number. Introduced by Adobe DNG specification. + + + + + DNG compatibility version. Introduced by Adobe DNG specification. + + + + + Name for the camera model. Introduced by Adobe DNG specification. + + + + + Localized camera model name. Introduced by Adobe DNG specification. + + + + + CFAPattern->LinearRaw space mapping. Introduced by Adobe DNG specification. + + + + + Spatial layout of the CFA. Introduced by Adobe DNG specification. + + + + + Lookup table description. Introduced by Adobe DNG specification. + + + + + Repeat pattern size for the BlackLevel tag. Introduced by Adobe DNG specification. + + + + + Zero light encoding level. Introduced by Adobe DNG specification. + + + + + Zero light encoding level differences (columns). Introduced by Adobe DNG specification. + + + + + Zero light encoding level differences (rows). Introduced by Adobe DNG specification. + + + + + Fully saturated encoding level. Introduced by Adobe DNG specification. + + + + + Default scale factors. Introduced by Adobe DNG specification. + + + + + Origin of the final image area. Introduced by Adobe DNG specification. + + + + + Size of the final image area. Introduced by Adobe DNG specification. + + + + + XYZ->reference color space transformation matrix 1. + Introduced by Adobe DNG specification. + + + + + XYZ->reference color space transformation matrix 2. + Introduced by Adobe DNG specification. + + + + + Calibration matrix 1. Introduced by Adobe DNG specification. + + + + + Calibration matrix 2. Introduced by Adobe DNG specification. + + + + + Dimensionality reduction matrix 1. Introduced by Adobe DNG specification. + + + + + Dimensionality reduction matrix 2. Introduced by Adobe DNG specification. + + + + + Gain applied the stored raw values. Introduced by Adobe DNG specification. + + + + + Selected white balance in linear reference space. + Introduced by Adobe DNG specification. + + + + + Selected white balance in x-y chromaticity coordinates. + Introduced by Adobe DNG specification. + + + + + How much to move the zero point. Introduced by Adobe DNG specification. + + + + + Relative noise level. Introduced by Adobe DNG specification. + + + + + Relative amount of sharpening. Introduced by Adobe DNG specification. + + + + + How closely the values of the green pixels in the blue/green rows + track the values of the green pixels in the red/green rows. + Introduced by Adobe DNG specification. + + + + + Non-linear encoding range. Introduced by Adobe DNG specification. + + + + + Camera's serial number. Introduced by Adobe DNG specification. + + + + + Information about the lens. + + + + + Chroma blur radius. Introduced by Adobe DNG specification. + + + + + Relative strength of the camera's anti-alias filter. + Introduced by Adobe DNG specification. + + + + + Used by Adobe Camera Raw. Introduced by Adobe DNG specification. + + + + + Manufacturer's private data. Introduced by Adobe DNG specification. + + + + + Whether the EXIF MakerNote tag is safe to preserve along with the rest of the EXIF data. + Introduced by Adobe DNG specification. + + + + + Illuminant 1. Introduced by Adobe DNG specification. + + + + + Illuminant 2. Introduced by Adobe DNG specification. + + + + + Best quality multiplier. Introduced by Adobe DNG specification. + + + + + Unique identifier for the raw image data. Introduced by Adobe DNG specification. + + + + + File name of the original raw file. Introduced by Adobe DNG specification. + + + + + Contents of the original raw file. Introduced by Adobe DNG specification. + + + + + Active (non-masked) pixels of the sensor. Introduced by Adobe DNG specification. + + + + + List of coordinates of fully masked pixels. Introduced by Adobe DNG specification. + + + + + Used to map cameras's color space into ICC profile space. + Introduced by Adobe DNG specification. + + + + + Used to map cameras's color space into ICC profile space. + Introduced by Adobe DNG specification. + + + + + Introduced by Adobe DNG specification. + + + + + Introduced by Adobe DNG specification. + + + + + Undefined tag used by Eastman Kodak, hue shift correction data. + + + + + [pseudo tag. not written to file]
+ Group 3/4 format control. + For the list of possible values, see . +
+
+ + + [pseudo tag. not written to file]
+ Compression quality level. Quality level is on the IJG 0-100 scale. Default value is 75. +
+
+ + + [pseudo tag. not written to file]
+ Auto RGB<=>YCbCr convert. + For the list of possible values, see . +
+
+ + + [pseudo tag. not written to file]
+ For the list of possible values, see . + Default is | . +
+
+ + + [pseudo tag. not written to file]
+ G3/G4 fill function. +
+
+ + + [pseudo tag. not written to file]
+ PixarLogCodec I/O data sz. +
+
+ + + [pseudo tag. not written to file]
+ Imager mode & filter. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ Interpolation mode. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ Color balance values. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ Color correction values. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ Gamma value. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ Toe & shoulder points. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ Calibration file description. +
+
+ + + [pseudo tag. not written to file]
+ Compression quality level. + Quality level is on the ZLIB 1-9 scale. Default value is -1. +
+
+ + + [pseudo tag. not written to file]
+ PixarLog uses same scale. +
+
+ + + [pseudo tag. not written to file]
+ Area of image to acquire. + Allocated to Oceana Matrix (dev@oceana.com). +
+
+ + + [pseudo tag. not written to file]
+ SGILog user data format. +
+
+ + + [pseudo tag. not written to file]
+ SGILog data encoding control. +
+
+ + + Exposure time. + + + + + F number. + + + + + Exposure program. + + + + + Spectral sensitivity. + + + + + ISO speed rating. + + + + + Optoelectric conversion factor. + + + + + Exif version. + + + + + Date and time of original data generation. + + + + + Date and time of digital data generation. + + + + + Meaning of each component. + + + + + Image compression mode. + + + + + Shutter speed. + + + + + Aperture. + + + + + Brightness. + + + + + Exposure bias. + + + + + Maximum lens aperture. + + + + + Subject distance. + + + + + Metering mode. + + + + + Light source. + + + + + Flash. + + + + + Lens focal length. + + + + + Subject area. + + + + + Manufacturer notes. + + + + + User comments. + + + + + DateTime subseconds. + + + + + DateTimeOriginal subseconds. + + + + + DateTimeDigitized subseconds. + + + + + Supported Flashpix version. + + + + + Color space information. + + + + + Valid image width. + + + + + Valid image height. + + + + + Related audio file. + + + + + Flash energy. + + + + + Spatial frequency response. + + + + + Focal plane X resolution. + + + + + Focal plane Y resolution. + + + + + Focal plane resolution unit. + + + + + Subject location. + + + + + Exposure index. + + + + + Sensing method. + + + + + File source. + + + + + Scene type. + + + + + CFA pattern. + + + + + Custom image processing. + + + + + Exposure mode. + + + + + White balance. + + + + + Digital zoom ratio. + + + + + Focal length in 35 mm film. + + + + + Scene capture type. + + + + + Gain control. + + + + + Contrast. + + + + + Saturation. + + + + + Sharpness. + + + + + Device settings description. + + + + + Subject distance range. + + + + + Unique image ID. + + + + + Tiff tag methods. + + + + Initializes a new instance of the class + + + + Gets the value(s) of a tag in an open TIFF file. + + An instance of the class. + The tag. + The value(s) of a tag in an open TIFF file/stream as array of + objects or null if there is no such tag set. + + + + Prints formatted description of the contents of the current directory to the + specified stream using specified print (formatting) options. + + An instance of the class. + The stream to print to. + The print (formatting) options. + + + + Sets the value(s) of a tag in a TIFF file/stream open for writing. + + An instance of the class. + The tag. + The tag value(s). + + true if tag value(s) were set successfully; otherwise, false. + + + + + Tag data type. + + + + + Placeholder. + + + + + For field descriptor searching. + + + + + 8-bit unsigned integer. + + + + + 8-bit bytes with last byte null. + + + + + 16-bit unsigned integer. + + + + + 32-bit unsigned integer. + + + + + 64-bit unsigned fraction. + + + + + 8-bit signed integer. + + + + + 8-bit untyped data. + + + + + 16-bit signed integer. + + + + + 32-bit signed integer. + + + + + 64-bit signed fraction. + + + + + 32-bit IEEE floating point. + + + + + 64-bit IEEE floating point. + + + + + 32-bit unsigned integer (offset) + + + + + Subsample positioning.
+ Possible values for .YCBCRPOSITIONING tag. +
+
+ + + As in PostScript Level 2 + + + + + As in CCIR 601-1 + + + + \ No newline at end of file diff --git a/Resources/Libraries/Quartz/C5.dll b/Resources/Libraries/Quartz/C5.dll new file mode 100644 index 0000000000000000000000000000000000000000..2130d1fa206f3d5b518d8863687feda53fa93395 GIT binary patch literal 272384 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 DUP$wm#uw^Tg;I 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 z

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%0ARvnXl@O#8ZZMOyi!>(cNZ3+ zux)y-ihG{4$a8j-1vx!giJ!usQF@}oApBRQ;BgLPfs|`}7v<@((rgZ9&FC<=I$ll+ zWNj|UOOFKn$ z46h}O>7O-y=6oZb1}%r|(+J%CfKX^rS^OPQ+44*!-of|lYMb!s1YReEP;!}D_@k(N z2JlQOe5TTd&*Cq(aGuR4)meW+CU>(^SUq%zL7u#;)pLk4z9yTyS=ksZdQyA)nLf;sBfJhzvAz;BKX0M87(0!3 zN51O`tdmQ0FIsMwe!`UMsQitgrBn}|Dl}^^qoAm zcxH~ellP`V^`(sCKBY?~9!|P%S{)yf3|~TMW$IYZ2FdWHD&z+KpbCGP+%M;kZhZ9z zY>&PI4>!O5jZY}vwMNKx)QFl_u<%z)U z2nou9v2jZ?O1>Gz>}7^Gs+?ExC#b!ezoZmV4pvv2ci-l_J8veF=DRzuA+lDySdzpw z7Bs>hrh?{%D-1!7^06=3nL>Lc3qT4TWtE; zW(5`lcKR^ot1x|AVHum>Jehp{Tm33IO{1Ge!);Kw4ToAz6f#yry3^&XfC=_ttiYN`1G1#J5+7ohl zaZ(EW!`D(YcLjqCV4;yTY8sfnR(l;FvtcH^V(s<#)S5TxYdZ2%!0%h4ky%cg;6%;d zzU!eze#~sD70kXGyNoW}EURTJmsP@>$zhb<_9JkJY@~6d#ShRqZ=Z8zV)WQZzmT?j zP2W}@*uv~Fkql~QGE*84l4C*b4P-|xhEe@602jhr@Y9=nZNildZxz1D+8bT0epC!^ zQiNqugdlvgVg!3e;3pg8Yj75fk+gk9|Bh_3@n0I1jnmwCAB1mFJ{Y57--Zoe0O zfg`Dx`j%wA`YvZFN%e_oiW-_$U)Xmdm&vS@b+;`M|*0g$K z>~}OuG3%_hO>impDO7V}n{WEJSw;1x>pFYW6|0oZ1WzX7c$5IcXS~M<{`QjVfBF2z z{ng*&%F!x8$C`BY*ICcgl~&%WHxp@H`QF+)@J4B#(@Mi+S81F*XP1Vj#fgh4!FTf6 zv#OodmuF)(*p>%%-ky!ccE+=o2MBw&7pL3E*j3{~G3_(zV4&}NNIo|6UjAOqoUUpmUw>(3ug0HQOxwg)(B_qV9Uy1Zg;`%xX*mn6<*j$6y~DUEJ8SM0{$xbbR&w z6UhI2ZFMX*K2Mf2?^B!jwf_5Y7w6ZEI>Gb9Cc|PFJ$f6&#m{=%kd;LDL5VdVpbjcy z+oCc=eao!&4`l6SS68BY$mK2ij4VkX-=t8g5`I7|X5;b_am5AA=8xh=bYY?xYx^bW z^1*+eF70Ks=<*L_y@)Om{y+G8_{_Sf@Umpa-A(8Yhz?-ny@? zK1=kCJIVK-lo{=1wA$t$$a+!R2>;`t^pD%{Z_nEeR|kkZdAT`NSE6@yOXf+gq7~Y| z{P@^EPowrSTJ`t`vTouZ$yL$l)!_eA@OSszl8rasfs%2Brc7PVW4giR9M96Q+?p+R z)wktab44CVb!*Zw9FnuykxAzWxjexvQ?Rql0I#mc)q!E0`WlVLADHjWySX2;TjqZL z_GqSck=?I1rV=MT)zsdYhs8eOzpCGjvFFztUhTS|t$995eSW6;VBmly_W{?38R4aj z@y*$9vqq;@I@9Ar*plkbrt>#iEj!IvRQmc$Hzaf8KgmsO46?3&UjQQIREjI?o(#4= zr%E3HnR-5>+Q~^lR`=_f_@aRJ?bNK$eNrzzOW}38EKPMM^E`qlUey2%=sSS4I8uvFnN9VkJ(t=~;sMm0W zEBq8Cbme(GeY%p#Gf&lwCtr16t5nuKQr$W6s`wF;%*=V#I<7uliA$g4){L71&Eo>g zX6!LB4>}1yQWK00k)tqfb|n^)Hnlo-m`OyIymdfY@_riJYz_RMa=;#`+GirrXXV%w zgl~oJ?ldIZPM-r9V=$vxQud*AejZzK?;>)sKAa8TjiV5-CI22AeBP^Eo&haKz4qzu zcx4#}Ts^ai+6Gt8qd~@5{kK$O=BM#HYBB#e7Wlb*+7>Q-cRW7p-^i~X;Dcy)H&6N{ zbzm<00?;gEYMlN@K%-gi=w-V1d1@|$jq0CYqEa{ve;fH?ppBY-&~l^p@8D8L*5(ha#4Ue zh?$Q7=7_~CL;>a?W-$Vo13+g4Fb9CH2w)BX-4VbX0G34na{yQ#0n7oQ6amZupeF*D z13)1TaUe3Vl(4Ibs2oD8L+KQH=oRh{f!W0?a|ofe2s@0D}?093=guWFY}V zQGhuB3`YQS09X+L%n?hvG72yUF-IbRIRLDR0Op7#T^$9OBUY0&QGhwfVr>L42Y`bj zfH?rHivZ>TFd6~O0pQ>WU=9Ga2w;w=_%r-QX?1Qr;p{7nDH_q`wQgb#02ZKr6UC@U zG0Z`X@d#j!s00Egq5yLMn2Z4Ch{fEX02>d2#F>2mpgtZZc^@Ub8{xn${o02$>bUzH zKI9%kI_tf;a9;8QMX92M-@!BLFZ2Jv4ykb+ih#S>tWXwytQbwKI^K;HY@C0WG;_is zs2#324~>JkYlXKe2y-DKO>^QxVR2 zxH-SCTsE8Y7?RCxG3O5i-D=Js%6WvG)wv@LVz?e{&cA@`-1e4phn((2MEu&op#mr8 zw((I5D;sNJa{xFh0+<7U5@=URD1<)(19^l*c%SpwlU-pC< zYyU!@WByv}Cder^euIE^8dbN)UrpVVwMWI0Ge0I<+3fuZ->^aoJD25c>x!0cd_N@7 zeT-`}m9@i{6))pKl}JNK8Lj*^4LgARYl-f|T>ff1@uB_&;lW@ORBJ_jDzz?sX4RD8 zPr)~sRr`fMGpAbBL)Dbw&kbsH{DnD~HeN}E-MQp!_zFnA<$0_powK~9Qr^1x3jC!lrL8w& zLGX1%7~kf;m4Lv#fs1n@@%-OGlzyJF;|S=?Ii- zU&@6yDVrVc>#`ZQY^1bv8KIqRW+aku`e0E;U&w`TP(~NHZ}}+Ub8_h@@UfezZziyI zjnK+*Na41oFJH=0?@~3Yx1)b4SIW;k0NLEl=LqAY!1(rDc&jf+-}2F}prch#fh&oB zZf0G?_dwH!)fWnSL98G(X{lK1w0FnCXT(W!vAtV$Uzb9F#Yq!meH^M0ncW%|IZ`4=$SZ5DV-&z6Cf|&a& z=YExgd0;E&E96k>UXVKAX%=<9W;x@7DyMUCIWxb5B;{q<@KvhTr2DE`Yn_v7?Nvx` z$;a`4@b{#PHCky|_=hHO|AW$64Mxx(Rme8GQ`)nwcE5Z)%o6^PoE_tq@ZHz+_2BzS z(^tm#v!<^X-!Jf$`*8e9j!G~qfnDkiU#Lg0s-RFR=`SpCO9FdJx~|n!ce@zuh`6 z4VH$&KT*dflW&LRKkA6(-b>>Cku~1eAXKTp7UPfpunJ-j>Ca@a^)6l2?(W&Px036K zE>6z;MdV}Yx9=81GONXW99m3(@Bz}rTWmP|D-hQm(nD=6HXQzs3fZx_i;a|?9kspk ztthPszejDuw>7K0G6KD$2^xt&?`(orMW7EhL8~LsyPKdj5$L^5(AuH$K@s%*f?ms? ziE@mO?z@VE-W}tEJ#A5L5wM08*Ft@$J;YX~kEf5ZN)&dVJq$ z`o@CN`fxzJSuc%^FDs4J0&;YUzPx)Z7`L?nVjkfAa zcj@3Oe@tc~gM*%aJ!6QfbqrP1rQwR1+6)Fr$1(ZA!QtQko8@9X3O?rJ=m&*Q)@OD26nzd3pUNj}@aM`4RM$g&3xppA-SNl8eNHHy zwFuNEnGP!*7L!be<7-K#&80)_ZL-qgrOgK@nVtnPN{7ZJ)1hHMghCjksod849x%zY zV{fI(I?OX-yI_7c_oC8{#^d-X#+3MJv=6%WV z4O(1iUrq6J9w+H`8BqT)!DFJUvk^xT_9y0q1J{kvhndIj`4$D)5saI%)jfB&JpFsV z-SW)Tsfc#s$N6f`th{P`|7`Pd&FjX4K@?YqJOQsuc7^o8|V|*+u_{pGD?^k0B;VzEth)`H@D41DEAs{xmYSz8sDJM zn@YuMCLAJyjo*0t8}~W*KsFqX!3P`nJGeay>ug_S!-L4bbMs32DI3!(h~CAsz$^KV zCiBkd$se&Apk^FD!Oc%6*1P%RI95-s>AF_Xbj~n|6BCc85jTIHe(n=2a|tH0dH1Lc zd9CniPa>@=rAX5qxSh$*~G@jL-*xg70 zO+9llzCNnl@9~AJm8#OXf9Vtx6lsaNlKE=*0}^aT_9Uw1%w~?P@p57%Ttfydz|t(b z)(Wd64zop}CzZA3x#hoM5=V{khr8Oj`QKH}x zfX|m;*N9V4x<0j_J-$w4j?~!uJT{@U_K>;mQuI(y&YrgSCAgO~)_I~2k3{N#vMjJP zOY91FQCL(nz~85Cqnp_f;IgZl%T?%@whHN?$i~abktZTs73%J9yx+lE73ywPh=Wzj zl6gw7C!M(=RnM!~@2I@_%eYzCD(yt)@tr~zUK-!DoR_IIH37C>`Wt_7umQ(AfCd}O zR|%tmIpzW!H?g@p&H!Iy9T3^eUoUR#IHjol!M1p$f; zt>sxNZ$Z>VEq`Vl_1QK;>D5W!@+FzgbS+rD`%hWua_*F<@WgYcX$AH?fMo8;K=SGj!wRpd$qzbbA@*cE^k0TpnL$Lf_}~v}K$7M6_k@aYaVS7}=xhUoj6u*Q-=@qXchz*;L@t7Lt0O zwv^*pT90JJM!gOTJ-*pXS-nwNro}T7Rw%3Du*Y_u5j^hyK0 z-q*O&Dyu?S6;~FvtAFnVLW8DX!S99qI{E3J8jYMOf|-L#us5Bb7zy5HCp-g7r=2s3`EpqVUF&a1V+Q)?$p%PpVU!~0ryR4GWC zTsl8}Dfs`*WR`%oaN4Malh$t&l%|u^lYGZ}v%TTvsA}9gQTI$c=cnSUrq8;~l@GMq zSx09%=IqXVyE|<;9oMk?CTFmZ^dO212Ir2|r?x?L8=TolJq)+NY;w}TrJ382*t#vJ z_~8ff;8vpW{my-y+}Akw@p6CIxgRX|N1Xcvx$l&F?CfN12c@tRWeB7k0t>;_rNRA6 zg9nxd`^qiMduZv{!%Kr#c7AJ(^xD%X zb>v9rJ{@;$gLb|+K|`l0j9k3)+DicLQmn?oYdfA$2{)0-`8VLN#{7rl?~nPn;U9?k zAB=x6=6@Lep_u1YYw>%O&HqOH9%b{t9luA}{O`l>P#$}4bWaPL06?Rco~`rQN%6Te zz=#$1!>l8fx&0B+egW;rWzBi|Egx>8>hm@CSw)lJTkSq;+-H){3`;SrCkJcEfPcUK zs3~jJ^yiX!(+YL3w?f_3lT6m8p^`Ih$5y??Lzk0FyoK~haIgomFH>><3sfke9hG8z zD=$$98Cjm1V1OIngyY#bvb94rz(+>3FDqnR(bG8}q38jVcl2~bxo)!xnpV*^rq6_w zW0wW9`cCjd`+q`@Ie8pNo7kc@{Y2-ddZ;5faCiH7FdB8Yw7Juze&o(uB@+33BCWHw zYkVYv5~~vVL>Fop%^^=?EJ#5oq~l|(oSm-dnM0uKoIJtoS#gj&!R*;_kUYWcIdPCY z!R#aBAbEn>N5w(%1hePHLGo0Xm+H9R;C0Uc^L2YJP0^nZ1)pko7=Me|GH*P0ZhnBO zXj4)fyo!#gB(!IRE%yM=3?Fr$J_FMe`H_>umqN$B$u%xQb!s5rIDZr8PCp8`vZ>g3 zK#cu9hPSITLkE=L4F|;%)bk^2eF>{@M!xD!JB!*kS!`@s7e&wegN~Zu>Xt{B-SUuP zrrcdAFXM(scWK#;%p|cun+Z=*vzC^jDP&Px>PA)gU0u3Dt+2DqG`mz}xAiYt)(#qCPy66ZDe9T_L;|1Jn2y8$2<-j zGQVkNJwGAi)t01xyn&es=HZCtPCjyDWe!G zBR#bJCl0+wsukgu$_9_zLtDs6??l4RSi%-^UnD(fw2+%VW+7&lx9~dhbwqY}#j+R6 zl6_Y!``pOd=^e@@pi%CmGg+dVl=^e$Ti@2->L%vtatuvnW^~Hv>iJ_v8!rNJ*XMF0 zCr?iyf6gO{9=@vks%2_Tx=RB^+1;_SOXak zI~@Tw9O9W~WYy$)m0?XZlAj!IoJ%1-aJQt5=~^6K>7mJG=>fX$jl_vS)6>E11t2<6 zcM{M24Yx=-ofU57qZ@i77fu%&%hyNAf{_dRDjr8L9GlGLMmB7}mDa~IJqSXcy_W?e z7xhK8sj4;`rZ+Z&Hw?CLUp3j)^5iM)`OVUlrxCK%Q#NcL6D#UTGhb4%@s(x*wcgp# z&z>F2j1;CUb!Oy0`EQ#kX;!iNEzauMoq4euurGye4lie&=cZC`jEJ22rb8{~4=*7 zo)V!L?qG~O(&!|s~MV-|=Cp-%A zgJu1A-CrD!BpJU{q<6(5X;KxgVYam(r!U7NX{1^zr{BdRNd_zxX=p>UZGu^ehNU7M z7mMVUbNeEMJBY5eE8CEXEMq{@FFeLGjnm0yEID$KElcog>%yOVukt?d(VAPO>XYpL zZo{bsIE+}RUBaKP>_lhAt?3+}{LlHB_`yyw4^6uo=z9UYzB2E)gde0#72(47K&ZZ-2DTZ_z$9iaW z`k-WGQ&)22h>f|_$Pq`s8L~ivBVNz9aTWw|LtS^Oe|oixSXIR8(bu|&le3LGVzCCM z*Cwl*3dxa?jp-Ca)1%01awjyNJhhSC*vf5idZmlksd$}JhbrF2#s#q`L({8dLutjv zRBFXkpTd_bpZEZ*$zk90pu+l+eUmv8u*|A=vS2Otb>*@fn0shCe;feQ{Oc=? z`5?a%zY0HTCEMK za`!q_-<Kq^^iVVei0=~tDX_B+?{8|TMa1CzpIPQvn$^yDMS$VXC-k0cr&X=KKFDaQ1! zbA0pgF|!-Z(4<%+$o0aRy|^H3HWO~Al}E8?vOJmg9jPZukzvl7&WvoC`sU1KbcD_* zLOz$4QMyzeM|Gz;*%{rf%&i1lRchv(bGW1utH9;!(tpu0&rqLArZOpa>$jL~B^tZJ z^t{P%2S|-~de1T9)IP$b@N9-Tj}IF{k9Zzs6eOqMRQ8fn_6cBne93O-#k{Zi)2(Bx z(p5^~*iF-=Q%O7MY1&QG^%ds3MtRMpj|vRsI30z;F4EVXa*DH2U*4EcysQ8pQueZr zwP3-&Upsvv(y4Zy>dS?Rlla!|rlbNL2UQ75!J0IxvW=*b7Pfj2HSNre_vFH3MF1W) z$DWErDPy(`#>bnt^&sH38k!m@&&f-b;3EYtA1QG8NP){o3fxi($At4sghEcjCO$;obpFC#&xS+FG0t?;6IA3Ji zd=x$5@8v)SqT3SrG%JBa1Sn@!8+92ra2M4k6V)c8+Ss(jYJ=q#YJ;7Y{1KX+l2?qh zwFj#Sxb9KPOHRKjMf5xlaXjx(Zk`JkSIl9fjNjvO5g^KnWB za}Jk-a+qqrx%G7Uf=c9Du_iDs*G9!cEV_HT zYK#(GzbGvmp6;T(r)klC8oj<=5Ij{7tPhu#O?1;}-4-lJ0f^_1p5^4CnyEl6a$pY% z3>I~;<+Vd7DOvk9(rL>k>Op;6jW=U9$kS@eCt);I&`25@8)jK+I?^3Lje2@Yu12i> z7S#wyt43w3QBSN!=9fZMeD`)lbjq?v@F!!>Nv!7HCr1xu6$< z^-k56%7LC}vwlYc&l=f0M|Sh2!Vx;(V~j%QF-%8z1FY59Cb!G$xJ&>uomH!=pKbnW zs@aFJSZ>|7kMjFA^04Z@3B37T@njrfFM!c&W zy@~q7a){I1W$-MM2U_K9;dVw_g$G*|9;%dwOGBl>4S8MFIjcNeUnVbA9$bNcXL-27 zWtZW~RIeXuC;mXErX~h<4P4-Kb(6Wn~dnC>VtDJ|M4t`wX7>@c)Wh&=; z&8kXyb!nuu3hr1{8ac~(Al0fB_;!|8FQ{sH4U|~Dv$W=b>b$;ZeN^Yqwbx>aI=_h+ zrPYZVSrH6gQ*80UBzW0~~(MI{5fOswHEhL5VO)qVifsr?oci zpDOl@`MVyR47aH-rwJF0>iJ0O zk)>FUOgJazWG#x1_#Bp1dU3C{?QfQq$0}pL-A8IOMY-qm2*}#`S}vhy@FiSnz)Qe$ z>?`CXR6cYZ}orf~FRx9Ce9pG{W+94{=jny7XNKm^%nA+J| z(Y*`)aK{#EApynt{z7AVikq*E)A?J&2zwzj^Jo5IU?!q_cXy&+bYB_FT&~Qdj}*^+ z2ObD&?*x>ry^Ft%y=0NJJ%Ygg+A9H=uW=}_)=k?P;BIh0Q%~9rVoZj1(XegPCJ##Hbc0kSnx_`+t>F6tK3Z<-=yK2a`>tcXW7RW)mB6d z?^J@UeSP0!^;NBXF8{VLml&Ep4=k6ft&+yxI?~lQr>1g;z#><*2}^nxWlGPrjPEk_ zYr93*I<=)RX-i^ZywG(rOw~I3CB2}w*_M-jW-XMvc7}qT>q=aE*gWe5D1B+Zlr<|@tcvwyFfDPnE9EMp?$V!% zWns=?bBc$=V?knl;;{2f`IBg{dGa_Sb2#qt`t;2`QJ>mF!HbiHPlfF8Un+4kX-le8 z7pHyIFO(=8#)Dfa!$Ie6$nDP+Dyy&`xIG1s!ho@Jgd2d>iy5n_d4k!HxE4WQ3+BF1>26Feu+yjx@omF}aG{DBR*<}w8LqO4;KHTh1yviH3 z{NH(O#HVV9Lf=I z6_TA8SzDIN-=H)4Vi>csmZLNNEXdTJp~gEbFy`@@;uCAMeBw3lJ6G?Ko(P^1x#rXq z?m(m{E|lmWDcwm-^okBT9(jE$fwdud{ILnDJse8dty5Of$}Qt=pFWP(;+3VmojNPV znlK(-;C*+UO6$zIb7@`fsxe9-@mqCzxnn|SI2TnAXYdu!Kh5k$Ej)7M+0C$RE^J`B z(hM8vZw0Svy!a4gvZdesReDI{efXVWY~vk{_tt&`E*vEK9U+cF+;(^b_2an?eaohgg z=_)W6^yF%oB`fg3!k9i73oBR;n{#|1d8&TyNfYU-lH1MUF|)p=iDqFXA}3r|DTsbXMd`S8=QHG`YHqdOZBB(=}skcA1kpt zt4QNpdRRSLC1$OXvsSxVtI4cYVOF@q;ffyaREtW#RzKg)U>-=?nY9oqJd2b(sdpd= zvbMa*j2-R9dFo^6$gdd+enU+DcRRmO490Ga&kNE~n59iy3-D}0Go@w#nDXOH+J4vGoUs{G`6H)tYIKW9n`{m*<3es`dsIr1_k7^X+aodmU&k6Vv=8 z+cm$??hNZ=yGy=`@4xV?pRz2GathKhbB)nb&Lu^+T&C4=AlZj-t}UP{*9wH45V45T z9*#BsiXd_lf&6ve_+q}|x5agD5vyRlv@aU8@z2s^%DN?#%2PjHy1cZtCeI71srOMh zn-WlTafuG@i?Mn=gmQRNV~KjTmD8QBiCL_Iw&&57z1s!>l!>hYJ8Z7lwl=H1$@5Y! zaW3VGmssg>#JMnmqg9vMQvea75ssafwZ!EgyCZ5?ao1ud1E_^*yS@!!AzEHR;wp9g zyJbaLw~CIIsy5cLBkk9~@^X0G7wMzh+3?mv_>5M4Y+$e5=J?z3(uwfWf#B1syWg|f zcika@R?<;lYw^;l)c-)s`vrd7$>+f=_Ka)Pq#-?Bstd-b~IaD?U0C#C|xw^*l8 z0cy0A#GoCO@8)K{|GQiy!~RGfoL^ynwkgflG>5xJ4~x2bU@d6u*x9OAJq$+r+jB+lVtWp(G-UHOqCH$)m)LSs@BpQw^=akNna z@P3%T+4hRd^eD3c0XKGHoM-_J9{Uf_;Mo14K$!7hJ0fkAFp*3=X^s|9V$%U+oo~x} z>;O`5_B=h(_sl(4qw>riy4TzbH(E z!WZHWW}l67VkD?N%H~2HdnvTGd6EHFFAt<2rROT{>skPCQ+t5vm{>Th!zqaLp6oXU0aBUg1!csZDJ z9qq8-c+d-FCWLYgEBwz};D7!C{|grQcQ5c`MTh)k1Lh>?JP4hAg+GTv(5`3~>qA+) zY0Q;q7nTWsN;TRHMBfuP5Y5cbI3luDQc4`W*{z31gOO#mXHcY`5*6!kd1^a74pD0Q zw}hsBZeXnJmeWNMGJb*ZtP+%OPrOLW! zQ9f<&tiAv;7u@Tr?vTodX<%2kAhC+Novig)(%aL%iW4XuJcX7Fza@_4`y!Dd>bGri zttA%cDIvd)cuT(ZvL77o@i^QN;qZ^OS{%pK>w^bIt9w13FOBd# z&^-4S??VSx_78m7FFBC1<9Y6{>^l#v?E8G#FIL%+jdcv}xA@8IjR%aoF04WeSr0glp{OJ=S{W*C<=-b>Y-Dv4Lcg7AK* zVkR|j%2b2!=Ph4<5dN~|8whIuMj1D`x3z?BZ|!3GvP0ZlYXUdwsCG8ojQy5@;}#7P z)wx^s8R?vRqyN5H-~PGV^{G9dU5}u3KrDPNepduGM>1o7Ik0S?%kHHzV*Z;>?0^RP zcc58uHm!EuQn^87RcY+pBpb&N+B}WNZ;7TMgsZNR%sQSj{n^9nS;r;u75M3Ps#fAW zJef4oAiLVXjn|W-)4aKBSEep>?Rg9-TkZK}A`aMNV`|S?5!f~^)Sk0%YWezu*|)TO zb{7RCb?1cbgaprwl#=n6aJELzY?14YExE}P$2Z#P-~LH|VGTel7`-u%Z4FG1Wcn9I z>-W)gRtP;DAoz!QEOL-_44In~p@RIJC^SD%PBqpaVJ5$t*4msx1N#@)YK#8Knv8yuP0U8w zSDO`En;b9)aLJ0N@m(o76JjN&c{|#@0lA7M$TJgnJFq=G(y2JMn9@SoR`c~5+My0x z(Q|CDxiI>uDPAlF7q4GNGOfXF3Dz5g&%y5#*-5C04`uwru{R4xaJ@-i4i&wXZ}UR6 zJPu^lkk|A|uc8h;(m8ZQI){!{hjls!hoLLkiX30LjQR)>5Ob@k?JvBuCe@L{+Iq^s zbhq9Jw%YcqySollje!SR;QknRP+&chE+S^fZln*rLFfmws^XmL7kH16XU=M_Hc8of zSUQv_jiK4pmqch5g23+_h`g5GWj^+$)OaCf!c!OQ%_G@49`rkpM5kF+3|~shiC};| zYVEme4^VoYAjBG8v%%0l_D|-M)yZ_yJ*#3kO1~u85rn%G*P}{i)k3C!dN_!QOt<~f zL~<-so$gy0997?VvO(U`kwx`~PNG+fPOaAE;a(BWUFqNMJ!-CuYvqYd3}!d|xw%#w zWlS9J*$4e|dWShNLZ7G#Y*@QQrd$z>IL z1vmn5I6w?G-s`?3x{Ji&Y>Ku{*^{4caF~oCxy>W#J2w5-5puee@|ETazuU|5QBXa& z-e6lY#h$D`yOJGaWuxInS7bZ4o$)s=w>!Y}naRbuxyGqfyXspGkYt{&!`nT|l|p_Z zkIf>ynUnN-v}qEY#5|$PGCcoZ<86d ziP5%Lkr^BxwR7{2;acy>O?HD{b!S%;=-UQk;cBDo60NfMB+SA_S(82RHsCH$(**mrLJiKDnYaf(~u{{_W)#G_TA115epKeX*JG1?!W zjAs*Th6zY4TsdP`#ksf%OwaFGt&QY292m(pmJC88TD3HD89fZj>0F+8y-&GIAL(#VoxTbf9hCJYv=Pg?7ZHa$sQRrY!ki{g|PNpxsW1z-Jh z$~Q(F7WFCCGk55dp8JSC-Kn{c+BZGNat?oH?ql}N&VAgzxw-#`y*B}fs`>)|?|p9= z7R3!^6Li206cF4samN)EWD$2+21SuU78S(;HOeKo%B-~1EKMVq%rwn35jCyM)cmHo zN7<(JwMD-zzjMyL^Ja!c(689{_xt}T&%Dn)cRBC8`_8@ZzBg|U(x>C>BKmZieTY75 z%r2(SnzIknr}OM1^jT~6QTnVs8`g+uzJsmek-%p06Whg4Y!^SVUHrs$@e|v{PizN2 zv0nVddhwI$#kB@_of5voqi)6?@G5=L2Nw}LXN8v^flvZ}(zqOh`8pV8iuu9!NMu5OH`RZO9v zM89TgX}B*hYowUE$sFgjG|a(!XeL>=EWTg~T?o50b|vi6_=#N^Kd~$0vwoa@WKley z*9BT|y5QJ6qcv1YUyL$8*9Y%0a)cYs%0PvlWSI@?7I0CWih;*7vj-HT@mQ>%!HxL3 z^iF;AB&s|8E;PMg-!u%Hu&keHc@^>F(Keaje8#>HJ%efaEOlPS4vO#WzgwMUGTpt- zw_!P^(mKmzqB_O<)6q`Ft+i`LHh54z*=Tuasv@r_@a_`)*#UYLJM6Pc&k$CjF4f9w zHkDuj;TH1mImHW!A@-&EN+4v z$L&F4`y<>IkIKTZBl(>8EKMwXV6YfDc8-w4$=_b}slv&sUX>o(@ zAvf-6(PG1-#SPL9*R(VV%8W;&aDg!aHy~7EEBJ}^;U|`ac!xG6ph57bQYMiVUZw<( zl+*5#Yzu?2vsfg7Dm0RjIZ6Gt!}WUpk{vujtIn>vvA8vZ`EL1 zZ@pD>ZENePT46W*qN*#tQWVW|ixUR9#l;IHY*0IP^ls&5aBi5_Vw|+^%fdpETuQ+w zEPjE0DUmLc=_w*k*B!7>D10FH6!*t39r{o`W>3!qic1UFAB+ug@aY3<1>WXW#*8I! zRA_w>E0L>>?ipKlGf4FicFR;xnF?>b$3|qTSH`xwn3tYV#1(J6aSJEuX~=>Hkv?Cu zTELin0W?a(*_ZG`+|IpDU`^F8&_a3QG@gfAAXUaajw0KxQ_ANHPV&$_xgS z%aCLm1`}V{{t~w%#WuEN8X>kX;`S)mR%V@t&5CZ^F2E)*gUn|Nry^G%B>?Zu;)ZF6 zs1of>CvLu?@nVa-L(vX*PNb3JTEf%-V*)*w zCVWZRaQ{R$auB7VvDBozhpe$q+(Q`_UMfJgonhn6b6S6@fc1Vb?Wsxy7l1&?_q><>KnQ8)8A zvOGnJ#68c zqUi)w2pPvhMtI7nrh~4{DfsOmbS%Z9XP|v}9thS%wU(jdm1+ofNHkQ#92wzp_7*Z5 zt_)I}_-?rxkQJM<*R_QuH1T8Nx;CfbX*J9eSfid^u4%zSvjVATqKkb!d&^80AI_rH zYzJB=UkCQVw_q#ukG98V_n6HIYzQxC!mwj+Cl+%t?3g_!yrsQYHB?%n69?W=`m5Dh znQlibZ0$khG~18lwh_dC~9hIlrdwPF(a@|a1f*> zWhZ8#b3+HGBxaa0P03lJ0?HF$*^AgVLBaSR*bGM67>24!n~KlOG)_rK&7roUax$}w zQ-aV}0fty(MkaVBR5lP`=nefeJHr^7X3WmYh))eLL}VvGj~Qgli8g_cLK8Z6jBlUV zzC%dow(X3;ojOIGCdprw3Km1qA|VllQYbm?V&pdhDWVyTlQ=~nwHqx zl$t8yOK4U`wz1MZPDn{h>Lr|8rTj?=y;9QRGjg!QQ2ZP)C4K@lqeXiP)`s3;m?VeL z@|A5Vv4=A>V-(^tw2dvjT{y#Ium?MvQh9C^Pk71^CMV5G6$w(s$ z-gU6CJ*MRkIRC)me4yix^uxUjL9$4dMKn< z=za#I_QCf)B2~$lY95lR(e7#*l&Z~QEl5_!uvBeUKcs=F+U(c7{xFB8DxGMyC6=x=J3D0kiTTFQ@QTxbmo8gS9wRxycdc>GVHtbhQsl z56S2MQ=<~aAM+u;+Z9ulP6VxA-P5RqHdNE7RK17vfe%XPiF+NCu*}^CrJ=)m_6`q& z!&hDa9-0xKm}(r_C!+M78lea4`2AS(v>Zb! zF81QN!} zh+b+esnla-#*tpBrUV>0@Gj8c9JuQ*Hf4k~WwgeJ2Jl{uvy-9R83GiVni?2V>LLeg z3J?`qh8Cy>#(TIvqJxt7XD5xBeGsbg|tr%s(az&O$_sXXs!?Uour zEG-AorW`-Sw$)u6OFl~*3 zB3N24Yh>x+z>>GxE!8|JM*vIHWz95)e@mW+ZJtfUCo?Jz_@t&tVZI!(3ijRadUDzZ zddu#Xb%|A!w`8k!uiQ&uujppI=AJ6VbS-ZM@!ZkzZtm=Cd$***Slzk&C$h|qceY(v zs>t0?%YzNoor4~5tgaRdA5g5W2HUg<^B`h%HP}~8vAP;8)jatCVs-VKcR#TjLdCrX z>&~T?dMt6_zM^$C_~k)H>&~T@bM78^D~Q+PSzda+R8G0u!<5^Pp4f#aS`DVO)Exiv z7kET8ZeNx8H`Eyf?yT5CsHM{Bx2)trhIDB50Y>!dGVlQe^y)E9J4655cwRl`RYN$h z9z!)h{+H4Gp;&kC!5l-xy~T1U@xUhD)#H>07s+8?t32<9y!Q~tLrTYSLtr4Rs^29F zmwLFi-1#{^K-=N2u{@+Iv79P-ps_sU!N&6HG4O%J^6D^6J465bSY93GRZA?d4ns9R z{@1bmAy{`Gu^d9gJ;w5o2N}z&!zm9imWSL!EDtF^mg5Qv&dMW9nOX4VIQ%-?kn{P;TrOn{DFWmnsD96ACl`fb8(SjG=iS4zrktp2V^Z%@Uq*Xa z$4m2)46>qKbXlhCMMClLJXOjfo4_ip6Bgb5ywGZ~TAwcWW~8VR&w1NDAwTA4Dj%>|2?6F@0lfYHA96nY)#tXP=>lA;v7rT|WFSIK)ZNV!l2ZDeyI6Lt=cI zApyT9o}HFtfNvUiF-*+LO7GITb*3phBhd(DCK!X#j9IPIGfb1C{mrV1gND^GP)X*8;kE}c zDwubJoLJew0F&pt2jbE*adYhzc+}cSI5Drnto+^v2C(O04Gh(1e{~NG)n&PMN>=N@ zP+itP?17=W_Cq@g)j2RcB;)USV1V;q+yAN$3{dLf3=Gxfwg)>ffIG?^7>1@A`y^Df z7*0wURBRqJq(tl20O9pOMK6OZZ=}&`t!TZ+dPJeBD_`fS%4^`Xc1w*W*4KiRCy1o= zwS`rd>Nn0ZR9H1DY%*IWFC47&)oqq`29{aSv2s~Nxyw1#ZCW`&-pVoMI8K}LTV<Xi9>@p}sNEeFHoB zc85nc;9W3v1@B6Xq!V;h>9{bVlxol z(o>By@I16>C(}4J8xEt-3^-cZX$g31#+YQb(`>8lj-_W911%jWPzKOU zUqco&66#xl8ZGcOOi4*Iw+8*ls_hW#HY@ay=*hTWwqEEhZhq3cY~c=*afUH5JIj~^ zcbnj*lF?u}4EUy7100!51H2;Dkd=`#VFL7Qd=ss95(HJ~W!ZYUz9v_pM*2!~c6nXH z%6mz$q6+Vmoo2N1pZVMjv?#09dwnz;@Lj-khb}eMG#&gmeImZt`G3uQ(w@6@r*gZp zI27fb5te>c<@3T)#P;lf&SgFmFajhQv*J@yD>-}?Yw@f0qGq!!8(3toHMb)1zMG)# zZr*L1=1Eh&yGT{KtCwFB1-mS;G67CW85?B?HSYqPHkptiZGv?WpmJq{B>JUn0EiXi zlNim61{h%I&EhZ^nP2-&#@R*palCVoOgbgr9?m(HQY(r%$di$kz#w9+b@-1WPK zM{@({kE+FIY{RzyB>}<>ag1?+DQSTdGECX&W&K=nAhz^HtG;kg$D$8eV2FoTjH4Ce zeeP*+Karv=ysA72#y1*J;f>>9U68@IrLXzn0GL8STsE0A)hC>tokvuioaTrfrr&wwfg8ry2I{qiPQWlfPGP@V$+KzEQWSGh}6@%;J!I|q*a*axhJRjosl!ZuQu?O^4UzS~e; z(M()6ie0Zv|1H}eO)%Y=4!;Uw45a9wT@A_$Ca5IAWJ)#0rVVK{5*?Q9vTzinLzWf1oc957)7Z`3_5U0mWsc)k|ScMAsz=2 z6a4&%oHpPB1vY3fW@JE3WS9xBT<Xd#4TGvk})$eBZYo2!>U)yD>2(E1k1o( zwiKyZ8olK6O>{*dR09BlxgL^>bqd>;P`Yhz_y2r%V1L6 zwe#8@H|xc_a;DW~{RkI*89C-7LO`B-K)$k6_yC*)3*2Dqf8naTbf?Ki%?TBqD7F*w zY4NEr_*>=*rOqv~(xw|zN>%%q94Y8f+_&eV#X9PJI4p6ZDJ9W%W!iS{GgEN=+PwRM zWOFv%r@SZtzd{C6sw@ghxLxIP@u|kNr1%WDiieRC{I69a6$4~?c@+xpTXyT7jz)X} z99{Um9P5e==0w|RAf8}lPFLXt+ta%@tc}A3hO83SOX%@#_%WW$`#4@U9gQx@zzo|X z_J8+4cJJ0>l>V=WV)&Up`rSZtPXn*Q!pRWh1h@}0&4~RC?o*VyJTOPja=X5{3zxq? zwxRrP6<#pn@0A*~w9i%1E@@R54{yw02$IAD*b8155~YXWR}(eXreF!lJNer0e|l@)YlyG ztizyIK)Bn+CE_TQcO2wTZ9*i6zzV-l32m4Uws1{gmKeJN%gI?z-==pVo13$>#P+CK znOlAj$uOqFuWiEJQ@A`cn`E6xU#4rxM#@d6+(z?(GWQ~@ z#Te@Ydry6|^w4as`<{DfZ_60}|3Lplw^ZIcZF`+1mXzP=s80CRT)2ILr<=Lol}awB z>y_5IAn$oO;r<|HrY*YDNt{S`6T_$Yz-Oc*IkW*>~`2Rq6!_i5b@IL5%_uoV* z2m`hg%uHC&ya2+>p0=%R8;^wbzM@b3B`SLp;D=yq4## z!7tNjGz^TN7T?E|NWZ;poDq-LN}2SII1$PX@B`5ByV&umusj%_HkqD}={+$676GH- z{v14Xn zfxm$b5A;}>l4(dynQSz)4TRrq6N}ENFlSDsmS}}I9Uc?5sup}0Fg+gj0q#wsqj60Ty_0Clzz2BJAfOsj zO{U43+eVGf9D|wRX158Rdw{%_-OGfrU;cbDUs>5vqq~o>tqm)) zO7S9xx;(I;@giu(tJoZ3p@fjTu%2^FxIHb4RtojkaTK4@4QQmB%VRGG$7Y zIz(mk{`A6kQ6U`Ydp=lwdX6v*?Q0l3bVzjniaTA1=s06WiH(pz+GXraZE@d2kt0`63Z(z?MxqZWWL5{6>j*KY7f)2qfkce=LhFlZgfmo?(ncaxzYV&a{CS&kQ>!AIyWk22>JMK`f|>j zyJjc<-8DyEk4Kv4w%!* zYb7}!GzV?G&PtERd03i(7XCwh{os%6sC-n*z1OiA_Y($S{D4u{AN}x8Hdkf9ggt=Rm%25~g)Ud!BP;4j~i6qlsqFdoxUC>5i@#=Ay5 zEM93Gg-Y(4r)tqy^uS6(aCdVImb+sKyrsN=XI|w&6ISKr6q3TGRUo9eC$7iEx-wig zLmEa|jDcmYrOPah-s^?*knAZ5aQTQ|cY>8Gx)K(3(q)`nX*T!;hR_upT$73WWJdo7 z74UIs0&n7I5g+#xt|JGeC8lO)!d)J7zz+=3Ze~>3YZdyfimTlB>dh!RXxdH1!6})^ z@Ffz%0LwD_{oGx&>K_#kl;sSOQB&Z~P=pB{Kg-cvC;CyTv2++b@j~CoG7f>I?BVbX zS{OdB3(ulr20AzQP9Y%DUImrs>u#52G6a_tw6sL2JIsRp84whM1;n zPO5VMs^F}o6|Tzep!|QNZ}l+^F~O2nna7?=bwNA?L*a{e5ArbF+uH5D9uHjahBI3{ z3h{s4DgO^1ma>b{_v(7h>oKs#{V*eHpZH25X@7WSrxr%ajkSYQ(%=hUmE^&t*t=(m zqMP-1&okU;oP75jBaHDDbE_QnC?k#-Q{v&sG1e<;U@y)%d^4J{n(%KL{_t?y;I<*1 zF~yFhg4~$TS(8T@t3QXcjo&iXBnskV+JsEZu{Tv=b)beOF;VRJn<}dVX-)dY4Cn)& z=Yi`N0OOA_VrKYL7^^e<<#nwb8w1>F)|R<4YW+WeUBQeL9b-OV$l4l=ErqlUU^bfz|4asa2{A&*X9)W-L;2(VRTkfTvEpf?m(X-Vg z_ql9#abiI%%cT|zV`m`!Uy!0_-@04{`4h?ikgQc7Q##c5sIO-OXgiitj8ylH5k6KBPRSNM56qUqRMmdtBde)iZau-$6Ea&vJ2P=REd$=$V@**4&ij zHBW4PKtq)2BxiwiWs4f+G}5y^jWPX~R@YkTnHqrdi=ZPxdiF}|BSD_5f4i>jJmJWq ze3qmsv}-#(yEqn0-3IB(UL23xZ;#(R-jih~bZzI#1}35nc1BEhNI}_`WZq=lUY&}v zasKAq zmkFOgc@XV<{UElr6{N516%C5e&)teJJ%Y9u7Nr(Bv3H6#7wOqyO8>41?F>JJrLe4? zJ$ndC9e@-)`{B^(Lwe>@+@KixRWYUvEynzlibobtXY-2D{%49YzsKRLE}pFC;h@8M z_9$#mXDbdfc9ElRJ=yxhcr*`Dp7XS=JA(f2egtb9aRfau?+Dhg`UvKH9k%uCAjz&r zF@5S$Oy6)6^Lu@W+Sm^_k9U#B?%D~=bLRy1pO8-*ehPd2=~b6mQhNZl_3X<}@w~Y8 zDYol(5>otS99v_KMY4vE9>G(OTWLD_8Zb z&NbZY4%ZCVTv-@N6UfJuqHEZfE?-02ntg?(0!X$cnF7+4?fz=*S9*5hEA;0NUm317 zVulj?l140qWG|AjBvVP|fple0mtf9)unlK@$>#Bm*!Lv^;2i&pq~U8k-{VQnAUTKR z&aW}ge%k&Lq@E4?2777zH)z{Dkgja!H_v^eXP(zFr47m6Bx6V>T*tG12FbbC@eJKf z@{ye4LX7q}9-!oGEqpd$UXr+>4n%t|R!h@$k~$qjT^Nun=?9xsbC73x>}+Y$WKK!g$w)uZ5h+ z94%|k+L103blyOnINI_gkss^9(dxC3)0=f*<4E@==;ByMHkoQE;-5qLKI}2lU7>P) z*j%FDxvF@xeoz~>=c}kN8pp9spkpiu$Qx)obf@mhtO}2oKC7Lg3Jkg6l>p_=Dw1vto;>kpZh?ek4M4wU4r+J1B zJ@~C1o&nGD>15e0JFfQznoZ=Y=lTG?k}oD|M)V?IP1J^H6@Qbc2T>vakSK!aP5wF2 zc%p6mYiiG=$M)XhzmaaH{t0OBEq;eATSfFX=XUwv!L5?)?a-h5fts^-crBt&NcRq} zPjsGiySOLOx1`&}4Me{Y?dHv?PSqaU+rtCxRH(BaOp{aj`@Aht6G`ofI!NkB)K5}p zJM>wcJ?_K%{1Kvfd+e?6^Khc6lEzYdbL^MfdxLHw={8Wg<9r=iwjXqh_;LOQ>CThx zEI&iK>!dr&&y(&p=`M0rkA2C-0n1(F&U&;Z*a2<%fp^xUm%5Yg2i}8pkq&6tFFb+D z#XC%Q@CHgE-CQd73!gx`XQgfu>E0mSpL{0O`3~v+3$|% zedR-{^H0*%R}}j^h-c1@*m?^k!XEdbDUqKNMbwF?l`@iO2vLAChG-N~pt8aq_txZy zdplm)K)Ni)#~mRSC>x2E5*d}vlyemjW0RCEL~lvjN;wZv&PmEPdyE>NK)yJZp}bAH z3#7|d-XSWHw43N>M;y6kEBlD-osb?=j!+A}PH0)4a*1?pNtdU5WuFf%gcHqCZjx>s zkU^QN{7SlMqW=5jnjWXw@mRPs$Zjh z4R7|e(%J!|TR*rW^k!?7-VW%qp*671*OUR2GrmSM?hQ1EbU9KtgmjCgZYb$CNnIrA zc1qnaqQgLO$_6Ed=rZXxDdQa&wEhFpZsipseNAldU1g&K3^S}QP$=80Y^HL}Np}bc z?QCBY?L4Y%Azgpc9aXlGE`fBXlmn!jL%LJS2SjU#PAkQf^Igh$S~)_xVyXMY0mqKd z;c7XKT~WRw-8IscDBlv@mUM%tp)*?jt@4`#o>f84p96iTa7Uz`ME_Qt9C4hEc204I zvr4H&lr5>YBObp6lIl~rmxyjFUZg7|`a>B&x}A~+Q7wCk{#J$&eJUx2=!&FRs^v#X zV@dZn5mO(fI_uO*aUKSj_;ZMw*Xmx&8|XQru|zs`4bcoD2laKweAvGiiJa6oNw1i0B$oL-iEVEuu#1IU;>+Y~4q_LR62)SN)2}K;*C9BI-=k zO1(`qo+wcLi)d!;#kGA{YgKhZ?>-OY&4N`&Cmii})W$yFOKs(ZeQ959JR5tfflhe- zeFEeS6h!4N1H}RbJK^!;bx=1z?d`-3jJ1>$MmakZO;jfl^#U5nCaIIDTrBBQ)f~_< zHVbGhOI2r)ZWZaKsY|I`v83fhCxK$vY;_me`5O=e+U&Al=96XrebI zjiqwCiB78VRPG>93_Go+Q41Gx|S%Ci0fV_q z_d3xXA}8Huq9(_&&f2;{qQOLUbz6uI6S?TN5&b~aK=&3={g1Gmo9=C*5kwxkcZfbA zYN*>y^aqi*ZVyq@kFi{1-Frm+iF|bL6HOs%qB}seji{OKAki737P>=3e-QcW4iokM z1nX?2J4&>eC{TBd=qyo)?qedS6PUBD?gUX=qV~FzLV}1e1SPf=$wdxiAL&b5)CIBrK?3Gj>>3V9il^|8>6d7bdzYTu0E05Ijl25=StL* zC{gE5B#vg1&eMvFIxj0q)-@u!bP;Qrs58`r(9CXsjg+GEt?9$|yH4jqa(2q~aR?k| zT^B&gIoHLo{gvy}Ae*?Ygp@Dcz5w}y#}UN`mLyTO@;nZ*ujfUOM$ex?Vr?O8Rii|m z58K#iBFOEHQbF!(lnz%)#f`E-o@tZ=^1DWJKxAT#{-LCPFI ztY-;nH-PkEf3!-{o4tpA<19V^_c|pY7p^6y24Foi1JKUpwEa9tv0ouxryX1l3xeC3+aDTo`$V)yJKrCHK;Y_ zAJG~uNg}zFQr>L+KBRv}d9JlC(nsgnx8G+Mo#zRXvk;IztXKO&`*v(_`)we{!gg%l z+mIfccZlR?B)=wkn`Dg+sBJ_tkYrDi;UveC%py65az4rDNxn{U7s^B~yN5S&z2UKWCqi-GFN5sBZjp5ChT9EE29xYdatz7YB$txh zM)D()-;z|iV_6T9ElGxvj3+shCgjf@FdxqWEjafl364dk$i>Z z4w6Sno+J4yNyna8Ph*npNk)*IKym@e*GL{F`8COUy|7d>l08VqlAJ;^kK_v^w~#za z@+Xq@dSltPB!`pCCb^L0Dw5ks9w+$?NnIZ-A{ zvOCGKBp(GCndjIadp^cP&YHqDXMQBxknBdXKgnp2J}kMvw;PONl+tA&M!XRNv8?E~ zQwL%VOGs`WXmaN4@W9!S|LcKsKspXW?Hl1JkB4uAl<&f^2Cu<8VY}U6Odm0L4{T@C z_R7JieQ)p{ID<~b;(1g;@)k+^;h5qEGBVE}Bxn6e3d^I0V_7j0#Y4J|rICD$`Z)HRYnlDth)A9n-t)QiJbn#N(yN8)ZlN>to!kO^_P zk5l8;>U8X}I2>i3j>Fb*#N=!nZ670f0i@a6f5f3r#MtLNVw>Z9={QC{xu%!ca6t9?c&kHVvH6(5#A8T zRQLxYp4ompvOer${7z^~9A9Cfa}w@FP!iTAj#0J|{jiwi29o=YxYuV$es3)D;!I6O z>6skU2uhJ0l8io?2r@G7RPsKs5PO{u`zHB0$Ri@2B{p_oKSG`k><`LmKVd^7ALcaS z4UpawwnF~R6R@9bnXnUV-Z=qldvC%HT?bZwB9>|flCv8VYr{hgf6#V=l=_V$^A@F` zohwqpAbnj5+S7PaE~KYU!d^6+0DPX}g5EA)Z0n`AqZp&-pOvG{cK!vvBhlEND^(ii%2HkVSCl6*NG zt=gWB^QiaI@mPNdDf#5*5T<0JwqYiwH_OC4fh0poMv``XW--)>e&#GQ6Zh){k~>Iy z5VoW9L_KS=av_gsMYL$CEuU(L%^Q}z$Ijet`8heWZr7N7s0nB3*&l;^jHIPq&K5y! zqRvQZgQZ2G#oDl+TS~>|jhKdG?qraWd3n?DoWdR(!r~nUH}hf7OvC(}r)|@Puy>{n zYi8?n;pgwCy$=@K+t2^D+(){0t9nI<0+=qRd(+?!(g!G(n*uI!kyD^*{ zIauo7IoSGNIXiT47R*H1n55W?)-%zPE;DoWKCI`=$mX1_pP33ZY@Uhz=dGFP&FeCs zQ{xiqvSgCmPCX6VH&5*Z8E_h9_UYpw-#+~}$lD~lp9x5;%d*bIfIM^t^ZY^Et^S26 zNhBA3f!lfK{!R#y=W?xCZ!`~K9y2jN{2Z@wd}yW}nb&<5`ZJcKk>p&GFO&R` zRcw?Ie$q zyaX~b?>5PLbIi5jwP$LG4{JMTD#-4T9-G&PWDLm(BxjLaK=K8Wn?Q!J;}ps9>d%K= zn^U_DO1xGzr$j-Di1s37++34PF`qRv=hB!$at+CCB(an^&&TsH&lQrlNebsx^Pm{5>y5bbi7Re*VPqj7ANyK$J?x~m|_^>Gp z4!3PiF+@*sL$A+SfblJV!Iy1g^X8LWPI8bNrVI;0xr$QOlYAQ_*09H|IgO#sAqv^S zvrBtOdtd<`{SzP~^DdFR3DWFIbs>%g4hzvIbxC@Yj9=KjT?m`Hun#;i@z^3Pdu|cN zaB&p`>9Foe3%zVm}fqP^#nbI9t$NY=1BdY$^z}+r?CF9B(t8%fs{UrF=zk9 ztDuI+#cLoX8d75OMlZ&klSyWh%mr!gZ|5kk;@kaZh&!N_CB}(h<4wTZ5WHiYH zlIbMptegd9m#@TlyJ}?~Y`?w|Exhskdf2Z20@mhDau~@;BpGnVMQF|XhiM-s`&B-2UGBDosoZ_#=A zv|T`Q8Oaw(z5+6YZF;5Pkr4J4NFVm@E9fO`Wgh$FmBo+DW1o|}Nb)O^Kan(MqxN^& z{_B-(x_PYT`aO2@n8$kD_9NMmQo?9^ILS#MJFr=h4$s8BhO!1om?6N-*1V6_do5;4 zyI;eZ(lL@aI}$lNuyd~+YSMvyPm*oGIo0kBsC}R0L6S#Eenj#V$#Wa(H#SG1!qo&-5TmT-y*M}HYz(E3BbiEaI>~t?UnIG) z@Uu`D7YfgU#6BQmMQq-CTd=pEB>6Q--BwKT1!?x=u&t5ZWAnz7oI)}#5>xVM`vsEQ zK>9Gert@J3psWu&wsj{&+S6Mx%Hind!!FSFCAv0j2z%kfe%y*ZTB-IX;5S(lx?jCimjtz}s^P0a6y5@_LVuuZ0X-A;?6s<2 zXsvUK?O{8gi!fVQkqyIk9B0pYR>FEkf&XnZQ5l7Ja zc!}dE_C@TSkn4A14I;hg%!R&sCep+zpZBT)RO-Zf7Pt_Xa*t`*#LR5OwO=zcmT~-5(nL1yB9LO)vN>;aJXr!PJWg zTX0}wh%P%effgKDGLfj$3A4dpvE9@L9k_*Z8-(&2LIt|T4Z=9xVxycdHVEg=nr;*5 zYH73wbnxg0{T16CZ4d?b9nEwWbnxH;{T17N4Lb4t7Hs{u265a)(=pd^yuL;?fEsAj zz%`1)S8wRA*v&RwI9uF2d(qrR?pSVN7**if1c<=M~*qBQau9zU$*2|*4; zuCsVUwuGpdqn8@8Ws=ZKUhHW}=p}fPQxf{65qnM&`m8Z~UK0Anz+RMuKJ#I#C83vm z*~^m9OYqdTB=k#D_KGC*Su^&kB=k#jwm}m5tOa{r5_-vxZI*;yYRL*Ep_f{+Et1en zE!j3n=%tqIElKF5mYR1@5WP)0>}RWaOLku5WLPeMU6bXeHrT*{e6eUTZ|`=81+trx zu$Dm9-w$;~JdAV$B@J>bVMSt?H z8U?x6R=R1_2dIZeW8A%zUK(Y&2P%CuTIe3CglV+ey_eEgqeAyVRcq~^UHR|dSs=(7}^jB;*%wwGrrBSlS8&;I#@s<*; z=@xtJR$?@I&EtI~mi>o(R>ILsv8-kQs*(QWacrX`^wLOHCs63nOQYEgN$8ic?1Uur z**MlGNaRE>#j`b%&`SyIcS-1_1lGT`$cbJ`WN{kBD@JyUsDSNtzoSfGPX>#e=(7}d zQxf_NzD*D!bm*li>@D?j}6ss=w;E_ z`8K=*-{25`#m;^W4OY6|);hak4O?32#(^%|T+VJnDJtZe&Urz@5EZ`@iGRh;FGA}U z+S1U)iVjI_i{j3k#EMyfd)ebX>hnWfQfpj?e=d5utKYvk@VUWKoU z(qFM%bFT^NV;Z&dnxW=f(HwQIM%}%_`8WrYc$ep952u)(d$|D35}*exhFN6 z1?A>zw7_dEd>=#n72BT->Sc!w%0G#cY=uX|3T6z|v7 zl^V_T9$`bF%JZ6T9_U`MqVejB8ZGs%rCX)Zi{2i()f#Q|4$!^KBHCfXGWT~IAJna3 z1w8;Ob?4;fDA zUSV4$oidyOx+HSKX!xaWJsZ-AYH_$~xUSp4;smj&4eqcF%z*~WeD<3GskNj(h=vjs zbJgbtlp7k}#rdWovq%u7qR%+{Wtk6ombAJG(~1e+kF_xr0UbMqM$-*z-19DG6iG zPL@YggM1e3P@mhnUF>_JVvccXH(Nu~h7zDT>K<0Vuc#B_(q0xJ3FFdx z?1UtYOZ!+&nnVxV>62_&2%$=qp z#T?^O5sQ|DajA$sB?;qF5qnh<#-$>5LK4QML#)R@(H_R7ViqR}<5DrplZ0{UFneAS z#-$@{J5dS8sBx4X(`dZi5I1NvRkRG(1gGu9&<_o%>Op-(U66njPxTkkUn=#r#8 zJ~ix4v+%)`lbwNbXV^1>9B%onQ$A!JcYVWcCTR7 z;wvRJ^#2BEi=>wRH|%QjcO-T6{{`q{NqzkPu&cw*NE+qO^>z47q7^K|-(FvrdnJm! z&G2_rU3hCE7>oU#^)5VAki+x-_4W06n4~xTUDWz~u%zSug}gqGmGrHDBYgutRuXI3 z6lj7Z*OsmHuG}Qazhwx}3`t#EUe~$tJV_BPTdHn+zNDmVj{Vb% z2M`r7oC$dG&LSt9>5bG^=p3-0dGRQrbHL;7#p5N_3rNv>^E63~157}c_Y4n zsDOnA++mIRN}^)cE5K20%s-PkafPQbKSy-1#`gg&LH7qyKKnD^y3W82M%;&kHQWMS zR0H=TnhSgMnBKsS_0f1iOQ=FsrK1pO7;Vbr$}#^hj4htVxW zBec2=*JWZsJa6CBx8-p}V(e(oHxiX_tfd3rDGAGUev6nsSg2%jryEaP9O+C=fbyo00xZNAa>1RMMt4g}gtH6U4u0^Mif>PbLzve4y4}qS~qU7K(3|YG95`%a;wJ!SgApR-Q3YOjeUC4QfsE9w= z{(${po<0pdh;|;fAHp4`BR#`bv_Gti;7f^$Ia(dT*GWRFBlr$UXmtd?C<(2O;6Dj+ zL^~t+ZArKf5nP#pEfhPV)sfsu5M8fC@|r}#XOX-<(F#_h%S7i$-c{3OI!E(Cf|!4o z9OoDwr_mheINmh}TgYdjU7m6t&9jIK*r+bgI*&E`4DJWK>^xqhNnJKNCu;Oq7e_To zqjg=jI9uogpoyC9N|*PXQ#Dc^IqaOq3#q*ljxD5XI&2|RBWxi{Qjy)DuG3vDG`?$| zYc~IkYMJMd)74R(#?Og8a+u#WicjO$r0#jpP3PZB-J77B&VP}*gI(vl&ftGa-N~*? zfE;F`UrIPyox>MN!u^}Y$L9(i?!#leKP?rNaNJw?=3yS{#HjW-cPA=lxJQrkHj;3U z3V2tdB8GcZz_&`mJ$i!2=QH>d$M#8{qS0p8C;4N792SH++ArWwNP0f>ZTNQ15=pOz z?g3g!B)q$j?;{dkTFi@y^2tk!`6p6`o>;;^mpb&s5`IbQ(1T0)H&TZlT*`kUD&e?C z%lPk-aBr9K`g3p}ga?=Nm6Fhd&+zecg$_Nql0P|55PI+h9`QJm*!P!s9Fg$gOFTmo zw)ZlhMGXK2*%M~&7;2M7ANlPtjc@E`V#;zZECwwjMw%MXv$G@kX;_P3?Q3Ge3 z-THp#T`jbwUy19hnr=_OA6++?$@y?U7xi_Gu-94Wr+!g<6YsCJ=i|1SuOM3Hkk-GI z+g83#((L|ifwmCMqq|Al_&ZX!2y$+dEfm?U>faUU1nEjR+W9u$@djF5!qLuMJho5} z+W9V@EXWb<+{@F5<~eNW?+7$a(w6>Fd@o-v=^dc=_*SBPcBuaywvW5LiFM9%_zKGH zIuG5(lgh9KqvjDe7hj>#7XmcWQQY=g>d9LrRn^;%z-yOpl|U^?K0$~+c}NG zhuqSg*C=7g=WbtWls)7s+{rVSTQuZ`+eM9D9`YZzOBzjWVDEleqn$%)xnI%fUqjs8 zOEkJU#LxX3jcN?-?Ealb!9xeR-_R&xXq@{^D;nqilSWBHC%FGxqb#6bG@3Vbs{3ym ztsa{1ep{o$p$pyrqtPCqKQ%f8wfwEoXG5QLH$QGrYo3SMvWo^Jc2dq8~L7dJB{LiI%t#}neX07qemk&V$2VH(|ue8QujMzw~;xew6DFl@d1 zKr4FMV~|GehP~!7Sfhc%_IM1{X#B8oaNp8wSq@N?6&>}6(P%leH(aCJ4S#fv(`d`E zvmPTgIy&q}*HIc>8g|uVj7B$r#%uH!IRra3fsNX%NXf!2ii?d0iyeOS#rbaISP19(1l#6GMM(3l(xzEz*MpVB0 zY>n)reLNr2$SZoB`&^AeqFZ}Du2J9UE}lZ%sQ!gtJ2jzFIl0>85$UtX$J5*K>_>lSr&V ztW(-=MHk|nD2lIBx@mNWy`uCb5_P_!*)p}kT+dfE!lySjX!KdMHC?qKyceS7bjG_T z7P=L^$kRf24@Dz8L(Ec(&JNcjU)S2h^~g;cwT+2XH*3^2#zR-AQDn>rb&E!$VruEO zYLpyvMct-RM$8MI+ckPDX1uyXqo-m5bZ=|4DrTMMPK`Flyy3Y^BfLAX+lt1k?`pIs z<__DV(aD%URSR8;302>R{cQJ~za(L(GkVfHNA9xmPgm-=pYn14965e=VK2!0|&rywLd0p}R zP$Rtab4(+=^JAgSUO&Sd6U?>Xou7|1!aF|}8WgKEw9vTNIqC^5=d@UthM#IQFSefD zNi#X)Z0)p0IIlaS(etsL^q(sc+WByYomFaWLu-m18;x*O&nm8x0!Kvgvr1zkG28x^ z(n9KRR{1ZbwIrNX{!8g4DGA#9LK!Iu=aJ`>1W9PwIc2gWoPVBIG9{s%=apQd5=XT2 zOXX3b0tZ}~y`U6G!j;(z$`VO9kG!a?Br0~q^Y4!^|JE5q`VPc>J{a%q?bo@(qBN4Tihl|4LD}3(waZd0khc)R5F-WJ|R~36a!wq>K8s(pl1QDEGC} zOHu~tzEK8BdKz@!C{aWO4m&`1T^S|mB!=3yH)L-uva=igSHl~M!&~U3BHoy2uOP?3(JS3o^<$2p^2)SF6?AXssk z>v>aoW+&EC%yE49S#fv=sf6SB@Uv1^5{?f)D_%t6Uir_;enE~nKK!f{5f#DJr<)gi z?`#*=QpBGdeFxsY)>R{u=Pye5yQnMXuZ%W${i-b5BXYhox~13eN~gU@`Rt?79lZWf zz9%Z-IIeKD<9nzR_qkNHnnh>Tm$5gyVSRruHW)0vhM#uJ-vr=x}susNR%>V~&@4 z>!8r#sOGKqEkep?Uyoks-dK&3^vCFr-F?(&h)Ot)YE9JRL`6W8yqc;>heRznsx?>F z6BY5tVm@|np+*!79gb@L>N7+|d{xXeuU2Z0!$OB+T#!10sEBWlF?zICuSp$_4@&eTcduj`P7#wcRn16UV>qY8FuuzZCPM zYY)}oxX|Hf*h}p}RK#z@{OHkJ{ZZ<0Yz$K!J`#1Z*f{qvbu3W{$C0wHIz#H}fUd9l zvDD$X*-!mO>Y9SCpBnzLXb(rx{^~rUBHm!k7WV<_O{v52eUR$+3Fe%~=6Nr44_BWd z!Y2d9t3%Y|n(kxwp{n-@Q74Z5k!mNRd2CON$um-2DRnqb4^vMN6>*<2uX#kNKA(zm zIBLhJU5SeLQLpvxG3rxNhhuoGx>4$W1zoIqTk3E`AFkFviM15*6z}!!!_^r?B^<~1 zICZPkb&l=lF+#2XnP?Bk_fcv%Q8DlCwaRO>ntBR##T>`?v1-<7K{&pTQ+E&*@sKgE z!E+|hoDn)4?Gx4G8m;n5QfHhMIvn4V)!csx!ts5AdR7w7Cnl=yUkF|AG26US)WPSF zN;u9ECaV*Pih<60OjeIe!udq1TJyXpH_Pj3k16U`l5oyoQrVY6x6{kyX;KR%;S3^O zJ))7xGhJPCLFB~w#8kEEMWiA=ddy+3EVajFq!Ny^iy7(+q9UMkUODQeE2t~xIMD*?zoOr#21fgZ1=d@ z>03c>jR{c;)KQYIg04VKmDFggi~5AR<~xzoZ>+ud6YBo&k@8vBvGu*5R9F3gG>^rN z_48h!{y|j4Cqd4I>XSdBu88N14e?&2_W8GJW!wbsmFi8Ys{^_hRKqW* zo5$*aZk1Z+SEOaE<+yC`msEF(`f!KwsLAtX^%9-^`7Gyn$j~)v1f9kCY$?!Mb-$#| zKU!!g`D`}O>uP^tCp`zaNlhif>#C=`H_5%l??1pZUm7hR|BSbVULOB~ z_ZymS@A$Reh3YJ-1=rc{z&jLYOTuz*s`Djbxh?7Hx`arqbZ=9iBf|T|PkC=s z&k_|=o!iyFCE?ZCcD2rL=<9s;^LQ6^ySkD{+}qu*=KhX4QOkDq6p^UqE%lZptmQ4$ z;s3Dr9?(@3?F0Ahz1x=nf^-N;2oM$NkVp~<3WBdFD2Sk_5PC0C0s4{JQ|{h{fPa1e<$UKmU(UIc`OWi8e`a=fc6avIKq^Xw z&HhXzN@cTu(hZP7$<|8QN+Ppq$Kw7i{*6qXI+mBTjcHuRS*5o4-$kOe^ez5VNV)Pk zz%gaF_{DFKX0CwTxB8nS_Fexjm*gt3Ki8!ZWpn%|Jn?e<=a8U1jnW7G zv;Kf`<|w~)lxw*DTp~QrI^=&3DOU+k++E?2ztEqcDQD=!+zN;Non1O!;fQ|^6Ra{G z^;Z)LYQiex3I91JSQ$F$@2`*y)*MgytN8-dzU*oLFG%?ctX7=!FYuEL)*~NhgB!$UOfEmtHRYg+I~&S-t`*8DIKgcVj3utWI9`SCjkN0>OIg*Z#Upu-^J_ ze`_XKZ@uDAW`gzBtNt7&Sa1EtFKkK$)?2^zCm_jZ(-J?ba1D25g&bi0^E>}mhcsdR z^9TQ+LPW6s`J-RReRDt))<1vtCo#cU-miYOFv(#3^EdwjCRqRc-Je$kWGNyg@mvL= znng(yRzrPiYbIC?^{c0tU^P@#d*1_^@=kB!7Zr3hsu;zCwNXQjyO#*oMjiDO6ReGf zsHNpQlTc1r8@)%}zy#-*#nrgdB!jil5^6RRtcI3WTbCgjtcHfFc}%cw8mV?KOEOp+ zjZ)7s!P;mwwRJg?!P;mI^$ZiNjn+{U%99M%M(e2?kaCn|iSx=wtA#3%3|2}XQdcm+ zN@=WmG?ZkpQu?rZv?39#lqRUzVMMS}`iQ!w5>STNmH2Cg#_Ca|Tm{xmA5$kqk|wO1 zHdAX>CW3X-f2rlG5W%`>b2XC*)=i&OOIHP%ybgF~dYPxx6-e@FSGjK5QcZ}Wc(79X zjGD;=E2XW~%Pt)%(?(6Wk2GPWw5^)P1S_TO)L)ozZB!j`KWXCHsCu0V*GARe50DJk zM%6qfTpLxBtC0-XM%7=KaBWm={vgS4ZB)%+!nIMgS#^@(+NgS+3DzU~sd@NVjr@j1 zqCfN%^$Jq10_&!O)c*KbO}+vvkV$GaH+%o}e5LQt~tI5$o z`3kIYj#cFcHBbg?s^iqwOt7XpUcJTyYpSoSgB~JHSW}&>9%OU7a+-bqEq?M+3H26ft?~l=ctq7K~tWeb*dRUSIuF{>eL|g4YlUOBwHb6^VQx+ zxeBa_FI0bFf;&x%RHGqi<|=TfX^C3grO_eF)yhb8oL;Ryij*UuS5~Xfdt__WM3+XC zU8DAPsg?X1!(b#j0X%5l0_N6D>d#Ctw{BKTCqT(4_iQx`Dc9Q3=_@r` zjbb|9>3)BNuvgQnpQISCsohOyuscvQZvh$;%JJolYzLTLI4zq->XZk}0H1v(R_c zPngPfc}mhHrm9l5Tm3gvT`AkGUT135Mc$ECZ!$gAMc$ECwMN(v<_l8xt{TGBUCQ27 zOA^WRr5j?e8hQ&gM#?bZF8*G15K=DQx8JKKJW5sv_wDzqbsH1GeftAyGLn2(LEg7N zq>e!vYr+#6ht!EkDJDFjaY)T%8LV6$R_Cz{RxS^#OIbEs%8saOSq4vU98tF*!FlWa zkfZ83CU~~uxO#~Rp5-{MiY8DpdY0paI+h8Zn`@ z>zrB?iERFyTGb;vuh#U)&Z~owa^(|CqeDJb7kV^5S6909X6WZ?4#$J1BJ$Pt%^^QJ z|NL704heG44*gm!{3MpetkrFI=vB2OQ!F}{^)y7P4 zAN^bPNv6Zynk(1THcThGtuFPQ`V!M8-7NoiYFDN&y48}@ABpbne5Y;6;h*v=YyNX0BDO$Nd%kT1}>hdX$kAhm)yA_7YNTsZnV?3x zHVY}=f*KjxLMEt@sjWmx6@7XDZKQY#)X&uNn4o@^CU2)fS(K4IdTX{OCqqe8TU&eC zr7NMfHVBDo|&h3egr5S!;VdRk4V+n(3V$Z6%!`QjYidHMFR94k<@DFXX ztO=#Aq+Mi!Qb%gt+fgb|mde^JCU~m4vSvRIvQ)Er&&-OIwPH+-dd`tljYzcaDc@Ds znjz&1sC!jy1k0SB3oBOD-enooJxV)AGFjUL#(mlqmtGBfKoc)ueo{6zthyHEQhHc@ zt))xz!y0NGTv{2{NE_hNmaxWJic34g9@8?BsLdYN(%J{x>O2PR+d{b3!oc}#_S zzZaIMMRkFA)DK;?Y$UM3kHWfYUAvMD`k|YaLS$9#eLk$aHU)`BmHgV0OIJd>Ydevs z1$$_Fx=|`Hs(NXcnV<#xXr;T83|g?SHi8LSu%EVqNNL#nT3A2rC{qhb{k3bX3Dz?} zi|hfZK&gKY8=&<-%9V6o9jJ{ZnY54_;uUSaOIJc)(RLzHIR|MSdIrlmM4N?_f={9+ zY0F3^=Yo5}leBeA@AN1s=^&Au3(AKN(~9)MRFrEy!o!DaQA`th7x$0QS`y)0FhU#4 z1a%*&-P@aThq{l_+A=}?Mro6fpng@uM``b~4C?oqc7NidcL(0Yajnkr-pnl`DMntlHb;47%Cz!7FXb?VL>&yi8dtKX2 zg!Ow}yUYajo1pdX7p&hzZ37e3Z=#lm1oe9)e4=(=f6|2dP10l`i8%L(I^IB4r7^&&=={+9;;NeHKX?heY|!(9)2|BD1swOi+iJ+9o7O zb5rwhf7L zn5XSS$`a%I91VX{JHa$v(tPba(_%>rw6B>qN?NG>jFcmwWQ#QYl|W0J4PUI4K*|!k z`+OF@L<>Wrx-Zq5B0Bx>Dd+9W1u-DR2>6i9PZ_;Srg$`XhA{1CoUE5&q5 z(kd;I>5`q%2TiU5DKqC9xsSQD*^T?gr z3f6=)cWN7vX!d?b+vbtIqwV#`_GpJavOU@d9@$>)tVgz2%k#)`0(A(1v*sYd*|tks zi@v)ux;>|5SL>u!N_i#UkE&>8cYSAQ*}vu zuWxbx{y=`(r!tiweRm6){hCI&vXCNv`_k72|XT=$vM4S#0i&f_8T1WzDtGsUkUxdrSSeK5vN=#-1~<3C_o|b z8S8(*aHGUy{yfSI8pqebJA#>rC+8;Ky3Up*W7L5BgjFPc-?N6*#U~ z=ljcNf3)^YUrO0otuxaPQg&8LWBOCd&S~jPg$BrHf3$a)$_%jl=e3WRpx@7HzcYbN zoYz8=AisPItl(2Eh6$|Tg7z#@u2n^*a>1<;jE)OhAC`fIT+jwHfrVVqMlpd+T+~vT zz+NtDQ<=a*KGRk)frWe)$RPyA(dXJ`mO`|LAIh&Hv;Q*!<7hDb4|G{#Wh6SE(hQ9#Gu>t5%Z;-&Xxq zOD9tL444)1t9FQGaJ0Cgoo1QSbAH5cnlb`Y!RxAB^c8Ebb4|KrhL&sO=Gd zYTshX=y>#}_J>PHq^!_Ls1e9cMfmh+mp+Zq^`}(DGq= z8764?Fg=1uf%Xj7??cKFV1wa$3{tKD8;sDmGQoUZNpGJ__5v0esdrByf)P+fzs>|! zURA%z1Y^3Yu8t;6n1!qAAxtp(qx6zYFdpvH!;r=bvtMYX`}LUd5Kn%QU{LK!)%00N zxhBj+)%BvUQ<^Zws_PFh!RV;2w`YP`vAVvB$b_*{UEhF2XFBpT^7xk<(pWC;1nI>= zmcNE8gI);|^omQ`5UE)+po#WbQ~wxqAp5MT%NO)y9zd;>n)*F19WZL?ja*8oR7X#8 zDLtaTzQ(1dl^W<5U20jWpR+k3ehn#Cz_np(J!%qY=37v|)_Q9u zsNb`CFQilxR$QLdlaXiyw9(U;U<9<$|6l@}e@-_iW6PUh^Uvvz5eew`w)#^{(C=;a zHcZg(ZS|L#px@i+-I4Nf4e)t=CKI&o^LjRGf=#@j&zgey3FyuC`eh=tg7*5WQ>iR4 zHrwmTL;`H0y*?L-?7F?ahGk&aFY1-kAzrFjKIqrbm-L!0&DUSn<1#2eu=$Sq0w%Ee zM19sYl7Y>4){W^v`3hJ;7d?~-MpYL*3Tdp^G-!OKE_!RG-GiD&bPd=`$gx4?{oR5j zXN@4iJQ1YxgJx6;(zRPi89dh`D>`_ohhX$~cXNQz?-E*T4}C0_jI6bXzR;x)D)rE_ zUHZIIUp>#I?<)<`{h8Q;(yj|dzN$BNscPgHJqw9!X|leD32bSyUS$Thpb54#MX$*O zwlqZ_g(T-s*)CJ{RHRgM*5DX@s=g>7ldY7luVNX@t?Bw}^K}$^2e?uY*nXVVgqP_(S$A zB|qM3G)YlG0YL4v*w(r*L4 zQWv|Lg$Lg64-)j>5?2QO=Mq}-QoYzBr~_H@QoXWEt(2vDO_vTB%k-CAdNy)}-rJ>@ zB3J7(UFsgWUSHx;|HzH{A(w_lX6qljG&ypc9S^3{sBr#gK$bXZ4b6 zsU?0J@?zyrb-7gs^q=zEkZzSP>djnwrE;F$-lcJszt)ponqT=leT7RqEB~r@Ur(t( zjr_(umo7=#f<&WHHDqRxpImWSS}I6z-58{MhnDgXTpI>uVMB|1WYun=CvTy?Ued-4 zy;NB>j$&D;S5)JIOJ7OZ*DhVFtQ*BPK#f52m&$Ut52ReYVlQkw!vt6Cg^eLhaK&E4 z7{vrv>_v<SQu@PI)f|j_)xSt8Gpzks2FhRQ%Gh&%S zk`C&{jKNIMO2v(ICb)twZp>yXlO%U)G8QpGyOc0iF+qElFg7t&mzpJv9Z2#FNy5Q-RS@(umoFrN-;OlEzLVypAhr+`AcMIZA^hUzL(ZYb07-E@cctg0*yC zmD0vYmcja98DkPsz5+c~#lp8N83DN|c1FK6* zY7`NqHA-Jm^OcT~1f^;*fw-zL0*tcqsiVgcpEgLAA z7Cx+8l^|6f7G9;ikw>j0ZLnRH3dW{vvJhyAFk?Ftv_zP(mkC-T%s9*hEfHp%WP+9m zGd^L0mIyOGXM&apGrnemmIyPxN6NRLCBlpwOwbZxhVLyXOTGmy5oXv-&=O%rF{E4z z>KQV^ou6m!FChSETBzVf%OKX)N z!7ifryYXNb(P}Qi-k=Y<1iOLOa0zw_t?3f%4O+`3*nPB)OR)QBJ(pnj(fTgcm2Y%J zdnm~t;}X0x(!eFy4K&szc-JJ(CD=tY-X(ZTT|Jw-1iN}Z=@Pt= z^OQ@lFQb>@eJxxWykpeTLmm82y97IoK4X-^(E-P?!Bw6y8YAW6o{g=IG$t4w&l)?4 zEZ9-Fjqw!|jE*+O(6@2!QNZTg7}JR?7%OdzJxnlG+89@vV63z;%5J52Fgn^8O_^W> zv@r%T;k!x3LM9jiZH!zZ3&v3!;}e#_czDhzy$#1Z?#BC^@iJ1b1>>QuF^LHG=51?a zGr@RhYn0wjW$9LKtr7zR?Tv&T6b~%&gaDJB>l z9gWgENfSmuqS2lS#!)9@2@{N*&cz zy^PZDP&^nby^Z!vVDo*91x#S`eT_UO7%TmZsNEC~#!7#qJrj(F0mkc0FdhaNIZQAf z1{mfZiU;FipwXNO#=|Q{IuneCLB=U2u+PCp>31m}y!AH3XwC%oIn+pFf{`=SILZVg zC&>ugOYvaj3^S6LVC0N6b~3@p8D(5U%9n4it@OWUl-LLH@-3KmUo#?+a^;Su?W8P; zWVpX+vT+nCN7*xcWR(=d%z=17X;nrWjhT)PpIK#$v6bn<@OhH5adcz|>r}hMamHs% z%_OB7MR5eAh{>l0CXP2IB4vpArzR$*8C#jooZ681y72{5sSh_KPB4n0m1l_7AMQz< zXf$McporlIeclAEaMtd zhOl2^-|=UMkZ6eS3iiHZ(K&A9OfI>Sq9&UnQ#2g1mB5SU^oXLO**?@XcR}H z_jVT=;Y={sEi!5#<>Fko*ob3-xo)x1oHb#tTWp+V8O(Kyjmsp%*=Dg}9>h9WF!L=o zN-)99x7dh4%2#0KTWr)|0-KllF~MB7*m#@>t#z@{1}Rs*zqwM%Ix)cA!KG&Y zmBv*jm=#wUH<4&}@im5h2wEavfmv~_QHBX-#q~y2q+A7eB{%9Z!K}E^c$5id#ZAUD zOfV~E8|__6^1o&DLZUsj-!_K1)WN^i7|)t8V{S8MFu{zu-B`>7Gv*FsBNNP+JB{5; zFk|jAjxoWE`Hpdx31-aQ##c-*W9~72W`Y^>T|+%gmJBoIyT(0CFh{;?RAhqrbFc9r z6U>{Q^nP48=Z#>5Y^I)#gg$d@t1IAD$m5s6kEjvI1wFL#U`H!PPn zO3l(lxcB}EqyJIR%n)xTZ>@2{xQqmEuWhXHzH#p{kmV?wlW&NVM)G?=DdJG_`N)$- z`8<*xN`AM-Nuw4MywP~dXpEGrz&gW+MwUyLB;DlvV$S7s`N&v|GMY6`yXQoaLtfBM z8{1Gu^TZkB6cViByr7*iw&p|b@|%k(y=s1JM16^bt1;({nn)DyoY4{~7vr5XdVfWw zej#N?>-4{ZjVU{M4l}De``}u?97%tuGqcNR;M9;}jC5dC}d4Q=e3FT8Mr+#7##*Kuqa$kn zVw`a)-uJ6f;XAC6X^nZrcf+WLl#jb_-!PJyV889(j8jao7xzsg>U)fb$CW>fSeK$| z|6#NslDTj8{b{_&bYryKX~*ov6h3CRPcf5_@)h`+m0})cg0ETm%&;FIhkX2&mfsx2 z1mDt9&4WzvEiKI~f1NbpTUxr=p9#LDB~K@q;9FXzN!zOBEAWjf%k2Fl#e*+vS>_%l z_j=)$pl}|3NefROq#HJdSSCO6YQu_)ZEGh-_j~-7W#!W z;p*0@gc{9ePcwYr`B$2d`MZQpT z5>mc=Q@(cXQ1c=alq}3lxIy)Ul0}%AOi;2)<`pDbDXn5^zkw!=zbb(`;2!f;%n+32 zq77Cti!gx=RyFTo0vn7niz88O?>A#fhC6{jU_MGR(R0kJwI48(NhToPgJ#rC%pGmF zhS`V+=a(9{l%iB`Ira?qC`sWzEceOc_$vOm0^Kxzl>` zCOq~hp_k>AbZ6up`LY{tNDhgP^lV*P(5m>=f<_JF#*vr%A zYe-bvR^~2}SvSWO_qQ_lGZjueeRz#9JlggfMV^(E?Rn0bL4c3G`kJ^~gNV(R#si4`A>3C`@ zrH$E)>3r%}>T_mGrf*X3_djR0WBM~yt_heOnM#hA*ZpQsq*U|4@p-k|nFC3tz>&F~ znaKoof8Okl8&Og}v^O{4MwBU{!T76sdvmBotqU#jqB#O7MLaeBhuSZiU1?5qfG8DAgQ~l51P%E%^qnuSr8Ydw}$+~3nI$&{G3R_SS0WEv%9 zz09giv!$$;S(8XW4!zB>L`rsA?K*wUX1M8Rj&d-qL7o2Q(?}`eVp=O@p!tGJBg(#F zE<>V{4K~w}sAPl94Y$aK7stM}VDGTO=4d9^J8ZDI0x3s1JcE>r`%=kN zm|&%QxcLhcT;INGnkBIgawn>%{UgllOt7QWDD!eDkmW0|htz9k_tHeLhg7n8nF;og zN-;CbQYx?))EILC6YO9$)~s7TAj_(gY9`?(s=0D6s6}Pd%%h7a;xxlt!35W1QdXH{uxgZLW;4OnS(e$mD#_qFe5SdF39iFun)gPL z40cDFX)Zv@QIrX9)|q9NzYk&!NnAi?fP&6PQ3wfiX^>|He1%z1zau1x2d z&8iW>UP*75QPqjy%Jfb13=`~KG~djtK{B{9U0`;{ZD?~9*d1x1S+q9E;L3E7naKoK zri;wTIv~qYVkT^9agPG!Snw^FU1npX zTx-e1^8Q_BbEdTuWAt6-vrJni%Kg&K7n$}=lzY*bU71cu*>1Bh(?u!UZ4PC+CS`lf z*O~eTjj8CQ=5^mSGngVLwW_<cxS3q;0d6Hy!l-XyVL!u+lKC@Y4s5`aUJ~xL2lU}YHq&1V|dlRkT9))1=ArNg4BNrg@Wl z=!ebknbuG4C+Rn&Tx;)S`8K>6-UR#BIz3sw4R7Ah1iL#PHET1$?v6*zSSBd-G4oL- z7=OpiCQMN3_snKQ@_2MZ95+ufLEVp=YnqZRL7Sa0vzr0sE6`@|n+cBtjTKiWPpJF8 zxdJIixiLAT?n$%kzbGCYt3EIzk#dy6Qzq2?z)V7-em`YSL4vWewC*W$o=Y3+o-xlL z?ejw_=goVcfHYI(7lC%yJ#Y3#qLqwK&1z3leo%)`&FW0B`tzyThza(yx?nbDg8i&6 znoW_&LOwHFBIV=x%V*{yl9^MdSpLtQtabOz(@-DMW9`Vl>N>uOJsJR z>aX{`8Nu}0R7+Adq%1LcY8go_nckRsU%l&Q64Uajwd(z3&SKgy^`Uydm|K~)O>I=~ zhIx(Y@YJX3-874~gxuk7#H;oGFiRoP-H1QT`;l^$Yg1FCtR+*$_VQb%R&S$z4m%A!byPuN)2Af$Zd(ew>cb1cUzQes;@$6CnL zB7IN2Le|@?S@qR}^$J_LENh!y-e1J}0O>O;G5u7%BGyHw=}1>ub65JuQg#C=Upbim zxuknqL#gwX_`cWGqE6%2nWgM{(;}q|cPk)4!=#+)8B4s;_>l7PkhF z%&L$PUgchEEK`$=a#c!Lvsg2}@4xWriF-^%R?hmuBFuj5FEz{Zz z`BaPbGt+jI-5^qqW!w;9@=}%ZJC{*Org;z3j~VyX54XaI@LVI@n#ly`8WGk8q|X$4 zTD|%a)>e)eJ*}*yqfFt$VkN1#;l5l2pY~||NUJkamI#?XvVLW2KN8J@Rjgw!9Wbg` z8g9)`s}50C2opTF7G;$n!sl(GteQ+vvM4Kw3Et$1vTh>f%eQfdLLYzMW?5>=+p ztAD>WfvNiR#q}SsrZd%_zOw#<);y+W)7RCnZkf+hyn|_5>esN=BV~wZrthj>%i6=T zPSbPh*RjH0AkFNwqxI`rYh3!UezcX`o@B2~KVSbLYXyE#AWMv$o>xE4s{azn7EJ%9 z{=-%iq+Dy;^xx_ySWhBBD{ZWiV6`Wia&r1ry^%H6B_;Y1YdcfkbR)X4mE%%KbQ7!D z%aDV7c5-^Wuc?*fQis3p z)iY~Fx3nTVQoQP!^`oD*l9>`R=ON=HIHd*X0Pa%EzyN!voZ%qceFaYG(0-d z+QYOm(}?bDC3Pju9hu3|U98bAjgRhXrMomWy1Ui88)#;UqnWd#ds%5rS0(kfW+7z= z-;4#(eXO|dq*-Og$ohS)$C>I#>SuLgdUVG6=>Ap`Q=1vt(F3ehBpMH|$Q@fC6`&aX z6>BCE&B=qTg-G;-;t*>U6O4eN*4so%*BSdmhgwHj_VBbF(L=4s9#q@#Vf&+#thz28 zi5_k>cIo}-5msxLPDhWjI=gf}I@ucJ(xvFp)>xMg7-Ow;roJ9 zds6NrXT(LPS&f-eXVi**-AZOkpAqkyVC`g@JEKbUMC%u(H>O_ICs}oSVY`?=%=j&O zvK7Y^lI4q;Y&Bu3nq|jKv7Tf~$ht>T8>V(yWn!jUFEMq^3X{~0>6I+`?Jlby(`#As z+g(-?k?e;XBEw2%S-F|}Lo=*2rdl%}kIAqyn3_u2G;20fM=6_TEn<3gW{a5V)+(mg zXSR{FnQ7+Cmtr!l9ZV}{c9E1rgt^bKjl6GRx4$Ob)G3g%Cf94n5s!x zmh}x0rZUs|iDi(=OzRIONM)vF^rqH@RAyO4m>`u|7JZ^5)!Z#*v#l_e9hb7%)_qJD zq->5=i|OA|Hpgnf^s|)BwH{$oXSY)3T2CWN6iQd|LE0w85`nT$QYbsN(+0$YcSTmW1&b}75z*@jG zX14q`ytRU9*6g*)LTe)u-IrNpZDZMu*{fm}S?@Bbb2dskOoVN{*gDCws5$a^4eJx8 znsZtyi>*scF;cd~`Zv=fQntjpPK2o}wQjO3OKL8))IQWlYo+E=D}*UW%9dFrm`+RC zGAoqnYbjf9Rbf)*wo;Z`HHa{W6;?FMAcqxJLng>!h1HCy-(1VT(rU>xTBfqnYR5D~ z%2rt&nHEXeDyt_E=CIlt$TG-bwKbdxa#(GRVLBsISz}FPx-3&!V`VZy{nlFZn4o@Z zt))bm!#Zm%%ZilPAG6MSi>XEW5lQcOG}l|XEQ1lS-g=J-M!fVl}yiUSQ3gGR-YkC#H{Nnp>>iOxL9BZEFyd z_QqP}ZEGYGw98g&922z5R%;3qw97UtiwW9gn>C*Z%d*{C&a&s;$cx!-t!H}qjekqp z%GB+RA7XY`dzfB%>wTnLEAx%g5AC$h5t(b>kl*98TK2=%Wz9}5$*=QS zLtP4gXqT0aM90l{tQD@TN2xtle1GbrpWc)^6TF}=Qr4A4Pxpvf2E`pq+I2x@i)XiYl=&9|72^HO9zY`OC11Zk^8LA z-`pVA>Wn1U*5=<32d#rlS@Y#C7S@tiK~wHXJHM@R$lAp8_WT_U4qJPej?QlyeZ)G) z^tGg;R@4ZJ=PcOU;F#5(spf)14c@aZBFV3tE@-8ku+HFzqEf{01t%N4Z<(X8l|=f2 zPa1q+#USM>=?m&BA6k#OG_LkXR%@3&Z*az1z%;i)edVk*X)NWwdcnUNoU;mz0~#w1 z$W+c-?O!L^Hw*l+pISYcw1qds1#2i%MWpFS^83>Z<k+2sC4FtRW9ldA z-&TL7F^ihUUa^KVZ9p2!bOvb(leYLtsX2@3-GOaluUdds=3lHYncz+GUoGEMj7PgQScQ<}en?B!NB?TY zF}=TJW&ImgOQf+PZ%HfVH!Cj#;^ipUm&}O0Y30l$GMCPa{nMH^7bw+)H@p4z5+pg| zkPf~DpM;p3L-+B;DT1)O_jYSko@OkTjoNx+Auboy=6TPfl!z zU1$->+AnP$UDS?Y>bU9Uvi!;xU7ol`N=p2wOn zRw~;cBV~yq%dShhjFchDOR8d5+WLMky7p^K8<1XSI)gMF32Z)AYA!&^5-XNH z5?9aO=~DB!X!{}(*?a>#eG}wP=YtLGwMZ~eycE~K&PJknqJiCMGibs*(OJr-G5xTx zZ(N-HCX=Q2QWn}pA^@~evK&xX);rD zq`6GbEuSVeH#2pU^oYHOY4GyCagW;jw@?ma7EOw4Y#(RZfb=ob8Kg^06J@-{_En@5 zIfumPO>FTtq>?4(E>Dbo%r5WJ+_zz?8py zlcXr5R5|a?D)oeYn(3G2JK~%{f1MSwkNb{VeSM1G9-$~6ub`F!da(~z$yZk$(SxVAi zy8~0Tl~v=1*qwKiEJ0F|owSFj^~x7xhuc$_I!b!gUc%I0(g=Gy(`%AO+9#N%Ng8G6 zGcAzxnoS?}qd6qmmJKHVa<$uG=uP%Hrh8X+h~8|g2Pn-4BxTz*ky1s> z>K!%TvU@XC9=0KVi#?V!t$wTJm6Sc1Y2xbQ{;l>5rsYz$)qa!dT`AjUFGHdcu+3iQ z(vY&-?6+NNrEItNxHO{d4*Rf6Yn5I0$1c4U|Bn5YOFQHD*f)@nm5Ez`=m>) zl%w`Jmkt=m?DB`8ERaKb#BsX^Qm&=0EARin9>8R;i_t%@UuP;RWvA>+rf?}cWnX5h zz0UG~XvZ9;`ZZc7zkq3vJwnt{#{0;g#MDd1`^cU}ggb_uwksb+P29oiv>io+JCvNZ zYcj!Z4X5oGBHWedwB3pc&SFp7?O79cayVoAk71g)bHvAXH73|A;uE_+6YPd|)?UH{ zyYig3cO%hm6zA;|EQ38)KDDd8M`^{=4{m`)#JW>wlKC2Z{DM`O-eX z1Up=OX}`w=J6v40KcskQJzv?MB9RS#ZC`d}ZIvr_`BP9bu!1JaRl9{tH^evgb1t<~ zzOg&FG@|Ucc2Ac~A{VqB*ic_+*n*v0#hrbW=!yYmFBc$dKqPHnR;U?9hgQUb!RG4uDp!bpXm(d zo`jSt(lsoy4`<}MABG>B=Olo*N+Xgb|pN^WR5 zYnYBmndAK8QgXvWPTVIH?@K8w?4-Gr+^~pq6p7BS?{U<#pb6*KX$|jj3N!t%Fr#5H zrvlT&(pWzvj`}bsR+uNFx5k9!PEn(9n+ggotWN7>VpJV6B#ni zp)9i&Wi%||q%u{MRMMG+lqIz6Hyf66cDj@pTgJ&lqAQKE&PPPz$XCVV%R1+o{zR&G z4(l#^b6dl*PFt7uG_2r^KuQs?`$a|P5>l49KRdT!MdvEhquIwBMmRrFJhM%KDKHV_VNk*c(P?ep-OmJ;j#ktIyBeI)DRB_sV3aQW@>{Xqe zNHE?nHLU6!Au?xVf88+3`2dN|`J$ZPk-$EGk}~xI_4K}lR+T8{7}MUBH>K>nOa6rW zoU1N52@g0wGaZ+j)g1ZxU$mFA+4m+q=r~N5vu`%6?v!BqExTMo4W}ZL|E=v2HJ#c_ zh2DxxsOiKp6??08LM`VpriyRHCe(IXx^%N)9jAj!{)D0MC^Uj8Mg0dH!twdt5l)d2O?Fq`-J6DLrT$yHj=ghl7*^ACaBC%V_UUX9S24ycf zlZZr~l)dCUxGyMs*@+<%g^%zefv}d_#0_ULz6@AF0)%gOjj77_Xz#j7W5m zvW`wvZcvu!)Fcv9q%6^iJP?$1a;g!Dty0#>+2fIQb`G-al9Y9Jt{)7>>*Cxb5`~ZU zE8E2>ieI3ma&~n}6NzZ~Ey=FV6_2c&bDd=!rL3D%6Tc5j@wz)PMB=QJb$5<>WIdcy zEK}rnCVM#j@oTXZucwnlB%-9Or!xY-T}iTD&R8PRN6LCR?eXiaB}e!hYy0KQ2eI7%A)PEFnT!KW7cg+P_z;ML#F$qhOo$can)j zij3FaG0y~L1Dv8nV!xCPa5i{k1D&lb`&y&ME=fb2$j^eBL!D|w;)?uk=TPUON0#JVW?ATo zS}l^C{$B*+4Rex+MAH-f$_{g;;5SRDWW${-A~8qC8}5AMk-h4C%Cdb@_NwzB?k7O; zMmY6|#OV(jB#vB$j<6Wh0$Gw<@wQ6mOJcY(oVwa>@~+E5;3Rk zy01BnJ+fq{Im_Cg9@Z(@neLILICEJxM#@s0GalJ!=OW8i$uvhhRd)pQ8{^a<5=T!r zNF3wz_Q=LMgIM;xj5pTV;gOAV_OYz&nFfjD9I-Q)W~yTniN;cv>NNJq#yibf)45QD^pcN^?H*$X<88V%hRDcHP&VI=I^gwdVvUmPl-qvI$O-M>f$(X4x?* zo9OKH$R;^CEQ@*1t~<#QxDyAZIoUCZM0+Wl>@@bsrZ~-6mLg?SoHUPYs*}#L&t-m7 zoueLEx^s$UzeriSQxtc3p!_nN(nP}g*sh!5tngBp$+C|>$?rVd`Nbof;|Sc-B2}no?YeWE zL?WEQ<~luD_Q2T&iF2JL9@#u+4a=TAdry~n&JKEm8RNa-?Bn;D>s^Sb{f1MP-d07~ zn@$9gsCS`z?KhqG{DEV*+%3~NLnPk{+uvipBkZ7Tp<@z>A1;jQxzG_p5p&)Gcd2xJ z;+;_NufmWG=x#xGH@e>N{?$QqKZYL~2L2-j{2yTmg_Hk%)Lh>U^vUhl|91Z+8OtZW zERY)IQZP+Q-wQ1%T>%#*#hMO*C#ZOKLq_y2A_bugVw z%S+cMq6+w%VE8i_UeHha5Uz-;RfF#H7>lG{f58;IDc>!%o|rzl|4BI&LHSbpf2W*O zW^dWClW+1N{_>+JyWa z(Gn=c>!%i=5U<}m2U0lMl6Mr)yazVm7bS2Ud1pnM|AVei)W)*iErjgtuib~6K|3_W zbheC#_W5glukQ0QpTQRHDD7MkLBC%-A@fqjvzR04cR)Y&-LBW6JY6wlpmcp= zB>KI_GHQQvsU;~c94UNa6CNeKIH5W2829!NRb0pL-%)cF9`XHKp#==-Dgx5}l7vUH} zZBh+&!0#73CO}`1W&U+I**WQupV9~Wxix*tr55H`u!X%T{QVpYmX>lMck^_pZ|8WZ z?>}Sbj%r$-d|g_xRI1{w(xUE6tUDzgQw&Rjl)b zZ}s?LMEJ#CPYBG%8?Za_xfr6A)UYDzdf#B>~~9bYwmQ0 zLn#*=DZ%hSss4`6?c<$VAdmt`{Q}xk6(72#^5IoRARO9R!*^*ZUr~_8#6R~(s{`aJ@sVL@tH5#WHx$@TrxK$Z-_7 zDuHVypCC=LNxB9Be;{QF=eStrtFnayS3MB-PFFo-f#iDQQfl6C^4~2S`obrm7yP0- z)`*V0aK1<9Te?4$wxeVTh=ysNj2canO?zBdHIZ=DB%Qa@g&sDkDPx~3x+bOK}T z5Z3epy58_h81jR3ed1@26h^Khg04^eiPB=*Asj}uPyBs9r4!6IU>pB5WNHV<{i>Xw z|10+dYLfeh^!r4~j?m+ErK0o#rGHyr&?cORZB z-s#-id;ImD5fwZS|Ldc3P#UlVIEDs}*TG!8J>nC=vxPt`I(0&+vEDN*A!7hww_$!aoh0LlG6wcj?-JuPj0`W50nS`CD0~!(+SQ?f%AE9 zzku|goW0-eD!`kL_Y5Cu6iDA24lViLJM;I}%iAwh5*QJIR`N;#8AbU^>F{kN9fd;U)|y!Y%nc#eImHF_=F zYk}VIe|FUnDD&N}9bjDF>DnPU-f8TUP9Qas!irpAO`h&McwJi8q7WLP^>KtY#L-HA zZ#eWa9bW?La({n)gWA(O-xi#oNyj^1{by&he;w<;vzp{x#VWWC=^Za#+wjg#f2~6; zK<@2r8(1mwmZ4Z%I47Z1RvLqJ-tJvJGvsXJ6E@B{6>vV^f+4%m?`^9`-1*suXA8Hk z!g)2x{{-rj`)zlyjS@Z3-lX5he(zD$>!%c2p`|^K>3GxcSRiF@T(6&E?OqP~23?=% zizy62ms0cInHq)RP-eNxdYfO~t-xA%bMg8M)}2B)9Xz+Eyk3_n%d-Vf`VbWCzr%vUC;kPwVI{t+(}JF*R}% zF#Th)$K_oH>8j#iDE0O)S);eiUccA6p2oNx|6vNZTV253yea?v@=$66ungb^QuDU0 zH#NE%rI7W#L4SvI<@$-o@73}8%k}~NNa-qkSMhFA&{RZ0m-M~i|5*yZWBTNJQ}EWp z>-XwFi}|>0)DAo`JR+(o__K4E4P-)FCbjKC4866%P%%z2|=peB89s61?Z@#qhSjA9dv?q z)KFhXeFODP*8iui?QMr(zXw`_LMY96tSPk~xIQrx`)Dcp*Z#x)swn4qZ*Sh(gLm#( zP5f0XlInbtg&Dsokz=a>{pWVLJCFmvr92Hu1Lb5exy>Cr+TBED+i` z(B>3E?R*Axyg5?6wk-pjIU-#Zd;d-r1v)C~+{vQ6HVK*N z{dJpz{Tl+}ni$u@yzGBqx89b#o2{Prw3ydopgHp+-IHaqHn-2tC zc+x;#Ny+yb6j2!6;@IZpq~FgWW)#FNE?s#v@kk+D{mXC-pUBe1ht=*LR}(d4UOH+T zch&49^U^Rc9rX>=H~%AjON^GO*#w3%cI>4%1}5ce_h4CQ1L=+W%+!v|wKp?6te~ z``!AQ^vV6FeM)PmUUxmVGdv}z2zYZ%5!8|+cY{Cpe53TEX0CMo;y7xObnlY75R~6NztBE?& z)kUmy4e_XS74d|0eFF69_!~G1=V6-g3@Sa9N>5PVnhRY4(UY77^=Tc9dV#JNsLjcL zx99Eu&NKFqLg1Z(+x>w%@=!Lvc-KcK>E9_$>Z70=c%t=cRcNuk*s4P@cW*2G z(_B(89U6CkeY_*7SHED{DCBPGc;nt)&O5b$SI3(>98YgOhLUs=wuU#C`DppmFgy$W zG%Lc>ygor=fvz`c)!OTygDpdOdHvqndBY)Y;7G9$kvEQvS#ZhlIEQu`5OK?;f>|I;!TAFjj5we-m_>;8h$JBMq6(ox=l6rg8sb?;UN z3ip--?nVXfTfsGpDoROL6Mx8XUD)#6OkUAT*Ax%pO2renTJ;jTAu{*C8waJ)UlGgm zPyP2}T)L<55T;PjO~7#P+N{^Vx|>gyglb1;<}^mQz8H4|x&@`d5L)L9q(k~CGL}z_ zzb)>qnxsSTrjZ4bOJ#tkFBCBiQ=oZ_Mk1}Yk!B`JgZ&sN1BH-|cjke5`2>V0d;|v_ zpU9Hw$mb0(H435g4e$9IwaI3w6Ub!?`g1TA>3d6Z62t%B9CE=ep`71bf8cC{%6|#N zgRW0}?S_!wFMh%h1JAzb2y!p_>1nsyUD?|5T3ZnXEtC4IY&uB2cKAQ(zjaOib{h^z zsjvTkw_ppDR#&=$rx0(BvvQrbB0Il$X~J`T7NgkV{8TI-*fJEir``(d~;aT}QxE#PS(w z3`s+G4!Ud5-HGlIbkCxD1>JYB{5R2Gcn{Qqo<=T-{%F_r3A$FLHDtPrO6#lMRaTOc zOLspVxne0xCFjP#HHbF^=1i4mHadTMOy)@XitzgB*|ug<>KDzW8;C{MHBY;-{1{8Y z9DN=?g(#vGYPP|2+F?5FrK^d~(v?>(xJE~J6`@`}ad0_=!-}^e_MyMK)bz0*`d1O& zGZ1eJ48Sxg1k&+|W0*qF?-yMLLkg2IO$hh1&ddTKXEAQDU*r`T-UWa@BEO&e=&vnd z5tfSF_2?%To(We3tb7J+pkVJ)8OWuUp&G$mR|VUO>PYut1NYyzp%h#n-;t-5q;$Nc z^|s92(xiR?JC{#>V)_5;SgL^b)C85}c73l@=brW2_Fws>g8GyKi&(4J)5e+~uzb#y@*IGX=={GVbu>BvQ{cW(UeqBqc$fbQ))%BcLH^)so1a6xEkJ2{&xNRW{%#1}W4-mRoVT0>{WSB? z-2`&~kYx_sb-n$LL*Q$U?d)qu6##Hx|&#?3fB~$O1~j4c7SV&a&rE(#5Xd;7Jo|D5&A|U3W?&<4G|Tk zTUb<)ZV|CN3u<(FF}TOky?`#wPT=}j>J1@HZwSSziS;5W&1@yn5-5GriN-*mjQ>jd5avi{hIBVAJsZ+2XgM?@Xrv$R4?6U`;x6>l9ik%`cRltX+`m@vPQ8!s z)YG-_?IZ4gZhk0OX75$`qq3%Q^;ljZ`o-f|Yg+Ardy9VY42F1hs>`bw`Q{N`%aEnf zX!VXedYRB1(Az|34^Ni3rhJ{+^Y;=j5-Q{5>y!FNphP z%J<1%b;6BzKkmuF~IC`n!o)N;k>fBzKeCUHZFAe|PEcAr>e-B=?ZqLvl~)?dRjP*}@NtH^m^|0x`n3P|6pJG~ZI$2g{^?x%97_RYHw-CELZr96agBXl1}_i1$7q1zGN9@1T_3_y1nhNPhXb?Kf+ zm@VBHeW7%3h?VGWM7O+v5ODuM*HpI2@K#DS33y>i@2F_L(`8a=-6;o*$m`u65R4d+omW+WVX{5%jkv}wflTRjk7RSNYs6XuPm{=`-+5IC1`R}_sgMa3Of zYt-I*ULMfaM7fPMP1tif@hsONg`z|X<+hbFbC&IEDV2W~`}T zPt&9hEa{-oUz}{Etlg8AbXL$`!aOVJ?^>SaHtJ(~Z_m9+@tk73)S>no!VDz;O_cFfQ`9y<{=pPAAF{8(TT{z~XF zrP&H!$|_~uUTWDF_uiROqrA1ZrO9RbU@!VJ+HuOQRs8ovYs6oBf9OAm|9S@XjrA#J zC2C)+vW6{eU<;_WOV;qC zEI+~Wa@5TE;Uu?NW0l+XbubZred`|4p}WJhN6=r;Jg+P%Iv9JAV_oK0S6O0KsV_Cg zxEN?{rBWF?s8q(rD)lJpf%|P;RO(k%E!1#R`^|^&>V>{PU4~70xK@Wve>7ne$-%0MFw21Rsdnnh%l>p=7UW8<5 z+!diHZ|}Ql1hqw<5sLEhzW%@i4-6dD9P zJi@HfU$>1`^7aoNsQ_bB%7t%#>Bt)4-#>TcAmy*Ui$yc-Ur?rc^UQm*~qJ0&sS9%5u=qi;<`B%%u#=h6$8=Nmq4Ykc`05|iYt*4}Vib); z+o;BzN{yOO-FuYN2wVY4wDL&xgbeDL zg&8&C&FbQe9_GLH&IKObU71lW_EmRIjOS7eF;TBbHqj_fXZz90$?DB*qA|Y>9+|^B zeNY=(DxS!rWq!#~EEMRL@Y&lwa_`}U@%*vA=#wyY1GlNI2 zGNl*oj9q0KRD|)!Wu!X!Q>@|CH!yBu`6jlxMk3{q#%a5ZgWRJw2>N@(8wCAT=`Eb% zc8D#SALrceA<#f$v%4cIUKP@8dUkcWhEtyr^_newm( zy)I{5v@-3`vUZnL-=Xsf<)%9iJq*dIR{t2+!AxF62Q#f2U66<4u^kv|#F9faUe+D@ zVjSUV;KoB=j-z(R>ZZJQ$Y;5zlI1uv)j+(NS}NX5Ej63VvVr}abk5HZ&d(6e&r)&UDv?jZ!v#Le20?!nJe~Dd zDCWcXd#OsZ*56xm%+%{v@cf_4_2%Z(eTWsS_+a7E#2U5v;T@JiYjNga0he8N`IyXf+y ztz!J)-zTk8@(wGLH!3urZ&avt28o%6eU{N;q1R`rVw+pVv&&Nl^kGjmTA6>i-Q+6N z*gfWLz=NC;^FUF>$?cN5SYV~UDQP_Dkb_mb;C(P}NK8rmM$?@2WQci2}W%D0JnXy+P z`7_pRp*)x^l!wL^%0rFXqj;!VqsB811+If8&9qcM7>SHp{hVrb`;?=C{(krd?i&i~ zIW{F)nRH}AhN5_m+=SJ64)|!LlJVXnTc$)Ss~D+nqm?I)Trh9OD!+K@X2_QUsl}u5 zH_2a{8m&Bc% z{2|X~)6d5j_TOr5cH-p$E6@iv-@Ms$&52h$E0jie?6>VQ=bdO{su6db_{4Lb<6h)+ z&s*+3@e?F8)-H1`?K1Z+itTpULi6fHcq0kpuCkn3y!ni)EMEcN9)GXZyz9jD8D}xG z70$R|em@@mn^|C0C68#yj6oQii{KaibfTr{68Z+b5sbcm{Z}Ym%fGkQh*`Tg7Hkky z!<$k66$3X2D(_~j4qFQpOTUvej_%mI7do-!xAu1+x7mtf8GEv&$zjPmd9}c7rCQny zPi!xEnpMnJnyWWp*SQroAE^#t9{39uU=z3tbwUWA;Aj=!49Hwd>o7KuEr*;-5SPnb@-$pqB-pQq_R(?FSudrJA z4U)!OqH3k}Y0`-WPGp^lmeY5gD2(SFRy^;pTA>~?Q{t5or!PTH?bX3by}g5#TF}js zE-dN7l3b3P%W>m4ZZ5~oWzBfjjAzXuT*Jx8$jK6q#$}AFfH>t~|6vVF zf>!F)Ra|>jR+?2dFa{-3Uk!3-&`M)`1LG#Ht19LfaOfJY!)44b0nz9`_ z&e#PUYYXEZwzG`+HC%^lte>47XkEkd?b1Hw5TR(7gWN6$xkZAk6UTGuQ7d^qN3G=f zY_QV2dII{sl=G}#1-?iBi{SSbUFNpC%q@G7?ZlaAU$cc{UFBG28}-j+9IG+-y+y5T z)Z(pd)E^q#sNYsuDb_MZs!5#E*l1_eh2wT%oj8`nvm~A+UD!Jv!jd6ULc6wP8(B!V zQ4d^Yy|#6%l4GM8BZnp1t#oD;$7}HdunPqyQObvNinY(V4Dgg6mwCv! z(vb_8ui~66Ln=5G;ruVKjX!s0&JU1Kp10dtJ+Rrlhf^e-r2c!@!XCDEl-q7Qr@O~St+vNTb$FCpbGwaZ?-hJj zw#P))7lw!`wVe&=nZPbWeT z2P)Ab?YnJMR-Ib|3nx}|?oaLV{Lt0xnYV)H=}TF`XLQkK^2d<+3bp@5l;TgZjCHDb zq+e!970&UF^}EXaWv=71qCKh7@>(thW@prS;7*?$D>O|FP)UN4r?zBpK;w*PWRaI@97e|K;z@NkfJ;_Y+I zcG5K4dG)l@>RAK1scaW?+LzUcL0^t2OE3-pa$U!*=DaVn%4ioqzH9@0Nb;1Zw-DNu z4eWnz5Cc}W>tBuf&sNG!i@vtLE?go)oaNfd zJBnjTJY!=%fr)2%V?M2-)fs2zmMve=?wk7OCdOpOcsofN^T|&v=cfk{9)j)InXwBu z@!U9sEf2BNo_Yx9Y6x0Go3ZlSu=+FsoWiRT(HPgq|KrOXQ$aF$e{}ugB%*<(8laZR&hzIxD?B{ zHiC>kJIw|`PLa-#?@VdTHD4os`ugmhyWmxRbLS@Rb*t>;C$B*)tYXmL*)Lj&npqRG zf$fyrg5RW9P%j-q@7HrQ>gn=6~x!cjY|9UB-oE8D+WJYqYivKfCN`lZT2;=nf#2exoNPjEgr z!l&xje>+Rgb1D}(mCefM-z=W0@QJ0OocpHbUD3+--_RcCzys~>y3BDm^Nx6(@;l_~ zlqMHEcdbTiK5^GZwzd)c$pM>flP<(8#<;_oPc)Z{N_QlAvz2fwV-5DON0Rp-)_&Vo z#2T@9Gw(60Z4X~qvAEjy%!NxsX{TH;`4B>{h-0>cFMYT8Ag6Mba}tf*wjA0RJu@>! z0ls$YQMOiPrt#HO`n39@MhpLWd!g6r2x1} znGbwaSqEH$`fZBmfA0e~C})7rDVKno6tkl#p7pf_Zc%yz-%>^cw=2cKoyrQ}9_1v_)|Y@m>oMRw>lNSvYx_>ft#t^n%IfLV zNZe!fbux)%)_I-m;w`H^7IAI2cD9QJww=H&jBi1L_O)H^g7&p_>}nS$Y-wGQPy7CE z=ppt`f!pnufIIDR-O)qr`M?AAO~8Zpzknax``-Wy_7{Pl+ne@4S?meGGxkNm^Y#~j z-`M{JylC%uBg$g;0WaHk0e`bM>WLm=9|;tWyMSiL5un`>ABP^|moDJp9^z;MbUOwD3mrv3pW^{wh2wo-mE#-WJ&xGk=nszJ zz*UZN;G>RZz%?vi%kt+O|Ab_d;~4N2#}B|Qj;KDUTgMH+?G7h!r(+!OsG}12xnmXZ zgyUJ@8OKiGdB+F9Zycw97aiaC!LRK!y8jmBywS>AOd_Yzkz4HIa-)CswTs^xrJ)6{ zHu@U8h`I}CeKcx9 zKeSiWUHy^6#_@yD`i-Xm4>Vo?JlOb8;Kz+e4z`OfO(^vnno#O-O(^x=O(^yFCY1WX zCY1V+CY1WHCJS!0i{vJiz%=I5ng5L~TxAQQDOoT#B@6bZWTA0Wve3LKS!jjEg|()X z;xNYKrqrL)no{cN95;*O=5X8z95x#`#N2a)a=mY=NoCXssd*aYqWb4XkTku*Uq36&n4xRk}j6=b@G0fq`Qg694I5Y zKBoH|qW8t5btSqu<~5c-9&@N#KD6QyvX6rU)CC$-i3!){4U?X>$O&?DDxxNAM= zx$9rNE2)Ea-?^g}zCH%&pr7rQ^qi!o>oj?1Ns}bamvphD>m}VS={ZSFon(ATlO)ZT zbg`uCCEYFQIY~{iGQOlqlIBagSkm>9?w0hNq^9d-d`Xie&6jksr0XT!E$KN)O`Tm}VS={ZSFU1WSolO)ZTbg`uCBwa7*E=hMwdREeNk}6#_yCz9vCG9L} zf}}~3x+Kk)v{KT=lCG0PhPCNAvvaGrj$_`F_}7Ej&-s3Q5;Wx>M3KIvt|vi=i6r zB!3Ia&Unaxdr+q_>ps z-SaOnEt&5~V7v2sFx@ua$+Tp?m+2?-mooi!{zfUUW?D1<0@HiuI}$0qjdy4?M$*zd zmO}nQO!9)Apw#YXBt0wX1r9$xPb6vKilh$E7h<+8AbLFJ^97xxJXX>k9DZs6(c>|{ zEEp!`36kbX>XNiV(n?8}g1!**`+~Ldex0NnS#DmqQ{L~A^o*ouB^Ajszmj&66c2K_ zoWmqdkTg$Hm!uVvR!X{7(sh#VlysM*XC&>EBJE3>CuxPGYbD(&=^07Ia4lXZNry?A zCuxPGYbD(&=^05ys*Eq`FiFpj)Z|Kzq+>N2D{18<8Lw2M!z9g~6)#Bp?XDuI+4wE!b(h5n}>fsM) z>qMuOlCIL|nTIvHbG1f?;TuU>Pli1q!@rj4eIwJ8beN=hl2%B%R??l4o{>~skntrQ zCTX6e6_T!%bf=_ebopg1{xG}3JFd*^n z#MOyUCGJYBPHdUfFKJ9tY0~1Pr;=Vu`Y!2@q@KyQCC^Nro4h1>Me>^D50bw~{xbQ; z4~nP0vW5nqHE=B>l1U4e3osC6AgvDmtS} zMtsJ|jAerX66T( zUu9m*{CDPWnbxevS=VHB$m*6Amo*@3XjWQQM%L`CxmgRd7H6%<+L-ln*0!u&S;w+Y zXI;wrJhr%^ErRzM2~GVw&U2|WBZRy8#{5V zdu-|0Ib$owE+4yR>?dP?7;71K-MAj(CXKs)+%x0e8~5S3@5cQ!?#eiIeB<%$#`hUN zX#Aw{<>MEQUpD@s@f*j#IsT*Zm&bRQkUwGegas4UOn7#}jtK`R9G~#@1nb1ui9;q% zoj7~qs)?&7uAlhI#C;S0GqKI2-jfDS8aip>q=HGoNfndsoAltMCnoKlR6Xg;B-`Z1 zlRHlyI(hNrrzdZj{PyH`Cx0;c$mC;_Pfz|~@~@LS=MK)z%AJurH@719q1v=!q^>Hn6J?whI^^EI`>ze5ure8n3|MXGQv!~C<_vHuj zSLQ#O|Bw6)`OoLSlK)2j_WaZNU*><8e<}ah{6F$dZil;>yS00mdzSlQ_v`L$?p^LP z?!Vj?Pn4&N=SEMwC)tzk$@3I==6n9;dCc>==h_)h%vfLWO2J13QH5O!GYZER&M$nd z@cF_|3(pn)QP{*A>+SDN^N#c0;l0PZ%KH!RChuF`FTAa0_McfibI#25GygSHoz-qu z-&wcM%AS=!>(s0`-)P?)-xA-Wz7sxC6jO9d(a@r_qU@rwqNPQvip~_>Ts*7z?c#qH ze^LBhaqE)wlDkXxmmDq;r9(-bS$RX{EtMIS&sM%xxxI2%<;RsLDu1q2?&^HkxVwt) z3f}d%ySgmCY4L!?NsC7>&R_h<;$4e>Tm0wZ##JqR^?bzK_Cp zQ4V|y)mWHCGu$;7E%Cn>zH+)*v=)8wrBi}vBa-o5RGMgyZn!Y_K_oT#^`!dFoDiUHyUd;#^67>2K)5^%nhD0W~r-U(*}bE?>f z?{NN!?{VJ8S5Y6}d!LW-P0k^FhjT<^ilZV+e1h+AKE+p3pWzFsWB5YqI8r|$CW(_s z`Lu9}Z;|@XB41nL|GCh+daUB@^h%$-w}GY+k?RWbXx-)-X`w|=}9>+?l}Q`MbD|gch2qh@nt+#HG( zN3pb4Na;oTV|tNfBJ0oNIZKxGB?~K=f2!|q z2z{IJQ`Y&q@1KxdX1;kmX?`D1asP~OXN%;A3?+FQy zTl7+wKqqzNGT^w8D}eC(6lLv@))C zQLN1_%EL!4($_+@R>*Qw4)fe3*J|vp8Iaa>hp(*D@L{Z)C}T&!J}1m`^Q-S{`1XO}Tx*zZ2zJ@23*I%Ba=$EHv}i>p~P#;U8Y+0p7sOXa>Gl}OXnc&*ip^`M1nv9z?VE2CT))9P9FN@qOtVN5N1 z1H6`&(N5i1#{6ipjCQmf8dF^Fr_rIs(ySRJ#vG2E^KBP>u85j@vMYK5OKJ*eF49_O z#ax=twf?huF4gKf#vP2u8IA3(w{`s%H2u1EdX#tThFP>c4tQ%hjhf_gN-MLR>Tq&7 z^HrkY_u&1HTKWpaK_CvH) zUR%dCAHe8EG^DR-YO$i`(n)vSSelN}=h5`F6g7Qq{x`O-Ced1|&0_K^G+vjGk73l& z;89&Wn#am@82n|w#L=f{E_6V(v zA26PKqzLlw9|;n&*Xk-I9V360*T)xEll*nYf3nUF=HFlaDB{Mnrks4b`XAs=t)|j7 zeQYcE7kITze~jW@`#51w#=(r5U>)f%Wz<^yv2~4Z72@f2t$@aL#I}hvuVd`T zIPPU?uL+Evm&sZw^Tv5wv#{jlKZnA@dD(nh@dvH|* z@jD~<6+8Scg(~J?H?E4gA{sakJ8~7jqtO~TU$g<4tO{A z=BoG`cIT>CBDw-MV~38v=79YYS2i%HX zyCU8O;&*PvAmDa!EASmL6u3j&4ty88c~$JhULL=#BvOFyVNZ|Go3W!;#D47ORqXBw ztFfn7#bNB|RqX3W1CL@yuVQaM7ATbQK$9{NXj3Kw;ivY*^SUI zf%t7SWiR+|fcUF(%6{453XJo2thlX|A4xq=kAKd^BTA^(-WN)Uj)Gxtb15`v?oVKVqk0ETQ zUVx-MP{qm2ci=lRUZ;K!Nep8r^+(8K89S?&Aio}n-)vNW2H%CToB9hR-5GCGe}%jU zV^6gP@;IO>Zc={--wUXUo7F$S_h!6B{R@&lKm~8MDhhs4pRu26QWVjjaiD5}d;sGh z)du-sAlg@T0H0E$fa}#JkbkT;10GVNfrr(Wz)#fH2tCU9soDnoXKGu>KW99qwuj^k zwId|Q8BeO$L2?49h*N4T_|s}<@Mjp$s$C)Zm)aeY^J)+9=NP|KdqVOR5bdts1pXVw zZ`GS2xxo0H+6VHBj6bM-A^#qzh@aGc;D2Piqz-`O-;9^lL6HB<_=|cgvmw8YahN#(`RzbO zB$~^>Com?N=R%UqINV$gc?x5y`3}g_fT|d2UI@%I-wDhzS3*9TG26Ttk}*IonYEu(Sqlw6p;}Z)ppB)zTiJuL0pNSvmq=w_FFw8$gU)ODy=efbf?rox#5i#HwfM z3Vu5f{mRlE{0<=eB})(RJAv?*EIq-$2gF~9v)lwcYPlJbPc41Gf5!N^1@pH!2EnOx>0P!1n)=cnGK>TW=bu{=^jMrGRA!*In#yS@AYk{h0YaI{19b*UU zL`d2*cC=20JO-$Wp4KVAUe;-l+|1a=>Vl*<<1N;F$om2@n^`@;{?-EEAgdSh!9a{7 z>n!j?fT|d3EdqZV5FVYi1pG+GQP$azq%&q%1CVC|F(X;afZ5i$zyfPIaHjPR;4JGx zpwD_IaK5z?c!zZ{aDnx1;6m#X;3Df%;GNd{fECvJftA+fz$MlduzwHZz19aIS;}~y z^&#-ftdAh{ejxgxbv5|qj4P~mYfU@loq~@T;v) z1D~=!3tVsA2;5+O0r<4_Mc^~mmx0e(Hv^xuz6RWAeI59`^-bUl)~&!z)@{HSt?vL| zvc3y^*}4lUz5>MVz`7gwx^*w`4eNg3o7QUJTh{l1Tdf}e-?n}P+-5xl+-^Mre8>6; zaEJ9X;Jemiz@66Pz+Kjpu>2n59_wjHb~9F6&w@W_JqP^2`X%r~>({`KtQUYETfalB zBi8T1AGQ7n{K9$(XtDhawAy|F+HJoA9kv=^BirxLZ)W=gd<)xOz=1Z!gjTkhfYWT4 zCh(n#4LIHA0Os4GfNon8pvTq>=(RAScCnVb$-?djlzJqbM zeKF+kF&?zv4fzN5CBP5uOCdjGzYqLjAa$o(i7l+0jl^W=}BOXeH|oM?CXKQ+nF zId+5Z%6NlgFZdpg{lFU?)xe&P_kp)KK7eLlAm&oXN5CPDL%^YqBf#4np8#)ndvQZzs2~r<1fg!0nu9=iWz_F2Z*_ge$G<7%ec#7fn+BT?`}D4 z;NN51>u^A_4~Sn-cSM1&W_;h#1d@L;e&A>Z`G<@jJE9@~2#7xBXbJuh<55RzNIqfw z%+Ut&PZ>XVw1xZ_P!-1=?ZKY_s^X-hBluH{XB^i-avF$V3wOkV{}8W zD`SnLALLhnnBN=&z+VNz6Lt&&{}&K@qDHrZSAgi-jfMivjcx}vYLozZ6cGKnQ4;tj zK+J57Qh?1Gr2?Bbaso#-8i~*mK&;x0MgcE2%7o-QpelZ7G#dQ(jK4L?hU8a9HEJy6 zCLmIb8V}wA#Au3|2;Ro%h?)$Eov~5W6!1||(|}E*T+nI8*fA;}k`9b9Q69*z17epQ zRRHWAJH$oQ44`XqV5C^ zjj9CR7PS~SBkFEoLDUjpVboG!Nz{F2i?|kNgD;A_77k!e3mb4u3k%TQA__R81^s62 zy)ByIw~3>ndmT>k`r~9S1?OyI#T2}YQ-t%wg*XTNyLenYhqJ!zIFbnrhnrFxr?yD#ojNErA=Q~WI(1I!>#5hKbxrG==1MD0TafmA z+N)`o(|%9u;Oy+&=-ll5(D{?I<1Bkmdb;>Zt2o*P-6e#59Cqy8Ed zmC-X}ea5DYEg7dX24=3yI+XQY*09m@Mpul!GP?1YWn)&2Su^JI?4PoK%N9AsIdgIr z3?b=WCCc;h146{Gjkcp~c(Q zdz1Heug6>J{g?MoZ`8~iX5KsV(OK(fy)IxE(f=&SY}^3_+u1R4dp z1qKI_1ET`Lz}<;Du4g61dx1IP!;2Yz_JsR)4-GX!QcwGH( z^~W^;S1#Ukn}Ta9u4%X`MTK}kEEgN_#pFJWs^fT%_XMt!xK80Zjq4Z0`wy;Pas7s? z2GknLi;`$4hz(*|#E)|yvml>A@mlc-{mmQY_S0h|exEkYXf~zU6X1JQ; zipJFfS4&*2aJ9yD4X!pg)xH*2TU_mMwa3)~S4UhixUR$130Ewx>v46))dg2qT-|VW z$8`g)9=LAA)e~17uA6Z6!gVvQ-njbUx&>EXT=BU2;p&fT0Iq>b70&RN-~|8gIKN+x z8mD&ha{F5)wM*Ja(hZV6Ba&N@{&SK(FX<*pUy}3{Nne$8i=>m3z$=tGh|BI#Z)oxBs0}S%&F*h+J$|sg=lEA`>A2R9?{B|mLVx?d z2`if`>8qNznAG3iVp3w%Q+bI|&*jZ)>YP5W>DBakP45PM9@lrc+U3t{nu==~u2-|? zHSO=7*VKh;8LpRceSxb6*S-m_w77l7D=kuRjl?w?*LYl0aFyUH!*vI)N?Z>oz0!j6 zzXJRtGj3O{Ghb;jXx2h&Rq4Q1!xmXYjIiRe;j-g$;A(^`3Rh!XO>jlyH!ND<4b#@R zuEEs?*R{CXLf!@MhIYkUm1y!Iqe|RmKF@7pbeYQ^oZrjs^9g6RCz#hqmn4<=e4hNE zx1?C4xdMe+m@~V?AN07jn;gH#6Tu1Rh?41J%8IiKJwD%XSAMX>UmiB+_aKG*LJy_u zPxl6bo??$*28%iY*=41rNK20%(s$+*`aLc;QYm&#_j!aNMKR73Eb+Kg=H+`zIp0n_ z)+kr8s{o1Bx_1_pqSRwNMI}M9rBy{JCwkJ^UQ(+anC$Vn%25+~fwF_BM%<+4vVzNB`0JncWUTODv3S2>t;9B+|$x@F$==B5| zR@Hk(5{g{xcKMyfsP{Q8U&Ap3vRth7<%D8)j^9-rK<7lyPAlgfUg*DlJ6C3TF;=vMj%6hId}VTo)wCiQ!PaBAmtEpx5Q|&UaA; z6Z{1MG2H9-AlF=VV?6mKemAvFLO%LQpai`v+3%g>@#_Y{EpHeI#i$>z8`UtwTTtd_ z(}qyJ?P)M^Cooj8Z@MdgmVWQdDKGV;m$=+%9v|9CWRzr zhJ*>l#bqvE=$3{>=!OSD=nezN>volg?njjr2Mc}S`|%#nEW@pHlq-n(^<#Cx01V$4 zb0MVxk%HPN4;Esk3@c^_{So)6{*toNaPUY^dH5#7Rpc?;l?1~#ndq2$Ml_R|=*BM0 zdm?2vitY`ThXg#K2gZAYg&|Q&u{%An!1qssw zLG-|&es8P_DGP{Du0RksAqyd4DEpxxy(fnRAzj(*p#XzHeVu?PsSpE0^L9d-wPNbpVMiv*S61LH z7UVu@QPbcipvI(Jb|3AomkiUjrSZrZ*@b06cgb8V^d+n2=7Wm!!-i-<%h83?-yoHze#4UD<&+iav1FISJt@-bt-b^%dHf~W-uWIwIh0EP$nXxA5e^2C&Rw z1;yy_=A)&!*!r}mbu@!rO+e8CLKYWZb(YH?ps6iL%c((I6TrSPX*ofmqa&5D<9JJN zeda<)FY0C5%nFNCLIjukJ*C>%fh-^U3Ald&auOR3A^$AsnTd(Y6}d2SG|1uHxZp|i zEk>)qoH^7(eR}{cEbP_ueZY&Yj=uh~1hqih5#}igUS#+#oP9ShN|MG_bZ4Azo!UZCwh#-9l)YFwIg-4VWP$Nn< zVg)3FhILb_Xp`$$K8MOF33V;*BKi?jjwlLX$L{mON#msl=PUZTTA&xZ0N#A~`5__3 zt}~^W+&DTdz+K&FMul)N&J&XQi3GpjRZb3<43PZ;r%!s0Mqvpkbomm?$9QIFod?PL zN{T&voF-F)hZ{thd+8nxPgrz7s5v;SnnShaqVTdz=@|4EUpg^qR5N*Jm^a@+N7 z1Rr?Fk>RGBvBiPVt?X;Vy>QOpmALi(ndK@AgzvDh8*j-YDKdoW_pqJd#)PA7q-e!u zRz^msZijLwZID#w^^xl5Q_k=X$ytoyQtX~yj#FhE<>{jzLOLxr2&6k6DIqtIoOE3( z9f>5L2Zv;Ctb24I*-LH;gcFSL;i3j0o-S0SfCnyS2ZUaAenBTs`nj2O+iG=h>aXzM z{pc!lymaj942&!Bp|iuM56HZZ@ysssz-e@2-^iT4rx1xA+N_Wbs!5UM!V)=${N@aJ zwljDXl8YZ;J=zP&0Mw|yB?^RMYjI?2*A3S7q{0{vJfQTFl2Uo*&F!U&JXlt+VJ$Au z-CM4zlseM75_Aqj=1|p`NHDG=#qtP+x6!=))N`u`U_=?LNNGT%)-R^rc!Zf+inSwB zZfaFiJt93Xn)O=xdLS}de+Z}9P*A-lDbuwg)Mtcp8X6vYy~&!aD~HWG!a#V&53eKH zrJj6k=jj%ierzz{Q-mg2QQ#|??joN?PcR@wbut`|gsE6Ie%;ui7S)1kTL}e+Mxr5I zjM-3;=%9|fW=NuUSf@KuuFuyrzhb-nZ-0)$k zoa3GPgB7Dt+k8>9@XAAXnDz}OWjj*<84!=O=3^D~}V=AEtQm99QsyuHDM=-=i z<6@4-K-TwIIP9SXAasjZ_3>JAAvaMZ6?*6)26^n#0vFQIih;=Xz|hxMRvtQ`JHxPv z939T^$k0ax(l88$+5;hcuML9wyM9D}t=(7a>! z9eZgw{-^QFyg&3nlzXC>Zc*@a*vXScsgsL$dG&6kW z26j||Utre=KZ73X2K0xmV=%@`iUgh}5-G%^#GDd5-J650XKIpE%hdP77~VJ$EiUi~ zTANW38xvQSy1NVt4g*Y)ZCio!Ht;j;7X66e**ITZ)`qtMU@P#cqr#CdgSvNotbZ0%?o7L4e%^ozr-< z(VpR%EBgLC({cUNr_eO+31|R+pBE zcx8>%4mBoJD=Z?hT47l0;8vHP&2pLk0rlU4hz_5{injS~2UC zDxhtrG`n>}bqRVNZ!Glt&`UId@Uq>oPIw2|kd=saIM85X5o!%;X-l;3sW)sbQm;XC zTB4})|5@XIOzXc{k=cPt!)7Aa*oJD8Cv!~n4TkG`;s2%(+8Q^cgp6WB_%F#oL32;A z_R18s$64?uXpYuz!Uq)T-WeV`{E?et>@ayf)|MIlhL;$9)ebE$p`IC9S{htAYONZ$ zl`DomxrJz<@;sxz{#$ydGnJbE1^AbtKekLzjbSzILg`1%djRxfOQpR`}4(w^k=W=Lk zTL9ZGda}xLgHueQS|(YUVi|73pD=k88ajGYXXAC$% za=PIldS`gi(=c*Fy<9$HCZn}vnxiwS!5XJbH5?jYF!bD(;)Ie3Nl90$m{7BYYa=8g zEp9qPYm!=R8R?BOwz8H{L$i|xkI8zPo|GF3`!De#x<&)>Lpp{oV(1SV%Z(pucrdja zG*o^1m}s~SLaL#fu2svmt1hD28YqP}o7JtkQ0e4WOG^qn4WV&z_{+O2zqiDX*PeJ@ z3f)lUN8C6AiFggL0B>EvfgVwUW6zut?U^wiE=vm$I2 zdl}SciVIJrJbvmf-eSC#5WwWkeyDVr!$-_Ag*x(xs*}~$K)nR0Jb3z#m(KHpJPG3{ z&QmnqSI#%s(92gK_|Pt2du2d-5|4LPig3E3J*6+z?~?hYQ~fvrkFxZ4)#bYm*f8UP zPc3yltRXq)B^1XQ&`<5^#v@JbO@$v~p=7Janm@KedQuj_U);kT2 z2mucOLn~<$LAcc@9EY*S#v+wkB29}+#6{6m!uOntUJD_OP`$9kV8d7|22)0HUF`;H zsc!rR6eIE&Za#J`LOC_aNk8lct4A-?LF>^E zg+;`xr*lWdZ6G|kb|)jFMqy7}39xmCy`S ztJC82g5Fc&rVCl%I~ii^Z;_$~x=_f9p_@c@2t(_Klw~W|y4ULv=j(FzsHcUD4Z&qM z3c@k#X_fy=4eLj^^jZhLLy%P=A8XfpCu>gA)+dipgpdHn@NmQxDxuT}-&0=*x0>`n zs6*8&q<2qng6A@P{UM`-LiAcSeBcshaTLHG<8V#phbBE~!yW#TCd}fA?5wgQa%)W+a>F?}3i_y`BRHR6un2=(yUBl5;y-%#=aUIzI45qP5VHD$r~a#ap!cM-1} zNtxkwa4AW|1Hs66ylspW>5njE9BqA%R3Xn!Pgvg}VjGXABUswXiuAK@kDsehlOg|+ zcl_)|MsNm_@pTGb9|_%u9>;63(dqeBZ~2N>NKO0rfqIV=$!GO=bAi7&DVJiZJt)ze zT%qh}j{vn>yk(N__iA5{X%bmtL!PC?m~W#`CJob*0B=bd@7vjZjWB1dC23DiHC%6W z6k>>k?+y%iqu|x~`CVcCB{R)*$PrKQd0lw1fGpLMF}%%=_fL}G$>SwHR?;NA&7da? zGNW)2^=E}}-85mXmjN{)^(I54NqChATW~E*-(eZ5PwQ&r&}%9w^fG5C0^b>HNAHFP z3%W=epk8PQO?L%?N%UyVTWqK_DG3!)|2}~_n{?zjRoZRPUWsoK@@JRPJ0#j&=ukzw z#Z0HY_ra>Dg#1|{P5K5<(~@p6>u7w0rhYVsN15E8^!INJeL@@3`fESbOQ;nh?rXgS zYYeONGNmz)TMn)7bLD$@GLbdm4uATGBMLdCho|9eOj;O3l$9KO4am!8I21NYU4D99 zj+Rrr&{(W}{beW;ZD%y0em+dLlD#zcir~c3+gs>4_z;j^M8)x@j4bDCyvQs+cWO9X ztJ#Lb=_|H|L%BAznh&QbGZB#e4hsQ=;ayv8veRyFiM;JAZ_)9L%JNoMrl(29VEtYX zPxj;+gXOIrnuvGdjluf;EqDcvwngD`=mT0lZ>}dmtM+;Vv>CRZ0JLS@)~O@Zzga85 zYHjRlw4@vFDV#U5G@|KCIX`A3QmP{)O~Y4^q+_@pVlaB!tZ6u$q6wj3xYy%ziy^g* z)zt`_suO0gtUZu7W;Gm-o>I$w5;;DGuTBL%{L;Tbt13!4R2$reRH+s;p>D+>iEMsN&Dbbm)lkmDqFU+W zYt3+2-ImadM^tZE-Ov)+d{(Ofn$TE)ND04UgLfkFVk&)XOEaRb%(Ws#;o=&kwacsN z8l|BwSU0EvJ18tar=V%00TubaQYgR11hueQ$?7)ijx;S>p>R36$nA+R8m^m&#?)d% zB%L2}zR7V6<&1;)H5_C8LOQ&}U#H<9*1VjE_>msH(K5C@waTeKqBjl@EswQBWK@1u ziw#N0Y+b$3e85F(Al%SU_%)0Ml)|Zy-!1c)QzG3+Lugr1Jv~r9!HZC6<7aw)T*v-n4z>dTE*+67(LTUkl@L;n z2pR4#Das7uoBvv=MD~qv4(oIc&8)N;)-x6$ER|~9oSYyfUn}K?bqvMO%P`AZ8d({7 z03UCJ>cc2)ILXKy)sq?-4Mf&h0AKFVZwv6#Gx-FDd1rt~=3E>VvA0Mk9q9Gg@Q2*Z zdPET}bl7c`PXQ5^zK6jJup!%cbT`{aZw+7U zGmpMTaUgNY-+duh-Do)SmbV1_N&@NN_aC&kp2-0320%IYl7`J^d$2#0=_7}sTHj_j>fN)Jd<7P|J@uC=WVGhfXu)?U0Bf z)!7^k(aKj>ZY)s4p-y+*uy9f9hD8>#Zg}m&)zt_Wtxi}(N%?06FyxHo;7<$;)m}R_ zD2M8eYL(_LJ-&QPrItw7qBRUXqNtP`o0P&5(xItYe(*{IUmk~soHUO0Kj}z281%Zj z&W7e_LuN@^&UU(*;a1PL9zmOWsp}XEs7YnIbxvqW8+ooHA7V67Uk8b(o;s~K;O`OI@XKrPK{G7KH1fu1Y->P*+Jm>8%rDOaL7$qGI@)zyH=}jFGjLswXpa zbcd%(IC1j0it(JH%tI1+Pb*mR^pKPv=Wxdji?Gm9Pp+d$Li%Jkq^S#xnh`DmXR*$r zsX1!3{d4*SyV|nQ&VYA>bwk;gh*XkoOOBr0N8v~bm85^aK{co!Rnpsrv<_15)10V~ zpQJlgoUpXXn?dQ&Yo|2fi2M-`7Z;zVQ!~nsM#2W^xrbKra4hXUw5j045UM-E`hCa& z)v_zIBQtMwIU_1x9={sHWz2}YNtxE0A`Gx7(&Ldfjd3Cs0+AY#&R*Ep{9md?8vB3j zy-SGaSC;2@1JMY%D1;D&C<>ueR~IQwb*7Y=dX&1PQbk5S6s3GABeK-$vPdH1kqRju zsrW}K6(!ensEeiKKB~LNu0k3A-~HXkx#ymHUiaMd%hco+)eusaT*zzT$zIeN3BGiJ#BK?4 zLGGn2m3nRKj#jJ+i@IMEPwp_+g9P#!mjjT?eH8{pSTfdGWm&czHY5|kbQWd}h=|EY zabg-8mKkMJU&tvod=~(Yy_r{Vz1$DlhZ!&fHj{6MEnm>?F@9uP_31}pNx`7Q!?1k| zilSNo)ql=lXk~-@W?*XOkh`mkU?@8)(d)>Y^Ltv@+%Uv!EKRs|m{w%H zFRbp)-ru#;*!A5@OB;$mRc;xgP2|=RXcx}ACA)#|KzA!qO?2U5`HM)+IkAmNG$<7@ zcys$XKTGdU&U3L}v>4lB-JMSr_Jixg_jA*?$D|FiilG-Gym7F`b;Wby0yiKSoI z-nyb~BWJzhS_M+|^+nFrHSsG53IyK1FaNdyPL;f(0oisxSK9>G zI2lrix20*gD3QE27({)_qE?2nkQ+5GjFTMor@W%oaD8)z79xIVdte26XxX$SlDw#gh=!}=(3 zYnLSiwzqsEuPpv?WOAS1?*J4t!1!Fe3_fnLwT@#&OAV1vFm`Ye&)SmLqwyM z%Pg~mEIbFfg0sq=Vd*6Eg>6?1uCEQ=2pUVZBT+r~nR2D+BqOV!At|aCnwLg)Jw(5A zjjWfz1*Pc|6&X=K;&S!Tbia>W+bA783 zH7@tJlr}P71vsSsc&GE5$_unES)@AwYwJpOWK3&*D=9ZdgiWOj+nJTggRr&2r3&4X z$O4V~`dcg4ckX?*w6!{TC;7UZ>#te5u}BCV!(@J#7aFJ9$4fg~^J^kR5-*xQw{`zs zMSaRmrM$(Jb6csh?kJk0Dk9csy{6bp_qUdn!6bW<*^1lub!A)9V%E~KDW^?-H}4Mi z?y24o*1!PQ?aM#e-n_FeSy~B#DZKpvzFu);I`6n~?5<9vPhp}5^2h1iuT2ncoUbja zIM|R+jWDAN2eO%%4ZNb`2h2Bk!C>EiJ`p7>dF=JAopm@&MBm00kNN9Tp_Msnvwk_N zTccL?dA^|+DP_s7U@4`x?r%bm6WtN#69Br6d;MPeOx_@A%RO!};eHAUUsqRpZ`@c? zJ{Vn?ne68KGhAA_D<+0(X{e9s>XUdxTk(EyKXyFsbXRsCR{p< z;Kze&W!^T@iLrnKUTgUz!xs=%&$%+~}&JAYA+@75mqnvM)ETtbehp zklg#yU;$cMvx8~DdY0H{q2tZQiK`A6*!0+n`F6G^r&!(Dhr8;_v)}|e;F8LJ9exyb znTES1qofvD%*@^@3NY>EsC4epyuy{d&@!Cgh5x@ZDb1fm=B$bWH{|dOdh<8xO$sfq}+Pkj|K< z7r#sS*{b}kpZtl8x9*;+%FkK3OcC$Ie$az{cys$f2@#ZD$$v$eSEKB#$ZJ{7fQ_uT z*l%x=U!1Amc*Fe0;mclcZ__<6Qhx9@-NU6Dzk;0=t}f*)E4@(HbyaatoV(~ZA8FbY z#d`{v`T*&~FyLL-Q^{A3zHs9tQqsCvlQ9X)agi#lXMV0)z|4RHZJJ>R!R8ZlH z-uykN;~NwCKz>j-D4=P5v%)Nu>ZXOUuk7;RD-{NLxN59GY0JdJB3~}76X@facTBDx zqiKFeokoF@J(N2hw6qHgT(jKG4}~+ENC5h%=T>Uevt+BDa&>Z1c~CblZmi-FnOxtp z#~TFJo6n3%bO1=B-SSMf3@u^$_3Fwe(k{44N}h?r&K!L<+5tgUJLg0Q9bY*pjui zG)7y=x3u=#SL9OqKyEV6+?xxou5VdRW`DgPZ;-AFbniAc);U76reI$;wxzx;aJRtj z2VCEh{$`aVc;$&xjPzZSHRrKvDa+$FWw~Q3)7_h4hhA8B=OuM#QO96h zcj4d7BNhl!>t+|wQvf;F@4UBo!-5DmQX{&?Mil)rElH`M?ra2K1U;!w|1C~qH^aeq z(MUQHZp`&$h@9$Y z)!yDja~`_Z=$}hMoUB@#PhhtDTfT;atk~IgfJ83-qwDD6R|)_SS%99tbYm5Q<1xC8 zlyzCI-|^m3Qq|Il!fbotZ;1PC6l?UF`VFoqxQsEeM@O@Fmz0}A&wb&hB3(>sZsg@H z7UR3Sf}t!}fNg6mNzInmjSV)_8Nglv*Z?=JH{+mL=ox}2s1U?s(-8&LAUuxXDqBnP zR6uZIu$tebQ32f7q0zI)%jJ6RYg)VTFv*j+>5k}{23E`ZPvUwcD|j!`kFat+2$=C-lnJFZdTUxN)m5pq zxTIvQT{Rw}3vFcMlOt%)bR)*7`-9ucc34@Z9V0M~?$&HviS|)rfDVifgnD>U(rEvT z-QMA}uNi=bk>X)(6CG_$+n#K%xG^SrqQ71deQEV|nDo_ZCv#_|JxowYHekXFOJ7NT zW(C@!YWL>XsC!|1RhM}c!AT0hc60;3EwV(r6);B}bz$m=C|rx%mz7E5{=MQ!omEb$ zpstijuFc7ND-yM{D_@ad>)Prn8RzJ1RN;dvMqgaEfZeQBF5K4zQGFkDw5CW%3TXOR z8Xo-ly76>~&$+ZZ;^F-2ntWwOt4=NMsAK$&bGn8@QRbbc0Hq@<8qB47tb6PA)buiF zGOu9hwRJ^(;$L5>`VXS=(KBWFgVTzG4jlF1bMkJM%)-oBx|c1&;x-~q08}&Rfl6l$ zxI$Yro=dtq z##wWr<-L+_Xy^QO8PMcJabPoYo3H0X2!koc$Y~-XQ$RORF855j{nGN>bpwrv0h@cA z-;s)d-`NSO*N878!cL4DFw%*tAY4R1#OG?K(8D0C^|HD4LJq{hG3bE<9yr)wpwIK1 zR!FU|&NmK~e0cl*hH?zs37c)?7~cudzH?A=C)n=Di5ceI(zQ7iBr?OSc{n< zaU=%vBhtQX)vK#JcP$7cGy^&V(;haNpPFR~Dux^LJ^)$izYt#>=zKJ|>0cf7+1dw4 z^Dqhluw8cJ{w`!*qKM)QuL}>8%<874K(TI0gXxs1=vOz58q!hl$3V|utDk^VUNcKt z`FV#g{p#XJB!@Z}brRxWPVB=N%o6lXmOc2PL7imPS2cj@GX@m*=6kIxILkp_1&iD< zJLdnW(E(mD7{shVD9KP*XMWF(XBUs!I|iBqD4p%Z|;e znjbki8xyNZ{<6(?*mSQG2V{@rtZGp8{)u<$6K_S=<)$ehmk2c=>|}9 z(AhO|?Bt}TgQ|d0E`E#yrJa$p)gJbK8k$U<9AV6$uG}aM z%Xo1!#^BbICkTs{v-0{m+Y@6$nJa8~dF?K8psyjO>+(YG=*#oauR5crNqjgFH&)@j z@>tTh6hyf(y6@&1-n%Ehs~gC%H}c!AZ{FYZV~SaMl}Q<-FISP2*Ap$lzAfdJpz~^q zc#$K7a{pk3b;RSKcQvW|69M7kSG%qw8SzpIDa%D2mZgqc(wxBEjY#&^eZzB){j4Zd z)gZErWW%X?A$?F==%2~oEb-U-Q zn(dOE0QfhJBQE6H>h5X2aV!_}`bJ$TZCF|YP637RAb>2=yT`jyPvSvAC|wg)v3nrd zx3*=``14N8exUA~Y*xWQ>IizN!2<>FYWC)jYC!EhaIBkQF|{>ShtCXlJyr0)qu9JuFt+YfYCsqnt?P0vV?lNqxubmi6hps08^m_cVI{fI~ckxYfZfU{gw08jJVV|STro7U!yQ+~JamQZD04J7q!loe7Rh9v#qN|-Q$=;m; z#vml+-SL43^``Wf#+yUhlkVI2LRrOH zn?z)VN8!1l)7yBFcI9S(t1ih`%ZcIY?c2hY=UL1_t1H>th>s{oS^Jmda63nVFQ<5d z1|URwYjp!fW^q}`Jj>$;ySw+o4M~1oLs?cab2Tf%LQQv~!m@W@Z}M+ba&xj?s@#meK`&DUle58pq5l;te&I?UEzkrO* zzs@eX0g!AZ`$0)JB}%&o-sJW+1zy(A)q9&(^}c)VPk}c5G6SO{nvV1Y>%+A1QUW#JV4Osl8HHx+VXU zI<;>#Tj&?s*{Z393I<=IYjkCn^3MIqUi@CRY*$*bmF=~)8`4-I(Dm|FJx(91@2O;i zZPNF}*qS`Z{Tp6wYQ^X8&=#L)hCa?VS*~7D>4nZ?;I3X(h+Ct>U3QB5{JcwXQE3A^ z7GPSYj`rJShau&cSFZZq(KmPXpP@8q&*}Gd%d%#l_zTW1znzZ86m4)%CW8H#H17>H zOh!}i*VS(;@7nPq9(dE*nbr}A8YzyxyXGTx#ARXC^WpYpr88WOFI0Us&%4glO%Kao z8D8xijdYOtU|oUYVg@hn>|GWs-I7Co_x_F@b!8WWilxMyJByX9A8)jW^CS(38h|7VM2-?sAz~()@a;Q!6 z+TPYj1~(01PQ{Ml=4iFFN^|mX*5?c-4yBCLH#UoZrP2cT-!|rzwuMoxU{jo)Xj*&#EF zKG;|8*SLh~crRi66I+M!%=-+Rfgitfd6`$hY&{0Z)}(u&O%1-iZ3=R)c{(v*Jn}YA z$zH|ps=Q2$iR22UFre>%ZAMpV3>94udXW6sQG6`C!-v&l28LhuI(@O4t9*rxUTUk{ z>hhP?_S#DPm;bxzA)D(ukI7-X-UC{_e1qAeH&%9EF2pk0upb+0q!?J*-mPY@XjqH! zMrvB|$S}SB+DB_du-a;OTf(OT1^-&bWnyhD1E5y~sL{^ecMrXaUAY6ZjFDOfstT)V zTBRJ9=)XlcyXLikEG#&PoX|YvsFBiTu4>)IZ=lVstUP`@!b@aP?hMQzLop;HuM=gu0?hfJle>>7=Hs${obtlpm4nXpqggm&}6n- zK+~JRlWmva+idOltt~?!v1D^+1$Ji5_=`BG_~ls3co}-pM~aKt{k5yh^D9!*lb8JQ zrlKj`%UiOvAvK1omL-Liyo~5j+L8+W)Il^Vy+%s-gGD z+|8X;g*qgjtTySBZyL{aD-7lL>L8pRec8tSB>&5RbQDmy0`lRu9Xt zJBb%Lh56Y2Je|p^BG#`YV`g_02dcurwle3>I=4t2^867x0UumhJs;rYEwAE^}b z#2=AERE5cmTDh4yK(}GKtpy&-n5Ee4=8+d%SK7OSn{oTW$m_f;M(jl47Sb!rGxBnr zyarTMQIP+Pshdk#o*bDSB<@Ov7X?)0qq6v6%jNNI3ZLHnES9l(P?|ow+cN2u`i-`J zDUsm)G9sUQjk&SaFSF}j{X#wDou26hAWkmr0`y0 zSS=La?&DcEleA~3C)bN!=E!mNUmm(w-fTRUJzbV|CZW0lRal(mE7VEAbwR zVq^?NXj%H&CNC$9B;aIC`uurwF%Zvg>%gjXasHI%aL!UbKe37h4;@dcifn^a&lajy zp4Edq-y~9C2+Z#CZb8nJd_95d619oXfsyK0MeO=*wV;dqM_W`$wwE=8=f^cv;nY`=48+xNs~cL6~=DU*2b`T7>uYPK|dT(5wBHueO> z(wQ)8d*{`=N6}0$=&pe+a6B1$odft{KxIbNkjeatv?}g%7|m2^4MfJ6TKOu7 zV(+kOAWxZ77wjU(Ub=d3PLM4_Iyt{RG zN-YGlvC~{FOrUP8TpvyT^Mow{!_adI$X;8Eu5+EtD6}K-VTa^b^(@wn2jl~>%gP-kx4^Gmut!~L+*DT6 zFwO_%kkB=ARa`T23J45n=%p#3Hqg%6p_MhO9<8tO`Op*Wa%8HPS533ru&ev*sZQ(5 z2&YX`?noaLGuP{D#w>v(Z>_t9V4fl>v76d zIxuaV?kNLp3acg@{aU3SY@@(LgE2tjT>-+`wevmgc4;9ZQ4tA81J3FCr6^JTva0>! z_U_U~aQ9v>gLhqDgEs*QLgQe!0kYxXT5R!JkQMEIde70OlWRw6)C$aFG#MGj{f0pn z$r7iYNwTY$F#mx(M|@`yxcR^f75O_af&wWvQuG)0GYhkDELGApLVyv11Zc zG&hN5|8(pH?&3YjF_#@2jN&<~y33np?u)8egBuYz7q@!O?}adM8%<`3kv=n&k)}tQ z6*TyFKr*B4db>uv=Z4UttX(iH&#qz;N;b3?s5fS(tdkoX+Ye+t@2)T3-&op-T_pY~ z{iUl8JEi_4Zrv}JG?MEiC9~*xDHJQKUq?owoy1|O0u|*o>%_Y}^dae;fp1Rk%0qKs z+0-U}w`A@9hVv5njneY&*ErBGeyuDE>tdsp3T*P(ssbBS99Lfy4Yn)BCsb=9OPdzY z(FLY-7i>(Ln)+z2LE5Cnl z1r7*46E! z7|=g}ph!Bo2DU8vNU=af8WBbAKzXbbc>q_sv=6F8!5v99T`}>IMbq~;^KV-_A;jP8 z>Q@&4m6kXl(6Vc5iYEwT_Tx#U{dn^-2(UB$)AS*ed9F0Fj9x}mVCu3GowoSiJ? zw`+N)#j4m8?BrXEC?Z|{!u=#^Yx|0Z-&s`DuYO;&tiS%WxukDD5DP01c302n2$Q?; z5H?VY>NsB|=U>seffa+9zWb7 z7%AmE6aKc_UiOGe$VX&!=4#h%>a^WoiE}+ru5CH-~Cz~(h_SEFQQ;j zqA50|GZIWG2C%*Y|Jj%~MzlhBQVt?z3E3}8J3C8z3Z>?cFO)#qyk{;t&rApfTGiFg zf8D0-vyD<^-7C-P${cIK#p$)GI4F+#^bneA-C$T=x5$o=Y5?lz(p~*DznjavO;19& znv*YH$Wt^jSEBb#d0qha0WLcoQix2K@cq%DaM)(2$Y-2cgg{ePjZ3r2fP&2PF}oh< zS^j>~G03}WDQC2CVv8lCB1xi1+hh4+aG26g#O#Wm<-PuTPtG~fvwRi7u%T446~N=7 z%rAIx4zWIQN0MasYA;=gxUGWHe1o&=R&rQ0lq}J+rsVAUoT!q1R7^*Mh@vd`(fL+> z@LqN%JImtevc#S7tUHt9umXfLm)X1SfOP4gY!=+q&HSw}(@7!+m);*I_9v6%+|s?JWxCFu2zAN! zIBlMT?R&aI_SL!$x0CJ|7qtQ9#o2`a>nvqANorOUU{q=JU{lxQx)H$Q_QkK4#Fti+ zZr*r=tl=n2Ajgv)*j(h~n5fb{9T4+7HmN@fE)l#oRZhsEnxvOsmHS%!Zeq6-M3!Ic zlv}T~c7)vygA=p{c74&bE<;YHf>NN-Ne%9+N%|FnY%FwWJs;ne1KCm%x^5|Pt+zbO z8BE3!v6HWs#F_De)X(NbsS9wBfY)Bawv=;@+3IIwh0PyvTqRZ@&n#5!b$E#YSl&rr ziASW(t@N36tEIi|HT{Il^q(>aDrSH|wZZ%xo)evN*k;Vj^L@g`@`2@ceSQQ{8S8^_ zEo~x$VQVA`A%KC;UDxW7n~*|&cL4P z9u{3_n;b_^u^-Na4Hvi;;L%cBvX8-^A_jS`PF7I1K)k-Ov%PYEx!N1?qRM1EY=xGv zw56jJfk1?~Vge?sn|C($xM(1NKO5;#qJBlr)15CyT1kh|@lAO#cV)p85n`CD((TP( zDi5Z@+e=vt{7Vls9=?#;vSc67Dz7fA-noDGE@AThG9e##joU`L>V>q>m&BI7wqGS8 zK4mszc-UR{oK~f?i(l`qZgDtXisCYBe^iV0zbf3V?v%=+E7@+c=OUlK@e~LvU)8X2 zcf<>H^8_iPJAG|k)w@YLVh$HLGB5_EoBI9@3j6qheeoihzmB~dZt8)9^Z6#RP z-N_<(VMF&Aa=h0({Dh=4tK|6236mn&-LL*AkVkuYtIFgdRY@%55&`1?CBJGxbE(GC6mvf-;fItS--2mp)e(4r!(Me04*MKCFCQ zF^g6nCB`kS#J+H&p)X6&paWuIFi2iaSI0~dweE6$EW1~nt6Y`v$54gzCOWx?pmh(2 zpGuBxBI|SrVU$k}qlIDrQI=CMSkmB_yc1AvZ`PpGT`+oG`-Rhsj^wvfunG{EA2z_U zEoAu0oycKx-;|E{F{dX*ac-1-W`mYhci%b2rG@6?RAP4R!WYPM4uDnj<2C*v*1IX7 z8qOW7zRqXmsS<9a8~62rJU02qD1X9+C|2M}V97zC5FOhg;8Lt9}jy%y(kxwaxQ{%Tz!kS$~YUR!-2@?IsabBzziQ)71n z;AgnqJ(-?y;k;c$@x|kH<^xT;szc!HdQft8Gh8WTPT>ZSQx*%>hO5g3zkKjY-}c$I zVtDLN7Q3|9>|MEsH)?n6MA87c)<`$iWUb17UvoP$52ZB5)wSrNro zM7&yRY8I%VIPS|Z0jX&UhFS4-LIM-ib$(C9?+Wfk7vf@`=#z3`{Or!{+pnju)7-)z zy!*3vZYxhU_RZ|p_ST+s3ngJ;l33h)$?S}rk7#d-XE6U4cg=OZP%+82^%bdEZ&u&K zMr@(K33hGs=EH{RyzYK))#kT-+(dqKA%9+=zIyU9CkxJ*HQXbDL zo;f>G^Q|(CNx_BJe{-b1ppI{{W+2b}WTcuP_nA}^K67WJqM*;4uCBQ{ta(<@$H-OH zvu8%C3h+Yt5-Gc@MjH@7594PAypcjUQLLiYc2H5k`;3~JTGv5M0Uv-ib$vg|9_YS2 z%V6iUpaM3E>jgWfxmB;CGg}-9-NDG`G(pwZy5RS<&P51)_|9o|b9nsBPv_M{1%qmu zTEChW-@=9^JQmz3f-^z<%ElU@)^ox|S&0rR$AsYQtV9Fj4M#;rLGPX8B5;5R@HQiO zc*F4!sFWPbr257PI^GaE>aQ6xl{ZH4@rLkW^`ftl{riR{7IhrD5uChfI~aSgBI7sK zkh{*fgfRPYT|xb(qYoG7P21q~k)e5W1PyO$7B|iCR3!uF&5<4brsh%4-z#cc2n;I^ z{%GsrZ$~!ro5s7US$R#(-#QV+fY>)}yHhI{yd`AxDeo;oIsA;I_4k&jVA`t@47{aj zjDL+8VBQ+p=5J|g9o^u9vWg?S{4G&-u4pj^h<+|2TK$!DQ#KLbX*B8B6MrZc5}$*4 zzpcq-g}^_|NMCP{An0w;cUMswgkCM8`sSb1H2o^A_=x0J<{0-t`|y-XMJUFAoC=Gkc-}?B@>I8B)mc3$KfDT? zL|1e+ECZqGcIFgQoTRKYX#i;PdAiCfrPIW2a`LQQUo&H?fY({Ot-@5NN#NF>4ZgwE zo=I}MPG+O4lp=il4qf73X?u$4+>=Fsd(7_6_?qG$mW{k}Yd+>B{lzyhePdB6EuWbN z5A-n&zb7w@qg|}aZHT6k;|FRzgSN6KrHAuNKCZMt7MyH+pxxOEi}tAs(eH8O2nO?u zRj(Ge&BN0eUa{P6+GIuFhK{fn89WYvP=IG8z{z3rqPjq|bjME1)$n0u(ArFuC@}R7 zhm|GdaBm)EOxB9rK}WmmYZhX^xNTUpNoy8cItkjDD2xXr40ew;&-_G;&e)VQF1CWU zk3OH}8eZ>}cqoHqN#ql!gs#I&cL>5KsYee3j73yL;X$`H~h{|zRRNt>A zboKRsv!ZA*i0EiU={T$DVX4|zu1!HWJHi=Im8;>b9;$VJymJDz#Qp~9qEruR3fgX5 zW{FNcs3d@!?yRC#SUQ<2&!N1XlkU`S{e}R{Y%3!G?bwJi7tgSQ#3px&v|oXwa^Hi1%$bP(%47OTbj6P#RM%_ zkV(BYLX~g%hR$`PSG3GQug;Eza8HnLJ&sW3TbgjsHbQY6bSJ?3)ih%>q3Bu)-;s9l z+nQ9FthLni`=h-r8Z5OstM_fqeo$3ZsGSwYl=Y~o52}eSoy?n>ntZ?JPqF~WmjbOr zOval zD4<5bj#MGxwGJ%J0rjrbI}4akhBJEYCgtd`x1k?C67pff9ver?Nrpjekg9 z+a;fIU_J<_iJYtIyh*h#$0MRtLBeq)W4c(s8V5(?4ZZr(mMgFBCM@V=Vf;j*3}C)Z zaO0J2@^__MaIemKF%_(fBIw>1Oww2(igrRooB^ub1GzZmhUC6?{54_MH7`&2bLqmY z0UpAf=~{YR(ZcSY7LW@4XSYqRZRhwSs@&2=abo! zrf?gpA4TETLH6Q;sOT;?q6nO3E26I91LBF77H%g-yyb@lPjDPjd56tWepPYp+Pyo% zV_7m=WCdu@dTvf$(5{Zn6Z^p4;cQbNhk3tCYY{CIi?rkXKEJ&p+e4us*#;DcC-{Pf ztMc|c)#G=zZs!$rzP24lZU8YqAtP**aCyzIz`xriO*UKk^|ZQ_WQJVW-dxhbgMshn zVlJ_kewwA|p_P^Rti0h$JY6^WIfsHY!)zR|C#0kk9z+G`XB8Er%n-nDt!&`gJMvS@ zK(XAw`Pk!{;&eVwq~73nUS!)oZZ-1LLh<0TsC7K zG!C)C#Im!wD&gvB@e~49{EwS&96gq6t~wXnGHyd|dfP?wH~4vxTsW{g9&$$A`5T#< z90^WYMj&0ix*ddi) zpV2Q`loSWMemGfL`58sOz7wdTnae?GKDXu#JXHA1Avt$Gzo{sht2&(eOlG>Igq_!w z5p=Hn*{+F*-jYODr*#k_cB@;|z6f-!Yk`pycR>kOg%dxoKCFw=mbI6Ea;ItDH(h>g zI-B>A#$Fvd4#|S`Um3;c5DA1k^h9#rsHjtvWfv}xj!TOqUX*jlUei%F$JQ$=>_S`a zO9Xx8Gj(lHvYEtzp)XUepd2dx8Ty6z#%#w6RHBb)LQD1w{z4Q0=adwxo+ZZ7vxzI) zv=XCtI7^&{2@h2hCGa6DU7;`=Tg$HtRB{oB|L`+fBa?NKw#C;mbW{&%M`Vf)`*~Cc z90_X=2rcDdZb@GkwKv9g=i8PsYF(wY@Kl-fnwh!X_P@Vs8_P5BY2XQ`r8W20_!hdb zX5ZZI&N)rA>Rnf0JYnwsWOsYB^V<07usdYHtX5rtQaLxDXz#8>tU5pQmg7B#+c0G* zTI*|yz!V#_NV3fOIP>$fOh3OQTA{4J(gk>*N}#iSA1zFuIq-mK{bKO40QwyG_9my! zcC4x)C3!?l3OQL>?cn#*YF!ju*j>G+BS>z#*Dpy-$t^-%+?6U)-ee+CPL|W6eEZ6t zlb1?Bcd4lYzKGQnT=X--rmTDDevt7cf2h4Jv)iGiD0}+Ne^^T0J!e86d@A}+;#NHd zxFS5ET-eMif|kVeY}UrQvQ#ksQk%%s$hdy3ePc8=(TZoiHi{TQ7V73wDR=D^>gboX z?Y&;9(@5{GUz>xCAgFwc+tb7Z{Pfm&nuY;w5e0DA6aZ_1OI1X4bb}O%6E;lgMhn1o zt#G(}!fWg8w%+7t-<*5>!ug9oIsfLVGq1mX;nW**Z(cn0lXGvMIrYZdZ_mAc>Ge0> zId}HbZ_*$9!KNLNzy9@GufP8K(wRG_6!7GspB`*KiANjMRTpg_3uBg?^K*1xH#Pi4#<(x_ADyeW^aO5lDos?yM?E*?jl;TC`tYg7FjwJnFi~ z?SU%TrCh?<$tvWOhmQ1a5#8H8rS6x@WW}_iD#`ECy-1huuj`}Qs}Jn2W~a!$D~g4z zV_*IGLv+RqS_PnTf!SFA*@M_Uo0O14JA0iKI;1VE$h@#B)4Qja31oI{^hn0EZ0XYG zhz9t%oFnYCVy2W^?DVqPo>2%jot|CcBRO`IoTFq;uiUwpHGs)!{mS7N(MoiB`t$8O zkuOx6`1XoUU2dPf{rc&zCo75neKV`;)F+YxpY{K3{dYqDF6;mI^;@CtdR|uz1&604 z{Z)js{_?Lxq~3k5+IRGq=;9OlwW@zt75SlC6zXBudN|$Hdr!Ykrf<^g={Nd2Gke3v zypuLmZ&U9M8fiD}rF*K^^l{T9 z`(lGz)(V(o71H$>-Eqvid?r{|(*xC7>Y%H8@i|hWR4>9XYfG~mPxn|3EUT`?vtJ`$WuR{z&}T2UFa zx1m1R7Yd*krKY)?`mKu@)&@$2!kl(?RcBqZkNJD=PzRVUJ2q|B)Ly@fp89JrzN?N% z{0B{sSu7yG|V_nUM^TsM9D%;8gY0H#gR*<7$a$9TO4&OZJQ zpkn`jeLSd$^*TrfvO`|!WW%(Tt%0H&ANQnS?y#r_`s)m;W)>^PE?==t5Q4Z& z&lLig4x7mpier=P{{MFPl#aGLTL}$c{hOZJU;nOnALLio1}mIOKT(DfxfIqMFF8ME3$K)!d)=6*_b z5RS0duheEE;~`ousi#mOLNG`X>?s6~1j((3hvbBWk}K;-LtU>lalfPa&14*1QaMTu zwGdxpctH_y5-idiZ{;k}PC6Tnp(&!bn$&H6rlB+_V-S zj&1Ba5_>KPTQ$b}D@x0z<`#yC`ug$M=+Fd)%PEb=xJ$;ZX7>ML(GYebjWrrW6@a@9 zgudoNZ%K>5Z*<88^@qK)BA^}!{8vmHfWN>pVS{K2z6=muM!>1D@dI7$c+;jBweM-H z`x-6x{LaBWJG6m5v`L3sqwIfsQJ}h!1dm{XK4E?p9*{8(6l(IQWDf_pRL55feY{|K)iD(#gkdRTn+zuy@rUNNb{DA*f&-f2gj* z?x{g(HQm}5fPxbGGCDcH17K*&VvQd=0-5@fM#6%^zd<|3^2zkIX$%hb6^L?m#>uz{ zh4kJS8v_~rSq=OCRZ6EmH5iJ416**3vO9eNP9)WS>eH0IHz)Y1QIbvFU|_u*M1<+-tEzuHrDrdsi|JCDO}Ek&m82JZW_>Z5 zUTWbQyuY=mwJo-6|9wjrtSxkg4+IT6#Cq{_INO=Y-j2uA+v-J)TC>YAV13KDT^Sbj zkl_uXaP74)VH3d%Cp4?;85{HlWwc&|S2|^(jJ$440}5kTy5)+jvOf3!;gbQqza7|o zP5@|p?UKHiwT86+kDd%LWBc<+06jM=+PxxxFNls8^-X3g$g(2jJ+-Fb=5tC}z3Tl!;j zH1YW6T8sjAoyJ*zGIJZzh@a3%eLLXE&B>{8Rx9MHpGNxf$zabZ(4F+5${}bq;{I

*ma1cz6^&g@HBmOu&%72=n2|kDYFh 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 HX$t&bLti&x literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Quartz/ClientProfile/Quartz.pdb b/Resources/Libraries/Quartz/ClientProfile/Quartz.pdb new file mode 100644 index 0000000000000000000000000000000000000000..7dd4a17f322fd3ee7d9c3bfd32a844bb1934d921 GIT binary patch literal 1191424 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�**o4V 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Quartz/ClientProfile/Quartz.xml b/Resources/Libraries/Quartz/ClientProfile/Quartz.xml new file mode 100644 index 00000000..de320e2a --- /dev/null +++ b/Resources/Libraries/Quartz/ClientProfile/Quartz.xml @@ -0,0 +1,20066 @@ + + + + Quartz + + + +

+ A wrapper for generic HashSet that brings a common interface. + + + + + + Represents a collection ob objects that contains no duplicate elements. + + Marko Lahma (.NET) + + + + A sorted set. + + Marko Lahma (.NET) + + + + Returns a portion of the list whose elements are greater than the limit object parameter. + + The start element of the portion to extract. + The portion of the collection whose elements are greater than the limit object parameter. + + + + Returns the first item in the set. + + First object. + + + + Returns the object in the specified index. + + + + + + + Simple C5 wrapper for common interface. + + + + + + Default constructor. + + + + + Constructor that accepts comparer. + + Comparer to use. + + + + Constructor that prepolutates. + + + + + + Returns the first element. + + + + + + Return items from given range. + + + + + + + Indexer. + + + + + + + Only for backwards compatibility with serialization! + + + + + Responsible for creating the instances of + to be used within the instance. + + James House + Marko Lahma (.NET) + + + + Initialize the factory, providing a handle to the + that should be made available within the and + the s within it. + + + + + Called by the + to obtain instances of . + + + + + JobRunShell instances are responsible for providing the 'safe' environment + for s to run in, and for performing all of the work of + executing the , catching ANY thrown exceptions, updating + the with the 's completion code, + etc. + + A instance is created by a + on behalf of the which then runs the + shell in a thread from the configured when the + scheduler determines that a has been triggered. + + + + + + + James House + Marko Lahma (.NET) + + + + A helpful abstract base class for implementors of + . + + + The methods in this class are empty so you only need to override the + subset for the events you care about. + + Marko Lahma (.NET) + + + + + The interface to be implemented by classes that want to be informed of major + events. + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + is scheduled. + + + + + Called by the when a + is unscheduled. + + + + + + Called by the when a + has reached the condition in which it will never fire again. + + + + + Called by the a s has been paused. + + + + + Called by the a group of + s has been paused. + + + If a all groups were paused, then the parameter + will be null. + + The trigger group. + + + + Called by the when a + has been un-paused. + + + + + Called by the when a + group of s has been un-paused. + + + If all groups were resumed, then the parameter + will be null. + + The trigger group. + + + + Called by the when a + has been added. + + + + + + Called by the when a + has been deleted. + + + + + Called by the when a + has been paused. + + + + + Called by the when a + group of s has been paused. + + If all groups were paused, then the parameter will be + null. If all jobs were paused, then both parameters will be null. + + + The job group. + + + + Called by the when a + has been un-paused. + + + + + Called by the when a + has been un-paused. + + The job group. + + + + Called by the when a serious error has + occurred within the scheduler - such as repeated failures in the , + or the inability to instantiate a instance when its + has fired. + + + + + Called by the to inform the listener + that it has move to standby mode. + + + + + Called by the to inform the listener + that it has started. + + + + + Called by the to inform the listener + that it has Shutdown. + + + + + Called by the to inform the listener + that it has begun the shutdown sequence. + + + + + Called by the to inform the listener + that all jobs, triggers and calendars were deleted. + + + + + Get the for this + type's category. This should be used by subclasses for logging. + + + + + This interface should be implemented by any class whose instances are intended + to be executed by a thread. + + Marko Lahma (.NET) + + + + This method has to be implemented in order that starting of the thread causes the object's + run method to be called in that separately executing thread. + + + + + Create a JobRunShell instance with the given settings. + + The instance that should be made + available within the . + + + + + Initializes the job execution context with given scheduler and bundle. + + The scheduler. + + + + Requests the Shutdown. + + + + + This method has to be implemented in order that starting of the thread causes the object's + run method to be called in that separately executing thread. + + + + + Runs begin procedures on this instance. + + + + + Completes the execution. + + if set to true [successful execution]. + + + + Passivates this instance. + + + + + Completes the trigger retry loop. + + The trigger. + The job detail. + The inst code. + + + + + Vetoeds the job retry loop. + + The trigger. + The job detail. + The inst code. + + + + + Default concrete implementation of . + + + + + Client programs may be interested in the 'listener' interfaces that are + available from Quartz. The interface + provides notifications of Job executions. The + interface provides notifications of + firings. The + interface provides notifications of scheduler events and + errors. Listeners can be associated with local schedulers through the + interface. + + + + jhouse + 2.0 - previously listeners were managed directly on the Scheduler interface. + + + + Add the given to the, + and register it to receive events for Jobs that are matched by ANY of the + given Matchers. + + + If no matchers are provided, the will be used. + + + + + + + Add the given to the, + and register it to receive events for Jobs that are matched by ANY of the + given Matchers. + + + If no matchers are provided, the will be used. + + + + + + + Add the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the identified listener was found and updated + + + + Remove the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Set the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + Removes any existing matchers for the identified listener! + + the name of the listener to add the matcher to + the matchers to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Get the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the matchers registered for selecting events for the identified listener + + + + Remove the identified from the. + + + + true if the identified listener was found in the list, and removed. + + + + Get a List containing all of the s in + the. + + + + + Get the that has the given name. + + + + + Add the given to the, + and register it to receive events for Triggers that are matched by ANY of the + given Matchers. + + + If no matcher is provided, the will be used. + + + + + + + Add the given to the, + and register it to receive events for Triggers that are matched by ANY of the + given Matchers. + + + If no matcher is provided, the will be used. + + + + + + + Add the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the identified listener was found and updated + + + + Remove the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Set the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + Removes any existing matchers for the identified listener! + + the name of the listener to add the matcher to + the matchers to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Get the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the matchers registered for selecting events for the identified listener + + + + Remove the identified from the. + + + + true if the identified listener was found in the list, and + removed. + + + + Get a List containing all of the s + in the. + + + + + Get the that has the given name. + + + + + Register the given with the + . + + + + + Remove the given from the + . + + + + true if the identified listener was found in the list, and removed. + + + + Get a List containing all of the s + registered with the. + + + + + This is the heart of Quartz, an indirect implementation of the + interface, containing methods to schedule s, + register instances, etc. + + + + + + James House + Marko Lahma (.NET) + + + + Remote scheduler service interface. + + Marko Lahma (.NET) + + + + Starts this instance. + + + + + Standbies this instance. + + + + + Shutdowns this instance. + + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Initializes the class. + + + + + Register the given with the + 's list of internal listeners. + + + + + + Remove the given from the + 's list of internal listeners. + + + true if the identified listener was found in the list, andremoved. + + + + Create a with the given configuration + properties. + + + + + + Bind the scheduler to remoting infrastructure. + + + + + Un-bind the scheduler from remoting infrastructure. + + + + + Adds an object that should be kept as reference to prevent + it from being garbage collected. + + The obj. + + + + Removes the object from garbae collection protected list. + + The obj. + + + + + Starts the 's threads that fire s. + + All s that have misfired will + be passed to the appropriate TriggerListener(s). + + + + + + Temporarily halts the 's firing of s. + + The scheduler is not destroyed, and can be re-started at any time. + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the QuartzScheduler. + Equivalent to . + + The scheduler cannot be re-started. + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the QuartzScheduler. + + The scheduler cannot be re-started. + + + + if the scheduler will not allow this method + to return until all currently executing jobs have completed. + + + + + Validates the state. + + + + + Add the identified by the given + to the Scheduler, and + associate the given with it. + + If the given Trigger does not reference any , then it + will be set to reference the Job passed with it into this method. + + + + + + Schedule the given with the + identified by the 's settings. + + + + + Add the given to the Scheduler - with no associated + . The will be 'dormant' until + it is scheduled with a , or + is called for it. + + The must by definition be 'durable', if it is not, + SchedulerException will be thrown. + + + + + + Delete the identified from the Scheduler - and any + associated s. + + true if the Job was found and deleted. + + + + Remove the indicated from the + scheduler. + + + + + Remove (delete) the with the + given name, and store the new given one - which must be associated + with the same job. + + the key of the trigger + The new to be stored. + + if a with the given + name and group was not found and removed from the store, otherwise + the first fire time of the newly scheduled trigger. + + + + + Creates a new positive random number + + The last random obtained + Returns a new positive random number + + + + Trigger the identified (Execute it now) - with a non-volatile trigger. + + + + + Store and schedule the identified + + + + + + Pause the with the given name. + + + + + Pause all of the s in the given group. + + + + + Pause the with the given + name - by pausing all of its current s. + + + + + Pause all of the s in the + given group - by pausing all of their s. + + + + + Resume (un-pause) the with the given + name. + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Resume (un-pause) all of the s in the + matching groups. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Gets the paused trigger groups. + + + + + + Resume (un-pause) the with + the given name. + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s + in the matching groups. + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + with a matcher matching all known groups. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + Get the names of all known groups. + + + + + Get the names of all the s in the + given group. + + + + + Get all s that are associated with the + identified . + + + + + Get the names of all known + groups. + + + + + Get the names of all the s in + the matching groups. + + + + + Get the for the + instance with the given name and group. + + + + + Get the instance with the given name and + group. + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Trigger exists with the given identifier + + + + Clears (deletes!) all scheduling data - all s, s + s. + + + + + Get the current state of the identified . + + + + + + Add (register) the given to the Scheduler. + + + + + Delete the identified from the Scheduler. + + true if the Calendar was found and deleted. + + + + Get the instance with the given name. + + + + + Get the names of all registered s. + + + + + Add the given to the + 's internal list. + + + + + + Remove the identified from the 's + list of internal listeners. + + + true if the identified listener was found in the list, and removed. + + + + Get the internal + that has the given name. + + + + + + + Add the given to the + 's internal list. + + + + + + Remove the identified from the 's + list of internal listeners. + + + true if the identified listener was found in the list, and removed. + + + + Get the internal that + has the given name. + + + + + + + Notifies the job store job complete. + + The trigger. + The detail. + The instruction code. + + + + Notifies the scheduler thread. + + + + + Notifies the trigger listeners about fired trigger. + + The job execution context. + + + + + Notifies the trigger listeners about misfired trigger. + + The trigger. + + + + Notifies the trigger listeners of completion. + + The job executution context. + The instruction code to report to triggers. + + + + Notifies the job listeners about job to be executed. + + The jec. + + + + Notifies the job listeners that job exucution was vetoed. + + The job execution context. + + + + Notifies the job listeners that job was executed. + + The jec. + The je. + + + + Notifies the scheduler listeners about scheduler error. + + The MSG. + The se. + + + + Notifies the scheduler listeners about job that was scheduled. + + The trigger. + + + + Notifies the scheduler listeners about job that was unscheduled. + + + + + Notifies the scheduler listeners about finalized trigger. + + The trigger. + + + + Notifies the scheduler listeners about paused trigger. + + The group. + + + + Notifies the scheduler listeners about paused trigger. + + + + + Notifies the scheduler listeners resumed trigger. + + The group. + + + + Notifies the scheduler listeners resumed trigger. + + + + + Notifies the scheduler listeners about paused job. + + + + + Notifies the scheduler listeners about paused job. + + The group. + + + + Notifies the scheduler listeners about resumed job. + + + + + Notifies the scheduler listeners about resumed job. + + The group. + + + + Notifies the scheduler listeners about scheduler shutdown. + + + + + Interrupt all instances of the identified InterruptableJob. + + + + + Interrupt all instances of the identified InterruptableJob executing in this Scheduler instance. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + + + + + + Obtains a lifetime service object to control the lifetime policy for this instance. + + + + + Gets the version of the Quartz Scheduler. + + The version. + + + + Gets the version major. + + The version major. + + + + Gets the version minor. + + The version minor. + + + + Gets the version iteration. + + The version iteration. + + + + Gets the scheduler signaler. + + The scheduler signaler. + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Gets or sets a value indicating whether to signal on scheduling change. + + + true if schduler should signal on scheduling change; otherwise, false. + + + + + Reports whether the is paused. + + + + + Gets the job store class. + + The job store class. + + + + Gets the thread pool class. + + The thread pool class. + + + + Gets the size of the thread pool. + + The size of the thread pool. + + + + Reports whether the has been Shutdown. + + + + + Return a list of objects that + represent all currently executing Jobs in this Scheduler instance. + + This method is not cluster aware. That is, it will only return Jobs + currently executing in this Scheduler instance, not across the entire + cluster. + + + Note that the list returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the true list of executing jobs may be different. + + + + + + Get a List containing all of the internal s + registered with the . + + + + + Gets or sets the job factory. + + The job factory. + + + + Gets the running since. + + The running since. + + + + Gets the number of jobs executed. + + The number of jobs executed. + + + + Gets a value indicating whether this scheduler supports persistence. + + true if supports persistence; otherwise, false. + + + + Get a List containing all of the s + in the 's internal list. + + + + + + Get a list containing all of the s + in the 's internal list. + + + + + Helper class to start scheduler in a delayed fashion. + + + + + ErrorLogger - Scheduler Listener Class + + + + + The interface to be implemented by classes that want to be informed when a + executes. In general, applications that use a + will not have use for this mechanism. + + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + is about to be executed (an associated + has occurred). + + This method will not be invoked if the execution of the Job was vetoed + by a . + + + + + + + Called by the when a + was about to be executed (an associated + has occurred), but a vetoed it's + execution. + + + + + + Called by the after a + has been executed, and be for the associated 's + method has been called. + + + + + Get the name of the . + + + + + Contains all of the resources (,, + etc.) necessary to create a instance. + + + James House + Marko Lahma (.NET) + + + + Gets the unique identifier. + + Name of the scheduler. + The scheduler instance id. + + + + + Gets the unique identifier. + + + + + + Add the given for the + to use. This method expects the plugin's + "initialize" method to be invoked externally (either before or after + this method is called). + + + + + + Get or set the name for the . + + + if name is null or empty. + + + + + Get or set the instance Id for the . + + + if name is null or empty. + + + + + Get or set the name for the . + + + if name is null or empty. + + + + + Get or set the for the + to use. + + + if threadPool is null. + + + + + Get or set the for the + to use. + + + if jobStore is null. + + + + + Get or set the for the + to use. + + + if jobRunShellFactory is null. + + + + + Get the of all s for the + to use. + + + + + + Gets or sets a value indicating whether to make scheduler thread daemon. + + + true if scheduler should be thread daemon; otherwise, false. + + + + + Gets or sets the scheduler exporter. + + The scheduler exporter. + + + + The ThreadExecutor which runs the QuartzSchedulerThread. + + + + + Gets or sets the batch time window. + + + + + The thread responsible for performing the work of firing + s that are registered with the . + + + + + James House + Marko Lahma (.NET) + + + + Support class used to handle threads + + Marko Lahma (.NET) + + + + The instance of System.Threading.Thread + + + + + Initializes a new instance of the QuartzThread class + + + + + Initializes a new instance of the Thread class. + + The name of the thread + + + + This method has no functionality unless the method is overridden + + + + + Causes the operating system to change the state of the current thread instance to ThreadState.Running + + + + + Interrupts a thread that is in the WaitSleepJoin thread state + + + + + Blocks the calling thread until a thread terminates + + + + + Obtain a string that represents the current object + + A string that represents the current object + + + + Gets or sets the name of the thread + + + + + Gets or sets a value indicating the scheduling priority of a thread + + + + + Gets or sets a value indicating whether or not a thread is a background thread. + + + + + Gets the randomized idle wait time. + + The randomized idle wait time. + + + + Construct a new for the given + as a non-daemon + with normal priority. + + + + + Construct a new for the given + as a with the given + attributes. + + + + + Signals the main processing loop to pause at the next possible point. + + + + + Signals the main processing loop to pause at the next possible point. + + + + + Signals the main processing loop that a change in scheduling has been + made - in order to interrupt any sleeping that may be occuring while + waiting for the fire time to arrive. + + + the time when the newly scheduled trigger + will fire. If this method is being called do to some other even (rather + than scheduling a trigger), the caller should pass null. + + + + + The main processing loop of the . + + + + + Trigger retry loop that is executed on error condition. + + The bndle. + + + + Releases the trigger retry loop. + + The trigger. + + + + Gets the log. + + The log. + + + + Sets the idle wait time. + + The idle wait time. + + + + Gets a value indicating whether this is paused. + + true if paused; otherwise, false. + + + + Gets or sets the db failure retry interval. + + The db failure retry interval. + + + + An interface to be used by instances in order to + communicate signals back to the . + + James House + Marko Lahma (.NET) + + + + An interface to be used by instances in order to + communicate signals back to the . + + James House + Marko Lahma (.NET) + + + + Notifies the scheduler about misfired trigger. + + The trigger that misfired. + + + + Notifies the scheduler about finalized trigger. + + The trigger that has finalized. + + + + Signals the scheduling change. + + + + + Notifies the scheduler about misfired trigger. + + The trigger that misfired. + + + + Notifies the scheduler about finalized trigger. + + The trigger that has finalized. + + + + Signals the scheduling change. + + + + + Metadata information about specific ADO.NET driver library. Metadata is used to + create correct types of object instances to interact with the underlying + database. + + Marko Lahma + + + + Initializes this instance. Parses information and initializes startup + values. + + + + + Gets the name of the parameter which includes the parameter prefix for this + database. + + Name of the parameter. + + + Gets or sets the name of the assembly that holds the connection library. + The name of the assembly. + + + + Gets or sets the name of the product. + + The name of the product. + + + + Gets or sets the type of the connection. + + The type of the connection. + + + + Gets or sets the type of the command. + + The type of the command. + + + + Gets or sets the type of the parameter. + + The type of the parameter. + + + + Gets the type of the command builder. + + The type of the command builder. + + + Gets the command builder's derive parameters method. + The command builder derive parameters method. + + + + Gets or sets the parameter name prefix. + + The parameter name prefix. + + + + Gets or sets the type of the exception that is thrown when using driver + library. + + The type of the exception. + + + + Gets or sets a value indicating whether parameters are bind by name when using + ADO.NET parameters. + + true if parameters are bind by name; otherwise, false. + + + Gets or sets the type of the database parameters. + The type of the parameter db. + + + + Gets the parameter db type property. + + The parameter db type property. + + + + Gets the parameter is nullable property. + + The parameter is nullable property. + + + + Gets or sets the type of the db binary column. This is a string representation of + Enum element because this information is database driver specific. + + The type of the db binary. + + + Gets the type of the db binary. + The type of the db binary. + + + + Sets the name of the parameter db type property. + + The name of the parameter db type property. + + + + Gets or sets a value indicating whether [use parameter name prefix in parameter collection]. + + + true if [use parameter name prefix in parameter collection]; otherwise, false. + + + + + Concrete implementation of . + + Marko Lahma + + + + Data access provider interface. + + Marko Lahma + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + A new Command Builder + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Shutdowns this instance. + + + + + Connection string used to create connections. + + + + + Registers DB metadata information for given provider name. + + + + + + + Initializes a new instance of the class. + + Name of the db provider. + The connection string. + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + A new Command Builder + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Shutdowns this instance. + + + + + Connection string used to create connections. + + + + + + Gets the metadata. + + The metadata. + + + + This interface can be implemented by any + class that needs to use the constants contained herein. + + Jeffrey Wescott + James House + Marko Lahma(.NET) + + + + Simple Trigger type. + + + + + Cron Trigger type. + + + + + Calendar Interval Trigger type. + + + + + Daily Time Interval Trigger type. + + + + + A general blob Trigger type. + + + + + This class contains utility functions for use in all delegate classes. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + Replace the table prefix in a query by replacing any occurrences of + "{0}" with the table prefix. + + The unsubstitued query + The table prefix + the scheduler name + The query, with proper table prefix substituted + + + + Common helper methods for working with ADO.NET. + + Marko Lahma + + + + Persist a CalendarIntervalTriggerImpl by converting internal fields to and from + SimplePropertiesTriggerProperties. + + + + + + + A base implementation of that persists + trigger fields in the "QRTZ_SIMPROP_TRIGGERS" table. This allows extending + concrete classes to simply implement a couple methods that do the work of + getting/setting the trigger's fields, and creating the + for the particular type of trigger. + + + jhouse + Marko Lahma (.NET) + + + + An interface which provides an implementation for storing a particular + type of 's extended properties. + + jhouse + + + + Initializes the persistence delegate. + + + + + Returns whether the trigger type can be handled by delegate. + + + + + Returns database discriminator value for trigger type. + + + + + Inserts trigger's special properties. + + + + + Updates trigger's special properties. + + + + + Deletes trigger's special properties. + + + + + Loads trigger's special properties. + + + + + Returns whether the trigger type can be handled by delegate. + + + + + Returns database discriminator value for trigger type. + + + + + Utility class to keep track of both active transaction + and connection. + + Marko Lahma + + + + Initializes a new instance of the class. + + The connection. + The transaction. + + + + Gets or sets the connection. + + The connection. + + + + Gets or sets the transaction. + + The transaction. + + + + Persist a CronTriggerImpl. + + + + + + + Persist a DailyTimeIntervalTrigger by converting internal fields to and from + SimplePropertiesTriggerProperties. + + + + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + + + + + + + Base class for database based lock handlers for providing thread/resource locking + in order to protect resources from being altered by multiple threads at the + same time. + + Marko Lahma (.NET) + + + + This class extends + to include the query string constants in use by the + class. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + An interface for providing thread/resource locking in order to protect + resources from being altered by multiple threads at the same time. + + James House + Marko Lahma (.NET) + + + + Grants a lock on the identified resource to the calling thread (blocking + until it is available). + + true if the lock was obtained. + + + + Release the lock on the identified resource if it is held by the calling + thread. + + + + + Determine whether the calling thread owns a lock on the identified + resource. + + + + + Whether this Semaphore implementation requires a database connection for + its lock management operations. + + + + + + + + Interface for Quartz objects that need to know what the table prefix of + the tables used by a ADO.NET JobStore is. + + Marko Lahma (.NET) + + + + Table prefix to use. + + + + + Initializes a new instance of the class. + + The table prefix. + the scheduler name + The SQL. + The default SQL. + The db provider. + + + + Execute the SQL that will lock the proper database row. + + + + + + + + + Grants a lock on the identified resource to the calling thread (blocking + until it is available). + + + + + true if the lock was obtained. + + + + Release the lock on the identified resource if it is held by the calling + thread. + + + + + + + Determine whether the calling thread owns a lock on the identified + resource. + + + + + + + + Gets or sets the lock owners. + + The lock owners. + + + + Gets the log. + + The log. + + + + This Semaphore implementation does use the database. + + + + + Gets or sets the table prefix. + + The table prefix. + + + + Initialization argumens holder for implementations. + + + + + Whether simple should be used (for serialization safety). + + + + + The logger to use during execution. + + + + + The prefix of all table names. + + + + + The instance's name. + + + + + The instance id. + + + + + The db provider. + + + + + The type loading strategy. + + + + + Object serializer and deserializer strategy to use. + + + + + Custom driver delegate initialization. + + + initStrings are of the format: + settingName=settingValue|otherSettingName=otherSettingValue|... + + + + + Conveys the state of a fired-trigger record. + + James House + Marko Lahma (.NET) + + + + Gets or sets the fire instance id. + + The fire instance id. + + + + Gets or sets the fire timestamp. + + The fire timestamp. + + + + Gets or sets a value indicating whether job disallows concurrent execution. + + + + + Gets or sets the job key. + + The job key. + + + + Gets or sets the scheduler instance id. + + The scheduler instance id. + + + + Gets or sets the trigger key. + + The trigger key. + + + + Gets or sets the state of the fire instance. + + The state of the fire instance. + + + + Gets or sets a value indicating whether [job requests recovery]. + + true if [job requests recovery]; otherwise, false. + + + + Gets or sets the priority. + + The priority. + + + + Service interface or modifying parameters + and resultset values. + + + + + Prepares a to be used to access database. + + Connection and tranasction pair + SQL to run + + + + + Adds a parameter to . + + Command to add parameter to + Parameter's name + Parameter's value + + + + Adds a parameter to . + + Command to add parameter to + Parameter's name + Parameter's value + Parameter's data type + + + + Gets the db presentation for boolean value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the boolean value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for date/time value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the date/time value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for time span value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the time span value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + This is the base interface for all driver delegate classes. + + + + This interface is very similar to the + interface except each method has an additional + parameter. + + + Unless a database driver has some extremely-DB-specific + requirements, any IDriverDelegate implementation classes should extend the + class. + + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + Initializes the driver delegate with configuration data. + + + + + + Update all triggers having one of the two given states, to the given new + state. + + The DB Connection + The new state for the triggers + The first old state to update + The second old state to update + Number of rows updated + + + + Get the names of all of the triggers that have misfired - according to + the given timestamp. + + The DB Connection + The timestamp. + An array of objects + + + + Get the names of all of the triggers in the given state that have + misfired - according to the given timestamp. + + The DB Connection + The state. + The time stamp. + An array of objects + + + + Get the names of all of the triggers in the given group and state that + have misfired - according to the given timestamp. + + The DB Connection + Name of the group. + The state. + The timestamp. + An array of objects + + + + Select all of the triggers for jobs that are requesting recovery. The + returned trigger objects will have unique "recoverXXX" trigger names and + will be in the trigger group. + + + In order to preserve the ordering of the triggers, the fire time will be + set from the ColumnFiredTime column in the TableFiredTriggers + table. The caller is responsible for calling + on each returned trigger. It is also up to the caller to insert the + returned triggers to ensure that they are fired. + + The DB Connection + An array of objects + + + + Delete all fired triggers. + + The DB Connection + The number of rows deleted + + + + Delete all fired triggers of the given instance. + + The DB Connection + The instance id. + The number of rows deleted + + + + Insert the job detail record. + + The DB Connection + The job to insert. + Number of rows inserted. + + + + Update the job detail record. + + The DB Connection. + The job to update. + Number of rows updated. + + + + Get the names of all of the triggers associated with the given job. + + + + The DB Connection + The key identifying the job. + + + + Delete the job detail record for the given job. + + The DB Connection + The key identifying the job. + the number of rows deleted + + + + Check whether or not the given job is stateful. + + The DB Connection + The key identifying the job. + true if the job exists and is stateful, false otherwise + + + + Check whether or not the given job exists. + + The DB Connection + The key identifying the job. + true if the job exists, false otherwise + + + + Update the job data map for the given job. + + The DB Connection + The job. + the number of rows updated + + + + Select the JobDetail object for a given job name / group name. + + The DB Connection + The key identifying the job. + The class load helper. + The populated JobDetail object + + + + Select the total number of jobs stored. + + The DB Connection + the total number of jobs stored + + + + Select all of the job group names that are stored. + + The DB Connection. + an array of group names + + + + Select all of the jobs contained in a given group. + + The DB Connection + + an array of job names + + + + Insert the base trigger data. + + The DB Connection + The trigger to insert. + The state that the trigger should be stored in. + The job detail. + The number of rows inserted + + + + Insert the blob trigger data. + + The DB Connection + The trigger to insert + The number of rows inserted + + + + Update the base trigger data. + + the DB Connection + The trigger. + The state. + The job detail. + the number of rows updated + + + + Update the blob trigger data. + + the DB Connection + The trigger. + the number of rows updated + + + + Check whether or not a trigger exists. + + the DB Connection + The key identifying the trigger. + the number of rows updated + + + + Update the state for a given trigger. + + The DB Connection + The key identifying the trigger. + The new state for the trigger. + the number of rows updated + + + + Update the given trigger to the given new state, if it is in the given + old state. + + The DB connection + The key identifying the trigger. + The new state for the trigger + The old state the trigger must be in + int the number of rows updated + + + + Update the given trigger to the given new state, if it is one of the + given old states. + + The DB connection + The key identifying the trigger. + The new state for the trigger + One of the old state the trigger must be in + One of the old state the trigger must be in + One of the old state the trigger must be in + + int the number of rows updated + + SQLException + + + + Update all triggers in the given group to the given new state, if they + are in one of the given old states. + + The DB connection + + The new state for the trigger + One of the old state the trigger must be in + One of the old state the trigger must be in + One of the old state the trigger must be in + The number of rows updated + + + + Update all of the triggers of the given group to the given new state, if + they are in the given old state. + + The DB connection + + The new state for the trigger group + The old state the triggers must be in. + int the number of rows updated + + + + Update the states of all triggers associated with the given job. + + The DB Connection + The key identifying the job. + The new state for the triggers. + The number of rows updated + + + + Update the states of any triggers associated with the given job, that + are the given current state. + + The DB Connection + The key identifying the job. + The new state for the triggers + The old state of the triggers + the number of rows updated + + + + Delete the BLOB trigger data for a trigger. + + The DB Connection + The key identifying the trigger. + The number of rows deleted + + + + Delete the base trigger data for a trigger. + + The DB Connection + The key identifying the trigger. + the number of rows deleted + + + + Select the number of triggers associated with a given job. + + The DB Connection + The key identifying the job. + the number of triggers for the given job + + + + Select the job to which the trigger is associated. + + The DB Connection + The key identifying the trigger. + The load helper. + + The object associated with the given trigger + + + + + Select the triggers for a job> + + The DB Connection + The key identifying the job. + an array of objects associated with a given job. + + + + Select the triggers for a calendar + + The DB Connection. + Name of the calendar. + + An array of objects associated with a given job. + + + + + Select a trigger. + + The DB Connection. + The key identifying the trigger. + The object. + + + + + Select a trigger's JobDataMap. + + The DB Connection. + The key identifying the trigger. + The of the Trigger, never null, but possibly empty. + + + + Select a trigger's state value. + + The DB Connection. + The key identifying the trigger. + The object. + + + + Select a triggers status (state and next fire time). + + The DB Connection. + The key identifying the trigger. + A object, or null + + + + Select the total number of triggers stored. + + The DB Connection. + The total number of triggers stored. + + + + Select all of the trigger group names that are stored. + + The DB Connection. + An array of group names. + + + + Select all of the triggers contained in a given group. + + The DB Connection. + + An array of trigger names. + + + + Select all of the triggers in a given state. + + The DB Connection. + The state the triggers must be in. + An array of trigger s. + + + + Inserts the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes all paused trigger groups. + + The conn. + + + + + Determines whether the specified trigger group is paused. + + The conn. + Name of the group. + + true if trigger group is paused; otherwise, false. + + + + + Selects the paused trigger groups. + + The DB Connection. + + + + + Determines whether given trigger group already exists. + + The conn. + Name of the group. + + true if trigger group exists; otherwise, false. + + + + + Insert a new calendar. + + The DB Connection. + The name for the new calendar. + The calendar. + The number of rows inserted. + + + + Update a calendar. + + The DB Connection. + The name for the new calendar. + The calendar. + The number of rows updated. + + + + Check whether or not a calendar exists. + + The DB Connection. + The name of the calendar. + true if the trigger exists, false otherwise. + + + + Select a calendar. + + The DB Connection. + The name of the calendar. + The Calendar. + + + + Check whether or not a calendar is referenced by any triggers. + + The DB Connection. + The name of the calendar. + true if any triggers reference the calendar, false otherwise + + + + Delete a calendar. + + The DB Connection + The name of the trigger. + The number of rows deleted. + + + + Select the total number of calendars stored. + + The DB Connection + The total number of calendars stored. + + + + Select all of the stored calendars. + + The DB Connection + An array of calendar names. + + + + Select the trigger that will be fired at the given fire time. + + The DB Connection + The time that the trigger will be fired. + + A representing the + trigger that will be fired at the given fire time, or null if no + trigger will be fired at that time + + + + + Insert a fired trigger. + + The DB Connection + The trigger. + The state that the trigger should be stored in. + The job detail. + The number of rows inserted. + + + + Select the states of all fired-trigger records for a given trigger, or + trigger group if trigger name is . + + The DB Connection + Name of the trigger. + Name of the group. + A list of FiredTriggerRecord objects. + + + + Select the states of all fired-trigger records for a given job, or job + group if job name is . + + The DB Connection + Name of the job. + Name of the group. + A List of FiredTriggerRecord objects. + + + + Select the states of all fired-trigger records for a given scheduler + instance. + + The DB Connection + Name of the instance. + A list of FiredTriggerRecord objects. + + + + Delete a fired trigger. + + The DB Connection + The fired trigger entry to delete. + The number of rows deleted. + + + + Get the number instances of the identified job currently executing. + + The DB Connection + The key identifying the job. + + The number instances of the identified job currently executing. + + + + + Insert a scheduler-instance state record. + + The DB Connection + The instance id. + The check in time. + The interval. + The number of inserted rows. + + + + Delete a scheduler-instance state record. + + The DB Connection + The instance id. + The number of deleted rows. + + + + Update a scheduler-instance state record. + + The DB Connection + The instance id. + The check in time. + The number of updated rows. + + + + A List of all current s. + + If instanceId is not null, then only the record for the identified + instance will be returned. + + + The DB Connection + The instance id. + + + + + Select the next trigger which will fire to fire between the two given timestamps + in ascending order of fire time, and then descending by priority. + + The conn. + highest value of of the triggers (exclusive) + highest value of of the triggers (inclusive) + maximum number of trigger keys allow to acquired in the returning list. + A (never null, possibly empty) list of the identifiers (Key objects) of the next triggers to be fired. + + + + Select the distinct instance names of all fired-trigger records. + + + This is useful when trying to identify orphaned fired triggers (a + fired trigger without a scheduler state record.) + + The conn. + + + + + Counts the misfired triggers in states. + + The conn. + The state1. + The ts. + + + + + Selects the misfired triggers in states. + + The conn. + The state1. + The ts. + The count. + The result list. + + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + Exception class for when a driver delegate cannot be found for a given + configuration, or lack thereof. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + Base class for exceptions thrown by the Quartz . + + + SchedulerExceptions may contain a reference to another + , which was the underlying cause of the SchedulerException. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The MSG. + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Initializes a new instance of the class. + + The cause. + + + + Initializes a new instance of the class. + + The MSG. + The cause. + + + + Creates and returns a string representation of the current exception. + + + A string representation of the current exception. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + is meant to be used in an application-server + or other software framework environment that provides + container-managed-transactions. No commit / rollback will be handled by this class. + + + If you need commit / rollback, use + instead. + + Jeffrey Wescott + James House + Srinivas Venkatarangaiah + Marko Lahma (.NET) + + + + Contains base functionality for ADO.NET-based JobStore implementations. + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + The interface to be implemented by classes that want to provide a + and storage mechanism for the + 's use. + + + Storage of s and s should be keyed + on the combination of their name and group for uniqueness. + + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Called by the QuartzScheduler to inform the that + the scheduler has started. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has been paused. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has resumed after being paused. + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Store the given and . + + The to be stored. + The to be stored. + ObjectAlreadyExistsException + + + + returns true if the given JobGroup is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Store the given . + + The to be stored. + + If , any existing in the + with the same name and group should be + over-written. + + + + + Remove (delete) the with the given + key, and any s that reference + it. + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + if a with the given name and + group was found and removed from the store. + + + + + Retrieve the for the given + . + + + The desired , or null if there is no match. + + + + + Store the given . + + The to be stored. + If , any existing in + the with the same name and group should + be over-written. + ObjectAlreadyExistsException + + + + Remove (delete) the with the given key. + + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + If removal of the results in an 'orphaned' + that is not 'durable', then the should be deleted + also. + + + + if a with the given + name and group was found and removed from the store. + + + + + Remove (delete) the with the + given name, and store the new given one - which must be associated + with the same job. + + The to be replaced. + The new to be stored. + + if a with the given + name and group was found and removed from the store. + + + + + Retrieve the given . + + + The desired , or null if there is no + match. + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a trigger exists with the given identifier + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + + Store the given . + + The name. + The to be stored. + If , any existing + in the with the same name and group + should be over-written. + If , any s existing + in the that reference an existing + Calendar with the same name with have their next fire time + re-computed with the new . + ObjectAlreadyExistsException + + + + Remove (delete) the with the + given name. + + + If removal of the would result in + s pointing to non-existent calendars, then a + will be thrown. + + The name of the to be removed. + + if a with the given name + was found and removed from the store. + + + + + Retrieve the given . + + The name of the to be retrieved. + + The desired , or null if there is no + match. + + + + + Get the number of s that are + stored in the . + + + + + + Get the number of s that are + stored in the . + + + + + + Get the number of s that are + stored in the . + + + + + + Get the names of all of the s that + have the given group name. + + If there are no jobs in the given group name, the result should be a + zero-length array (not ). + + + + + + + + Get the names of all of the s + that have the given group name. + + If there are no triggers in the given group name, the result should be a + zero-length array (not ). + + + + + + Get the names of all of the + groups. + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + + Get the names of all of the + groups. + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + + Get the names of all of the s + in the . + + + If there are no Calendars in the given group name, the result should be + a zero-length array (not ). + + + + + + Get all of the Triggers that are associated to the given Job. + + + If there are no matches, a zero-length array should be returned. + + + + + Get the current state of the identified . + + + + + + Pause the with the given key. + + + + + Pause all of the s in the + given group. + + + The JobStore should "remember" that the group is paused, and impose the + pause on any new triggers that are added to the group while the group is + paused. + + + + + Pause the with the given key - by + pausing all of its current s. + + + + + Pause all of the s in the given + group - by pausing all of their s. + + The JobStore should "remember" that the group is paused, and impose the + pause on any new jobs that are added to the group while the group is + paused. + + + + + + + + Resume (un-pause) the with the + given key. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + + Resume (un-pause) all of the s + in the given group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Gets the paused trigger groups. + + + + + + Resume (un-pause) the with the + given key. + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s in + the given group. + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + on every group. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + + Get a handle to the next trigger to be fired, and mark it as 'reserved' + by the calling scheduler. + + If > 0, the JobStore should only return a Trigger + that will fire no later than the time represented in this value as + milliseconds. + + + + + + + + + Inform the that the scheduler no longer plans to + fire the given , that it had previously acquired + (reserved). + + + + + Inform the that the scheduler is now firing the + given (executing its associated ), + that it had previously acquired (reserved). + + + May return null if all the triggers or their calendars no longer exist, or + if the trigger was not successfully put into the 'executing' + state. Preference is to return an empty list if none of the triggers + could be fired. + + + + + Inform the that the scheduler has completed the + firing of the given (and the execution its + associated ), and that the + in the given should be updated if the + is stateful. + + + + + Indicates whether job store supports persistence. + + + + + + How long (in milliseconds) the implementation + estimates that it will take to release a trigger and acquire a new one. + + + + + Whether or not the implementation is clustered. + + + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + Tells the JobStore the pool size used to execute jobs. + + + + + Initializes a new instance of the class. + + + + + Gets the connection and starts a new transaction. + + + + + + Called by the QuartzScheduler before the is + used, in order to give it a chance to Initialize. + + + + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has been paused. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has resumed after being paused. + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Will recover any failed or misfired jobs and clean up the data store as + appropriate. + + + + + Will recover any failed or misfired jobs and clean up the data store as + appropriate. + + + + + Store the given and . + + Job to be stored. + Trigger to be stored. + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Stores the given . + + The to be stored. + + If , any existing in the + with the same name & group should be over-written. + + + + + Insert or update a job. + + + + + + Check existence of a given job. + + + + + Store the given . + + The to be stored. + + If , any existing in + the with the same name & group should + be over-written. + + + if a with the same name/group already + exists, and replaceExisting is set to false. + + + + + Insert or update a trigger. + + + + + Check existence of a given trigger. + + + + + Remove (delete) the with the given + name, and any s that reference + it. + + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + if a with the given name & + group was found and removed from the store. + + + + + Delete a job and its listeners. + + + + + + + Delete a trigger, its listeners, and its Simple/Cron/BLOB sub-table entry. + + + + + + + + Retrieve the for the given + . + + The key identifying the job. + The desired , or null if there is no match. + + + + Remove (delete) the with the + given name. + + + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + + If removal of the results in an 'orphaned' + that is not 'durable', then the should be deleted + also. + + + The key identifying the trigger. + + if a with the given + name & group was found and removed from the store. + + + + + + + + Retrieve the given . + + The key identifying the trigger. + The desired , or null if there is no match. + + + + Get the current state of the identified . + + + + + + + + + + Gets the state of the trigger. + + The conn. + The key identifying the trigger. + + + + + Store the given . + + The name of the calendar. + The to be stored. + + If , any existing + in the with the same name & group + should be over-written. + + + + if a with the same name already + exists, and replaceExisting is set to false. + + + + + Remove (delete) the with the given name. + + + If removal of the would result in + s pointing to non-existent calendars, then a + will be thrown. + + The name of the to be removed. + + if a with the given name + was found and removed from the store. + + + + + Retrieve the given . + + The name of the to be retrieved. + The desired , or null if there is no match. + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the names of all of the s that + have the given group name. + + + If there are no jobs in the given group name, the result should be a + zero-length array (not ). + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Trigger exists with the given identifier + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + + Get the names of all of the s + that have the given group name. + + + If there are no triggers in the given group name, the result should be a + zero-length array (not ). + + + + + Get the names of all of the + groups. + + + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + Get the names of all of the + groups. + + + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + Get the names of all of the s + in the . + + + If there are no Calendars in the given group name, the result should be + a zero-length array (not ). + + + + + Get all of the Triggers that are associated to the given Job. + + + If there are no matches, a zero-length array should be returned. + + + + + Pause the with the given name. + + + + + Pause the with the given name. + + + + + Pause the with the given name - by + pausing all of its current s. + + + + + + Pause all of the s in the given + group - by pausing all of their s. + + + + + + Determines if a Trigger for the given job should be blocked. + State can only transition to StatePausedBlocked/StateBlocked from + StatePaused/StateWaiting respectively. + + StatePausedBlocked, StateBlocked, or the currentState. + + + + Resume (un-pause) the with the + given name. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + Resume (un-pause) the with the + given name. + + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s in + the given group. + + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all of the s in the given group. + + + + + + Pause all of the s in the given group. + + + + + Pause all of the s in the + given group. + + + + + Resume (un-pause) all of the s + in the given group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + on every group. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + Get a handle to the next N triggers to be fired, and mark them as 'reserved' + by the calling scheduler. + + + + + + Inform the that the scheduler no longer plans to + fire the given , that it had previously acquired + (reserved). + + + + + Inform the that the scheduler has completed the + firing of the given (and the execution its + associated ), and that the + in the given should be updated if the + is stateful. + + + + + Get a list of all scheduler instances in the cluster that may have failed. + This includes this scheduler if it is checking in for the first time. + + + + + Create dummy objects for fired triggers + that have no scheduler state record. Checkin timestamp and interval are + left as zero on these dummy objects. + + + List of all current s + + + + Cleanup the given database connection. This means restoring + any modified auto commit or transaction isolation connection + attributes, and then closing the underlying connection. + + + + This is separate from closeConnection() because the Spring + integration relies on being able to overload closeConnection() and + expects the same connection back that it originally returned + from the datasource. + + + + + + Closes the supplied connection. + + (Optional) + + + + Rollback the supplied connection. + + (Optional) + + JobPersistenceException thrown if a SQLException occurs when the + connection is rolled back + + + + + Commit the supplied connection. + + The CTH. + if set to true opens a new transaction. + JobPersistenceException thrown if a SQLException occurs when the + + + + Execute the given callback in a transaction. Depending on the JobStore, + the surrounding transaction may be assumed to be already present + (managed). + + + This method just forwards to ExecuteInLock() with a null lockName. + + + + + + Execute the given callback having acquired the given lock. + Depending on the JobStore, the surrounding transaction may be + assumed to be already present (managed). This version is just a + handy wrapper around executeInLock that doesn't require a return + value. + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a transaction. + + + The callback to excute after having acquired the given lock. + + + + + + Execute the given callback having acquired the given lock. + Depending on the JobStore, the surrounding transaction may be + assumed to be already present (managed). + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a transaction. + + + The callback to excute after having acquired the given lock. + + + + + Execute the given callback having optionally acquired the given lock. + This uses the non-managed transaction connection. This version is just a + handy wrapper around executeInNonManagedTXLock that doesn't require a return + value. + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a non-managed transaction. + + + + The callback to excute after having acquired the given lock. + + + + + Execute the given callback having optionally acquired the given lock. + This uses the non-managed transaction connection. + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a non-managed transaction. + + + The callback to excute after having acquired the given lock. + + + + + Get or set the datasource name. + + + + + Gets the log. + + The log. + + + + Get or sets the prefix that should be pre-pended to all table names. + + + + + Set whether string-only properties will be handled in JobDataMaps. + + + + + Get or set the instance Id of the Scheduler (must be unique within a cluster). + + + + + Get or set the instance Id of the Scheduler (must be unique within this server instance). + + + + + Get or set whether this instance is part of a cluster. + + + + + Get or set the frequency at which this instance "checks-in" + with the other instances of the cluster. -- Affects the rate of + detecting failed instances. + + + + + Get or set the maximum number of misfired triggers that the misfire handling + thread will try to recover at one time (within one transaction). The + default is 20. + + + + + Gets or sets the database retry interval. + + The db retry interval. + + + + Get or set whether this instance should use database-based thread + synchronization. + + + + + Whether or not to obtain locks when inserting new jobs/triggers. + Defaults to , which is safest - some db's (such as + MS SQLServer) seem to require this to avoid deadlocks under high load, + while others seem to do fine without. + + + Setting this property to will provide a + significant performance increase during the addition of new jobs + and triggers. + + + + + The time span by which a trigger must have missed its + next-fire-time, in order for it to be considered "misfired" and thus + have its misfire instruction applied. + + + + + Don't call set autocommit(false) on connections obtained from the + DataSource. This can be helpfull in a few situations, such as if you + have a driver that complains if it is called when it is already off. + + + + + Set the transaction isolation level of DB connections to sequential. + + + + + Whether or not the query and update to acquire a Trigger for firing + should be performed after obtaining an explicit DB lock (to avoid + possible race conditions on the trigger's db row). This is + is considered unnecessary for most databases (due to the nature of + the SQL update that is performed), and therefore a superfluous performance hit. + + + However, if batch acquisition is used, it is important for this behavior + to be used for all dbs. + + + + + Get or set the ADO.NET driver delegate class name. + + + + + The driver delegate's initialization string. + + + + + set the SQL statement to use to select and lock a row in the "locks" + table. + + + + + + Get whether the threads spawned by this JobStore should be + marked as daemon. Possible threads include the + and the . + + + + + + Get whether to check to see if there are Triggers that have misfired + before actually acquiring the lock to recover them. This should be + set to false if the majority of the time, there are are misfired + Triggers. + + + + + + Get the driver delegate for DB operations. + + + + + Get whether String-only properties will be handled in JobDataMaps. + + + + + Indicates whether this job store supports persistence. + + + + + + + An interface for classes wishing to provide the service of loading classes + and resources within the scheduler... + + James House + Marko Lahma (.NET) + + + + Called to give the ClassLoadHelper a chance to Initialize itself, + including the oportunity to "steal" the class loader off of the calling + thread, which is the thread that is initializing Quartz. + + + + + Return the class with the given name. + + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a java.net.URL object + + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a java.io.InputStream object + + + + + Helper class for returning the composite result of trying + to recover misfired jobs. + + + + + Initializes a new instance of the class. + + if set to true [has more misfired triggers]. + The processed misfired trigger count. + + + + + Gets a value indicating whether this instance has more misfired triggers. + + + true if this instance has more misfired triggers; otherwise, false. + + + + + Gets the processed misfired trigger count. + + The processed misfired trigger count. + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Gets the non managed TX connection. + + + + + + Execute the given callback having optionally acquired the given lock. + Because CMT assumes that the connection is already part of a managed + transaction, it does not attempt to commit or rollback the + enclosing transaction. + + + + + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + txCallback is still executed in a transaction. + + Callback to execute. + + + + is meant to be used in a standalone environment. + Both commit and rollback will be handled by this class. + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + + + For , the non-managed TX connection is just + the normal connection because it is not CMT. + + + + + + Execute the given callback having optionally aquired the given lock. + For , because it manages its own transactions + and only has the one datasource, this is the same behavior as + . + + + The name of the lock to aquire, for example "TRIGGER_ACCESS". + If null, then no lock is aquired, but the lockCallback is still + executed in a transaction. + + Callback to execute. + + + + + + + + + Exception class for when there is a failure obtaining or releasing a + resource lock. + + + James House + Marko Lahma (.NET) + + + + An exception that is thrown to indicate that there has been a failure in the + scheduler's underlying persistence mechanism. + + James House + Marko Lahma (.NET) + + + + Create a with the given message. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Create a with the given message + and cause. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + This is a driver delegate for the MySQL ADO.NET driver. + + Marko Lahma + + + + This is meant to be an abstract base class for most, if not all, + implementations. Subclasses should override only those methods that need + special handling for the DBMS driver in question. + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + Initializes the driver delegate. + + + + + Insert the job detail record. + + the DB Connection + the new state for the triggers + the first old state to update + the second old state to update + number of rows updated + + + + Get the names of all of the triggers that have misfired. + + the DB Connection + The ts. + an array of objects + + + + Select all of the triggers in a given state. + + The DB Connection + The state the triggers must be in + an array of trigger s + + + + Get the names of all of the triggers in the given state that have + misfired - according to the given timestamp. + + The DB Connection + The state. + The time stamp. + An array of objects + + + + Get the names of all of the triggers in the given state that have + misfired - according to the given timestamp. No more than count will + be returned. + + The conn. + The state1. + The ts. + The most misfired triggers to return, negative for all + + Output parameter. A List of objects. Must not be null + + Whether there are more misfired triggers left to find beyond the given count. + + + + Get the number of triggers in the given state that have + misfired - according to the given timestamp. + + + + + + + + + Get the names of all of the triggers in the given group and state that + have misfired. + + The DB Connection + Name of the group. + The state. + The timestamp. + an array of objects + + + + Select all of the triggers for jobs that are requesting recovery. The + returned trigger objects will have unique "recoverXXX" trigger names and + will be in the + trigger group. + + + In order to preserve the ordering of the triggers, the fire time will be + set from the ColumnFiredTime column in the TableFiredTriggers + table. The caller is responsible for calling + on each returned trigger. It is also up to the caller to insert the + returned triggers to ensure that they are fired. + + The DB Connection + an array of objects + + + + Delete all fired triggers. + + The DB Connection. + The number of rows deleted. + + + + Delete all fired triggers of the given instance. + + The DB Connection + The instance id. + The number of rows deleted + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + + Insert the job detail record. + + The DB Connection. + The job to insert. + Number of rows inserted. + + + + Gets the db presentation for boolean value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the boolean value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for date/time value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the date/time value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for time span value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the time span value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Update the job detail record. + + The DB Connection. + The job to update. + Number of rows updated. + + + + Get the names of all of the triggers associated with the given job. + + The DB Connection. + The key identifying the job. + An array of objects + + + + Delete the job detail record for the given job. + + the DB Connection + The key identifying the job. + the number of rows deleted + + + + Check whether or not the given job is stateful. + + the DB Connection + The key identifying the job. + + true if the job exists and is stateful, false otherwise + + + + + Check whether or not the given job exists. + + the DB Connection + The key identifying the job. + true if the job exists, false otherwise + + + + Update the job data map for the given job. + + The conn. + the job to update + the number of rows updated + + + + Select the JobDetail object for a given job name / group name. + + The DB Connection. + The key identifying the job. + The load helper. + The populated JobDetail object. + + + build Map from java.util.Properties encoding. + + + + Select the total number of jobs stored. + + The DB Connection. + The total number of jobs stored. + + + + Select all of the job group names that are stored. + + The DB Connection. + An array of group names. + + + + Select all of the jobs contained in a given group. + + The DB Connection. + + An array of job names. + + + + Insert the base trigger data. + + the DB Connection + the trigger to insert + the state that the trigger should be stored in + The job detail. + the number of rows inserted + + + + Insert the blob trigger data. + + The DB Connection. + The trigger to insert. + The number of rows inserted. + + + + Update the base trigger data. + + The DB Connection. + The trigger to insert. + The state that the trigger should be stored in. + The job detail. + The number of rows updated. + + + + Update the blob trigger data. + + The DB Connection. + The trigger to insert. + The number of rows updated. + + + + Check whether or not a trigger exists. + + The DB Connection. + the key of the trigger + true if the trigger exists, false otherwise + + + + Update the state for a given trigger. + + The DB Connection. + the key of the trigger + The new state for the trigger. + The number of rows updated. + + + + Update the given trigger to the given new state, if it is one of the + given old states. + + The DB connection. + the key of the trigger + The new state for the trigger. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + The number of rows updated. + + + + Update all triggers in the given group to the given new state, if they + are in one of the given old states. + + The DB connection. + + The new state for the trigger. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + The number of rows updated. + + + + Update the given trigger to the given new state, if it is in the given + old state. + + the DB connection + the key of the trigger + the new state for the trigger + the old state the trigger must be in + int the number of rows updated + + + + Update all of the triggers of the given group to the given new state, if + they are in the given old state. + + the DB connection + + the new state for the trigger group + the old state the triggers must be in + int the number of rows updated + + + + Update the states of all triggers associated with the given job. + + the DB Connection + the key of the job + the new state for the triggers + the number of rows updated + + + + Updates the state of the trigger states for job from other. + + The conn. + Key of the job. + The state. + The old state. + + + + + Delete the cron trigger data for a trigger. + + the DB Connection + the key of the trigger + the number of rows deleted + + + + Delete the base trigger data for a trigger. + + the DB Connection + the key of the trigger + the number of rows deleted + + + + Select the number of triggers associated with a given job. + + the DB Connection + the key of the job + the number of triggers for the given job + + + + Select the job to which the trigger is associated. + + the DB Connection + the key of the trigger + The load helper. + The object associated with the given trigger + + + + Select the triggers for a job + + the DB Connection + the key of the job + + an array of objects + associated with a given job. + + + + + Select the triggers for a calendar + + The DB Connection. + Name of the calendar. + + An array of objects associated with a given job. + + + + + Select a trigger. + + the DB Connection + the key of the trigger + The object + + + + Select a trigger's JobDataMap. + + the DB Connection + the key of the trigger + The of the Trigger, never null, but possibly empty. + + + + Select a trigger's state value. + + the DB Connection + the key of the trigger + The object + + + + Select a trigger status (state and next fire time). + + the DB Connection + the key of the trigger + + a object, or null + + + + + Select the total number of triggers stored. + + the DB Connection + the total number of triggers stored + + + + Select all of the trigger group names that are stored. + + the DB Connection + + an array of group names + + + + + Select all of the triggers contained in a given group. + + the DB Connection + + + an array of trigger names + + + + + Inserts the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes all paused trigger groups. + + The conn. + + + + + Determines whether the specified trigger group is paused. + + The conn. + Name of the group. + + true if trigger group is paused; otherwise, false. + + + + + Determines whether given trigger group already exists. + + The conn. + Name of the group. + + true if trigger group exists; otherwise, false. + + + + + Insert a new calendar. + + the DB Connection + The name for the new calendar. + The calendar. + the number of rows inserted + IOException + + + + Update a calendar. + + the DB Connection + The name for the new calendar. + The calendar. + the number of rows updated + IOException + + + + Check whether or not a calendar exists. + + the DB Connection + The name of the calendar. + + true if the trigger exists, false otherwise + + + + + Select a calendar. + + the DB Connection + The name of the calendar. + the Calendar + ClassNotFoundException + IOException + + + + Check whether or not a calendar is referenced by any triggers. + + the DB Connection + The name of the calendar. + + true if any triggers reference the calendar, false otherwise + + + + + Delete a calendar. + + the DB Connection + The name of the trigger. + the number of rows deleted + + + + Select the total number of calendars stored. + + the DB Connection + the total number of calendars stored + + + + Select all of the stored calendars. + + the DB Connection + + an array of calendar names + + + + + Select the trigger that will be fired at the given fire time. + + the DB Connection + the time that the trigger will be fired + + a representing the + trigger that will be fired at the given fire time, or null if no + trigger will be fired at that time + + + + + Select the next trigger which will fire to fire between the two given timestamps + in ascending order of fire time, and then descending by priority. + + The conn. + highest value of of the triggers (exclusive) + highest value of of the triggers (inclusive) + maximum number of trigger keys allow to acquired in the returning list. + A (never null, possibly empty) list of the identifiers (Key objects) of the next triggers to be fired. + + + + Insert a fired trigger. + + the DB Connection + the trigger + the state that the trigger should be stored in + The job. + the number of rows inserted + + + + + Update a fired trigger. + + + + + + the DB Connection + + the trigger + + + the state that the trigger should be stored in + the number of rows inserted + + + + Select the states of all fired-trigger records for a given trigger, or + trigger group if trigger name is . + + The DB connection. + Name of the trigger. + Name of the group. + a List of objects. + + + + Select the states of all fired-trigger records for a given job, or job + group if job name is . + + The DB connection. + Name of the job. + Name of the group. + a List of objects. + + + + Select the states of all fired-trigger records for a given scheduler + instance. + + The DB Connection + Name of the instance. + A list of FiredTriggerRecord objects. + + + + Select the distinct instance names of all fired-trigger records. + + The conn. + + + This is useful when trying to identify orphaned fired triggers (a + fired trigger without a scheduler state record.) + + + + + Delete a fired trigger. + + the DB Connection + the fired trigger entry to delete + the number of rows deleted + + + + Selects the job execution count. + + The DB connection. + The key of the job. + + + + + Inserts the state of the scheduler. + + The conn. + The instance id. + The check in time. + The interval. + + + + + Deletes the state of the scheduler. + + The database connection. + The instance id. + + + + + Updates the state of the scheduler. + + The database connection. + The instance id. + The check in time. + + + + + A List of all current s. + + If instanceId is not null, then only the record for the identified + instance will be returned. + + + The DB Connection + The instance id. + + + + + Replace the table prefix in a query by replacing any occurrences of + "{0}" with the table prefix. + + The unsubstitued query + The query, with proper table prefix substituted + + + + Create a serialized version of an Object. + + the object to serialize + Serialized object as byte array. + + + + Remove the transient data from and then create a serialized + version of a and returns the underlying bytes. + + The data. + the serialized data as byte array + + + + serialize + + The data. + + + + + Convert the JobDataMap into a list of properties. + + + + + Convert the JobDataMap into a list of properties. + + + + + This method should be overridden by any delegate subclasses that need + special handling for BLOBs. The default implementation uses standard + ADO.NET operations. + + The data reader, already queued to the correct row. + The column index for the BLOB. + The deserialized object from the DataReader BLOB. + + + + This method should be overridden by any delegate subclasses that need + special handling for BLOBs for job details. + + The result set, already queued to the correct row. + The column index for the BLOB. + The deserialized Object from the ResultSet BLOB. + + + + Selects the paused trigger groups. + + The DB Connection. + + + + + Gets the select next trigger to acquire SQL clause. + MySQL version with LIMIT support. + + + + + + Exception class for when a driver delegate cannot be found for a given + configuration, or lack thereof. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + This is a driver delegate for the Oracle database. + + Marko Lahma + + + + Creates the SQL for select next trigger to acquire. + + + + + Gets the db presentation for boolean value. For Oracle we use true/false of "1"/"0". + + Value to map to database. + + + + + Conveys a scheduler-instance state record. + + James House + Marko Lahma (.NET) + + + + Gets or sets the checkin interval. + + The checkin interval. + + + + Gets or sets the checkin timestamp. + + The checkin timestamp. + + + + Gets or sets the scheduler instance id. + + The scheduler instance id. + + + + Internal in-memory lock handler for providing thread/resource locking in + order to protect resources from being altered by multiple threads at the + same time. + + James House + Marko Lahma (.NET) + + + + Grants a lock on the identified resource to the calling thread (blocking + until it is available). + + True if the lock was obtained. + + + Release the lock on the identified resource if it is held by the calling + thread. + + + + + Determine whether the calling thread owns a lock on the identified + resource. + + + + + Gets the thread locks. + + The thread locks. + + + + Whether this Semaphore implementation requires a database connection for + its lock management operations. + + + + + + + + + This is a driver delegate for the SQLiteDelegate ADO.NET driver. + + Marko Lahma + + + + Gets the select next trigger to acquire SQL clause. + SQLite version with LIMIT support. + + + + + + A SQL Server specific driver delegate. + + Marko Lahma + + + + Gets the select next trigger to acquire SQL clause. + SQL Server specific version with TOP functionality + + + + + + Internal database based lock handler for providing thread/resource locking + in order to protect resources from being altered by multiple threads at the + same time. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The table prefix. + the scheduler name + The select with lock SQL. + + + + + Execute the SQL select for update that will lock the proper database row. + + + + + Property name and value holder for trigger state data. + + + + + Object representing a job or trigger key. + + James House + Marko Lahma (.NET) + + + + Construct a new TriggerStatus with the status name and nextFireTime. + + The trigger's status + The next time trigger will fire + + + + Return the string representation of the TriggerStatus. + + + + + + Provide thread/resource locking in order to protect + resources from being altered by multiple threads at the same time using + a db row update. + + + + Note: This Semaphore implementation is useful for databases that do + not support row locking via "SELECT FOR UPDATE" or SQL Server's type syntax. + + + As of Quartz.NET 2.0 version there is no need to use this implementation for + SQL Server databases. + + + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Execute the SQL that will lock the proper database row. + + + + + + + + + This implementation of the Calendar excludes a set of days of the year. You + may use it to exclude bank holidays which are on the same date every year. + + + + Juergen Donnerstag + Marko Lahma (.NET) + + + + This implementation of the Calendar may be used (you don't have to) as a + base class for more sophisticated one's. It merely implements the base + functionality required by each Calendar. + + + Regarded as base functionality is the treatment of base calendars. Base + calendar allow you to chain (stack) as much calendars as you may need. For + example to exclude weekends you may use WeeklyCalendar. In order to exclude + holidays as well you may define a WeeklyCalendar instance to be the base + calendar for HolidayCalendar instance. + + + Juergen Donnerstag + James House + Marko Lahma (.NET) + + + + An interface to be implemented by objects that define spaces of time during + which an associated may (not) fire. Calendars + do not define actual fire times, but rather are used to limit a + from firing on its normal schedule if necessary. Most + Calendars include all times by default and allow the user to specify times + to exclude. + + + As such, it is often useful to think of Calendars as being used to exclude a block + of time - as opposed to include a block of time. (i.e. the + schedule "fire every five minutes except on Sundays" could be + implemented with a and a + which excludes Sundays) + + Implementations MUST take care of being properly cloneable and Serializable. + + + James House + Juergen Donnerstag + Marko Lahma (.NET) + + + + Determine whether the given UTC time is 'included' by the + Calendar. + + + + + Determine the next UTC time that is 'included' by the + Calendar after the given UTC time. + + + + + Gets or sets a description for the instance - may be + useful for remembering/displaying the purpose of the calendar, though + the description has no meaning to Quartz. + + + + + Set a new base calendar or remove the existing one. + Get the base calendar. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The base calendar. + + + + Initializes a new instance of the class. + + The time zone. + + + + Initializes a new instance of the class. + + The base calendar. + The time zone. + + + + Serialization constructor. + + + + + + + checks whether two arrays have + the same length and + for any given place there are equal elements + in both arrays + + + + + + Get the base calendar. Will be null, if not set. + + + + + Check if date/time represented by timeStamp is included. If included + return true. The implementation of BaseCalendar simply calls the base + calendars IsTimeIncluded() method if base calendar is set. + + + + + + Determine the next UTC time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return 0 if all days are excluded. + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Gets or sets the time zone. + + The time zone. + + + + Gets or sets the description given to the instance by + its creator (if any). + + + + + Set a new base calendar or remove the existing one + + + + + + Constructor + + + + + Constructor + + The base calendar. + + + + Serialization constructor. + + + + + + + Return true, if day is defined to be exluded. + + + + + Redefine a certain day to be excluded (true) or included (false). + + + + + Determine whether the given UTC time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next UTC time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStampUtc is + included. Return 0 if all days are excluded. + + Note that this Calendar is only has full-day precision. + + + + + + Get or the array which defines the exclude-value of each day of month. + Setting will redefine the array of days excluded. The array must of size greater or + equal 31. + + + + + This implementation of the Calendar excludes the set of times expressed by a + given CronExpression. + + + For example, you could use this calendar to exclude all but business hours (8AM - 5PM) every + day using the expression "* * 0-7,18-23 ? * *". + + It is important to remember that the cron expression here describes a set of + times to be excluded from firing. Whereas the cron expression in + CronTrigger describes a set of times that can + be included for firing. Thus, if a has a + given cron expression and is associated with a with + the same expression, the calendar will exclude all the times the + trigger includes, and they will cancel each other out. + + + Aaron Craven + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + a string representation of the desired cron expression + + + + Create a with the given cron expression and + . + + + the base calendar for this calendar instance + see BaseCalendar for more information on base + calendar functionality + + a string representation of the desired cron expression + + + + Create a with the given cron expression and + . + + + the base calendar for this calendar instance + see BaseCalendar for more information on base + calendar functionality + + a string representation of the desired cron expression + + + + + Serialization constructor. + + + + + + + Determine whether the given time is 'included' by the + Calendar. + + the time to test + a boolean indicating whether the specified time is 'included' by the CronCalendar + + + + Determine the next time that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return 0 if all days are excluded. + + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Sets the cron expression for the calendar to a new value. + + The expression. + + + + Returns the object representation of the cron expression that defines the + dates and times this calendar excludes. + + + + + This implementation of the Calendar excludes (or includes - see below) a + specified time range each day. + + + For example, you could use this calendar to + exclude business hours (8AM - 5PM) every day. Each + only allows a single time range to be specified, and that time range may not + * cross daily boundaries (i.e. you cannot specify a time range from 8PM - 5AM). + If the property is (default), + the time range defines a range of times in which triggers are not allowed to + * fire. If is , the time range + is inverted: that is, all times outside the defined time range + are excluded. + + Note when using , it behaves on the same principals + as, for example, WeeklyCalendar defines a set of days that are + excluded every week. Likewise, defines a + set of times that are excluded every day. + + + Mike Funk + Aaron Craven + Marko Lahma (.NET) + + + + Create a with a time range defined by the + specified strings and no baseCalendar. + and + must be in the format "HH:MM[:SS[:mmm]]" where: +
    +
  • + HH is the hour of the specified time. The hour should be + specified using military (24-hour) time and must be in the range + 0 to 23. +
  • +
  • + MM is the minute of the specified time and must be in the range + 0 to 59. +
  • +
  • + SS is the second of the specified time and must be in the range + 0 to 59. +
  • +
  • + mmm is the millisecond of the specified time and must be in the + range 0 to 999. +
  • +
  • items enclosed in brackets ('[', ']') are optional.
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+
+ + + Create a with a time range defined by the + specified strings and the specified baseCalendar. + and + must be in the format "HH:MM[:SS[:mmm]]" where: +
    +
  • + HH is the hour of the specified time. The hour should be + specified using military (24-hour) time and must be in the range + 0 to 23. +
  • +
  • + MM is the minute of the specified time and must be in the range + 0 to 59. +
  • +
  • + SS is the second of the specified time and must be in the range + 0 to 59. +
  • +
  • + mmm is the millisecond of the specified time and must be in the + range 0 to 999. +
  • +
  • + items enclosed in brackets ('[', ']') are optional. +
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+ The base calendar for this calendar instance see BaseCalendar for more + information on base calendar functionality. +
+ + + Create a with a time range defined by the + specified values and no baseCalendar. Values are subject to + the following validations: +
    +
  • + Hours must be in the range 0-23 and are expressed using military + (24-hour) time. +
  • +
  • Minutes must be in the range 0-59
  • +
  • Seconds must be in the range 0-59
  • +
  • Milliseconds must be in the range 0-999
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+ The range starting hour of day. + The range starting minute. + The range starting second. + The range starting millis. + The range ending hour of day. + The range ending minute. + The range ending second. + The range ending millis. +
+ + + Create a with a time range defined by the + specified values and the specified . Values are + subject to the following validations: +
    +
  • + Hours must be in the range 0-23 and are expressed using military + (24-hour) time. +
  • +
  • Minutes must be in the range 0-59
  • +
  • Seconds must be in the range 0-59
  • +
  • Milliseconds must be in the range 0-999
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+ The range starting hour of day. + The range starting minute. + The range starting second. + The range starting millis. + The range ending hour of day. + The range ending minute. + The range ending second. + The range ending millis. +
+ + + Create a with a time range defined by the + specified s and no + baseCalendar. The Calendars are subject to the following + considerations: +
    +
  • + Only the time-of-day fields of the specified Calendars will be + used (the date fields will be ignored) +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time fields are + are used, it is possible for two Calendars to represent a valid + time range and + rangeStartingCalendar.after(rangeEndingCalendar) == true) + +
  • +
+
+ The range starting calendar. + The range ending calendar. +
+ + + Create a with a time range defined by the + specified s and the specified + . The Calendars are subject to the following + considerations: +
    +
  • + Only the time-of-day fields of the specified Calendars will be + used (the date fields will be ignored) +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time fields are + are used, it is possible for two Calendars to represent a valid + time range and + rangeStartingCalendarUtc > rangeEndingCalendarUtc == true) +
  • +
+
+ The range starting calendar. + The range ending calendar. +
+ + + Create a with a time range defined by the + specified values and no baseCalendar. The values are + subject to the following considerations: +
    +
  • + Only the time-of-day portion of the specified values will be + used +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time value are + are used, it is possible for the two values to represent a valid + time range and rangeStartingTime > rangeEndingTime) +
  • +
+
+ The range starting time in millis. + The range ending time in millis. +
+ + + Create a with a time range defined by the + specified values and the specified . The values + are subject to the following considerations: +
    +
  • + Only the time-of-day portion of the specified values will be + used +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time value are + are used, it is possible for the two values to represent a valid + time range and rangeStartingTime > rangeEndingTime) +
  • +
+
+ The range starting time in millis. + The range ending time in millis. +
+ + + Serialization constructor. + + + + + + + Determine whether the given time is 'included' by the + Calendar. + + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return 0 if all days are excluded. + + + + + + + + Returns the start time of the time range of the day + specified in . + + + a DateTime representing the start time of the + time range for the specified date. + + + + + Returns the end time of the time range of the day + specified in + + + A DateTime representing the end time of the + time range for the specified date. + + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Sets the time range for the to the times + represented in the specified Strings. + + The range starting time string. + The range ending time string. + + + + Sets the time range for the to the times + represented in the specified values. + + The range starting hour of day. + The range starting minute. + The range starting second. + The range starting millis. + The range ending hour of day. + The range ending minute. + The range ending second. + The range ending millis. + + + + Sets the time range for the to the times + represented in the specified s. + + The range starting calendar. + The range ending calendar. + + + + Sets the time range for the to the times + represented in the specified values. + + The range starting time. + The range ending time. + + + + Gets the start of day, practically zeroes time part. + + The time. + + + + + Gets the end of day, pratically sets time parts to maximum allowed values. + + The time. + + + + + Checks the specified values for validity as a set of time values. + + The hour of day. + The minute. + The second. + The millis. + + + + Indicates whether the time range represents an inverted time range (see + class description). + + true if invert time range; otherwise, false. + + + + This implementation of the Calendar stores a list of holidays (full days + that are excluded from scheduling). + + + The implementation DOES take the year into consideration, so if you want to + exclude July 4th for the next 10 years, you need to add 10 entries to the + exclude list. + + Sharada Jambula + Juergen Donnerstag + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The base calendar. + + + + Serialization constructor. + + + + + + + Determine whether the given time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. + + Note that this Calendar is only has full-day precision. + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Add the given Date to the list of excluded days. Only the month, day and + year of the returned dates are significant. + + + + + Removes the excluded date. + + The date to remove. + + + + Returns a of Dates representing the excluded + days. Only the month, day and year of the returned dates are + significant. + + + + + This implementation of the Calendar excludes a set of days of the month. You + may use it to exclude every 1. of each month for example. But you may define + any day of a month. + + + + Juergen Donnerstag + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Constructor + + The base calendar. + + + + Serialization constructor. + + + + + + + Initialize internal variables + + + + + Return true, if mday is defined to be exluded. + + + + + Redefine a certain day of the month to be excluded (true) or included + (false). + + + + + Check if all days are excluded. That is no day is included. + + boolean + + + + + Determine whether the given time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return DateTime.MinValue if all days are excluded. + + Note that this Calendar is only has full-day precision. + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Get or set the array which defines the exclude-value of each day of month + Setting will redefine the array of days excluded. The array must of size greater or + equal 31. + + + + + This implementation of the Calendar excludes a set of days of the week. You + may use it to exclude weekends for example. But you may define any day of + the week. + + + + Juergen Donnerstag + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The base calendar. + + + + Serialization constructor. + + + + + + + Initialize internal variables + + + + + Return true, if wday is defined to be exluded. E. g. + saturday and sunday. + + + + + Redefine a certain day of the week to be excluded (true) or included + (false). Use enum to determine the weekday. + + + + + Check if all week ays are excluded. That is no day is included. + + + + + Determine whether the given time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return DateTime.MinValue if all days are excluded. + + Note that this Calendar is only has full-day precision. + + + + + + Get the array with the week days. + Setting will redefine the array of days excluded. The array must of size greater or + equal 8. java.util.Calendar's constants like MONDAY should be used as + index. A value of true is regarded as: exclude it. + + + + + Matches using an AND operator on two Matcher operands. + + James House + Marko Lahma (.NET) + + + + Matchers can be used in various API methods to + select the entities that should be operated upon. + + James House + + + + + Create an AndMatcher that depends upon the result of both of the given matchers. + + + + + + + + + Matches on the complete key being equal (both name and group). + + + + jhouse + + + + Create an EverythingMatcher that matches all jobs. + + + + + + Create an EverythingMatcher that matches all triggers. + + + + + + Matches on group (ignores name) property of Keys. + + James House + Marko Lahma (.NET) + + + + An abstract base class for some types of matchers. + + James House + Marko Lahma (.NET) + + + + Create a GroupMatcher that matches groups equaling the given string. + + + + + + + Create a GroupMatcher that matches groups starting with the given string. + + + + + + + Create a GroupMatcher that matches groups ending with the given string. + + + + + + + Create a GroupMatcher that matches groups containing the given string. + + + + + + + Matches on the complete key being equal (both name and group). + + James House + Marko Lahma (.NET) + + + + Create a KeyMatcher that matches Keys that equal the given key. + + + + + + + + Matches on name (ignores group) property of Keys. + + James House + Marko Lahma (.NET) + + + + Create a NameMatcher that matches names equaling the given string. + + + + + + + Create a NameMatcher that matches names starting with the given string. + + + + + + + Create a NameMatcher that matches names ending with the given string. + + + + + + + Create a NameMatcher that matches names containing the given string. + + + + + + + Matches using an NOT operator on another Matcher. + + James House + Marko Lahma (.NET) + + + + Create a NotMatcher that reverses the result of the given matcher. + + + + + + + + Matches using an OR operator on two Matcher operands. + + James House + Marko Lahma (.NET) + + + + Create an OrMatcher that depends upon the result of at least one of the given matchers. + + + + + + + + + Operators available for comparing string values. + + + + + The base abstract class to be extended by all triggers. + + + + s have a name and group associated with them, which + should uniquely identify them within a single . + + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + Triggers can 'send' parameters/data to s by placing contents + into the on the . + + + + + + + + James House + Sharada Jambula + Marko Lahma (.NET) + + + + Internal interface for managing triggers. This interface should not be used by the Quartz client. + + + + + Should not be used by end users. + + + + + The base interface with properties common to all s - + use to instantiate an actual Trigger. + + + + s have a associated with them, which + should uniquely identify them within a single . + + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + Triggers can 'send' parameters/data to s by placing contents + into the on the . + + + + + + + + + + James House + Sharada Jambula + Marko Lahma (.NET) + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + Used by the to determine whether or not + it is possible for this to fire again. + + If the returned value is then the + may remove the from the . + + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + Get or set the description given to the instance by + its creator (if any). + + + + + Get or set the with the given name with + this Trigger. Use when setting to dis-associate a Calendar. + + + + + Get or set the that is associated with the + . + + Changes made to this map during job execution are not re-persisted, and + in fact typically result in an illegal state. + + + + + + Returns the last UTC time at which the will fire, if + the Trigger will repeat indefinitely, null will be returned. + + Note that the return time *may* be in the past. + + + + + + Get or set the instruction the should be given for + handling misfire situations for this - the + concrete type that you are using will have + defined a set of additional MISFIRE_INSTRUCTION_XXX + constants that may be set to this property. + + If not explicitly set, the default value is . + + + + + + + + + Gets and sets the date/time on which the trigger must stop firing. This + defines the final boundary for trigger firings 舒 the trigger will + not fire after to this date and time. If this value is null, no end time + boundary is assumed, and the trigger can continue indefinitely. + + + + + The time at which the trigger's scheduling should start. May or may not + be the first actual fire time of the trigger, depending upon the type of + trigger and the settings of the other properties of the trigger. However + the first actual first time will not be before this date. + + + Setting a value in the past may cause a new trigger to compute a first + fire time that is in the past, which may cause an immediate misfire + of the trigger. + + + + + The priority of a acts as a tie breaker such that if + two s have the same scheduled fire time, then Quartz + will do its best to give the one with the higher priority first access + to a worker thread. + + + If not explicitly set, the default value is 5. + + + + + + + Set a description for the instance - may be + useful for remembering/displaying the purpose of the trigger, though the + description has no meaning to Quartz. + + + + + Associate the with the given name with this Trigger. + + + + + Set the to be associated with the + . + + + + + The priority of a acts as a tie breaker such that if + two s have the same scheduled fire time, then Quartz + will do its best to give the one with the higher priority first access + to a worker thread. + + + If not explicitly set, the default value is 5. + + + + + + + The time at which the trigger's scheduling should start. May or may not + be the first actual fire time of the trigger, depending upon the type of + trigger and the settings of the other properties of the trigger. However + the first actual first time will not be before this date. + + + Setting a value in the past may cause a new trigger to compute a first + fire time that is in the past, which may cause an immediate misfire + of the trigger. + + ew DateTimeOffset StartTimeUtc { get; set; } + + + + + + Set the time at which the should quit repeating - + regardless of any remaining repeats (based on the trigger's particular + repeat settings). + + + + + + + + Set the instruction the should be given for + handling misfire situations for this - the + concrete type that you are using will have + defined a set of additional MisfireInstruction.XXX + constants that may be passed to this method. + + + If not explicitly set, the default value is . + + + + + + + + This method should not be used by the Quartz client. + + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + This method should not be used by the Quartz client. + + + Called after the has executed the + associated with the + in order to get the final instruction code from the trigger. + + + is the that was used by the + 's method. + is the thrown by the + , if any (may be null). + + + One of the members. + + + + + + + + + + This method should not be used by the Quartz client. + + To be implemented by the concrete classes that extend this class. + + + The implementation should update the 's state + based on the MISFIRE_INSTRUCTION_XXX that was selected when the + was created. + + + + + + This method should not be used by the Quartz client. + + The implementation should update the 's state + based on the given new version of the associated + (the state should be updated so that it's next fire time is appropriate + given the Calendar's new settings). + + + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + This method should not be used by the Quartz client. + + + Usable by + implementations, in order to facilitate 'recognizing' instances of fired + s as their jobs complete execution. + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Create a with no specified name, group, or . + + + Note that the , and + the and properties + must be set before the can be placed into a + . + + + + + Create a with the given name, and default group. + + + Note that the and + properties must be set before the + can be placed into a . + + The name. + + + + Create a with the given name, and group. + + + Note that the and + properties must be set before the + can be placed into a . + + The name. + if , Scheduler.DefaultGroup will be used. + + + + Create a with the given name, and group. + + The name. + if , Scheduler.DefaultGroup will be used. + Name of the job. + The job group. + ArgumentException + if name is null or empty, or the group is an empty string. + + + + + This method should not be used by the Quartz client. + + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + This method should not be used by the Quartz client. + + + Called after the has executed the + associated with the + in order to get the final instruction code from the trigger. + + + is the that was used by the + 's method. + is the thrown by the + , if any (may be null). + + + One of the members. + + + + + + + Used by the to determine whether or not + it is possible for this to fire again. + + If the returned value is then the + may remove the from the . + + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + This method should not be used by the Quartz client. + + To be implemented by the concrete classes that extend this class. + + + The implementation should update the 's state + based on the MISFIRE_INSTRUCTION_XXX that was selected when the + was created. + + + + + + This method should not be used by the Quartz client. + + The implementation should update the 's state + based on the given new version of the associated + (the state should be updated so that it's next fire time is appropriate + given the Calendar's new settings). + + + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Return a simple string representation of this object. + + + + + Compare the next fire time of this to that of + another by comparing their keys, or in other words, sorts them + according to the natural (i.e. alphabetical) order of their keys. + + + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + true if the specified is equal to the current ; otherwise, false. + + + + + Trigger equality is based upon the equality of the TriggerKey. + + + true if the key of this Trigger equals that of the given Trigger + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Get or sets the name of this . + + If name is null or empty. + + + + Get the group of this . If , Scheduler.DefaultGroup will be used. + + + if group is an empty string. + + + + + Get or set the name of the associated . + + + if jobName is null or empty. + + + + + Gets or sets the name of the associated 's + group. If set with , Scheduler.DefaultGroup will be used. + + ArgumentException + if group is an empty string. + + + + + Returns the 'full name' of the in the format + "group.name". + + + + + Gets the key. + + The key. + + + + Returns the 'full name' of the that the + points to, in the format "group.name". + + + + + Get or set the description given to the instance by + its creator (if any). + + + + + Get or set the with the given name with + this Trigger. Use when setting to dis-associate a Calendar. + + + + + Get or set the that is associated with the + . + + Changes made to this map during job execution are not re-persisted, and + in fact typically result in an illegal state. + + + + + + Returns the last UTC time at which the will fire, if + the Trigger will repeat indefinitely, null will be returned. + + Note that the return time *may* be in the past. + + + + + + Get or set the instruction the should be given for + handling misfire situations for this - the + concrete type that you are using will have + defined a set of additional MISFIRE_INSTRUCTION_XXX + constants that may be passed to this method. + + If not explicitly set, the default value is . + + + + + + + + + + This method should not be used by the Quartz client. + + + Usable by + implementations, in order to facilitate 'recognizing' instances of fired + s as their jobs complete execution. + + + + + Gets and sets the date/time on which the trigger must stop firing. This + defines the final boundary for trigger firings 舒 the trigger will + not fire after to this date and time. If this value is null, no end time + boundary is assumed, and the trigger can continue indefinitely. + + + + + The time at which the trigger's scheduling should start. May or may not + be the first actual fire time of the trigger, depending upon the type of + trigger and the settings of the other properties of the trigger. However + the first actual first time will not be before this date. + + + Setting a value in the past may cause a new trigger to compute a first + fire time that is in the past, which may cause an immediate misfire + of the trigger. + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + The priority of a acts as a tie breaker such that if + two s have the same scheduled fire time, then Quartz + will do its best to give the one with the higher priority first access + to a worker thread. + + + If not explicitly set, the default value is 5. + + + + + + + Gets a value indicating whether this instance has additional properties + that should be considered when for example saving to database. + + + If trigger implementation has additional properties that need to be saved + with base properties you need to make your class override this property with value true. + Returning true will effectively mean that ADOJobStore needs to serialize + this trigger instance to make sure additional properties are also saved. + + + true if this instance has additional properties; otherwise, false. + + + + + A concrete that is used to fire a + based upon repeating calendar time intervals. + + + The trigger will fire every N (see ) units of calendar time + (see ) as specified in the trigger's definition. + This trigger can achieve schedules that are not possible with (e.g + because months are not a fixed number of seconds) or (e.g. because + "every 5 months" is not an even divisor of 12). + + If you use an interval unit of then care should be taken when setting + a value that is on a day near the end of the month. For example, + if you choose a start time that occurs on January 31st, and have a trigger with unit + and interval 1, then the next fire time will be February 28th, + and the next time after that will be March 28th - and essentially each subsequent firing will + occur on the 28th of the month, even if a 31st day exists. If you want a trigger that always + fires on the last day of the month - regardless of the number of days in the month, + you should use . + + + + + + + 2.0 + James House + Marko Lahma (.NET) + + + + A that is used to fire a + based upon repeating calendar time intervals. + + + + + Get or set the interval unit - the time unit on with the interval applies. + + + + + Get the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + Get the number of times the has already fired. + + + + + Gets the time zone within which time calculations related to this trigger will be performed. + + + If null, the system default TimeZone will be used. + + + + + If intervals are a day or greater, this property (set to true) will + cause the firing of the trigger to always occur at the same time of day, + (the time of day of the startTime) regardless of daylight saving time + transitions. Default value is false. + + + + For example, without the property set, your trigger may have a start + time of 9:00 am on March 1st, and a repeat interval of 2 days. But + after the daylight saving transition occurs, the trigger may start + firing at 8:00 am every other day. + + + If however, the time of day does not exist on a given day to fire + (e.g. 2:00 am in the United States on the days of daylight saving + transition), the trigger will go ahead and fire one hour off on + that day, and then resume the normal hour on other days. If + you wish for the trigger to never fire at the "wrong" hour, then + you should set the property skipDayIfHourDoesNotExist. + + + + + + + + + If intervals are a day or greater, and + preserveHourOfDayAcrossDaylightSavings property is set to true, and the + hour of the day does not exist on a given day for which the trigger + would fire, the day will be skipped and the trigger advanced a second + interval if this property is set to true. Defaults to false. + + + CAUTION! If you enable this property, and your hour of day happens + to be that of daylight savings transition (e.g. 2:00 am in the United + States) and the trigger's interval would have had the trigger fire on + that day, then you may actually completely miss a firing on the day of + transition if that hour of day does not exist on that day! In such a + case the next fire time of the trigger will be computed as double (if + the interval is 2 days, then a span of 4 days between firings will + occur). + + + + + + Create a with no settings. + + + + + Create a that will occur immediately, and + repeat at the the given interval. + + Name for the trigger instance. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur immediately, and + repeat at the the given interval + + Name for the trigger instance. + Group for the trigger instance. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + Name for the trigger instance. + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + Name for the trigger instance. + Group for the trigger instance. + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + Name for the trigger instance. + Group for the trigger instance. + Name of the associated job. + Group of the associated job. + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + Updates the 's state based on the + MisfireInstruction.XXX that was selected when the + was created. + + + If the misfire instruction is set to , + then the following scheme will be used: +
    +
  • The instruction will be interpreted as
  • +
+
+
+ + + This method should not be used by the Quartz client. + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + + This method should not be used by the Quartz client. + + The implementation should update the 's state + based on the given new version of the associated + (the state should be updated so that it's next fire time is appropriate + given the Calendar's new settings). + + + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + Determines whether or not the will occur + again. + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + + + Get the time at which the should occur. + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + Get the time at which the should quit + repeating. + + + + + Get or set the interval unit - the time unit on with the interval applies. + + + + + Get the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + If intervals are a day or greater, this property (set to true) will + cause the firing of the trigger to always occur at the same time of day, + (the time of day of the startTime) regardless of daylight saving time + transitions. Default value is false. + + + + For example, without the property set, your trigger may have a start + time of 9:00 am on March 1st, and a repeat interval of 2 days. But + after the daylight saving transition occurs, the trigger may start + firing at 8:00 am every other day. + + + If however, the time of day does not exist on a given day to fire + (e.g. 2:00 am in the United States on the days of daylight saving + transition), the trigger will go ahead and fire one hour off on + that day, and then resume the normal hour on other days. If + you wish for the trigger to never fire at the "wrong" hour, then + you should set the property skipDayIfHourDoesNotExist. + + + + + + + + + If intervals are a day or greater, and + preserveHourOfDayAcrossDaylightSavings property is set to true, and the + hour of the day does not exist on a given day for which the trigger + would fire, the day will be skipped and the trigger advanced a second + interval if this property is set to true. Defaults to false. + + + CAUTION! If you enable this property, and your hour of day happens + to be that of daylight savings transition (e.g. 2:00 am in the United + States) and the trigger's interval would have had the trigger fire on + that day, then you may actually completely miss a firing on the day of + transition if that hour of day does not exist on that day! In such a + case the next fire time of the trigger will be computed as double (if + the interval is 2 days, then a span of 4 days between firings will + occur). + + + + + + Get the number of times the has already fired. + + + + + Returns the final time at which the will + fire, if there is no end time set, null will be returned. + + + Note that the return time may be in the past. + + + + A concrete that is used to fire a + at given moments in time, defined with Unix 'cron-like' definitions. + + + + For those unfamiliar with "cron", this means being able to create a firing + schedule such as: "At 8:00am every Monday through Friday" or "At 1:30am + every last Friday of the month". + + + + The format of a "Cron-Expression" string is documented on the + class. + + + + Here are some full examples:
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Expression Meaning
"0 0 12 * * ?"" /> Fire at 12pm (noon) every day" />
"0 15 10 ? * *"" /> Fire at 10:15am every day" />
"0 15 10 * * ?"" /> Fire at 10:15am every day" />
"0 15 10 * * ? *"" /> Fire at 10:15am every day" />
"0 15 10 * * ? 2005"" /> Fire at 10:15am every day during the year 2005" /> +
"0 * 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:59pm, every day" /> +
"0 0/5 14 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, every day" /> +
"0 0/5 14,18 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, AND fire every 5 minutes starting at 6pm and ending at 6:55pm, every day" /> +
"0 0-5 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:05pm, every day" /> +
"0 10,44 14 ? 3 WED"" /> Fire at 2:10pm and at 2:44pm every Wednesday in the month of March." /> +
"0 15 10 ? * MON-FRI"" /> Fire at 10:15am every Monday, Tuesday, Wednesday, Thursday and Friday" /> +
"0 15 10 15 * ?"" /> Fire at 10:15am on the 15th day of every month" /> +
"0 15 10 L * ?"" /> Fire at 10:15am on the last day of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L 2002-2005"" /> Fire at 10:15am on every last Friday of every month during the years 2002, 2003, 2004 and 2005" /> +
"0 15 10 ? * 6#3"" /> Fire at 10:15am on the third Friday of every month" /> +
+
+ + + Pay attention to the effects of '?' and '*' in the day-of-week and + day-of-month fields! + + + + NOTES: +
    +
  • Support for specifying both a day-of-week and a day-of-month value is + not complete (you'll need to use the '?' character in on of these fields). +
  • +
  • Be careful when setting fire times between mid-night and 1:00 AM - + "daylight savings" can cause a skip or a repeat depending on whether the + time moves back or jumps forward.
  • +
+
+
+ + + Sharada Jambula + James House + Contributions from Mads Henderson + Marko Lahma (.NET) +
+ + + The public interface for inspecting settings specific to a CronTrigger, + which is used to fire a + at given moments in time, defined with Unix 'cron-like' schedule definitions. + + + + For those unfamiliar with "cron", this means being able to create a firing + schedule such as: "At 8:00am every Monday through Friday" or "At 1:30am + every last Friday of the month". + + + + The format of a "Cron-Expression" string is documented on the + class. + + + + Here are some full examples:
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Expression Meaning
"0 0 12 * * ?"" /> Fire at 12pm (noon) every day" />
"0 15 10 ? * *"" /> Fire at 10:15am every day" />
"0 15 10 * * ?"" /> Fire at 10:15am every day" />
"0 15 10 * * ? *"" /> Fire at 10:15am every day" />
"0 15 10 * * ? 2005"" /> Fire at 10:15am every day during the year 2005" /> +
"0 * 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:59pm, every day" /> +
"0 0/5 14 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, every day" /> +
"0 0/5 14,18 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, AND fire every 5 minutes starting at 6pm and ending at 6:55pm, every day" /> +
"0 0-5 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:05pm, every day" /> +
"0 10,44 14 ? 3 WED"" /> Fire at 2:10pm and at 2:44pm every Wednesday in the month of March." /> +
"0 15 10 ? * MON-FRI"" /> Fire at 10:15am every Monday, Tuesday, Wednesday, Thursday and Friday" /> +
"0 15 10 15 * ?"" /> Fire at 10:15am on the 15th day of every month" /> +
"0 15 10 L * ?"" /> Fire at 10:15am on the last day of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L 2002-2005"" /> Fire at 10:15am on every last Friday of every month during the years 2002, 2003, 2004 and 2005" /> +
"0 15 10 ? * 6#3"" /> Fire at 10:15am on the third Friday of every month" /> +
+
+ + + Pay attention to the effects of '?' and '*' in the day-of-week and + day-of-month fields! + + + + NOTES: +
    +
  • Support for specifying both a day-of-week and a day-of-month value is + not complete (you'll need to use the '?' character in on of these fields). +
  • +
  • Be careful when setting fire times between mid-night and 1:00 AM - + "daylight savings" can cause a skip or a repeat depending on whether the + time moves back or jumps forward.
  • +
+
+
+ + + Sharada Jambula + James House + Contributions from Mads Henderson + Marko Lahma (.NET) +
+ + + Gets the expression summary. + + + + + + Gets or sets the cron expression string. + + The cron expression string. + + + + Sets the time zone for which the of this + will be resolved. + + + If is set after this + property, the TimeZone setting on the CronExpression will "win". However + if is set after this property, the + time zone applied by this method will remain in effect, since the + string cron expression does not carry a time zone! + + The time zone. + + + + Create a with no settings. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + + + + Create a with the given name and default group. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + + + + Create a with the given name and group. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + The group of the + + + + Create a with the given name, group and + expression. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + The group of the + A cron expression dictating the firing sequence of the + + + + Create a with the given name and group, and + associated with the identified . + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the . + The group of the + name of the executed on firetime + Group of the executed on firetime + + + + Create a with the given name and group, + associated with the identified , + and with the given "cron" expression. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A cron expression dictating the firing sequence of the + + + + Create a with the given name and group, + associated with the identified , + and with the given "cron" expression resolved with respect to the . + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A cron expression dictating the firing sequence of the + + Specifies for which time zone the cronExpression should be interpreted, + i.e. the expression 0 0 10 * * ?, is resolved to 10:00 am in this time zone. + + + + + Create a that will occur at the given time, + until the given end time. + + If null, the start-time will also be set to the current time, the time + zone will be set the the system's default. + + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A set to the earliest time for the to start firing. + A set to the time for the to quit repeat firing. + A cron expression dictating the firing sequence of the + + + + Create a with fire time dictated by the + resolved with respect to the specified + occurring from the until + the given . + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A set to the earliest time for the to start firing. + A set to the time for the to quit repeat firing. + + + + Clones this instance. + + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + + Sets the next fire time. + + This method should not be invoked by client code. + + + The fire time. + + + + Sets the previous fire time. + + This method should not be invoked by client code. + + + The fire time. + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + + + Used by the to determine whether or not + it is possible for this to fire again. + + If the returned value is then the + may remove the from the . + + + + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + This method should not be used by the Quartz client. + + To be implemented by the concrete classes that extend this class. + + + The implementation should update the 's state + based on the MISFIRE_INSTRUCTION_XXX that was selected when the + was created. + + + + + + + + Determines whether the date and (optionally) time of the given Calendar + instance falls on a scheduled fire-time of this trigger. + + + + Equivalent to calling . + + + The date to compare. + + + + + Determines whether the date and (optionally) time of the given Calendar + instance falls on a scheduled fire-time of this trigger. + + Note that the value returned is NOT validated against the related + ICalendar (if any). + + + The date to compare + If set to true, the method will only determine if the + trigger will fire during the day represented by the given Calendar + (hours, minutes and seconds will be ignored). + + + + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + + Updates the trigger with new calendar. + + The calendar to update with. + The misfire threshold. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + After this method has been called, + should return a valid answer. + + + + + the first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Gets the expression summary. + + + + + + Gets the next time to fire after the given time. + + The time to compute from. + + + + + NOT YET IMPLEMENTED: Returns the time before the given time + that this will fire. + + The date. + + + + + Gets or sets the cron expression string. + + The cron expression string. + + + + Set the CronExpression to the given one. The TimeZone on the passed-in + CronExpression over-rides any that was already set on the Trigger. + + The cron expression. + + + + Returns the date/time on which the trigger may begin firing. This + defines the initial boundary for trigger firings the trigger + will not fire prior to this date and time. + + + + + + Get or sets the time at which the CronTrigger should quit + repeating - even if repeastCount isn't yet satisfied. + + + + + Sets the time zone for which the of this + will be resolved. + + + If is set after this + property, the TimeZone setting on the CronExpression will "win". However + if is set after this property, the + time zone applied by this method will remain in effect, since the + string cron expression does not carry a time zone! + + The time zone. + + + + Returns the last UTC time at which the will fire, if + the Trigger will repeat indefinitely, null will be returned. + + Note that the return time *may* be in the past. + + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + + A concrete implementation of DailyTimeIntervalTrigger that is used to fire a + based upon daily repeating time intervals. + + + + The trigger will fire every N ( ) seconds, minutes or hours + (see ) during a given time window on specified days of the week. + + + For example#1, a trigger can be set to fire every 72 minutes between 8:00 and 11:00 everyday. It's fire times would + be 8:00, 9:12, 10:24, then next day would repeat: 8:00, 9:12, 10:24 again. + + + For example#2, a trigger can be set to fire every 23 minutes between 9:20 and 16:47 Monday through Friday. + + + On each day, the starting fire time is reset to startTimeOfDay value, and then it will add repeatInterval value to it until + the endTimeOfDay is reached. If you set daysOfWeek values, then fire time will only occur during those week days period. Again, + remember this trigger will reset fire time each day with startTimeOfDay, regardless of your interval or endTimeOfDay! + + + The default values for fields if not set are: startTimeOfDay defaults to 00:00:00, the endTimeOfDay default to 23:59:59, + and daysOfWeek is default to every day. The startTime default to current time-stamp now, while endTime has not value. + + + If startTime is before startTimeOfDay, then startTimeOfDay will be used and startTime has no affect. Else if startTime is + after startTimeOfDay, then the first fire time for that day will be the next interval after the startTime. For example, if + you set startingTimeOfDay=9am, endingTimeOfDay=11am, interval=15 mins, and startTime=9:33am, then the next fire time will + be 9:45pm. Note also that if you do not set startTime value, the trigger builder will default to current time, and current time + maybe before or after the startTimeOfDay! So be aware how you set your startTime. + + + This trigger also supports "repeatCount" feature to end the trigger fire time after + a certain number of count is reached. Just as the SimpleTrigger, setting repeatCount=0 + means trigger will fire once only! Setting any positive count then the trigger will repeat + count + 1 times. Unlike SimpleTrigger, the default value of repeatCount of this trigger + is set to REPEAT_INDEFINITELY instead of 0 though. + + + + + 2.0 + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + A that is used to fire a + based upon daily repeating time intervals. + + + The trigger will fire every N (see ) seconds, minutes or hours + (see during a given time window on specified days of the week. + + For example#1, a trigger can be set to fire every 72 minutes between 8:00 and 11:00 everyday. It's fire times + be 8:00, 9:12, 10:24, then next day would repeat: 8:00, 9:12, 10:24 again. + + For example#2, a trigger can be set to fire every 23 minutes between 9:20 and 16:47 Monday through Friday. + + On each day, the starting fire time is reset to startTimeOfDay value, and then it will add repeatInterval value to it until + the endTimeOfDay is reached. If you set daysOfWeek values, then fire time will only occur during those week days period. + + The default values for fields if not set are: startTimeOfDay defaults to 00:00:00, the endTimeOfDay default to 23:59:59, + and daysOfWeek is default to every day. The startTime default to current time-stamp now, while endTime has not value. + + If startTime is before startTimeOfDay, then it has no affect. Else if startTime after startTimeOfDay, then the first fire time + for that day will be normal startTimeOfDay incremental values after startTime value. Same reversal logic is applied to endTime + with endTimeOfDay. + + + + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + + + + + + Get the the number of times for interval this trigger should repeat, + after which it will be automatically deleted. + + + + + Get the interval unit - the time unit on with the interval applies. + The only intervals that are valid for this type of trigger are , + , and + + + + + Get the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + The time of day to start firing at the given interval. + + + + + The time of day to complete firing at the given interval. + + + + + The days of the week upon which to fire. + + + A Set containing the integers representing the days of the week, per the values 0-6 as defined by + DayOfWees.Sunday - DayOfWeek.Saturday. + + + + + Get the number of times the has already fired. + + + + + Used to indicate the 'repeat count' of the trigger is indefinite. Or in + other words, the trigger should repeat continually until the trigger's + ending timestamp. + + + + + Create a with no settings. + + + + + Create a that will occur immediately, and + repeat at the the given interval. + + + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + + + + + Create a that will occur immediately, and + repeat at the the given interval. + + + + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + + + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + fire the identified job and repeat at the the given + interval until the given end time. + + + + + + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + The number of milliseconds to pause between the repeat firing. + + + + Updates the 's state based on the + MisfireInstruction.XXX that was selected when the + was created. + + + If the misfire instruction is set to , + then the following scheme will be used: +
    +
  • The instruction will be interpreted as
  • +
+
+
+ + + Called when the scheduler has decided to 'fire' + the trigger (execute the associated job), in order to + give the trigger a chance to update itself for its next + triggering (if any). + + + + + + + + + + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Set the next time at which the should fire. + + + This method should not be invoked by client code. + + + + + + Set the previous time at which the fired. + + + This method should not be invoked by client code. + + + + + + Returns the next time at which the will + fire, after the given time. If the trigger will not fire after the given + time, will be returned. + + + + + + + Given fireTime time, we need to advance/calculate and return a time of next available week day. + + given next fireTime. + flag to whether to advance day without check existing week day. This scenario + can happen when a caller determine fireTime has passed the endTimeOfDay that fireTime should move to next day anyway. + + a next day fireTime. + + + + Determines whether or not the will occur + again. + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + + The time at which the should occur. + + + + + the time at which the should quit repeating. + + + + + + Get the the number of times for interval this trigger should repeat, + after which it will be automatically deleted. + + + + + the interval unit - the time unit on with the interval applies. + + + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + + + + + the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + the number of times the has already + fired. + + + + + Returns the final time at which the will + fire, if there is no end time set, null will be returned. + + Note that the return time may be in the past. + + + + + The days of the week upon which to fire. + + + A Set containing the integers representing the days of the week, per the values 0-6 as defined by + DayOfWees.Sunday - DayOfWeek.Saturday. + + + + + The time of day to start firing at the given interval. + + + + + The time of day to complete firing at the given interval. + + + + + This trigger has no additional properties besides what's defined in this class. + + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + A concrete that is used to fire a + at a given moment in time, and optionally repeated at a specified interval. + + + + James House + Contributions by Lieven Govaerts of Ebitec Nv, Belgium. + Marko Lahma (.NET) + + + + A that is used to fire a + at a given moment in time, and optionally repeated at a specified interval. + + + + James House + Contributions by Lieven Govaerts of Ebitec Nv, Belgium. + Marko Lahma (.NET) + + + + Get or set thhe number of times the should + repeat, after which it will be automatically deleted. + + + + + + Get or set the the time interval at which the should repeat. + + + + + Get or set the number of times the has already + fired. + + + + + Used to indicate the 'repeat count' of the trigger is indefinite. Or in + other words, the trigger should repeat continually until the trigger's + ending timestamp. + + + + + Create a with no settings. + + + + + Create a that will occur immediately, and + not repeat. + + + + + Create a that will occur immediately, and + not repeat. + + + + + Create a that will occur immediately, and + repeat at the the given interval the given number of times. + + + + + Create a that will occur immediately, and + repeat at the the given interval the given number of times. + + + + + Create a that will occur at the given time, + and not repeat. + + + + + Create a that will occur at the given time, + and not repeat. + + + + + Create a that will occur at the given time, + and repeat at the the given interval the given number of times, or until + the given end time. + + The name. + A UTC set to the time for the to fire. + A UTC set to the time for the + to quit repeat firing. + The number of times for the to repeat + firing, use for unlimited times. + The time span to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval the given number of times, or until + the given end time. + + The name. + The group. + A UTC set to the time for the to fire. + A UTC set to the time for the + to quit repeat firing. + The number of times for the to repeat + firing, use for unlimited times. + The time span to pause between the repeat firing. + + + + Create a that will occur at the given time, + fire the identified and repeat at the the given + interval the given number of times, or until the given end time. + + The name. + The group. + Name of the job. + The job group. + A set to the time for the + to fire. + A set to the time for the + to quit repeat firing. + The number of times for the to repeat + firing, use RepeatIndefinitely for unlimited times. + The time span to pause between the repeat firing. + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + Updates the 's state based on the + MisfireInstruction value that was selected when the + was created. + + + If MisfireSmartPolicyEnabled is set to true, + then the following scheme will be used:
+
    +
  • If the Repeat Count is 0, then the instruction will + be interpreted as .
  • +
  • If the Repeat Count is , then + the instruction will be interpreted as . + WARNING: using MisfirePolicy.SimpleTrigger.RescheduleNowWithRemainingRepeatCount + with a trigger that has a non-null end-time may cause the trigger to + never fire again if the end-time arrived during the misfire time span. +
  • +
  • If the Repeat Count is > 0, then the instruction + will be interpreted as . +
  • +
+
+
+ + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + Updates the instance with new calendar. + + The calendar. + The misfire threshold. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Returns the next time at which the will + fire. If the trigger will not fire again, will be + returned. The value returned is not guaranteed to be valid until after + the has been added to the scheduler. + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be + returned. + + + + + Returns the next UTC time at which the will + fire, after the given UTC time. If the trigger will not fire after the given + time, will be returned. + + + + + Returns the last UTC time at which the will + fire, before the given time. If the trigger will not fire before the + given time, will be returned. + + + + + Computes the number of times fired between the two UTC date times. + + The UTC start date and time. + The UTC end date and time. + + + + + Determines whether or not the will occur + again. + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Get or set thhe number of times the should + repeat, after which it will be automatically deleted. + + + + + + Get or set the the time interval at which the should repeat. + + + + + Get or set the number of times the has already + fired. + + + + + Returns the final UTC time at which the will + fire, if repeatCount is RepeatIndefinitely, null will be returned. + + Note that the return time may be in the past. + + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + + Schedules work on a newly spawned thread. This is the default Quartz behavior. + + matt.accola + + + + Allows different strategies for scheduling threads. The + method is required to be called before the first call to + . The Thread containing the work to be performed is + passed to execute and the work is scheduled by the underlying implementation. + + matt.accola + + + + Submit a task for execution. + + Thread to execute. + + + + Initialize any state prior to calling . + + + + + A singleton implementation of . + + + Here are some examples of using this class: + + To create a scheduler that does not write anything to the database (is not + persistent), you can call : + + + DirectSchedulerFactory.Instance.CreateVolatileScheduler(10); // 10 threads + // don't forget to start the scheduler: + DirectSchedulerFactory.Instance.GetScheduler().Start(); + + + Several create methods are provided for convenience. All create methods + eventually end up calling the create method with all the parameters: + + + public void CreateScheduler(string schedulerName, string schedulerInstanceId, IThreadPool threadPool, IJobStore jobStore) + + + Here is an example of using this method: + + + // create the thread pool + SimpleThreadPool threadPool = new SimpleThreadPool(maxThreads, ThreadPriority.Normal); + threadPool.Initialize(); + // create the job store + JobStore jobStore = new RAMJobStore(); + + DirectSchedulerFactory.Instance.CreateScheduler("My Quartz Scheduler", "My Instance", threadPool, jobStore); + // don't forget to start the scheduler: + DirectSchedulerFactory.Instance.GetScheduler("My Quartz Scheduler", "My Instance").Start(); + + > + Mohammad Rezaei + James House + Marko Lahma (.NET) + + + + + + Provides a mechanism for obtaining client-usable handles to + instances. + + + + James House + Marko Lahma (.NET) + + + + Returns a client-usable handle to a . + + + + + Returns a handle to the Scheduler with the given name, if it exists. + + + + + Returns handles to all known Schedulers (made by any SchedulerFactory + within this app domain.). + + + + + Initializes a new instance of the class. + + + + + Creates an in memory job store () + The thread priority is set to Thread.NORM_PRIORITY + + The number of threads in the thread pool + + + + Creates a proxy to a remote scheduler. This scheduler can be retrieved + via . + + SchedulerException + + + + Same as , + with the addition of specifying the scheduler name and instance ID. This + scheduler can only be retrieved via . + + The name for the scheduler. + The instance ID for the scheduler. + + SchedulerException + + + + Creates a scheduler using the specified thread pool and job store. This + scheduler can be retrieved via DirectSchedulerFactory#GetScheduler() + + + The thread pool for executing jobs + + + The type of job store + + SchedulerException + if initialization failed + + + + + Same as DirectSchedulerFactory#createScheduler(ThreadPool threadPool, JobStore jobStore), + with the addition of specifying the scheduler name and instance ID. This + scheduler can only be retrieved via DirectSchedulerFactory#getScheduler(String) + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + The type of job store + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + The type of job store + The idle wait time. You can specify "-1" for + the default value, which is currently 30000 ms. + The db failure retry interval. + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + The type of job store + + The idle wait time. You can specify TimeSpan.Zero for + the default value, which is currently 30000 ms. + The db failure retry interval. + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + Thread executor. + The type of job store + + The idle wait time. You can specify TimeSpan.Zero for + the default value, which is currently 30000 ms. + The db failure retry interval. + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + Thread executor. + The type of job store + + The idle wait time. You can specify TimeSpan.Zero for + the default value, which is currently 30000 ms. + The db failure retry interval. + The maximum batch size of triggers, when acquiring them + The time window for which it is allowed to "pre-acquire" triggers to fire + + + + Returns a handle to the Scheduler produced by this factory. + + you must call createRemoteScheduler or createScheduler methods before + calling getScheduler() + + + + SchedulerException + + + + Returns a handle to the Scheduler with the given name, if it exists. + + + + + Gets the log. + + The log. + + + + Gets the instance. + + The instance. + + + + Returns a handle to all known Schedulers (made by any + StdSchedulerFactory instance.). + + + + + + Conveys the detail properties of a given job instance. + + + Quartz does not store an actual instance of a type, but + instead allows you to define an instance of one, through the use of a . + + s have a name and group associated with them, which + should uniquely identify them within a single . + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + + + + + James House + Marko Lahma (.NET) + + + + Conveys the detail properties of a given job instance. + JobDetails are to be created/defined with . + + + Quartz does not store an actual instance of a type, but + instead allows you to define an instance of one, through the use of a . + + s have a name and group associated with them, which + should uniquely identify them within a single . + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + + + + + James House + Marko Lahma (.NET) + + + + Get a that is configured to produce a + identical to this one. + + + + + The key that identifies this jobs uniquely. + + + + + Get or set the description given to the instance by its + creator (if any). + + + + + Get or sets the instance of that will be executed. + + + + + Get or set the that is associated with the . + + + + + Whether or not the should remain stored after it is + orphaned (no s point to it). + + + If not explicitly set, the default value is . + + + if the Job should remain persisted after being orphaned. + + + + + Whether the associated Job class carries the . + + + + + + Whether the associated Job class carries the . + + + + + + Set whether or not the the should re-Execute + the if a 'recovery' or 'fail-over' situation is + encountered. + + + If not explicitly set, the default value is . + + + + + + Create a with no specified name or group, and + the default settings of all the other properties. + + Note that the , and + properties must be set before the job can be + placed into a . + + + + + + Create a with the given name, default group, and + the default settings of all the other properties. + If , Scheduler.DefaultGroup will be used. + + + If name is null or empty, or the group is an empty string. + + + + + Create a with the given name, and group, and + the default settings of all the other properties. + If , Scheduler.DefaultGroup will be used. + + + If name is null or empty, or the group is an empty string. + + + + + Create a with the given name, and group, and + the given settings of all the other properties. + + The name. + if , Scheduler.DefaultGroup will be used. + Type of the job. + if set to true, job will be durable. + if set to true, job will request recovery. + + ArgumentException if name is null or empty, or the group is an empty string. + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Return a simple string representation of this object. + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Determines whether the specified detail is equal to this instance. + + The detail to examine. + + true if the specified detail is equal; otherwise, false. + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + if the specified is equal to the + current ; otherwise, . + + + + + Checks equality between given job detail and this instance. + + The detail to compare this instance with. + + + + + Serves as a hash function for a particular type, suitable + for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Get or sets the name of this . + + + if name is null or empty. + + + + + Get or sets the group of this . + If , will be used. + + + If the group is an empty string. + + + + + Returns the 'full name' of the in the format + "group.name". + + + + + Gets the key. + + The key. + + + + Get or set the description given to the instance by its + creator (if any). + + + May be useful for remembering/displaying the purpose of the job, though the + description has no meaning to Quartz. + + + + + Get or sets the instance of that will be executed. + + + if jobType is null or the class is not a . + + + + + Get or set the that is associated with the . + + + + + Set whether or not the the should re-Execute + the if a 'recovery' or 'fail-over' situation is + encountered. + + If not explicitly set, the default value is . + + + + + + + Whether or not the should remain stored after it is + orphaned (no s point to it). + + If not explicitly set, the default value is . + + + + if the Job should remain persisted after + being orphaned. + + + + + Whether the associated Job class carries the attribute. + + + + + Whether the associated Job class carries the attribute. + + + + + A context bundle containing handles to various environment information, that + is given to a instance as it is + executed, and to a instance after the + execution completes. + + + + The found on this object (via the + method) serves as a convenience - + it is a merge of the found on the + and the one found on the , with + the value in the latter overriding any same-named values in the former. + It is thus considered a 'best practice' that the Execute code of a Job + retrieve data from the JobDataMap found on this object + + + NOTE: Do not + expect value 'set' into this JobDataMap to somehow be set back onto a + job's own JobDataMap. + + + + s are also returned from the + + method. These are the same instances as those past into the jobs that are + currently executing within the scheduler. The exception to this is when your + application is using Quartz remotely (i.e. via remoting or WCF) - in which case you get + a clone of the s, and their references to + the and instances have been lost (a + clone of the is still available - just not a handle + to the job instance that is running). + + + + + + + + James House + Marko Lahma (.NET) + + + + A context bundle containing handles to various environment information, that + is given to a instance as it is + executed, and to a instance after the + execution completes. + + + + + Put the specified value into the context's data map with the given key. + Possibly useful for sharing data between listeners and jobs. + + NOTE: this data is volatile - it is lost after the job execution + completes, and all TriggerListeners and JobListeners have been + notified. + + + + + + + + + + Get the value with the given key from the context's data map. + + + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the referenced by the + instance that fired the . + + + + + If the is being re-executed because of a 'recovery' + situation, this method will return . + + + + + Gets the refire count. + + The refire count. + + + + Get the convenience of this execution context. + + + + The found on this object serves as a convenience - + it is a merge of the found on the + and the one found on the , with + the value in the latter overriding any same-named values in the former. + It is thus considered a 'best practice' that the Execute code of a Job + retrieve data from the JobDataMap found on this object. + + + NOTE: Do not expect value 'set' into this JobDataMap to somehow be + set back onto a job's own JobDataMap. + + + Attempts to change the contents of this map typically result in an + illegal state. + + + + + + Get the associated with the . + + + + + Get the instance of the that was created for this + execution. + + Note: The Job instance is not available through remote scheduler + interfaces. + + + + + + The actual time the trigger fired. For instance the scheduled time may + have been 10:00:00 but the actual fire time may have been 10:00:03 if + the scheduler was too busy. + + Returns the fireTimeUtc. + + + + + The scheduled time the trigger fired for. For instance the scheduled + time may have been 10:00:00 but the actual fire time may have been + 10:00:03 if the scheduler was too busy. + + Returns the scheduledFireTimeUtc. + + + + + Gets the previous fire time. + + The previous fire time. + + + + Gets the next fire time. + + The next fire time. + + + + Get the unique Id that identifies this particular firing instance of the + trigger that triggered this job execution. It is unique to this + JobExecutionContext instance as well. + + the unique fire instance id + + + + + Returns the result (if any) that the set before its + execution completed (the type of object set as the result is entirely up + to the particular job). + + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + Set the result (if any) of the 's execution (the type of + object set as the result is entirely up to the particular job). + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + + + + The amount of time the job ran for. The returned + value will be until the job has actually completed (or thrown an + exception), and is therefore generally only useful to + s and s. + + + + + Create a JobExcecutionContext with the given context data. + + + + + Increments the refire count. + + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Put the specified value into the context's data map with the given key. + Possibly useful for sharing data between listeners and jobs. + + NOTE: this data is volatile - it is lost after the job execution + completes, and all TriggerListeners and JobListeners have been + notified. + + + + + + + + + + Get the value with the given key from the context's data map. + + + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the referenced by the + instance that fired the . + + + + + If the is being re-executed because of a 'recovery' + situation, this method will return . + + + + + Gets the refire count. + + The refire count. + + + + Get the convenience of this execution context. + + + + The found on this object serves as a convenience - + it is a merge of the found on the + and the one found on the , with + the value in the latter overriding any same-named values in the former. + It is thus considered a 'best practice' that the Execute code of a Job + retrieve data from the JobDataMap found on this object. + + + NOTE: Do not expect value 'set' into this JobDataMap to somehow be + set back onto a job's own JobDataMap. + + + Attempts to change the contents of this map typically result in an + illegal state. + + + + + + Get the associated with the . + + + + + Get the instance of the that was created for this + execution. + + Note: The Job instance is not available through remote scheduler + interfaces. + + + + + + The actual time the trigger fired. For instance the scheduled time may + have been 10:00:00 but the actual fire time may have been 10:00:03 if + the scheduler was too busy. + + Returns the fireTimeUtc. + + + + + The scheduled time the trigger fired for. For instance the scheduled + time may have been 10:00:00 but the actual fire time may have been + 10:00:03 if the scheduler was too busy. + + Returns the scheduledFireTimeUtc. + + + + + Gets the previous fire time. + + The previous fire time. + + + + Gets the next fire time. + + The next fire time. + + + + Returns the result (if any) that the set before its + execution completed (the type of object set as the result is entirely up + to the particular job). + + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + Set the result (if any) of the 's execution (the type of + object set as the result is entirely up to the particular job). + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + + + + The amount of time the job ran for. The returned + value will be until the job has actually completed (or thrown an + exception), and is therefore generally only useful to + s and s. + + + + + Returns the fire instace id. + + + + + An implementation of the interface that remotely + proxies all method calls to the equivalent call on a given + instance, via remoting or similar technology. + + + + James House + Marko Lahma (.NET) + + + + This is the main interface of a Quartz Scheduler. + + + + A maintains a registry of + s and s. Once + registered, the is responsible for executing + s when their associated s + fire (when their scheduled time arrives). + + + instances are produced by a + . A scheduler that has already been + created/initialized can be found and used through the same factory that + produced it. After a has been created, it is in + "stand-by" mode, and must have its method + called before it will fire any s. + + + s are to be created by the 'client program', by + defining a class that implements the interface. + objects are then created (also by the client) to + define a individual instances of the . + instances can then be registered with the + via the %IScheduler.ScheduleJob(JobDetail, + Trigger)% or %IScheduler.AddJob(JobDetail, bool)% method. + + + s can then be defined to fire individual + instances based on given schedules. + s are most useful for one-time firings, or + firing at an exact moment in time, with N repeats with a given delay between + them. s allow scheduling based on time of day, + day of week, day of month, and month of year. + + + s and s have a name and + group associated with them, which should uniquely identify them within a single + . The 'group' feature may be useful for creating + logical groupings or categorizations of s and + s. If you don't have need for assigning a group to a + given s of s, then you can use + the constant defined on + this interface. + + + Stored s can also be 'manually' triggered through the + use of the %IScheduler.TriggerJob(string, string)% function. + + + Client programs may also be interested in the 'listener' interfaces that are + available from Quartz. The interface provides + notifications of executions. The + interface provides notifications of + firings. The + interface provides notifications of events and + errors. Listeners can be associated with local schedulers through the + interface. + + + The setup/configuration of a instance is very + customizable. Please consult the documentation distributed with Quartz. + + + + + + + + + Marko Lahma (.NET) + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Get a object describing the settings + and capabilities of the scheduler instance. + + + Note that the data returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the meta data values may be different. + + + + + Return a list of objects that + represent all currently executing Jobs in this Scheduler instance. + + + + This method is not cluster aware. That is, it will only return Jobs + currently executing in this Scheduler instance, not across the entire + cluster. + + + Note that the list returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the true list of executing jobs may be different. + Also please read the doc associated with - + especially if you're using remoting. + + + + + + + Get the names of all known groups. + + + + + Get the names of all known groups. + + + + + Get the names of all groups that are paused. + + + + + Starts the 's threads that fire s. + When a scheduler is first created it is in "stand-by" mode, and will not + fire triggers. The scheduler can also be put into stand-by mode by + calling the method. + + + The misfire/recovery process will be started, if it is the initial call + to this method on this scheduler instance. + + + + + + + + Calls after the indicated delay. + (This call does not block). This can be useful within applications that + have initializers that create the scheduler immediately, before the + resources needed by the executing jobs have been fully initialized. + + + + + + + + Temporarily halts the 's firing of s. + + + + When is called (to bring the scheduler out of + stand-by mode), trigger misfire instructions will NOT be applied + during the execution of the method - any misfires + will be detected immediately afterward (by the 's + normal process). + + + The scheduler is not destroyed, and can be re-started at any time. + + + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the Scheduler. Equivalent to + . + + + The scheduler cannot be re-started. + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the Scheduler. + + + The scheduler cannot be re-started. + + + if the scheduler will not allow this method + to return until all currently executing jobs have completed. + + + + + + Add the given to the + Scheduler, and associate the given with + it. + + + If the given Trigger does not reference any , then it + will be set to reference the Job passed with it into this method. + + + + + Schedule the given with the + identified by the 's settings. + + + + + Schedule all of the given jobs with the related set of triggers. + + + If any of the given jobs or triggers already exist (or more + specifically, if the keys are not unique) and the replace + parameter is not set to true then an exception will be thrown. + + + + + Remove the indicated from the scheduler. + If the related job does not have any other triggers, and the job is + not durable, then the job will also be deleted. + + + + + Remove all of the indicated s from the scheduler. + + + If the related job does not have any other triggers, and the job is + not durable, then the job will also be deleted. + Note that while this bulk operation is likely more efficient than + invoking several + times, it may have the adverse affect of holding data locks for a + single long duration of time (rather than lots of small durations + of time). + + + + + Remove (delete) the with the + given key, and store the new given one - which must be associated + with the same job (the new trigger must have the job name & group specified) + - however, the new trigger need not have the same name as the old trigger. + + The to be replaced. + + The new to be stored. + + + if a with the given + name and group was not found and removed from the store (and the + new trigger is therefore not stored), otherwise + the first fire time of the newly scheduled trigger. + + + + + Add the given to the Scheduler - with no associated + . The will be 'dormant' until + it is scheduled with a , or + is called for it. + + + The must by definition be 'durable', if it is not, + SchedulerException will be thrown. + + + + + Delete the identified from the Scheduler - and any + associated s. + + true if the Job was found and deleted. + + + + Delete the identified jobs from the Scheduler - and any + associated s. + + + Note that while this bulk operation is likely more efficient than + invoking several + times, it may have the adverse affect of holding data locks for a + single long duration of time (rather than lots of small durations + of time). + + + true if all of the Jobs were found and deleted, false if + one or more were not deleted. + + + + + Trigger the identified + (Execute it now). + + + + + Trigger the identified (Execute it now). + + + the (possibly ) JobDataMap to be + associated with the trigger that fires the job immediately. + + + The of the to be executed. + + + + + Pause the with the given + key - by pausing all of its current s. + + + + + Pause all of the s in the + matching groups - by pausing all of their s. + + + + The Scheduler will "remember" that the groups are paused, and impose the + pause on any new jobs that are added to any of those groups until it is resumed. + + NOTE: There is a limitation that only exactly matched groups + can be remembered as paused. For example, if there are pre-existing + job in groups "aaa" and "bbb" and a matcher is given to pause + groups that start with "a" then the group "aaa" will be remembered + as paused and any subsequently added jobs in group "aaa" will be paused, + however if a job is added to group "axx" it will not be paused, + as "axx" wasn't known at the time the "group starts with a" matcher + was applied. HOWEVER, if there are pre-existing groups "aaa" and + "bbb" and a matcher is given to pause the group "axx" (with a + group equals matcher) then no jobs will be paused, but it will be + remembered that group "axx" is paused and later when a job is added + in that group, it will become paused. + + + + + + Pause the with the given key. + + + + + Pause all of the s in the groups matching. + + + + The Scheduler will "remember" all the groups paused, and impose the + pause on any new triggers that are added to any of those groups until it is resumed. + + NOTE: There is a limitation that only exactly matched groups + can be remembered as paused. For example, if there are pre-existing + triggers in groups "aaa" and "bbb" and a matcher is given to pause + groups that start with "a" then the group "aaa" will be remembered as + paused and any subsequently added triggers in that group be paused, + however if a trigger is added to group "axx" it will not be paused, + as "axx" wasn't known at the time the "group starts with a" matcher + was applied. HOWEVER, if there are pre-existing groups "aaa" and + "bbb" and a matcher is given to pause the group "axx" (with a + group equals matcher) then no triggers will be paused, but it will be + remembered that group "axx" is paused and later when a trigger is added + in that group, it will become paused. + + + + + + Resume (un-pause) the with + the given key. + + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + Resume (un-pause) all of the s + in matching groups. + + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Resume (un-pause) the with the given + key. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + Resume (un-pause) all of the s in matching groups. + + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Pause all triggers - similar to calling + on every group, however, after using this method + must be called to clear the scheduler's state of 'remembering' that all + new triggers will be paused as they are added. + + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + + Resume (un-pause) all triggers - similar to calling + on every group. + + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Get the keys of all the s in the matching groups. + + + + + Get all s that are associated with the + identified . + + + The returned Trigger objects will be snap-shots of the actual stored + triggers. If you wish to modify a trigger, you must re-store the + trigger afterward (e.g. see ). + + + + + Get the names of all the s in the given + groups. + + + + + Get the for the + instance with the given key . + + + The returned JobDetail object will be a snap-shot of the actual stored + JobDetail. If you wish to modify the JobDetail, you must re-store the + JobDetail afterward (e.g. see ). + + + + + Get the instance with the given key. + + + The returned Trigger object will be a snap-shot of the actual stored + trigger. If you wish to modify the trigger, you must re-store the + trigger afterward (e.g. see ). + + + + + Get the current state of the identified . + + + + + + + + + + + Add (register) the given to the Scheduler. + + Name of the calendar. + The calendar. + if set to true [replace]. + whether or not to update existing triggers that + referenced the already existing calendar so that they are 'correct' + based on the new trigger. + + + + Delete the identified from the Scheduler. + + + If removal of the Calendar would result in + s pointing to non-existent calendars, then a + will be thrown. + + Name of the calendar. + true if the Calendar was found and deleted. + + + + Get the instance with the given name. + + + + + Get the names of all registered . + + + + + Request the interruption, within this Scheduler instance, of all + currently executing instances of the identified , which + must be an implementor of the interface. + + + + If more than one instance of the identified job is currently executing, + the method will be called on + each instance. However, there is a limitation that in the case that + on one instances throws an exception, all + remaining instances (that have not yet been interrupted) will not have + their method called. + + + + If you wish to interrupt a specific instance of a job (when more than + one is executing) you can do so by calling + to obtain a handle + to the job instance, and then invoke on it + yourself. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + + true is at least one instance of the identified job was found and interrupted. + + + + + + + Request the interruption, within this Scheduler instance, of the + identified executing job instance, which + must be an implementor of the interface. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + + + + + the unique identifier of the job instance to be interrupted (see + + + true if the identified job instance was found and interrupted. + + + + Determine whether a with the given identifier already + exists within the scheduler. + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + the identifier to check for + true if a Trigger exists with the given identifier + + + + Clears (deletes!) all scheduling data - all s, s + s. + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Reports whether the is in stand-by mode. + + + + + + + Reports whether the has been Shutdown. + + + + + Set the that will be responsible for producing + instances of classes. + + + JobFactories may be of use to those wishing to have their application + produce instances via some special mechanism, such as to + give the opportunity for dependency injection. + + + + + + Get a reference to the scheduler's , + through which listeners may be registered. + + the scheduler's + + + + + + + + Whether the scheduler has been started. + + + Note: This only reflects whether has ever + been called on this Scheduler, so it will return even + if the is currently in standby mode or has been + since shutdown. + + + + + + + + Construct a instance to proxy the given + RemoteableQuartzScheduler instance. + + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Get a object describiing the settings + and capabilities of the scheduler instance. + + Note that the data returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the meta data values may be different. + + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Get the names of all groups that are paused. + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Get the names of all registered . + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Set the that will be responsible for producing + instances of classes. + + JobFactories may be of use to those wishing to have their application + produce instances via some special mechanism, such as to + give the opertunity for dependency injection. + + + + + SchedulerException + + + + Whether the scheduler has been started. + + + + Note: This only reflects whether has ever + been called on this Scheduler, so it will return even + if the is currently in standby mode or has been + since shutdown. + + + + + + + + This utility calls methods reflectively on the given objects even though the + methods are likely on a proper interface (ThreadPool, JobStore, etc). The + motivation is to be tolerant of older implementations that have not been + updated for the changes in the interfaces (eg. LocalTaskExecutorThreadPool in + spring quartz helpers) + + teck + Marko Lahma (.NET) + + + + Holds references to Scheduler instances - ensuring uniqueness, and + preventing garbage collection, and allowing 'global' lookups. + + James House + Marko Lahma (.NET) + + + + Binds the specified sched. + + The sched. + + + + Removes the specified sched name. + + Name of the sched. + + + + + Lookups the specified sched name. + + Name of the sched. + + + + + Lookups all. + + + + + + Gets the singleton instance. + + The instance. + + + + Responsible for creating the instances of + to be used within the instance. + + James House + Marko Lahma (.NET) + + + + Initialize the factory, providing a handle to the + that should be made available within the and + the s within it. + + + + + Called by the to obtain instances of + . + + + + + An implementation of the interface that directly + proxies all method calls to the equivalent call on a given + instance. + + + + James House + Marko Lahma (.NET) + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Get a object describiing the settings + and capabilities of the scheduler instance. + + Note that the data returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the meta data values may be different. + + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Construct a instance to proxy the given + instance. + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Get the names of all registered . + + + + + + Request the interruption, within this Scheduler instance, of all + currently executing instances of the identified , which + must be an implementor of the interface. + + + + If more than one instance of the identified job is currently executing, + the method will be called on + each instance. However, there is a limitation that in the case that + on one instances throws an exception, all + remaining instances (that have not yet been interrupted) will not have + their method called. + + + If you wish to interrupt a specific instance of a job (when more than + one is executing) you can do so by calling + to obtain a handle + to the job instance, and then invoke on it + yourself. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + true is at least one instance of the identified job was found and interrupted. + UnableToInterruptJobException if the job does not implement + + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Whether the scheduler has been started. + + + + Note: This only reflects whether has ever + been called on this Scheduler, so it will return even + if the is currently in standby mode or has been + since shutdown. + + + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + + + + + An implementation of that + does all of it's work of creating a instance + based on the contents of a properties file. + + + + By default a properties are loaded from App.config's quartz section. + If that fails, then the file is loaded "quartz.properties". If file does not exist, + default configration located (as a embedded resource) in Quartz.dll is loaded. If you + wish to use a file other than these defaults, you must define the system + property 'quartz.properties' to point to the file you want. + + + See the sample properties that are distributed with Quartz for + information about the various settings available within the file. + + + Alternativly, you can explicitly Initialize the factory by calling one of + the methods before calling . + + + Instances of the specified , + , classes will be created + by name, and then any additional properties specified for them in the config + file will be set on the instance by calling an equivalent 'set' method. For + example if the properties file contains the property 'quartz.jobStore. + myProp = 10' then after the JobStore class has been instantiated, the property + 'MyProp' will be set with the value. Type conversion to primitive CLR types + (int, long, float, double, boolean, enum and string) are performed before calling + the property's setter method. + + + James House + Anthony Eden + Mohammad Rezaei + Marko Lahma (.NET) + + + + Returns a handle to the default Scheduler, creating it if it does not + yet exist. + + + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The props. + + + + Initialize the . + + + By default a properties file named "quartz.properties" is loaded from + the 'current working directory'. If that fails, then the + "quartz.properties" file located (as an embedded resource) in the Quartz.NET + assembly is loaded. If you wish to use a file other than these defaults, + you must define the system property 'quartz.properties' to point to + the file you want. + + + + + Creates a new name value collection and overrides its values + with system values (environment variables). + + The base properties to override. + A new NameValueCollection instance. + + + + Initialize the with + the contents of the given key value collection object. + + + + + + + + Needed while loadhelper is not constructed. + + + + + + + Returns a handle to the Scheduler produced by this factory. + + + If one of the methods has not be previously + called, then the default (no-arg) method + will be called by this method. + + + + + Returns a handle to the Scheduler with the given name, if it exists (if + it has already been instantiated). + + + + + + Returns a handle to all known Schedulers (made by any + StdSchedulerFactory instance.). + + + + + + Inspects a directory and compares whether any files' "last modified dates" + have changed since the last time it was inspected. If one or more files + have been updated (or created), the job invokes a "call-back" method on an + identified that can be found in the + . + + pl47ypus + James House + Marko Lahma (.NET) + + + + + The interface to be implemented by classes which represent a 'job' to be + performed. + + + Instances of this interface must have a + no-argument constructor. provides a mechanism for 'instance member data' + that may be required by some implementations of this interface. + + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + fires that is associated with the . + + + The implementation may wish to set a result object on the + JobExecutionContext before this method exits. The result itself + is meaningless to Quartz, but may be informative to + s or + s that are watching the job's + execution. + + The execution context. + + + key with which to specify the directory to be + monitored - an absolute path is recommended. + + + key with which to specify the + to be + notified when the directory contents change. + + + key with which to specify a + value that represents the minimum number of milliseconds that must have + passed since the file's last modified time in order to consider the file + new/altered. This is necessary because another process may still be + in the middle of writing to the file when the scan occurs, and the + file may therefore not yet be ready for processing. + If this parameter is not specified, a default value of 5000 (five seconds) will be used. + + + + This is the main entry point for job execution. The scheduler will call this method on the + job once it is triggered. + + The that + the job will use during execution. + + + + Inspects a file and compares whether it's "last modified date" has changed + since the last time it was inspected. If the file has been updated, the + job invokes a "call-back" method on an identified + that can be found in the + . + + James House + Marko Lahma (.NET) + + + + + JobDataMap key with which to specify the name of the file to monitor. + + + + + JobDataMap key with which to specify the + to be notified when the file contents change. + + + + + key with which to specify a long + value that represents the minimum number of milliseconds that must have + past since the file's last modified time in order to consider the file + new/altered. This is necessary because another process may still be + in the middle of writing to the file when the scan occurs, and the + file may therefore not yet be ready for processing. + + If this parameter is not specified, a default value of + 5000 (five seconds) will be used. + + + + + Initializes a new instance of the class. + + + + + Called by the when a + fires that is associated with the . + + The implementation may wish to set a result object on the + JobExecutionContext before this method exits. The result itself + is meaningless to Quartz, but may be informative to + s or + s that are watching the job's + execution. + + + The execution context. + + + + + + Gets the last modified date. + + Name of the file. + + + + + Gets the log. + + The log. + + + Interface for objects wishing to receive a 'call-back' from a + Instances should be stored in the such that the + can find it. + James House + Marko Lahma (.NET) + + + An array of objects that were updated/added + since the last scan of the directory + + + + Interface for objects wishing to receive a 'call-back' from a + . + + James House + Marko Lahma (.NET) + + + + + Ãnforms that certain file has been updated. + + Name of the file. + + + + Built in job for executing native executables in a separate process. + + + + JobDetail job = new JobDetail("dumbJob", null, typeof(Quartz.Jobs.NativeJob)); + job.JobDataMap.Put(Quartz.Jobs.NativeJob.PropertyCommand, "echo \"hi\" >> foobar.txt"); + Trigger trigger = TriggerUtils.MakeSecondlyTrigger(5); + trigger.Name = "dumbTrigger"; + sched.ScheduleJob(job, trigger); + + If PropertyWaitForProcess is true, then the integer exit value of the process + will be saved as the job execution result in the JobExecutionContext. + + Matthew Payne + James House + Steinar Overbeck Cook + Marko Lahma (.NET) + + + + Required parameter that specifies the name of the command (executable) + to be ran. + + + + + Optional parameter that specifies the parameters to be passed to the + executed command. + + + + + Optional parameter (value should be 'true' or 'false') that specifies + whether the job should wait for the execution of the native process to + complete before it completes. + + Defaults to . + + + + + Optional parameter (value should be 'true' or 'false') that specifies + whether the spawned process's stdout and stderr streams should be + consumed. If the process creates output, it is possible that it might + 'hang' if the streams are not consumed. + + Defaults to . + + + + + Optional parameter that specifies the workling directory to be used by + the executed command. + + + + + Initializes a new instance of the class. + + + + + Called by the when a + fires that is associated with the . + + The implementation may wish to set a result object on the + JobExecutionContext before this method exits. The result itself + is meaningless to Quartz, but may be informative to + s or + s that are watching the job's + execution. + + + + + + + Gets the log. + + The log. + + + + Consumes data from the given input stream until EOF and prints the data to stdout + + cooste + James House + + + + Initializes a new instance of the class. + + The enclosing instance. + The input stream. + The type. + + + + Runs this object as a separate thread, printing the contents of the input stream + supplied during instantiation, to either Console. or stderr + + + + + An implementation of Job, that does absolutely nothing - useful for system + which only wish to use s + and s, rather than writing + Jobs that perform work. + + James House + Marko Lahma (.NET) + + + + Do nothing. + + + + + A Job which sends an e-mail with the configured content to the configured + recipient. + + James House + Marko Lahma (.NET) + + + The host name of the smtp server. REQUIRED. + + + The e-mail address to send the mail to. REQUIRED. + + + The e-mail address to cc the mail to. Optional. + + + The e-mail address to claim the mail is from. REQUIRED. + + + The e-mail address the message should say to reply to. Optional. + + + The subject to place on the e-mail. REQUIRED. + + + The e-mail message body. REQUIRED. + + + + Executes the job. + + The job execution context. + + + + Holds a List of references to JobListener instances and broadcasts all + events to them (in order). + + + The broadcasting behavior of this listener to delegate listeners may be + more convenient than registering all of the listeners directly with the + Scheduler, and provides the flexibility of easily changing which listeners + get notified. + + + + + James House (jhouse AT revolition DOT net) + + + + Construct an instance with the given name. + + + (Remember to add some delegate listeners!) + + the name of this instance + + + + Construct an instance with the given name, and List of listeners. + + + + the name of this instance + the initial List of JobListeners to broadcast to. + + + + Holds a List of references to SchedulerListener instances and broadcasts all + events to them (in order). + + + This may be more convenient than registering all of the listeners + directly with the Scheduler, and provides the flexibility of easily changing + which listeners get notified. + + + + James House + Marko Lahma (.NET) + + + + Construct an instance with the given List of listeners. + + The initial List of SchedulerListeners to broadcast to. + + + + Holds a List of references to TriggerListener instances and broadcasts all + events to them (in order). + + + The broadcasting behavior of this listener to delegate listeners may be + more convenient than registering all of the listeners directly with the + Scheduler, and provides the flexibility of easily changing which listeners + get notified. + + + + + James House (jhouse AT revolition DOT net) + + + + The interface to be implemented by classes that want to be informed when a + fires. In general, applications that use a + will not have use for this mechanism. + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called before the method of this + interface. + + + The that has fired. + + The that will be passed to the 's method. + + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called after the method of this + interface. If the implementation vetos the execution (via + returning ), the job's execute method will not be called. + + + The that has fired. + The that will be passed to + the 's method. + Returns true if job execution should be vetoed, false otherwise. + + + + Called by the when a + has misfired. + + Consideration should be given to how much time is spent in this method, + as it will affect all triggers that are misfiring. If you have lots + of triggers misfiring at once, it could be an issue it this method + does a lot. + + + The that has misfired. + + + + Called by the when a + has fired, it's associated + has been executed, and it's method has been + called. + + The that was fired. + + The that was passed to the + 's method. + + + The result of the call on the 's method. + + + + + Get the name of the . + + + + + Construct an instance with the given name. + + + (Remember to add some delegate listeners!) + + the name of this instance + + + + Construct an instance with the given name, and List of listeners. + + + + the name of this instance + the initial List of TriggerListeners to broadcast to. + + + + Keeps a collection of mappings of which Job to trigger after the completion + of a given job. If this listener is notified of a job completing that has a + mapping, then it will then attempt to trigger the follow-up job. This + achieves "job chaining", or a "poor man's workflow". + + + + Generally an instance of this listener would be registered as a global + job listener, rather than being registered directly to a given job. + + + If for some reason there is a failure creating the trigger for the + follow-up job (which would generally only be caused by a rare serious + failure in the system, or the non-existence of the follow-up job), an error + messsage is logged, but no other action is taken. If you need more rigorous + handling of the error, consider scheduling the triggering of the flow-up + job within your job itself. + + + James House + Marko Lahma (.NET) + + + + A helpful abstract base class for implementors of . + + + + The methods in this class are empty so you only need to override the + subset for the events you care about. + + + + You are required to implement + to return the unique name of your . + + + Marko Lahma (.NET) + + + + + Initializes a new instance of the class. + + + + + Called by the when a + is about to be executed (an associated + has occured). + + This method will not be invoked if the execution of the Job was vetoed + by a . + + + + + + + + Called by the when a + was about to be executed (an associated + has occured), but a vetoed it's + execution. + + + + + + + Called by the after a + has been executed, and be for the associated 's + method has been called. + + + + + + + Get the for this class's category. + This should be used by subclasses for logging. + + + + + Get the name of the . + + + + + + Construct an instance with the given name. + + The name of this instance. + + + + Add a chain mapping - when the Job identified by the first key completes + the job identified by the second key will be triggered. + + a JobKey with the name and group of the first job + a JobKey with the name and group of the follow-up job + + + + A helpful abstract base class for implementors of + . + + + + The methods in this class are empty so you only need to override the + subset for the events + you care about. + + + + You are required to implement + to return the unique name of your . + + + Marko Lahma (.NET) + + + + + Get the for this + class's category. This should be used by subclasses for logging. + + + + + Get the name of the . + + + + + + Logs a history of all job executions (and execution vetos) via common + logging. + + + + The logged message is customizable by setting one of the following message + properties to a string that conforms to the syntax of . + + + JobToBeFiredMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
+ The default message text is "Job {1}.{0} fired (by trigger {4}.{3}) at: + {2, date, HH:mm:ss MM/dd/yyyy" +
+ + JobSuccessMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
8ObjectThe string value (toString() having been called) of the result (if any) + that the Job set on the JobExecutionContext, with on it. "NULL" if no + result was set.
+ The default message text is "Job {1}.{0} execution complete at {2, date, + HH:mm:ss MM/dd/yyyy} and reports: {8" +
+ + JobFailedMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
8StringThe message from the thrown JobExecution Exception. +
+ The default message text is "Job {1}.{0} execution failed at {2, date, + HH:mm:ss MM/dd/yyyy} and reports: {8" +
+ + JobWasVetoedMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
+ The default message text is "Job {1}.{0} was vetoed. It was to be fired + (by trigger {4}.{3}) at: {2, date, HH:mm:ss MM/dd/yyyy" +
+
+ Marko Lahma (.NET) +
+ + + Provides an interface for a class to become a "plugin" to Quartz. + + + Plugins can do virtually anything you wish, though the most interesting ones + will obviously interact with the scheduler in some way - either actively: by + invoking actions on the scheduler, or passively: by being a , + , and/or . + + If you use to + Initialize your Scheduler, it can also create and Initialize your plugins - + look at the configuration docs for details. + + + If you need direct access your plugin, you can have it explicitly put a + reference to itself in the 's + as part of its + method. + + + James House + Marko Lahma (.NET) + + + + Called during creation of the in order to give + the a chance to Initialize. + + + At this point, the Scheduler's is not yet + + If you need direct access your plugin, you can have it explicitly put a + reference to itself in the 's + as part of its + method. + + + + The name by which the plugin is identified. + + + The scheduler to which the plugin is registered. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Called during creation of the in order to give + the a chance to Initialize. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Called by the when a is + about to be executed (an associated has occurred). + + This method will not be invoked if the execution of the Job was vetoed by a + . + + + + + + + Called by the after a + has been executed, and be for the associated 's + method has been called. + + + + + + + Called by the when a + was about to be executed (an associated + has occured), but a vetoed it's + execution. + + + + + + + Logger instance to use. Defaults to common logging. + + + + + Get or sets the message that is logged when a Job successfully completes its + execution. + + + + + Get or sets the message that is logged when a Job fails its + execution. + + + + + Gets or sets the message that is logged when a Job is about to Execute. + + + + + Gets or sets the message that is logged when a Job execution is vetoed by a + trigger listener. + + + + + Get the name of the . + + + + + + Logs a history of all trigger firings via the Jakarta Commons-Logging + framework. + + + + The logged message is customizable by setting one of the following message + properties to a string that conforms to the syntax of . + + + + TriggerFiredMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Trigger's Name.
1StringThe Trigger's Group.
2DateThe scheduled fire time.
3DateThe next scheduled fire time.
4DateThe actual fire time.
5StringThe Job's name.
6StringThe Job's group.
7IntegerThe re-fire count from the JobExecutionContext.
+ + The default message text is "Trigger {1}.{0} fired job {6}.{5} at: {4, + date, HH:mm:ss MM/dd/yyyy" +
+ + + TriggerMisfiredMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Trigger's Name.
1StringThe Trigger's Group.
2DateThe scheduled fire time.
3DateThe next scheduled fire time.
4DateThe actual fire time. (the time the misfire was detected/handled)
5StringThe Job's name.
6StringThe Job's group.
+ + The default message text is "Trigger {1}.{0} misfired job {6}.{5} at: + {4, date, HH:mm:ss MM/dd/yyyy}. Should have fired at: {3, date, HH:mm:ss + MM/dd/yyyy" +
+ + + TriggerCompleteMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Trigger's Name.
1StringThe Trigger's Group.
2DateThe scheduled fire time.
3DateThe next scheduled fire time.
4DateThe job completion time.
5StringThe Job's name.
6StringThe Job's group.
7IntegerThe re-fire count from the JobExecutionContext.
8IntegerThe trigger's resulting instruction code.
9StringA human-readable translation of the trigger's resulting instruction + code.
+ + The default message text is "Trigger {1}.{0} completed firing job + {6}.{5} at {4, date, HH:mm:ss MM/dd/yyyy} with resulting trigger instruction + code: {9" +
+
+ James House + Marko Lahma (.NET) +
+ + + Called during creation of the in order to give + the a chance to Initialize. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called before the method of this + interface. + + + The that has fired. + The that will be passed to the 's method. + + + + Called by the when a + has misfired. + + Consideration should be given to how much time is spent in this method, + as it will affect all triggers that are misfiring. If you have lots + of triggers misfiring at once, it could be an issue it this method + does a lot. + + + The that has misfired. + + + + Called by the when a + has fired, it's associated + has been executed, and it's method has been + called. + + The that was fired. + The that was passed to the + 's method. + The result of the call on the 's method. + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called after the method of this + interface. + + + The that has fired. + The that will be passed to + the 's method. + + + + + Logger instance to use. Defaults to common logging. + + + + + Get or set the message that is printed upon the completion of a trigger's + firing. + + + + + Get or set the message that is printed upon a trigger's firing. + + + + + Get or set the message that is printed upon a trigger's mis-firing. + + + + + Get the name of the . + + + + + + This plugin catches the event of the VM terminating (such as upon a CRTL-C) + and tells the scheuler to Shutdown. + + + James House + Marko Lahma (.NET) + + + + Called during creation of the in order to give + the a chance to Initialize. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Determine whether or not the plug-in is configured to cause a clean + Shutdown of the scheduler. + + The default value is . + + + + + + + This plugin loads XML file(s) to add jobs and schedule them with triggers + as the scheduler is initialized, and can optionally periodically scan the + file for changes. + + + The periodically scanning of files for changes is not currently supported in a + clustered environment. + + James House + Pierre Awaragi + + + + Initializes a new instance of the class. + + + + + + + + + + + Called during creation of the in order to give + the a chance to initialize. + + The name. + The scheduler. + SchedulerConfigException + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Helper method for generating unique job/trigger name for the + file scanning jobs (one per FileJob). The unique names are saved + in jobTriggerNameSet. + + + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Gets the log. + + The log. + + + + Comma separated list of file names (with paths) to the XML files that should be read. + + + + + The interval at which to scan for changes to the file. + If the file has been changed, it is re-loaded and parsed. The default + value for the interval is 0, which disables scanning. + + + + + Whether or not initialization of the plugin should fail (throw an + exception) if the file cannot be found. Default is . + + + + + Information about a file that should be processed by . + + + + + Default object serialization strategy that uses + under the hood. + + Marko Lahma + + + + Interface for object serializers. + + Marko Lahma + + + + + Serializes given object as bytes + that can be stored to permanent stores. + + Object to serialize, always non-null. + + + + Deserializes object from byte array presentation. + + Data to deserialize object from, always non-null and non-empty. + + + + Serializes given object as bytes + that can be stored to permanent stores. + + Object to serialize. + + + + Deserializes object from byte array presentation. + + Data to deserialize object from. + + + + that names the scheduler instance using + just the machine hostname. + + + This class is useful when you know that your scheduler instance will be the + only one running on a particular machine. Each time the scheduler is + restarted, it will get the same instance id as long as the machine is not + renamed. + + Marko Lahma (.NET) + + + + + + An IInstanceIdGenerator is responsible for generating the clusterwide unique + instance id for a node. + + + This interface may be of use to those wishing to have specific control over + the mechanism by which the instances in their + application are named. + + + Marko Lahma (.NET) + + + + Generate the instance id for a + + The clusterwide unique instance id. + + + + + Generate the instance id for a + + The clusterwide unique instance id. + + + + A JobFactory that instantiates the Job instance (using the default no-arg + constructor, or more specifically: ), and + then attempts to set all values from the and + the 's merged onto + properties of the job. + + + Set the WarnIfPropertyNotFound property to true if you'd like noisy logging in + the case of values in the not mapping to properties on your job + class. This may be useful for troubleshooting typos of property names, etc. + but very noisy if you regularly (and purposely) have extra things in your + . + Also of possible interest is the ThrowIfPropertyNotFound property which + will throw exceptions on unmatched JobDataMap keys. + + + + + + + + James Houser + Marko Lahma (.NET) + + + + The default JobFactory used by Quartz - simply calls + on the job class. + + + + James House + Marko Lahma (.NET) + + + + A JobFactory is responsible for producing instances of + classes. + + + This interface may be of use to those wishing to have their application + produce instances via some special mechanism, such as to + give the opertunity for dependency injection. + + + + + James House + Marko Lahma (.NET) + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + + a handle to the scheduler that is about to execute the job + SchedulerException if there is a problem instantiating the Job. + the newly instantiated Job + + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + + the newly instantiated Job + SchedulerException if there is a problem instantiating the Job. + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + + the newly instantiated Job + SchedulerException if there is a problem instantiating the Job. + + + + Sets the object properties. + + The object to set properties to. + The data to set. + + + + Whether the JobInstantiation should fail and throw and exception if + a key (name) and value (type) found in the JobDataMap does not + correspond to a proptery setter on the Job class. + + + + + Get or set whether a warning should be logged if + a key (name) and value (type) found in the JobDataMap does not + correspond to a proptery setter on the Job class. + + + + + This class implements a that + utilizes RAM as its storage device. + + As you should know, the ramification of this is that access is extrememly + fast, but the data is completely volatile - therefore this + should not be used if true persistence between program shutdowns is + required. + + + James House + Sharada Jambula + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Gets the fired trigger record id. + + The fired trigger record id. + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Called by the QuartzScheduler to inform the that + the scheduler has started. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has been paused. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has resumed after being paused. + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Clears (deletes!) all scheduling data - all s, s + s. + + + + + Store the given and . + + The to be stored. + The to be stored. + + + + Returns true if the given job group is paused. + + Job group name + + + + + returns true if the given TriggerGroup is paused. + + + + + + + Store the given . + + The to be stored. + If , any existing in the + with the same name and group should be + over-written. + + + + Remove (delete) the with the given + name, and any s that reference + it. + + + if a with the given name and + group was found and removed from the store. + + + + + Remove (delete) the with the + given name. + + + if a with the given + name and group was found and removed from the store. + + + + + Store the given . + + The to be stored. + If , any existing in + the with the same name and group should + be over-written. + + + + Remove (delete) the with the + given name. + + + + if a with the given + name and group was found and removed from the store. + + The to be removed. + Whether to delete orpahaned job details from scheduler if job becomes orphaned from removing the trigger. + + + + Replaces the trigger. + + The of the to be replaced. + The new trigger. + + + + + Retrieve the for the given + . + + + The desired , or null if there is no match. + + + + + Retrieve the given . + + + The desired , or null if there is no match. + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + triggerKey the identifier to check for + true if a Trigger exists with the given identifier + + + + Get the current state of the identified . + + + + + + + + + + + Store the given . + + The name. + The to be stored. + If , any existing + in the with the same name and group + should be over-written. + If , any s existing + in the that reference an existing + Calendar with the same name with have their next fire time + re-computed with the new . + + + + Remove (delete) the with the + given name. + + If removal of the would result in + s pointing to non-existent calendars, then a + will be thrown. + + The name of the to be removed. + + if a with the given name + was found and removed from the store. + + + + + Retrieve the given . + + The name of the to be retrieved. + + The desired , or null if there is no match. + + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the names of all of the s that + match the given group matcher. + + + + + Get the names of all of the s + in the . + + If there are no ICalendars in the given group name, the result should be + a zero-length array (not ). + + + + + + Get the names of all of the s + that have the given group name. + + + + + Get the names of all of the + groups. + + + + + Get the names of all of the groups. + + + + + Get all of the Triggers that are associated to the given Job. + + If there are no matches, a zero-length array should be returned. + + + + + + Gets the trigger wrappers for job. + + + + + + Gets the trigger wrappers for calendar. + + Name of the cal. + + + + + Pause the with the given name. + + + + + Pause all of the s in the given group. + + The JobStore should "remember" that the group is paused, and impose the + pause on any new triggers that are added to the group while the group is + paused. + + + + + + Pause the with the given + name - by pausing all of its current s. + + + + + Pause all of the s in the + given group - by pausing all of their s. + + The JobStore should "remember" that the group is paused, and impose the + pause on any new jobs that are added to the group while the group is + paused. + + + + + + Resume (un-pause) the with the given key. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + Resume (un-pause) all of the s in the + given group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Resume (un-pause) the with + the given name. + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s + in the given group. + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + on every group. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every trigger group and setting all job groups unpaused />. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + Applies the misfire. + + The trigger wrapper. + + + + + Get a handle to the next trigger to be fired, and mark it as 'reserved' + by the calling scheduler. + + + + + + Inform the that the scheduler no longer plans to + fire the given , that it had previously acquired + (reserved). + + + + + Inform the that the scheduler is now firing the + given (executing its associated ), + that it had previously acquired (reserved). + + + + + Inform the that the scheduler has completed the + firing of the given (and the execution its + associated ), and that the + in the given should be updated if the + is stateful. + + + + + Sets the state of all triggers of job to specified state. + + + + + Peeks the triggers. + + + + + + + + + The time span by which a trigger must have missed its + next-fire-time, in order for it to be considered "misfired" and thus + have its misfire instruction applied. + + + + + Returns whether this instance supports persistence. + + + + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + Comparer for trigger wrappers. + + + + + Indicates whether the current object is equal to another object of the same type. + + + true if the current object is equal to the parameter; otherwise, false. + + An object to compare with this object. + + + + Serves as a hash function for a particular type. + + + A hash code for the current . + + 2 + + + + Possible internal trigger states + in RAMJobStore + + + + + Waiting + + + + + Acquired + + + + + Executing + + + + + Complete + + + + + Paused + + + + + Blocked + + + + + Paused and Blocked + + + + + Error + + + + + Helper wrapper class + + + + + The key used + + + + + Job's key + + + + + The trigger + + + + + Current state + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + true if the specified is equal to the current ; otherwise, false. + + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Scheduler exporter that exports scheduler to remoting context. + + Marko Lahma + + + + Service interface for scheduler exporters. + + Marko Lahma + + + + Binds (exports) scheduler to external context. + + + + + + Unbinds scheduler from external context. + + + + + + Registers remoting channel if needed. This is determined + by checking whether there is a positive value for port. + + + + + Gets or sets the port used for remoting. + + + + + Gets or sets the name to use when exporting + scheduler to remoting context. + + + + + Gets or sets the name to use when binding to + tcp channel. + + + + + Sets the channel type when registering remoting. + + + + + + Sets the used when + exporting to remoting context. Defaults to + . + + + + + A implementation that creates + connection to remote scheduler using remoting. + + + + + Client Proxy to a IRemotableQuartzScheduler + + + + + Returns a client proxy to a remote . + + + + + Returns a client proxy to a remote . + + + + + Gets or sets the remote scheduler address. + + The remote scheduler address. + + + + The default InstanceIdGenerator used by Quartz when instance id is to be + automatically generated. Instance id is of the form HOSTNAME + CURRENT_TIME. + + Marko Lahma (.NET) + + + + + + Generate the instance id for a + + The clusterwide unique instance id. + + + + This is class is a simple implementation of a thread pool, based on the + interface. + + + objects are sent to the pool with the + method, which blocks until a becomes available. + + The pool has a fixed number of s, and does not grow or + shrink based on demand. + + James House + Juergen Donnerstag + Marko Lahma (.NET) + + + + The interface to be implemented by classes that want to provide a thread + pool for the 's use. + + + implementation instances should ideally be made + for the sole use of Quartz. Most importantly, when the method + returns a value of 1 or greater, + there must still be at least one available thread in the pool when the + method is called a few moments (or + many moments) later. If this assumption does not hold true, it may + result in extra JobStore queries and updates, and if clustering features + are being used, it may result in greater imballance of load. + + + James House + Marko Lahma (.NET) + + + + Execute the given in the next + available . + + + The implementation of this interface should not throw exceptions unless + there is a serious problem (i.e. a serious misconfiguration). If there + are no available threads, rather it should either queue the Runnable, or + block until a thread is available, depending on the desired strategy. + + + + + Determines the number of threads that are currently available in in + the pool. Useful for determining the number of times + can be called before returning + false. + + + The implementation of this method should block until there is at + least one available thread. + + the number of currently available threads + + + + Must be called before the is + used, in order to give the it a chance to Initialize. + + + Typically called by the . + + + + + Called by the QuartzScheduler to inform the + that it should free up all of it's resources because the scheduler is + shutting down. + + + + + Get the current number of threads in the . + + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + Create a new (unconfigured) . + + + + + Create a new with the specified number + of s that have the given priority. + + + the number of worker s in the pool, must + be > 0. + + + the thread priority for the worker threads. + + + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Terminate any worker threads in this thread group. + Jobs currently in progress will complete. + + + + + Run the given object in the next available + . If while waiting the thread pool is asked to + shut down, the Runnable is executed immediately within a new additional + thread. + + The to be added. + + + + Creates the worker threads. + + The thread count. + + + + + Terminate any worker threads in this thread group. + Jobs currently in progress will complete. + + + + + Gets or sets the number of worker threads in the pool. + Set has no effect after has been called. + + + + + Get or set the thread priority of worker threads in the pool. + Set operation has no effect after has been called. + + + + + Gets or sets the thread name prefix. + + The thread name prefix. + + + + Gets or sets the value of makeThreadsDaemons. + + + + + Gets the size of the pool. + + The size of the pool. + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + A Worker loops, waiting to Execute tasks. + + + + + Create a worker thread and start it. Waiting for the next Runnable, + executing it, and waiting for the next Runnable, until the Shutdown + flag is set. + + + + + Create a worker thread, start it, Execute the runnable and terminate + the thread (one time execution). + + + + + Signal the thread that it should terminate. + + + + + Loop, executing targets as they are received. + + + + + A that simply calls . + + + James House + Marko Lahma (.NET) + + + + Called to give the ClassLoadHelper a chance to Initialize itself, + including the oportunity to "steal" the class loader off of the calling + thread, which is the thread that is initializing Quartz. + + + + Return the class with the given name. + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a Uri object + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a Stream object + + + + + InstanceIdGenerator that will use a to configure the scheduler. + If no value set for the property, a is thrown. + Alex Snaps + + + + + System property to read the instanceId from. + + + + + Returns the cluster wide value for this scheduler instance's id, based on a system property. + + + + + A string of text to prepend (add to the beginning) to the instanceId found in the system property. + + + + + A string of text to postpend (add to the end) to the instanceId found in the system property. + + + + + The name of the system property from which to obtain the instanceId. + + + Defaults to . + + + + + This is class is a simple implementation of a zero size thread pool, based on the + interface. + + + The pool has zero s and does not grow or shrink based on demand. + Which means it is obviously not useful for most scenarios. When it may be useful + is to prevent creating any worker threads at all - which may be desirable for + the sole purpose of preserving system resources in the case where the scheduler + instance only exists in order to schedule jobs, but which will never execute + jobs (e.g. will never have Start() called on it). + + Wayne Fay + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Shutdowns this instance. + + + + + Called by the QuartzScheduler to inform the + that it should free up all of it's resources because the scheduler is + shutting down. + + + + + + Execute the given in the next + available . + + + + + The implementation of this interface should not throw exceptions unless + there is a serious problem (i.e. a serious misconfiguration). If there + are no available threads, rather it should either queue the Runnable, or + block until a thread is available, depending on the desired strategy. + + + + + Determines the number of threads that are currently available in in + the pool. Useful for determining the number of times + can be called before returning + false. + + + the number of currently available threads + + + The implementation of this method should block until there is at + least one available thread. + + + + + Gets the log. + + The log. + + + + Gets the size of the pool. + + The size of the pool. + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + A simple class (structure) used for returning execution-time data from the + JobStore to the . + + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The job. + The trigger. + The calendar. + if set to true [job is recovering]. + The fire time. + The scheduled fire time. + The previous fire time. + The next fire time. + + + + Gets the job detail. + + The job detail. + + + + Gets the trigger. + + The trigger. + + + + Gets the calendar. + + The calendar. + + + + Gets a value indicating whether this is recovering. + + true if recovering; otherwise, false. + + + + Returns the UTC fire time. + + + + + Gets the next UTC fire time. + + The next fire time. + Returns the nextFireTimeUtc. + + + + Gets the previous UTC fire time. + + The previous fire time. + Returns the previous fire time. + + + + Returns the scheduled UTC fire time. + + + + + Result holder for trigger firing event. + + + + + Constructor. + + + + + + Constructor. + + + + + Bundle. + + + + + Possible exception. + + + + + Extension methods for . + + + + + Tries to read value and returns the value if successfully read. Otherwise return default value + for value's type. + + + + + + + + + + Extension methods for simplified access. + + + + + Returns string from given column name, or null if DbNull. + + + + + Returns int from given column name. + + + + + Returns long from given column name. + + + + + Returns long from given column name, or null if DbNull. + + + + + Returns decimal from given column name. + + + + + Manages a collection of IDbProviders, and provides transparent access + to their database. + + + James House + Sharada Jambula + Mohammad Rezaei + Marko Lahma (.NET) + + + + Private constructor + + + + + Adds the connection provider. + + Name of the data source. + The provider. + + + + Get a database connection from the DataSource with the given name. + + a database connection + + + + Shuts down database connections from the DataSource with the given name, + if applicable for the underlying provider. + + a database connection + + + + Gets the db provider. + + Name of the ds. + + + + + Get the class instance. + + an instance of this class + + + + + An implementation of that wraps another + and flags itself 'dirty' when it is modified. + + James House + Marko Lahma (.NET) + + + + Create a DirtyFlagMap that 'wraps' a . + + + + + Create a DirtyFlagMap that 'wraps' a that has the + given initial capacity. + + + + + Serialization constructor. + + + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + When implemented by a class, removes all elements from the . + + + The is read-only. + + + + + When implemented by a class, determines whether the contains an element with the specified key. + + The key to locate in the . + + if the contains an element with the key; otherwise, . + + + is . + + + + When implemented by a class, removes the element with the + specified key from the . + + The key of the element to remove. + + is . + + The is read-only. + -or- + The has a fixed size. + + + + + When implemented by a class, returns an + for the . + + + An for the . + + + + + When implemented by a class, adds an element with the provided key and value to the . + + The to use as the key of the element to add. + The to use as the value of the element to add. + is . + + An element with the same key already exists in the . + + + The is read-only. + -or- + The has a fixed size. + + + + + When implemented by a class, copies the elements of + the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in at which copying begins. + + is . + + is less than zero. + + + is multidimensional. + -or- + + is equal to or greater than the length of . + -or- + The number of elements in the source is greater than the available space from to the end of the destination . + + The type of the source cannot be cast automatically to the type of the destination . + + + + Clear the 'dirty' flag (set dirty flag to ). + + + + + Determines whether the specified obj contains value. + + The obj. + + true if the specified obj contains value; otherwise, false. + + + + + Gets the entries as a set. + + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + if the specified is equal to the + current ; otherwise, . + + + + + Serves as a hash function for a particular type, suitable + for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets keyset for this map. + + + + + + Puts the value behind a specified key. + + The key. + The val. + + + + + Puts all. + + The t. + + + + Determine whether the is flagged dirty. + + + + + Get a direct handle to the underlying Map. + + + + + Gets a value indicating whether this instance is empty. + + true if this instance is empty; otherwise, false. + + + + Gets or sets the with the specified key. + + + + + + When implemented by a class, gets the number of + elements contained in the . + + + + + + When implemented by a class, gets an containing the values in the . + + + + + + When implemented by a class, gets an containing the keys of the . + + + + + + When implemented by a class, gets a value indicating whether the + is read-only. + + + + + + When implemented by a class, gets a value indicating whether the + has a fixed size. + + + + + + When implemented by a class, gets an object that + can be used to synchronize access to the . + + + + + + When implemented by a class, gets a value + indicating whether access to the is synchronized + (thread-safe). + + + + + + Utility class for file handling related things. + + Marko Lahma + + + + Resolves file to actual file if for example relative '~' used. + + File name to check + Expanded file name or actual no resolving was done. + + + + Object representing a job or trigger key. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + The default group for scheduling entities, with the value "DEFAULT". + + + + + Construct a new key with the given name and group. + + the name + the group + + + + Return the string representation of the key. The format will be: + <group>.<name>. + + + + the string representation of the key + + + + + Get the name portion of the key. + + the name + + + + + Get the group portion of the key. + + + + the group + + + + + Wrapper class to access thread local data. + Data is either accessed from thread or HTTP Context's + data if HTTP Context is avaiable. + + Marko Lahma .NET + + + + Retrieves an object with the specified name. + + The name of the item. + The object in the call context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the call context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + + Generic extension methods for objects. + + + + + Creates a deep copy of object by serializing to memory stream. + + + + + + Utility methods that are used to convert objects from one type into another. + + Aleksandar Seovic + Marko Lahma + + + + Convert the value to the required (if necessary from a string). + + The proposed change value. + + The we must convert to. + + The new value, possibly the result of type conversion. + + + + Determines whether value is assignable to required type. + + The value to check. + Type of the required. + + true if value can be assigned as given type; otherwise, false. + + + + + Instantiates an instance of the type specified. + + + + + + Sets the object properties using reflection. + + + + + Sets the object properties using reflection. + + The object to set values to. + The properties to set to object. + + + + This is an utility class used to parse the properties. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The props. + + + + Gets the string property. + + The name. + + + + + Gets the string property. + + The name. + The default value. + + + + + Gets the string array property. + + The name. + + + + + Gets the string array property. + + The name. + The default value. + + + + + Gets the boolean property. + + The name. + + + + + Gets the boolean property. + + The name. + if set to true [defaultValue]. + + + + + Gets the byte property. + + The name. + + + + + Gets the byte property. + + The name. + The default value. + + + + + Gets the char property. + + The name. + + + + + Gets the char property. + + The name. + The default value. + + + + + Gets the double property. + + The name. + + + + + Gets the double property. + + The name. + The default value. + + + + + Gets the float property. + + The name. + + + + + Gets the float property. + + The name. + The default value. + + + + + Gets the int property. + + The name. + + + + + Gets the int property. + + The name. + The default value. + + + + + Gets the int array property. + + The name. + + + + + Gets the int array property. + + The name. + The default value. + + + + + Gets the long property. + + The name. + + + + + Gets the long property. + + The name. + The def. + + + + + Gets the TimeSpan property. + + The name. + The def. + + + + + Gets the short property. + + The name. + + + + + Gets the short property. + + The name. + The default value. + + + + + Gets the property groups. + + The prefix. + + + + + Gets the property group. + + The prefix. + + + + + Gets the property group. + + The prefix. + if set to true [strip prefix]. + + + + + Get all properties that start with the given prefix. + + The prefix for which to search. If it does not end in a "." then one will be added to it for search purposes. + Whether to strip off the given in the result's keys. + Optional array of fully qualified prefixes to exclude. For example if is "a.b.c", then might be "a.b.c.ignore". + Group of that start with the given prefix, optionally have that prefix removed, and do not include properties that start with one of the given excluded prefixes. + + + + Reads the properties from assembly (embedded resource). + + The file name to read resources from. + + + + + Reads the properties from file system. + + The file name to read resources from. + + + + + Gets the underlying properties. + + The underlying properties. + + + + Extension methods for . + + + + + Allows null-safe trimming of string. + + + + + + + Trims string and if resulting string is empty, null is returned. + + + + + + + An implementation of that wraps another + and flags itself 'dirty' when it is modified, enforces that all keys are + strings. + + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The initial capacity. + + + + Serialization constructor. + + + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + if the specified is equal to the + current ; otherwise, . + + + + + Serves as a hash function for a particular type, suitable + for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets the keys. + + + + + + Adds the name-value pairs in the given to the . + + All keys must be s, and all values must be serializable. + + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Reports JobSchedulingDataProcessor validation exceptions. + + Chris Bonham + Marko Lahma (.NET) + + + + Constructor for ValidationException. + + + + + Constructor for ValidationException. + + exception message. + + + + Constructor for ValidationException. + + collection of validation exceptions. + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Gets the validation exceptions. + + The validation exceptions. + + + + Returns the detail message string. + + + + + Parses an XML file that declares Jobs and their schedules (Triggers). + + + + The xml document must conform to the format defined in "job_scheduling_data_2_0.xsd" + + + + After creating an instance of this class, you should call one of the + functions, after which you may call the ScheduledJobs() + function to get a handle to the defined Jobs and Triggers, which can then be + scheduled with the . Alternatively, you could call + the function to do all of this + in one step. + + + + The same instance can be used again and again, with the list of defined Jobs + being cleared each time you call a method, + however a single instance is not thread-safe. + + + Chris Bonham + James House + Marko Lahma (.NET) + + + + Constructor for XMLSchedulingDataProcessor. + + + + + Process the xml file in the default location (a file named + "quartz_jobs.xml" in the current working directory). + + + + + Process the xml file named . + + meta data file name. + + + + Process the xmlfile named with the given system + ID. + + Name of the file. + The system id. + + + + Process the xmlfile named with the given system + ID. + + The stream. + The system id. + + + + Process the xml file in the default location, and schedule all of the jobs defined within it. + + Note that we will set overWriteExistingJobs after the default xml is parsed. + + + + + + Process the xml file in the default location, and schedule all of the + jobs defined within it. + + + + + Process the xml file in the given location, and schedule all of the + jobs defined within it. + + meta data file name. + The scheduler. + + + + Process the xml file in the given location, and schedule all of the + jobs defined within it. + + Name of the file. + The system id. + The sched. + + + + Schedules the given sets of jobs and triggers. + + The sched. + + + + Adds a detected validation exception. + + The exception. + + + + Resets the the number of detected validation exceptions. + + + + + Throws a ValidationException if the number of validationExceptions + detected is greater than zero. + + + DTD validation exception. + + + + + Whether the existing scheduling data (with same identifiers) will be + overwritten. + + + If false, and is not false, and jobs or + triggers with the same names already exist as those in the file, an + error will occur. + + + + + + If true (and is false) then any + job/triggers encountered in this file that have names that already exist + in the scheduler will be ignored, and no error will be produced. + + + + + + Gets the log. + + The log. + + + + Helper class to map constant names to their values. + + + + + CalendarIntervalScheduleBuilder is a + that defines calendar time (day, week, month, year) interval-based + schedules for Triggers. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + JobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + Trigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + + Base class for implementors. + + + + + + Schedule builders offer fluent interface and are responsible for creating schedules. + + + + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Create a CalendarIntervalScheduleBuilder. + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Specify the time unit and interval for the Trigger to be produced. + + + + the interval at which the trigger should repeat. + the time unit (IntervalUnit) of the interval. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.SECOND that the produced + Trigger will repeat at. + + + + the number of seconds at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.MINUTE that the produced + Trigger will repeat at. + + + + the number of minutes at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.HOUR that the produced + Trigger will repeat at. + + + + the number of hours at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.DAY that the produced + Trigger will repeat at. + + + + the number of days at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.WEEK that the produced + Trigger will repeat at. + + + + the number of weeks at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.MONTH that the produced + Trigger will repeat at. + + + + the number of months at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.YEAR that the produced + Trigger will repeat at. + + + + the number of years at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CalendarIntervalScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CalendarIntervalScheduleBuilder + + + + + TimeZone in which to base the schedule. + + the time-zone for the schedule + the updated CalendarIntervalScheduleBuilder + + + + + If intervals are a day or greater, this property (set to true) will + cause the firing of the trigger to always occur at the same time of day, + (the time of day of the startTime) regardless of daylight saving time + transitions. Default value is false. + + + + For example, without the property set, your trigger may have a start + time of 9:00 am on March 1st, and a repeat interval of 2 days. But + after the daylight saving transition occurs, the trigger may start + firing at 8:00 am every other day. + + + If however, the time of day does not exist on a given day to fire + (e.g. 2:00 am in the United States on the days of daylight saving + transition), the trigger will go ahead and fire one hour off on + that day, and then resume the normal hour on other days. If + you wish for the trigger to never fire at the "wrong" hour, then + you should set the property skipDayIfHourDoesNotExist. + + + + + + + + + + If intervals are a day or greater, and + preserveHourOfDayAcrossDaylightSavings property is set to true, and the + hour of the day does not exist on a given day for which the trigger + would fire, the day will be skipped and the trigger advanced a second + interval if this property is set to true. Defaults to false. + + + CAUTION! If you enable this property, and your hour of day happens + to be that of daylight savings transition (e.g. 2:00 am in the United + States) and the trigger's interval would have had the trigger fire on + that day, then you may actually completely miss a firing on the day of + transition if that hour of day does not exist on that day! In such a + case the next fire time of the trigger will be computed as double (if + the interval is 2 days, then a span of 4 days between firings will + occur). + + + + + + Extension methods that attach to . + + + + + Provides a parser and evaluator for unix-like cron expressions. Cron + expressions provide the ability to specify complex time combinations such as + "At 8:00am every Monday through Friday" or "At 1:30am every + last Friday of the month". + + + + Cron expressions are comprised of 6 required fields and one optional field + separated by white space. The fields respectively are described as follows: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Field Name Allowed Values Allowed Special Characters
Seconds 0-59 , - /// /
Minutes 0-59 , - /// /
Hours 0-23 , - /// /
Day-of-month 1-31 , - /// ? / L W C
Month 1-12 or JAN-DEC , - /// /
Day-of-Week 1-7 or SUN-SAT , - /// ? / L #
Year (Optional) empty, 1970-2199 , - /// /
+ + The '*' character is used to specify all values. For example, "*" + in the minute field means "every minute". + + + The '?' character is allowed for the day-of-month and day-of-week fields. It + is used to specify 'no specific value'. This is useful when you need to + specify something in one of the two fields, but not the other. + + + The '-' character is used to specify ranges For example "10-12" in + the hour field means "the hours 10, 11 and 12". + + + The ',' character is used to specify additional values. For example + "MON,WED,FRI" in the day-of-week field means "the days Monday, + Wednesday, and Friday". + + + The '/' character is used to specify increments. For example "0/15" + in the seconds field means "the seconds 0, 15, 30, and 45". And + "5/15" in the seconds field means "the seconds 5, 20, 35, and + 50". Specifying '*' before the '/' is equivalent to specifying 0 is + the value to start with. Essentially, for each field in the expression, there + is a set of numbers that can be turned on or off. For seconds and minutes, + the numbers range from 0 to 59. For hours 0 to 23, for days of the month 0 to + 31, and for months 1 to 12. The "/" character simply helps you turn + on every "nth" value in the given set. Thus "7/6" in the + month field only turns on month "7", it does NOT mean every 6th + month, please note that subtlety. + + + The 'L' character is allowed for the day-of-month and day-of-week fields. + This character is short-hand for "last", but it has different + meaning in each of the two fields. For example, the value "L" in + the day-of-month field means "the last day of the month" - day 31 + for January, day 28 for February on non-leap years. If used in the + day-of-week field by itself, it simply means "7" or + "SAT". But if used in the day-of-week field after another value, it + means "the last xxx day of the month" - for example "6L" + means "the last friday of the month". You can also specify an offset + from the last day of the month, such as "L-3" which would mean the third-to-last + day of the calendar month. When using the 'L' option, it is important not to + specify lists, or ranges of values, as you'll get confusing/unexpected results. + + + The 'W' character is allowed for the day-of-month field. This character + is used to specify the weekday (Monday-Friday) nearest the given day. As an + example, if you were to specify "15W" as the value for the + day-of-month field, the meaning is: "the nearest weekday to the 15th of + the month". So if the 15th is a Saturday, the trigger will fire on + Friday the 14th. If the 15th is a Sunday, the trigger will fire on Monday the + 16th. If the 15th is a Tuesday, then it will fire on Tuesday the 15th. + However if you specify "1W" as the value for day-of-month, and the + 1st is a Saturday, the trigger will fire on Monday the 3rd, as it will not + 'jump' over the boundary of a month's days. The 'W' character can only be + specified when the day-of-month is a single day, not a range or list of days. + + + The 'L' and 'W' characters can also be combined for the day-of-month + expression to yield 'LW', which translates to "last weekday of the + month". + + + The '#' character is allowed for the day-of-week field. This character is + used to specify "the nth" XXX day of the month. For example, the + value of "6#3" in the day-of-week field means the third Friday of + the month (day 6 = Friday and "#3" = the 3rd one in the month). + Other examples: "2#1" = the first Monday of the month and + "4#5" = the fifth Wednesday of the month. Note that if you specify + "#5" and there is not 5 of the given day-of-week in the month, then + no firing will occur that month. If the '#' character is used, there can + only be one expression in the day-of-week field ("3#1,6#3" is + not valid, since there are two expressions). + + + + + + The legal characters and the names of months and days of the week are not + case sensitive. + + + NOTES: +
    +
  • Support for specifying both a day-of-week and a day-of-month value is + not complete (you'll need to use the '?' character in one of these fields). +
  • +
  • Overflowing ranges is supported - that is, having a larger number on + the left hand side than the right. You might do 22-2 to catch 10 o'clock + at night until 2 o'clock in the morning, or you might have NOV-FEB. It is + very important to note that overuse of overflowing ranges creates ranges + that don't make sense and no effort has been made to determine which + interpretation CronExpression chooses. An example would be + "0 0 14-6 ? * FRI-MON".
  • +
+
+
+ Sharada Jambula + James House + Contributions from Mads Henderson + Refactoring from CronTrigger to CronExpression by Aaron Craven + Marko Lahma (.NET) +
+ + + Field specification for second. + + + + + Field specification for minute. + + + + + Field specification for hour. + + + + + Field specification for day of month. + + + + + Field specification for month. + + + + + Field specification for day of week. + + + + + Field specification for year. + + + + + Field specification for all wildcard value '*'. + + + + + Field specification for not specified value '?'. + + + + + Field specification for wildcard '*'. + + + + + Field specification for no specification at all '?'. + + + + + Seconds. + + + + + minutes. + + + + + Hours. + + + + + Days of month. + + + + + Months. + + + + + Days of week. + + + + + Years. + + + + + Last day of week. + + + + + Nth day of week. + + + + + Last day of month. + + + + + Nearest weekday. + + + + + Calendar day of week. + + + + + Calendar day of month. + + + + + Expression parsed. + + + + + Constructs a new based on the specified + parameter. + + + String representation of the cron expression the new object should represent + + + + + + Indicates whether the given date satisfies the cron expression. + + + Note that milliseconds are ignored, so two Dates falling on different milliseconds + of the same second will always have the same result here. + + The date to evaluate. + a boolean indicating whether the given date satisfies the cron expression + + + + Returns the next date/time after the given date/time which + satisfies the cron expression. + + the date/time at which to begin the search for the next valid date/time + the next valid date/time + + + + Returns the next date/time after the given date/time which does + not satisfy the expression. + + the date/time at which to begin the search for the next invalid date/time + the next valid date/time + + + + Returns the string representation of the + + The string representation of the + + + + Indicates whether the specified cron expression can be parsed into a + valid cron expression + + the expression to evaluate + a boolean indicating whether the given expression is a valid cron + expression + + + + Builds the expression. + + The expression. + + + + Stores the expression values. + + The position. + The string to traverse. + The type of value. + + + + + Checks the next value. + + The position. + The string to check. + The value. + The type to search. + + + + + Gets the expression summary. + + + + + + Gets the expression set summary. + + The data. + + + + + Skips the white space. + + The i. + The s. + + + + + Finds the next white space. + + The i. + The s. + + + + + Adds to set. + + The val. + The end. + The incr. + The type. + + + + Gets the set of given type. + + The type of set to get. + + + + + Gets the value. + + The v. + The s. + The i. + + + + + Gets the numeric value from string. + + The string to parse from. + The i. + + + + + Gets the month number. + + The string to map with. + + + + + Gets the day of week number. + + The s. + + + + + Gets the time from given time parts. + + The seconds. + The minutes. + The hours. + The day of month. + The month. + + + + + Gets the next fire time after the given time. + + The UTC time to start searching from. + + + + + Creates the date time without milliseconds. + + The time. + + + + + Advance the calendar to the particular hour paying particular attention + to daylight saving problems. + + The date. + The hour. + + + + + Gets the time before. + + The end time. + + + + + NOT YET IMPLEMENTED: Returns the final time that the + will match. + + + + + + Determines whether given year is a leap year. + + The year. + + true if the specified year is a leap year; otherwise, false. + + + + + Gets the last day of month. + + The month num. + The year. + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . + + + + Serves as a hash function for a particular type. + + + A hash code for the current . + + 2 + + + + Sets or gets the time zone for which the of this + will be resolved. + + + + + Gets the cron expression string. + + The cron expression string. + + + + Helper class for cron expression handling. + + + + + The value. + + + + + The position. + + + + + CronScheduleBuilder is a that defines + -based schedules for s. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = newTrigger() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithSimpleSchedule(x => x.WithIntervalInHours(1).RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Create a CronScheduleBuilder with the given cron-expression - which + is presumed to b e valid cron expression (and hence only a RuntimeException + will be thrown if it is not). + + + + the cron expression to base the schedule on. + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with the given cron-expression string - which + may not be a valid cron expression (and hence a ParseException will be thrown + f it is not). + + the cron expression string to base the schedule on + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with the given cron-expression. + + the cron expression to base the schedule on. + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire every day at the given time (hour and minute). + + + + the hour of day to fire + the minute of the given hour to fire + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire at the given day at the given time (hour and minute) on the given days of the week. + + the hour of day to fire + the minute of the given hour to fire + the days of the week to fire + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire one per week on the given day at the given time + (hour and minute). + + + + the day of the week to fire + the hour of day to fire + the minute of the given hour to fire + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire one per month on the given day of month at the given + time (hour and minute). + + + + the day of the month to fire + the hour of day to fire + the minute of the given hour to fire + the new CronScheduleBuilder + + + + + The in which to base the schedule. + + + + the time-zone for the schedule. + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + Extension methods that attach to . + + + + + A implementation that build schedule for DailyTimeIntervalTrigger. + + + + This builder provide an extra convenient method for you to set the trigger's EndTimeOfDay. You may + use either endingDailyAt() or EndingDailyAfterCount() to set the value. The later will auto calculate + your EndTimeOfDay by using the interval, IntervalUnit and StartTimeOfDay to perform the calculation. + + + When using EndingDailyAfterCount(), you should note that it is used to calculating EndTimeOfDay. So + if your startTime on the first day is already pass by a time that would not add up to the count you + expected, until the next day comes. Remember that DailyTimeIntervalTrigger will use StartTimeOfDay + and endTimeOfDay as fresh per each day! + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithDailyTimeIntervalSchedule(x => + x.WithIntervalInMinutes(15) + .StartingDailyAt(TimeOfDay.HourAndMinuteOfDay(8, 0)) + .Build(); + + scheduler.scheduleJob(job, trigger); + + + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + A set of all days of the week. + + + The set contains all values between and + + + + + A set of the business days of the week (for locales similar to the USA). + + + The set contains all values between and + + + + + A set of the weekend days of the week (for locales similar to the USA). + + + The set contains and + + + + + Create a DailyTimeIntervalScheduleBuilder + + The new DailyTimeIntervalScheduleBuilder + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Specify the time unit and interval for the Trigger to be produced. + + + + the interval at which the trigger should repeat. + the time unit (IntervalUnit) of the interval. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.Second that the produced + Trigger will repeat at. + + The number of seconds at which the trigger should repeat. + the updated DailyTimeIntervalScheduleBuilder> + + + + + + Specify an interval in the IntervalUnit.Minute that the produced + Trigger will repeat at. + + The number of minutes at which the trigger should repeat. + the updated DailyTimeIntervalScheduleBuilder> + + + + + + Specify an interval in the IntervalUnit.Hour that the produced + Trigger will repeat at. + + The number of hours at which the trigger should repeat. + the updated DailyTimeIntervalScheduleBuilder> + + + + + + Set the trigger to fire on the given days of the week. + + a Set containing the integers representing the days of the week, defined by - . + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on the given days of the week. + + a variable length list of week days representing the days of the week + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on the days from Monday through Friday. + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on the days Saturday and Sunday. + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on all days of the week. + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to begin firing each day at the given time. + + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the startTimeOfDay for this trigger to end firing each day at the given time. + + + the updated DailyTimeIntervalScheduleBuilder + + + + Calculate and set the EndTimeOfDay using count, interval and StarTimeOfDay. This means + that these must be set before this method is call. + + + the updated DailyTimeIntervalScheduleBuilder + + + + If the Trigger misfires, use the + instruction. + + the updated DailyTimeIntervalScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + the updated DailyTimeIntervalScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + the updated DailyTimeIntervalScheduleBuilder + + + + + Set number of times for interval to repeat. + + + Note: if you want total count = 1 (at start time) + repeatCount + + + + + + + Extension methods that attach to . + + + + + DateBuilder is used to conveniently create + instances that meet particular criteria. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = newTrigger() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minutes)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + Create a DateBuilder, with initial settings for the current date + and time in the system default timezone. + + + + + Create a DateBuilder, with initial settings for the current date and time in the given timezone. + + + + + + Create a DateBuilder, with initial settings for the current date and time in the system default timezone. + + + + + + Create a DateBuilder, with initial settings for the current date and time in the given timezone. + + Time zone to use. + + + + + Build the defined by this builder instance. + + New date time based on builder parameters. + + + + Set the hour (0-23) for the Date that will be built by this builder. + + + + + + + Set the minute (0-59) for the Date that will be built by this builder. + + + + + + + Set the second (0-59) for the Date that will be built by this builder, and truncate the milliseconds to 000. + + + + + + + Set the day of month (1-31) for the Date that will be built by this builder. + + + + + + + Set the month (1-12) for the Date that will be built by this builder. + + + + + + + Set the year for the Date that will be built by this builder. + + + + + + + Set the TimeZoneInfo for the Date that will be built by this builder (if "null", system default will be used) + + + + + + + Get a object that represents the given time, on + tomorrow's date. + + + + + + + + + Get a object that represents the given time, on + today's date (equivalent to . + + + + + + + + + Get a object that represents the given time, on today's date. + + The value (0-59) to give the seconds field of the date + The value (0-59) to give the minutes field of the date + The value (0-23) to give the hours field of the date + the new date + + + + Get a object that represents the given time, on the + given date. + + The value (0-59) to give the seconds field of the date + The value (0-59) to give the minutes field of the date + The value (0-23) to give the hours field of the date + The value (1-31) to give the day of month field of the date + The value (1-12) to give the month field of the date + the new date + + + + Get a object that represents the given time, on the + given date. + + + + The value (0-59) to give the seconds field of the date + The value (0-59) to give the minutes field of the date + The value (0-23) to give the hours field of the date + The value (1-31) to give the day of month field of the date + The value (1-12) to give the month field of the date + The value (1970-2099) to give the year field of the date + the new date + + + + Returns a date that is rounded to the next even hour after the current time. + + + For example a current time of 08:13:54 would result in a date + with the time of 09:00:00. If the date's time is in the 23rd hour, the + date's 'day' will be promoted, and the time will be set to 00:00:00. + + the new rounded date + + + + Returns a date that is rounded to the next even hour above the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 09:00:00. If the date's time is in the 23rd hour, the + date's 'day' will be promoted, and the time will be set to 00:00:00. + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the previous even hour below the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 08:00:00. + + the Date to round, if the current time will + be used + the new rounded date + + + + + Returns a date that is rounded to the next even minute after the current time. + + + + For example a current time of 08:13:54 would result in a date + with the time of 08:14:00. If the date's time is in the 59th minute, + then the hour (and possibly the day) will be promoted. + + the new rounded date + + + + Returns a date that is rounded to the next even minute above the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 08:14:00. If the date's time is in the 59th minute, + then the hour (and possibly the day) will be promoted. + + The Date to round, if the current time will be used + The new rounded date + + + + Returns a date that is rounded to the previous even minute below the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 08:13:00. + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the next even second after the current time. + + the new rounded date + + + + Returns a date that is rounded to the next even second above the given date. + + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the previous even second below the + given date. + + + + For example an input date with a time of 08:13:54.341 would result in a + date with the time of 08:13:00.000. + + + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the next even multiple of the given + minute. + + + + For example an input date with a time of 08:13:54, and an input + minute-base of 5 would result in a date with the time of 08:15:00. The + same input date with an input minute-base of 10 would result in a date + with the time of 08:20:00. But a date with the time 08:53:31 and an + input minute-base of 45 would result in 09:00:00, because the even-hour + is the next 'base' for 45-minute intervals. + + + More examples: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Input TimeMinute-BaseResult Time
11:16:412011:20:00
11:36:412011:40:00
11:46:412012:00:00
11:26:413011:30:00
11:36:413012:00:00
11:16:411711:17:00
11:17:411711:34:00
11:52:411712:00:00
11:52:41511:55:00
11:57:41512:00:00
11:17:41012:00:00
11:17:41111:08:00
+
+
+ + the Date to round, if the current time will + be used + + the base-minute to set the time on + the new rounded date + +
+ + + Returns a date that is rounded to the next even multiple of the given + minute. + + + The rules for calculating the second are the same as those for + calculating the minute in the method . + + the Date to round, if the current time will + be used + the base-second to set the time on + the new rounded date + + + + + An attribute that marks a class as one that must not have multiple + instances executed concurrently (where instance is based-upon a + definition - or in other words based upon a . + + + This can be used in lieu of implementing the StatefulJob marker interface that + was used prior to Quartz 2.0 + + + James House + Marko Lahma (.NET) + + + + The interface to be implemented by s that provide a + mechanism for having their execution interrupted. It is NOT a requirement + for jobs to implement this interface - in fact, for most people, none of + their jobs will. + + + + The means of actually interrupting the Job must be implemented within the + itself (the method of this + interface is simply a means for the scheduler to inform the + that a request has been made for it to be interrupted). The mechanism that + your jobs use to interrupt themselves might vary between implementations. + However the principle idea in any implementation should be to have the + body of the job's periodically check some flag to + see if an interruption has been requested, and if the flag is set, somehow + abort the performance of the rest of the job's work. An example of + interrupting a job can be found in the java source for the class + . It is legal to use + some combination of and + synchronization within and + in order to have the method block until the + signals that it has noticed the set flag. + + + + If the Job performs some form of blocking I/O or similar functions, you may + want to consider having the method store a + reference to the calling as a member variable. Then the + implementation of this interfaces method can call + on that Thread. Before attempting this, make + sure that you fully understand what + does and doesn't do. Also make sure that you clear the Job's member + reference to the Thread when the Execute(..) method exits (preferably in a + block. + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a user + interrupts the . + + void (nothing) if job interrupt is successful. + + + + Supported interval units used by . + + + + + A marker interface for s that + wish to have their state maintained between executions. + + + instances follow slightly different rules from + regular instances. The key difference is that their + associated is re-persisted after every + execution of the job, thus preserving state for the next execution. The + other difference is that stateful jobs are not allowed to Execute + concurrently, which means new triggers that occur before the completion of + the method will be delayed. + + + + + + + + James House + Marko Lahma (.NET) + + + + JobBuilder is used to instantiate s. + + + + The builder will always try to keep itself in a valid state, with + reasonable defaults set for calling Build() at any point. For instance + if you do not invoke WithIdentity(..) a job name will be generated + for you. + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x.WithIntervalInHours(1).RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + + scheduler.scheduleJob(job, trigger); + + + + + + + + + Create a JobBuilder with which to define a . + + a new JobBuilder + + + + Create a JobBuilder with which to define a , + and set the class name of the job to be executed. + + a new JobBuilder + + + + Create a JobBuilder with which to define a , + and set the class name of the job to be executed. + + a new JobBuilder + + + + Produce the instance defined by this JobBuilder. + + the defined JobDetail. + + + + Use a with the given name and default group to + identify the JobDetail. + + + If none of the 'withIdentity' methods are set on the JobBuilder, + then a random, unique JobKey will be generated. + + the name element for the Job's JobKey + the updated JobBuilder + + + + + + Use a with the given name and group to + identify the JobDetail. + + + If none of the 'withIdentity' methods are set on the JobBuilder, + then a random, unique JobKey will be generated. + + the name element for the Job's JobKey + the group element for the Job's JobKey + the updated JobBuilder + + + + + + Use a to identify the JobDetail. + + + If none of the 'withIdentity' methods are set on the JobBuilder, + then a random, unique JobKey will be generated. + + the Job's JobKey + the updated JobBuilder + + + + + + Set the given (human-meaningful) description of the Job. + + the description for the Job + the updated JobBuilder + + + + + Set the class which will be instantiated and executed when a + Trigger fires that is associated with this JobDetail. + + the updated JobBuilder + + + + + Set the class which will be instantiated and executed when a + Trigger fires that is associated with this JobDetail. + + the updated JobBuilder + + + + + Instructs the whether or not the job + should be re-executed if a 'recovery' or 'fail-over' situation is + encountered. + + + If not explicitly set, the default value is . + + the updated JobBuilder + + + + + Instructs the whether or not the job + should be re-executed if a 'recovery' or 'fail-over' situation is + encountered. + + + If not explicitly set, the default value is . + + + the updated JobBuilder + + + + Whether or not the job should remain stored after it is + orphaned (no s point to it). + + + If not explicitly set, the default value is . + + the updated JobBuilder + + + + + Whether or not the job should remain stored after it is + orphaned (no s point to it). + + + If not explicitly set, the default value is . + + the value to set for the durability property. + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Set the JobDetail's , adding any values to it + that were already set on this JobBuilder using any of the + other 'usingJobData' methods. + + the updated JobBuilder + + + + + Holds state information for instances. + + + instances are stored once when the + is added to a scheduler. They are also re-persisted after every execution of + instances that have present. + + instances can also be stored with a + . This can be useful in the case where you have a Job + that is stored in the scheduler for regular/repeated use by multiple + Triggers, yet with each independent triggering, you want to supply the + Job with different data inputs. + + + The passed to a Job at execution time + also contains a convenience that is the result + of merging the contents of the trigger's JobDataMap (if any) over the + Job's JobDataMap (if any). + + + + + + + James House + Marko Lahma (.NET) + + + + Create an empty . + + + + + Create a with the given data. + + + + + Create a with the given data. + + + + + Serialization constructor. + + + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the + . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Gets the date time. + + The key. + + + + + Gets the value behind the specified key. + + The key. + + + + + An exception that can be thrown by a + to indicate to the Quartz that an error + occurred while executing, and whether or not the requests + to be re-fired immediately (using the same , + or whether it wants to be unscheduled. + + + Note that if the flag for 'refire immediately' is set, the flags for + unscheduling the Job are ignored. + + + + + James House + Marko Lahma (.NET) + + + + Create a JobExcecutionException, with the 're-fire immediately' flag set + to . + + + + + Create a JobExcecutionException, with the given cause. + + The cause. + + + + Create a JobExcecutionException, with the given message. + + + + + Initializes a new instance of the class. + + The message. + The original cause. + + + + Create a JobExcecutionException with the 're-fire immediately' flag set + to the given value. + + + + + Create a JobExcecutionException with the given underlying exception, and + the 're-fire immediately' flag set to the given value. + + + + + Create a JobExcecutionException with the given message, and underlying + exception, and the 're-fire immediately' flag set to the given value. + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Creates and returns a string representation of the current exception. + + + A string representation of the current exception. + + + + + + Gets or sets a value indicating whether to unschedule firing trigger. + + + true if firing trigger should be unscheduled; otherwise, false. + + + + + Gets or sets a value indicating whether to unschedule all triggers. + + + true if all triggers should be unscheduled; otherwise, false. + + + + + Gets or sets a value indicating whether to refire immediately. + + true if to refire immediately; otherwise, false. + + + + Uniquely identifies a . + + + Keys are composed of both a name and group, and the name must be unique + within the group. If only a group is specified then the default group + name will be used. + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + Misfire instructions. + + Marko Lahma (.NET) + + + + Instruction not set (yet). + + + + + Use smart policy. + + + + + Instructs the that the + will never be evaluated for a misfire situation, + and that the scheduler will simply try to fire it as soon as it can, + and then update the Trigger as if it had fired at the proper time. + + + NOTE: if a trigger uses this instruction, and it has missed + several of its scheduled firings, then several rapid firings may occur + as the trigger attempt to catch back up to where it would have been. + For example, a SimpleTrigger that fires every 15 seconds which has + misfired for 5 minutes will fire 20 times once it gets the chance to + fire. + + + + + Misfire policy settings for SimpleTrigger. + + + + + Instructs the that upon a mis-fire + situation, the wants to be fired + now by . + + NOTE: This instruction should typically only be used for + 'one-shot' (non-repeating) Triggers. If it is used on a trigger with a + repeat count > 0 then it is equivalent to the instruction + . + + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to 'now' (even if the associated + excludes 'now') with the repeat count left as-is. This does obey the + end-time however, so if 'now' is after the + end-time the will not fire again. + + + + NOTE: Use of this instruction causes the trigger to 'forget' + the start-time and repeat-count that it was originally setup with (this + is only an issue if you for some reason wanted to be able to tell what + the original values were at some later time). + + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to 'now' (even if the associated + excludes 'now') with the repeat count set to what it would be, if it had + not missed any firings. This does obey the end-time + however, so if 'now' is after the end-time the will + not fire again. + + + NOTE: Use of this instruction causes the trigger to 'forget' + the start-time and repeat-count that it was originally setup with. + Instead, the repeat count on the trigger will be changed to whatever + the remaining repeat count is (this is only an issue if you for some + reason wanted to be able to tell what the original values were at some + later time). + + + + NOTE: This instruction could cause the + to go to the 'COMPLETE' state after firing 'now', if all the + repeat-fire-times where missed. + + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to the next scheduled time after 'now' - taking into + account any associated , and with the + repeat count set to what it would be, if it had not missed any firings. + + + NOTE/WARNING: This instruction could cause the + to go directly to the 'COMPLETE' state if all fire-times where missed. + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to the next scheduled time after 'now' - taking into + account any associated , and with the + repeat count left unchanged. + + + + NOTE/WARNING: This instruction could cause the + to go directly to the 'COMPLETE' state if all the end-time of the trigger + has arrived. + + + + + + misfire instructions for CronTrigger + + + + + Instructs the that upon a mis-fire + situation, the wants to be fired now + by . + + + + + Instructs the that upon a mis-fire + situation, the wants to have it's + next-fire-time updated to the next time in the schedule after the + current time (taking into account any associated , + but it does not want to be fired now. + + + + + misfire instructions for NthIncludedDayTrigger + + + + + Instructs the that upon a mis-fire situation, the + wants to be fired now by the + + + + + + Instructs the that upon a mis-fire situation, the + wants to have + nextFireTime updated to the next time in the schedule after + the current time, but it does not want to be fired now. + + + + + Misfire instructions for DateIntervalTrigger + + + + + Instructs the that upon a mis-fire + situation, the wants to be + fired now by . + + + + + Instructs the that upon a mis-fire + situation, the wants to have it's + next-fire-time updated to the next time in the schedule after the + current time (taking into account any associated , + but it does not want to be fired now. + + + + + Misfire instructions for DailyTimeIntervalTrigger + + + + + Instructs the that upon a mis-fire + situation, the wants to be + fired now by . + + + + + Instructs the that upon a mis-fire + situation, the wants to have it's + next-fire-time updated to the next time in the schedule after the + current time (taking into account any associated , + but it does not want to be fired now. + + + + + A trigger which fires on the Nth day of every interval type + , or + that is not excluded by the associated + calendar. + + + When determining what the Nth day of the month or year + is, will skip excluded days on the + associated calendar. This would commonly be used in an Nth + business day situation, in which the user wishes to fire a particular job on + the Nth business day (i.e. the 5th business day of + every month). Each also has an associated + which indicates at what time of day the trigger is + to fire. + + All s default to a monthly interval type + (fires on the Nth day of every month) with N = 1 (first + non-excluded day) and set to 12:00 PM (noon). These + values can be changed using the , , and + methods. Users may also want to note the + and + methods. + + + Take, for example, the following calendar: + + + July August September + Su Mo Tu We Th Fr Sa Su Mo Tu We Th Fr Sa Su Mo Tu We Th Fr Sa + 1 W 1 2 3 4 5 W 1 2 W + W H 5 6 7 8 W W 8 9 10 11 12 W W H 6 7 8 9 W + W 11 12 13 14 15 W W 15 16 17 18 19 W W 12 13 14 15 16 W + W 18 19 20 21 22 W W 22 23 24 25 26 W W 19 20 21 22 23 W + W 25 26 27 28 29 W W 29 30 31 W 26 27 28 29 30 + W + + Where W's represent weekend days, and H's represent holidays, all of which + are excluded on a calendar associated with an + with n=5 and + intervalType=IntervalTypeMonthly. In this case, the trigger + would fire on the 8th of July (because of the July 4 holiday), + the 5th of August, and the 8th of September (because + of Labor Day). + + Aaron Craven + Marko Lahma (.NET) + + + + Indicates a monthly trigger type (fires on the Nth included + day of every month). + + + + indicates a yearly trigger type (fires on the Nth included + day of every year). + + + + + Indicates a weekly trigger type (fires on the Nth included + day of every week). When using this interval type, care must be taken + not to think of the value of as an analog to + . Such a comparison can only + be drawn when there are no calendars associated with the trigger. To + illustrate, consider an with + n = 3 which is associated with a Calendar excluding + non-weekdays. The trigger would fire on the 3rd + included day of the week, which would be 4th + actual day of the week. + + + + + Create an with no specified name, + group, or . This will result initially in a + default monthly trigger that fires on the first day of every month at + 12:00 PM (n = 1, + intervalType=, + fireAtTime="12:00"). + + + Note that and , must be + called before the can be placed into + a . + + + + + Create an with the given name and + default group but no specified . This will result + initially in a default monthly trigger that fires on the first day of + every month at 12:00 PM (=1, + intervalType=, + fireAtTime=12:00"). + + Note that must + be called before the can be placed + into a . + + + the name for the + + + + + Create an with the given name and + group but no specified . This will result + initially in a default monthly trigger that fires on the first day of + every month at 12:00 PM (=1, + intervalType=, + fireAtTime=12:00"). + + Note that must + be called before the can be placed + into a . + + + the name for the + + the group for the + + + + + Create an with the given name and + group and the specified . This will result + initially in a default monthly trigger that fires on the first day of + every month at 12:00 PM (=1, + intervalType=, + fireAtTime="12:00"). + + The name for the . + The group for the . + The name of the job to associate with the . + The group containing the job to associate with the . + + + + Returns the next UTC time at which the + will fire. If the trigger will not fire again, will be + returned. + + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + property. The default cutoff is 12 + of the intervals specified by intervalType. + + + The returned value is not guaranteed to be valid until after + the trigger has been added to the scheduler. + + + the next fire time for the trigger + + + + + Returns the previous UTC time at which the + fired. If the trigger has not yet + fired, will be returned. + + the previous fire time for the trigger + + + + Returns the first time the will fire + after the specified date. + + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + property. The default cutoff is 12 + of the intervals specified by intervalType. + + + Therefore, for triggers with intervalType = + , if the trigger + will not fire within 12 + weeks after the given date/time, will be returned. For + triggers with intervalType = + + , if the trigger will not fire within 12 + months after the given date/time, will be returned. + For triggers with intervalType = + + , if the trigger will not fire within 12 + years after the given date/time, will be returned. In + all cases, if the trigger will not fire before , + will be returned. + + + The time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + + the first time the trigger will fire following the specified date + + + + + Called when the has decided to 'fire' the trigger + (Execute the associated ), in order to give the + a chance to update itself for its next triggering + (if any). + + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + After this method has been called, + should return a valid answer. + + + + the first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first + firing of the ). + + + + + Called after the has executed the + associated with the in order + to get the final instruction code from the trigger. + + + The that was used by the + 's method. + + + The thrown by the + , if any (may be ) + + one of the Trigger.INSTRUCTION_XXX constants. + + + + + Used by the to determine whether or not it is + possible for this to fire again. + ' + + + If the returned value is then the + may remove the from the + + + + + A boolean indicator of whether the trigger could potentially fire + again. + + + + + Indicates whether is a valid misfire + instruction for this . + + Whether is valid. + + + Updates the 's state based on the + MisfireInstruction that was selected when the + was created +

+ If the misfire instruction is set to MISFIRE_INSTRUCTION_SMART_POLICY, + then the instruction will be interpreted as + . +

+
+ a new or updated calendar to use for the trigger + +
+ + + Updates the 's state based on the + given new version of the associated . + + A new or updated calendar to use for the trigger + the amount of time that must + be between "now" and the time the next + firing of the trigger is supposed to occur. + + + + + Calculates the first time an with + intervalType = IntervalTypeWeekly will fire + after the specified date. See for more + information. + + The time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + the first time the trigger will fire following the specified + date + + + + + Calculates the first UTC time an with + intervalType = will fire + after the specified date. See for more + information. + + + The UTC time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + the first time the trigger will fire following the specified date + + + + Calculates the first time an with + intervalType = will fire + after the specified date. See for more + information. + + + The UTC time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + the first time the trigger will fire following the specified + date + + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + + Gets or sets the day of the interval on which the + should fire. If the Nth + day of the interval does not exist (i.e. the 32nd of a + month), the trigger simply will never fire. N may not be less than 1. + + + + + Returns the interval type for the . + + + Sets the interval type for the . If + , the trigger will fire on the + Nth included day of every month. If + , the trigger will fire on the + Nth included day of every year. If + , the trigger will fire on the + Nth included day of every week. + + + + + + + + Returns the fire time for the as a + string with the format "HH:MM[:SS]", with HH representing the + 24-hour clock hour of the fire time. Seconds are optional and their + inclusion depends on whether or not they were provided to + . + + + + + Returns the for the + . + + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + property. The default cutoff is 12 + of the intervals specified by intervalType" />. + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + method. The default cutoff is 12 + of the intervals specified by intervalType". + + + In most cases, the default value of this setting (12) is sufficient (it + is highly unlikely, for example, that you will need to look at more than + 12 months of dates to ensure that your trigger will never fire again). + However, this setting is included to allow for the rare exceptions where + this might not be true. + + + For example, if your trigger is associated with a calendar that excludes + a great many dates in the next 12 months, and hardly any following that, + it is possible (if is large enough) that you could run + into this situation. + + + + + + Returns the last UTC time the will fire. + If the trigger will not fire at any point between + and , will be returned. + + the last time the trigger will fire. + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + + Sets or gets the time zone in which the will be resolved. + If no time zone is provided, then the default time zone will be used. + + + + + + + Gets or sets the trigger's calendar week rule. + + The trigger calendar week rule. + + + + Gets or sets the trigger's calendar first day of week rule. + + The trigger calendar first day of week. + + + + An exception that is thrown to indicate that an attempt to store a new + object (i.e. , + or ) in a + failed, because one with the same name and group already exists. + + James House + Marko Lahma (.NET) + + + + Create a with the given + message. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Create a and auto-generate a + message using the name/group from the given . + + + + The message will read:
"Unable to store Job with name: '__' and + group: '__', because one already exists with this identification." +
+
+
+ + + Create a and auto-generate a + message using the name/group from the given . + + + + The message will read:
"Unable to store Trigger with name: '__' and + group: '__', because one already exists with this identification." +
+
+
+ + + An attribute that marks a class as one that makes updates to its + during execution, and wishes the scheduler to re-store the + when execution completes. + + + + Jobs that are marked with this annotation should also seriously consider + using the attribute, to avoid data + storage race conditions with concurrently executing job instances. + + + This can be used in lieu of implementing the StatefulJob marker interface that + was used prior to Quartz 2.0 + + + + James House + Marko Lahma (.NET) + + + + An exception that is thrown to indicate that there is a misconfiguration of + the - or one of the components it + configures. + + James House + Marko Lahma (.NET) + + + + Create a with the given message. + + + + + Create a with the given message + and cause. + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Scheduler constants. + + Marko Lahma (.NET) + + + + A (possibly) useful constant that can be used for specifying the group + that and instances belong to. + + + + + A constant group name used internally by the + scheduler - clients should not use the value of this constant + ("RECOVERING_JOBS") for thename of a 's group. + + + + + A constant group name used internally by the + scheduler - clients should not use the value of this constant + ("FAILED_OVER_JOBS") for thename of a 's group. + + + + + A constant key that can be used to retrieve the + name of the original from a recovery trigger's + data map in the case of a job recovering after a failed scheduler + instance. + + + + + + A constant key that can be used to retrieve the + group of the original from a recovery trigger's + data map in the case of a job recovering after a failed scheduler + instance. + + + + + + A constant key that can be used to retrieve the + scheduled fire time of the original from a recovery + trigger's data map in the case of a job recovering after a failed scheduler + instance. + + + + + + Holds context/environment data that can be made available to Jobs as they + are executed. + + + Future versions of Quartz may make distinctions on how it propagates + data in between instances of proxies to a + single scheduler instance - i.e. if Quartz is being used via WCF of Remoting. + + + James House + Marko Lahma (.NET) + + + + Create an empty . + + + + + Create a with the given data. + + + + + Serialization constructor. + + + + + + + Instructs Scheduler what to do with a trigger and job. + + Marko Lahma (.NET) + + + + Instructs the that the + has no further instructions. + + + + + Instructs the that the + wants the to re-Execute + immediately. If not in a 'RECOVERING' or 'FAILED_OVER' situation, the + execution context will be re-used (giving the the + ability to 'see' anything placed in the context by its last execution). + + + + + Instructs the that the + should be put in the state. + + + + + Instructs the that the + wants itself deleted. + + + + + Instructs the that all + s referencing the same as + this one should be put in the state. + + + + + Instructs the that all + s referencing the same as + this one should be put in the state. + + + + + Instructs the that the + should be put in the state. + + + + + Describes the settings and capabilities of a given + instance. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + Name of the scheduler. + The scheduler instance. + The scheduler type. + if set to true, scheduler is a remote scheduler. + if set to true, scheduler is started. + if set to true, scheduler is in standby mode. + if set to true, scheduler is shutdown. + The start time. + The number of jobs executed. + The job store type. + if set to true, job store is persistent. + if set to true, the job store is clustered + The thread pool type. + Size of the thread pool. + The version string. + + + + Returns a formatted (human readable) string describing all the 's + meta-data values. + + + + The format of the string looks something like this: +
+            Quartz Scheduler 'SchedulerName' with instanceId 'SchedulerInstanceId' Scheduler class: 'Quartz.Impl.StdScheduler' - running locally. Running since: '11:33am on Jul 19, 2002' Not currently paused. Number of Triggers fired: '123' Using thread pool 'Quartz.Simpl.SimpleThreadPool' - with '8' threads Using job-store 'Quartz.Impl.JobStore' - which supports persistence.
+            
+
+
+
+ + + Return a simple string representation of this object. + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the class-name of the instance. + + + + + Returns whether the is being used remotely (via remoting). + + + + + Returns whether the scheduler has been started. + + + Note: may return even if + returns . + + + + + Reports whether the is in standby mode. + + + Note: may return even if + returns . + + + + + Reports whether the has been Shutdown. + + + + + Returns the class-name of the instance that is + being used by the . + + + + + Returns the type name of the instance that is + being used by the . + + + + + Returns the number of threads currently in the 's + + + + + Returns the version of Quartz that is running. + + + + + Returns the at which the Scheduler started running. + + null if the scheduler has not been started. + + + + + Returns the number of jobs executed since the + started.. + + + + + Returns whether or not the 's + instance supports persistence. + + + + + Returns whether or not the 's + is clustered. + + + + + SimpleScheduleBuilder is a + that defines strict/literal interval-based schedules for + s. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + JobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + Trigger trigger = TriggerBuilder.Create() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + + Create a SimpleScheduleBuilder. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with a 1 minute interval. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with an interval + of the given number of minutes. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with a 1 second interval. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with an interval + of the given number of seconds. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with a 1 hour interval. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with an interval + of the given number of hours. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with a 1 minute interval. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with an interval of the given number of minutes. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with a 1 second interval. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with an interval of the given number of seconds. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with a 1 hour interval. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with an interval of the given number of hours. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + + + Specify a repeat interval in milliseconds. + + + + the time span at which the trigger should repeat. + the updated SimpleScheduleBuilder + + + + + + Specify a repeat interval in seconds. + + + + the time span at which the trigger should repeat. + the updated SimpleScheduleBuilder + + + + + + Specify a the number of time the trigger will repeat - total number of + firings will be this number + 1. + + + + the number of seconds at which the trigger should repeat. + the updated SimpleScheduleBuilder + + + + + + Specify that the trigger will repeat indefinitely. + + + + the updated SimpleScheduleBuilder + + + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + Extension methods that attach to . + + + + + A time source for Quartz.NET that returns the current time. + Original idea by Ayende Rahien: + http://ayende.com/Blog/archive/2008/07/07/Dealing-with-time-in-tests.aspx + + + + + Return current UTC time via . Allows easier unit testing. + + + + + Return current time in current time zone via . Allows easier unit testing. + + + + + Represents a time in hour, minute and second of any given day. + + + The hour is in 24-hour convention, meaning values are from 0 to 23. + + + + + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + Create a TimeOfDay instance for the given hour, minute and second. + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + The second of the minute, between 0 and 59. + + + + Create a TimeOfDay instance for the given hour, minute (at the zero second of the minute). + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + + + + Create a TimeOfDay instance for the given hour, minute and second. + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + The second of the minute, between 0 and 59. + + + + + Create a TimeOfDay instance for the given hour, minute (at the zero second of the minute).. + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + The newly instantiated TimeOfDay + + + + Determine with this time of day is before the given time of day. + + + True this time of day is before the given time of day. + + + + Return a date with time of day reset to this object values. The millisecond value will be zero. + + + + + + The hour of the day (between 0 and 23). + + + + + The minute of the hour (between 0 and 59). + + + + + The second of the minute (between 0 and 59). + + + + + Attribute to use with public properties that + can be set with Quartz configuration. Attribute can be used to advice + parsing to use correct type of time span (milliseconds, seconds, minutes, hours) + as it may depend on property. + + Marko Lahma (.NET) + + + + + Initializes a new instance of the class. + + The rule. + + + + Gets the rule. + + The rule. + + + + Possible parse rules for s. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + TriggerBuilder is used to instantiate s. + + + + The builder will always try to keep itself in a valid state, with + reasonable defaults set for calling build() at any point. For instance + if you do not invoke WithSchedule(..) method, a default schedule + of firing once immediately will be used. As another example, if you + do not invoked WithIdentity(..) a trigger name will be generated + for you. + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + Create a new TriggerBuilder with which to define a + specification for a Trigger. + + + + the new TriggerBuilder + + + + Produce the . + + + + a Trigger that meets the specifications of the builder. + + + + Use a with the given name and default group to + identify the Trigger. + + + If none of the 'withIdentity' methods are set on the TriggerBuilder, + then a random, unique TriggerKey will be generated. + + the name element for the Trigger's TriggerKey + the updated TriggerBuilder + + + + + + Use a TriggerKey with the given name and group to + identify the Trigger. + + + If none of the 'withIdentity' methods are set on the TriggerBuilder, + then a random, unique TriggerKey will be generated. + + the name element for the Trigger's TriggerKey + the group element for the Trigger's TriggerKey + the updated TriggerBuilder + + + + + + Use the given TriggerKey to identify the Trigger. + + + If none of the 'withIdentity' methods are set on the TriggerBuilder, + then a random, unique TriggerKey will be generated. + + the TriggerKey for the Trigger to be built + the updated TriggerBuilder + + + + + + Set the given (human-meaningful) description of the Trigger. + + + + the description for the Trigger + the updated TriggerBuilder + + + + + Set the Trigger's priority. When more than one Trigger have the same + fire time, the scheduler will fire the one with the highest priority + first. + + + + the priority for the Trigger + the updated TriggerBuilder + + + + + + Set the name of the that should be applied to this + Trigger's schedule. + + + + the name of the Calendar to reference. + the updated TriggerBuilder + + + + + + Set the time the Trigger should start at - the trigger may or may + not fire at this time - depending upon the schedule configured for + the Trigger. However the Trigger will NOT fire before this time, + regardless of the Trigger's schedule. + + + + the start time for the Trigger. + the updated TriggerBuilder + + + + + + Set the time the Trigger should start at to the current moment - + the trigger may or may not fire at this time - depending upon the + schedule configured for the Trigger. + + + + the updated TriggerBuilder + + + + + Set the time at which the Trigger will no longer fire - even if it's + schedule has remaining repeats. + + + + the end time for the Trigger. If null, the end time is indefinite. + the updated TriggerBuilder + + + + + + Set the that will be used to define the + Trigger's schedule. + + + The particular used will dictate + the concrete type of Trigger that is produced by the TriggerBuilder. + + the SchedulerBuilder to use. + the updated TriggerBuilder + + + + + + + + Set the identity of the Job which should be fired by the produced + Trigger. + + + + the identity of the Job to fire. + the updated TriggerBuilder + + + + + Set the identity of the Job which should be fired by the produced + Trigger - a will be produced with the given + name and default group. + + + + the name of the job (in default group) to fire. + the updated TriggerBuilder + + + + + Set the identity of the Job which should be fired by the produced + Trigger - a will be produced with the given + name and group. + + + + the name of the job to fire. + the group of the job to fire. + the updated TriggerBuilder + + + + + Set the identity of the Job which should be fired by the produced + Trigger, by extracting the JobKey from the given job. + + + + the Job to fire. + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Common constants for triggers. + + + + + The default value for priority. + + + + + Uniquely identifies a . + + + Keys are composed of both a name and group, and the name must be unique + within the group. If only a name is specified then the default group + name will be used. + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + All trigger states known to Scheduler. + + Marko Lahma (.NET) + + + + Indicates that the is in the "normal" state. + + + + + Indicates that the is in the "paused" state. + + + + + Indicates that the is in the "complete" state. + + + "Complete" indicates that the trigger has not remaining fire-times in + its schedule. + + + + + Indicates that the is in the "error" state. + + + + A arrives at the error state when the scheduler + attempts to fire it, but cannot due to an error creating and executing + its related job. Often this is due to the 's + class not existing in the classpath. + + + + When the trigger is in the error state, the scheduler will make no + attempts to fire it. + + + + + + Indicates that the is in the "blocked" state. + + + A arrives at the blocked state when the job that + it is associated with has a and it is + currently executing. + + + + + + Indicates that the does not exist. + + + + + A Comparator that compares trigger's next fire times, or in other words, + sorts them according to earliest next fire time. If the fire times are + the same, then the triggers are sorted according to priority (highest + value first), if the priorities are the same, then they are sorted + by key. + + + + + Convenience and utility methods for simplifying the construction and + configuration of s and DateTimeOffsetOffsets. + + + + James House + Marko Lahma (.NET) + + + + Returns a list of Dates that are the next fire times of a + . + The input trigger will be cloned before any work is done, so you need + not worry about its state being altered by this method. + + The trigger upon which to do the work + The calendar to apply to the trigger's schedule + The number of next fire times to produce + List of java.util.Date objects + + + + Compute the that is 1 second after the Nth firing of + the given , taking the triger's associated + into consideration. + + + The input trigger will be cloned before any work is done, so you need + not worry about its state being altered by this method. + + The trigger upon which to do the work + The calendar to apply to the trigger's schedule + The number of next fire times to produce + the computed Date, or null if the trigger (as configured) will not fire that many times + + + + Returns a list of Dates that are the next fire times of a + that fall within the given date range. The input trigger will be cloned + before any work is done, so you need not worry about its state being + altered by this method. + + NOTE: if this is a trigger that has previously fired within the given + date range, then firings which have already occurred will not be listed + in the output List. + + + The trigger upon which to do the work + The calendar to apply to the trigger's schedule + The starting date at which to find fire times + The ending date at which to stop finding fire times + List of java.util.Date objects + + + + An exception that is thrown to indicate that a call to + failed without interrupting the Job. + + + James House + Marko Lahma (.NET) + + + + Create a with the given message. + + + + + Create a with the given cause. + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + diff --git a/Resources/Libraries/Quartz/Common.Logging.dll b/Resources/Libraries/Quartz/Common.Logging.dll new file mode 100644 index 0000000000000000000000000000000000000000..5c1feac985f479c1e1bfec5b1062d0d94f49cf0d GIT binary patch literal 49152 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�{~#sS^yjX0GclV4s4|j_}?Pg6BRbEP>&HZ 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�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 D=?0gC literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Quartz/Quartz.pdb b/Resources/Libraries/Quartz/Quartz.pdb new file mode 100644 index 0000000000000000000000000000000000000000..5fee49e8e3698c376469b869e662e77083b26ba5 GIT binary patch literal 1191424 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%0DF3bSPibkx z71R%?lppuT4}ARTe(=U~^nK68seVw256nC32QJTw{Zang{IBX^g*gA;RGR7k@E=0{ z7tH@|3bgh-p8xI6{@-{WIR5^l+dCA#0ba-Vt&}F!+r^w6EB#J3KU^28kTMAff%DD! zHy7yJ6W^A-{2Y*O=2+rna*$#W`lb6Vol-lVzkF^7|RZ;03S(jvM%^z@O{nW7WqBLLRou*tau*xX=IHyS(?W^ zO|oiK00?6|a=*_Y>spi5i|^H$UN(Lh(a#H69?5zOvK};9f~Rwr1KykUZXd^ zJpUwqd3l(NO`h}ac)|DZloVecyR+}puYZ_cRxfT1dR0VvtwparrdM=!1mC)GFK&s} zo?AH?meYfGT#NiBo~6y^Z0h>^L@kQa_Eyq%)Y4Wkr@f8zmBS-?qp|drMd@46xoD9N zBreu=)~DPV(sxdjzPFLShZs?~s!`=?a$8IDoy+(XY`d#Fim7i+US$w;K_u_($g4Mb zDqE*Pp7ogy26=j)&cZt6J!$ghWIOW3<&LRwie}#Y;1l8G9#4arnLr@Aw72IF2ds z$bF}R)#sb$;&_0yk6ZKN@O_o!yOnVq55R-z-QG;ecrn)lGp}%Q*m?uQ$I#a($@Njr z<=#p_VSb1s3sxK&6RZ3#=2~OsM(~BsBC3=s?PWQ zg=9TOb)2n7y#~G^@F{}j9T>&29`J2!N!XQ=|LxEX@ThPrALJJw=6V!(Gk9XSUj_asvSjy< zfgcX{*^8U`1a!^d_ko`Te+oQUJA(=Rn9=ATzF~51rq=c9b-zDpEM+~cG@KzJ-}UWh za*jf*=RXps?6VU*8vHr%U}iE0hwmdwPx+m1<4Rn6$0cvCC4To6c+@<76?{JUYhab< zuY<>erT;kaH@T*KWxfrj%w+b1=YYQhegynoa4Gp(N)1`cuE2h*&nfi7*Hj*Luax)4 z^*u_+5zaIJlHqDdmgRD@v1Z2hz(;3EP;|b?*a~y-UGL z`#IpjZcnwoV_8jJ)i`@7K3{K_xH_CmuaC+ zj9eM<^>F$*FuW?@)SOs)2&#(&E0Bi+z0|$U(z@R34 z6sQ5_0v*6=U=y$dH~<_2%9pZU3QPwYfEB=6U>mRpI0_7EW{nG&4lDt>fOWtYU>9(@ zgY0a5r}7ZJFR5PAI_7^~`F5NCnavkAmS)4ekG9FVK8)hP|6B<-TD8COfp_QHUpJ=A zoBOTd`Jog(Zbf{#Ib5oDFHiGS2Z2k0bs=r)Gb#Cryd0lv>($jOZpQ0XO~mbW zD+x7O{<#wLk6c~(VzBBE)g2?jx>hPWZqGbOK0Hi2`jERm z%I^RmUiUhn{BJqEJ`m?W?WqgaUg=^b`TsN(sgqhgc}aHRV|OlVZ13PTA)+|S>N$9Utp;dp*m zXT3|9&GpbnP}h@?KLj5m|#^!FccI(c%4LG^txbH?()!Z~9rBevgHYj_s!!$z%U zqdOWJIOcUJuV~JyZ>wL*;l6F6>&ZA!Hdoq-()IJa4U@i+`a&u@3XI8JANES{ja+O0 z%wTrd4W?}w%+4Ogq5hRmU-IsO@?CvF1$wKlFMU1u60RxK?o1!zBd$BhkSgMu?#4M* z{yrRXX$bUdD0@4AeZcXv{yYD=OwVY}9`ZC#*J^u1_aTS(F`SpCj%Pa}IL-OA@QQ44xs%&Wf z;3_aa&b~{3mKtL_H;$A455~ub@?mt&ox$i|4I7)daki|+H>;5#ajbb zeH+JXbE65Lo%7J1YeV8^+MM31eg5q}&UM7OmN*{;59dNED^AtRSwT;;0ms9h-As;DSUb3l-`b4_94UPMTxT?m+pP=-TH&j z%s6BixCN}T@i=%CSbeQa!?oJDcJ8Yk?*QKso=*i)TkVB&Q>>fhM7+T3dQ&nkC9QF7IGQ~+MDD?(Ip{(pe{|H6B${Lg0e$0Ay&1{%T;P@BLe zGFT|q55^3S=J-0 z{I~g^uD}`R|3}IH%m3zt{GZvy3&OWB7cqmC z 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 z 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 + + + Quartz + + + +

+ A wrapper for generic HashSet that brings a common interface. + + + + + + Represents a collection ob objects that contains no duplicate elements. + + Marko Lahma (.NET) + + + + A sorted set. + + Marko Lahma (.NET) + + + + Returns a portion of the list whose elements are greater than the limit object parameter. + + The start element of the portion to extract. + The portion of the collection whose elements are greater than the limit object parameter. + + + + Returns the first item in the set. + + First object. + + + + Returns the object in the specified index. + + + + + + + Simple C5 wrapper for common interface. + + + + + + Default constructor. + + + + + Constructor that accepts comparer. + + Comparer to use. + + + + Constructor that prepolutates. + + + + + + Returns the first element. + + + + + + Return items from given range. + + + + + + + Indexer. + + + + + + + Only for backwards compatibility with serialization! + + + + + Responsible for creating the instances of + to be used within the instance. + + James House + Marko Lahma (.NET) + + + + Initialize the factory, providing a handle to the + that should be made available within the and + the s within it. + + + + + Called by the + to obtain instances of . + + + + + JobRunShell instances are responsible for providing the 'safe' environment + for s to run in, and for performing all of the work of + executing the , catching ANY thrown exceptions, updating + the with the 's completion code, + etc. + + A instance is created by a + on behalf of the which then runs the + shell in a thread from the configured when the + scheduler determines that a has been triggered. + + + + + + + James House + Marko Lahma (.NET) + + + + A helpful abstract base class for implementors of + . + + + The methods in this class are empty so you only need to override the + subset for the events you care about. + + Marko Lahma (.NET) + + + + + The interface to be implemented by classes that want to be informed of major + events. + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + is scheduled. + + + + + Called by the when a + is unscheduled. + + + + + + Called by the when a + has reached the condition in which it will never fire again. + + + + + Called by the a s has been paused. + + + + + Called by the a group of + s has been paused. + + + If a all groups were paused, then the parameter + will be null. + + The trigger group. + + + + Called by the when a + has been un-paused. + + + + + Called by the when a + group of s has been un-paused. + + + If all groups were resumed, then the parameter + will be null. + + The trigger group. + + + + Called by the when a + has been added. + + + + + + Called by the when a + has been deleted. + + + + + Called by the when a + has been paused. + + + + + Called by the when a + group of s has been paused. + + If all groups were paused, then the parameter will be + null. If all jobs were paused, then both parameters will be null. + + + The job group. + + + + Called by the when a + has been un-paused. + + + + + Called by the when a + has been un-paused. + + The job group. + + + + Called by the when a serious error has + occurred within the scheduler - such as repeated failures in the , + or the inability to instantiate a instance when its + has fired. + + + + + Called by the to inform the listener + that it has move to standby mode. + + + + + Called by the to inform the listener + that it has started. + + + + + Called by the to inform the listener + that it has Shutdown. + + + + + Called by the to inform the listener + that it has begun the shutdown sequence. + + + + + Called by the to inform the listener + that all jobs, triggers and calendars were deleted. + + + + + Get the for this + type's category. This should be used by subclasses for logging. + + + + + This interface should be implemented by any class whose instances are intended + to be executed by a thread. + + Marko Lahma (.NET) + + + + This method has to be implemented in order that starting of the thread causes the object's + run method to be called in that separately executing thread. + + + + + Create a JobRunShell instance with the given settings. + + The instance that should be made + available within the . + + + + + Initializes the job execution context with given scheduler and bundle. + + The scheduler. + + + + Requests the Shutdown. + + + + + This method has to be implemented in order that starting of the thread causes the object's + run method to be called in that separately executing thread. + + + + + Runs begin procedures on this instance. + + + + + Completes the execution. + + if set to true [successful execution]. + + + + Passivates this instance. + + + + + Completes the trigger retry loop. + + The trigger. + The job detail. + The inst code. + + + + + Vetoeds the job retry loop. + + The trigger. + The job detail. + The inst code. + + + + + Default concrete implementation of . + + + + + Client programs may be interested in the 'listener' interfaces that are + available from Quartz. The interface + provides notifications of Job executions. The + interface provides notifications of + firings. The + interface provides notifications of scheduler events and + errors. Listeners can be associated with local schedulers through the + interface. + + + + jhouse + 2.0 - previously listeners were managed directly on the Scheduler interface. + + + + Add the given to the, + and register it to receive events for Jobs that are matched by ANY of the + given Matchers. + + + If no matchers are provided, the will be used. + + + + + + + Add the given to the, + and register it to receive events for Jobs that are matched by ANY of the + given Matchers. + + + If no matchers are provided, the will be used. + + + + + + + Add the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the identified listener was found and updated + + + + Remove the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Set the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + Removes any existing matchers for the identified listener! + + the name of the listener to add the matcher to + the matchers to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Get the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the matchers registered for selecting events for the identified listener + + + + Remove the identified from the. + + + + true if the identified listener was found in the list, and removed. + + + + Get a List containing all of the s in + the. + + + + + Get the that has the given name. + + + + + Add the given to the, + and register it to receive events for Triggers that are matched by ANY of the + given Matchers. + + + If no matcher is provided, the will be used. + + + + + + + Add the given to the, + and register it to receive events for Triggers that are matched by ANY of the + given Matchers. + + + If no matcher is provided, the will be used. + + + + + + + Add the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the identified listener was found and updated + + + + Remove the given Matcher to the set of matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the additional matcher to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Set the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + Removes any existing matchers for the identified listener! + + the name of the listener to add the matcher to + the matchers to apply for selecting events + true if the given matcher was found and removed from the listener's list of matchers + + + + Get the set of Matchers for which the listener + will receive events if ANY of the matchers match. + + + + the name of the listener to add the matcher to + the matchers registered for selecting events for the identified listener + + + + Remove the identified from the. + + + + true if the identified listener was found in the list, and + removed. + + + + Get a List containing all of the s + in the. + + + + + Get the that has the given name. + + + + + Register the given with the + . + + + + + Remove the given from the + . + + + + true if the identified listener was found in the list, and removed. + + + + Get a List containing all of the s + registered with the. + + + + + This is the heart of Quartz, an indirect implementation of the + interface, containing methods to schedule s, + register instances, etc. + + + + + + James House + Marko Lahma (.NET) + + + + Remote scheduler service interface. + + Marko Lahma (.NET) + + + + Starts this instance. + + + + + Standbies this instance. + + + + + Shutdowns this instance. + + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Initializes the class. + + + + + Register the given with the + 's list of internal listeners. + + + + + + Remove the given from the + 's list of internal listeners. + + + true if the identified listener was found in the list, andremoved. + + + + Create a with the given configuration + properties. + + + + + + Bind the scheduler to remoting infrastructure. + + + + + Un-bind the scheduler from remoting infrastructure. + + + + + Adds an object that should be kept as reference to prevent + it from being garbage collected. + + The obj. + + + + Removes the object from garbae collection protected list. + + The obj. + + + + + Starts the 's threads that fire s. + + All s that have misfired will + be passed to the appropriate TriggerListener(s). + + + + + + Temporarily halts the 's firing of s. + + The scheduler is not destroyed, and can be re-started at any time. + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the QuartzScheduler. + Equivalent to . + + The scheduler cannot be re-started. + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the QuartzScheduler. + + The scheduler cannot be re-started. + + + + if the scheduler will not allow this method + to return until all currently executing jobs have completed. + + + + + Validates the state. + + + + + Add the identified by the given + to the Scheduler, and + associate the given with it. + + If the given Trigger does not reference any , then it + will be set to reference the Job passed with it into this method. + + + + + + Schedule the given with the + identified by the 's settings. + + + + + Add the given to the Scheduler - with no associated + . The will be 'dormant' until + it is scheduled with a , or + is called for it. + + The must by definition be 'durable', if it is not, + SchedulerException will be thrown. + + + + + + Delete the identified from the Scheduler - and any + associated s. + + true if the Job was found and deleted. + + + + Remove the indicated from the + scheduler. + + + + + Remove (delete) the with the + given name, and store the new given one - which must be associated + with the same job. + + the key of the trigger + The new to be stored. + + if a with the given + name and group was not found and removed from the store, otherwise + the first fire time of the newly scheduled trigger. + + + + + Creates a new positive random number + + The last random obtained + Returns a new positive random number + + + + Trigger the identified (Execute it now) - with a non-volatile trigger. + + + + + Store and schedule the identified + + + + + + Pause the with the given name. + + + + + Pause all of the s in the given group. + + + + + Pause the with the given + name - by pausing all of its current s. + + + + + Pause all of the s in the + given group - by pausing all of their s. + + + + + Resume (un-pause) the with the given + name. + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Resume (un-pause) all of the s in the + matching groups. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Gets the paused trigger groups. + + + + + + Resume (un-pause) the with + the given name. + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s + in the matching groups. + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + with a matcher matching all known groups. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + Get the names of all known groups. + + + + + Get the names of all the s in the + given group. + + + + + Get all s that are associated with the + identified . + + + + + Get the names of all known + groups. + + + + + Get the names of all the s in + the matching groups. + + + + + Get the for the + instance with the given name and group. + + + + + Get the instance with the given name and + group. + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Trigger exists with the given identifier + + + + Clears (deletes!) all scheduling data - all s, s + s. + + + + + Get the current state of the identified . + + + + + + Add (register) the given to the Scheduler. + + + + + Delete the identified from the Scheduler. + + true if the Calendar was found and deleted. + + + + Get the instance with the given name. + + + + + Get the names of all registered s. + + + + + Add the given to the + 's internal list. + + + + + + Remove the identified from the 's + list of internal listeners. + + + true if the identified listener was found in the list, and removed. + + + + Get the internal + that has the given name. + + + + + + + Add the given to the + 's internal list. + + + + + + Remove the identified from the 's + list of internal listeners. + + + true if the identified listener was found in the list, and removed. + + + + Get the internal that + has the given name. + + + + + + + Notifies the job store job complete. + + The trigger. + The detail. + The instruction code. + + + + Notifies the scheduler thread. + + + + + Notifies the trigger listeners about fired trigger. + + The job execution context. + + + + + Notifies the trigger listeners about misfired trigger. + + The trigger. + + + + Notifies the trigger listeners of completion. + + The job executution context. + The instruction code to report to triggers. + + + + Notifies the job listeners about job to be executed. + + The jec. + + + + Notifies the job listeners that job exucution was vetoed. + + The job execution context. + + + + Notifies the job listeners that job was executed. + + The jec. + The je. + + + + Notifies the scheduler listeners about scheduler error. + + The MSG. + The se. + + + + Notifies the scheduler listeners about job that was scheduled. + + The trigger. + + + + Notifies the scheduler listeners about job that was unscheduled. + + + + + Notifies the scheduler listeners about finalized trigger. + + The trigger. + + + + Notifies the scheduler listeners about paused trigger. + + The group. + + + + Notifies the scheduler listeners about paused trigger. + + + + + Notifies the scheduler listeners resumed trigger. + + The group. + + + + Notifies the scheduler listeners resumed trigger. + + + + + Notifies the scheduler listeners about paused job. + + + + + Notifies the scheduler listeners about paused job. + + The group. + + + + Notifies the scheduler listeners about resumed job. + + + + + Notifies the scheduler listeners about resumed job. + + The group. + + + + Notifies the scheduler listeners about scheduler shutdown. + + + + + Interrupt all instances of the identified InterruptableJob. + + + + + Interrupt all instances of the identified InterruptableJob executing in this Scheduler instance. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + + + + + + Obtains a lifetime service object to control the lifetime policy for this instance. + + + + + Gets the version of the Quartz Scheduler. + + The version. + + + + Gets the version major. + + The version major. + + + + Gets the version minor. + + The version minor. + + + + Gets the version iteration. + + The version iteration. + + + + Gets the scheduler signaler. + + The scheduler signaler. + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Gets or sets a value indicating whether to signal on scheduling change. + + + true if schduler should signal on scheduling change; otherwise, false. + + + + + Reports whether the is paused. + + + + + Gets the job store class. + + The job store class. + + + + Gets the thread pool class. + + The thread pool class. + + + + Gets the size of the thread pool. + + The size of the thread pool. + + + + Reports whether the has been Shutdown. + + + + + Return a list of objects that + represent all currently executing Jobs in this Scheduler instance. + + This method is not cluster aware. That is, it will only return Jobs + currently executing in this Scheduler instance, not across the entire + cluster. + + + Note that the list returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the true list of executing jobs may be different. + + + + + + Get a List containing all of the internal s + registered with the . + + + + + Gets or sets the job factory. + + The job factory. + + + + Gets the running since. + + The running since. + + + + Gets the number of jobs executed. + + The number of jobs executed. + + + + Gets a value indicating whether this scheduler supports persistence. + + true if supports persistence; otherwise, false. + + + + Get a List containing all of the s + in the 's internal list. + + + + + + Get a list containing all of the s + in the 's internal list. + + + + + Helper class to start scheduler in a delayed fashion. + + + + + ErrorLogger - Scheduler Listener Class + + + + + The interface to be implemented by classes that want to be informed when a + executes. In general, applications that use a + will not have use for this mechanism. + + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + is about to be executed (an associated + has occurred). + + This method will not be invoked if the execution of the Job was vetoed + by a . + + + + + + + Called by the when a + was about to be executed (an associated + has occurred), but a vetoed it's + execution. + + + + + + Called by the after a + has been executed, and be for the associated 's + method has been called. + + + + + Get the name of the . + + + + + Contains all of the resources (,, + etc.) necessary to create a instance. + + + James House + Marko Lahma (.NET) + + + + Gets the unique identifier. + + Name of the scheduler. + The scheduler instance id. + + + + + Gets the unique identifier. + + + + + + Add the given for the + to use. This method expects the plugin's + "initialize" method to be invoked externally (either before or after + this method is called). + + + + + + Get or set the name for the . + + + if name is null or empty. + + + + + Get or set the instance Id for the . + + + if name is null or empty. + + + + + Get or set the name for the . + + + if name is null or empty. + + + + + Get or set the for the + to use. + + + if threadPool is null. + + + + + Get or set the for the + to use. + + + if jobStore is null. + + + + + Get or set the for the + to use. + + + if jobRunShellFactory is null. + + + + + Get the of all s for the + to use. + + + + + + Gets or sets a value indicating whether to make scheduler thread daemon. + + + true if scheduler should be thread daemon; otherwise, false. + + + + + Gets or sets the scheduler exporter. + + The scheduler exporter. + + + + The ThreadExecutor which runs the QuartzSchedulerThread. + + + + + Gets or sets the batch time window. + + + + + The thread responsible for performing the work of firing + s that are registered with the . + + + + + James House + Marko Lahma (.NET) + + + + Support class used to handle threads + + Marko Lahma (.NET) + + + + The instance of System.Threading.Thread + + + + + Initializes a new instance of the QuartzThread class + + + + + Initializes a new instance of the Thread class. + + The name of the thread + + + + This method has no functionality unless the method is overridden + + + + + Causes the operating system to change the state of the current thread instance to ThreadState.Running + + + + + Interrupts a thread that is in the WaitSleepJoin thread state + + + + + Blocks the calling thread until a thread terminates + + + + + Obtain a string that represents the current object + + A string that represents the current object + + + + Gets or sets the name of the thread + + + + + Gets or sets a value indicating the scheduling priority of a thread + + + + + Gets or sets a value indicating whether or not a thread is a background thread. + + + + + Gets the randomized idle wait time. + + The randomized idle wait time. + + + + Construct a new for the given + as a non-daemon + with normal priority. + + + + + Construct a new for the given + as a with the given + attributes. + + + + + Signals the main processing loop to pause at the next possible point. + + + + + Signals the main processing loop to pause at the next possible point. + + + + + Signals the main processing loop that a change in scheduling has been + made - in order to interrupt any sleeping that may be occuring while + waiting for the fire time to arrive. + + + the time when the newly scheduled trigger + will fire. If this method is being called do to some other even (rather + than scheduling a trigger), the caller should pass null. + + + + + The main processing loop of the . + + + + + Trigger retry loop that is executed on error condition. + + The bndle. + + + + Releases the trigger retry loop. + + The trigger. + + + + Gets the log. + + The log. + + + + Sets the idle wait time. + + The idle wait time. + + + + Gets a value indicating whether this is paused. + + true if paused; otherwise, false. + + + + Gets or sets the db failure retry interval. + + The db failure retry interval. + + + + An interface to be used by instances in order to + communicate signals back to the . + + James House + Marko Lahma (.NET) + + + + An interface to be used by instances in order to + communicate signals back to the . + + James House + Marko Lahma (.NET) + + + + Notifies the scheduler about misfired trigger. + + The trigger that misfired. + + + + Notifies the scheduler about finalized trigger. + + The trigger that has finalized. + + + + Signals the scheduling change. + + + + + Notifies the scheduler about misfired trigger. + + The trigger that misfired. + + + + Notifies the scheduler about finalized trigger. + + The trigger that has finalized. + + + + Signals the scheduling change. + + + + + Metadata information about specific ADO.NET driver library. Metadata is used to + create correct types of object instances to interact with the underlying + database. + + Marko Lahma + + + + Initializes this instance. Parses information and initializes startup + values. + + + + + Gets the name of the parameter which includes the parameter prefix for this + database. + + Name of the parameter. + + + Gets or sets the name of the assembly that holds the connection library. + The name of the assembly. + + + + Gets or sets the name of the product. + + The name of the product. + + + + Gets or sets the type of the connection. + + The type of the connection. + + + + Gets or sets the type of the command. + + The type of the command. + + + + Gets or sets the type of the parameter. + + The type of the parameter. + + + + Gets the type of the command builder. + + The type of the command builder. + + + Gets the command builder's derive parameters method. + The command builder derive parameters method. + + + + Gets or sets the parameter name prefix. + + The parameter name prefix. + + + + Gets or sets the type of the exception that is thrown when using driver + library. + + The type of the exception. + + + + Gets or sets a value indicating whether parameters are bind by name when using + ADO.NET parameters. + + true if parameters are bind by name; otherwise, false. + + + Gets or sets the type of the database parameters. + The type of the parameter db. + + + + Gets the parameter db type property. + + The parameter db type property. + + + + Gets the parameter is nullable property. + + The parameter is nullable property. + + + + Gets or sets the type of the db binary column. This is a string representation of + Enum element because this information is database driver specific. + + The type of the db binary. + + + Gets the type of the db binary. + The type of the db binary. + + + + Sets the name of the parameter db type property. + + The name of the parameter db type property. + + + + Gets or sets a value indicating whether [use parameter name prefix in parameter collection]. + + + true if [use parameter name prefix in parameter collection]; otherwise, false. + + + + + Concrete implementation of . + + Marko Lahma + + + + Data access provider interface. + + Marko Lahma + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + A new Command Builder + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Shutdowns this instance. + + + + + Connection string used to create connections. + + + + + Registers DB metadata information for given provider name. + + + + + + + Initializes a new instance of the class. + + Name of the db provider. + The connection string. + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + A new Command Builder + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Shutdowns this instance. + + + + + Connection string used to create connections. + + + + + + Gets the metadata. + + The metadata. + + + + This interface can be implemented by any + class that needs to use the constants contained herein. + + Jeffrey Wescott + James House + Marko Lahma(.NET) + + + + Simple Trigger type. + + + + + Cron Trigger type. + + + + + Calendar Interval Trigger type. + + + + + Daily Time Interval Trigger type. + + + + + A general blob Trigger type. + + + + + This class contains utility functions for use in all delegate classes. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + Replace the table prefix in a query by replacing any occurrences of + "{0}" with the table prefix. + + The unsubstitued query + The table prefix + the scheduler name + The query, with proper table prefix substituted + + + + Common helper methods for working with ADO.NET. + + Marko Lahma + + + + Persist a CalendarIntervalTriggerImpl by converting internal fields to and from + SimplePropertiesTriggerProperties. + + + + + + + A base implementation of that persists + trigger fields in the "QRTZ_SIMPROP_TRIGGERS" table. This allows extending + concrete classes to simply implement a couple methods that do the work of + getting/setting the trigger's fields, and creating the + for the particular type of trigger. + + + jhouse + Marko Lahma (.NET) + + + + An interface which provides an implementation for storing a particular + type of 's extended properties. + + jhouse + + + + Initializes the persistence delegate. + + + + + Returns whether the trigger type can be handled by delegate. + + + + + Returns database discriminator value for trigger type. + + + + + Inserts trigger's special properties. + + + + + Updates trigger's special properties. + + + + + Deletes trigger's special properties. + + + + + Loads trigger's special properties. + + + + + Returns whether the trigger type can be handled by delegate. + + + + + Returns database discriminator value for trigger type. + + + + + Utility class to keep track of both active transaction + and connection. + + Marko Lahma + + + + Initializes a new instance of the class. + + The connection. + The transaction. + + + + Gets or sets the connection. + + The connection. + + + + Gets or sets the transaction. + + The transaction. + + + + Persist a CronTriggerImpl. + + + + + + + Persist a DailyTimeIntervalTrigger by converting internal fields to and from + SimplePropertiesTriggerProperties. + + + + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + + + + + + + Base class for database based lock handlers for providing thread/resource locking + in order to protect resources from being altered by multiple threads at the + same time. + + Marko Lahma (.NET) + + + + This class extends + to include the query string constants in use by the + class. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + An interface for providing thread/resource locking in order to protect + resources from being altered by multiple threads at the same time. + + James House + Marko Lahma (.NET) + + + + Grants a lock on the identified resource to the calling thread (blocking + until it is available). + + true if the lock was obtained. + + + + Release the lock on the identified resource if it is held by the calling + thread. + + + + + Determine whether the calling thread owns a lock on the identified + resource. + + + + + Whether this Semaphore implementation requires a database connection for + its lock management operations. + + + + + + + + Interface for Quartz objects that need to know what the table prefix of + the tables used by a ADO.NET JobStore is. + + Marko Lahma (.NET) + + + + Table prefix to use. + + + + + Initializes a new instance of the class. + + The table prefix. + the scheduler name + The SQL. + The default SQL. + The db provider. + + + + Execute the SQL that will lock the proper database row. + + + + + + + + + Grants a lock on the identified resource to the calling thread (blocking + until it is available). + + + + + true if the lock was obtained. + + + + Release the lock on the identified resource if it is held by the calling + thread. + + + + + + + Determine whether the calling thread owns a lock on the identified + resource. + + + + + + + + Gets or sets the lock owners. + + The lock owners. + + + + Gets the log. + + The log. + + + + This Semaphore implementation does use the database. + + + + + Gets or sets the table prefix. + + The table prefix. + + + + Initialization argumens holder for implementations. + + + + + Whether simple should be used (for serialization safety). + + + + + The logger to use during execution. + + + + + The prefix of all table names. + + + + + The instance's name. + + + + + The instance id. + + + + + The db provider. + + + + + The type loading strategy. + + + + + Object serializer and deserializer strategy to use. + + + + + Custom driver delegate initialization. + + + initStrings are of the format: + settingName=settingValue|otherSettingName=otherSettingValue|... + + + + + Conveys the state of a fired-trigger record. + + James House + Marko Lahma (.NET) + + + + Gets or sets the fire instance id. + + The fire instance id. + + + + Gets or sets the fire timestamp. + + The fire timestamp. + + + + Gets or sets a value indicating whether job disallows concurrent execution. + + + + + Gets or sets the job key. + + The job key. + + + + Gets or sets the scheduler instance id. + + The scheduler instance id. + + + + Gets or sets the trigger key. + + The trigger key. + + + + Gets or sets the state of the fire instance. + + The state of the fire instance. + + + + Gets or sets a value indicating whether [job requests recovery]. + + true if [job requests recovery]; otherwise, false. + + + + Gets or sets the priority. + + The priority. + + + + Service interface or modifying parameters + and resultset values. + + + + + Prepares a to be used to access database. + + Connection and tranasction pair + SQL to run + + + + + Adds a parameter to . + + Command to add parameter to + Parameter's name + Parameter's value + + + + Adds a parameter to . + + Command to add parameter to + Parameter's name + Parameter's value + Parameter's data type + + + + Gets the db presentation for boolean value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the boolean value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for date/time value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the date/time value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for time span value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the time span value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + This is the base interface for all driver delegate classes. + + + + This interface is very similar to the + interface except each method has an additional + parameter. + + + Unless a database driver has some extremely-DB-specific + requirements, any IDriverDelegate implementation classes should extend the + class. + + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + Initializes the driver delegate with configuration data. + + + + + + Update all triggers having one of the two given states, to the given new + state. + + The DB Connection + The new state for the triggers + The first old state to update + The second old state to update + Number of rows updated + + + + Get the names of all of the triggers that have misfired - according to + the given timestamp. + + The DB Connection + The timestamp. + An array of objects + + + + Get the names of all of the triggers in the given state that have + misfired - according to the given timestamp. + + The DB Connection + The state. + The time stamp. + An array of objects + + + + Get the names of all of the triggers in the given group and state that + have misfired - according to the given timestamp. + + The DB Connection + Name of the group. + The state. + The timestamp. + An array of objects + + + + Select all of the triggers for jobs that are requesting recovery. The + returned trigger objects will have unique "recoverXXX" trigger names and + will be in the trigger group. + + + In order to preserve the ordering of the triggers, the fire time will be + set from the ColumnFiredTime column in the TableFiredTriggers + table. The caller is responsible for calling + on each returned trigger. It is also up to the caller to insert the + returned triggers to ensure that they are fired. + + The DB Connection + An array of objects + + + + Delete all fired triggers. + + The DB Connection + The number of rows deleted + + + + Delete all fired triggers of the given instance. + + The DB Connection + The instance id. + The number of rows deleted + + + + Insert the job detail record. + + The DB Connection + The job to insert. + Number of rows inserted. + + + + Update the job detail record. + + The DB Connection. + The job to update. + Number of rows updated. + + + + Get the names of all of the triggers associated with the given job. + + + + The DB Connection + The key identifying the job. + + + + Delete the job detail record for the given job. + + The DB Connection + The key identifying the job. + the number of rows deleted + + + + Check whether or not the given job is stateful. + + The DB Connection + The key identifying the job. + true if the job exists and is stateful, false otherwise + + + + Check whether or not the given job exists. + + The DB Connection + The key identifying the job. + true if the job exists, false otherwise + + + + Update the job data map for the given job. + + The DB Connection + The job. + the number of rows updated + + + + Select the JobDetail object for a given job name / group name. + + The DB Connection + The key identifying the job. + The class load helper. + The populated JobDetail object + + + + Select the total number of jobs stored. + + The DB Connection + the total number of jobs stored + + + + Select all of the job group names that are stored. + + The DB Connection. + an array of group names + + + + Select all of the jobs contained in a given group. + + The DB Connection + + an array of job names + + + + Insert the base trigger data. + + The DB Connection + The trigger to insert. + The state that the trigger should be stored in. + The job detail. + The number of rows inserted + + + + Insert the blob trigger data. + + The DB Connection + The trigger to insert + The number of rows inserted + + + + Update the base trigger data. + + the DB Connection + The trigger. + The state. + The job detail. + the number of rows updated + + + + Update the blob trigger data. + + the DB Connection + The trigger. + the number of rows updated + + + + Check whether or not a trigger exists. + + the DB Connection + The key identifying the trigger. + the number of rows updated + + + + Update the state for a given trigger. + + The DB Connection + The key identifying the trigger. + The new state for the trigger. + the number of rows updated + + + + Update the given trigger to the given new state, if it is in the given + old state. + + The DB connection + The key identifying the trigger. + The new state for the trigger + The old state the trigger must be in + int the number of rows updated + + + + Update the given trigger to the given new state, if it is one of the + given old states. + + The DB connection + The key identifying the trigger. + The new state for the trigger + One of the old state the trigger must be in + One of the old state the trigger must be in + One of the old state the trigger must be in + + int the number of rows updated + + SQLException + + + + Update all triggers in the given group to the given new state, if they + are in one of the given old states. + + The DB connection + + The new state for the trigger + One of the old state the trigger must be in + One of the old state the trigger must be in + One of the old state the trigger must be in + The number of rows updated + + + + Update all of the triggers of the given group to the given new state, if + they are in the given old state. + + The DB connection + + The new state for the trigger group + The old state the triggers must be in. + int the number of rows updated + + + + Update the states of all triggers associated with the given job. + + The DB Connection + The key identifying the job. + The new state for the triggers. + The number of rows updated + + + + Update the states of any triggers associated with the given job, that + are the given current state. + + The DB Connection + The key identifying the job. + The new state for the triggers + The old state of the triggers + the number of rows updated + + + + Delete the BLOB trigger data for a trigger. + + The DB Connection + The key identifying the trigger. + The number of rows deleted + + + + Delete the base trigger data for a trigger. + + The DB Connection + The key identifying the trigger. + the number of rows deleted + + + + Select the number of triggers associated with a given job. + + The DB Connection + The key identifying the job. + the number of triggers for the given job + + + + Select the job to which the trigger is associated. + + The DB Connection + The key identifying the trigger. + The load helper. + + The object associated with the given trigger + + + + + Select the triggers for a job> + + The DB Connection + The key identifying the job. + an array of objects associated with a given job. + + + + Select the triggers for a calendar + + The DB Connection. + Name of the calendar. + + An array of objects associated with a given job. + + + + + Select a trigger. + + The DB Connection. + The key identifying the trigger. + The object. + + + + + Select a trigger's JobDataMap. + + The DB Connection. + The key identifying the trigger. + The of the Trigger, never null, but possibly empty. + + + + Select a trigger's state value. + + The DB Connection. + The key identifying the trigger. + The object. + + + + Select a triggers status (state and next fire time). + + The DB Connection. + The key identifying the trigger. + A object, or null + + + + Select the total number of triggers stored. + + The DB Connection. + The total number of triggers stored. + + + + Select all of the trigger group names that are stored. + + The DB Connection. + An array of group names. + + + + Select all of the triggers contained in a given group. + + The DB Connection. + + An array of trigger names. + + + + Select all of the triggers in a given state. + + The DB Connection. + The state the triggers must be in. + An array of trigger s. + + + + Inserts the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes all paused trigger groups. + + The conn. + + + + + Determines whether the specified trigger group is paused. + + The conn. + Name of the group. + + true if trigger group is paused; otherwise, false. + + + + + Selects the paused trigger groups. + + The DB Connection. + + + + + Determines whether given trigger group already exists. + + The conn. + Name of the group. + + true if trigger group exists; otherwise, false. + + + + + Insert a new calendar. + + The DB Connection. + The name for the new calendar. + The calendar. + The number of rows inserted. + + + + Update a calendar. + + The DB Connection. + The name for the new calendar. + The calendar. + The number of rows updated. + + + + Check whether or not a calendar exists. + + The DB Connection. + The name of the calendar. + true if the trigger exists, false otherwise. + + + + Select a calendar. + + The DB Connection. + The name of the calendar. + The Calendar. + + + + Check whether or not a calendar is referenced by any triggers. + + The DB Connection. + The name of the calendar. + true if any triggers reference the calendar, false otherwise + + + + Delete a calendar. + + The DB Connection + The name of the trigger. + The number of rows deleted. + + + + Select the total number of calendars stored. + + The DB Connection + The total number of calendars stored. + + + + Select all of the stored calendars. + + The DB Connection + An array of calendar names. + + + + Select the trigger that will be fired at the given fire time. + + The DB Connection + The time that the trigger will be fired. + + A representing the + trigger that will be fired at the given fire time, or null if no + trigger will be fired at that time + + + + + Insert a fired trigger. + + The DB Connection + The trigger. + The state that the trigger should be stored in. + The job detail. + The number of rows inserted. + + + + Select the states of all fired-trigger records for a given trigger, or + trigger group if trigger name is . + + The DB Connection + Name of the trigger. + Name of the group. + A list of FiredTriggerRecord objects. + + + + Select the states of all fired-trigger records for a given job, or job + group if job name is . + + The DB Connection + Name of the job. + Name of the group. + A List of FiredTriggerRecord objects. + + + + Select the states of all fired-trigger records for a given scheduler + instance. + + The DB Connection + Name of the instance. + A list of FiredTriggerRecord objects. + + + + Delete a fired trigger. + + The DB Connection + The fired trigger entry to delete. + The number of rows deleted. + + + + Get the number instances of the identified job currently executing. + + The DB Connection + The key identifying the job. + + The number instances of the identified job currently executing. + + + + + Insert a scheduler-instance state record. + + The DB Connection + The instance id. + The check in time. + The interval. + The number of inserted rows. + + + + Delete a scheduler-instance state record. + + The DB Connection + The instance id. + The number of deleted rows. + + + + Update a scheduler-instance state record. + + The DB Connection + The instance id. + The check in time. + The number of updated rows. + + + + A List of all current s. + + If instanceId is not null, then only the record for the identified + instance will be returned. + + + The DB Connection + The instance id. + + + + + Select the next trigger which will fire to fire between the two given timestamps + in ascending order of fire time, and then descending by priority. + + The conn. + highest value of of the triggers (exclusive) + highest value of of the triggers (inclusive) + maximum number of trigger keys allow to acquired in the returning list. + A (never null, possibly empty) list of the identifiers (Key objects) of the next triggers to be fired. + + + + Select the distinct instance names of all fired-trigger records. + + + This is useful when trying to identify orphaned fired triggers (a + fired trigger without a scheduler state record.) + + The conn. + + + + + Counts the misfired triggers in states. + + The conn. + The state1. + The ts. + + + + + Selects the misfired triggers in states. + + The conn. + The state1. + The ts. + The count. + The result list. + + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + Exception class for when a driver delegate cannot be found for a given + configuration, or lack thereof. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + Base class for exceptions thrown by the Quartz . + + + SchedulerExceptions may contain a reference to another + , which was the underlying cause of the SchedulerException. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The MSG. + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Initializes a new instance of the class. + + The cause. + + + + Initializes a new instance of the class. + + The MSG. + The cause. + + + + Creates and returns a string representation of the current exception. + + + A string representation of the current exception. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + is meant to be used in an application-server + or other software framework environment that provides + container-managed-transactions. No commit / rollback will be handled by this class. + + + If you need commit / rollback, use + instead. + + Jeffrey Wescott + James House + Srinivas Venkatarangaiah + Marko Lahma (.NET) + + + + Contains base functionality for ADO.NET-based JobStore implementations. + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + The interface to be implemented by classes that want to provide a + and storage mechanism for the + 's use. + + + Storage of s and s should be keyed + on the combination of their name and group for uniqueness. + + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Called by the QuartzScheduler to inform the that + the scheduler has started. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has been paused. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has resumed after being paused. + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Store the given and . + + The to be stored. + The to be stored. + ObjectAlreadyExistsException + + + + returns true if the given JobGroup is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Store the given . + + The to be stored. + + If , any existing in the + with the same name and group should be + over-written. + + + + + Remove (delete) the with the given + key, and any s that reference + it. + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + if a with the given name and + group was found and removed from the store. + + + + + Retrieve the for the given + . + + + The desired , or null if there is no match. + + + + + Store the given . + + The to be stored. + If , any existing in + the with the same name and group should + be over-written. + ObjectAlreadyExistsException + + + + Remove (delete) the with the given key. + + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + If removal of the results in an 'orphaned' + that is not 'durable', then the should be deleted + also. + + + + if a with the given + name and group was found and removed from the store. + + + + + Remove (delete) the with the + given name, and store the new given one - which must be associated + with the same job. + + The to be replaced. + The new to be stored. + + if a with the given + name and group was found and removed from the store. + + + + + Retrieve the given . + + + The desired , or null if there is no + match. + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a trigger exists with the given identifier + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + + Store the given . + + The name. + The to be stored. + If , any existing + in the with the same name and group + should be over-written. + If , any s existing + in the that reference an existing + Calendar with the same name with have their next fire time + re-computed with the new . + ObjectAlreadyExistsException + + + + Remove (delete) the with the + given name. + + + If removal of the would result in + s pointing to non-existent calendars, then a + will be thrown. + + The name of the to be removed. + + if a with the given name + was found and removed from the store. + + + + + Retrieve the given . + + The name of the to be retrieved. + + The desired , or null if there is no + match. + + + + + Get the number of s that are + stored in the . + + + + + + Get the number of s that are + stored in the . + + + + + + Get the number of s that are + stored in the . + + + + + + Get the names of all of the s that + have the given group name. + + If there are no jobs in the given group name, the result should be a + zero-length array (not ). + + + + + + + + Get the names of all of the s + that have the given group name. + + If there are no triggers in the given group name, the result should be a + zero-length array (not ). + + + + + + Get the names of all of the + groups. + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + + Get the names of all of the + groups. + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + + Get the names of all of the s + in the . + + + If there are no Calendars in the given group name, the result should be + a zero-length array (not ). + + + + + + Get all of the Triggers that are associated to the given Job. + + + If there are no matches, a zero-length array should be returned. + + + + + Get the current state of the identified . + + + + + + Pause the with the given key. + + + + + Pause all of the s in the + given group. + + + The JobStore should "remember" that the group is paused, and impose the + pause on any new triggers that are added to the group while the group is + paused. + + + + + Pause the with the given key - by + pausing all of its current s. + + + + + Pause all of the s in the given + group - by pausing all of their s. + + The JobStore should "remember" that the group is paused, and impose the + pause on any new jobs that are added to the group while the group is + paused. + + + + + + + + Resume (un-pause) the with the + given key. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + + Resume (un-pause) all of the s + in the given group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Gets the paused trigger groups. + + + + + + Resume (un-pause) the with the + given key. + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s in + the given group. + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + on every group. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + + Get a handle to the next trigger to be fired, and mark it as 'reserved' + by the calling scheduler. + + If > 0, the JobStore should only return a Trigger + that will fire no later than the time represented in this value as + milliseconds. + + + + + + + + + Inform the that the scheduler no longer plans to + fire the given , that it had previously acquired + (reserved). + + + + + Inform the that the scheduler is now firing the + given (executing its associated ), + that it had previously acquired (reserved). + + + May return null if all the triggers or their calendars no longer exist, or + if the trigger was not successfully put into the 'executing' + state. Preference is to return an empty list if none of the triggers + could be fired. + + + + + Inform the that the scheduler has completed the + firing of the given (and the execution its + associated ), and that the + in the given should be updated if the + is stateful. + + + + + Indicates whether job store supports persistence. + + + + + + How long (in milliseconds) the implementation + estimates that it will take to release a trigger and acquire a new one. + + + + + Whether or not the implementation is clustered. + + + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + Tells the JobStore the pool size used to execute jobs. + + + + + Initializes a new instance of the class. + + + + + Gets the connection and starts a new transaction. + + + + + + Called by the QuartzScheduler before the is + used, in order to give it a chance to Initialize. + + + + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has been paused. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has resumed after being paused. + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Will recover any failed or misfired jobs and clean up the data store as + appropriate. + + + + + Will recover any failed or misfired jobs and clean up the data store as + appropriate. + + + + + Store the given and . + + Job to be stored. + Trigger to be stored. + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Stores the given . + + The to be stored. + + If , any existing in the + with the same name & group should be over-written. + + + + + Insert or update a job. + + + + + + Check existence of a given job. + + + + + Store the given . + + The to be stored. + + If , any existing in + the with the same name & group should + be over-written. + + + if a with the same name/group already + exists, and replaceExisting is set to false. + + + + + Insert or update a trigger. + + + + + Check existence of a given trigger. + + + + + Remove (delete) the with the given + name, and any s that reference + it. + + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + if a with the given name & + group was found and removed from the store. + + + + + Delete a job and its listeners. + + + + + + + Delete a trigger, its listeners, and its Simple/Cron/BLOB sub-table entry. + + + + + + + + Retrieve the for the given + . + + The key identifying the job. + The desired , or null if there is no match. + + + + Remove (delete) the with the + given name. + + + + + If removal of the results in an empty group, the + group should be removed from the 's list of + known group names. + + + + If removal of the results in an 'orphaned' + that is not 'durable', then the should be deleted + also. + + + The key identifying the trigger. + + if a with the given + name & group was found and removed from the store. + + + + + + + + Retrieve the given . + + The key identifying the trigger. + The desired , or null if there is no match. + + + + Get the current state of the identified . + + + + + + + + + + Gets the state of the trigger. + + The conn. + The key identifying the trigger. + + + + + Store the given . + + The name of the calendar. + The to be stored. + + If , any existing + in the with the same name & group + should be over-written. + + + + if a with the same name already + exists, and replaceExisting is set to false. + + + + + Remove (delete) the with the given name. + + + If removal of the would result in + s pointing to non-existent calendars, then a + will be thrown. + + The name of the to be removed. + + if a with the given name + was found and removed from the store. + + + + + Retrieve the given . + + The name of the to be retrieved. + The desired , or null if there is no match. + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the names of all of the s that + have the given group name. + + + If there are no jobs in the given group name, the result should be a + zero-length array (not ). + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + + + the identifier to check for + true if a Trigger exists with the given identifier + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + + Get the names of all of the s + that have the given group name. + + + If there are no triggers in the given group name, the result should be a + zero-length array (not ). + + + + + Get the names of all of the + groups. + + + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + Get the names of all of the + groups. + + + + If there are no known group names, the result should be a zero-length + array (not ). + + + + + Get the names of all of the s + in the . + + + If there are no Calendars in the given group name, the result should be + a zero-length array (not ). + + + + + Get all of the Triggers that are associated to the given Job. + + + If there are no matches, a zero-length array should be returned. + + + + + Pause the with the given name. + + + + + Pause the with the given name. + + + + + Pause the with the given name - by + pausing all of its current s. + + + + + + Pause all of the s in the given + group - by pausing all of their s. + + + + + + Determines if a Trigger for the given job should be blocked. + State can only transition to StatePausedBlocked/StateBlocked from + StatePaused/StateWaiting respectively. + + StatePausedBlocked, StateBlocked, or the currentState. + + + + Resume (un-pause) the with the + given name. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + Resume (un-pause) the with the + given name. + + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s in + the given group. + + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all of the s in the given group. + + + + + + Pause all of the s in the given group. + + + + + Pause all of the s in the + given group. + + + + + Resume (un-pause) all of the s + in the given group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + on every group. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + Get a handle to the next N triggers to be fired, and mark them as 'reserved' + by the calling scheduler. + + + + + + Inform the that the scheduler no longer plans to + fire the given , that it had previously acquired + (reserved). + + + + + Inform the that the scheduler has completed the + firing of the given (and the execution its + associated ), and that the + in the given should be updated if the + is stateful. + + + + + Get a list of all scheduler instances in the cluster that may have failed. + This includes this scheduler if it is checking in for the first time. + + + + + Create dummy objects for fired triggers + that have no scheduler state record. Checkin timestamp and interval are + left as zero on these dummy objects. + + + List of all current s + + + + Cleanup the given database connection. This means restoring + any modified auto commit or transaction isolation connection + attributes, and then closing the underlying connection. + + + + This is separate from closeConnection() because the Spring + integration relies on being able to overload closeConnection() and + expects the same connection back that it originally returned + from the datasource. + + + + + + Closes the supplied connection. + + (Optional) + + + + Rollback the supplied connection. + + (Optional) + + JobPersistenceException thrown if a SQLException occurs when the + connection is rolled back + + + + + Commit the supplied connection. + + The CTH. + if set to true opens a new transaction. + JobPersistenceException thrown if a SQLException occurs when the + + + + Execute the given callback in a transaction. Depending on the JobStore, + the surrounding transaction may be assumed to be already present + (managed). + + + This method just forwards to ExecuteInLock() with a null lockName. + + + + + + Execute the given callback having acquired the given lock. + Depending on the JobStore, the surrounding transaction may be + assumed to be already present (managed). This version is just a + handy wrapper around executeInLock that doesn't require a return + value. + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a transaction. + + + The callback to excute after having acquired the given lock. + + + + + + Execute the given callback having acquired the given lock. + Depending on the JobStore, the surrounding transaction may be + assumed to be already present (managed). + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a transaction. + + + The callback to excute after having acquired the given lock. + + + + + Execute the given callback having optionally acquired the given lock. + This uses the non-managed transaction connection. This version is just a + handy wrapper around executeInNonManagedTXLock that doesn't require a return + value. + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a non-managed transaction. + + + + The callback to excute after having acquired the given lock. + + + + + Execute the given callback having optionally acquired the given lock. + This uses the non-managed transaction connection. + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + lockCallback is still executed in a non-managed transaction. + + + The callback to excute after having acquired the given lock. + + + + + Get or set the datasource name. + + + + + Gets the log. + + The log. + + + + Get or sets the prefix that should be pre-pended to all table names. + + + + + Set whether string-only properties will be handled in JobDataMaps. + + + + + Get or set the instance Id of the Scheduler (must be unique within a cluster). + + + + + Get or set the instance Id of the Scheduler (must be unique within this server instance). + + + + + Get or set whether this instance is part of a cluster. + + + + + Get or set the frequency at which this instance "checks-in" + with the other instances of the cluster. -- Affects the rate of + detecting failed instances. + + + + + Get or set the maximum number of misfired triggers that the misfire handling + thread will try to recover at one time (within one transaction). The + default is 20. + + + + + Gets or sets the database retry interval. + + The db retry interval. + + + + Get or set whether this instance should use database-based thread + synchronization. + + + + + Whether or not to obtain locks when inserting new jobs/triggers. + Defaults to , which is safest - some db's (such as + MS SQLServer) seem to require this to avoid deadlocks under high load, + while others seem to do fine without. + + + Setting this property to will provide a + significant performance increase during the addition of new jobs + and triggers. + + + + + The time span by which a trigger must have missed its + next-fire-time, in order for it to be considered "misfired" and thus + have its misfire instruction applied. + + + + + Don't call set autocommit(false) on connections obtained from the + DataSource. This can be helpfull in a few situations, such as if you + have a driver that complains if it is called when it is already off. + + + + + Set the transaction isolation level of DB connections to sequential. + + + + + Whether or not the query and update to acquire a Trigger for firing + should be performed after obtaining an explicit DB lock (to avoid + possible race conditions on the trigger's db row). This is + is considered unnecessary for most databases (due to the nature of + the SQL update that is performed), and therefore a superfluous performance hit. + + + However, if batch acquisition is used, it is important for this behavior + to be used for all dbs. + + + + + Get or set the ADO.NET driver delegate class name. + + + + + The driver delegate's initialization string. + + + + + set the SQL statement to use to select and lock a row in the "locks" + table. + + + + + + Get whether the threads spawned by this JobStore should be + marked as daemon. Possible threads include the + and the . + + + + + + Get whether to check to see if there are Triggers that have misfired + before actually acquiring the lock to recover them. This should be + set to false if the majority of the time, there are are misfired + Triggers. + + + + + + Get the driver delegate for DB operations. + + + + + Get whether String-only properties will be handled in JobDataMaps. + + + + + Indicates whether this job store supports persistence. + + + + + + + An interface for classes wishing to provide the service of loading classes + and resources within the scheduler... + + James House + Marko Lahma (.NET) + + + + Called to give the ClassLoadHelper a chance to Initialize itself, + including the oportunity to "steal" the class loader off of the calling + thread, which is the thread that is initializing Quartz. + + + + + Return the class with the given name. + + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a java.net.URL object + + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a java.io.InputStream object + + + + + Helper class for returning the composite result of trying + to recover misfired jobs. + + + + + Initializes a new instance of the class. + + if set to true [has more misfired triggers]. + The processed misfired trigger count. + + + + + Gets a value indicating whether this instance has more misfired triggers. + + + true if this instance has more misfired triggers; otherwise, false. + + + + + Gets the processed misfired trigger count. + + The processed misfired trigger count. + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Gets the non managed TX connection. + + + + + + Execute the given callback having optionally acquired the given lock. + Because CMT assumes that the connection is already part of a managed + transaction, it does not attempt to commit or rollback the + enclosing transaction. + + + + + + + The name of the lock to acquire, for example + "TRIGGER_ACCESS". If null, then no lock is acquired, but the + txCallback is still executed in a transaction. + + Callback to execute. + + + + is meant to be used in a standalone environment. + Both commit and rollback will be handled by this class. + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + + + For , the non-managed TX connection is just + the normal connection because it is not CMT. + + + + + + Execute the given callback having optionally aquired the given lock. + For , because it manages its own transactions + and only has the one datasource, this is the same behavior as + . + + + The name of the lock to aquire, for example "TRIGGER_ACCESS". + If null, then no lock is aquired, but the lockCallback is still + executed in a transaction. + + Callback to execute. + + + + + + + + + Exception class for when there is a failure obtaining or releasing a + resource lock. + + + James House + Marko Lahma (.NET) + + + + An exception that is thrown to indicate that there has been a failure in the + scheduler's underlying persistence mechanism. + + James House + Marko Lahma (.NET) + + + + Create a with the given message. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Create a with the given message + and cause. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + This is a driver delegate for the MySQL ADO.NET driver. + + Marko Lahma + + + + This is meant to be an abstract base class for most, if not all, + implementations. Subclasses should override only those methods that need + special handling for the DBMS driver in question. + + Jeffrey Wescott + James House + Marko Lahma (.NET) + + + + Initializes the driver delegate. + + + + + Insert the job detail record. + + the DB Connection + the new state for the triggers + the first old state to update + the second old state to update + number of rows updated + + + + Get the names of all of the triggers that have misfired. + + the DB Connection + The ts. + an array of objects + + + + Select all of the triggers in a given state. + + The DB Connection + The state the triggers must be in + an array of trigger s + + + + Get the names of all of the triggers in the given state that have + misfired - according to the given timestamp. + + The DB Connection + The state. + The time stamp. + An array of objects + + + + Get the names of all of the triggers in the given state that have + misfired - according to the given timestamp. No more than count will + be returned. + + The conn. + The state1. + The ts. + The most misfired triggers to return, negative for all + + Output parameter. A List of objects. Must not be null + + Whether there are more misfired triggers left to find beyond the given count. + + + + Get the number of triggers in the given state that have + misfired - according to the given timestamp. + + + + + + + + + Get the names of all of the triggers in the given group and state that + have misfired. + + The DB Connection + Name of the group. + The state. + The timestamp. + an array of objects + + + + Select all of the triggers for jobs that are requesting recovery. The + returned trigger objects will have unique "recoverXXX" trigger names and + will be in the + trigger group. + + + In order to preserve the ordering of the triggers, the fire time will be + set from the ColumnFiredTime column in the TableFiredTriggers + table. The caller is responsible for calling + on each returned trigger. It is also up to the caller to insert the + returned triggers to ensure that they are fired. + + The DB Connection + an array of objects + + + + Delete all fired triggers. + + The DB Connection. + The number of rows deleted. + + + + Delete all fired triggers of the given instance. + + The DB Connection + The instance id. + The number of rows deleted + + + + Clear (delete!) all scheduling data - all s, s + s. + + + + + + + Insert the job detail record. + + The DB Connection. + The job to insert. + Number of rows inserted. + + + + Gets the db presentation for boolean value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the boolean value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for date/time value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the date/time value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Gets the db presentation for time span value. Subclasses can overwrite this behaviour. + + Value to map to database. + + + + + Gets the time span value from db presentation. Subclasses can overwrite this behaviour. + + Value to map from database. + + + + + Update the job detail record. + + The DB Connection. + The job to update. + Number of rows updated. + + + + Get the names of all of the triggers associated with the given job. + + The DB Connection. + The key identifying the job. + An array of objects + + + + Delete the job detail record for the given job. + + the DB Connection + The key identifying the job. + the number of rows deleted + + + + Check whether or not the given job is stateful. + + the DB Connection + The key identifying the job. + + true if the job exists and is stateful, false otherwise + + + + + Check whether or not the given job exists. + + the DB Connection + The key identifying the job. + true if the job exists, false otherwise + + + + Update the job data map for the given job. + + The conn. + the job to update + the number of rows updated + + + + Select the JobDetail object for a given job name / group name. + + The DB Connection. + The key identifying the job. + The load helper. + The populated JobDetail object. + + + build Map from java.util.Properties encoding. + + + + Select the total number of jobs stored. + + The DB Connection. + The total number of jobs stored. + + + + Select all of the job group names that are stored. + + The DB Connection. + An array of group names. + + + + Select all of the jobs contained in a given group. + + The DB Connection. + + An array of job names. + + + + Insert the base trigger data. + + the DB Connection + the trigger to insert + the state that the trigger should be stored in + The job detail. + the number of rows inserted + + + + Insert the blob trigger data. + + The DB Connection. + The trigger to insert. + The number of rows inserted. + + + + Update the base trigger data. + + The DB Connection. + The trigger to insert. + The state that the trigger should be stored in. + The job detail. + The number of rows updated. + + + + Update the blob trigger data. + + The DB Connection. + The trigger to insert. + The number of rows updated. + + + + Check whether or not a trigger exists. + + The DB Connection. + the key of the trigger + true if the trigger exists, false otherwise + + + + Update the state for a given trigger. + + The DB Connection. + the key of the trigger + The new state for the trigger. + The number of rows updated. + + + + Update the given trigger to the given new state, if it is one of the + given old states. + + The DB connection. + the key of the trigger + The new state for the trigger. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + The number of rows updated. + + + + Update all triggers in the given group to the given new state, if they + are in one of the given old states. + + The DB connection. + + The new state for the trigger. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + One of the old state the trigger must be in. + The number of rows updated. + + + + Update the given trigger to the given new state, if it is in the given + old state. + + the DB connection + the key of the trigger + the new state for the trigger + the old state the trigger must be in + int the number of rows updated + + + + Update all of the triggers of the given group to the given new state, if + they are in the given old state. + + the DB connection + + the new state for the trigger group + the old state the triggers must be in + int the number of rows updated + + + + Update the states of all triggers associated with the given job. + + the DB Connection + the key of the job + the new state for the triggers + the number of rows updated + + + + Updates the state of the trigger states for job from other. + + The conn. + Key of the job. + The state. + The old state. + + + + + Delete the cron trigger data for a trigger. + + the DB Connection + the key of the trigger + the number of rows deleted + + + + Delete the base trigger data for a trigger. + + the DB Connection + the key of the trigger + the number of rows deleted + + + + Select the number of triggers associated with a given job. + + the DB Connection + the key of the job + the number of triggers for the given job + + + + Select the job to which the trigger is associated. + + the DB Connection + the key of the trigger + The load helper. + The object associated with the given trigger + + + + Select the triggers for a job + + the DB Connection + the key of the job + + an array of objects + associated with a given job. + + + + + Select the triggers for a calendar + + The DB Connection. + Name of the calendar. + + An array of objects associated with a given job. + + + + + Select a trigger. + + the DB Connection + the key of the trigger + The object + + + + Select a trigger's JobDataMap. + + the DB Connection + the key of the trigger + The of the Trigger, never null, but possibly empty. + + + + Select a trigger's state value. + + the DB Connection + the key of the trigger + The object + + + + Select a trigger status (state and next fire time). + + the DB Connection + the key of the trigger + + a object, or null + + + + + Select the total number of triggers stored. + + the DB Connection + the total number of triggers stored + + + + Select all of the trigger group names that are stored. + + the DB Connection + + an array of group names + + + + + Select all of the triggers contained in a given group. + + the DB Connection + + + an array of trigger names + + + + + Inserts the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes the paused trigger group. + + The conn. + Name of the group. + + + + + Deletes all paused trigger groups. + + The conn. + + + + + Determines whether the specified trigger group is paused. + + The conn. + Name of the group. + + true if trigger group is paused; otherwise, false. + + + + + Determines whether given trigger group already exists. + + The conn. + Name of the group. + + true if trigger group exists; otherwise, false. + + + + + Insert a new calendar. + + the DB Connection + The name for the new calendar. + The calendar. + the number of rows inserted + IOException + + + + Update a calendar. + + the DB Connection + The name for the new calendar. + The calendar. + the number of rows updated + IOException + + + + Check whether or not a calendar exists. + + the DB Connection + The name of the calendar. + + true if the trigger exists, false otherwise + + + + + Select a calendar. + + the DB Connection + The name of the calendar. + the Calendar + ClassNotFoundException + IOException + + + + Check whether or not a calendar is referenced by any triggers. + + the DB Connection + The name of the calendar. + + true if any triggers reference the calendar, false otherwise + + + + + Delete a calendar. + + the DB Connection + The name of the trigger. + the number of rows deleted + + + + Select the total number of calendars stored. + + the DB Connection + the total number of calendars stored + + + + Select all of the stored calendars. + + the DB Connection + + an array of calendar names + + + + + Select the trigger that will be fired at the given fire time. + + the DB Connection + the time that the trigger will be fired + + a representing the + trigger that will be fired at the given fire time, or null if no + trigger will be fired at that time + + + + + Select the next trigger which will fire to fire between the two given timestamps + in ascending order of fire time, and then descending by priority. + + The conn. + highest value of of the triggers (exclusive) + highest value of of the triggers (inclusive) + maximum number of trigger keys allow to acquired in the returning list. + A (never null, possibly empty) list of the identifiers (Key objects) of the next triggers to be fired. + + + + Insert a fired trigger. + + the DB Connection + the trigger + the state that the trigger should be stored in + The job. + the number of rows inserted + + + + + Update a fired trigger. + + + + + + the DB Connection + + the trigger + + + the state that the trigger should be stored in + the number of rows inserted + + + + Select the states of all fired-trigger records for a given trigger, or + trigger group if trigger name is . + + The DB connection. + Name of the trigger. + Name of the group. + a List of objects. + + + + Select the states of all fired-trigger records for a given job, or job + group if job name is . + + The DB connection. + Name of the job. + Name of the group. + a List of objects. + + + + Select the states of all fired-trigger records for a given scheduler + instance. + + The DB Connection + Name of the instance. + A list of FiredTriggerRecord objects. + + + + Select the distinct instance names of all fired-trigger records. + + The conn. + + + This is useful when trying to identify orphaned fired triggers (a + fired trigger without a scheduler state record.) + + + + + Delete a fired trigger. + + the DB Connection + the fired trigger entry to delete + the number of rows deleted + + + + Selects the job execution count. + + The DB connection. + The key of the job. + + + + + Inserts the state of the scheduler. + + The conn. + The instance id. + The check in time. + The interval. + + + + + Deletes the state of the scheduler. + + The database connection. + The instance id. + + + + + Updates the state of the scheduler. + + The database connection. + The instance id. + The check in time. + + + + + A List of all current s. + + If instanceId is not null, then only the record for the identified + instance will be returned. + + + The DB Connection + The instance id. + + + + + Replace the table prefix in a query by replacing any occurrences of + "{0}" with the table prefix. + + The unsubstitued query + The query, with proper table prefix substituted + + + + Create a serialized version of an Object. + + the object to serialize + Serialized object as byte array. + + + + Remove the transient data from and then create a serialized + version of a and returns the underlying bytes. + + The data. + the serialized data as byte array + + + + serialize + + The data. + + + + + Convert the JobDataMap into a list of properties. + + + + + Convert the JobDataMap into a list of properties. + + + + + This method should be overridden by any delegate subclasses that need + special handling for BLOBs. The default implementation uses standard + ADO.NET operations. + + The data reader, already queued to the correct row. + The column index for the BLOB. + The deserialized object from the DataReader BLOB. + + + + This method should be overridden by any delegate subclasses that need + special handling for BLOBs for job details. + + The result set, already queued to the correct row. + The column index for the BLOB. + The deserialized Object from the ResultSet BLOB. + + + + Selects the paused trigger groups. + + The DB Connection. + + + + + Gets the select next trigger to acquire SQL clause. + MySQL version with LIMIT support. + + + + + + Exception class for when a driver delegate cannot be found for a given + configuration, or lack thereof. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + This is a driver delegate for the Oracle database. + + Marko Lahma + + + + Creates the SQL for select next trigger to acquire. + + + + + Gets the db presentation for boolean value. For Oracle we use true/false of "1"/"0". + + Value to map to database. + + + + + Conveys a scheduler-instance state record. + + James House + Marko Lahma (.NET) + + + + Gets or sets the checkin interval. + + The checkin interval. + + + + Gets or sets the checkin timestamp. + + The checkin timestamp. + + + + Gets or sets the scheduler instance id. + + The scheduler instance id. + + + + Internal in-memory lock handler for providing thread/resource locking in + order to protect resources from being altered by multiple threads at the + same time. + + James House + Marko Lahma (.NET) + + + + Grants a lock on the identified resource to the calling thread (blocking + until it is available). + + True if the lock was obtained. + + + Release the lock on the identified resource if it is held by the calling + thread. + + + + + Determine whether the calling thread owns a lock on the identified + resource. + + + + + Gets the thread locks. + + The thread locks. + + + + Whether this Semaphore implementation requires a database connection for + its lock management operations. + + + + + + + + + This is a driver delegate for the SQLiteDelegate ADO.NET driver. + + Marko Lahma + + + + Gets the select next trigger to acquire SQL clause. + SQLite version with LIMIT support. + + + + + + A SQL Server specific driver delegate. + + Marko Lahma + + + + Gets the select next trigger to acquire SQL clause. + SQL Server specific version with TOP functionality + + + + + + Internal database based lock handler for providing thread/resource locking + in order to protect resources from being altered by multiple threads at the + same time. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The table prefix. + the scheduler name + The select with lock SQL. + + + + + Execute the SQL select for update that will lock the proper database row. + + + + + Property name and value holder for trigger state data. + + + + + Object representing a job or trigger key. + + James House + Marko Lahma (.NET) + + + + Construct a new TriggerStatus with the status name and nextFireTime. + + The trigger's status + The next time trigger will fire + + + + Return the string representation of the TriggerStatus. + + + + + + Provide thread/resource locking in order to protect + resources from being altered by multiple threads at the same time using + a db row update. + + + + Note: This Semaphore implementation is useful for databases that do + not support row locking via "SELECT FOR UPDATE" or SQL Server's type syntax. + + + As of Quartz.NET 2.0 version there is no need to use this implementation for + SQL Server databases. + + + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Execute the SQL that will lock the proper database row. + + + + + + + + + This implementation of the Calendar excludes a set of days of the year. You + may use it to exclude bank holidays which are on the same date every year. + + + + Juergen Donnerstag + Marko Lahma (.NET) + + + + This implementation of the Calendar may be used (you don't have to) as a + base class for more sophisticated one's. It merely implements the base + functionality required by each Calendar. + + + Regarded as base functionality is the treatment of base calendars. Base + calendar allow you to chain (stack) as much calendars as you may need. For + example to exclude weekends you may use WeeklyCalendar. In order to exclude + holidays as well you may define a WeeklyCalendar instance to be the base + calendar for HolidayCalendar instance. + + + Juergen Donnerstag + James House + Marko Lahma (.NET) + + + + An interface to be implemented by objects that define spaces of time during + which an associated may (not) fire. Calendars + do not define actual fire times, but rather are used to limit a + from firing on its normal schedule if necessary. Most + Calendars include all times by default and allow the user to specify times + to exclude. + + + As such, it is often useful to think of Calendars as being used to exclude a block + of time - as opposed to include a block of time. (i.e. the + schedule "fire every five minutes except on Sundays" could be + implemented with a and a + which excludes Sundays) + + Implementations MUST take care of being properly cloneable and Serializable. + + + James House + Juergen Donnerstag + Marko Lahma (.NET) + + + + Determine whether the given UTC time is 'included' by the + Calendar. + + + + + Determine the next UTC time that is 'included' by the + Calendar after the given UTC time. + + + + + Gets or sets a description for the instance - may be + useful for remembering/displaying the purpose of the calendar, though + the description has no meaning to Quartz. + + + + + Set a new base calendar or remove the existing one. + Get the base calendar. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The base calendar. + + + + Initializes a new instance of the class. + + The time zone. + + + + Initializes a new instance of the class. + + The base calendar. + The time zone. + + + + Serialization constructor. + + + + + + + checks whether two arrays have + the same length and + for any given place there are equal elements + in both arrays + + + + + + Get the base calendar. Will be null, if not set. + + + + + Check if date/time represented by timeStamp is included. If included + return true. The implementation of BaseCalendar simply calls the base + calendars IsTimeIncluded() method if base calendar is set. + + + + + + Determine the next UTC time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return 0 if all days are excluded. + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Gets or sets the time zone. + + The time zone. + + + + Gets or sets the description given to the instance by + its creator (if any). + + + + + Set a new base calendar or remove the existing one + + + + + + Constructor + + + + + Constructor + + The base calendar. + + + + Serialization constructor. + + + + + + + Return true, if day is defined to be exluded. + + + + + Redefine a certain day to be excluded (true) or included (false). + + + + + Determine whether the given UTC time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next UTC time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStampUtc is + included. Return 0 if all days are excluded. + + Note that this Calendar is only has full-day precision. + + + + + + Get or the array which defines the exclude-value of each day of month. + Setting will redefine the array of days excluded. The array must of size greater or + equal 31. + + + + + This implementation of the Calendar excludes the set of times expressed by a + given CronExpression. + + + For example, you could use this calendar to exclude all but business hours (8AM - 5PM) every + day using the expression "* * 0-7,18-23 ? * *". + + It is important to remember that the cron expression here describes a set of + times to be excluded from firing. Whereas the cron expression in + CronTrigger describes a set of times that can + be included for firing. Thus, if a has a + given cron expression and is associated with a with + the same expression, the calendar will exclude all the times the + trigger includes, and they will cancel each other out. + + + Aaron Craven + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + a string representation of the desired cron expression + + + + Create a with the given cron expression and + . + + + the base calendar for this calendar instance + see BaseCalendar for more information on base + calendar functionality + + a string representation of the desired cron expression + + + + Create a with the given cron expression and + . + + + the base calendar for this calendar instance + see BaseCalendar for more information on base + calendar functionality + + a string representation of the desired cron expression + + + + + Serialization constructor. + + + + + + + Determine whether the given time is 'included' by the + Calendar. + + the time to test + a boolean indicating whether the specified time is 'included' by the CronCalendar + + + + Determine the next time that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return 0 if all days are excluded. + + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Sets the cron expression for the calendar to a new value. + + The expression. + + + + Returns the object representation of the cron expression that defines the + dates and times this calendar excludes. + + + + + This implementation of the Calendar excludes (or includes - see below) a + specified time range each day. + + + For example, you could use this calendar to + exclude business hours (8AM - 5PM) every day. Each + only allows a single time range to be specified, and that time range may not + * cross daily boundaries (i.e. you cannot specify a time range from 8PM - 5AM). + If the property is (default), + the time range defines a range of times in which triggers are not allowed to + * fire. If is , the time range + is inverted: that is, all times outside the defined time range + are excluded. + + Note when using , it behaves on the same principals + as, for example, WeeklyCalendar defines a set of days that are + excluded every week. Likewise, defines a + set of times that are excluded every day. + + + Mike Funk + Aaron Craven + Marko Lahma (.NET) + + + + Create a with a time range defined by the + specified strings and no baseCalendar. + and + must be in the format "HH:MM[:SS[:mmm]]" where: +
    +
  • + HH is the hour of the specified time. The hour should be + specified using military (24-hour) time and must be in the range + 0 to 23. +
  • +
  • + MM is the minute of the specified time and must be in the range + 0 to 59. +
  • +
  • + SS is the second of the specified time and must be in the range + 0 to 59. +
  • +
  • + mmm is the millisecond of the specified time and must be in the + range 0 to 999. +
  • +
  • items enclosed in brackets ('[', ']') are optional.
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+
+ + + Create a with a time range defined by the + specified strings and the specified baseCalendar. + and + must be in the format "HH:MM[:SS[:mmm]]" where: +
    +
  • + HH is the hour of the specified time. The hour should be + specified using military (24-hour) time and must be in the range + 0 to 23. +
  • +
  • + MM is the minute of the specified time and must be in the range + 0 to 59. +
  • +
  • + SS is the second of the specified time and must be in the range + 0 to 59. +
  • +
  • + mmm is the millisecond of the specified time and must be in the + range 0 to 999. +
  • +
  • + items enclosed in brackets ('[', ']') are optional. +
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+ The base calendar for this calendar instance see BaseCalendar for more + information on base calendar functionality. +
+ + + Create a with a time range defined by the + specified values and no baseCalendar. Values are subject to + the following validations: +
    +
  • + Hours must be in the range 0-23 and are expressed using military + (24-hour) time. +
  • +
  • Minutes must be in the range 0-59
  • +
  • Seconds must be in the range 0-59
  • +
  • Milliseconds must be in the range 0-999
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+ The range starting hour of day. + The range starting minute. + The range starting second. + The range starting millis. + The range ending hour of day. + The range ending minute. + The range ending second. + The range ending millis. +
+ + + Create a with a time range defined by the + specified values and the specified . Values are + subject to the following validations: +
    +
  • + Hours must be in the range 0-23 and are expressed using military + (24-hour) time. +
  • +
  • Minutes must be in the range 0-59
  • +
  • Seconds must be in the range 0-59
  • +
  • Milliseconds must be in the range 0-999
  • +
  • + The time range starting time must be before the time range ending + time. Note this means that a time range may not cross daily + boundaries (10PM - 2AM) +
  • +
+
+ The range starting hour of day. + The range starting minute. + The range starting second. + The range starting millis. + The range ending hour of day. + The range ending minute. + The range ending second. + The range ending millis. +
+ + + Create a with a time range defined by the + specified s and no + baseCalendar. The Calendars are subject to the following + considerations: +
    +
  • + Only the time-of-day fields of the specified Calendars will be + used (the date fields will be ignored) +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time fields are + are used, it is possible for two Calendars to represent a valid + time range and + rangeStartingCalendar.after(rangeEndingCalendar) == true) + +
  • +
+
+ The range starting calendar. + The range ending calendar. +
+ + + Create a with a time range defined by the + specified s and the specified + . The Calendars are subject to the following + considerations: +
    +
  • + Only the time-of-day fields of the specified Calendars will be + used (the date fields will be ignored) +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time fields are + are used, it is possible for two Calendars to represent a valid + time range and + rangeStartingCalendarUtc > rangeEndingCalendarUtc == true) +
  • +
+
+ The range starting calendar. + The range ending calendar. +
+ + + Create a with a time range defined by the + specified values and no baseCalendar. The values are + subject to the following considerations: +
    +
  • + Only the time-of-day portion of the specified values will be + used +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time value are + are used, it is possible for the two values to represent a valid + time range and rangeStartingTime > rangeEndingTime) +
  • +
+
+ The range starting time in millis. + The range ending time in millis. +
+ + + Create a with a time range defined by the + specified values and the specified . The values + are subject to the following considerations: +
    +
  • + Only the time-of-day portion of the specified values will be + used +
  • +
  • + The starting time must be before the ending time of the defined + time range. Note this means that a time range may not cross + daily boundaries (10PM - 2AM). (because only time value are + are used, it is possible for the two values to represent a valid + time range and rangeStartingTime > rangeEndingTime) +
  • +
+
+ The range starting time in millis. + The range ending time in millis. +
+ + + Serialization constructor. + + + + + + + Determine whether the given time is 'included' by the + Calendar. + + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return 0 if all days are excluded. + + + + + + + + Returns the start time of the time range of the day + specified in . + + + a DateTime representing the start time of the + time range for the specified date. + + + + + Returns the end time of the time range of the day + specified in + + + A DateTime representing the end time of the + time range for the specified date. + + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Sets the time range for the to the times + represented in the specified Strings. + + The range starting time string. + The range ending time string. + + + + Sets the time range for the to the times + represented in the specified values. + + The range starting hour of day. + The range starting minute. + The range starting second. + The range starting millis. + The range ending hour of day. + The range ending minute. + The range ending second. + The range ending millis. + + + + Sets the time range for the to the times + represented in the specified s. + + The range starting calendar. + The range ending calendar. + + + + Sets the time range for the to the times + represented in the specified values. + + The range starting time. + The range ending time. + + + + Gets the start of day, practically zeroes time part. + + The time. + + + + + Gets the end of day, pratically sets time parts to maximum allowed values. + + The time. + + + + + Checks the specified values for validity as a set of time values. + + The hour of day. + The minute. + The second. + The millis. + + + + Indicates whether the time range represents an inverted time range (see + class description). + + true if invert time range; otherwise, false. + + + + This implementation of the Calendar stores a list of holidays (full days + that are excluded from scheduling). + + + The implementation DOES take the year into consideration, so if you want to + exclude July 4th for the next 10 years, you need to add 10 entries to the + exclude list. + + Sharada Jambula + Juergen Donnerstag + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The base calendar. + + + + Serialization constructor. + + + + + + + Determine whether the given time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. + + Note that this Calendar is only has full-day precision. + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Add the given Date to the list of excluded days. Only the month, day and + year of the returned dates are significant. + + + + + Removes the excluded date. + + The date to remove. + + + + Returns a of Dates representing the excluded + days. Only the month, day and year of the returned dates are + significant. + + + + + This implementation of the Calendar excludes a set of days of the month. You + may use it to exclude every 1. of each month for example. But you may define + any day of a month. + + + + Juergen Donnerstag + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Constructor + + The base calendar. + + + + Serialization constructor. + + + + + + + Initialize internal variables + + + + + Return true, if mday is defined to be exluded. + + + + + Redefine a certain day of the month to be excluded (true) or included + (false). + + + + + Check if all days are excluded. That is no day is included. + + boolean + + + + + Determine whether the given time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return DateTime.MinValue if all days are excluded. + + Note that this Calendar is only has full-day precision. + + + + + + Creates a new object that is a copy of the current instance. + + A new object that is a copy of this instance. + + + + Get or set the array which defines the exclude-value of each day of month + Setting will redefine the array of days excluded. The array must of size greater or + equal 31. + + + + + This implementation of the Calendar excludes a set of days of the week. You + may use it to exclude weekends for example. But you may define any day of + the week. + + + + Juergen Donnerstag + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The base calendar. + + + + Serialization constructor. + + + + + + + Initialize internal variables + + + + + Return true, if wday is defined to be exluded. E. g. + saturday and sunday. + + + + + Redefine a certain day of the week to be excluded (true) or included + (false). Use enum to determine the weekday. + + + + + Check if all week ays are excluded. That is no day is included. + + + + + Determine whether the given time (in milliseconds) is 'included' by the + Calendar. + + Note that this Calendar is only has full-day precision. + + + + + + Determine the next time (in milliseconds) that is 'included' by the + Calendar after the given time. Return the original value if timeStamp is + included. Return DateTime.MinValue if all days are excluded. + + Note that this Calendar is only has full-day precision. + + + + + + Get the array with the week days. + Setting will redefine the array of days excluded. The array must of size greater or + equal 8. java.util.Calendar's constants like MONDAY should be used as + index. A value of true is regarded as: exclude it. + + + + + Matches using an AND operator on two Matcher operands. + + James House + Marko Lahma (.NET) + + + + Matchers can be used in various API methods to + select the entities that should be operated upon. + + James House + + + + + Create an AndMatcher that depends upon the result of both of the given matchers. + + + + + + + + + Matches on the complete key being equal (both name and group). + + + + jhouse + + + + Create an EverythingMatcher that matches all jobs. + + + + + + Create an EverythingMatcher that matches all triggers. + + + + + + Matches on group (ignores name) property of Keys. + + James House + Marko Lahma (.NET) + + + + An abstract base class for some types of matchers. + + James House + Marko Lahma (.NET) + + + + Create a GroupMatcher that matches groups equaling the given string. + + + + + + + Create a GroupMatcher that matches groups starting with the given string. + + + + + + + Create a GroupMatcher that matches groups ending with the given string. + + + + + + + Create a GroupMatcher that matches groups containing the given string. + + + + + + + Matches on the complete key being equal (both name and group). + + James House + Marko Lahma (.NET) + + + + Create a KeyMatcher that matches Keys that equal the given key. + + + + + + + + Matches on name (ignores group) property of Keys. + + James House + Marko Lahma (.NET) + + + + Create a NameMatcher that matches names equaling the given string. + + + + + + + Create a NameMatcher that matches names starting with the given string. + + + + + + + Create a NameMatcher that matches names ending with the given string. + + + + + + + Create a NameMatcher that matches names containing the given string. + + + + + + + Matches using an NOT operator on another Matcher. + + James House + Marko Lahma (.NET) + + + + Create a NotMatcher that reverses the result of the given matcher. + + + + + + + + Matches using an OR operator on two Matcher operands. + + James House + Marko Lahma (.NET) + + + + Create an OrMatcher that depends upon the result of at least one of the given matchers. + + + + + + + + + Operators available for comparing string values. + + + + + The base abstract class to be extended by all triggers. + + + + s have a name and group associated with them, which + should uniquely identify them within a single . + + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + Triggers can 'send' parameters/data to s by placing contents + into the on the . + + + + + + + + James House + Sharada Jambula + Marko Lahma (.NET) + + + + Internal interface for managing triggers. This interface should not be used by the Quartz client. + + + + + Should not be used by end users. + + + + + The base interface with properties common to all s - + use to instantiate an actual Trigger. + + + + s have a associated with them, which + should uniquely identify them within a single . + + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + Triggers can 'send' parameters/data to s by placing contents + into the on the . + + + + + + + + + + James House + Sharada Jambula + Marko Lahma (.NET) + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + Used by the to determine whether or not + it is possible for this to fire again. + + If the returned value is then the + may remove the from the . + + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + Get or set the description given to the instance by + its creator (if any). + + + + + Get or set the with the given name with + this Trigger. Use when setting to dis-associate a Calendar. + + + + + Get or set the that is associated with the + . + + Changes made to this map during job execution are not re-persisted, and + in fact typically result in an illegal state. + + + + + + Returns the last UTC time at which the will fire, if + the Trigger will repeat indefinitely, null will be returned. + + Note that the return time *may* be in the past. + + + + + + Get or set the instruction the should be given for + handling misfire situations for this - the + concrete type that you are using will have + defined a set of additional MISFIRE_INSTRUCTION_XXX + constants that may be set to this property. + + If not explicitly set, the default value is . + + + + + + + + + Gets and sets the date/time on which the trigger must stop firing. This + defines the final boundary for trigger firings 舒 the trigger will + not fire after to this date and time. If this value is null, no end time + boundary is assumed, and the trigger can continue indefinitely. + + + + + The time at which the trigger's scheduling should start. May or may not + be the first actual fire time of the trigger, depending upon the type of + trigger and the settings of the other properties of the trigger. However + the first actual first time will not be before this date. + + + Setting a value in the past may cause a new trigger to compute a first + fire time that is in the past, which may cause an immediate misfire + of the trigger. + + + + + The priority of a acts as a tie breaker such that if + two s have the same scheduled fire time, then Quartz + will do its best to give the one with the higher priority first access + to a worker thread. + + + If not explicitly set, the default value is 5. + + + + + + + Set a description for the instance - may be + useful for remembering/displaying the purpose of the trigger, though the + description has no meaning to Quartz. + + + + + Associate the with the given name with this Trigger. + + + + + Set the to be associated with the + . + + + + + The priority of a acts as a tie breaker such that if + two s have the same scheduled fire time, then Quartz + will do its best to give the one with the higher priority first access + to a worker thread. + + + If not explicitly set, the default value is 5. + + + + + + + The time at which the trigger's scheduling should start. May or may not + be the first actual fire time of the trigger, depending upon the type of + trigger and the settings of the other properties of the trigger. However + the first actual first time will not be before this date. + + + Setting a value in the past may cause a new trigger to compute a first + fire time that is in the past, which may cause an immediate misfire + of the trigger. + + ew DateTimeOffset StartTimeUtc { get; set; } + + + + + + Set the time at which the should quit repeating - + regardless of any remaining repeats (based on the trigger's particular + repeat settings). + + + + + + + + Set the instruction the should be given for + handling misfire situations for this - the + concrete type that you are using will have + defined a set of additional MisfireInstruction.XXX + constants that may be passed to this method. + + + If not explicitly set, the default value is . + + + + + + + + This method should not be used by the Quartz client. + + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + This method should not be used by the Quartz client. + + + Called after the has executed the + associated with the + in order to get the final instruction code from the trigger. + + + is the that was used by the + 's method. + is the thrown by the + , if any (may be null). + + + One of the members. + + + + + + + + + + This method should not be used by the Quartz client. + + To be implemented by the concrete classes that extend this class. + + + The implementation should update the 's state + based on the MISFIRE_INSTRUCTION_XXX that was selected when the + was created. + + + + + + This method should not be used by the Quartz client. + + The implementation should update the 's state + based on the given new version of the associated + (the state should be updated so that it's next fire time is appropriate + given the Calendar's new settings). + + + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + This method should not be used by the Quartz client. + + + Usable by + implementations, in order to facilitate 'recognizing' instances of fired + s as their jobs complete execution. + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Create a with no specified name, group, or . + + + Note that the , and + the and properties + must be set before the can be placed into a + . + + + + + Create a with the given name, and default group. + + + Note that the and + properties must be set before the + can be placed into a . + + The name. + + + + Create a with the given name, and group. + + + Note that the and + properties must be set before the + can be placed into a . + + The name. + if , Scheduler.DefaultGroup will be used. + + + + Create a with the given name, and group. + + The name. + if , Scheduler.DefaultGroup will be used. + Name of the job. + The job group. + ArgumentException + if name is null or empty, or the group is an empty string. + + + + + This method should not be used by the Quartz client. + + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + This method should not be used by the Quartz client. + + + Called after the has executed the + associated with the + in order to get the final instruction code from the trigger. + + + is the that was used by the + 's method. + is the thrown by the + , if any (may be null). + + + One of the members. + + + + + + + Used by the to determine whether or not + it is possible for this to fire again. + + If the returned value is then the + may remove the from the . + + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + This method should not be used by the Quartz client. + + To be implemented by the concrete classes that extend this class. + + + The implementation should update the 's state + based on the MISFIRE_INSTRUCTION_XXX that was selected when the + was created. + + + + + + This method should not be used by the Quartz client. + + The implementation should update the 's state + based on the given new version of the associated + (the state should be updated so that it's next fire time is appropriate + given the Calendar's new settings). + + + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Return a simple string representation of this object. + + + + + Compare the next fire time of this to that of + another by comparing their keys, or in other words, sorts them + according to the natural (i.e. alphabetical) order of their keys. + + + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + true if the specified is equal to the current ; otherwise, false. + + + + + Trigger equality is based upon the equality of the TriggerKey. + + + true if the key of this Trigger equals that of the given Trigger + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Get or sets the name of this . + + If name is null or empty. + + + + Get the group of this . If , Scheduler.DefaultGroup will be used. + + + if group is an empty string. + + + + + Get or set the name of the associated . + + + if jobName is null or empty. + + + + + Gets or sets the name of the associated 's + group. If set with , Scheduler.DefaultGroup will be used. + + ArgumentException + if group is an empty string. + + + + + Returns the 'full name' of the in the format + "group.name". + + + + + Gets the key. + + The key. + + + + Returns the 'full name' of the that the + points to, in the format "group.name". + + + + + Get or set the description given to the instance by + its creator (if any). + + + + + Get or set the with the given name with + this Trigger. Use when setting to dis-associate a Calendar. + + + + + Get or set the that is associated with the + . + + Changes made to this map during job execution are not re-persisted, and + in fact typically result in an illegal state. + + + + + + Returns the last UTC time at which the will fire, if + the Trigger will repeat indefinitely, null will be returned. + + Note that the return time *may* be in the past. + + + + + + Get or set the instruction the should be given for + handling misfire situations for this - the + concrete type that you are using will have + defined a set of additional MISFIRE_INSTRUCTION_XXX + constants that may be passed to this method. + + If not explicitly set, the default value is . + + + + + + + + + + This method should not be used by the Quartz client. + + + Usable by + implementations, in order to facilitate 'recognizing' instances of fired + s as their jobs complete execution. + + + + + Gets and sets the date/time on which the trigger must stop firing. This + defines the final boundary for trigger firings 舒 the trigger will + not fire after to this date and time. If this value is null, no end time + boundary is assumed, and the trigger can continue indefinitely. + + + + + The time at which the trigger's scheduling should start. May or may not + be the first actual fire time of the trigger, depending upon the type of + trigger and the settings of the other properties of the trigger. However + the first actual first time will not be before this date. + + + Setting a value in the past may cause a new trigger to compute a first + fire time that is in the past, which may cause an immediate misfire + of the trigger. + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + The priority of a acts as a tie breaker such that if + two s have the same scheduled fire time, then Quartz + will do its best to give the one with the higher priority first access + to a worker thread. + + + If not explicitly set, the default value is 5. + + + + + + + Gets a value indicating whether this instance has additional properties + that should be considered when for example saving to database. + + + If trigger implementation has additional properties that need to be saved + with base properties you need to make your class override this property with value true. + Returning true will effectively mean that ADOJobStore needs to serialize + this trigger instance to make sure additional properties are also saved. + + + true if this instance has additional properties; otherwise, false. + + + + + A concrete that is used to fire a + based upon repeating calendar time intervals. + + + The trigger will fire every N (see ) units of calendar time + (see ) as specified in the trigger's definition. + This trigger can achieve schedules that are not possible with (e.g + because months are not a fixed number of seconds) or (e.g. because + "every 5 months" is not an even divisor of 12). + + If you use an interval unit of then care should be taken when setting + a value that is on a day near the end of the month. For example, + if you choose a start time that occurs on January 31st, and have a trigger with unit + and interval 1, then the next fire time will be February 28th, + and the next time after that will be March 28th - and essentially each subsequent firing will + occur on the 28th of the month, even if a 31st day exists. If you want a trigger that always + fires on the last day of the month - regardless of the number of days in the month, + you should use . + + + + + + + 2.0 + James House + Marko Lahma (.NET) + + + + A that is used to fire a + based upon repeating calendar time intervals. + + + + + Get or set the interval unit - the time unit on with the interval applies. + + + + + Get the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + Get the number of times the has already fired. + + + + + Gets the time zone within which time calculations related to this trigger will be performed. + + + If null, the system default TimeZone will be used. + + + + + If intervals are a day or greater, this property (set to true) will + cause the firing of the trigger to always occur at the same time of day, + (the time of day of the startTime) regardless of daylight saving time + transitions. Default value is false. + + + + For example, without the property set, your trigger may have a start + time of 9:00 am on March 1st, and a repeat interval of 2 days. But + after the daylight saving transition occurs, the trigger may start + firing at 8:00 am every other day. + + + If however, the time of day does not exist on a given day to fire + (e.g. 2:00 am in the United States on the days of daylight saving + transition), the trigger will go ahead and fire one hour off on + that day, and then resume the normal hour on other days. If + you wish for the trigger to never fire at the "wrong" hour, then + you should set the property skipDayIfHourDoesNotExist. + + + + + + + + + If intervals are a day or greater, and + preserveHourOfDayAcrossDaylightSavings property is set to true, and the + hour of the day does not exist on a given day for which the trigger + would fire, the day will be skipped and the trigger advanced a second + interval if this property is set to true. Defaults to false. + + + CAUTION! If you enable this property, and your hour of day happens + to be that of daylight savings transition (e.g. 2:00 am in the United + States) and the trigger's interval would have had the trigger fire on + that day, then you may actually completely miss a firing on the day of + transition if that hour of day does not exist on that day! In such a + case the next fire time of the trigger will be computed as double (if + the interval is 2 days, then a span of 4 days between firings will + occur). + + + + + + Create a with no settings. + + + + + Create a that will occur immediately, and + repeat at the the given interval. + + Name for the trigger instance. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur immediately, and + repeat at the the given interval + + Name for the trigger instance. + Group for the trigger instance. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + Name for the trigger instance. + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + Name for the trigger instance. + Group for the trigger instance. + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + Name for the trigger instance. + Group for the trigger instance. + Name of the associated job. + Group of the associated job. + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The repeat interval unit (minutes, days, months, etc). + The number of milliseconds to pause between the repeat firing. + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + Updates the 's state based on the + MisfireInstruction.XXX that was selected when the + was created. + + + If the misfire instruction is set to , + then the following scheme will be used: +
    +
  • The instruction will be interpreted as
  • +
+
+
+ + + This method should not be used by the Quartz client. + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + + This method should not be used by the Quartz client. + + The implementation should update the 's state + based on the given new version of the associated + (the state should be updated so that it's next fire time is appropriate + given the Calendar's new settings). + + + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + Determines whether or not the will occur + again. + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + + + Get the time at which the should occur. + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + Get the time at which the should quit + repeating. + + + + + Get or set the interval unit - the time unit on with the interval applies. + + + + + Get the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + If intervals are a day or greater, this property (set to true) will + cause the firing of the trigger to always occur at the same time of day, + (the time of day of the startTime) regardless of daylight saving time + transitions. Default value is false. + + + + For example, without the property set, your trigger may have a start + time of 9:00 am on March 1st, and a repeat interval of 2 days. But + after the daylight saving transition occurs, the trigger may start + firing at 8:00 am every other day. + + + If however, the time of day does not exist on a given day to fire + (e.g. 2:00 am in the United States on the days of daylight saving + transition), the trigger will go ahead and fire one hour off on + that day, and then resume the normal hour on other days. If + you wish for the trigger to never fire at the "wrong" hour, then + you should set the property skipDayIfHourDoesNotExist. + + + + + + + + + If intervals are a day or greater, and + preserveHourOfDayAcrossDaylightSavings property is set to true, and the + hour of the day does not exist on a given day for which the trigger + would fire, the day will be skipped and the trigger advanced a second + interval if this property is set to true. Defaults to false. + + + CAUTION! If you enable this property, and your hour of day happens + to be that of daylight savings transition (e.g. 2:00 am in the United + States) and the trigger's interval would have had the trigger fire on + that day, then you may actually completely miss a firing on the day of + transition if that hour of day does not exist on that day! In such a + case the next fire time of the trigger will be computed as double (if + the interval is 2 days, then a span of 4 days between firings will + occur). + + + + + + Get the number of times the has already fired. + + + + + Returns the final time at which the will + fire, if there is no end time set, null will be returned. + + + Note that the return time may be in the past. + + + + A concrete that is used to fire a + at given moments in time, defined with Unix 'cron-like' definitions. + + + + For those unfamiliar with "cron", this means being able to create a firing + schedule such as: "At 8:00am every Monday through Friday" or "At 1:30am + every last Friday of the month". + + + + The format of a "Cron-Expression" string is documented on the + class. + + + + Here are some full examples:
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Expression Meaning
"0 0 12 * * ?"" /> Fire at 12pm (noon) every day" />
"0 15 10 ? * *"" /> Fire at 10:15am every day" />
"0 15 10 * * ?"" /> Fire at 10:15am every day" />
"0 15 10 * * ? *"" /> Fire at 10:15am every day" />
"0 15 10 * * ? 2005"" /> Fire at 10:15am every day during the year 2005" /> +
"0 * 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:59pm, every day" /> +
"0 0/5 14 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, every day" /> +
"0 0/5 14,18 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, AND fire every 5 minutes starting at 6pm and ending at 6:55pm, every day" /> +
"0 0-5 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:05pm, every day" /> +
"0 10,44 14 ? 3 WED"" /> Fire at 2:10pm and at 2:44pm every Wednesday in the month of March." /> +
"0 15 10 ? * MON-FRI"" /> Fire at 10:15am every Monday, Tuesday, Wednesday, Thursday and Friday" /> +
"0 15 10 15 * ?"" /> Fire at 10:15am on the 15th day of every month" /> +
"0 15 10 L * ?"" /> Fire at 10:15am on the last day of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L 2002-2005"" /> Fire at 10:15am on every last Friday of every month during the years 2002, 2003, 2004 and 2005" /> +
"0 15 10 ? * 6#3"" /> Fire at 10:15am on the third Friday of every month" /> +
+
+ + + Pay attention to the effects of '?' and '*' in the day-of-week and + day-of-month fields! + + + + NOTES: +
    +
  • Support for specifying both a day-of-week and a day-of-month value is + not complete (you'll need to use the '?' character in on of these fields). +
  • +
  • Be careful when setting fire times between mid-night and 1:00 AM - + "daylight savings" can cause a skip or a repeat depending on whether the + time moves back or jumps forward.
  • +
+
+
+ + + Sharada Jambula + James House + Contributions from Mads Henderson + Marko Lahma (.NET) +
+ + + The public interface for inspecting settings specific to a CronTrigger, + which is used to fire a + at given moments in time, defined with Unix 'cron-like' schedule definitions. + + + + For those unfamiliar with "cron", this means being able to create a firing + schedule such as: "At 8:00am every Monday through Friday" or "At 1:30am + every last Friday of the month". + + + + The format of a "Cron-Expression" string is documented on the + class. + + + + Here are some full examples:
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Expression Meaning
"0 0 12 * * ?"" /> Fire at 12pm (noon) every day" />
"0 15 10 ? * *"" /> Fire at 10:15am every day" />
"0 15 10 * * ?"" /> Fire at 10:15am every day" />
"0 15 10 * * ? *"" /> Fire at 10:15am every day" />
"0 15 10 * * ? 2005"" /> Fire at 10:15am every day during the year 2005" /> +
"0 * 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:59pm, every day" /> +
"0 0/5 14 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, every day" /> +
"0 0/5 14,18 * * ?"" /> Fire every 5 minutes starting at 2pm and ending at 2:55pm, AND fire every 5 minutes starting at 6pm and ending at 6:55pm, every day" /> +
"0 0-5 14 * * ?"" /> Fire every minute starting at 2pm and ending at 2:05pm, every day" /> +
"0 10,44 14 ? 3 WED"" /> Fire at 2:10pm and at 2:44pm every Wednesday in the month of March." /> +
"0 15 10 ? * MON-FRI"" /> Fire at 10:15am every Monday, Tuesday, Wednesday, Thursday and Friday" /> +
"0 15 10 15 * ?"" /> Fire at 10:15am on the 15th day of every month" /> +
"0 15 10 L * ?"" /> Fire at 10:15am on the last day of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L"" /> Fire at 10:15am on the last Friday of every month" /> +
"0 15 10 ? * 6L 2002-2005"" /> Fire at 10:15am on every last Friday of every month during the years 2002, 2003, 2004 and 2005" /> +
"0 15 10 ? * 6#3"" /> Fire at 10:15am on the third Friday of every month" /> +
+
+ + + Pay attention to the effects of '?' and '*' in the day-of-week and + day-of-month fields! + + + + NOTES: +
    +
  • Support for specifying both a day-of-week and a day-of-month value is + not complete (you'll need to use the '?' character in on of these fields). +
  • +
  • Be careful when setting fire times between mid-night and 1:00 AM - + "daylight savings" can cause a skip or a repeat depending on whether the + time moves back or jumps forward.
  • +
+
+
+ + + Sharada Jambula + James House + Contributions from Mads Henderson + Marko Lahma (.NET) +
+ + + Gets the expression summary. + + + + + + Gets or sets the cron expression string. + + The cron expression string. + + + + Sets the time zone for which the of this + will be resolved. + + + If is set after this + property, the TimeZone setting on the CronExpression will "win". However + if is set after this property, the + time zone applied by this method will remain in effect, since the + string cron expression does not carry a time zone! + + The time zone. + + + + Create a with no settings. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + + + + Create a with the given name and default group. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + + + + Create a with the given name and group. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + The group of the + + + + Create a with the given name, group and + expression. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + The group of the + A cron expression dictating the firing sequence of the + + + + Create a with the given name and group, and + associated with the identified . + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the . + The group of the + name of the executed on firetime + Group of the executed on firetime + + + + Create a with the given name and group, + associated with the identified , + and with the given "cron" expression. + + + The start-time will also be set to the current time, and the time zone + will be set the the system's default time zone. + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A cron expression dictating the firing sequence of the + + + + Create a with the given name and group, + associated with the identified , + and with the given "cron" expression resolved with respect to the . + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A cron expression dictating the firing sequence of the + + Specifies for which time zone the cronExpression should be interpreted, + i.e. the expression 0 0 10 * * ?, is resolved to 10:00 am in this time zone. + + + + + Create a that will occur at the given time, + until the given end time. + + If null, the start-time will also be set to the current time, the time + zone will be set the the system's default. + + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A set to the earliest time for the to start firing. + A set to the time for the to quit repeat firing. + A cron expression dictating the firing sequence of the + + + + Create a with fire time dictated by the + resolved with respect to the specified + occurring from the until + the given . + + The name of the + The group of the + name of the executed on firetime + Group of the executed on firetime + A set to the earliest time for the to start firing. + A set to the time for the to quit repeat firing. + + + + Clones this instance. + + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + + Sets the next fire time. + + This method should not be invoked by client code. + + + The fire time. + + + + Sets the previous fire time. + + This method should not be invoked by client code. + + + The fire time. + + + + Returns the next time at which the will fire, + after the given time. If the trigger will not fire after the given time, + will be returned. + + + + + + + Used by the to determine whether or not + it is possible for this to fire again. + + If the returned value is then the + may remove the from the . + + + + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + This method should not be used by the Quartz client. + + To be implemented by the concrete classes that extend this class. + + + The implementation should update the 's state + based on the MISFIRE_INSTRUCTION_XXX that was selected when the + was created. + + + + + + + + Determines whether the date and (optionally) time of the given Calendar + instance falls on a scheduled fire-time of this trigger. + + + + Equivalent to calling . + + + The date to compare. + + + + + Determines whether the date and (optionally) time of the given Calendar + instance falls on a scheduled fire-time of this trigger. + + Note that the value returned is NOT validated against the related + ICalendar (if any). + + + The date to compare + If set to true, the method will only determine if the + trigger will fire during the day represented by the given Calendar + (hours, minutes and seconds will be ignored). + + + + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + + Updates the trigger with new calendar. + + The calendar to update with. + The misfire threshold. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + After this method has been called, + should return a valid answer. + + + + + the first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Gets the expression summary. + + + + + + Gets the next time to fire after the given time. + + The time to compute from. + + + + + NOT YET IMPLEMENTED: Returns the time before the given time + that this will fire. + + The date. + + + + + Gets or sets the cron expression string. + + The cron expression string. + + + + Set the CronExpression to the given one. The TimeZone on the passed-in + CronExpression over-rides any that was already set on the Trigger. + + The cron expression. + + + + Returns the date/time on which the trigger may begin firing. This + defines the initial boundary for trigger firings the trigger + will not fire prior to this date and time. + + + + + + Get or sets the time at which the CronTrigger should quit + repeating - even if repeastCount isn't yet satisfied. + + + + + Sets the time zone for which the of this + will be resolved. + + + If is set after this + property, the TimeZone setting on the CronExpression will "win". However + if is set after this property, the + time zone applied by this method will remain in effect, since the + string cron expression does not carry a time zone! + + The time zone. + + + + Returns the last UTC time at which the will fire, if + the Trigger will repeat indefinitely, null will be returned. + + Note that the return time *may* be in the past. + + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + + A concrete implementation of DailyTimeIntervalTrigger that is used to fire a + based upon daily repeating time intervals. + + + + The trigger will fire every N ( ) seconds, minutes or hours + (see ) during a given time window on specified days of the week. + + + For example#1, a trigger can be set to fire every 72 minutes between 8:00 and 11:00 everyday. It's fire times would + be 8:00, 9:12, 10:24, then next day would repeat: 8:00, 9:12, 10:24 again. + + + For example#2, a trigger can be set to fire every 23 minutes between 9:20 and 16:47 Monday through Friday. + + + On each day, the starting fire time is reset to startTimeOfDay value, and then it will add repeatInterval value to it until + the endTimeOfDay is reached. If you set daysOfWeek values, then fire time will only occur during those week days period. Again, + remember this trigger will reset fire time each day with startTimeOfDay, regardless of your interval or endTimeOfDay! + + + The default values for fields if not set are: startTimeOfDay defaults to 00:00:00, the endTimeOfDay default to 23:59:59, + and daysOfWeek is default to every day. The startTime default to current time-stamp now, while endTime has not value. + + + If startTime is before startTimeOfDay, then startTimeOfDay will be used and startTime has no affect. Else if startTime is + after startTimeOfDay, then the first fire time for that day will be the next interval after the startTime. For example, if + you set startingTimeOfDay=9am, endingTimeOfDay=11am, interval=15 mins, and startTime=9:33am, then the next fire time will + be 9:45pm. Note also that if you do not set startTime value, the trigger builder will default to current time, and current time + maybe before or after the startTimeOfDay! So be aware how you set your startTime. + + + This trigger also supports "repeatCount" feature to end the trigger fire time after + a certain number of count is reached. Just as the SimpleTrigger, setting repeatCount=0 + means trigger will fire once only! Setting any positive count then the trigger will repeat + count + 1 times. Unlike SimpleTrigger, the default value of repeatCount of this trigger + is set to REPEAT_INDEFINITELY instead of 0 though. + + + + + 2.0 + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + A that is used to fire a + based upon daily repeating time intervals. + + + The trigger will fire every N (see ) seconds, minutes or hours + (see during a given time window on specified days of the week. + + For example#1, a trigger can be set to fire every 72 minutes between 8:00 and 11:00 everyday. It's fire times + be 8:00, 9:12, 10:24, then next day would repeat: 8:00, 9:12, 10:24 again. + + For example#2, a trigger can be set to fire every 23 minutes between 9:20 and 16:47 Monday through Friday. + + On each day, the starting fire time is reset to startTimeOfDay value, and then it will add repeatInterval value to it until + the endTimeOfDay is reached. If you set daysOfWeek values, then fire time will only occur during those week days period. + + The default values for fields if not set are: startTimeOfDay defaults to 00:00:00, the endTimeOfDay default to 23:59:59, + and daysOfWeek is default to every day. The startTime default to current time-stamp now, while endTime has not value. + + If startTime is before startTimeOfDay, then it has no affect. Else if startTime after startTimeOfDay, then the first fire time + for that day will be normal startTimeOfDay incremental values after startTime value. Same reversal logic is applied to endTime + with endTimeOfDay. + + + + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + + + + + + Get the the number of times for interval this trigger should repeat, + after which it will be automatically deleted. + + + + + Get the interval unit - the time unit on with the interval applies. + The only intervals that are valid for this type of trigger are , + , and + + + + + Get the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + The time of day to start firing at the given interval. + + + + + The time of day to complete firing at the given interval. + + + + + The days of the week upon which to fire. + + + A Set containing the integers representing the days of the week, per the values 0-6 as defined by + DayOfWees.Sunday - DayOfWeek.Saturday. + + + + + Get the number of times the has already fired. + + + + + Used to indicate the 'repeat count' of the trigger is indefinite. Or in + other words, the trigger should repeat continually until the trigger's + ending timestamp. + + + + + Create a with no settings. + + + + + Create a that will occur immediately, and + repeat at the the given interval. + + + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + + + + + Create a that will occur immediately, and + repeat at the the given interval. + + + + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval until the given end time. + + + + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + The number of milliseconds to pause between the repeat firing. + + + + Create a that will occur at the given time, + fire the identified job and repeat at the the given + interval until the given end time. + + + + + + A set to the time for the to fire. + A set to the time for the to quit repeat firing. + The that the repeating should begin occurring. + The that the repeating should stop occurring. + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + The number of milliseconds to pause between the repeat firing. + + + + Updates the 's state based on the + MisfireInstruction.XXX that was selected when the + was created. + + + If the misfire instruction is set to , + then the following scheme will be used: +
    +
  • The instruction will be interpreted as
  • +
+
+
+ + + Called when the scheduler has decided to 'fire' + the trigger (execute the associated job), in order to + give the trigger a chance to update itself for its next + triggering (if any). + + + + + + + + + + + + + + + This method should not be used by the Quartz client. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Returns the next time at which the is scheduled to fire. If + the trigger will not fire again, will be returned. Note that + the time returned can possibly be in the past, if the time that was computed + for the trigger to next fire has already arrived, but the scheduler has not yet + been able to fire the trigger (which would likely be due to lack of resources + e.g. threads). + + + The value returned is not guaranteed to be valid until after the + has been added to the scheduler. + + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be returned. + + + + + Set the next time at which the should fire. + + + This method should not be invoked by client code. + + + + + + Set the previous time at which the fired. + + + This method should not be invoked by client code. + + + + + + Returns the next time at which the will + fire, after the given time. If the trigger will not fire after the given + time, will be returned. + + + + + + + Given fireTime time, we need to advance/calculate and return a time of next available week day. + + given next fireTime. + flag to whether to advance day without check existing week day. This scenario + can happen when a caller determine fireTime has passed the endTimeOfDay that fireTime should move to next day anyway. + + a next day fireTime. + + + + Determines whether or not the will occur + again. + + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + + The time at which the should occur. + + + + + the time at which the should quit repeating. + + + + + + Get the the number of times for interval this trigger should repeat, + after which it will be automatically deleted. + + + + + the interval unit - the time unit on with the interval applies. + + + The repeat interval unit. The only intervals that are valid for this type of trigger are + , , and . + + + + + the the time interval that will be added to the 's + fire time (in the set repeat interval unit) in order to calculate the time of the + next trigger repeat. + + + + + the number of times the has already + fired. + + + + + Returns the final time at which the will + fire, if there is no end time set, null will be returned. + + Note that the return time may be in the past. + + + + + The days of the week upon which to fire. + + + A Set containing the integers representing the days of the week, per the values 0-6 as defined by + DayOfWees.Sunday - DayOfWeek.Saturday. + + + + + The time of day to start firing at the given interval. + + + + + The time of day to complete firing at the given interval. + + + + + This trigger has no additional properties besides what's defined in this class. + + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + A concrete that is used to fire a + at a given moment in time, and optionally repeated at a specified interval. + + + + James House + Contributions by Lieven Govaerts of Ebitec Nv, Belgium. + Marko Lahma (.NET) + + + + A that is used to fire a + at a given moment in time, and optionally repeated at a specified interval. + + + + James House + Contributions by Lieven Govaerts of Ebitec Nv, Belgium. + Marko Lahma (.NET) + + + + Get or set thhe number of times the should + repeat, after which it will be automatically deleted. + + + + + + Get or set the the time interval at which the should repeat. + + + + + Get or set the number of times the has already + fired. + + + + + Used to indicate the 'repeat count' of the trigger is indefinite. Or in + other words, the trigger should repeat continually until the trigger's + ending timestamp. + + + + + Create a with no settings. + + + + + Create a that will occur immediately, and + not repeat. + + + + + Create a that will occur immediately, and + not repeat. + + + + + Create a that will occur immediately, and + repeat at the the given interval the given number of times. + + + + + Create a that will occur immediately, and + repeat at the the given interval the given number of times. + + + + + Create a that will occur at the given time, + and not repeat. + + + + + Create a that will occur at the given time, + and not repeat. + + + + + Create a that will occur at the given time, + and repeat at the the given interval the given number of times, or until + the given end time. + + The name. + A UTC set to the time for the to fire. + A UTC set to the time for the + to quit repeat firing. + The number of times for the to repeat + firing, use for unlimited times. + The time span to pause between the repeat firing. + + + + Create a that will occur at the given time, + and repeat at the the given interval the given number of times, or until + the given end time. + + The name. + The group. + A UTC set to the time for the to fire. + A UTC set to the time for the + to quit repeat firing. + The number of times for the to repeat + firing, use for unlimited times. + The time span to pause between the repeat firing. + + + + Create a that will occur at the given time, + fire the identified and repeat at the the given + interval the given number of times, or until the given end time. + + The name. + The group. + Name of the job. + The job group. + A set to the time for the + to fire. + A set to the time for the + to quit repeat firing. + The number of times for the to repeat + firing, use RepeatIndefinitely for unlimited times. + The time span to pause between the repeat firing. + + + + Validates the misfire instruction. + + The misfire instruction. + + + + + Updates the 's state based on the + MisfireInstruction value that was selected when the + was created. + + + If MisfireSmartPolicyEnabled is set to true, + then the following scheme will be used:
+
    +
  • If the Repeat Count is 0, then the instruction will + be interpreted as .
  • +
  • If the Repeat Count is , then + the instruction will be interpreted as . + WARNING: using MisfirePolicy.SimpleTrigger.RescheduleNowWithRemainingRepeatCount + with a trigger that has a non-null end-time may cause the trigger to + never fire again if the end-time arrived during the misfire time span. +
  • +
  • If the Repeat Count is > 0, then the instruction + will be interpreted as . +
  • +
+
+
+ + + Called when the has decided to 'fire' + the trigger (Execute the associated ), in order to + give the a chance to update itself for its next + triggering (if any). + + + + + + Updates the instance with new calendar. + + The calendar. + The misfire threshold. + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + After this method has been called, + should return a valid answer. + + + + The first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first firing of the ). + + + + + Returns the next time at which the will + fire. If the trigger will not fire again, will be + returned. The value returned is not guaranteed to be valid until after + the has been added to the scheduler. + + + + + Returns the previous time at which the fired. + If the trigger has not yet fired, will be + returned. + + + + + Returns the next UTC time at which the will + fire, after the given UTC time. If the trigger will not fire after the given + time, will be returned. + + + + + Returns the last UTC time at which the will + fire, before the given time. If the trigger will not fire before the + given time, will be returned. + + + + + Computes the number of times fired between the two UTC date times. + + The UTC start date and time. + The UTC end date and time. + + + + + Determines whether or not the will occur + again. + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Get or set thhe number of times the should + repeat, after which it will be automatically deleted. + + + + + + Get or set the the time interval at which the should repeat. + + + + + Get or set the number of times the has already + fired. + + + + + Returns the final UTC time at which the will + fire, if repeatCount is RepeatIndefinitely, null will be returned. + + Note that the return time may be in the past. + + + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + + Schedules work on a newly spawned thread. This is the default Quartz behavior. + + matt.accola + + + + Allows different strategies for scheduling threads. The + method is required to be called before the first call to + . The Thread containing the work to be performed is + passed to execute and the work is scheduled by the underlying implementation. + + matt.accola + + + + Submit a task for execution. + + Thread to execute. + + + + Initialize any state prior to calling . + + + + + A singleton implementation of . + + + Here are some examples of using this class: + + To create a scheduler that does not write anything to the database (is not + persistent), you can call : + + + DirectSchedulerFactory.Instance.CreateVolatileScheduler(10); // 10 threads + // don't forget to start the scheduler: + DirectSchedulerFactory.Instance.GetScheduler().Start(); + + + Several create methods are provided for convenience. All create methods + eventually end up calling the create method with all the parameters: + + + public void CreateScheduler(string schedulerName, string schedulerInstanceId, IThreadPool threadPool, IJobStore jobStore) + + + Here is an example of using this method: + + + // create the thread pool + SimpleThreadPool threadPool = new SimpleThreadPool(maxThreads, ThreadPriority.Normal); + threadPool.Initialize(); + // create the job store + JobStore jobStore = new RAMJobStore(); + + DirectSchedulerFactory.Instance.CreateScheduler("My Quartz Scheduler", "My Instance", threadPool, jobStore); + // don't forget to start the scheduler: + DirectSchedulerFactory.Instance.GetScheduler("My Quartz Scheduler", "My Instance").Start(); + + > + Mohammad Rezaei + James House + Marko Lahma (.NET) + + + + + + Provides a mechanism for obtaining client-usable handles to + instances. + + + + James House + Marko Lahma (.NET) + + + + Returns a client-usable handle to a . + + + + + Returns a handle to the Scheduler with the given name, if it exists. + + + + + Returns handles to all known Schedulers (made by any SchedulerFactory + within this app domain.). + + + + + Initializes a new instance of the class. + + + + + Creates an in memory job store () + The thread priority is set to Thread.NORM_PRIORITY + + The number of threads in the thread pool + + + + Creates a proxy to a remote scheduler. This scheduler can be retrieved + via . + + SchedulerException + + + + Same as , + with the addition of specifying the scheduler name and instance ID. This + scheduler can only be retrieved via . + + The name for the scheduler. + The instance ID for the scheduler. + + SchedulerException + + + + Creates a scheduler using the specified thread pool and job store. This + scheduler can be retrieved via DirectSchedulerFactory#GetScheduler() + + + The thread pool for executing jobs + + + The type of job store + + SchedulerException + if initialization failed + + + + + Same as DirectSchedulerFactory#createScheduler(ThreadPool threadPool, JobStore jobStore), + with the addition of specifying the scheduler name and instance ID. This + scheduler can only be retrieved via DirectSchedulerFactory#getScheduler(String) + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + The type of job store + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + The type of job store + The idle wait time. You can specify "-1" for + the default value, which is currently 30000 ms. + The db failure retry interval. + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + The type of job store + + The idle wait time. You can specify TimeSpan.Zero for + the default value, which is currently 30000 ms. + The db failure retry interval. + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + Thread executor. + The type of job store + + The idle wait time. You can specify TimeSpan.Zero for + the default value, which is currently 30000 ms. + The db failure retry interval. + + + + Creates a scheduler using the specified thread pool and job store and + binds it for remote access. + + The name for the scheduler. + The instance ID for the scheduler. + The thread pool for executing jobs + Thread executor. + The type of job store + + The idle wait time. You can specify TimeSpan.Zero for + the default value, which is currently 30000 ms. + The db failure retry interval. + The maximum batch size of triggers, when acquiring them + The time window for which it is allowed to "pre-acquire" triggers to fire + + + + Returns a handle to the Scheduler produced by this factory. + + you must call createRemoteScheduler or createScheduler methods before + calling getScheduler() + + + + SchedulerException + + + + Returns a handle to the Scheduler with the given name, if it exists. + + + + + Gets the log. + + The log. + + + + Gets the instance. + + The instance. + + + + Returns a handle to all known Schedulers (made by any + StdSchedulerFactory instance.). + + + + + + Conveys the detail properties of a given job instance. + + + Quartz does not store an actual instance of a type, but + instead allows you to define an instance of one, through the use of a . + + s have a name and group associated with them, which + should uniquely identify them within a single . + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + + + + + James House + Marko Lahma (.NET) + + + + Conveys the detail properties of a given job instance. + JobDetails are to be created/defined with . + + + Quartz does not store an actual instance of a type, but + instead allows you to define an instance of one, through the use of a . + + s have a name and group associated with them, which + should uniquely identify them within a single . + + + s are the 'mechanism' by which s + are scheduled. Many s can point to the same , + but a single can only point to one . + + + + + + + + James House + Marko Lahma (.NET) + + + + Get a that is configured to produce a + identical to this one. + + + + + The key that identifies this jobs uniquely. + + + + + Get or set the description given to the instance by its + creator (if any). + + + + + Get or sets the instance of that will be executed. + + + + + Get or set the that is associated with the . + + + + + Whether or not the should remain stored after it is + orphaned (no s point to it). + + + If not explicitly set, the default value is . + + + if the Job should remain persisted after being orphaned. + + + + + Whether the associated Job class carries the . + + + + + + Whether the associated Job class carries the . + + + + + + Set whether or not the the should re-Execute + the if a 'recovery' or 'fail-over' situation is + encountered. + + + If not explicitly set, the default value is . + + + + + + Create a with no specified name or group, and + the default settings of all the other properties. + + Note that the , and + properties must be set before the job can be + placed into a . + + + + + + Create a with the given name, default group, and + the default settings of all the other properties. + If , Scheduler.DefaultGroup will be used. + + + If name is null or empty, or the group is an empty string. + + + + + Create a with the given name, and group, and + the default settings of all the other properties. + If , Scheduler.DefaultGroup will be used. + + + If name is null or empty, or the group is an empty string. + + + + + Create a with the given name, and group, and + the given settings of all the other properties. + + The name. + if , Scheduler.DefaultGroup will be used. + Type of the job. + if set to true, job will be durable. + if set to true, job will request recovery. + + ArgumentException if name is null or empty, or the group is an empty string. + + + + + Validates whether the properties of the are + valid for submission into a . + + + + + Return a simple string representation of this object. + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Determines whether the specified detail is equal to this instance. + + The detail to examine. + + true if the specified detail is equal; otherwise, false. + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + if the specified is equal to the + current ; otherwise, . + + + + + Checks equality between given job detail and this instance. + + The detail to compare this instance with. + + + + + Serves as a hash function for a particular type, suitable + for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Get or sets the name of this . + + + if name is null or empty. + + + + + Get or sets the group of this . + If , will be used. + + + If the group is an empty string. + + + + + Returns the 'full name' of the in the format + "group.name". + + + + + Gets the key. + + The key. + + + + Get or set the description given to the instance by its + creator (if any). + + + May be useful for remembering/displaying the purpose of the job, though the + description has no meaning to Quartz. + + + + + Get or sets the instance of that will be executed. + + + if jobType is null or the class is not a . + + + + + Get or set the that is associated with the . + + + + + Set whether or not the the should re-Execute + the if a 'recovery' or 'fail-over' situation is + encountered. + + If not explicitly set, the default value is . + + + + + + + Whether or not the should remain stored after it is + orphaned (no s point to it). + + If not explicitly set, the default value is . + + + + if the Job should remain persisted after + being orphaned. + + + + + Whether the associated Job class carries the attribute. + + + + + Whether the associated Job class carries the attribute. + + + + + A context bundle containing handles to various environment information, that + is given to a instance as it is + executed, and to a instance after the + execution completes. + + + + The found on this object (via the + method) serves as a convenience - + it is a merge of the found on the + and the one found on the , with + the value in the latter overriding any same-named values in the former. + It is thus considered a 'best practice' that the Execute code of a Job + retrieve data from the JobDataMap found on this object + + + NOTE: Do not + expect value 'set' into this JobDataMap to somehow be set back onto a + job's own JobDataMap. + + + + s are also returned from the + + method. These are the same instances as those past into the jobs that are + currently executing within the scheduler. The exception to this is when your + application is using Quartz remotely (i.e. via remoting or WCF) - in which case you get + a clone of the s, and their references to + the and instances have been lost (a + clone of the is still available - just not a handle + to the job instance that is running). + + + + + + + + James House + Marko Lahma (.NET) + + + + A context bundle containing handles to various environment information, that + is given to a instance as it is + executed, and to a instance after the + execution completes. + + + + + Put the specified value into the context's data map with the given key. + Possibly useful for sharing data between listeners and jobs. + + NOTE: this data is volatile - it is lost after the job execution + completes, and all TriggerListeners and JobListeners have been + notified. + + + + + + + + + + Get the value with the given key from the context's data map. + + + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the referenced by the + instance that fired the . + + + + + If the is being re-executed because of a 'recovery' + situation, this method will return . + + + + + Gets the refire count. + + The refire count. + + + + Get the convenience of this execution context. + + + + The found on this object serves as a convenience - + it is a merge of the found on the + and the one found on the , with + the value in the latter overriding any same-named values in the former. + It is thus considered a 'best practice' that the Execute code of a Job + retrieve data from the JobDataMap found on this object. + + + NOTE: Do not expect value 'set' into this JobDataMap to somehow be + set back onto a job's own JobDataMap. + + + Attempts to change the contents of this map typically result in an + illegal state. + + + + + + Get the associated with the . + + + + + Get the instance of the that was created for this + execution. + + Note: The Job instance is not available through remote scheduler + interfaces. + + + + + + The actual time the trigger fired. For instance the scheduled time may + have been 10:00:00 but the actual fire time may have been 10:00:03 if + the scheduler was too busy. + + Returns the fireTimeUtc. + + + + + The scheduled time the trigger fired for. For instance the scheduled + time may have been 10:00:00 but the actual fire time may have been + 10:00:03 if the scheduler was too busy. + + Returns the scheduledFireTimeUtc. + + + + + Gets the previous fire time. + + The previous fire time. + + + + Gets the next fire time. + + The next fire time. + + + + Get the unique Id that identifies this particular firing instance of the + trigger that triggered this job execution. It is unique to this + JobExecutionContext instance as well. + + the unique fire instance id + + + + + Returns the result (if any) that the set before its + execution completed (the type of object set as the result is entirely up + to the particular job). + + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + Set the result (if any) of the 's execution (the type of + object set as the result is entirely up to the particular job). + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + + + + The amount of time the job ran for. The returned + value will be until the job has actually completed (or thrown an + exception), and is therefore generally only useful to + s and s. + + + + + Create a JobExcecutionContext with the given context data. + + + + + Increments the refire count. + + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Put the specified value into the context's data map with the given key. + Possibly useful for sharing data between listeners and jobs. + + NOTE: this data is volatile - it is lost after the job execution + completes, and all TriggerListeners and JobListeners have been + notified. + + + + + + + + + + Get the value with the given key from the context's data map. + + + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the instance that fired the + . + + + + + Get a handle to the referenced by the + instance that fired the . + + + + + If the is being re-executed because of a 'recovery' + situation, this method will return . + + + + + Gets the refire count. + + The refire count. + + + + Get the convenience of this execution context. + + + + The found on this object serves as a convenience - + it is a merge of the found on the + and the one found on the , with + the value in the latter overriding any same-named values in the former. + It is thus considered a 'best practice' that the Execute code of a Job + retrieve data from the JobDataMap found on this object. + + + NOTE: Do not expect value 'set' into this JobDataMap to somehow be + set back onto a job's own JobDataMap. + + + Attempts to change the contents of this map typically result in an + illegal state. + + + + + + Get the associated with the . + + + + + Get the instance of the that was created for this + execution. + + Note: The Job instance is not available through remote scheduler + interfaces. + + + + + + The actual time the trigger fired. For instance the scheduled time may + have been 10:00:00 but the actual fire time may have been 10:00:03 if + the scheduler was too busy. + + Returns the fireTimeUtc. + + + + + The scheduled time the trigger fired for. For instance the scheduled + time may have been 10:00:00 but the actual fire time may have been + 10:00:03 if the scheduler was too busy. + + Returns the scheduledFireTimeUtc. + + + + + Gets the previous fire time. + + The previous fire time. + + + + Gets the next fire time. + + The next fire time. + + + + Returns the result (if any) that the set before its + execution completed (the type of object set as the result is entirely up + to the particular job). + + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + Set the result (if any) of the 's execution (the type of + object set as the result is entirely up to the particular job). + + + The result itself is meaningless to Quartz, but may be informative + to s or + s that are watching the job's + execution. + + + + + + The amount of time the job ran for. The returned + value will be until the job has actually completed (or thrown an + exception), and is therefore generally only useful to + s and s. + + + + + Returns the fire instace id. + + + + + An implementation of the interface that remotely + proxies all method calls to the equivalent call on a given + instance, via remoting or similar technology. + + + + James House + Marko Lahma (.NET) + + + + This is the main interface of a Quartz Scheduler. + + + + A maintains a registry of + s and s. Once + registered, the is responsible for executing + s when their associated s + fire (when their scheduled time arrives). + + + instances are produced by a + . A scheduler that has already been + created/initialized can be found and used through the same factory that + produced it. After a has been created, it is in + "stand-by" mode, and must have its method + called before it will fire any s. + + + s are to be created by the 'client program', by + defining a class that implements the interface. + objects are then created (also by the client) to + define a individual instances of the . + instances can then be registered with the + via the %IScheduler.ScheduleJob(JobDetail, + Trigger)% or %IScheduler.AddJob(JobDetail, bool)% method. + + + s can then be defined to fire individual + instances based on given schedules. + s are most useful for one-time firings, or + firing at an exact moment in time, with N repeats with a given delay between + them. s allow scheduling based on time of day, + day of week, day of month, and month of year. + + + s and s have a name and + group associated with them, which should uniquely identify them within a single + . The 'group' feature may be useful for creating + logical groupings or categorizations of s and + s. If you don't have need for assigning a group to a + given s of s, then you can use + the constant defined on + this interface. + + + Stored s can also be 'manually' triggered through the + use of the %IScheduler.TriggerJob(string, string)% function. + + + Client programs may also be interested in the 'listener' interfaces that are + available from Quartz. The interface provides + notifications of executions. The + interface provides notifications of + firings. The + interface provides notifications of events and + errors. Listeners can be associated with local schedulers through the + interface. + + + The setup/configuration of a instance is very + customizable. Please consult the documentation distributed with Quartz. + + + + + + + + + Marko Lahma (.NET) + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Get a object describing the settings + and capabilities of the scheduler instance. + + + Note that the data returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the meta data values may be different. + + + + + Return a list of objects that + represent all currently executing Jobs in this Scheduler instance. + + + + This method is not cluster aware. That is, it will only return Jobs + currently executing in this Scheduler instance, not across the entire + cluster. + + + Note that the list returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the true list of executing jobs may be different. + Also please read the doc associated with - + especially if you're using remoting. + + + + + + + Get the names of all known groups. + + + + + Get the names of all known groups. + + + + + Get the names of all groups that are paused. + + + + + Starts the 's threads that fire s. + When a scheduler is first created it is in "stand-by" mode, and will not + fire triggers. The scheduler can also be put into stand-by mode by + calling the method. + + + The misfire/recovery process will be started, if it is the initial call + to this method on this scheduler instance. + + + + + + + + Calls after the indicated delay. + (This call does not block). This can be useful within applications that + have initializers that create the scheduler immediately, before the + resources needed by the executing jobs have been fully initialized. + + + + + + + + Temporarily halts the 's firing of s. + + + + When is called (to bring the scheduler out of + stand-by mode), trigger misfire instructions will NOT be applied + during the execution of the method - any misfires + will be detected immediately afterward (by the 's + normal process). + + + The scheduler is not destroyed, and can be re-started at any time. + + + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the Scheduler. Equivalent to + . + + + The scheduler cannot be re-started. + + + + + + Halts the 's firing of s, + and cleans up all resources associated with the Scheduler. + + + The scheduler cannot be re-started. + + + if the scheduler will not allow this method + to return until all currently executing jobs have completed. + + + + + + Add the given to the + Scheduler, and associate the given with + it. + + + If the given Trigger does not reference any , then it + will be set to reference the Job passed with it into this method. + + + + + Schedule the given with the + identified by the 's settings. + + + + + Schedule all of the given jobs with the related set of triggers. + + + If any of the given jobs or triggers already exist (or more + specifically, if the keys are not unique) and the replace + parameter is not set to true then an exception will be thrown. + + + + + Remove the indicated from the scheduler. + If the related job does not have any other triggers, and the job is + not durable, then the job will also be deleted. + + + + + Remove all of the indicated s from the scheduler. + + + If the related job does not have any other triggers, and the job is + not durable, then the job will also be deleted. + Note that while this bulk operation is likely more efficient than + invoking several + times, it may have the adverse affect of holding data locks for a + single long duration of time (rather than lots of small durations + of time). + + + + + Remove (delete) the with the + given key, and store the new given one - which must be associated + with the same job (the new trigger must have the job name & group specified) + - however, the new trigger need not have the same name as the old trigger. + + The to be replaced. + + The new to be stored. + + + if a with the given + name and group was not found and removed from the store (and the + new trigger is therefore not stored), otherwise + the first fire time of the newly scheduled trigger. + + + + + Add the given to the Scheduler - with no associated + . The will be 'dormant' until + it is scheduled with a , or + is called for it. + + + The must by definition be 'durable', if it is not, + SchedulerException will be thrown. + + + + + Delete the identified from the Scheduler - and any + associated s. + + true if the Job was found and deleted. + + + + Delete the identified jobs from the Scheduler - and any + associated s. + + + Note that while this bulk operation is likely more efficient than + invoking several + times, it may have the adverse affect of holding data locks for a + single long duration of time (rather than lots of small durations + of time). + + + true if all of the Jobs were found and deleted, false if + one or more were not deleted. + + + + + Trigger the identified + (Execute it now). + + + + + Trigger the identified (Execute it now). + + + the (possibly ) JobDataMap to be + associated with the trigger that fires the job immediately. + + + The of the to be executed. + + + + + Pause the with the given + key - by pausing all of its current s. + + + + + Pause all of the s in the + matching groups - by pausing all of their s. + + + + The Scheduler will "remember" that the groups are paused, and impose the + pause on any new jobs that are added to any of those groups until it is resumed. + + NOTE: There is a limitation that only exactly matched groups + can be remembered as paused. For example, if there are pre-existing + job in groups "aaa" and "bbb" and a matcher is given to pause + groups that start with "a" then the group "aaa" will be remembered + as paused and any subsequently added jobs in group "aaa" will be paused, + however if a job is added to group "axx" it will not be paused, + as "axx" wasn't known at the time the "group starts with a" matcher + was applied. HOWEVER, if there are pre-existing groups "aaa" and + "bbb" and a matcher is given to pause the group "axx" (with a + group equals matcher) then no jobs will be paused, but it will be + remembered that group "axx" is paused and later when a job is added + in that group, it will become paused. + + + + + + Pause the with the given key. + + + + + Pause all of the s in the groups matching. + + + + The Scheduler will "remember" all the groups paused, and impose the + pause on any new triggers that are added to any of those groups until it is resumed. + + NOTE: There is a limitation that only exactly matched groups + can be remembered as paused. For example, if there are pre-existing + triggers in groups "aaa" and "bbb" and a matcher is given to pause + groups that start with "a" then the group "aaa" will be remembered as + paused and any subsequently added triggers in that group be paused, + however if a trigger is added to group "axx" it will not be paused, + as "axx" wasn't known at the time the "group starts with a" matcher + was applied. HOWEVER, if there are pre-existing groups "aaa" and + "bbb" and a matcher is given to pause the group "axx" (with a + group equals matcher) then no triggers will be paused, but it will be + remembered that group "axx" is paused and later when a trigger is added + in that group, it will become paused. + + + + + + Resume (un-pause) the with + the given key. + + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + Resume (un-pause) all of the s + in matching groups. + + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Resume (un-pause) the with the given + key. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + Resume (un-pause) all of the s in matching groups. + + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Pause all triggers - similar to calling + on every group, however, after using this method + must be called to clear the scheduler's state of 'remembering' that all + new triggers will be paused as they are added. + + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + + Resume (un-pause) all triggers - similar to calling + on every group. + + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Get the keys of all the s in the matching groups. + + + + + Get all s that are associated with the + identified . + + + The returned Trigger objects will be snap-shots of the actual stored + triggers. If you wish to modify a trigger, you must re-store the + trigger afterward (e.g. see ). + + + + + Get the names of all the s in the given + groups. + + + + + Get the for the + instance with the given key . + + + The returned JobDetail object will be a snap-shot of the actual stored + JobDetail. If you wish to modify the JobDetail, you must re-store the + JobDetail afterward (e.g. see ). + + + + + Get the instance with the given key. + + + The returned Trigger object will be a snap-shot of the actual stored + trigger. If you wish to modify the trigger, you must re-store the + trigger afterward (e.g. see ). + + + + + Get the current state of the identified . + + + + + + + + + + + Add (register) the given to the Scheduler. + + Name of the calendar. + The calendar. + if set to true [replace]. + whether or not to update existing triggers that + referenced the already existing calendar so that they are 'correct' + based on the new trigger. + + + + Delete the identified from the Scheduler. + + + If removal of the Calendar would result in + s pointing to non-existent calendars, then a + will be thrown. + + Name of the calendar. + true if the Calendar was found and deleted. + + + + Get the instance with the given name. + + + + + Get the names of all registered . + + + + + Request the interruption, within this Scheduler instance, of all + currently executing instances of the identified , which + must be an implementor of the interface. + + + + If more than one instance of the identified job is currently executing, + the method will be called on + each instance. However, there is a limitation that in the case that + on one instances throws an exception, all + remaining instances (that have not yet been interrupted) will not have + their method called. + + + + If you wish to interrupt a specific instance of a job (when more than + one is executing) you can do so by calling + to obtain a handle + to the job instance, and then invoke on it + yourself. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + + true is at least one instance of the identified job was found and interrupted. + + + + + + + Request the interruption, within this Scheduler instance, of the + identified executing job instance, which + must be an implementor of the interface. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + + + + + the unique identifier of the job instance to be interrupted (see + + + true if the identified job instance was found and interrupted. + + + + Determine whether a with the given identifier already + exists within the scheduler. + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + the identifier to check for + true if a Trigger exists with the given identifier + + + + Clears (deletes!) all scheduling data - all s, s + s. + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Reports whether the is in stand-by mode. + + + + + + + Reports whether the has been Shutdown. + + + + + Set the that will be responsible for producing + instances of classes. + + + JobFactories may be of use to those wishing to have their application + produce instances via some special mechanism, such as to + give the opportunity for dependency injection. + + + + + + Get a reference to the scheduler's , + through which listeners may be registered. + + the scheduler's + + + + + + + + Whether the scheduler has been started. + + + Note: This only reflects whether has ever + been called on this Scheduler, so it will return even + if the is currently in standby mode or has been + since shutdown. + + + + + + + + Construct a instance to proxy the given + RemoteableQuartzScheduler instance. + + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Get a object describiing the settings + and capabilities of the scheduler instance. + + Note that the data returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the meta data values may be different. + + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Get the names of all groups that are paused. + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Get the names of all registered . + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Set the that will be responsible for producing + instances of classes. + + JobFactories may be of use to those wishing to have their application + produce instances via some special mechanism, such as to + give the opertunity for dependency injection. + + + + + SchedulerException + + + + Whether the scheduler has been started. + + + + Note: This only reflects whether has ever + been called on this Scheduler, so it will return even + if the is currently in standby mode or has been + since shutdown. + + + + + + + + This utility calls methods reflectively on the given objects even though the + methods are likely on a proper interface (ThreadPool, JobStore, etc). The + motivation is to be tolerant of older implementations that have not been + updated for the changes in the interfaces (eg. LocalTaskExecutorThreadPool in + spring quartz helpers) + + teck + Marko Lahma (.NET) + + + + Holds references to Scheduler instances - ensuring uniqueness, and + preventing garbage collection, and allowing 'global' lookups. + + James House + Marko Lahma (.NET) + + + + Binds the specified sched. + + The sched. + + + + Removes the specified sched name. + + Name of the sched. + + + + + Lookups the specified sched name. + + Name of the sched. + + + + + Lookups all. + + + + + + Gets the singleton instance. + + The instance. + + + + Responsible for creating the instances of + to be used within the instance. + + James House + Marko Lahma (.NET) + + + + Initialize the factory, providing a handle to the + that should be made available within the and + the s within it. + + + + + Called by the to obtain instances of + . + + + + + An implementation of the interface that directly + proxies all method calls to the equivalent call on a given + instance. + + + + James House + Marko Lahma (.NET) + + + + returns true if the given JobGroup + is paused + + + + + + + returns true if the given TriggerGroup + is paused + + + + + + + Get a object describiing the settings + and capabilities of the scheduler instance. + + Note that the data returned is an 'instantaneous' snap-shot, and that as + soon as it's returned, the meta data values may be different. + + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Construct a instance to proxy the given + instance. + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Get the names of all registered . + + + + + + Request the interruption, within this Scheduler instance, of all + currently executing instances of the identified , which + must be an implementor of the interface. + + + + If more than one instance of the identified job is currently executing, + the method will be called on + each instance. However, there is a limitation that in the case that + on one instances throws an exception, all + remaining instances (that have not yet been interrupted) will not have + their method called. + + + If you wish to interrupt a specific instance of a job (when more than + one is executing) you can do so by calling + to obtain a handle + to the job instance, and then invoke on it + yourself. + + + This method is not cluster aware. That is, it will only interrupt + instances of the identified InterruptableJob currently executing in this + Scheduler instance, not across the entire cluster. + + + true is at least one instance of the identified job was found and interrupted. + UnableToInterruptJobException if the job does not implement + + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the of the . + + + + + Whether the scheduler has been started. + + + + Note: This only reflects whether has ever + been called on this Scheduler, so it will return even + if the is currently in standby mode or has been + since shutdown. + + + + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + Calls the equivalent method on the 'proxied' . + + + + + + + + + An implementation of that + does all of it's work of creating a instance + based on the contents of a properties file. + + + + By default a properties are loaded from App.config's quartz section. + If that fails, then the file is loaded "quartz.properties". If file does not exist, + default configration located (as a embedded resource) in Quartz.dll is loaded. If you + wish to use a file other than these defaults, you must define the system + property 'quartz.properties' to point to the file you want. + + + See the sample properties that are distributed with Quartz for + information about the various settings available within the file. + + + Alternativly, you can explicitly Initialize the factory by calling one of + the methods before calling . + + + Instances of the specified , + , classes will be created + by name, and then any additional properties specified for them in the config + file will be set on the instance by calling an equivalent 'set' method. For + example if the properties file contains the property 'quartz.jobStore. + myProp = 10' then after the JobStore class has been instantiated, the property + 'MyProp' will be set with the value. Type conversion to primitive CLR types + (int, long, float, double, boolean, enum and string) are performed before calling + the property's setter method. + + + James House + Anthony Eden + Mohammad Rezaei + Marko Lahma (.NET) + + + + Returns a handle to the default Scheduler, creating it if it does not + yet exist. + + + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The props. + + + + Initialize the . + + + By default a properties file named "quartz.properties" is loaded from + the 'current working directory'. If that fails, then the + "quartz.properties" file located (as an embedded resource) in the Quartz.NET + assembly is loaded. If you wish to use a file other than these defaults, + you must define the system property 'quartz.properties' to point to + the file you want. + + + + + Creates a new name value collection and overrides its values + with system values (environment variables). + + The base properties to override. + A new NameValueCollection instance. + + + + Initialize the with + the contents of the given key value collection object. + + + + + + + + Needed while loadhelper is not constructed. + + + + + + + Returns a handle to the Scheduler produced by this factory. + + + If one of the methods has not be previously + called, then the default (no-arg) method + will be called by this method. + + + + + Returns a handle to the Scheduler with the given name, if it exists (if + it has already been instantiated). + + + + + + Returns a handle to all known Schedulers (made by any + StdSchedulerFactory instance.). + + + + + + Inspects a directory and compares whether any files' "last modified dates" + have changed since the last time it was inspected. If one or more files + have been updated (or created), the job invokes a "call-back" method on an + identified that can be found in the + . + + pl47ypus + James House + Marko Lahma (.NET) + + + + + The interface to be implemented by classes which represent a 'job' to be + performed. + + + Instances of this interface must have a + no-argument constructor. provides a mechanism for 'instance member data' + that may be required by some implementations of this interface. + + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + fires that is associated with the . + + + The implementation may wish to set a result object on the + JobExecutionContext before this method exits. The result itself + is meaningless to Quartz, but may be informative to + s or + s that are watching the job's + execution. + + The execution context. + + + key with which to specify the directory to be + monitored - an absolute path is recommended. + + + key with which to specify the + to be + notified when the directory contents change. + + + key with which to specify a + value that represents the minimum number of milliseconds that must have + passed since the file's last modified time in order to consider the file + new/altered. This is necessary because another process may still be + in the middle of writing to the file when the scan occurs, and the + file may therefore not yet be ready for processing. + If this parameter is not specified, a default value of 5000 (five seconds) will be used. + + + + This is the main entry point for job execution. The scheduler will call this method on the + job once it is triggered. + + The that + the job will use during execution. + + + + Inspects a file and compares whether it's "last modified date" has changed + since the last time it was inspected. If the file has been updated, the + job invokes a "call-back" method on an identified + that can be found in the + . + + James House + Marko Lahma (.NET) + + + + + JobDataMap key with which to specify the name of the file to monitor. + + + + + JobDataMap key with which to specify the + to be notified when the file contents change. + + + + + key with which to specify a long + value that represents the minimum number of milliseconds that must have + past since the file's last modified time in order to consider the file + new/altered. This is necessary because another process may still be + in the middle of writing to the file when the scan occurs, and the + file may therefore not yet be ready for processing. + + If this parameter is not specified, a default value of + 5000 (five seconds) will be used. + + + + + Initializes a new instance of the class. + + + + + Called by the when a + fires that is associated with the . + + The implementation may wish to set a result object on the + JobExecutionContext before this method exits. The result itself + is meaningless to Quartz, but may be informative to + s or + s that are watching the job's + execution. + + + The execution context. + + + + + + Gets the last modified date. + + Name of the file. + + + + + Gets the log. + + The log. + + + Interface for objects wishing to receive a 'call-back' from a + Instances should be stored in the such that the + can find it. + James House + Marko Lahma (.NET) + + + An array of objects that were updated/added + since the last scan of the directory + + + + Interface for objects wishing to receive a 'call-back' from a + . + + James House + Marko Lahma (.NET) + + + + + Ãnforms that certain file has been updated. + + Name of the file. + + + + Built in job for executing native executables in a separate process. + + + + JobDetail job = new JobDetail("dumbJob", null, typeof(Quartz.Jobs.NativeJob)); + job.JobDataMap.Put(Quartz.Jobs.NativeJob.PropertyCommand, "echo \"hi\" >> foobar.txt"); + Trigger trigger = TriggerUtils.MakeSecondlyTrigger(5); + trigger.Name = "dumbTrigger"; + sched.ScheduleJob(job, trigger); + + If PropertyWaitForProcess is true, then the integer exit value of the process + will be saved as the job execution result in the JobExecutionContext. + + Matthew Payne + James House + Steinar Overbeck Cook + Marko Lahma (.NET) + + + + Required parameter that specifies the name of the command (executable) + to be ran. + + + + + Optional parameter that specifies the parameters to be passed to the + executed command. + + + + + Optional parameter (value should be 'true' or 'false') that specifies + whether the job should wait for the execution of the native process to + complete before it completes. + + Defaults to . + + + + + Optional parameter (value should be 'true' or 'false') that specifies + whether the spawned process's stdout and stderr streams should be + consumed. If the process creates output, it is possible that it might + 'hang' if the streams are not consumed. + + Defaults to . + + + + + Optional parameter that specifies the workling directory to be used by + the executed command. + + + + + Initializes a new instance of the class. + + + + + Called by the when a + fires that is associated with the . + + The implementation may wish to set a result object on the + JobExecutionContext before this method exits. The result itself + is meaningless to Quartz, but may be informative to + s or + s that are watching the job's + execution. + + + + + + + Gets the log. + + The log. + + + + Consumes data from the given input stream until EOF and prints the data to stdout + + cooste + James House + + + + Initializes a new instance of the class. + + The enclosing instance. + The input stream. + The type. + + + + Runs this object as a separate thread, printing the contents of the input stream + supplied during instantiation, to either Console. or stderr + + + + + An implementation of Job, that does absolutely nothing - useful for system + which only wish to use s + and s, rather than writing + Jobs that perform work. + + James House + Marko Lahma (.NET) + + + + Do nothing. + + + + + A Job which sends an e-mail with the configured content to the configured + recipient. + + James House + Marko Lahma (.NET) + + + The host name of the smtp server. REQUIRED. + + + The e-mail address to send the mail to. REQUIRED. + + + The e-mail address to cc the mail to. Optional. + + + The e-mail address to claim the mail is from. REQUIRED. + + + The e-mail address the message should say to reply to. Optional. + + + The subject to place on the e-mail. REQUIRED. + + + The e-mail message body. REQUIRED. + + + + Executes the job. + + The job execution context. + + + + Holds a List of references to JobListener instances and broadcasts all + events to them (in order). + + + The broadcasting behavior of this listener to delegate listeners may be + more convenient than registering all of the listeners directly with the + Scheduler, and provides the flexibility of easily changing which listeners + get notified. + + + + + James House (jhouse AT revolition DOT net) + + + + Construct an instance with the given name. + + + (Remember to add some delegate listeners!) + + the name of this instance + + + + Construct an instance with the given name, and List of listeners. + + + + the name of this instance + the initial List of JobListeners to broadcast to. + + + + Holds a List of references to SchedulerListener instances and broadcasts all + events to them (in order). + + + This may be more convenient than registering all of the listeners + directly with the Scheduler, and provides the flexibility of easily changing + which listeners get notified. + + + + James House + Marko Lahma (.NET) + + + + Construct an instance with the given List of listeners. + + The initial List of SchedulerListeners to broadcast to. + + + + Holds a List of references to TriggerListener instances and broadcasts all + events to them (in order). + + + The broadcasting behavior of this listener to delegate listeners may be + more convenient than registering all of the listeners directly with the + Scheduler, and provides the flexibility of easily changing which listeners + get notified. + + + + + James House (jhouse AT revolition DOT net) + + + + The interface to be implemented by classes that want to be informed when a + fires. In general, applications that use a + will not have use for this mechanism. + + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called before the method of this + interface. + + + The that has fired. + + The that will be passed to the 's method. + + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called after the method of this + interface. If the implementation vetos the execution (via + returning ), the job's execute method will not be called. + + + The that has fired. + The that will be passed to + the 's method. + Returns true if job execution should be vetoed, false otherwise. + + + + Called by the when a + has misfired. + + Consideration should be given to how much time is spent in this method, + as it will affect all triggers that are misfiring. If you have lots + of triggers misfiring at once, it could be an issue it this method + does a lot. + + + The that has misfired. + + + + Called by the when a + has fired, it's associated + has been executed, and it's method has been + called. + + The that was fired. + + The that was passed to the + 's method. + + + The result of the call on the 's method. + + + + + Get the name of the . + + + + + Construct an instance with the given name. + + + (Remember to add some delegate listeners!) + + the name of this instance + + + + Construct an instance with the given name, and List of listeners. + + + + the name of this instance + the initial List of TriggerListeners to broadcast to. + + + + Keeps a collection of mappings of which Job to trigger after the completion + of a given job. If this listener is notified of a job completing that has a + mapping, then it will then attempt to trigger the follow-up job. This + achieves "job chaining", or a "poor man's workflow". + + + + Generally an instance of this listener would be registered as a global + job listener, rather than being registered directly to a given job. + + + If for some reason there is a failure creating the trigger for the + follow-up job (which would generally only be caused by a rare serious + failure in the system, or the non-existence of the follow-up job), an error + messsage is logged, but no other action is taken. If you need more rigorous + handling of the error, consider scheduling the triggering of the flow-up + job within your job itself. + + + James House + Marko Lahma (.NET) + + + + A helpful abstract base class for implementors of . + + + + The methods in this class are empty so you only need to override the + subset for the events you care about. + + + + You are required to implement + to return the unique name of your . + + + Marko Lahma (.NET) + + + + + Initializes a new instance of the class. + + + + + Called by the when a + is about to be executed (an associated + has occured). + + This method will not be invoked if the execution of the Job was vetoed + by a . + + + + + + + + Called by the when a + was about to be executed (an associated + has occured), but a vetoed it's + execution. + + + + + + + Called by the after a + has been executed, and be for the associated 's + method has been called. + + + + + + + Get the for this class's category. + This should be used by subclasses for logging. + + + + + Get the name of the . + + + + + + Construct an instance with the given name. + + The name of this instance. + + + + Add a chain mapping - when the Job identified by the first key completes + the job identified by the second key will be triggered. + + a JobKey with the name and group of the first job + a JobKey with the name and group of the follow-up job + + + + A helpful abstract base class for implementors of + . + + + + The methods in this class are empty so you only need to override the + subset for the events + you care about. + + + + You are required to implement + to return the unique name of your . + + + Marko Lahma (.NET) + + + + + Get the for this + class's category. This should be used by subclasses for logging. + + + + + Get the name of the . + + + + + + Logs a history of all job executions (and execution vetos) via common + logging. + + + + The logged message is customizable by setting one of the following message + properties to a string that conforms to the syntax of . + + + JobToBeFiredMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
+ The default message text is "Job {1}.{0} fired (by trigger {4}.{3}) at: + {2, date, HH:mm:ss MM/dd/yyyy" +
+ + JobSuccessMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
8ObjectThe string value (toString() having been called) of the result (if any) + that the Job set on the JobExecutionContext, with on it. "NULL" if no + result was set.
+ The default message text is "Job {1}.{0} execution complete at {2, date, + HH:mm:ss MM/dd/yyyy} and reports: {8" +
+ + JobFailedMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
8StringThe message from the thrown JobExecution Exception. +
+ The default message text is "Job {1}.{0} execution failed at {2, date, + HH:mm:ss MM/dd/yyyy} and reports: {8" +
+ + JobWasVetoedMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Job's Name.
1StringThe Job's Group.
2DateThe current time.
3StringThe Trigger's name.
4StringThe Triggers's group.
5DateThe scheduled fire time.
6DateThe next scheduled fire time.
7IntegerThe re-fire count from the JobExecutionContext.
+ The default message text is "Job {1}.{0} was vetoed. It was to be fired + (by trigger {4}.{3}) at: {2, date, HH:mm:ss MM/dd/yyyy" +
+
+ Marko Lahma (.NET) +
+ + + Provides an interface for a class to become a "plugin" to Quartz. + + + Plugins can do virtually anything you wish, though the most interesting ones + will obviously interact with the scheduler in some way - either actively: by + invoking actions on the scheduler, or passively: by being a , + , and/or . + + If you use to + Initialize your Scheduler, it can also create and Initialize your plugins - + look at the configuration docs for details. + + + If you need direct access your plugin, you can have it explicitly put a + reference to itself in the 's + as part of its + method. + + + James House + Marko Lahma (.NET) + + + + Called during creation of the in order to give + the a chance to Initialize. + + + At this point, the Scheduler's is not yet + + If you need direct access your plugin, you can have it explicitly put a + reference to itself in the 's + as part of its + method. + + + + The name by which the plugin is identified. + + + The scheduler to which the plugin is registered. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Called during creation of the in order to give + the a chance to Initialize. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Called by the when a is + about to be executed (an associated has occurred). + + This method will not be invoked if the execution of the Job was vetoed by a + . + + + + + + + Called by the after a + has been executed, and be for the associated 's + method has been called. + + + + + + + Called by the when a + was about to be executed (an associated + has occured), but a vetoed it's + execution. + + + + + + + Logger instance to use. Defaults to common logging. + + + + + Get or sets the message that is logged when a Job successfully completes its + execution. + + + + + Get or sets the message that is logged when a Job fails its + execution. + + + + + Gets or sets the message that is logged when a Job is about to Execute. + + + + + Gets or sets the message that is logged when a Job execution is vetoed by a + trigger listener. + + + + + Get the name of the . + + + + + + Logs a history of all trigger firings via the Jakarta Commons-Logging + framework. + + + + The logged message is customizable by setting one of the following message + properties to a string that conforms to the syntax of . + + + + TriggerFiredMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Trigger's Name.
1StringThe Trigger's Group.
2DateThe scheduled fire time.
3DateThe next scheduled fire time.
4DateThe actual fire time.
5StringThe Job's name.
6StringThe Job's group.
7IntegerThe re-fire count from the JobExecutionContext.
+ + The default message text is "Trigger {1}.{0} fired job {6}.{5} at: {4, + date, HH:mm:ss MM/dd/yyyy" +
+ + + TriggerMisfiredMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Trigger's Name.
1StringThe Trigger's Group.
2DateThe scheduled fire time.
3DateThe next scheduled fire time.
4DateThe actual fire time. (the time the misfire was detected/handled)
5StringThe Job's name.
6StringThe Job's group.
+ + The default message text is "Trigger {1}.{0} misfired job {6}.{5} at: + {4, date, HH:mm:ss MM/dd/yyyy}. Should have fired at: {3, date, HH:mm:ss + MM/dd/yyyy" +
+ + + TriggerCompleteMessage - available message data are: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ElementData TypeDescription
0StringThe Trigger's Name.
1StringThe Trigger's Group.
2DateThe scheduled fire time.
3DateThe next scheduled fire time.
4DateThe job completion time.
5StringThe Job's name.
6StringThe Job's group.
7IntegerThe re-fire count from the JobExecutionContext.
8IntegerThe trigger's resulting instruction code.
9StringA human-readable translation of the trigger's resulting instruction + code.
+ + The default message text is "Trigger {1}.{0} completed firing job + {6}.{5} at {4, date, HH:mm:ss MM/dd/yyyy} with resulting trigger instruction + code: {9" +
+
+ James House + Marko Lahma (.NET) +
+ + + Called during creation of the in order to give + the a chance to Initialize. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called before the method of this + interface. + + + The that has fired. + The that will be passed to the 's method. + + + + Called by the when a + has misfired. + + Consideration should be given to how much time is spent in this method, + as it will affect all triggers that are misfiring. If you have lots + of triggers misfiring at once, it could be an issue it this method + does a lot. + + + The that has misfired. + + + + Called by the when a + has fired, it's associated + has been executed, and it's method has been + called. + + The that was fired. + The that was passed to the + 's method. + The result of the call on the 's method. + + + + Called by the when a + has fired, and it's associated + is about to be executed. + + It is called after the method of this + interface. + + + The that has fired. + The that will be passed to + the 's method. + + + + + Logger instance to use. Defaults to common logging. + + + + + Get or set the message that is printed upon the completion of a trigger's + firing. + + + + + Get or set the message that is printed upon a trigger's firing. + + + + + Get or set the message that is printed upon a trigger's mis-firing. + + + + + Get the name of the . + + + + + + This plugin catches the event of the VM terminating (such as upon a CRTL-C) + and tells the scheuler to Shutdown. + + + James House + Marko Lahma (.NET) + + + + Called during creation of the in order to give + the a chance to Initialize. + + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Determine whether or not the plug-in is configured to cause a clean + Shutdown of the scheduler. + + The default value is . + + + + + + + This plugin loads XML file(s) to add jobs and schedule them with triggers + as the scheduler is initialized, and can optionally periodically scan the + file for changes. + + + The periodically scanning of files for changes is not currently supported in a + clustered environment. + + James House + Pierre Awaragi + + + + Initializes a new instance of the class. + + + + + + + + + + + Called during creation of the in order to give + the a chance to initialize. + + The name. + The scheduler. + SchedulerConfigException + + + + Called when the associated is started, in order + to let the plug-in know it can now make calls into the scheduler if it + needs to. + + + + + Helper method for generating unique job/trigger name for the + file scanning jobs (one per FileJob). The unique names are saved + in jobTriggerNameSet. + + + + + + + Called in order to inform the that it + should free up all of it's resources because the scheduler is shutting + down. + + + + + Gets the log. + + The log. + + + + Comma separated list of file names (with paths) to the XML files that should be read. + + + + + The interval at which to scan for changes to the file. + If the file has been changed, it is re-loaded and parsed. The default + value for the interval is 0, which disables scanning. + + + + + Whether or not initialization of the plugin should fail (throw an + exception) if the file cannot be found. Default is . + + + + + Information about a file that should be processed by . + + + + + Default object serialization strategy that uses + under the hood. + + Marko Lahma + + + + Interface for object serializers. + + Marko Lahma + + + + + Serializes given object as bytes + that can be stored to permanent stores. + + Object to serialize, always non-null. + + + + Deserializes object from byte array presentation. + + Data to deserialize object from, always non-null and non-empty. + + + + Serializes given object as bytes + that can be stored to permanent stores. + + Object to serialize. + + + + Deserializes object from byte array presentation. + + Data to deserialize object from. + + + + that names the scheduler instance using + just the machine hostname. + + + This class is useful when you know that your scheduler instance will be the + only one running on a particular machine. Each time the scheduler is + restarted, it will get the same instance id as long as the machine is not + renamed. + + Marko Lahma (.NET) + + + + + + An IInstanceIdGenerator is responsible for generating the clusterwide unique + instance id for a node. + + + This interface may be of use to those wishing to have specific control over + the mechanism by which the instances in their + application are named. + + + Marko Lahma (.NET) + + + + Generate the instance id for a + + The clusterwide unique instance id. + + + + + Generate the instance id for a + + The clusterwide unique instance id. + + + + A JobFactory that instantiates the Job instance (using the default no-arg + constructor, or more specifically: ), and + then attempts to set all values from the and + the 's merged onto + properties of the job. + + + Set the WarnIfPropertyNotFound property to true if you'd like noisy logging in + the case of values in the not mapping to properties on your job + class. This may be useful for troubleshooting typos of property names, etc. + but very noisy if you regularly (and purposely) have extra things in your + . + Also of possible interest is the ThrowIfPropertyNotFound property which + will throw exceptions on unmatched JobDataMap keys. + + + + + + + + James Houser + Marko Lahma (.NET) + + + + The default JobFactory used by Quartz - simply calls + on the job class. + + + + James House + Marko Lahma (.NET) + + + + A JobFactory is responsible for producing instances of + classes. + + + This interface may be of use to those wishing to have their application + produce instances via some special mechanism, such as to + give the opertunity for dependency injection. + + + + + James House + Marko Lahma (.NET) + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + + a handle to the scheduler that is about to execute the job + SchedulerException if there is a problem instantiating the Job. + the newly instantiated Job + + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + + the newly instantiated Job + SchedulerException if there is a problem instantiating the Job. + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + + the newly instantiated Job + SchedulerException if there is a problem instantiating the Job. + + + + Sets the object properties. + + The object to set properties to. + The data to set. + + + + Whether the JobInstantiation should fail and throw and exception if + a key (name) and value (type) found in the JobDataMap does not + correspond to a proptery setter on the Job class. + + + + + Get or set whether a warning should be logged if + a key (name) and value (type) found in the JobDataMap does not + correspond to a proptery setter on the Job class. + + + + + This class implements a that + utilizes RAM as its storage device. + + As you should know, the ramification of this is that access is extrememly + fast, but the data is completely volatile - therefore this + should not be used if true persistence between program shutdowns is + required. + + + James House + Sharada Jambula + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Gets the fired trigger record id. + + The fired trigger record id. + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Called by the QuartzScheduler to inform the that + the scheduler has started. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has been paused. + + + + + Called by the QuartzScheduler to inform the JobStore that + the scheduler has resumed after being paused. + + + + + Called by the QuartzScheduler to inform the that + it should free up all of it's resources because the scheduler is + shutting down. + + + + + Clears (deletes!) all scheduling data - all s, s + s. + + + + + Store the given and . + + The to be stored. + The to be stored. + + + + Returns true if the given job group is paused. + + Job group name + + + + + returns true if the given TriggerGroup is paused. + + + + + + + Store the given . + + The to be stored. + If , any existing in the + with the same name and group should be + over-written. + + + + Remove (delete) the with the given + name, and any s that reference + it. + + + if a with the given name and + group was found and removed from the store. + + + + + Remove (delete) the with the + given name. + + + if a with the given + name and group was found and removed from the store. + + + + + Store the given . + + The to be stored. + If , any existing in + the with the same name and group should + be over-written. + + + + Remove (delete) the with the + given name. + + + + if a with the given + name and group was found and removed from the store. + + The to be removed. + Whether to delete orpahaned job details from scheduler if job becomes orphaned from removing the trigger. + + + + Replaces the trigger. + + The of the to be replaced. + The new trigger. + + + + + Retrieve the for the given + . + + + The desired , or null if there is no match. + + + + + Retrieve the given . + + + The desired , or null if there is no match. + + + + + Determine whether a with the given identifier already + exists within the scheduler. + + the identifier to check for + true if a Job exists with the given identifier + + + + Determine whether a with the given identifier already + exists within the scheduler. + + triggerKey the identifier to check for + true if a Trigger exists with the given identifier + + + + Get the current state of the identified . + + + + + + + + + + + Store the given . + + The name. + The to be stored. + If , any existing + in the with the same name and group + should be over-written. + If , any s existing + in the that reference an existing + Calendar with the same name with have their next fire time + re-computed with the new . + + + + Remove (delete) the with the + given name. + + If removal of the would result in + s pointing to non-existent calendars, then a + will be thrown. + + The name of the to be removed. + + if a with the given name + was found and removed from the store. + + + + + Retrieve the given . + + The name of the to be retrieved. + + The desired , or null if there is no match. + + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the number of s that are + stored in the . + + + + + Get the names of all of the s that + match the given group matcher. + + + + + Get the names of all of the s + in the . + + If there are no ICalendars in the given group name, the result should be + a zero-length array (not ). + + + + + + Get the names of all of the s + that have the given group name. + + + + + Get the names of all of the + groups. + + + + + Get the names of all of the groups. + + + + + Get all of the Triggers that are associated to the given Job. + + If there are no matches, a zero-length array should be returned. + + + + + + Gets the trigger wrappers for job. + + + + + + Gets the trigger wrappers for calendar. + + Name of the cal. + + + + + Pause the with the given name. + + + + + Pause all of the s in the given group. + + The JobStore should "remember" that the group is paused, and impose the + pause on any new triggers that are added to the group while the group is + paused. + + + + + + Pause the with the given + name - by pausing all of its current s. + + + + + Pause all of the s in the + given group - by pausing all of their s. + + The JobStore should "remember" that the group is paused, and impose the + pause on any new jobs that are added to the group while the group is + paused. + + + + + + Resume (un-pause) the with the given key. + + + If the missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + Resume (un-pause) all of the s in the + given group. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + Resume (un-pause) the with + the given name. + + If any of the 's s missed one + or more fire-times, then the 's misfire + instruction will be applied. + + + + + + Resume (un-pause) all of the s + in the given group. + + If any of the s had s that + missed one or more fire-times, then the 's + misfire instruction will be applied. + + + + + + Pause all triggers - equivalent of calling + on every group. + + When is called (to un-pause), trigger misfire + instructions WILL be applied. + + + + + + + Resume (un-pause) all triggers - equivalent of calling + on every trigger group and setting all job groups unpaused />. + + If any missed one or more fire-times, then the + 's misfire instruction will be applied. + + + + + + + Applies the misfire. + + The trigger wrapper. + + + + + Get a handle to the next trigger to be fired, and mark it as 'reserved' + by the calling scheduler. + + + + + + Inform the that the scheduler no longer plans to + fire the given , that it had previously acquired + (reserved). + + + + + Inform the that the scheduler is now firing the + given (executing its associated ), + that it had previously acquired (reserved). + + + + + Inform the that the scheduler has completed the + firing of the given (and the execution its + associated ), and that the + in the given should be updated if the + is stateful. + + + + + Sets the state of all triggers of job to specified state. + + + + + Peeks the triggers. + + + + + + + + + The time span by which a trigger must have missed its + next-fire-time, in order for it to be considered "misfired" and thus + have its misfire instruction applied. + + + + + Returns whether this instance supports persistence. + + + + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + Comparer for trigger wrappers. + + + + + Indicates whether the current object is equal to another object of the same type. + + + true if the current object is equal to the parameter; otherwise, false. + + An object to compare with this object. + + + + Serves as a hash function for a particular type. + + + A hash code for the current . + + 2 + + + + Possible internal trigger states + in RAMJobStore + + + + + Waiting + + + + + Acquired + + + + + Executing + + + + + Complete + + + + + Paused + + + + + Blocked + + + + + Paused and Blocked + + + + + Error + + + + + Helper wrapper class + + + + + The key used + + + + + Job's key + + + + + The trigger + + + + + Current state + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + true if the specified is equal to the current ; otherwise, false. + + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Scheduler exporter that exports scheduler to remoting context. + + Marko Lahma + + + + Service interface for scheduler exporters. + + Marko Lahma + + + + Binds (exports) scheduler to external context. + + + + + + Unbinds scheduler from external context. + + + + + + Registers remoting channel if needed. This is determined + by checking whether there is a positive value for port. + + + + + Gets or sets the port used for remoting. + + + + + Gets or sets the name to use when exporting + scheduler to remoting context. + + + + + Gets or sets the name to use when binding to + tcp channel. + + + + + Sets the channel type when registering remoting. + + + + + + Sets the used when + exporting to remoting context. Defaults to + . + + + + + A implementation that creates + connection to remote scheduler using remoting. + + + + + Client Proxy to a IRemotableQuartzScheduler + + + + + Returns a client proxy to a remote . + + + + + Returns a client proxy to a remote . + + + + + Gets or sets the remote scheduler address. + + The remote scheduler address. + + + + The default InstanceIdGenerator used by Quartz when instance id is to be + automatically generated. Instance id is of the form HOSTNAME + CURRENT_TIME. + + Marko Lahma (.NET) + + + + + + Generate the instance id for a + + The clusterwide unique instance id. + + + + This is class is a simple implementation of a thread pool, based on the + interface. + + + objects are sent to the pool with the + method, which blocks until a becomes available. + + The pool has a fixed number of s, and does not grow or + shrink based on demand. + + James House + Juergen Donnerstag + Marko Lahma (.NET) + + + + The interface to be implemented by classes that want to provide a thread + pool for the 's use. + + + implementation instances should ideally be made + for the sole use of Quartz. Most importantly, when the method + returns a value of 1 or greater, + there must still be at least one available thread in the pool when the + method is called a few moments (or + many moments) later. If this assumption does not hold true, it may + result in extra JobStore queries and updates, and if clustering features + are being used, it may result in greater imballance of load. + + + James House + Marko Lahma (.NET) + + + + Execute the given in the next + available . + + + The implementation of this interface should not throw exceptions unless + there is a serious problem (i.e. a serious misconfiguration). If there + are no available threads, rather it should either queue the Runnable, or + block until a thread is available, depending on the desired strategy. + + + + + Determines the number of threads that are currently available in in + the pool. Useful for determining the number of times + can be called before returning + false. + + + The implementation of this method should block until there is at + least one available thread. + + the number of currently available threads + + + + Must be called before the is + used, in order to give the it a chance to Initialize. + + + Typically called by the . + + + + + Called by the QuartzScheduler to inform the + that it should free up all of it's resources because the scheduler is + shutting down. + + + + + Get the current number of threads in the . + + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + Create a new (unconfigured) . + + + + + Create a new with the specified number + of s that have the given priority. + + + the number of worker s in the pool, must + be > 0. + + + the thread priority for the worker threads. + + + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Terminate any worker threads in this thread group. + Jobs currently in progress will complete. + + + + + Run the given object in the next available + . If while waiting the thread pool is asked to + shut down, the Runnable is executed immediately within a new additional + thread. + + The to be added. + + + + Creates the worker threads. + + The thread count. + + + + + Terminate any worker threads in this thread group. + Jobs currently in progress will complete. + + + + + Gets or sets the number of worker threads in the pool. + Set has no effect after has been called. + + + + + Get or set the thread priority of worker threads in the pool. + Set operation has no effect after has been called. + + + + + Gets or sets the thread name prefix. + + The thread name prefix. + + + + Gets or sets the value of makeThreadsDaemons. + + + + + Gets the size of the pool. + + The size of the pool. + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + A Worker loops, waiting to Execute tasks. + + + + + Create a worker thread and start it. Waiting for the next Runnable, + executing it, and waiting for the next Runnable, until the Shutdown + flag is set. + + + + + Create a worker thread, start it, Execute the runnable and terminate + the thread (one time execution). + + + + + Signal the thread that it should terminate. + + + + + Loop, executing targets as they are received. + + + + + A that simply calls . + + + James House + Marko Lahma (.NET) + + + + Called to give the ClassLoadHelper a chance to Initialize itself, + including the oportunity to "steal" the class loader off of the calling + thread, which is the thread that is initializing Quartz. + + + + Return the class with the given name. + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a Uri object + + + + Finds a resource with a given name. This method returns null if no + resource with this name is found. + + name of the desired resource + + a Stream object + + + + + InstanceIdGenerator that will use a to configure the scheduler. + If no value set for the property, a is thrown. + Alex Snaps + + + + + System property to read the instanceId from. + + + + + Returns the cluster wide value for this scheduler instance's id, based on a system property. + + + + + A string of text to prepend (add to the beginning) to the instanceId found in the system property. + + + + + A string of text to postpend (add to the end) to the instanceId found in the system property. + + + + + The name of the system property from which to obtain the instanceId. + + + Defaults to . + + + + + This is class is a simple implementation of a zero size thread pool, based on the + interface. + + + The pool has zero s and does not grow or shrink based on demand. + Which means it is obviously not useful for most scenarios. When it may be useful + is to prevent creating any worker threads at all - which may be desirable for + the sole purpose of preserving system resources in the case where the scheduler + instance only exists in order to schedule jobs, but which will never execute + jobs (e.g. will never have Start() called on it). + + Wayne Fay + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Shutdowns this instance. + + + + + Called by the QuartzScheduler to inform the + that it should free up all of it's resources because the scheduler is + shutting down. + + + + + + Execute the given in the next + available . + + + + + The implementation of this interface should not throw exceptions unless + there is a serious problem (i.e. a serious misconfiguration). If there + are no available threads, rather it should either queue the Runnable, or + block until a thread is available, depending on the desired strategy. + + + + + Determines the number of threads that are currently available in in + the pool. Useful for determining the number of times + can be called before returning + false. + + + the number of currently available threads + + + The implementation of this method should block until there is at + least one available thread. + + + + + Gets the log. + + The log. + + + + Gets the size of the pool. + + The size of the pool. + + + + Inform the of the Scheduler instance's Id, + prior to initialize being invoked. + + + + + Inform the of the Scheduler instance's name, + prior to initialize being invoked. + + + + + A simple class (structure) used for returning execution-time data from the + JobStore to the . + + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The job. + The trigger. + The calendar. + if set to true [job is recovering]. + The fire time. + The scheduled fire time. + The previous fire time. + The next fire time. + + + + Gets the job detail. + + The job detail. + + + + Gets the trigger. + + The trigger. + + + + Gets the calendar. + + The calendar. + + + + Gets a value indicating whether this is recovering. + + true if recovering; otherwise, false. + + + + Returns the UTC fire time. + + + + + Gets the next UTC fire time. + + The next fire time. + Returns the nextFireTimeUtc. + + + + Gets the previous UTC fire time. + + The previous fire time. + Returns the previous fire time. + + + + Returns the scheduled UTC fire time. + + + + + Result holder for trigger firing event. + + + + + Constructor. + + + + + + Constructor. + + + + + Bundle. + + + + + Possible exception. + + + + + Extension methods for . + + + + + Tries to read value and returns the value if successfully read. Otherwise return default value + for value's type. + + + + + + + + + + Extension methods for simplified access. + + + + + Returns string from given column name, or null if DbNull. + + + + + Returns int from given column name. + + + + + Returns long from given column name. + + + + + Returns long from given column name, or null if DbNull. + + + + + Returns decimal from given column name. + + + + + Manages a collection of IDbProviders, and provides transparent access + to their database. + + + James House + Sharada Jambula + Mohammad Rezaei + Marko Lahma (.NET) + + + + Private constructor + + + + + Adds the connection provider. + + Name of the data source. + The provider. + + + + Get a database connection from the DataSource with the given name. + + a database connection + + + + Shuts down database connections from the DataSource with the given name, + if applicable for the underlying provider. + + a database connection + + + + Gets the db provider. + + Name of the ds. + + + + + Get the class instance. + + an instance of this class + + + + + An implementation of that wraps another + and flags itself 'dirty' when it is modified. + + James House + Marko Lahma (.NET) + + + + Create a DirtyFlagMap that 'wraps' a . + + + + + Create a DirtyFlagMap that 'wraps' a that has the + given initial capacity. + + + + + Serialization constructor. + + + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + When implemented by a class, removes all elements from the . + + + The is read-only. + + + + + When implemented by a class, determines whether the contains an element with the specified key. + + The key to locate in the . + + if the contains an element with the key; otherwise, . + + + is . + + + + When implemented by a class, removes the element with the + specified key from the . + + The key of the element to remove. + + is . + + The is read-only. + -or- + The has a fixed size. + + + + + When implemented by a class, returns an + for the . + + + An for the . + + + + + When implemented by a class, adds an element with the provided key and value to the . + + The to use as the key of the element to add. + The to use as the value of the element to add. + is . + + An element with the same key already exists in the . + + + The is read-only. + -or- + The has a fixed size. + + + + + When implemented by a class, copies the elements of + the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in at which copying begins. + + is . + + is less than zero. + + + is multidimensional. + -or- + + is equal to or greater than the length of . + -or- + The number of elements in the source is greater than the available space from to the end of the destination . + + The type of the source cannot be cast automatically to the type of the destination . + + + + Clear the 'dirty' flag (set dirty flag to ). + + + + + Determines whether the specified obj contains value. + + The obj. + + true if the specified obj contains value; otherwise, false. + + + + + Gets the entries as a set. + + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + if the specified is equal to the + current ; otherwise, . + + + + + Serves as a hash function for a particular type, suitable + for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets keyset for this map. + + + + + + Puts the value behind a specified key. + + The key. + The val. + + + + + Puts all. + + The t. + + + + Determine whether the is flagged dirty. + + + + + Get a direct handle to the underlying Map. + + + + + Gets a value indicating whether this instance is empty. + + true if this instance is empty; otherwise, false. + + + + Gets or sets the with the specified key. + + + + + + When implemented by a class, gets the number of + elements contained in the . + + + + + + When implemented by a class, gets an containing the values in the . + + + + + + When implemented by a class, gets an containing the keys of the . + + + + + + When implemented by a class, gets a value indicating whether the + is read-only. + + + + + + When implemented by a class, gets a value indicating whether the + has a fixed size. + + + + + + When implemented by a class, gets an object that + can be used to synchronize access to the . + + + + + + When implemented by a class, gets a value + indicating whether access to the is synchronized + (thread-safe). + + + + + + Utility class for file handling related things. + + Marko Lahma + + + + Resolves file to actual file if for example relative '~' used. + + File name to check + Expanded file name or actual no resolving was done. + + + + Object representing a job or trigger key. + + Jeffrey Wescott + Marko Lahma (.NET) + + + + The default group for scheduling entities, with the value "DEFAULT". + + + + + Construct a new key with the given name and group. + + the name + the group + + + + Return the string representation of the key. The format will be: + <group>.<name>. + + + + the string representation of the key + + + + + Get the name portion of the key. + + the name + + + + + Get the group portion of the key. + + + + the group + + + + + Wrapper class to access thread local data. + Data is either accessed from thread or HTTP Context's + data if HTTP Context is avaiable. + + Marko Lahma .NET + + + + Retrieves an object with the specified name. + + The name of the item. + The object in the call context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the call context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + + Generic extension methods for objects. + + + + + Creates a deep copy of object by serializing to memory stream. + + + + + + Utility methods that are used to convert objects from one type into another. + + Aleksandar Seovic + Marko Lahma + + + + Convert the value to the required (if necessary from a string). + + The proposed change value. + + The we must convert to. + + The new value, possibly the result of type conversion. + + + + Determines whether value is assignable to required type. + + The value to check. + Type of the required. + + true if value can be assigned as given type; otherwise, false. + + + + + Instantiates an instance of the type specified. + + + + + + Sets the object properties using reflection. + + + + + Sets the object properties using reflection. + + The object to set values to. + The properties to set to object. + + + + This is an utility class used to parse the properties. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + The props. + + + + Gets the string property. + + The name. + + + + + Gets the string property. + + The name. + The default value. + + + + + Gets the string array property. + + The name. + + + + + Gets the string array property. + + The name. + The default value. + + + + + Gets the boolean property. + + The name. + + + + + Gets the boolean property. + + The name. + if set to true [defaultValue]. + + + + + Gets the byte property. + + The name. + + + + + Gets the byte property. + + The name. + The default value. + + + + + Gets the char property. + + The name. + + + + + Gets the char property. + + The name. + The default value. + + + + + Gets the double property. + + The name. + + + + + Gets the double property. + + The name. + The default value. + + + + + Gets the float property. + + The name. + + + + + Gets the float property. + + The name. + The default value. + + + + + Gets the int property. + + The name. + + + + + Gets the int property. + + The name. + The default value. + + + + + Gets the int array property. + + The name. + + + + + Gets the int array property. + + The name. + The default value. + + + + + Gets the long property. + + The name. + + + + + Gets the long property. + + The name. + The def. + + + + + Gets the TimeSpan property. + + The name. + The def. + + + + + Gets the short property. + + The name. + + + + + Gets the short property. + + The name. + The default value. + + + + + Gets the property groups. + + The prefix. + + + + + Gets the property group. + + The prefix. + + + + + Gets the property group. + + The prefix. + if set to true [strip prefix]. + + + + + Get all properties that start with the given prefix. + + The prefix for which to search. If it does not end in a "." then one will be added to it for search purposes. + Whether to strip off the given in the result's keys. + Optional array of fully qualified prefixes to exclude. For example if is "a.b.c", then might be "a.b.c.ignore". + Group of that start with the given prefix, optionally have that prefix removed, and do not include properties that start with one of the given excluded prefixes. + + + + Reads the properties from assembly (embedded resource). + + The file name to read resources from. + + + + + Reads the properties from file system. + + The file name to read resources from. + + + + + Gets the underlying properties. + + The underlying properties. + + + + Extension methods for . + + + + + Allows null-safe trimming of string. + + + + + + + Trims string and if resulting string is empty, null is returned. + + + + + + + An implementation of that wraps another + and flags itself 'dirty' when it is modified, enforces that all keys are + strings. + + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The initial capacity. + + + + Serialization constructor. + + + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + if the specified is equal to the + current ; otherwise, . + + + + + Serves as a hash function for a particular type, suitable + for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets the keys. + + + + + + Adds the name-value pairs in the given to the . + + All keys must be s, and all values must be serializable. + + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Adds the given value to the 's + data map. + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Reports JobSchedulingDataProcessor validation exceptions. + + Chris Bonham + Marko Lahma (.NET) + + + + Constructor for ValidationException. + + + + + Constructor for ValidationException. + + exception message. + + + + Constructor for ValidationException. + + collection of validation exceptions. + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Gets the validation exceptions. + + The validation exceptions. + + + + Returns the detail message string. + + + + + Parses an XML file that declares Jobs and their schedules (Triggers). + + + + The xml document must conform to the format defined in "job_scheduling_data_2_0.xsd" + + + + After creating an instance of this class, you should call one of the + functions, after which you may call the ScheduledJobs() + function to get a handle to the defined Jobs and Triggers, which can then be + scheduled with the . Alternatively, you could call + the function to do all of this + in one step. + + + + The same instance can be used again and again, with the list of defined Jobs + being cleared each time you call a method, + however a single instance is not thread-safe. + + + Chris Bonham + James House + Marko Lahma (.NET) + + + + Constructor for XMLSchedulingDataProcessor. + + + + + Process the xml file in the default location (a file named + "quartz_jobs.xml" in the current working directory). + + + + + Process the xml file named . + + meta data file name. + + + + Process the xmlfile named with the given system + ID. + + Name of the file. + The system id. + + + + Process the xmlfile named with the given system + ID. + + The stream. + The system id. + + + + Process the xml file in the default location, and schedule all of the jobs defined within it. + + Note that we will set overWriteExistingJobs after the default xml is parsed. + + + + + + Process the xml file in the default location, and schedule all of the + jobs defined within it. + + + + + Process the xml file in the given location, and schedule all of the + jobs defined within it. + + meta data file name. + The scheduler. + + + + Process the xml file in the given location, and schedule all of the + jobs defined within it. + + Name of the file. + The system id. + The sched. + + + + Schedules the given sets of jobs and triggers. + + The sched. + + + + Adds a detected validation exception. + + The exception. + + + + Resets the the number of detected validation exceptions. + + + + + Throws a ValidationException if the number of validationExceptions + detected is greater than zero. + + + DTD validation exception. + + + + + Whether the existing scheduling data (with same identifiers) will be + overwritten. + + + If false, and is not false, and jobs or + triggers with the same names already exist as those in the file, an + error will occur. + + + + + + If true (and is false) then any + job/triggers encountered in this file that have names that already exist + in the scheduler will be ignored, and no error will be produced. + + + + + + Gets the log. + + The log. + + + + Helper class to map constant names to their values. + + + + + CalendarIntervalScheduleBuilder is a + that defines calendar time (day, week, month, year) interval-based + schedules for Triggers. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + JobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + Trigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + + Base class for implementors. + + + + + + Schedule builders offer fluent interface and are responsible for creating schedules. + + + + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Create a CalendarIntervalScheduleBuilder. + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Specify the time unit and interval for the Trigger to be produced. + + + + the interval at which the trigger should repeat. + the time unit (IntervalUnit) of the interval. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.SECOND that the produced + Trigger will repeat at. + + + + the number of seconds at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.MINUTE that the produced + Trigger will repeat at. + + + + the number of minutes at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.HOUR that the produced + Trigger will repeat at. + + + + the number of hours at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.DAY that the produced + Trigger will repeat at. + + + + the number of days at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.WEEK that the produced + Trigger will repeat at. + + + + the number of weeks at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.MONTH that the produced + Trigger will repeat at. + + + + the number of months at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.YEAR that the produced + Trigger will repeat at. + + + + the number of years at which the trigger should repeat. + the updated CalendarIntervalScheduleBuilder + + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CalendarIntervalScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CalendarIntervalScheduleBuilder + + + + + TimeZone in which to base the schedule. + + the time-zone for the schedule + the updated CalendarIntervalScheduleBuilder + + + + + If intervals are a day or greater, this property (set to true) will + cause the firing of the trigger to always occur at the same time of day, + (the time of day of the startTime) regardless of daylight saving time + transitions. Default value is false. + + + + For example, without the property set, your trigger may have a start + time of 9:00 am on March 1st, and a repeat interval of 2 days. But + after the daylight saving transition occurs, the trigger may start + firing at 8:00 am every other day. + + + If however, the time of day does not exist on a given day to fire + (e.g. 2:00 am in the United States on the days of daylight saving + transition), the trigger will go ahead and fire one hour off on + that day, and then resume the normal hour on other days. If + you wish for the trigger to never fire at the "wrong" hour, then + you should set the property skipDayIfHourDoesNotExist. + + + + + + + + + + If intervals are a day or greater, and + preserveHourOfDayAcrossDaylightSavings property is set to true, and the + hour of the day does not exist on a given day for which the trigger + would fire, the day will be skipped and the trigger advanced a second + interval if this property is set to true. Defaults to false. + + + CAUTION! If you enable this property, and your hour of day happens + to be that of daylight savings transition (e.g. 2:00 am in the United + States) and the trigger's interval would have had the trigger fire on + that day, then you may actually completely miss a firing on the day of + transition if that hour of day does not exist on that day! In such a + case the next fire time of the trigger will be computed as double (if + the interval is 2 days, then a span of 4 days between firings will + occur). + + + + + + Extension methods that attach to . + + + + + Provides a parser and evaluator for unix-like cron expressions. Cron + expressions provide the ability to specify complex time combinations such as + "At 8:00am every Monday through Friday" or "At 1:30am every + last Friday of the month". + + + + Cron expressions are comprised of 6 required fields and one optional field + separated by white space. The fields respectively are described as follows: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Field Name Allowed Values Allowed Special Characters
Seconds 0-59 , - /// /
Minutes 0-59 , - /// /
Hours 0-23 , - /// /
Day-of-month 1-31 , - /// ? / L W C
Month 1-12 or JAN-DEC , - /// /
Day-of-Week 1-7 or SUN-SAT , - /// ? / L #
Year (Optional) empty, 1970-2199 , - /// /
+ + The '*' character is used to specify all values. For example, "*" + in the minute field means "every minute". + + + The '?' character is allowed for the day-of-month and day-of-week fields. It + is used to specify 'no specific value'. This is useful when you need to + specify something in one of the two fields, but not the other. + + + The '-' character is used to specify ranges For example "10-12" in + the hour field means "the hours 10, 11 and 12". + + + The ',' character is used to specify additional values. For example + "MON,WED,FRI" in the day-of-week field means "the days Monday, + Wednesday, and Friday". + + + The '/' character is used to specify increments. For example "0/15" + in the seconds field means "the seconds 0, 15, 30, and 45". And + "5/15" in the seconds field means "the seconds 5, 20, 35, and + 50". Specifying '*' before the '/' is equivalent to specifying 0 is + the value to start with. Essentially, for each field in the expression, there + is a set of numbers that can be turned on or off. For seconds and minutes, + the numbers range from 0 to 59. For hours 0 to 23, for days of the month 0 to + 31, and for months 1 to 12. The "/" character simply helps you turn + on every "nth" value in the given set. Thus "7/6" in the + month field only turns on month "7", it does NOT mean every 6th + month, please note that subtlety. + + + The 'L' character is allowed for the day-of-month and day-of-week fields. + This character is short-hand for "last", but it has different + meaning in each of the two fields. For example, the value "L" in + the day-of-month field means "the last day of the month" - day 31 + for January, day 28 for February on non-leap years. If used in the + day-of-week field by itself, it simply means "7" or + "SAT". But if used in the day-of-week field after another value, it + means "the last xxx day of the month" - for example "6L" + means "the last friday of the month". You can also specify an offset + from the last day of the month, such as "L-3" which would mean the third-to-last + day of the calendar month. When using the 'L' option, it is important not to + specify lists, or ranges of values, as you'll get confusing/unexpected results. + + + The 'W' character is allowed for the day-of-month field. This character + is used to specify the weekday (Monday-Friday) nearest the given day. As an + example, if you were to specify "15W" as the value for the + day-of-month field, the meaning is: "the nearest weekday to the 15th of + the month". So if the 15th is a Saturday, the trigger will fire on + Friday the 14th. If the 15th is a Sunday, the trigger will fire on Monday the + 16th. If the 15th is a Tuesday, then it will fire on Tuesday the 15th. + However if you specify "1W" as the value for day-of-month, and the + 1st is a Saturday, the trigger will fire on Monday the 3rd, as it will not + 'jump' over the boundary of a month's days. The 'W' character can only be + specified when the day-of-month is a single day, not a range or list of days. + + + The 'L' and 'W' characters can also be combined for the day-of-month + expression to yield 'LW', which translates to "last weekday of the + month". + + + The '#' character is allowed for the day-of-week field. This character is + used to specify "the nth" XXX day of the month. For example, the + value of "6#3" in the day-of-week field means the third Friday of + the month (day 6 = Friday and "#3" = the 3rd one in the month). + Other examples: "2#1" = the first Monday of the month and + "4#5" = the fifth Wednesday of the month. Note that if you specify + "#5" and there is not 5 of the given day-of-week in the month, then + no firing will occur that month. If the '#' character is used, there can + only be one expression in the day-of-week field ("3#1,6#3" is + not valid, since there are two expressions). + + + + + + The legal characters and the names of months and days of the week are not + case sensitive. + + + NOTES: +
    +
  • Support for specifying both a day-of-week and a day-of-month value is + not complete (you'll need to use the '?' character in one of these fields). +
  • +
  • Overflowing ranges is supported - that is, having a larger number on + the left hand side than the right. You might do 22-2 to catch 10 o'clock + at night until 2 o'clock in the morning, or you might have NOV-FEB. It is + very important to note that overuse of overflowing ranges creates ranges + that don't make sense and no effort has been made to determine which + interpretation CronExpression chooses. An example would be + "0 0 14-6 ? * FRI-MON".
  • +
+
+
+ Sharada Jambula + James House + Contributions from Mads Henderson + Refactoring from CronTrigger to CronExpression by Aaron Craven + Marko Lahma (.NET) +
+ + + Field specification for second. + + + + + Field specification for minute. + + + + + Field specification for hour. + + + + + Field specification for day of month. + + + + + Field specification for month. + + + + + Field specification for day of week. + + + + + Field specification for year. + + + + + Field specification for all wildcard value '*'. + + + + + Field specification for not specified value '?'. + + + + + Field specification for wildcard '*'. + + + + + Field specification for no specification at all '?'. + + + + + Seconds. + + + + + minutes. + + + + + Hours. + + + + + Days of month. + + + + + Months. + + + + + Days of week. + + + + + Years. + + + + + Last day of week. + + + + + Nth day of week. + + + + + Last day of month. + + + + + Nearest weekday. + + + + + Calendar day of week. + + + + + Calendar day of month. + + + + + Expression parsed. + + + + + Constructs a new based on the specified + parameter. + + + String representation of the cron expression the new object should represent + + + + + + Indicates whether the given date satisfies the cron expression. + + + Note that milliseconds are ignored, so two Dates falling on different milliseconds + of the same second will always have the same result here. + + The date to evaluate. + a boolean indicating whether the given date satisfies the cron expression + + + + Returns the next date/time after the given date/time which + satisfies the cron expression. + + the date/time at which to begin the search for the next valid date/time + the next valid date/time + + + + Returns the next date/time after the given date/time which does + not satisfy the expression. + + the date/time at which to begin the search for the next invalid date/time + the next valid date/time + + + + Returns the string representation of the + + The string representation of the + + + + Indicates whether the specified cron expression can be parsed into a + valid cron expression + + the expression to evaluate + a boolean indicating whether the given expression is a valid cron + expression + + + + Builds the expression. + + The expression. + + + + Stores the expression values. + + The position. + The string to traverse. + The type of value. + + + + + Checks the next value. + + The position. + The string to check. + The value. + The type to search. + + + + + Gets the expression summary. + + + + + + Gets the expression set summary. + + The data. + + + + + Skips the white space. + + The i. + The s. + + + + + Finds the next white space. + + The i. + The s. + + + + + Adds to set. + + The val. + The end. + The incr. + The type. + + + + Gets the set of given type. + + The type of set to get. + + + + + Gets the value. + + The v. + The s. + The i. + + + + + Gets the numeric value from string. + + The string to parse from. + The i. + + + + + Gets the month number. + + The string to map with. + + + + + Gets the day of week number. + + The s. + + + + + Gets the time from given time parts. + + The seconds. + The minutes. + The hours. + The day of month. + The month. + + + + + Gets the next fire time after the given time. + + The UTC time to start searching from. + + + + + Creates the date time without milliseconds. + + The time. + + + + + Advance the calendar to the particular hour paying particular attention + to daylight saving problems. + + The date. + The hour. + + + + + Gets the time before. + + The end time. + + + + + NOT YET IMPLEMENTED: Returns the final time that the + will match. + + + + + + Determines whether given year is a leap year. + + The year. + + true if the specified year is a leap year; otherwise, false. + + + + + Gets the last day of month. + + The month num. + The year. + + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . + + + + Serves as a hash function for a particular type. + + + A hash code for the current . + + 2 + + + + Sets or gets the time zone for which the of this + will be resolved. + + + + + Gets the cron expression string. + + The cron expression string. + + + + Helper class for cron expression handling. + + + + + The value. + + + + + The position. + + + + + CronScheduleBuilder is a that defines + -based schedules for s. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = newTrigger() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithSimpleSchedule(x => x.WithIntervalInHours(1).RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Create a CronScheduleBuilder with the given cron-expression - which + is presumed to b e valid cron expression (and hence only a RuntimeException + will be thrown if it is not). + + + + the cron expression to base the schedule on. + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with the given cron-expression string - which + may not be a valid cron expression (and hence a ParseException will be thrown + f it is not). + + the cron expression string to base the schedule on + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with the given cron-expression. + + the cron expression to base the schedule on. + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire every day at the given time (hour and minute). + + + + the hour of day to fire + the minute of the given hour to fire + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire at the given day at the given time (hour and minute) on the given days of the week. + + the hour of day to fire + the minute of the given hour to fire + the days of the week to fire + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire one per week on the given day at the given time + (hour and minute). + + + + the day of the week to fire + the hour of day to fire + the minute of the given hour to fire + the new CronScheduleBuilder + + + + + Create a CronScheduleBuilder with a cron-expression that sets the + schedule to fire one per month on the given day of month at the given + time (hour and minute). + + + + the day of the month to fire + the hour of day to fire + the minute of the given hour to fire + the new CronScheduleBuilder + + + + + The in which to base the schedule. + + + + the time-zone for the schedule. + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + Extension methods that attach to . + + + + + A implementation that build schedule for DailyTimeIntervalTrigger. + + + + This builder provide an extra convenient method for you to set the trigger's EndTimeOfDay. You may + use either endingDailyAt() or EndingDailyAfterCount() to set the value. The later will auto calculate + your EndTimeOfDay by using the interval, IntervalUnit and StartTimeOfDay to perform the calculation. + + + When using EndingDailyAfterCount(), you should note that it is used to calculating EndTimeOfDay. So + if your startTime on the first day is already pass by a time that would not add up to the count you + expected, until the next day comes. Remember that DailyTimeIntervalTrigger will use StartTimeOfDay + and endTimeOfDay as fresh per each day! + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithDailyTimeIntervalSchedule(x => + x.WithIntervalInMinutes(15) + .StartingDailyAt(TimeOfDay.HourAndMinuteOfDay(8, 0)) + .Build(); + + scheduler.scheduleJob(job, trigger); + + + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + A set of all days of the week. + + + The set contains all values between and + + + + + A set of the business days of the week (for locales similar to the USA). + + + The set contains all values between and + + + + + A set of the weekend days of the week (for locales similar to the USA). + + + The set contains and + + + + + Create a DailyTimeIntervalScheduleBuilder + + The new DailyTimeIntervalScheduleBuilder + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + Specify the time unit and interval for the Trigger to be produced. + + + + the interval at which the trigger should repeat. + the time unit (IntervalUnit) of the interval. + the updated CalendarIntervalScheduleBuilder + + + + + + Specify an interval in the IntervalUnit.Second that the produced + Trigger will repeat at. + + The number of seconds at which the trigger should repeat. + the updated DailyTimeIntervalScheduleBuilder> + + + + + + Specify an interval in the IntervalUnit.Minute that the produced + Trigger will repeat at. + + The number of minutes at which the trigger should repeat. + the updated DailyTimeIntervalScheduleBuilder> + + + + + + Specify an interval in the IntervalUnit.Hour that the produced + Trigger will repeat at. + + The number of hours at which the trigger should repeat. + the updated DailyTimeIntervalScheduleBuilder> + + + + + + Set the trigger to fire on the given days of the week. + + a Set containing the integers representing the days of the week, defined by - . + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on the given days of the week. + + a variable length list of week days representing the days of the week + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on the days from Monday through Friday. + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on the days Saturday and Sunday. + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to fire on all days of the week. + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the trigger to begin firing each day at the given time. + + + the updated DailyTimeIntervalScheduleBuilder + + + + Set the startTimeOfDay for this trigger to end firing each day at the given time. + + + the updated DailyTimeIntervalScheduleBuilder + + + + Calculate and set the EndTimeOfDay using count, interval and StarTimeOfDay. This means + that these must be set before this method is call. + + + the updated DailyTimeIntervalScheduleBuilder + + + + If the Trigger misfires, use the + instruction. + + the updated DailyTimeIntervalScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + the updated DailyTimeIntervalScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + the updated DailyTimeIntervalScheduleBuilder + + + + + Set number of times for interval to repeat. + + + Note: if you want total count = 1 (at start time) + repeatCount + + + + + + + Extension methods that attach to . + + + + + DateBuilder is used to conveniently create + instances that meet particular criteria. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = newTrigger() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minutes)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + Create a DateBuilder, with initial settings for the current date + and time in the system default timezone. + + + + + Create a DateBuilder, with initial settings for the current date and time in the given timezone. + + + + + + Create a DateBuilder, with initial settings for the current date and time in the system default timezone. + + + + + + Create a DateBuilder, with initial settings for the current date and time in the given timezone. + + Time zone to use. + + + + + Build the defined by this builder instance. + + New date time based on builder parameters. + + + + Set the hour (0-23) for the Date that will be built by this builder. + + + + + + + Set the minute (0-59) for the Date that will be built by this builder. + + + + + + + Set the second (0-59) for the Date that will be built by this builder, and truncate the milliseconds to 000. + + + + + + + Set the day of month (1-31) for the Date that will be built by this builder. + + + + + + + Set the month (1-12) for the Date that will be built by this builder. + + + + + + + Set the year for the Date that will be built by this builder. + + + + + + + Set the TimeZoneInfo for the Date that will be built by this builder (if "null", system default will be used) + + + + + + + Get a object that represents the given time, on + tomorrow's date. + + + + + + + + + Get a object that represents the given time, on + today's date (equivalent to . + + + + + + + + + Get a object that represents the given time, on today's date. + + The value (0-59) to give the seconds field of the date + The value (0-59) to give the minutes field of the date + The value (0-23) to give the hours field of the date + the new date + + + + Get a object that represents the given time, on the + given date. + + The value (0-59) to give the seconds field of the date + The value (0-59) to give the minutes field of the date + The value (0-23) to give the hours field of the date + The value (1-31) to give the day of month field of the date + The value (1-12) to give the month field of the date + the new date + + + + Get a object that represents the given time, on the + given date. + + + + The value (0-59) to give the seconds field of the date + The value (0-59) to give the minutes field of the date + The value (0-23) to give the hours field of the date + The value (1-31) to give the day of month field of the date + The value (1-12) to give the month field of the date + The value (1970-2099) to give the year field of the date + the new date + + + + Returns a date that is rounded to the next even hour after the current time. + + + For example a current time of 08:13:54 would result in a date + with the time of 09:00:00. If the date's time is in the 23rd hour, the + date's 'day' will be promoted, and the time will be set to 00:00:00. + + the new rounded date + + + + Returns a date that is rounded to the next even hour above the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 09:00:00. If the date's time is in the 23rd hour, the + date's 'day' will be promoted, and the time will be set to 00:00:00. + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the previous even hour below the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 08:00:00. + + the Date to round, if the current time will + be used + the new rounded date + + + + + Returns a date that is rounded to the next even minute after the current time. + + + + For example a current time of 08:13:54 would result in a date + with the time of 08:14:00. If the date's time is in the 59th minute, + then the hour (and possibly the day) will be promoted. + + the new rounded date + + + + Returns a date that is rounded to the next even minute above the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 08:14:00. If the date's time is in the 59th minute, + then the hour (and possibly the day) will be promoted. + + The Date to round, if the current time will be used + The new rounded date + + + + Returns a date that is rounded to the previous even minute below the given date. + + + For example an input date with a time of 08:13:54 would result in a date + with the time of 08:13:00. + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the next even second after the current time. + + the new rounded date + + + + Returns a date that is rounded to the next even second above the given date. + + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the previous even second below the + given date. + + + + For example an input date with a time of 08:13:54.341 would result in a + date with the time of 08:13:00.000. + + + + the Date to round, if the current time will + be used + the new rounded date + + + + Returns a date that is rounded to the next even multiple of the given + minute. + + + + For example an input date with a time of 08:13:54, and an input + minute-base of 5 would result in a date with the time of 08:15:00. The + same input date with an input minute-base of 10 would result in a date + with the time of 08:20:00. But a date with the time 08:53:31 and an + input minute-base of 45 would result in 09:00:00, because the even-hour + is the next 'base' for 45-minute intervals. + + + More examples: + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Input TimeMinute-BaseResult Time
11:16:412011:20:00
11:36:412011:40:00
11:46:412012:00:00
11:26:413011:30:00
11:36:413012:00:00
11:16:411711:17:00
11:17:411711:34:00
11:52:411712:00:00
11:52:41511:55:00
11:57:41512:00:00
11:17:41012:00:00
11:17:41111:08:00
+
+
+ + the Date to round, if the current time will + be used + + the base-minute to set the time on + the new rounded date + +
+ + + Returns a date that is rounded to the next even multiple of the given + minute. + + + The rules for calculating the second are the same as those for + calculating the minute in the method . + + the Date to round, if the current time will + be used + the base-second to set the time on + the new rounded date + + + + + An attribute that marks a class as one that must not have multiple + instances executed concurrently (where instance is based-upon a + definition - or in other words based upon a . + + + This can be used in lieu of implementing the StatefulJob marker interface that + was used prior to Quartz 2.0 + + + James House + Marko Lahma (.NET) + + + + The interface to be implemented by s that provide a + mechanism for having their execution interrupted. It is NOT a requirement + for jobs to implement this interface - in fact, for most people, none of + their jobs will. + + + + The means of actually interrupting the Job must be implemented within the + itself (the method of this + interface is simply a means for the scheduler to inform the + that a request has been made for it to be interrupted). The mechanism that + your jobs use to interrupt themselves might vary between implementations. + However the principle idea in any implementation should be to have the + body of the job's periodically check some flag to + see if an interruption has been requested, and if the flag is set, somehow + abort the performance of the rest of the job's work. An example of + interrupting a job can be found in the java source for the class + . It is legal to use + some combination of and + synchronization within and + in order to have the method block until the + signals that it has noticed the set flag. + + + + If the Job performs some form of blocking I/O or similar functions, you may + want to consider having the method store a + reference to the calling as a member variable. Then the + implementation of this interfaces method can call + on that Thread. Before attempting this, make + sure that you fully understand what + does and doesn't do. Also make sure that you clear the Job's member + reference to the Thread when the Execute(..) method exits (preferably in a + block. + + + + + + James House + Marko Lahma (.NET) + + + + Called by the when a user + interrupts the . + + void (nothing) if job interrupt is successful. + + + + Supported interval units used by . + + + + + A marker interface for s that + wish to have their state maintained between executions. + + + instances follow slightly different rules from + regular instances. The key difference is that their + associated is re-persisted after every + execution of the job, thus preserving state for the next execution. The + other difference is that stateful jobs are not allowed to Execute + concurrently, which means new triggers that occur before the completion of + the method will be delayed. + + + + + + + + James House + Marko Lahma (.NET) + + + + JobBuilder is used to instantiate s. + + + + The builder will always try to keep itself in a valid state, with + reasonable defaults set for calling Build() at any point. For instance + if you do not invoke WithIdentity(..) a job name will be generated + for you. + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x.WithIntervalInHours(1).RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + + scheduler.scheduleJob(job, trigger); + + + + + + + + + Create a JobBuilder with which to define a . + + a new JobBuilder + + + + Create a JobBuilder with which to define a , + and set the class name of the job to be executed. + + a new JobBuilder + + + + Create a JobBuilder with which to define a , + and set the class name of the job to be executed. + + a new JobBuilder + + + + Produce the instance defined by this JobBuilder. + + the defined JobDetail. + + + + Use a with the given name and default group to + identify the JobDetail. + + + If none of the 'withIdentity' methods are set on the JobBuilder, + then a random, unique JobKey will be generated. + + the name element for the Job's JobKey + the updated JobBuilder + + + + + + Use a with the given name and group to + identify the JobDetail. + + + If none of the 'withIdentity' methods are set on the JobBuilder, + then a random, unique JobKey will be generated. + + the name element for the Job's JobKey + the group element for the Job's JobKey + the updated JobBuilder + + + + + + Use a to identify the JobDetail. + + + If none of the 'withIdentity' methods are set on the JobBuilder, + then a random, unique JobKey will be generated. + + the Job's JobKey + the updated JobBuilder + + + + + + Set the given (human-meaningful) description of the Job. + + the description for the Job + the updated JobBuilder + + + + + Set the class which will be instantiated and executed when a + Trigger fires that is associated with this JobDetail. + + the updated JobBuilder + + + + + Set the class which will be instantiated and executed when a + Trigger fires that is associated with this JobDetail. + + the updated JobBuilder + + + + + Instructs the whether or not the job + should be re-executed if a 'recovery' or 'fail-over' situation is + encountered. + + + If not explicitly set, the default value is . + + the updated JobBuilder + + + + + Instructs the whether or not the job + should be re-executed if a 'recovery' or 'fail-over' situation is + encountered. + + + If not explicitly set, the default value is . + + + the updated JobBuilder + + + + Whether or not the job should remain stored after it is + orphaned (no s point to it). + + + If not explicitly set, the default value is . + + the updated JobBuilder + + + + + Whether or not the job should remain stored after it is + orphaned (no s point to it). + + + If not explicitly set, the default value is . + + the value to set for the durability property. + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Add the given key-value pair to the JobDetail's . + + the updated JobBuilder + + + + + Set the JobDetail's , adding any values to it + that were already set on this JobBuilder using any of the + other 'usingJobData' methods. + + the updated JobBuilder + + + + + Holds state information for instances. + + + instances are stored once when the + is added to a scheduler. They are also re-persisted after every execution of + instances that have present. + + instances can also be stored with a + . This can be useful in the case where you have a Job + that is stored in the scheduler for regular/repeated use by multiple + Triggers, yet with each independent triggering, you want to supply the + Job with different data inputs. + + + The passed to a Job at execution time + also contains a convenience that is the result + of merging the contents of the trigger's JobDataMap (if any) over the + Job's JobDataMap (if any). + + + + + + + James House + Marko Lahma (.NET) + + + + Create an empty . + + + + + Create a with the given data. + + + + + Create a with the given data. + + + + + Serialization constructor. + + + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Adds the given value as a string version to the + 's data map. + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the + . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Retrieve the identified value from the . + + + + + Gets the date time. + + The key. + + + + + Gets the value behind the specified key. + + The key. + + + + + An exception that can be thrown by a + to indicate to the Quartz that an error + occurred while executing, and whether or not the requests + to be re-fired immediately (using the same , + or whether it wants to be unscheduled. + + + Note that if the flag for 'refire immediately' is set, the flags for + unscheduling the Job are ignored. + + + + + James House + Marko Lahma (.NET) + + + + Create a JobExcecutionException, with the 're-fire immediately' flag set + to . + + + + + Create a JobExcecutionException, with the given cause. + + The cause. + + + + Create a JobExcecutionException, with the given message. + + + + + Initializes a new instance of the class. + + The message. + The original cause. + + + + Create a JobExcecutionException with the 're-fire immediately' flag set + to the given value. + + + + + Create a JobExcecutionException with the given underlying exception, and + the 're-fire immediately' flag set to the given value. + + + + + Create a JobExcecutionException with the given message, and underlying + exception, and the 're-fire immediately' flag set to the given value. + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Creates and returns a string representation of the current exception. + + + A string representation of the current exception. + + + + + + Gets or sets a value indicating whether to unschedule firing trigger. + + + true if firing trigger should be unscheduled; otherwise, false. + + + + + Gets or sets a value indicating whether to unschedule all triggers. + + + true if all triggers should be unscheduled; otherwise, false. + + + + + Gets or sets a value indicating whether to refire immediately. + + true if to refire immediately; otherwise, false. + + + + Uniquely identifies a . + + + Keys are composed of both a name and group, and the name must be unique + within the group. If only a group is specified then the default group + name will be used. + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + Misfire instructions. + + Marko Lahma (.NET) + + + + Instruction not set (yet). + + + + + Use smart policy. + + + + + Instructs the that the + will never be evaluated for a misfire situation, + and that the scheduler will simply try to fire it as soon as it can, + and then update the Trigger as if it had fired at the proper time. + + + NOTE: if a trigger uses this instruction, and it has missed + several of its scheduled firings, then several rapid firings may occur + as the trigger attempt to catch back up to where it would have been. + For example, a SimpleTrigger that fires every 15 seconds which has + misfired for 5 minutes will fire 20 times once it gets the chance to + fire. + + + + + Misfire policy settings for SimpleTrigger. + + + + + Instructs the that upon a mis-fire + situation, the wants to be fired + now by . + + NOTE: This instruction should typically only be used for + 'one-shot' (non-repeating) Triggers. If it is used on a trigger with a + repeat count > 0 then it is equivalent to the instruction + . + + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to 'now' (even if the associated + excludes 'now') with the repeat count left as-is. This does obey the + end-time however, so if 'now' is after the + end-time the will not fire again. + + + + NOTE: Use of this instruction causes the trigger to 'forget' + the start-time and repeat-count that it was originally setup with (this + is only an issue if you for some reason wanted to be able to tell what + the original values were at some later time). + + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to 'now' (even if the associated + excludes 'now') with the repeat count set to what it would be, if it had + not missed any firings. This does obey the end-time + however, so if 'now' is after the end-time the will + not fire again. + + + NOTE: Use of this instruction causes the trigger to 'forget' + the start-time and repeat-count that it was originally setup with. + Instead, the repeat count on the trigger will be changed to whatever + the remaining repeat count is (this is only an issue if you for some + reason wanted to be able to tell what the original values were at some + later time). + + + + NOTE: This instruction could cause the + to go to the 'COMPLETE' state after firing 'now', if all the + repeat-fire-times where missed. + + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to the next scheduled time after 'now' - taking into + account any associated , and with the + repeat count set to what it would be, if it had not missed any firings. + + + NOTE/WARNING: This instruction could cause the + to go directly to the 'COMPLETE' state if all fire-times where missed. + + + + + Instructs the that upon a mis-fire + situation, the wants to be + re-scheduled to the next scheduled time after 'now' - taking into + account any associated , and with the + repeat count left unchanged. + + + + NOTE/WARNING: This instruction could cause the + to go directly to the 'COMPLETE' state if all the end-time of the trigger + has arrived. + + + + + + misfire instructions for CronTrigger + + + + + Instructs the that upon a mis-fire + situation, the wants to be fired now + by . + + + + + Instructs the that upon a mis-fire + situation, the wants to have it's + next-fire-time updated to the next time in the schedule after the + current time (taking into account any associated , + but it does not want to be fired now. + + + + + misfire instructions for NthIncludedDayTrigger + + + + + Instructs the that upon a mis-fire situation, the + wants to be fired now by the + + + + + + Instructs the that upon a mis-fire situation, the + wants to have + nextFireTime updated to the next time in the schedule after + the current time, but it does not want to be fired now. + + + + + Misfire instructions for DateIntervalTrigger + + + + + Instructs the that upon a mis-fire + situation, the wants to be + fired now by . + + + + + Instructs the that upon a mis-fire + situation, the wants to have it's + next-fire-time updated to the next time in the schedule after the + current time (taking into account any associated , + but it does not want to be fired now. + + + + + Misfire instructions for DailyTimeIntervalTrigger + + + + + Instructs the that upon a mis-fire + situation, the wants to be + fired now by . + + + + + Instructs the that upon a mis-fire + situation, the wants to have it's + next-fire-time updated to the next time in the schedule after the + current time (taking into account any associated , + but it does not want to be fired now. + + + + + A trigger which fires on the Nth day of every interval type + , or + that is not excluded by the associated + calendar. + + + When determining what the Nth day of the month or year + is, will skip excluded days on the + associated calendar. This would commonly be used in an Nth + business day situation, in which the user wishes to fire a particular job on + the Nth business day (i.e. the 5th business day of + every month). Each also has an associated + which indicates at what time of day the trigger is + to fire. + + All s default to a monthly interval type + (fires on the Nth day of every month) with N = 1 (first + non-excluded day) and set to 12:00 PM (noon). These + values can be changed using the , , and + methods. Users may also want to note the + and + methods. + + + Take, for example, the following calendar: + + + July August September + Su Mo Tu We Th Fr Sa Su Mo Tu We Th Fr Sa Su Mo Tu We Th Fr Sa + 1 W 1 2 3 4 5 W 1 2 W + W H 5 6 7 8 W W 8 9 10 11 12 W W H 6 7 8 9 W + W 11 12 13 14 15 W W 15 16 17 18 19 W W 12 13 14 15 16 W + W 18 19 20 21 22 W W 22 23 24 25 26 W W 19 20 21 22 23 W + W 25 26 27 28 29 W W 29 30 31 W 26 27 28 29 30 + W + + Where W's represent weekend days, and H's represent holidays, all of which + are excluded on a calendar associated with an + with n=5 and + intervalType=IntervalTypeMonthly. In this case, the trigger + would fire on the 8th of July (because of the July 4 holiday), + the 5th of August, and the 8th of September (because + of Labor Day). + + Aaron Craven + Marko Lahma (.NET) + + + + Indicates a monthly trigger type (fires on the Nth included + day of every month). + + + + indicates a yearly trigger type (fires on the Nth included + day of every year). + + + + + Indicates a weekly trigger type (fires on the Nth included + day of every week). When using this interval type, care must be taken + not to think of the value of as an analog to + . Such a comparison can only + be drawn when there are no calendars associated with the trigger. To + illustrate, consider an with + n = 3 which is associated with a Calendar excluding + non-weekdays. The trigger would fire on the 3rd + included day of the week, which would be 4th + actual day of the week. + + + + + Create an with no specified name, + group, or . This will result initially in a + default monthly trigger that fires on the first day of every month at + 12:00 PM (n = 1, + intervalType=, + fireAtTime="12:00"). + + + Note that and , must be + called before the can be placed into + a . + + + + + Create an with the given name and + default group but no specified . This will result + initially in a default monthly trigger that fires on the first day of + every month at 12:00 PM (=1, + intervalType=, + fireAtTime=12:00"). + + Note that must + be called before the can be placed + into a . + + + the name for the + + + + + Create an with the given name and + group but no specified . This will result + initially in a default monthly trigger that fires on the first day of + every month at 12:00 PM (=1, + intervalType=, + fireAtTime=12:00"). + + Note that must + be called before the can be placed + into a . + + + the name for the + + the group for the + + + + + Create an with the given name and + group and the specified . This will result + initially in a default monthly trigger that fires on the first day of + every month at 12:00 PM (=1, + intervalType=, + fireAtTime="12:00"). + + The name for the . + The group for the . + The name of the job to associate with the . + The group containing the job to associate with the . + + + + Returns the next UTC time at which the + will fire. If the trigger will not fire again, will be + returned. + + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + property. The default cutoff is 12 + of the intervals specified by intervalType. + + + The returned value is not guaranteed to be valid until after + the trigger has been added to the scheduler. + + + the next fire time for the trigger + + + + + Returns the previous UTC time at which the + fired. If the trigger has not yet + fired, will be returned. + + the previous fire time for the trigger + + + + Returns the first time the will fire + after the specified date. + + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + property. The default cutoff is 12 + of the intervals specified by intervalType. + + + Therefore, for triggers with intervalType = + , if the trigger + will not fire within 12 + weeks after the given date/time, will be returned. For + triggers with intervalType = + + , if the trigger will not fire within 12 + months after the given date/time, will be returned. + For triggers with intervalType = + + , if the trigger will not fire within 12 + years after the given date/time, will be returned. In + all cases, if the trigger will not fire before , + will be returned. + + + The time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + + the first time the trigger will fire following the specified date + + + + + Called when the has decided to 'fire' the trigger + (Execute the associated ), in order to give the + a chance to update itself for its next triggering + (if any). + + + + + Called by the scheduler at the time a is first + added to the scheduler, in order to have the + compute its first fire time, based on any associated calendar. + + After this method has been called, + should return a valid answer. + + + + the first time at which the will be fired + by the scheduler, which is also the same value + will return (until after the first + firing of the ). + + + + + Called after the has executed the + associated with the in order + to get the final instruction code from the trigger. + + + The that was used by the + 's method. + + + The thrown by the + , if any (may be ) + + one of the Trigger.INSTRUCTION_XXX constants. + + + + + Used by the to determine whether or not it is + possible for this to fire again. + ' + + + If the returned value is then the + may remove the from the + + + + + A boolean indicator of whether the trigger could potentially fire + again. + + + + + Indicates whether is a valid misfire + instruction for this . + + Whether is valid. + + + Updates the 's state based on the + MisfireInstruction that was selected when the + was created +

+ If the misfire instruction is set to MISFIRE_INSTRUCTION_SMART_POLICY, + then the instruction will be interpreted as + . +

+
+ a new or updated calendar to use for the trigger + +
+ + + Updates the 's state based on the + given new version of the associated . + + A new or updated calendar to use for the trigger + the amount of time that must + be between "now" and the time the next + firing of the trigger is supposed to occur. + + + + + Calculates the first time an with + intervalType = IntervalTypeWeekly will fire + after the specified date. See for more + information. + + The time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + the first time the trigger will fire following the specified + date + + + + + Calculates the first UTC time an with + intervalType = will fire + after the specified date. See for more + information. + + + The UTC time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + the first time the trigger will fire following the specified date + + + + Calculates the first time an with + intervalType = will fire + after the specified date. See for more + information. + + + The UTC time after which to find the nearest fire time. + This argument is treated as exclusive 舒 that is, + if afterTime is a valid fire time for the trigger, it + will not be returned as the next fire time. + + the first time the trigger will fire following the specified + date + + + + + Get a that is configured to produce a + schedule identical to this trigger's schedule. + + + + + + + Gets or sets the day of the interval on which the + should fire. If the Nth + day of the interval does not exist (i.e. the 32nd of a + month), the trigger simply will never fire. N may not be less than 1. + + + + + Returns the interval type for the . + + + Sets the interval type for the . If + , the trigger will fire on the + Nth included day of every month. If + , the trigger will fire on the + Nth included day of every year. If + , the trigger will fire on the + Nth included day of every week. + + + + + + + + Returns the fire time for the as a + string with the format "HH:MM[:SS]", with HH representing the + 24-hour clock hour of the fire time. Seconds are optional and their + inclusion depends on whether or not they were provided to + . + + + + + Returns the for the + . + + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + property. The default cutoff is 12 + of the intervals specified by intervalType" />. + + + Because of the conceptual design of , + it is not always possible to decide with certainty that the trigger + will never fire again. Therefore, it will search for the next + fire time up to a given cutoff. These cutoffs can be changed by using the + method. The default cutoff is 12 + of the intervals specified by intervalType". + + + In most cases, the default value of this setting (12) is sufficient (it + is highly unlikely, for example, that you will need to look at more than + 12 months of dates to ensure that your trigger will never fire again). + However, this setting is included to allow for the rare exceptions where + this might not be true. + + + For example, if your trigger is associated with a calendar that excludes + a great many dates in the next 12 months, and hardly any following that, + it is possible (if is large enough) that you could run + into this situation. + + + + + + Returns the last UTC time the will fire. + If the trigger will not fire at any point between + and , will be returned. + + the last time the trigger will fire. + + + + Tells whether this Trigger instance can handle events + in millisecond precision. + + + + + + Sets or gets the time zone in which the will be resolved. + If no time zone is provided, then the default time zone will be used. + + + + + + + Gets or sets the trigger's calendar week rule. + + The trigger calendar week rule. + + + + Gets or sets the trigger's calendar first day of week rule. + + The trigger calendar first day of week. + + + + An exception that is thrown to indicate that an attempt to store a new + object (i.e. , + or ) in a + failed, because one with the same name and group already exists. + + James House + Marko Lahma (.NET) + + + + Create a with the given + message. + + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Create a and auto-generate a + message using the name/group from the given . + + + + The message will read:
"Unable to store Job with name: '__' and + group: '__', because one already exists with this identification." +
+
+
+ + + Create a and auto-generate a + message using the name/group from the given . + + + + The message will read:
"Unable to store Trigger with name: '__' and + group: '__', because one already exists with this identification." +
+
+
+ + + An attribute that marks a class as one that makes updates to its + during execution, and wishes the scheduler to re-store the + when execution completes. + + + + Jobs that are marked with this annotation should also seriously consider + using the attribute, to avoid data + storage race conditions with concurrently executing job instances. + + + This can be used in lieu of implementing the StatefulJob marker interface that + was used prior to Quartz 2.0 + + + + James House + Marko Lahma (.NET) + + + + An exception that is thrown to indicate that there is a misconfiguration of + the - or one of the components it + configures. + + James House + Marko Lahma (.NET) + + + + Create a with the given message. + + + + + Create a with the given message + and cause. + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + + Scheduler constants. + + Marko Lahma (.NET) + + + + A (possibly) useful constant that can be used for specifying the group + that and instances belong to. + + + + + A constant group name used internally by the + scheduler - clients should not use the value of this constant + ("RECOVERING_JOBS") for thename of a 's group. + + + + + A constant group name used internally by the + scheduler - clients should not use the value of this constant + ("FAILED_OVER_JOBS") for thename of a 's group. + + + + + A constant key that can be used to retrieve the + name of the original from a recovery trigger's + data map in the case of a job recovering after a failed scheduler + instance. + + + + + + A constant key that can be used to retrieve the + group of the original from a recovery trigger's + data map in the case of a job recovering after a failed scheduler + instance. + + + + + + A constant key that can be used to retrieve the + scheduled fire time of the original from a recovery + trigger's data map in the case of a job recovering after a failed scheduler + instance. + + + + + + Holds context/environment data that can be made available to Jobs as they + are executed. + + + Future versions of Quartz may make distinctions on how it propagates + data in between instances of proxies to a + single scheduler instance - i.e. if Quartz is being used via WCF of Remoting. + + + James House + Marko Lahma (.NET) + + + + Create an empty . + + + + + Create a with the given data. + + + + + Serialization constructor. + + + + + + + Instructs Scheduler what to do with a trigger and job. + + Marko Lahma (.NET) + + + + Instructs the that the + has no further instructions. + + + + + Instructs the that the + wants the to re-Execute + immediately. If not in a 'RECOVERING' or 'FAILED_OVER' situation, the + execution context will be re-used (giving the the + ability to 'see' anything placed in the context by its last execution). + + + + + Instructs the that the + should be put in the state. + + + + + Instructs the that the + wants itself deleted. + + + + + Instructs the that all + s referencing the same as + this one should be put in the state. + + + + + Instructs the that all + s referencing the same as + this one should be put in the state. + + + + + Instructs the that the + should be put in the state. + + + + + Describes the settings and capabilities of a given + instance. + + James House + Marko Lahma (.NET) + + + + Initializes a new instance of the class. + + Name of the scheduler. + The scheduler instance. + The scheduler type. + if set to true, scheduler is a remote scheduler. + if set to true, scheduler is started. + if set to true, scheduler is in standby mode. + if set to true, scheduler is shutdown. + The start time. + The number of jobs executed. + The job store type. + if set to true, job store is persistent. + if set to true, the job store is clustered + The thread pool type. + Size of the thread pool. + The version string. + + + + Returns a formatted (human readable) string describing all the 's + meta-data values. + + + + The format of the string looks something like this: +
+            Quartz Scheduler 'SchedulerName' with instanceId 'SchedulerInstanceId' Scheduler class: 'Quartz.Impl.StdScheduler' - running locally. Running since: '11:33am on Jul 19, 2002' Not currently paused. Number of Triggers fired: '123' Using thread pool 'Quartz.Simpl.SimpleThreadPool' - with '8' threads Using job-store 'Quartz.Impl.JobStore' - which supports persistence.
+            
+
+
+
+ + + Return a simple string representation of this object. + + + + + Returns the name of the . + + + + + Returns the instance Id of the . + + + + + Returns the class-name of the instance. + + + + + Returns whether the is being used remotely (via remoting). + + + + + Returns whether the scheduler has been started. + + + Note: may return even if + returns . + + + + + Reports whether the is in standby mode. + + + Note: may return even if + returns . + + + + + Reports whether the has been Shutdown. + + + + + Returns the class-name of the instance that is + being used by the . + + + + + Returns the type name of the instance that is + being used by the . + + + + + Returns the number of threads currently in the 's + + + + + Returns the version of Quartz that is running. + + + + + Returns the at which the Scheduler started running. + + null if the scheduler has not been started. + + + + + Returns the number of jobs executed since the + started.. + + + + + Returns whether or not the 's + instance supports persistence. + + + + + Returns whether or not the 's + is clustered. + + + + + SimpleScheduleBuilder is a + that defines strict/literal interval-based schedules for + s. + + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + Client code can then use the DSL to write code such as this: + + JobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + Trigger trigger = TriggerBuilder.Create() + .WithIdentity(triggerKey("myTrigger", "myTriggerGroup")) + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + + Create a SimpleScheduleBuilder. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with a 1 minute interval. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with an interval + of the given number of minutes. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with a 1 second interval. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with an interval + of the given number of seconds. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with a 1 hour interval. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat forever with an interval + of the given number of hours. + + + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with a 1 minute interval. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with an interval of the given number of minutes. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with a 1 second interval. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with an interval of the given number of seconds. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with a 1 hour interval. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Create a SimpleScheduleBuilder set to repeat the given number + of times - 1 with an interval of the given number of hours. + + + Note: Total count = 1 (at start time) + repeat count + + the new SimpleScheduleBuilder + + + + Build the actual Trigger -- NOT intended to be invoked by end users, + but will rather be invoked by a TriggerBuilder which this + ScheduleBuilder is given to. + + + + + + + + Specify a repeat interval in milliseconds. + + + + the time span at which the trigger should repeat. + the updated SimpleScheduleBuilder + + + + + + Specify a repeat interval in seconds. + + + + the time span at which the trigger should repeat. + the updated SimpleScheduleBuilder + + + + + + Specify a the number of time the trigger will repeat - total number of + firings will be this number + 1. + + + + the number of seconds at which the trigger should repeat. + the updated SimpleScheduleBuilder + + + + + + Specify that the trigger will repeat indefinitely. + + + + the updated SimpleScheduleBuilder + + + + + + + If the Trigger misfires, use the + instruction. + + + + the updated CronScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + If the Trigger misfires, use the + instruction. + + + + the updated SimpleScheduleBuilder + + + + + Extension methods that attach to . + + + + + A time source for Quartz.NET that returns the current time. + Original idea by Ayende Rahien: + http://ayende.com/Blog/archive/2008/07/07/Dealing-with-time-in-tests.aspx + + + + + Return current UTC time via . Allows easier unit testing. + + + + + Return current time in current time zone via . Allows easier unit testing. + + + + + Represents a time in hour, minute and second of any given day. + + + The hour is in 24-hour convention, meaning values are from 0 to 23. + + + + + James House + Zemian Deng saltnlight5@gmail.com + Nuno Maia (.NET) + + + + Create a TimeOfDay instance for the given hour, minute and second. + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + The second of the minute, between 0 and 59. + + + + Create a TimeOfDay instance for the given hour, minute (at the zero second of the minute). + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + + + + Create a TimeOfDay instance for the given hour, minute and second. + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + The second of the minute, between 0 and 59. + + + + + Create a TimeOfDay instance for the given hour, minute (at the zero second of the minute).. + + The hour of day, between 0 and 23. + The minute of the hour, between 0 and 59. + The newly instantiated TimeOfDay + + + + Determine with this time of day is before the given time of day. + + + True this time of day is before the given time of day. + + + + Return a date with time of day reset to this object values. The millisecond value will be zero. + + + + + + The hour of the day (between 0 and 23). + + + + + The minute of the hour (between 0 and 59). + + + + + The second of the minute (between 0 and 59). + + + + + Attribute to use with public properties that + can be set with Quartz configuration. Attribute can be used to advice + parsing to use correct type of time span (milliseconds, seconds, minutes, hours) + as it may depend on property. + + Marko Lahma (.NET) + + + + + Initializes a new instance of the class. + + The rule. + + + + Gets the rule. + + The rule. + + + + Possible parse rules for s. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + TriggerBuilder is used to instantiate s. + + + + The builder will always try to keep itself in a valid state, with + reasonable defaults set for calling build() at any point. For instance + if you do not invoke WithSchedule(..) method, a default schedule + of firing once immediately will be used. As another example, if you + do not invoked WithIdentity(..) a trigger name will be generated + for you. + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + + + Create a new TriggerBuilder with which to define a + specification for a Trigger. + + + + the new TriggerBuilder + + + + Produce the . + + + + a Trigger that meets the specifications of the builder. + + + + Use a with the given name and default group to + identify the Trigger. + + + If none of the 'withIdentity' methods are set on the TriggerBuilder, + then a random, unique TriggerKey will be generated. + + the name element for the Trigger's TriggerKey + the updated TriggerBuilder + + + + + + Use a TriggerKey with the given name and group to + identify the Trigger. + + + If none of the 'withIdentity' methods are set on the TriggerBuilder, + then a random, unique TriggerKey will be generated. + + the name element for the Trigger's TriggerKey + the group element for the Trigger's TriggerKey + the updated TriggerBuilder + + + + + + Use the given TriggerKey to identify the Trigger. + + + If none of the 'withIdentity' methods are set on the TriggerBuilder, + then a random, unique TriggerKey will be generated. + + the TriggerKey for the Trigger to be built + the updated TriggerBuilder + + + + + + Set the given (human-meaningful) description of the Trigger. + + + + the description for the Trigger + the updated TriggerBuilder + + + + + Set the Trigger's priority. When more than one Trigger have the same + fire time, the scheduler will fire the one with the highest priority + first. + + + + the priority for the Trigger + the updated TriggerBuilder + + + + + + Set the name of the that should be applied to this + Trigger's schedule. + + + + the name of the Calendar to reference. + the updated TriggerBuilder + + + + + + Set the time the Trigger should start at - the trigger may or may + not fire at this time - depending upon the schedule configured for + the Trigger. However the Trigger will NOT fire before this time, + regardless of the Trigger's schedule. + + + + the start time for the Trigger. + the updated TriggerBuilder + + + + + + Set the time the Trigger should start at to the current moment - + the trigger may or may not fire at this time - depending upon the + schedule configured for the Trigger. + + + + the updated TriggerBuilder + + + + + Set the time at which the Trigger will no longer fire - even if it's + schedule has remaining repeats. + + + + the end time for the Trigger. If null, the end time is indefinite. + the updated TriggerBuilder + + + + + + Set the that will be used to define the + Trigger's schedule. + + + The particular used will dictate + the concrete type of Trigger that is produced by the TriggerBuilder. + + the SchedulerBuilder to use. + the updated TriggerBuilder + + + + + + + + Set the identity of the Job which should be fired by the produced + Trigger. + + + + the identity of the Job to fire. + the updated TriggerBuilder + + + + + Set the identity of the Job which should be fired by the produced + Trigger - a will be produced with the given + name and default group. + + + + the name of the job (in default group) to fire. + the updated TriggerBuilder + + + + + Set the identity of the Job which should be fired by the produced + Trigger - a will be produced with the given + name and group. + + + + the name of the job to fire. + the group of the job to fire. + the updated TriggerBuilder + + + + + Set the identity of the Job which should be fired by the produced + Trigger, by extracting the JobKey from the given job. + + + + the Job to fire. + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Add the given key-value pair to the Trigger's . + + + + the updated TriggerBuilder + + + + + Common constants for triggers. + + + + + The default value for priority. + + + + + Uniquely identifies a . + + + Keys are composed of both a name and group, and the name must be unique + within the group. If only a name is specified then the default group + name will be used. + + + Quartz provides a builder-style API for constructing scheduling-related + entities via a Domain-Specific Language (DSL). The DSL can best be + utilized through the usage of static imports of the methods on the classes + , , + , , + and the various implementations. + + + Client code can then use the DSL to write code such as this: + + + IJobDetail job = JobBuilder.Create<MyJob>() + .WithIdentity("myJob") + .Build(); + ITrigger trigger = TriggerBuilder.Create() + .WithIdentity("myTrigger", "myTriggerGroup") + .WithSimpleSchedule(x => x + .WithIntervalInHours(1) + .RepeatForever()) + .StartAt(DateBuilder.FutureDate(10, IntervalUnit.Minute)) + .Build(); + scheduler.scheduleJob(job, trigger); + + + + + + + + All trigger states known to Scheduler. + + Marko Lahma (.NET) + + + + Indicates that the is in the "normal" state. + + + + + Indicates that the is in the "paused" state. + + + + + Indicates that the is in the "complete" state. + + + "Complete" indicates that the trigger has not remaining fire-times in + its schedule. + + + + + Indicates that the is in the "error" state. + + + + A arrives at the error state when the scheduler + attempts to fire it, but cannot due to an error creating and executing + its related job. Often this is due to the 's + class not existing in the classpath. + + + + When the trigger is in the error state, the scheduler will make no + attempts to fire it. + + + + + + Indicates that the is in the "blocked" state. + + + A arrives at the blocked state when the job that + it is associated with has a and it is + currently executing. + + + + + + Indicates that the does not exist. + + + + + A Comparator that compares trigger's next fire times, or in other words, + sorts them according to earliest next fire time. If the fire times are + the same, then the triggers are sorted according to priority (highest + value first), if the priorities are the same, then they are sorted + by key. + + + + + Convenience and utility methods for simplifying the construction and + configuration of s and DateTimeOffsetOffsets. + + + + James House + Marko Lahma (.NET) + + + + Returns a list of Dates that are the next fire times of a + . + The input trigger will be cloned before any work is done, so you need + not worry about its state being altered by this method. + + The trigger upon which to do the work + The calendar to apply to the trigger's schedule + The number of next fire times to produce + List of java.util.Date objects + + + + Compute the that is 1 second after the Nth firing of + the given , taking the triger's associated + into consideration. + + + The input trigger will be cloned before any work is done, so you need + not worry about its state being altered by this method. + + The trigger upon which to do the work + The calendar to apply to the trigger's schedule + The number of next fire times to produce + the computed Date, or null if the trigger (as configured) will not fire that many times + + + + Returns a list of Dates that are the next fire times of a + that fall within the given date range. The input trigger will be cloned + before any work is done, so you need not worry about its state being + altered by this method. + + NOTE: if this is a trigger that has previously fired within the given + date range, then firings which have already occurred will not be listed + in the output List. + + + The trigger upon which to do the work + The calendar to apply to the trigger's schedule + The starting date at which to find fire times + The ending date at which to stop finding fire times + List of java.util.Date objects + + + + An exception that is thrown to indicate that a call to + failed without interrupting the Job. + + + James House + Marko Lahma (.NET) + + + + Create a with the given message. + + + + + Create a with the given cause. + + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The class name is null or is zero (0). + The info parameter is null. + + + diff --git a/Resources/Libraries/SharpSSH/DiffieHellman.dll b/Resources/Libraries/SharpSSH/DiffieHellman.dll new file mode 100644 index 0000000000000000000000000000000000000000..aa3105110d3963b20d2171355c88d5f6b93bad66 GIT binary patch literal 53248 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/SharpSSH/Tamir.SharpSSH.dll b/Resources/Libraries/SharpSSH/Tamir.SharpSSH.dll new file mode 100644 index 0000000000000000000000000000000000000000..c2f67a826be086aacfd8d1488d0789c7f5e64ab3 GIT binary patch literal 212992 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 CT3X=% literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Common.Logging.dll b/Resources/Libraries/Spring.NET/Common.Logging.dll new file mode 100644 index 0000000000000000000000000000000000000000..d7a8f1582ac8a04a0417db7d750c7268b3ecaefa GIT binary patch literal 28672 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 + Namespace parser for the aop namespace. + + + Using the advisor tag you can configure an and have it + applied to all the relevant objects in your application context automatically. The + advisor tag supports only referenced s. + + Rob harrop + Adrian Colyer + Rod Johnson + Mark Pollack (.NET) + + + + Register the for the 'config' tag. + + + + + Utility class for handling registration of auto-proxy creators used internally by the + aop and tx namespace tags. + + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + Erich Eichinger (.NET) + + + + The object name of the internally managed auto-proxy creator. + + + + + The type of the APC that handles advisors with object role . + + + + + Registers the internal auto proxy creator if necessary. + + The parser context. + The source element. + + + + Registers the internal auto proxy creator if necessary. + + + + + Forces the auto proxy creator to use decorator proxy. + + The registry. + + + + The for the <aop:config> tag. + + Mark Pollack (.NET) + + + + The 'proxy-target-type' attribute + + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + The element to be parsed. + The object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + The primary object definition. + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+
+ + + Parses the supplied advisor element and registers the resulting + + The advisor element. + The parser context. + + + + implementation + that registers instances of any non-default + instances with the + + singleton. + + +

+ The only requirement for it to work is that it needs to be defined + in an application context along with any arbitrary "non-native" Spring.NET + instances that need + to be recognized by Spring.NET's AOP framework. +

+
+ Dmitriy Kopylenko + Aleksandar Seovic (.NET) +
+ + + Apply this + to the given new object instance before any object initialization callbacks. + + +

+ Does nothing, simply returns the supplied as is. +

+
+ + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + +
+ + + Apply this to the + given new object instance after any object initialization callbacks. + + +

+ Registers the supplied with the + + singleton if it is an + instance. +

+
+ + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + +
+ + + implementation + to enable to be used in the + Spring.NET AOP framework. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Permits the handling of new advisors and advice types as extensions to + the Spring AOP framework. + + +

+ Implementors can create AOP Alliance + s from custom advice + types, enabling these advice types to be used in the Spring.NET AOP + framework, which uses interception under the covers. +

+

+ There is no need for most Spring.NET users to implement this interface; + do so only if you need to introduce more + or + types to Spring.NET. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Does this adapter understand the supplied ? + + +

+ Is it valid to invoke the + + method with the given advice as an argument? +

+
+ + such as + . + + if this adapter understands the + supplied . + +
+ + + Return an AOP Alliance + exposing the + behaviour of the given advice to an interception-based AOP + framework. + + +

+ Don't worry about any + contained in the supplied ; + the AOP framework will take care of checking the pointcut. +

+
+ + The advice. The + + method must have previously returned on the + supplied . + + + An AOP Alliance + exposing the + behaviour of the given advice to an interception-based AOP + framework. + +
+ + + Returns if the supplied + is an instance of the + interface. + + The advice to check. + + if the supplied is + an instance of the interface; + if not or if the supplied + is . + + + + + Wraps the supplied 's + within a + + instance. + + + The advisor exposing the that + is to be wrapped. + + + The supplied 's + wrapped within a + + instance. + + + + + Interceptor to wrap an + instance. + + +

+ A more efficient alternative solution in cases where there is no + interception advice and therefore no need to create an + object may be + offered in future. +

+

+ Used internally by the AOP framework: application developers should not need + to use this class directly. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Intercepts calls on an interface on its way to the target. + + +

+ Such interceptions are nested "on top" of the target. +

+
+
+ + + Represents a generic interceptor. + + +

+ A generic interceptor can intercept runtime events that occur within a + base program. Those events are materialized by (reified in) joinpoints. + Runtime joinpoints can be invocations, field access, exceptions, etc. +

+

+ This interface is not used directly. Use the various derived interfaces + to intercept specific events. +

+
+ +
+ + + Tag interface for advice. + + +

+ Implementations can be any type of advice, such as interceptors. +

+
+
+ + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + Creates a new instance of the + + class. + + + The advice to be applied after a target method successfully + returns. + + + If the supplied is . + + + + + Executes interceptor after the target method successfully returns. + + + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + + + + + implementation + to enable to be used in the + Spring.NET AOP framework. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Returns if the supplied + is an instance of the + interface. + + The advice to check. + + if the supplied is + an instance of the interface; + if not or if the supplied + is . + + + + + Wraps the supplied 's + within a + + instance. + + + The advisor exposing the that + is to be wrapped. + + + The supplied 's + wrapped within a + + instance. + + + + + Default implementation of the + + interface. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + A registry of + instances. + + +

+ Implementations must also automatically register adapters for + types. +

+ + This is an SPI interface, that should not need to be implemented by any + Spring.NET user. + +
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Returns an wrapping the supplied + . + + + The object that should be an advice, such as + or + . + + + An wrapping the supplied + . Never returns . If + the parameter is an + , it will simply be returned. + + + If no registered + can wrap + the supplied . + + + + + Returns an to + allow the use of the supplied in an + interception-based framework. + + +

+ Don't worry about the pointcut associated with the + ; if it's an + , just return an + interceptor. +

+
+ + The advisor to find an interceptor for. + + + An interceptor to expose this advisor's behaviour. + + + If the advisor type is not understood by any registered + . + +
+ + + Register the given . + + +

+ Note that it is not necessary to register adapters for + instances: these + must be automatically recognized by an + + implementation. +

+
+ + An that + understands the particular advisor and advice types. + +
+ + + Creates a new instance of the + class. + + +

+ This constructor will also register the well-known + types. +

+
+ +
+ + + Returns an wrapping the supplied + . + + + The object that should be an advice, such as + or + . + + + An wrapping the supplied + . Never returns . If + the parameter is an + , it will simply be returned. + + + If no registered + can wrap + the supplied . + + + + + Returns an to + allow the use of the supplied in an + interception-based framework. + + The advisor to find an interceptor for. + + An interceptor to expose this advisor's behaviour. + + + If the advisor type is not understood by any registered + . + + + + + Register the given . + + + An that + understands the particular advisor and advice types. + + + + + Provides Singleton-style access to the default + instance. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + class. + + +

+ This contructor is marked as to enforce the + Singleton pattern +

+
+
+ + + The default instance. + + + + + implementation that + wraps instances. + + +

+ In the future Spring.NET may also offer a more efficient alternative + solution in cases where there is no interception advice and therefore + no need to create an + object. +

+

+ Used internally by the Spring.NET AOP framework: application developers + should not need to use this class directly. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + + class. + + + The that is to be wrapped. + + + If the supplied is . + + + + + Executes interceptor before the target method successfully returns. + + + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied . + + + If any of the interceptors in the chain or the target object itself + throws an exception. + + + + + implementation + to enable to be used in the + Spring.NET AOP framework. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Returns if the supplied + is an instance of the + interface. + + The advice to check. + + if the supplied is + an instance of the interface; + if not or if the supplied + is . + + + + + Wraps the supplied 's + within a + + instance. + + + The advisor exposing the that + is to be wrapped. + + + The supplied 's + wrapped within a + + instance. + + + + Interceptor to wrap an after throwing advice. + +

+ Implementations of the interface + must define methods of the form... + + AfterThrowing([MethodInfo method, Object[] args, Object target], Exception subclass); + + The method name is fixed (i.e. your methods must be named + AfterThrowing. The first three arguments (as a whole) are + optional, and only useful if futher information about the joinpoint is + required. The return type can be anything, but is almost always + by convention. +

+

+ Please note that the object encapsulating the throws advice does not + need to implement the interface. + Throws advice methods are discovered via reflection... the + interface serves merely to + discover objects that are to be considered as throws advice. + Other mechanisms for discovering throws advice such as attributes are + also equally valid... all that this class cares about is that a throws + advice object implement one or more methods with a valid throws advice + signature (see above, and the examples below). +

+

+ This is a framework class that should not normally need to be used + directly by Spring.NET users. +

+
+ +

+ Find below some examples of valid + method signatures... +

+ + public class GlobalExceptionHandlingAdvice : IThrowsAdvice + { + public void AfterThrowing(Exception ex) { + // handles absolutely any and every Exception... + } + } + + + public class RemotingExceptionHandlingAdvice : IThrowsAdvice + { + public void AfterThrowing(RemotingException ex) { + // handles any and every RemotingException (and subclasses of RemotingException)... + } + } + + + using System.Data; + + public class DataExceptionHandlingAdvice + { + public void AfterThrowing(ConstraintException ex) { + // specialised handling of ConstraintExceptions + } + + public void AfterThrowing(NoNullAllowedException ex) { + // specialised handling of NoNullAllowedExceptions + } + + public void AfterThrowing(DataException ex) { + // handles all other DataExceptions... + } + } + +
+ Rod Johnson + Aleksandar Seovic (.NET) + +
+ + + The mapping of exception Types to MethodInfo handlers. + + + + + Creates a new instance of the + class. + + + + + The throws advice to check for exception handler methods. + + + If the supplied is . + + + If no (0) handler methods were discovered on the supplied ; + or if more than one handler method suitable for a particular + type was discovered on the supplied + . + + + + + Executes interceptor if (and only if) the supplied + throws an exception that is mapped to + an appropriate exception handler. + + + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied (this assumes no + exception was thrown by the call to the supplied . + + + If any of the interceptors in the chain or the target object itself + throws an exception. + + + + + + Gets the exception handler (if any) that has been mapped to the + supplied . + + +

+ Will return if not found. +

+
+ + The exception handler for the of the + supplied given exception. + + exception that was thrown +
+ + + Invokes handler method with appropriate number of parameters + + + The original method invocation that was intercepted. + + + The exception that triggered this interceptor. + + + The exception handler method to invoke. + + + + + Convenience property that returns the number of exception handler + methods managed by this interceptor. + + + The number of exception handler methods managed by this interceptor. + + + + + Exception thrown when an attempt is made to use an unsupported + or + type. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + class. + + The advice that caused the exception. + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class with + the specified message. + + + A message about the exception. + + + + + Creates a new instance of the + class with + the specified message and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Summary description for AbstractPrototypeBasedTargetSourceCreator. + + + + + Implementations can create special target sources, such as pooling target + sources, for particular objects. For example, they may base their choice + on attributes, such as a pooling attribute, on the target type. + +

AbstractAutoProxyCreator can support a number of TargetSourceCreators, + which will be applied in order.

+
+ Rod Johnson + Adhari C Mahendra (.NET) +
+ + + Create a special TargetSource for the given object, if any. + + The type of the object to create a TargetSource for + the name of the object + the containing factory + a special TargetSource or null if this TargetSourceCreator isn't + interested in the particular object + + + + The logger + + + + + Create a special TargetSource for the given object, if any. + + the type of the object to create a TargetSource for + the name of the object + the containing factory + + a special TargetSource or null if this TargetSourceCreator isn't + interested in the particular object + + + + + Creates the prototype target source. + + The type of the object to create a target source for. + The name. + The factory. + + + + + Abstract IObjectPostProcessor implementation that creates AOP proxies. + This class is completely generic; it contains no special code to handle + any particular aspects, such as pooling aspects. + + +

Subclasses must implement the abstract FindCandidateAdvisors() method + to return a list of Advisors applying to any object. Subclasses can also + override the inherited ShouldSkip() method to exclude certain objects + from autoproxying, but they must be careful to invoke the ShouldSkip() + method of this class, which tries to avoid circular reference problems + and infinite loops.

+

Advisors or advices requiring ordering should implement the Ordered interface. + This class sorts advisors by Ordered order value. Advisors that don't implement + the Ordered interface will be considered to be unordered, and will appear + at the end of the advisor chain in undefined order.

+
+ + Rod Johnson + Adhari C Mahendra (.NET) + Erich Eichinger +
+ + + ObjectPostProcessor implementation that wraps a group of objects with AOP proxies + that delegate to the given interceptors before invoking the object itself. + + +

This class distinguishes between "common" interceptors: shared for all proxies it + creates, and "specific" interceptors: unique per object instance. There need not + be any common interceptors. If there are, they are set using the interceptorNames + property. As with ProxyFactoryObject, interceptors names in the current factory + are used rather than object references to allow correct handling of prototype + advisors and interceptors: for example, to support stateful mixins. + Any advice type is supported for "interceptorNames" entries.

+

Such autoproxying is particularly useful if there's a large number of objects that need + to be wrapped with similar proxies, i.e. delegating to the same interceptors. + Instead of x repetitive proxy definitions for x target objects, you can register + one single such post processor with the object factory to achieve the same effect.

+

Subclasses can apply any strategy to decide if a object is to be proxied, + e.g. by type, by name, by definition details, etc. They can also return + additional interceptors that should just be applied to the specific object + instance. The default concrete implementation is ObjectNameAutoProxyCreator, + identifying the objects to be proxied via a list of object names.

+

Any number of TargetSourceCreator implementations can be used with any subclass, + to create a custom target source - for example, to pool prototype objects. + Autoproxying will occur even if there is no advice if a TargetSourceCreator specifies + a custom TargetSource. If there are no TargetSourceCreators set, or if none matches, + a SingletonTargetSource will be used by default to wrap the object to be autoproxied.

+
+ Juergen Hoeller + Rod Johnson + Adhari C Mahendra (.NET) + + +
+ + + Convenience superclass for configuration used in creating proxies, + to ensure that all proxy creators have consistent properties. + + +

+ Note that it is no longer possible to configure subclasses to + expose the . + Interceptors should normally manage their own thread locals if they + need to make resources available to advised objects. If it is + absolutely necessary to expose the + , use an + interceptor to do so. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Copies the configuration from the supplied + into this instance. + + + The configuration to be copied. + + + If the supplied is + . + + + + + A that represents the current + configuration. + + + A that represents the current + configuration. + + + + + Use to synchronize access to this ProxyConfig instance + + + + + Is the target to be proxied in addition + to any interfaces declared on the proxied ? + + + + + Is target type attributes, method attributes, method's return type attributes + and method's parameter attributes to be proxied in addition + to any interfaces declared on the proxied ? + + + + + Are any agressive optimizations to be performed? + + +

+ The exact meaning of agressive optimizations will differ + between proxies, but there is usually some tradeoff. +

+

+ For example, optimization will usually mean that advice changes + won't take effect after a proxy has been created. For this reason, + optimization is disabled by default. An optimize value of + may be ignored if other settings preclude + optimization: for example, if the + property + is set to and such a value is not compatible + with the optimization. +

+

+ The default is . +

+
+
+ + + Should proxies obtained from this configuration expose + the AOP proxy to the + class? + + +

+ The default is , as enabling this property + may impair performance. +

+
+
+ + + Gets and set the factory to be used to create AOP proxies. + + +

+ This obviously allows one to customise the + implementation, + allowing different strategies to be dropped in without changing the + core framework. For example, an + implementation + could return an + using remoting proxies, Reflection.Emit or a code generation + strategy. +

+
+
+ + + Is this configuration frozen? + + +

+ The default is not frozen. +

+
+
+ + + The logger for this class hierarchy. + + + + + Convenience constant for subclasses: Return value for "do not proxy". + + + + + Convenience constant for subclasses: Return value for + "proxy without additional interceptors, just the common ones". + + + + + Default value is same as non-ordered + + + + + Default is global AdvisorAdapterRegistry + + + + + Indicates whether to mark the create proxy as immutable. + + + Setting this to true effectively disables modifying the generated + proxy's advisor configuration + + + + + Names of common interceptors. + We must use object name rather than object references + to handle prototype advisors/interceptors. + Default is the empty array: no common interceptors. + + + + + Set of object type + name strings, referring to all objects that this auto-proxy + creator created a custom TargetSource for. Used to detect own pre-built proxies + (from "PostProcessBeforeInstantiation") in the "PostProcessAfterInitialization" method. + + + + + Create a new instance of this AutoProxyCreator + + + + + Create a proxy with the configured interceptors if the object is + identified as one to proxy by the subclass. + + + + + No-op for before initialization. + + The obj. + The name. + + + + + Subclasses should override this method to return true if this + object should not be considered for autoproxying by this post processor. + Sometimes we need to be able to avoid this happening if it will lead to + a circular reference. This implementation returns false. + + the type of the object + the name of the object + if remarkable to skip + + + + Subclasses may choose to implement this: for example, + to change the interfaces exposed + + + ProxyFactory that will be used to create the proxy immediably after this method returns. + + + + + Determines whether the object is an infrastructure type, + IAdvisor, IAdvice, IAdvisors or AbstractAutoProxyCreator + + The object type to compare + The name of the object + + true if [is infrastructure type] [the specified obj]; otherwise, false. + + + + + Create a target source for object instances. Uses any + TargetSourceCreators if set. Returns null if no Custom TargetSource + should be used. + This implementation uses the customTargetSourceCreators property. + Subclasses can override this method to use a different mechanism. + + the type of the object to create a TargetSource for + the name of the object + a TargetSource for this object + + + + Return whether the given object is to be proxied, what additional + advices (e.g. AOP Alliance interceptors) and advisors to apply. + + +

The previous targetName of this method was "GetInterceptorAndAdvisorForObject". + It has been renamed in the course of general terminology clarification + in Spring 1.1. An AOP Alliance Interceptor is just a special form of + Advice, so the generic Advice term is preferred now.

+

The third parameter, customTargetSource, is new in Spring 1.1; + add it to existing implementations of this method.

+
+ the new object instance + the name of the object + targetSource returned by TargetSource property: + may be ignored. Will be null unless a custom target source is in use. + an array of additional interceptors for the particular object; + or an empty array if no additional interceptors but just the common ones; + or null if no proxy at all, not even with the common interceptors. +
+ + + Create an AOP proxy for the given object. + + Type of the object. + The name of the object. + The set of interceptors that is specific to this + object (may be empty but not null) + The target source for the proxy, already pre-configured to access the object. + The AOP Proxy for the object. + + + + Obtain a new proxy factory instance to be used for proxying a particular object + + A proxy factory instance for proxying a particular object + + + + Determines the advisors for the given object, including the specific interceptors + as well as the common interceptor, all adapted to the Advisor interface. + + The name of the object. + The set of interceptors that is specific to this + object (may be empty, but not null) + The list of Advisors for the given object + + + + Build a cache key for the given object type and object name + + The object type. + The object name. + The cache key for the given type and name + + + + Create the proxy if have a custom TargetSource + + The object type + The object name + null if not creating a proxy, otherwise return the proxy. + + + + Default behavior, return true and continue processing. + + The object instance + The object name. + true + + + + Default behavior, return passed in PropertyValues + + The property values that the factory is about to apply (never null). + he relevant property infos for the target object (with ignored + dependency types - which the factory handles specifically - already filtered out) + The object instance created, but whose properties have not yet + been set. + Name of the object. + The passed in PropertyValues + + + + Sets the AdvisorAdapterRegistry to use. + + + Default is the global AdvisorAdapterRegistry. + + + + + Sets custom TargetSourceCreators to be applied in this order. + + + + If the list is empty, or they all return null, a SingletonTargetSource + will be created. + + + TargetSourceCreators can only be invoked if this post processor is used + in a IObjectFactory, and its ObjectFactoryAware callback is used. + + + + + + Sets the common interceptors, a list of , + and introduction object names. + + + + If this property isn't set, there will be zero common interceptors. + This is perfectly valid, if "specific" interceptors such as + matching Advisors are all we want. + + + + The list of , + and introduction object names. + + + + + + + Sets whether the common interceptors should be applied before + object-specific ones. + + + Default is true; else, object-specific interceptors will get applied first. + + + + + Set whether or not the proxy should be frozen, preventing advice + from being added to it once it is created. + + +

Overridden from the super class to prevent the proxy configuration + from being frozen before the proxy is created. The default is not frozen. +

+
+
+ + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Propery Order + + + Ordering which will apply to this class's implementation + of Ordered, used when applying multiple ObjectPostProcessors. + Default value is int.MaxValue, meaning that it's non-ordered. + + + + + Initialize + + + + + An new was set. Initialize this creator instance + according to the specified object factory. + + + + + + Create the for retrieving the list of + applicable advisor objects. The default implementation calls back into + thus it usually is sufficient to just + override . Override + only if you know what you are doing! + + + + + + + Return whether the given object is to be proxied, what additional + advices (e.g. AOP Alliance interceptors) and advisors to apply. + + +

The previous targetName of this method was "GetInterceptorAndAdvisorForObject". + It has been renamed in the course of general terminology clarification + in Spring 1.1. An AOP Alliance Interceptor is just a special form of + Advice, so the generic Advice term is preferred now.

+

The third parameter, customTargetSource, is new in Spring 1.1; + add it to existing implementations of this method.

+
+ the type of the target object + the name of the target object + targetSource returned by TargetSource property: + may be ignored. Will be null unless a custom target source is in use. + + an array of additional interceptors for the particular object; + or an empty array if no additional interceptors but just the common ones; + or null if no proxy at all, not even with the common interceptors. + +
+ + + Find all eligible advices and for autoproxying this class. + + the type of the object to be advised + the name of the object to be advised + + the empty list, not null, if there are no pointcuts or interceptors. + The by-order sorted list of advisors otherwise + + + + + Find all possible advisor candidates to use in auto-proxying + + the type of the object to be advised + the name of the object to be advised + the list of candidate advisors + + + + From the given list of candidate advisors, select the ones that are applicable + to the given target specified by targetType and name. + + the list of candidate advisors to date + the target object's type + the target object's name + the list of applicable advisors + + + + Sorts the advisors. + + The advisors. + + + + + Extension hook that subclasses can override to add additional advisors for the given object, + given the sorted advisors obtained to date.
+ The default implementation does nothing.
+ Typically used to add advisors that expose contextual information required by some of the later advisors. +
+ + The advisor list passed into this method is already reduced to advisors applying to this particular object. + If you want to register additional common advisor candidates, override . + + Advisors that have already been identified as applying to a given object + the type of the object to be advised + the name of the object to be advised +
+ + + Whether the given advisor is eligible for the specified target. The default implementation + always returns true. + + the advisor name + the target object's type + the target object's name + + + + We override this method to ensure that all candidate advisors are materialized + under a stack trace including this object. Otherwise, the dependencies won't + be apparent to the circular-reference prevention strategy in AbstractObjectFactory. + + + + + Helper for retrieving standard Spring advisors from an for + use with auto-proxying. + + Erich Eichinger + + + + Interface encapsulating the advisor retrieval strategy used by + an to retrieve the + applicable list of advisor objects. + + + + + Get the list of advisor objects to apply on the target. + + + + + Create a new helper for the specified . + + + + + Find all all eligible advisor objects in the current object factory. + + the type of the object to be advised + the name of the object to be advised + A list of eligible instances + + + + Add the named advisor instance to the list of advisors. + + the advisor list + the object name of the advisor to add + + + + Gets the names of advisor candidates + + the type of the object to be advised + the name of the object to be advised + a non-null string array of advisor candidate names + + + + Determine, whether the specified aspect object is eligible. + The default implementation accepts all except for advisors that are + part of the internal infrastructure. + + the name of the candidate advisor + the type of the object to be advised + the name of the object to be advised + + + + The object factory to lookup advisors from + + + + + The base class for AutoProxyCreator implementations that mark objects + eligible for proxying based on arbitrary criteria. + + Erich Eichinger + + + + Overridden to call . + + the type of the object + the name of the object + if remarkable to skip + + + + Override to always return . + + + Whether an object shall be proxied or not is determined by the result of . + + ingored + ignored + ignored + + Always to indicate, that the object shall be proxied. + + + + + + Decide, whether the given object is eligible for proxying. + + + Override this method to allow or reject proxying for the given object. + + the object's type + the name of the object + + whether the given object shall be proxied. + + + + An AutoProxyCreator, that identifies objects to be proxied by checking s defined on their type. + + Erich Eichinger + + + + Determines, whether the given object shall be proxied by matching against . + + the object's type + the name of the object + + + + Checks if is annotated with any of the attributes within the given list of . + + the object's type + the list of types to match agains. + whether to check base classes and intefaces for any of the given attributes. + if any of the attributes is found + + + + Checks if is annotated with the specified . + + the object's type + the type to match agains. + whether to check base classes and intefaces for the specified attribute. + if the attributes is found + + + + Indicates, whether to consider base types for filtering when checking declared attributes. Defaults to false. + + + + + The list of attribute types marking object types as eligible for auto-proxying by this AutoProxyCreator. Must not be null. + + + + + ObjectPostProcessor implementation that creates AOP proxies based on all candidate + Advisors in the current IObjectFactory. This class is completely generic; it contains + no special code to handle any particular aspects, such as pooling aspects. + + Rod Johnson + Adhari C Mahendra (.NET) + Erich Eichinger (.NET) + + + + Separator between prefix and remainder of object name + + + + + Find all possible advisor candidates to use in auto-proxying + + the type of the object to be advised + the name of the object to be advised + the list of candidate advisors + + + + Whether the given advisor is eligible for the specified target. + + the advisor name + the target object's type + the target object's name + + + + Validate configuration + + + + + Gets or sets a value indicating whether to exclude + advisors with a certain prefix. + + true if [use prefix]; otherwise, false. + + + + Set the prefix for object names that will cause them to be included for + auto-proxying by this object. This prefix should be set to avoid circular + references. Default value is the object name of this object + a dot. + + The advisor object name prefix. + + + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + A special version of an APC that explicitely cares for infrastructure (=internal) + advisors only + + Erich Eichinger + + + + Overridden to create a special version of an + that accepts only infrastructure advisor definitions + + + + + + + implementation that replaces a group of objects + with a 'true' inheritance based AOP mechanism that delegates + to the given interceptors before invoking the object itself. + + Bruno Baia + + + + Allows for custom modification of an application context's object definitions. + + +

+ If the object name matches, replaces the type by a AOP proxied type based on inheritance. +

+
+
+ + + Determines whether the object is an infrastructure type, + IAdvisor, IAdvice, IAdvisors, AbstractAutoProxyCreator or InheritanceBasedAopConfigurer. + + The object type to compare + The name of the object + + true if [is infrastructure type] [the specified obj]; otherwise, false. + + + + + Create an AOP proxy for the given object. + + Type of the object. + The name of the object. + The AOP Proxy for the object. + + + + Return if the given object name matches one of the object names specified. + + +

+ The default implementation checks for "xxx*", "*xxx" and "*xxx*" matches, + as well as direct equality. Can be overridden in subclasses. +

+
+ the object name to check + if the names match +
+ + + Set the names of the objects in IList fashioned way + that should automatically get intercepted. + + + A name can specify a prefix to match by ending with "*", e.g. "myObject,tx*" + will match the object named "myObject" and all objects whose name start with "tx". + + + + + Sets the common interceptors, a list of , + and introduction object names. + + + + If this property isn't set, there will be zero common interceptors. + This is perfectly valid, if "specific" interceptors such as + matching Advisors are all we want. + + + + The list of , + and introduction object names. + + + + + + + Is target type attributes, method attributes, method's return type attributes + and method's parameter attributes to be proxied in addition + to any interfaces declared on the proxied ? + + + + + Gets or sets a value indicating whether inherited members should be proxied. + + + if inherited members should be proxied; + otherwise, . + + + + + Gets or sets a value indicating whether interfaces members should be proxied. + + + if interfaces members should be proxied; + otherwise, . + + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + + Ordering which will apply to this class's implementation + of Ordered, used when applying multiple ObjectPostProcessors. + Default value is int.MaxValue, meaning that it's non-ordered. + + The order value. + + + + Used to obtain the current "target" of an AOP invocation + + +

+ This target will be invoked via reflection if no around advice chooses + to end the interceptor chain itself. +

+

+ If an is "static", it + will always return the same target, allowing optimizations in the AOP + framework. Dynamic target sources can support pooling, hot swapping etc. +

+

+ Application developers don't usually need to work with target sources + directly: this is an AOP framework interface. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Returns the target object. + + The target object. + + If unable to obtain the target object. + + + + + Releases the target object. + + The target object to release. + + + + The of the target object. + + + + + Is the target source static? + + + if the target source is static. + + + + + AutoProxyCreator that identifies objects to proxy via a list of names. + + + + Auto proxy creator that identifies objects to proxy via a list of names. + Checks for direct, "xxx*", "*xxx" and "*xxx*" matches. + + In case of a IFactoryObject, only the objects created by the + FactoryBean will get proxied. If you intend to proxy a IFactoryObject instance itself + specify the object name of the IFactoryObject including + the factory-object prefix "&" e.g. "&MyFactoryObject". + + + + Juergen Hoeller + Adhari C Mahendra (.NET) + Erich Eichinger + + + + Initializes a new instance of . + + + + + Identify as object to proxy if the object name is in the configured list of names. + + + + + Return if the given object name matches the mapped name. + + +

+ The default implementation checks for "xxx*", "*xxx" and "*xxx*" matches, + as well as direct equality. Can be overridden in subclasses. +

+
+ the object name to check + the name in the configured list of names + if the names match +
+ + + Convenience method that may be used by derived classes. Iterates over the list of to match against. + + the object's type. Must not be null. + the name of the object Must not be null. + the list of patterns, that shall be matched against. Must not be null. + + If is null, will always return true, otherwise + if matches any of the patterns specified in . + + + + + Set the names of the objects in IList fashioned way that should automatically + get wrapped with proxies. + A name can specify a prefix to match by ending with "*", e.g. "myObject,tx*" + will match the object named "myObject" and all objects whose name start with "tx". + + + + + This AutoProxyCreator only proxies objects matching the specified . + + Erich Eichinger + + + + Determines, whether the given object shall be proxied. + + + + + Set the pointcut used to filter objects that should automatically get wrapped with proxies. + + + + + AutoProxyCreator, that identifies objects to proxy by matching their against a list of patterns. + + Erich Eichinger + + + + Decide, whether the given object is eligible for proxying. + + + Override this method to allow or reject proxying for the given object. + + the object's type + the name of the object + + whether the given object shall be proxied. + + + + The list of patterns to match against. For pattern syntax, see + + + + + A reusable base implementation of , providing + some useful default implementations + + Erich Eichinger + + + + Factory interface for the creation of AOP proxies based on + configuration + objects. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates an for the + supplied configuration. + + The AOP configuration. + An . + + If the supplied configuration is + invalid. + + + + + Creates an for the + supplied configuration. + + The AOP configuration. + An . + + If the supplied configuration is + invalid. + + + + + + Actually creates the proxy instance based on the supplied . + + the proxy instance described by . Must not be null + + + + If possible, checks for advisor duplicates on the supplied and + eliminates them. + + + + + Checks, if the given holds a proxy generated by this factory. + + + + + + Base class for AOP method builders that contains common functionalities. + + Aleksandar Seovic + Bruno Baia + + + + The implementation to use. + + + + + The dictionary to cache the list of target + s. + + + + + The dictionary to cache the list of target + s defined on the proxy. + + + + + The local variable to store the list of method interceptors. + + + + + The local variable to store the target type being proxied. + + + + + The local variable to store method arguments. + + + + + The local variable to store the return value. + + + + + The local variable to store the closed generic method + when the target method is generic. + + + + + The local variable to store the closed generic method + when the target method defined on the proxy is generic. + + + + + The field to cache the target . + + + + + The field to cache the target + defined on the proxy. + + + + + Indicates if the method returns a value. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + if the interface is to be + implemented explicitly; otherwise . + + + The dictionary to cache the list of target + s. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + if the interface is to be + implemented explicitly; otherwise . + + + The dictionary to cache the list of target + s. + + + The dictionary to cache the list of target + s defined on the proxy. + + + + + Generates the proxy method. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Generates unique method id for the cache field. + + The target method. + An unique method name. + + + + Create static field that will cache target method. + + The IL generator to use. + The target method. + + + + Create static field that will cache target method when defined on the proxy. + + The IL generator to use. + The target method. + + + + Create a closed generic method for the current call + if target method is a generic definition. + + The IL generator to use. + The target method. + + The field that contains the method generic definition + + + The local variable to store the closed generic method. + + + + + Generates the IL instructions that pushes + the target type on stack. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the current + instance on stack. + + The IL generator to use. + + + + Pushes the target to stack. + + The IL generator to use. + The method to proxy. + + + + Pushes the target defined on the proxy to stack. + + The IL generator to use. + The method to proxy. + + + + Creates local variable declarations. + + The IL generator to use. + The method to proxy. + + + + Initializes local variables + + The IL generator to use. + The method to proxy. + + + + Generates method logic. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Calls method using Invoke + + The IL generator to use. + The method to proxy. + + + + Setup proxied method arguments. + + The IL generator to use. + The method to proxy. + The method's parameters. + + + + Calls proxied method directly. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Ends method by returning return value if appropriate. + + The IL generator to use. + The method to proxy. + + + + Emits MSIL instructions to load a value of the specified + onto the evaluation stack indirectly. + + The IL generator to use. + The type of the value. + + + + Emit MSIL instructions to store a value of the specified + at a supplied address. + + The IL generator to use. + The type of the value. + + + + Emits MSIL instructions to convert the boxed representation + of the supplied to its unboxed form. + + The IL generator to use. + The type specified in the instruction. + + + + Base class for proxy builders that can be used + to create an AOP proxy for any object. + + Bruno Baia + + + + Describes the operations that generates IL instructions + used to build the Aop proxy type. + + Bruno Baia + + + + Generates the IL instructions that pushes + the current + instance on stack. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the current + instance on stack. + + The IL generator to use. + + + + Calculates and returns the list of attributes that apply to the + specified type. + + + Removes from the list. + + The type to find attributes for. + + A list of custom attributes that should be applied to type. + + + + + Represents the AOP configuration data built-in with the proxy. + + Bruno Baia + + + + Configuration data for an AOP proxy factory. + + +

+ This configuration includes the + s, + s, and (any) proxied interfaces. +

+

+ Any AOP proxy obtained from Spring.NET can be cast to this interface to + allow the manipulation of said proxy's AOP advice. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + +
+ + + Adds the supplied to the end (or tail) + of the advice (interceptor) chain. + + +

+ Please be aware that Spring.NET's AOP implementation only supports + method advice (as encapsulated by the + interface). +

+
+ + The to be added. + + + +
+ + + Adds the supplied to the supplied + in the advice (interceptor) chain. + + +

+ Please be aware that Spring.NET's AOP implementation only supports + method advice (as encapsulated by the + interface). +

+
+ + The zero (0) indexed position (from the head) at which the + supplied is to be inserted into the + advice (interceptor) chain. + + + The to be added. + + + +
+ + + Is the supplied (interface) + proxied? + + + The interface to test. + + + if the supplied + (interface) is proxied; + if not or the supplied + is . + + + + + Adds the advisors from the supplied + to the list of . + + + The to add advisors from. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The index in the + list at which the supplied + is to be inserted. + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The index in the + list at which the supplied + is to be inserted. + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Return the index (0 based) of the supplied + in the interceptor + (advice) chain for this proxy. + + +

+ The return value of this method can be used to index into + the + list. +

+
+ + The to search for. + + + The zero (0) based index of this advisor, or -1 if the + supplied is not an advisor for this + proxy. + +
+ + + Return the index (0 based) of the supplied + in the introductions + for this proxy. + + +

+ The return value of this method can be used to index into + the + list. +

+
+ + The to search for. + + + The zero (0) based index of this advisor, or -1 if the + supplied is not an introduction advisor + for this proxy. + +
+ + + Removes the supplied the list of advisors + for this proxy. + + The advisor to remove. + + if advisor was found in the list of + for this + proxy and was successfully removed; if not + or if the supplied is . + + + If this proxy configuration is frozen and the + cannot be removed. + + + + + Removes the at the supplied + in the + list + from the list of + for this proxy. + + + The index of the to remove. + + + If this proxy configuration is frozen and the + at the supplied + cannot be removed; or if the supplied is out of + range. + + + + + Removes the supplied from the list + of . + + + The to remove. + + + if the supplied was + found in the list of + and successfully removed. + + + If this proxy configuration is frozen and the + cannot be removed. + + + + + Removes the supplied from the list + of . + + + The to remove. + + + if the supplied was + found in the list of + and successfully removed. + + + If this proxy configuration is frozen and the + cannot be removed. + + + + + Removes the at the supplied + in the list of + for this proxy. + + The index of the advisor to remove. + + + If this proxy configuration is frozen and the + at the supplied + cannot be removed; or if the supplied + is out of range. + + + + + Replaces the that + exists at the supplied in the list of + + with the supplied . + + + The index of the + in the list of + + that is to be replaced. + + + The new (replacement) . + + + If the supplied is out of range. + + + + + Replaces the with the + . + + + The original (old) advisor to be replaced. + + + The new advisor to replace the with. + + + if the was + replaced; if the was not found in the + advisors collection, this method returns + and (effectively) does nothing. + + + If this proxy configuration is frozen and the + cannot be replaced. + + + + + + As will normally be passed + straight through to the advised target, this method returns the + equivalent for the AOP + proxy itself. + + + A description of the proxy configuration. + + + + + Should proxies obtained from this configuration expose + the AOP proxy to the + class? + + +

+ This is useful if an advised object needs to call another advised + method on itself. (If it uses the this reference (Me + in Visual Basic.NET), the invocation will not be advised). +

+
+
+ + + Gets the + + implementation that will be used to get the interceptor + chains for the advised + . + + + The + implementation that will be used to get the interceptor + chains for the advised + . + + + + + Is the target to be proxied in addition + to any interfaces declared on the proxied ? + + + + + Is target type attributes, method attributes, method's return type attributes + and method's parameter attributes to be proxied in addition + to any interfaces declared on the proxied ? + + + + + Returns the collection of + instances that have been applied to this proxy. + + +

+ Will never return , but may return an + empty array (in the case where no + instances have been applied to + this proxy). +

+
+ + The collection of + instances that have been applied to this proxy. + +
+ + + Returns the collection of + instances that have been applied to this proxy. + + +

+ Will never return , but may return an + empty array (in the case where no + instances have been + applied to this proxy). +

+
+ + The collection of + instances that have been applied to this proxy. + +
+ + + Returns the collection of interface s + to be (or that are being) proxied by this proxy. + + + The collection of interface s + to be (or that are being) proxied by this proxy. + + + + + Returns the mapping of the proxied interface + s to their delegates. + + + The mapping of the proxied interface + s to their delegates. + + + + + Is this configuration frozen? + + +

+ When a config is frozen, no advice changes can be made. This is + useful for optimization, and useful when we don't want callers + to be able to manipulate configuration after casting to + . +

+
+
+ + + Returns the used by this + object. + + + The used by this + object. + + + + + Returns a boolean specifying if this + instance can be serialized. + + + true if this instance can be serialized, false otherwise. + + + + + Should we use dynamic reflection for method invocation ? + + + + + Optimization fields + + + + + IAdvised delegate + + + + + Array of introduction delegates + + + + + Target source + + + + + Type of target object. + + + + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + The proxy configuration. + + + + Creates a new instance of the + class. + + The proxy configuration. + The proxy. + + + + Deserialization constructor. + + Serialization data. + Serialization context. + + + + Serializes this instance. + + Serialization data. + Serialization context. + + + + Initialization method. + + The proxy configuration. + + The current implementation. + + + + + Invokes intercepted methods using reflection + + proxy object + target object to invoke method on + target type + taget method to invoke + The method to invoke on proxy. + method arguments + interceptor chain + value returned by invocation chain + + + + Returns a list of method interceptors + + target type + target method + list of inteceptors for the specified method + + + + Adds the supplied to the end (or tail) + of the advice (interceptor) chain. + + + The to be added. + + + + + + + Adds the supplied to the supplied + in the advice (interceptor) chain. + + + The zero (0) indexed position (from the head) at which the + supplied is to be inserted into the + advice (interceptor) chain. + + + The to be added. + + + + + + + Gets the target type behind the implementing object. + Ttypically a proxy configuration or an actual proxy. + + The type of the target or null if not known. + + + + implementation + that delegates method calls to the base method. + + Bruno Baia + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + The dictionary to cache the list of target + s. + + + The dictionary to cache the list of target + s defined on the proxy. + + + + + Create static field that will cache target method when defined on the proxy. + + The IL generator to use. + The target method. + + + + Calls target method directly. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Base class that each dynamic composition proxy has to extend. + + Aleksandar Seovic + Bruno Baia + + + + The central interface for Spring.NET based AOP proxies. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new proxy object. + + + + + Default constructor. + + + + + Creates a new instance of the + class. + + The proxy configuration. + + + + Deserialization constructor. + + Serialization data. + Serialization context. + + + + Populates a with the data needed to serialize the target object. + + + + + Returns this proxy instance + + + + + + Delegate to target object handling of equals method. + + The object to compare with the current target object + true if the specified Object is equal to the current target object; otherwise, false + + + + Delgate to the target object generation of the hash code. + + A hash code for the target object. + + + + Returns a String the represents the target object. + + A String that represents the target object + + + + Implementation of the + interface that caches the AOP proxy instance. + + +

+ Caches against a key based on : + - the base type + - the target type + - the interfaces to proxy +

+
+ Bruno Baia + Erich Eichinger + + +
+ + + Default implementation of the + interface, + either creating a decorator-based dynamic proxy or + a composition-based dynamic proxy. + + +

+ Creates a decorator-base proxy if one the following is true : + - the "ProxyTargetType" property is set + - no interfaces have been specified +

+

+ In general, specify "ProxyTargetType" to enforce a decorator-based proxy, + or specify one or more interfaces to use a composition-based proxy. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + Bruno Baia (.NET) + Erich Eichinger (.NET) + +
+ + + Force transient assemblies to be resolvable by . + + + + + Creates an actual proxy instance based on the supplied + + + + + + + Generates the proxy type. + + + The to use + + The generated proxy class. + + + + The shared instance for this class. + + + + + Clears the type cache + + + + + Creates a new instance + + + + + Generates the proxy type and caches the + instance against the base type and the interfaces to proxy. + + + The to use + + The generated or cached proxy class. + + + + Returns the number of proxy types in the cache + + + + + Uniquely identifies a proxytype in the cache + + + + + Builds an AOP proxy type using composition. + + Aleksandar Seovic + Bruno Baia + + + + Creates a new instance of the + class. + + The proxy configuration. + + + + Creates the proxy type. + + The generated proxy type. + + + + Generates the IL instructions that pushes + the current + instance on stack. + + The IL generator to use. + + + + Implements serialization constructor. + + Type builder to use. + + + + Implements constructors for the proxy class. + + +

+ This implementation calls the base constructor. +

+
+ + The builder to use. + +
+ + + Determines if the specified + is one of those generated by this builder. + + The type to check. + + if the type is a composition-based proxy; + otherwise . + + + + + Builds an AOP proxy type using the decorator pattern. + + Bruno Baia + + + + AdvisedProxy instance calls should be delegated to. + + + + + Creates a new instance of the + class. + + The proxy configuration. + + + + Creates the proxy type. + + The generated proxy class. + + + + Generates the IL instructions that pushes + the current + instance on stack. + + The IL generator to use. + + + + Declares field that holds the + instance used by the proxy. + + + The builder to use for code generation. + + + + + Implements serialization method. + + + + + + Implements serialization constructor. + + Type builder to use. + + + + Implements constructors for the proxy class. + + +

+ This implementation creates a new instance + of the class. +

+
+ + The builder to use. + +
+ + + Implements interface. + + The type builder to use. + + + + Determines if the specified + is one of those generated by this builder. + + The type to check. + + if the type is a decorator-based proxy; + otherwise . + + + + + implementation that delegates + method calls to an instance. + + Bruno Baia + + + + The implementation to use. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Builds an AOP proxy type using inheritance. + + Bruno Baia + + + + AdvisedProxy instance calls should be delegated to. + + + + + Creates a new instance of the + class. + + The proxy configuration. + + + + Creates the proxy type. + + The generated proxy class. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the current + instance on stack. + + The IL generator to use. + + + + Declares field that holds the + instance used by the proxy. + + + The builder to use for code generation. + + + + + Implements serialization method. + + + + + + Implements serialization constructor. + + Type builder to use. + + + + Defines the types of the parameters for the specified constructor. + + The constructor to use. + The types for constructor's parameters. + + + + Generates the proxy constructor. + + +

+ This implementation creates instance of the AdvisedProxy object. +

+
+ The constructor builder to use. + The IL generator to use. + The constructor to delegate the creation to. +
+ + + Implements interface. + + The type builder to use. + + + + Determines if the specified + is one of those generated by this builder. + + The type to check. + + if the type is a inheritance-based proxy; + otherwise . + + + + + Gets or sets a value indicating whether inherited members should be proxied. + + + if inherited members should be proxied; + otherwise, . + + + + + implementation + that delegates method calls to introduction object. + + Aleksandar Seovic + Bruno Baia + + + + The index of the introduction to delegate call to. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + + + index of the introduction to delegate call to + + + + Generates the IL instructions that pushes + the introduction type on stack. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the introduction instance on stack. + + The IL generator to use. + + + + Calls proxied method directly. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + implementation + that delegates method calls to target object. + + Aleksandar Seovic + Bruno Baia + + + + The local variable to store the target instance. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + if the interface is to be + implemented explicitly; otherwise . + + + The dictionary to cache the list of target + s. + + + + + Creates local variable declarations. + + The IL generator to use. + The method to proxy. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Generates method logic. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Calls proxied method directly. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Convenience base class for + implementations. + + +

+ Subclasses can override the + + method to change this behavior, so this is a useful/ base class for + implementations. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + Rick Evans (.NET) + Bruno Baia (.NET) +
+ + + Description of an invocation to a method, given to an interceptor + upon method-call. + + +

+ A method invocation is a joinpoint and can be intercepted by a method + interceptor. +

+
+ +
+ + + Represents an invocation in the program. + + +

+ An invocation is a joinpoint and can be intercepted by an interceptor. + Typical examples would be a constructor invocation and a method call. +

+
+
+ + + Represents a generic runtime joinpoint (in the AOP terminology). + + +

+ A runtime joinpoint is an event that occurs on a static + joinpoint (i.e. a location in a program). For instance, an + invocation is the runtime joinpoint on a method (static joinpoint). + The static part of a given joinpoint can be generically retrieved + using the + property. +

+

+ In the context of an interception framework, a runtime joinpoint + is then the reification of an access to an accessible object (a + method, a constructor, a field), i.e. the static part of the + joinpoint. It is passed to the interceptors that are installed on + the static joinpoint. +

+
+ +
+ + + Proceeds to the next interceptor in the chain. + + +

+ The implementation and semantics of this method depend on the + actual joinpoint type. Consult the derived interfaces of this + interface for specifics. +

+
+ + Consult the derived interfaces of this interface for specifics. + + + If any of the interceptors at the joinpoint throws an exception. + +
+ + + Gets the static part of this joinpoint. + + +

+ The static part is an accessible object on which a chain of + interceptors are installed. +

+
+ + The static part of this joinpoint. + +
+ + + Gets the object that holds the current joinpoint's static part. + + +

+ For instance, the target object for a method invocation. +

+
+ + The object that holds the current joinpoint's static part. + +
+ + + Gets the arguments to an invocation. + + +

+ It is of course possible to change element values within this array + to change the arguments to an intercepted invocation. +

+
+ + The arguments to an invocation. + +
+ + + Gets the method invocation that is to be invoked. + + +

+ This property is a friendly implementation of the + property. + It should be used in preference to the + property + because it provides immediate access to the underlying method + without the need to resort to a cast. +

+
+ + The method invocation that is to be invoked. + +
+ + + Gets the proxy object for the invocation. + + + The proxy object for this method invocation. + + + + + Gets the target object for the invocation. + + + The target object for this method invocation. + + + + + Gets the type of the target object. + + + The type of the target object. + + + + + The arguments (if any = may be ) to the method + that is to be invoked. + + + + + The target object that the method is to be invoked on. + + + + + The AOP proxy for the target object. + + + + + The method invocation that is to be invoked. + + + + + The list of and + + that need dynamic checks. + + + + + The declaring type of the method that is to be invoked. + + + + + The index from 0 of the current interceptor we're invoking. + + + + + Creates a new instance of the + class. + + +

+ This is an abstract class, and as such exposes no publicly visible + constructors. +

+

+ + The list can also contain any + s + that need evaluation at runtime. + s included in an + + must already have been found to have matched as far as was possible + statically. Passing an array might be about 10% faster, but + would complicate the code, and it would work only for static + pointcuts. + +

+
+ The AOP proxy. + The target object. + the target method. + The target method's arguments. + + The of the target object. + + The list of interceptors that are to be applied. May be + . + + + If the is . + +
+ + + Proceeds to the next interceptor in the chain. + + + The return value of the method invocation. + + + If any of the interceptors at the joinpoint throws an exception. + + + + + + Retrieves a new instance + for the next Proceed method call. + + + The current instance. + + + The new instance to use. + + + + + + Performs sanity checks, whether the actual joinpoint may be invoked + + + By default checks that the underlying target is not null and the called method is implemented + by the target's type. + + if is null. + if the 's type does not implement . + + + + Invokes the joinpoint. + + +

+ Subclasses can override this to use custom invocation. +

+
+ + The return value of the invocation of the joinpoint. + + + If invoking the joinpoint resulted in an exception. + + +
+ + + A that represents the current + invocation. + + +

+ + Does not invoke on the + target + object, as that too may be proxied. + +

+
+ + A that represents the current invocation. + +
+ + + Gets the method invocation that is to be invoked. + + +

+ May or may not correspond with a method invoked on an underlying + implementation of that interface. +

+
+ +
+ + + Gets the static part of this joinpoint. + + + The proxied member's information. + + + + + + Gets the proxy that this interception was made through. + + + The proxy that this interception was made through. + + + + + Gets the target object for the invocation. + + + The target object for this method invocation. + + + + + Gets the type of the target object. + + + The type of the target object. + + + + + Gets and sets the arguments (if any - may be ) + to the method that is to be invoked. + + + The arguments (if any - may be ) to the + method that is to be invoked. + + + + + + The list of method interceptors. + + +

+ May be . +

+
+
+ + + Gets the target object. + + + + + Superclass for AOP proxy configuration managers. + + +

+ Instances of this class are not themselves AOP proxies, but + subclasses of this class are normally factories from which AOP proxy + instances are obtained directly. +

+

+ This class frees subclasses of the housekeeping of + and + instances, but doesn't actually + implement proxy creation methods, the functionality for which + is provided by subclasses. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + +
+ + The list of advice. + +

+ If an is added, it + will be wrapped in an advice before being added to this list. +

+
+
+ + + Array updated on changes to the advisors list, which is easier to + manipulate internally + + + + + List of introductions. + + + + + Interface map specifying which object should interface methods be + delegated to. + + +

+ If entry value is methods should be delegated + to the target object. +

+
+
+ + + The for this instance. + + + + + Set to when the first AOP proxy has been + created, meaning that we must track advice changes via the + OnAdviceChange() callback. + + + + + The list of event listeners. + + + + + The advisor chain factory. + + + + + If no explicit interfaces are specified, interfaces will be automatically determined + from the target type + + + + + Creates a new instance of the + class using the + default advisor chain factory. + + + + + Creates a new instance of the + class. + + The interfaces that are to be proxied. + + If this + + + + + Creates a new instance of the + class that proxys all of the interfaces exposed by the supplied + . + + The object to proxy. + + If the is . + + + + + Creates a new instance of the + class that proxys all of the interfaces exposed by the supplied + 's target. + + The providing access to the object to proxy. + + If the is . + + + + + Set interfaces to be proxied, bypassing locking and + + + + + Is the supplied (interface) + proxied? + + + The interface to test. + + + if the supplied + (interface) is proxied; + if not or the supplied + is . + + + + + + Adds the supplied to the end (or tail) + of the advice (interceptor) chain. + + + The to be added. + + + + + + + Adds the supplied to the supplied + in the advice (interceptor) chain. + + + The zero (0) indexed position (from the head) at which the + supplied is to be inserted into the + advice (interceptor) chain. + + + The to be added. + + + If the supplied is ; + or is not an + reference; or if the supplied is a + . + + + + + + + Return the index (0 based) of the supplied + in the interceptor + (advice) chain for this proxy. + + + The to search for. + + + The zero (0) based index of this advisor, or -1 if the + supplied is not an advisor for this + proxy. + + + + + Return the index (0 based) of the supplied + in the introductions + for this proxy. + + + The to search for. + + + The zero (0) based index of this advisor, or -1 if the + supplied is not an introduction advisor + for this proxy. + + + + + Removes the supplied the list of advisors + for this proxy. + + The advisor to remove. + + if advisor was found in the list of + for this + proxy and was successfully removed; if not + or if the supplied is . + + + If this proxy configuration is frozen and the + cannot be removed. + + + + + Removes the at the supplied + in the + list + from the list of + for this proxy. + + + The index of the to remove. + + + If this proxy configuration is frozen and the + at the supplied + cannot be removed; or if the supplied is out of + range. + + + + + Removes the supplied from the list + of . + + + The to remove. + + + if the supplied was + found in the list of + and successfully removed. + + + If this proxy configuration is frozen and the + cannot be removed. + + + + + Removes the supplied from the list + of . + + + The to remove. + + + if the supplied was + found in the list of + and successfully removed. + + + If this proxy configuration is frozen and the + cannot be removed. + + + + + Removes the at the supplied + in the list of + for this proxy. + + The index of the advisor to remove. + + + If this proxy configuration is frozen and the + at the supplied + cannot be removed; or if the supplied + is out of range. + + + + + Adds the supplied to the list + of . + + + The index in the + list at which the supplied + is to be inserted. If -1, appends to the end of the list. + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the advisors from the supplied + to the list of . + + + The to add advisors from. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The index in the + list at which the supplied + is to be inserted. + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Adds the supplied to the list + of . + + + The to add. + + + If this proxy configuration is frozen and the + cannot be added. + + + + + Replaces the that + exists at the supplied in the list of + + with the supplied . + + + The index of the + in the list of + + that is to be replaced. + + + The new (replacement) . + + + If the supplied is out of range. + + + + + Replaces the with the + . + + + The original (old) advisor to be replaced. + + + The new advisor to replace the with. + + + if the was + replaced; if the was not found in the + advisors collection (or the is + , this method returns + and (effectively) does nothing. + + + If this proxy configuration is frozen and the + cannot be replaced. + + + + + + As will normally be passed straight through + to the advised target, this method returns the + equivalent for the AOP proxy itself. + + To override this format, override + + A description of the proxy configuration. + + + + + Returns textual information about this configuration object + + + + + + Registers the supplied as a listener for + notifications. + + + The to + register. + + + + + Removes the supplied . + + + The to + be removed. + + + + + Adds a new interface to the list of interfaces that are proxied by this proxy. + + + The interface to be proxied by this proxy. + + + If this proxy configuration is frozen + (); + + + If the supplied is . + + + + + Adds a new interface to the list of interfaces that are proxied by this proxy. + + + The interface to be proxied by this proxy. + + + Access is not synchronized. + + + + + Removes the supplied (proxied) . + + +

+ Does nothing if the supplied (proxied) + isn't proxied. +

+
+ The interface to remove. + + if the interface was removed. +
+ + + Return the index (0 based) of the supplied + in the interceptor + (advice) chain for this proxy. + + +

+ The return value of this method can be used to index into + the + list. +

+
+ + The to search for. + + + The zero (0) based index of this interceptor, or -1 if the + supplied is not an advice for this + proxy. + +
+ + + Return the index (0 based) of the supplied + in the interceptor + (advice) chain for this proxy. + + +

Acces is not synchronized

+

+ The return value of this method can be used to index into + the + list. +

+
+ + The to search for. + + + The zero (0) based index of this interceptor, or -1 if the + supplied is not an advice for this + proxy. + +
+ + + Return the index (0 based) of the supplied + in the interceptor + (advice) chain for this proxy. + + + The to search for. + + + The zero (0) based index of this advisor, or -1 if the + supplied is not an advisor for this + proxy. + + + Access is not synchronized. + + + + + Return the index (0 based) of the supplied + in the introductions + for this proxy. + + + The to search for. + + + The zero (0) based index of this advisor, or -1 if the + supplied is not an introduction advisor + for this proxy. + + + Access is not synchronized + + + + + Removes the at the supplied + in the + list + from the list of + for this proxy. + + + The index of the to remove. + + + If this proxy configuration is frozen and the + at the supplied + cannot be removed; or if the supplied is out of + range. + + + Does not synchronize access. + + + + + Is the supplied included in any + advisor? + + + The to check for the + inclusion of. + + + if the supplied + could be run in an invocation (this does not imply that said + will be run). + + + + + Returns a count of all of the + type-compatible with the supplied . + + + The of the + to check. + + + A count of all of the + type-compatible with the supplied . + + + + + Throws an if + this instances proxy configuration data is frozen. + + + The message that will be passed through to the constructor of any + thrown . + + + If the configuration for this proxy is frozen. + + + + + + Bring the advisors array up to date with the list. + + + + + Callback method that is invoked when the list of proxied interfaces + has changed. + + +

+ An example of such a change would be when a new introduction is + added. Resetting + to + will cause a new proxy + to be generated on the next call to get a proxy. +

+
+
+ + + Callback method that is invoked when the interceptor list has changed. + + + + + Activates this instance. + + + + + Creates an AOP proxy using this instance's configuration data. + + +

+ Subclasses must not create a proxy by any other means (at least + without having a well thought out and cogent reason for doing so). + This is because the implementation of this method performs some + required housekeeping logic prior to creating an AOP proxy. +

+
+ +
+ + + Calculates the number of not delegating to one of the . + + + + + Copies the configuration from the supplied other + into this instance. + + +

+ Useful when this instance has been created using the no-argument + constructor, and needs to get all of its confiuration data from + another (most + usually to have an independant copy of said configuration data). +

+
+ + The instance + containing the configiration data that is to be copied into this + instance. + +
+ + + Copies the configuration from the supplied other + into this instance. + + +

+ Useful when this instance has been created using the no-argument + constructor, and needs to get all of its confiuration data from + another (most + usually to have an independant copy of said configuration data). +

+
+ + The instance + containing the configiration data that is to be copied into this + instance. + + the new target source + the advisors for the chain + the introductions for the chain +
+ + + A that represents the current + configuration. + + + A that represents the current + configuration. + + + + + Helper method that adds the names of all of the proxied interfaces + to the buffer of the supplied . + + + The to append the proxied interface + names to. + + + + + Helper method that adds advisor's + to the buffer of the supplied . + + + The to append the advisor details to. + + + + + Gets all of the interfaces implemented by the + of the supplied + . + + + The object to get the interfaces of. + + + All of the interfaces implemented by the + of the supplied + . + + + If the supplied is . + + + + + Gets and sets the + + implementation that will be used to get the interceptor + chains for the advised + . + + + The + implementation that will be used to get the interceptor + chains for the advised + . + + + + + Returns the current used + by this object. + + + The used by this + object. + + + + + + Returns a boolean specifying if this + instance can be serialized. + + + true if this instance can be serialized, false otherwise. + + + + + Returns the collection of interface s + to be (or that are being) proxied by this proxy. + + + The collection of interface s + to be (or that are being) proxied by this proxy. + + + + + + Returns the mapping of the proxied interface + s to their delegates. + + + The mapping of the proxied interface + s to their delegates. + + + + + + Returns the collection of + instances that have been applied to this proxy. + + + The collection of + instances that have been applied to this proxy. + + + + + + Returns the collection of + instances that have been applied to this proxy. + + +

+ Will never return , but may return an + empty array (in the case where no + instances have been + applied to this proxy). +

+
+ + The collection of + instances that have been applied to this proxy. + + +
+ + + Gets the target type behind the implementing object. + Ttypically a proxy configuration or an actual proxy. + + The type of the target or null if not known. + + + + If no explicit interfaces are specified, interfaces will be automatically determined + from the target type on proxy creation. Defaults to true + + + + + Sets the target object that is to be advised. + + +

+ This is a convenience write-only property that allows client code + to set the target object... the target object will be implicitly + wrapped within a new + instance. +

+
+
+ + + Called by subclasses to get a value indicating whether any AOP proxies have been created yet. + + true if this AOp proxies have been created; otherwise, false. + + + + Specifies the of proxies that are to be + created for this instance of proxy config. + + +

+ If this property value is it simply means that + no proxies have been created yet. Only when the first proxy is + created will this property value be set by the AOP framework. +

+

+ Users will be able to add interceptors dynamically without proxy + regeneration, but if they add introductions the proxy + will have to be regenerated. +

+
+ + The of proxies that are to be + created for this instance of proxy config; if + no proxies have been created yet. + +
+ + + Caches proxy constructor for performance reasons. + + + + + Utility methods for use by + implementations. + + +

+ Not intended to be used directly by applications. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Gets the list of + interceptors and dynamic interception + advice that may apply to the supplied + invocation. + + The proxy configuration. + The object proxy. + + The method to evaluate interceptors for. + + + The of the target object. + + + A of + (if there's + a dynamic method matcher that needs evaluation at runtime). + + + + + Creates a new instance of the + + class. + + +

+ This is a utility class, and as such has no publicly visible + constructors. +

+
+
+ + + Thrown in response to the misconfiguration of an AOP proxy. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class with + the specified message. + + + A message about the exception. + + + + + Creates a new instance of the + class with + the specified message and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + This class contains various methods used to + obtain information about the current AOP invocation. + + +

+ The + property is + usable if the AOP framework is configured to expose the current proxy + (not the default)... it returns the AOP proxy in use. Target objects or + advice can use this to make advised calls. They can also use it to find + advice configuration. +

+

+ To expose the current proxy, set the + property on the controlling proxy to . + The default value for the property + is , for performance reasons. +

+ + The AOP framework does not expose proxies by default, as there is a + performance cost in doing so. + +

+ The functionality in this class might be used by a target object that + needed access to resources on the invocation. However, this approach + should not be used when there is a reasonable alternative, as it makes + application code dependent on usage under AOP and the Spring.NET AOP + framework. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Sets the current proxy by pushing it to the proxy stack. + + +

+ This method is for internal use only, and should never be called by + client code. +

+
+ + The proxy to put on top of the proxy stack. + +
+ + + Removes the current proxy from the proxy stack, making the previous + proxy (if any) the current proxy. + + +

+ This method is for internal use only, and should never be called by + client code. +

+
+ + If the proxy stack is empty. + +
+ + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + The AOP proxy stack associated with this thread. + + + + + Indicates if the current call is executed under control of an AOP proxy. + + +

+ Will be unless the + property + on the controlling proxy has been set to . +

+

+ The default value for the + property + is , for performance reasons. +

+
+
+ + + Gets the current AOP proxy. + + + If the proxy stack is empty. + + + + + Utility methods used by the AOP framework. + + +

+ Not intended to be used directly by applications. +

+
+ Rod Johnson + Juergen Hoeller + Aleksandar Seovic (.NET) +
+ + + Is the supplied an AOP proxy? + + + Return whether the given type is either a composition-based or a decorator-based proxy type. + + The type to be checked. + if the supplied is an AOP proxy type. + + + + Is the supplied an AOP proxy? + + + Return whether the given object is either + a composition-based proxy or a decorator-based proxy. + + The instance to be checked. + + if the supplied is + an AOP proxy. + + + + + Is the supplied a composition-based AOP proxy? + + The instance to be checked. + + if the supplied is + an composition-based AOP proxy. + + + + + Is the supplied a composition based AOP proxy type? + + + Return whether the given type is a composition-based proxy type. + + The type to be checked. + if the supplied is a composition based AOP proxy type. + + + + Is the supplied a decorator-based AOP proxy? + + The instance to be checked. + + if the supplied is + an decorator-based AOP proxy. + + + + + Is the supplied a composition based AOP proxy type? + + + Return whether the given type is a composition-based proxy type. + + The type to be checked. + if the supplied is a composition based AOP proxy type. + + + + Gets all of the interfaces that the of the + supplied implements. + + +

+ This includes interfaces implemented by any superclasses. +

+
+ + The object to analyse for interfaces. + + + All of the interfaces that the of the + supplied implements; or an empty + array if the supplied is + . + +
+ + + Gets all of the interfaces that the + supplied implements. + + + This includes interfaces implemented by any superclasses. + + + The type to analyse for interfaces. + + + All of the interfaces that the supplied implements. + + + + + Can the supplied apply at all on the + supplied ? + + +

+ This is an important test as it can be used to optimize out a + pointcut for a class. +

+

+ Invoking this method with a that is + an interface type will always yield a + return value. +

+
+ The pointcut being tested. + The class being tested. + + The interfaces being proxied. If , all + methods on a class may be proxied. + + + if the pointcut can apply on any method. + +
+ + + Can the supplied apply at all on the + supplied ? + + +

+ This is an important test as it can be used to optimize out a + pointcut for a class. +

+

+ Invoking this method with a that is + an interface type will always yield a + return value. +

+
+ The pointcut being tested. + The class being tested. + + The interfaces being proxied. If , all + methods on a class may be proxied. + + whether or not the advisor chain for the target object includes any introductions. + + if the pointcut can apply on any method. + +
+ + + Can the supplied apply at all on the + supplied ? + + +

+ This is an important test as it can be used to optimize out an + advisor for a class. +

+
+ The advisor to check. + The class being tested. + + The interfaces being proxied. If , all + methods on a class may be proxied. + + + if the advisor can apply on any method. + +
+ + + Can the supplied apply at all on the + supplied ? + + +

+ This is an important test as it can be used to optimize out an + advisor for a class. +

+
+ The advisor to check. + The class being tested. + + The interfaces being proxied. If , all + methods on a class may be proxied. + + whether or not the advisor chain for the target object includes any introductions. + + if the advisor can apply on any method. + +
+ + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly + visible constructors. +

+
+
+ + + Gets the type of the target. + + The candidate. + + + + + Invokes a target method using dynamic reflection. + + + Aleksandar Seovic + Bruno Baia + + + + The method invocation that is to be invoked on the proxy. + + + + + Creates a new instance of the + class. + + The AOP proxy. + The target object. + The target method proxied. + The method to invoke on proxy. + The target method's arguments. + + The of the target object. + + The list of interceptors that are to be applied. May be + . + + + If any of the or + parameters is . + + + + + Invokes the joinpoint using dynamic reflection. + + +

+ Subclasses can override this to use custom invocation. +

+
+ + The return value of the invocation of the joinpoint. + + + If invoking the joinpoint resulted in an exception. + + +
+ + + Creates a new instance + from the specified and + increments the interceptor index. + + + The current instance. + + + The new instance to use. + + + + + implementation + that caches advisor chains on a per-advised-method basis. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Factory interface for advisor chains. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Callback interface for + listeners. + + +

+ Allows + implementations to be notified of notable lifecycle events relating + to the creation of a proxy, and changes to the configuration data of a + proxy. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Invoked when the first proxy is created. + + + The relevant source. + + + + + Invoked when advice is changed after a proxy is created. + + + The relevant source. + + + + + Invoked when interfaces are changed after a proxy is created. + + + The relevant source. + + + + + Gets the list of and + + instances for the supplied . + + The proxy configuration object. + The object proxy. + + The method for which the interceptors are to be evaluated. + + + The of the target object. + + + The list of and + + instances for the supplied . + + + + + Gets the list of and + + instances for the supplied . + + The proxy configuration object. + The object proxy. + + The method for which the interceptors are to be evaluated. + + + The of the target object. + + + The list of and + + instances for the supplied . + + + + + Invoked when the first proxy is created. + + + The relevant source. + + + + + Invoked when advice is changed after a proxy is created. + + + The relevant source. + + + + + Invoked when interfaces are changed after a proxy is created. + + + The relevant source. + + + + Internal framework class. + This class is required because if we put an interceptor that implements IInterceptionAdvice + in the interceptor list passed to MethodInvocation, it may be mistaken for an + advice that requires dynamic method matching. + + Rod Johnson + Aleksandar Seovic (.Net) + + + + Provides access to the target object of an AOP proxy. + + +

+ To be implemented by introduction aspects in order to obtain access to + the target object. +

+
+ Aleksandar Seovic +
+ + + Sets the target object. + + + + + Factory for AOP proxies for programmatic use, rather than via a + Spring.NET IoC container. + + +

+ This class provides a simple way of obtaining and configuring AOP + proxies in code. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class that proxys all of the interfaces exposed by the supplied + . + + The object to proxy. + + If the is . + + + + + Creates a new instance of the + class that has no target object, only interfaces. + + +

+ Interceptors must be added if this factory is to do anything useful. +

+
+ The interfaces to implement. +
+ + + Creates a new instance of the class for the + given interface and interceptor. + + Convenience method for creating a proxy for a single interceptor + , assuming that the interceptor handles all calls itself rather than delegating + to a target, like in the case of remoting proxies. + The interface that the proxy should implement. + The interceptor that the proxy should invoke. + + + + Create a new instance of the class for the specified + making the proxy implement the specified interface. + + + The interface that the proxy should implement. + The target source that the proxy should invoek. + + + + Creates a new proxy according to the settings in this factory. + + +

+ Can be called repeatedly; the effect of repeated invocations will + (of course) vary if interfaces have been added or removed. +

+
+ An AOP proxy for target object. +
+ + + Creates a new proxy for the supplied + and . + + +

+ This is a convenience method for creating a proxy for a single + interceptor. +

+
+ + The interface that the proxy must implement. + + + The interceptor that the proxy must invoke. + + + A new AOP proxy for the supplied + and . + +
+ + + implementation to + source AOP proxies from a Spring.NET IoC container (an + ). + + +

+ s and + s are identified by a list of object + names in the current container.

+

+ Global interceptors and advisors can be added at the factory level + (that is, outside the context of a + definition). The + specified interceptors and advisors are expanded in an interceptor list + (see + ) + where an 'xxx*' wildcard-style entry is included in the list, + matching the given prefix with the object names. For example, + 'global*' would match both 'globalObject1' and + 'globalObjectBar', and '*' would match all defined + interceptors. The matching interceptors get applied according to their + returned order value, if they implement the + interface. An interceptor name list + may not conclude with a global 'xxx*' pattern, as global + interceptors cannot invoke targets. +

+

+ It is possible to cast a proxy obtained from this factory to an + reference, or to obtain the + reference and + programmatically manipulate it. This won't work for existing prototype + references, which are independent... however, it will work for prototypes + subsequently obtained from the factory. Changes to interception will + work immediately on singletons (including existing references). + However, to change interfaces or the target it is necessary to obtain a + new instance from the surrounding container. This means that singleton + instances obtained from the factory do not have the same object + identity... however, they do have the same interceptors and target, and + changing any reference will change all objects. +

+
+ Rod Johnson + Juergen Hoeller + Federico Spinazzi (.NET) + Choy Rim (.NET) + Mark Pollack (.NET) + Aleksandar Seovic (.NET) + + + + + +
+ + + The instance for this class. + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + This suffix in a value in an interceptor list indicates to expand globals. + + + + + The cached instance if this proxy factory object is a singleton. + + + + + The owning object factory (which cannot be changed after this object is initialized). + + + + + The advisor adapter registry for wrapping pure advices and pointcuts according to needs + + + + + Names of interceptors and pointcut objects in the factory. + + +

+ Default is for globals expansion only. +

+
+
+ + + Names of introductions and pointcut objects in the factory. + + +

+ Default is for globals expansion only. +

+
+
+ + + The name of the target object(in the enclosing + ). + + + + + Indicates if the advisor chain has already been initialized + + + + + Indicate whether this config shall be frozen upon creation + of the first proxy instance + + + + + Creates a new instance of ProxyFactoryObject + + + + + Creates an instance of the AOP proxy to be returned by this factory + + +

+ Invoked when clients obtain objects from this factory object. The + (proxy) instance will be cached for a singleton, and created on each + call to + for a prototype. +

+
+ + A fresh AOP proxy reflecting the current state of this factory. + + +
+ + + Initialize this proxy factory - usually called after all properties are set + + + + Create the advisor (interceptor) chain. + + The advisors that are sourced from an ObjectFactory will be refreshed each time + a new prototype instance is added. Interceptors added programmatically through + the factory API are unaffected by such changes. + + + + Add all global interceptors and pointcuts. + + + + Configures introductions for this proxy. + + + + Add all global introductions. + + + Add the introduction to the introduction list. + + If specified parameter is IIntroducionAdvisor it is added directly, otherwise it is wrapped + with DefaultIntroductionAdvisor first. + + introducion to add + object name from which we obtained this object in our owning object factory + + + + Refreshes target object for prototype instances. + + + + Refresh named objects from the interceptor chain. + We need to do this every time a new prototype instance is returned, + to return distinct instances of prototype interfaces and pointcuts. + + + + Refresh named objects from the interceptor chain. + We need to do this every time a new prototype instance is returned, + to return distinct instances of prototype interfaces and pointcuts. + + + + Wraps target with SingletonTargetSource if necessary + target or target source object + target source passed or target wrapped with SingletonTargetSource + + + Wraps introduction with IIntroductionAdvisor if necessary + Wraps pointcut or interceptor with appropriate advisor + pointcut or interceptor that needs to be wrapped with advisor + Advisor + + + object to wrap + Introduction advisor + + + + Callback method that is invoked when the list of proxied interfaces + has changed. + + +

+ An example of such a change would be when a new introduction is + added. Resetting + to + will cause a new proxy + to be generated on the next call to get a proxy. +

+
+
+ + + Returns textual information about this configuration object + + + + + Check the interceptorNames list whether it contains a target name as final element. + If found, remove the final name from the list and set it as targetName. + + + + + Indicate whether this config shall be frozen upon creation + of the first proxy instance + + + + + If set true, any attempt to modify this proxy configuration will raise an exception + + + + + Specify the AdvisorAdapterRegistry to use. Default is the + + + + + Sets the names of the interfaces that are to be implemented by the proxy. + + + The names of the interfaces that are to be implemented by the proxy. + + + If the supplied value (or any of its elements) is ; + or if any of the element values is not the (assembly qualified) name of + an interface type. + + + + + Sets the name of the target object being proxied. + + +

+ Only works when the + + property is set; it is a logic error on the part of the programmer + if this value is set and the accompanying + is not also set. +

+
+ + The name of the target object being proxied. + +
+ + + Sets the list of and + object names. + + +

+ This property must always be set (configured) when using a + in an + context. +

+
+ + The list of and + object names. + + + + + +
+ + + Sets the list of introduction object names. + + +

+ Only works when the + + property is set; it is a logic error on the part of the programmer + if this value is set and the accompanying + is not supplied. +

+
+ + The list of introduction object names. . + +
+ + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + In case of initialization errors. + + + + + + + Return the of the proxy. + + + Will check the singleton instance if already created, + else fall back to the proxy interface (if a single one), + the target bean type, or the TargetSource's target class. + + Return the of object that this + creates, or + if not known in advance. + + + + Is the object managed by this factory a singleton or a prototype? + + + + + Superinterface for advisors that perform one or more AOP + introductions. + + +

+ This interface cannot be implemented directly; subinterfaces must + provide the advice type implementing the introduction. +

+

+ Introduction is the implementation of additional interfaces (not + implemented by a target) via AOP advice. +

+
+ + Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Base interface holding AOP advice and a filter determining the + applicability of the advice (such as a pointcut). + + + + This interface is not for use by Spring.NET users, but exists rather to + allow for commonality in the support for different types of advice + within the framework. + +

+ Spring.NET AOP is centered on around advice delivered via method + interception, compliant with the AOP Alliance interception API. + The interface allows support for + different types of advice, such as before and after + advice, which need not be implemented using interception. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + + + + +
+ + + Is this advice associated with a particular instance? + + +

+ An advisor that was creating a mixin would be a per instance + operation and would thus return . If the + advisor is not per instance, it is shared with all instances of the + advised class obtained from the same Spring.NET IoC container. +

+

+ Use singleton and prototype object definitions or + appropriate programmatic proxy creation to ensure that + s have the correct lifecycle model. +

+ + This method is not currently used by the framework. + +
+ + if this advice is associated with a + particular instance. + +
+ + + Return the advice part of this aspect. + + +

+ An advice may be an interceptor, a throws advice, before advice, + introduction etc. +

+
+ + The advice that should apply if the pointcut matches. + +
+ + + Can the advised interfaces be implemented by the introduction + advice? + + +

+ Invoked before adding an + . +

+
+ + If the advised interfaces cannot be implemented by the introduction + advice. + + +
+ + + Returns the filter determining which target classes this + introduction should apply to. + + +

+ This is the part of a pointcut. + Be advised that method matching doesn't make sense in the context + of introductions. +

+
+ + The filter determining which target classes this introduction + should apply to. + +
+ + + Gets the interfaces introduced by this + . + + + The interfaces introduced by this + . + + + + + Invokes a target method using standard reflection. + + Rod Johnson + Aleksandar Seovic (.NET) + Rick Evans (.NET) + Bruno Baia (.NET) + + + + The method invocation that is to be invoked on the proxy. + + + + + Creates a new instance of the + class. + + The AOP proxy. + The target object. + The target method proxied. + The method to invoke on proxy. + The target method's arguments. + + The of the target object. + + The list of interceptors that are to be applied. May be + . + + + If any of the or + parameters is . + + + + + Invokes the joinpoint using standard reflection. + + +

+ Subclasses can override this to use custom invocation. +

+
+ + The return value of the invocation of the joinpoint. + + + If invoking the joinpoint resulted in an exception. + + +
+ + + Creates a new instance + from the specified and + increments the interceptor index. + + + The current instance. + + + The new instance to use. + + + + + Abstract PointcutAdvisor that allows for any Advice to be configured. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Abstract base class for implementations. + + + Can be subclassed for returning a specific pointcut/advice or a freely configurable pointcut/advice. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Superinterface for all s that are + driven by a pointcut. + + +

+ This covers nearly all advisors except introduction advisors, for which + method-level matching does not apply. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + +
+ + + The that drives this advisor. + + + + + Determines whether the specified + is equal to the current . + + The advisor to compare with. + + if this instance is equal to the + specified . + + + + + Serves as a hash function for a particular type, suitable for use + in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Returns this s order in the + interception chain. + + + This s order in the + interception chain. + + + + + Return the advice part of this aspect. + + +

+ An advice may be an interceptor, a throws advice, before advice, + introduction etc. +

+
+ + The advice that should apply if the pointcut matches. + +
+ + + Is this advice associated with a particular instance? + + +

+ Not supported for dynamic advisors. +

+
+ + if this advice is associated with a + particular instance. + + Always. + +
+ + + The that drives this advisor. + + + + + 2 s are considered equals, if + a) their pointcuts are equal + b) their advices are equal + + + + + Calculates a unique hashcode based on advice + pointcut + + + + + Returns a that represents the current + . + + + A representation of this advisor. + + + + + Return the advice part of this advisor. + + + The advice that should apply if the pointcut matches. + + + + + + Abstract ObjectFactory-based IPointcutAdvisor that allows for any Advice to be + configured as reference to an Advice object in an ObjectFactory. + + + specifying the name of an advice object instead of the advice object itself + (if running within an ObjectFactory/ApplicationContext increses loose coupling + at initialization time, in order not to initialize the advice object until the + pointcut actually matches. + + Juergen Hoeller + Mark Pollack + + + + Describe this Advisor, showing name of advice object. + + + Type name and advice object name. + + + + + Gets or sets the name of the advice object that this advisor should refer to. + + An instance of the specified object will be obtained on first access of + this advisor's advice. This advisor will only ever obtain at most one + single instance of the advice object, caching the instance for the lifetime of + the advisor. + The name of the advice object. + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Return the advice part of this aspect. + + +

+ An advice may be an interceptor, a throws advice, before advice, + introduction etc. +

+
+ + The advice that should apply if the pointcut matches. + +
+ + + Abstract base regular expression pointcut object. + + +

+ The regular expressions must be a match. For example, the + .*Get.* pattern will match Com.Mycom.Foo.GetBar(), and + Get.* will not. +

+

+ This base class is serializable. Subclasses should decorate all + fields with the - the + + method in this class will be invoked again on the client side on deserialization. +

+
+ Rod Johnson + Juergen Hoeller + Simon White (.NET) +
+ + + Convenient superclass when one wants to force subclasses to + implement the interface + but subclasses will still want to be pointcuts. + + +

+ The + property can be overriden to customize filter + behavior as well. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + Mark Pollack (.NET) +
+ + + Convenient abstract superclass for static method matchers that don't care + about arguments at runtime. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + That part of an that checks whether a + target method is eligible for advice. + + +

+ An may be evaluated + statically or at runtime (dynamically). Static + matching involves only the method signature and (possibly) any + s that have been applied to a method. + Dynamic matching additionally takes into account the actual argument + values passed to a method invocation. +

+

+ If the value of the + property of an implementation instance returns , + evaluation can be performed statically, and the result will be the same + for all invocations of this method, whatever their arguments. This + means that if the value of the + is + , the three argument + + method will never be invoked for the lifetime of the + . +

+

+ If an implementation returns in its two argument + + method, and the value of it's + property is + , the three argument + + method will be invoked immediately before each and every potential + execution of the related advice, to decide whether the advice + should run. All previous advice, such as earlier interceptors in an + interceptor chain, will have run, so any state changes they have + produced in parameters or thread local storage, will be available at + the time of evaluation. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + +
+ + + Does the supplied satisfy this matcher? + + +

+ This is a static check. If this method invocation returns + ,or if the + property is + , then no runtime check will be made. +

+
+ The candidate method. + + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + + if this this method matches statically. + +
+ + + Is there a runtime (dynamic) match for the supplied + ? + + +

+ In order for this method to have even been invoked, the supplied + must have matched + statically. This method is invoked only if the two argument + + method returns for the supplied + and , and + if the property + is . +

+

+ Invoked immediately before any potential running of the + advice, and after any advice earlier in the advice chain has + run. +

+
+ The candidate method. + + The target . + + The arguments to the method + + if there is a runtime match. +
+ + + Is this dynamic? + + +

+ If , the three argument + + method will be invoked if the two argument + + method returns . +

+

+ Note that this property can be checked when an AOP proxy is created, + and implementations need not check the value of this property again + before each method invocation. +

+
+ + if this + is dynamic. + +
+ + + Is there a runtime (dynamic) match for the supplied + ? + + +

+ Always throws a . This + method should never be called on a static matcher. +

+
+ The candidate method. + + The target . + + The arguments to the method + + Always throws a . + + + Always. + +
+ + + Does the supplied satisfy this matcher? + + +

+ Must be implemented by a derived class in order to specify matching + rules. +

+
+ The candidate method. + + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + + if this this method matches statically. + +
+ + + Override in case you need to initialized non-serialized fields on deserialization. + + + + + Is this dynamic? + + +

+ Always returns . +

+
+ + Always returns . + +
+ + + Spring.NET's core pointcut abstraction. + + +

+ A pointcut is composed of s and + s. Both these basic terms and an + itself can be combined to build up + sophisticated combinations. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + The for this pointcut. + + + The current . + + + + + The for this pointcut. + + + The current . + + + + + Creates a new instance of the + + class. + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+
+ + + The for this pointcut. + + + The current . + + + + + The for this pointcut. + + + The current . + + + + + A filter that restricts the matching of a pointcut or introduction to + a given set of target types. + + +

+ Can be used as part of a pointcut, or for the entire targeting of an + introduction. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + + +
+ + + Should the pointcut apply to the supplied + ? + + + The candidate . + + + if the advice should apply to the supplied + + + + + + Creates a new instance of the + + class. + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+
+ + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + If an error was encountered during the deserialization process. + + + + + Overridden to ensure proper initialization + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + Subclasses must implement this to initialize regular expression pointcuts. + + +

+ Can be invoked multiple times. +

+

+ This method will be invoked from the property, + and also on deserialization. +

+
+ + The patterns to initialize. + + + In the case of an invalid pattern. + +
+ + + Does the pattern at the supplied + match this ? + + The pattern to match + The index of pattern. + + if there is a match. + + + + + Does the supplied satisfy this matcher? + + +

+ Try to match the regular expression against the fully qualified name + of the method's declaring , plus the name of + the supplied . +

+

+ Note that the declaring is that + that originally declared + the method, not necessarily the that is + currently exposing it. For example, + matches any subclass of 's + method. +

+
+ The candidate method. + + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + + if this this method matches statically. + +
+ + + Should the pointcut apply to the supplied + ? + + +

+ In this instance, simply returns . +

+
+ + The candidate . + + + if the advice should apply to the supplied + + +
+ + + The for this pointcut. + + + The current . + + + + + Convenience property for setting a single pattern. + + + Use this property or Patterns, not both. + + + + + The regular expressions defining methods to match. + + + Matching will be the union of all these; if any match, + the pointcut matches. + + + + + Pointcut that looks for a specific attribute being present on a class or + method. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class for the + given attribute type. + + Type of the attribute to look for at the class level. + + + + Initializes a new instance of the class for the + given attribute type + + Type of the attribute. + if set to true [check inherited]. + + + + Initializes a new instance of the class for the given + attribute type + + The attribute type to look for at the class level. + The attribute type to look for at the method attribute. + + + + The for this pointcut. + + The current . + + + + The for this pointcut. + + The current . + + + + implementation that matches methods + that have been decorated with a specified . + + Aleksandar Seovic + Ronald Wildenberg + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The to match. + + + + + Creates a new instance of the + + class. + + + The to match. + + + Flag that controls whether or not the inheritance tree of the + method to be included in the search for the ? + + + + + Creates a new instance of the + + class. + + + The to match. + + + Flag that controls whether or not the inheritance tree of the + method to be included in the search for the ? + + + Flag that controls whether or not interfaces attributes of the + method to be included in the search for the ? + + + + + Does the supplied satisfy this matcher? + + The candidate method. + + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + + if this this method matches statically. + + + + + The to match. + + + If the supplied value is not a that + derives from the class. + + + + + Is the inheritance tree of the method to be included in the search for the + ? + + +

+ The default is . +

+
+
+ + + Is the interfaces attributes of the method to be included in the search for theg + ? + + +

+ The default is . +

+
+
+ + + Convenient class for attribute-match method pointcuts that hold an Interceptor, + making them an Advisor. + + Bruno Baia + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class + for the supplied . + + the advice to apply if the pointcut matches + + + + Creates a new instance of the + class + for the supplied . + + + The to match. + + + Flag that controls whether or not the inheritance tree of the + method to be included in the search for the ? + + the advice to apply if the pointcut matches + + + + Is this advice associated with a particular instance? + + + if this advice is associated with a + particular instance. + + + Always; this property is not yet supported. + + + + + Returns this s order in the + interception chain. + + + This s order in the + interception chain. + + + + + Return the advice part of this advisor. + + + The advice that should apply if the pointcut matches. + + + + + + The that drives this advisor. + + + + + MethodMatcher that looks for a specific attribute being present on the + method (checking both the method on the onviked interface, if any and the corresponding + method on the target class + + Juergen hoeller + Mark Pollack + + + + + Initializes a new instance of the class for the + given atribute type. + + Type of the attribute to look for. + + + + Does the supplied satisfy this matcher? + + The candidate method. + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + if this this method matches statically. + + +

+ Must be implemented by a derived class in order to specify matching + rules. +

+
+
+ + + ITypeFilter that looks for a specific attribute being present on a class + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class for the + given attribute type. + + Type of the attribute to look for. + + + + Initializes a new instance of the class for the + given attribute type. + + Type of the attribute. + if set to true [check inherited]. + + + + Should the pointcut apply to the supplied ? + + The candidate . + + if the advice should apply to the supplied + + + + + + The attribute for this filter. + + + + + Indicates, whether this filter considers base types for filtering. + + + + + Convenient class for building up pointcuts. + + +

+ All methods return a + instance, which facilitates the following concise usage pattern... +

+ + IPointcut pointcut = new ComposablePointcut() + .Union(typeFilter) + .Intersection(methodMatcher) + .Intersection(pointcut); + +

+ There is no Union() method on this class. Use the + method for such functionality. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + class + that matches all the methods on all s. + + + + + Creates a new instance of the + class + that uses the supplied and + . + + + The type filter to use. + + + The method matcher to use. + + + + + Changes the current type filter to be the union of the existing filter and the + supplied . + + The filter to union with. + + The union of the existing filter and the supplied . + + + + + Changes the current type filter to be the intersection of the existing filter + and the supplied . + + The filter to diff against. + + The intersection of the existing filter and the supplied . + + + + + Changes the current method matcher to be the union of the existing matcher and the + supplied . + + The matcher to union with. + + The union of the existing matcher and the supplied . + + + + + Changes the current method matcher to be the intersection of the existing matcher + and the supplied . + + The matcher to diff against. + + The intersection of the existing matcher and the supplied . + + + + + Changes current pointcut to intersection of the current and supplied pointcut + + pointcut to diff against + updated pointcut + + + + The for this pointcut. + + + The current . + + + + + The for this pointcut. + + + The current . + + + + + Pointcut and method matcher for use in simple cflow-style + pointcuts. + + +

+ Evaluating such pointcuts is slower than evaluating normal pointcuts, + but can nevertheless be useful in some cases. Of course, your mileage + may vary as to what 'slower' actually means. +

+
+ Rod Johnson + Simon White (.NET) +
+ + + Creates a new instance of the + class. + + + The class under which all control flows are to be matched. + + + + + Construct a new pointcut that matches all calls below the + given method in the given class. + + +

+ If the supplied is + , all control flows below the given + class will be successfully matched. +

+
+ + The class under which all control flows are to be matched. + + + The method name under which all control flows are to be matched. + +
+ + + Should the pointcut apply to the supplied ? + + +

+ Subclasses are encouraged to override this method for greater + filtering (and performance). +

+

+ This, the default, implementation always matches (returns + ). +

+
+ The candidate target class. + + if the advice should apply to the supplied + + +
+ + + Does the supplied satisfy this matcher? + Perform static checking. If this returns false, or if the isRuntime() method + returns false, no runtime check will be made. + + +

+ Subclasses are encouraged to override this method if it is possible + to filter out some candidate classes. +

+

+ This, the default, implementation always matches (returns + ). This means that the three argument + + method will always be invoked. +

+
+ The candidate method. + + The target class (may be , in which case the + candidate class must be taken to be the 's + declaring class). + + + if this this method matches statically. + + +
+ + + Is there a runtime (dynamic) match for the supplied + ? + + +

+ Subclasses are encouraged to override this method if it is possible + to filter out some candidate classes. +

+
+ The candidate method. + The target class. + The arguments to the method + + if there is a runtime match. + +
+ + + The for this pointcut. + + + The current . + + + + + Gets the number of times this pointcut has been evaluated. + + +

+ Useful as a debugging aid. +

+

+ Note that this value is distinct from the number of times that this + pointcut sucessfully matches a target method, in that a + may be evaluated many times but + never actually match even once. +

+
+ + The number of times this pointcut has been evaluated. + +
+ + + The for this pointcut. + + + The current . + + + + + Is this a runtime pointcut? + + +

+ This implementation is a runtime pointcut, and so always returns + . +

+
+ + if this is a runtime pointcut. + + +
+ + + Simple implementation that + by default applies to any class. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + class using + the supplied + + +

+ This constructor adds all interfaces implemented by the supplied + (except the + interface) to the list of + interfaces to introduce. +

+
+ The introduction to use. +
+ + + Creates a new instance of the + class using + the supplied + + The introduction to use. + + The interface to introduce. + + + + + Creates a new instance of the + class using + the supplied + + The introduction to use. + + The interfaces to introduce. + + + If the supplied is . + + + + + Adds the supplied to the list of + introduced interfaces. + + The interface to add. + + If any of the are not interface . + + + + + Should the pointcut apply to the supplied + ? + + +

+ This, the default, implementation always returns . +

+
+ + The candidate . + + + if the advice should apply to the supplied + + +
+ + + Can the advised interfaces be implemented by the introduction + advice? + + +

+ Invoked before adding an + . +

+
+ + If the advised interfaces cannot be implemented by the introduction + advice. + + + + If any of the are not interface . + +
+ + + 2 IntroductionAdvisors are considered equal if + a) they are of the same type + b) their introduction advices are equal + c) they introduce the same interfaces + + + + + 2 IntroductionAdvisors are considered equal if + a) they are of the same type + b) their introduction advices are equal + c) they introduce the same interfaces + + + + + 2 IntroductionAdvisors are considered equal if + a) they are of the same type + b) their introduction advices are equal + c) they introduce the same interfaces + + + + + Returns the filter determining which target classes this + introduction should apply to. + + + The filter determining which target classes this introduction + should apply to. + + + + + Gets the interfaces introduced by this + . + + + The interfaces introduced by this + . + + + + + Is this advice associated with a particular instance? + + +

+ Default for an introduction is per-instance interception. +

+
+ + if this advice is associated with a + particular instance. + +
+ + + Return the advice part of this aspect. + + + The advice that should apply if the pointcut matches. + + + + + Concrete ObjectFactory-based IPointcutAdvisor thta allows for any Advice to be + configured as reference to an Advice object in the ObjectFatory, as well as + the Pointcut to be configured through an object property. + + + Specifying the name of an advice object instead of the advice object itself + (if running within a ObjectFactory/ApplicationContext) increases loose coupling + at initialization time, in order to not intialize the advice object until the pointcut + actually matches. + + Juerge Hoeller + Mark Pollack + + + + Describe this Advisor, showing pointcut and name of advice object. + + Type name , pointcut, and advice object name. + + + + The that drives this advisor. + + + + + Convenient pointcut-driven advisor implementation. + + +

+ This is the most commonly used implementation. + It can be used with any pointcut and advice type, except for introductions. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + + class for the supplied , + + + The advice to use. + + + + + Creates a new instance of the + + class for the supplied and + . + + + The advice to use. + + + The pointcut to use. + + + + + 2 s are considered equal, if + a) their pointcuts are equal + b) their advices are equal + + + + + Calculates a unique hashcode based on advice + pointcut + + + + + Returns a that represents the current + . + + + A representation of this advisor. + + + + + The that drives this advisor. + + + + + Convenient abstract superclass for dynamic method matchers that do + care about arguments at runtime. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Does the supplied satisfy this matcher? + + +

+ Derived classes can override this method to add preconditions for + dynamic matching. +

+

+ This implementation always returns . +

+
+ The candidate method. + + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + + if this this method matches statically. + +
+ + + Is there a runtime (dynamic) match for the supplied + ? + + +

+ Must be overriden by derived classes to provide criteria for dynamic matching. +

+
+ The candidate method. + + The target . + + The arguments to the method + + if there is a runtime match. +
+ + + Is this dynamic? + + + Always returns , to specify that this is a + dynamic matcher. + + + + + Convenient superclass for s + that are also dynamic pointcuts. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + + class. + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+
+ + + Creates a new instance of the + + class for the supplied . + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+ + The advice portion of this advisor. + +
+ + + Is this advice associated with a particular instance? + + +

+ Not supported for dynamic advisors. +

+
+ + if this advice is associated with a + particular instance. + + Always. + +
+ + + The for this pointcut. + + +

+ This implementation always returns a filter that evaluates to + for any . +

+
+ + The current . + +
+ + + The for this pointcut. + + +

+ This implementation always returns itself (this object). +

+
+ + The current . + +
+ + + Returns this s order in the + interception chain. + + + This s order in the + interception chain. + + + + + Return the advice part of this aspect. + + + The advice that should apply if the pointcut matches. + + + + + + The that drives this advisor. + + +

+ This implementation always returns itself (this object). +

+
+
+ + + Various utility methods relating to the composition of + s. + + +

+ A method matcher may be evaluated statically (based on method and target + class) or need further evaluation dynamically (based on arguments at + the time of method invocation). +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new that is the + union of the two supplied s. + + +

+ The newly created matcher will match all the methods that either of the two + supplied matchers would match. +

+
+ The first method matcher. + The second method matcher. + + A new that is the + union of the two supplied s + +
+ + + Creates a new that is the + intersection of the two supplied s. + + +

+ The newly created matcher will match only those methods that both + of the supplied matchers would match. +

+
+ The first method matcher. + The second method matcher. + + A new that is the + intersection of the two supplied s + +
+ + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly + visible constructors. +

+
+
+ + + Pointcut object for simple method name matches, useful as an alternative to pure + regular expression based patterns. + + Juergen Hoeller + Aleksandar Seovic (.NET) + + + + Does the of the supplied + matches any of the mapped names? + + + The to check. + + + The of the target class. + + + if the name of the supplied + matches one of the mapped names. + + + + + Does the supplied match the supplied ? + + +

+ The default implementation checks for "xxx*", "*xxx" and "*xxx*" matches, + as well as direct equality. Can be overridden in subclasses. +

+
+ + The method name of the class. + + + The name in the descriptor. + + + True if the names match. + +
+ + + Convenience property when we have only a single method name + to match. + + + + Use either this property or the + property, + not both. + + + + + + Set the method names defining methods to match. + + +

+ Matching will be the union of all these; if any match, the pointcut matches. +

+
+
+ + + Convenient class for name-match method pointcuts that hold an Interceptor, + making them an Advisor. + + Juergen Hoeller + Aleksandar Seovic (.NET) + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class + for the supplied . + + + + + + The for this pointcut. + + Default is + + The current . + + + + + Convenience property when we have only a single method name + to match. + + + + Use either this property or the + property, + not both. + + + + + + Set the method names defining methods to match. + + +

+ Matching will be the union of all these; if any match, the pointcut matches. +

+
+
+ + + The that drives this advisor. + + + + + Various related utility methods. + + +

+ These methods are particularly useful for composing pointcuts + using the union and intersection methods. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a union of the two supplied pointcuts. + + The first pointcut. + The second pointcut. + + The union of the two supplied pointcuts. + + + + + + Creates an that is the + intersection of the two supplied pointcuts. + + The first pointcut. + The second pointcut. + + An that is the + intersection of the two supplied pointcuts. + + + + + Performs the least expensive check for a match. + + + The to be evaluated. + + The candidate method. + + The target . + + The arguments to the method + if there is a runtime match. + + + + + Are the supplied s equal? + + The first pointcut. + The second pointcut. + + if the supplied s + are equal. + + + + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly + visible constructors. +

+
+
+ + + Convenient class for regular expression method pointcuts that hold an + , making them an + . + + +

+ Configure this class using the and + pass-through properties. These are analogous + to the and + s properties of the + class. +

+

+ Can delegate to any type of regular expression pointcut. Currently only + pointcuts based on the regular expression classes from the .NET Base + Class Library are supported. The + + property must be a subclass of the + class. +

+

+ This should not normally be set directly. +

+
+ Dmitriy Kopylenko + Rod Johnson + Simon White (.NET) + Mark Pollack (.NET) + +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class for the supplied . + + The target advice. + + + + + Initialises the pointcut. + + + + + A single pattern to be used during method evaluation. + + + + + Multiple patterns to be used during method evaluation. + + + + + The that drives this advisor. + + + + + Simple implementation that matches + all classes classes (and any derived subclasses) of a give root + . + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Creates a new instance of the + for the supplied + . + + The root . + + If the supplied is . + + + + + Should the pointcut apply to the supplied + ? + + +

+ Returns if the supplied + can be assigned to the root . +

+
+ + The candidate . + + + if the advice should apply to the supplied + + +
+ + + Regular expression based pointcut object. + + +

+ Uses the regular expression classes from the .NET Base Class Library. +

+

+ The regular expressions must be a match. For example, the + .*Get* pattern will match Com.Mycom.Foo.GetBar(), and + Get.* will not. +

+
+ Rod Johnson + Simon White (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class, + using the supplied pattern or . + + + The intial pattern value(s) to be matched against. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + If an error was encountered during the deserialization process. + + + + + Initializes the regular expression pointcuts. + + +

+ Can be invoked multiple times. +

+

+ This method will be invoked from the + property, + and also on deserialization. +

+
+ + The patterns to initialize. + + + In the case of an invalid pattern. + + + If the supplied is . + +
+ + + Does the pattern at the supplied + match this ? + + The pattern to match + The index of pattern. + + if there is a match. + + + + + Gets or sets default options that should be used by + regular expressions that don't have options explicitly set. + + + Default options that should be used by regular expressions + that don't have options explicitly set. + + + + + Convenient superclass for s that + are also static pointcuts. + + Rod Johnson + Aleksandar Seovic (.Net) + + + + Creates a new instance of the + + class. + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+
+ + + Creates a new instance of the + + class for the supplied + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+ + The advice to use. + +
+ + + Is this advice associated with a particular instance? + + + if this advice is associated with a + particular instance. + + + Always; this property is not yet supported. + + + + + Returns this s order in the + interception chain. + + + This s order in the + interception chain. + + + + + Return the advice part of this advisor. + + + The advice that should apply if the pointcut matches. + + + + + + The that drives this advisor. + + + + + Defines miscellaneous filter operations. + + Rod Johnson + Aleksandar Seovic (.Net) + + + + Creates a union of two filters. + + +

+ The filter arising from the union will match all of the + that either of the two supplied filters + would match. +

+
+ + The first filter. + + + The second filter. + + + The union of the supplied filters. + +
+ + + Creates the intersection of two filters. + + +

+ The filter arising from the intersection will match all of the + that both of the two supplied filters + would match. +

+
+ + The first filter. + + + The second filter. + + + The intersection of the supplied filters. + +
+ + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly visible constructors. +

+
+
+ + + Union class filter implementation. + + + + + Intersection implementation. + + + + + Simple implementation that matches + a given 's against . + For a list of supported pattern syntax see . + + Erich Eichinger + + + + + Creates a new instance of using a list of given . + + the list patterns to match typenames against. Must not be null. + + + + + Does the supplied type's match any of the ? + + + The candidate . + + + if the matches any of the . + + + + + Returns the list of type name patterns for this filter. + + + + + + A union. + + +

+ Such pointcut unions are tricky, because one cannot simply OR + the respective s: one has to + ascertain that each 's + is also satisfied. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + class. + + The first pointcut. + The second pointcut. + + + + The for this pointcut. + + + The current . + + + + + The for this pointcut. + + + The current . + + + + + Internal method matcher class for union pointcut. + + + + + Abstract superclass for pooling s. + + +

+ Maintains a pool of target instances, acquiring and releasing a target + object from the pool for each method invocation. +

+

+ This class is independent of pooling technology. +

+

+ Subclasses must implement the + and + + methods to work with their chosen pool. The + + method inherited from the + base class + can be used to create objects to put in the pool. Subclasses must also + implement some of the monitoring methods from the + interface. This class + provides the + + method to return an + making these statistics available on proxied objects. +

+

+ This class implements the interface in + order to force subclasses to implement the + method to cleanup and close + down their pool. +

+
+ Rod Johnson + Federico Spinazzi (.NET) +
+ + + Base class for dynamic + implementations that can create new prototype object instances to + support a pooling or new-instance-per-invocation strategy. + + +

+ All such s must run in an + , as they need to + call the + method to create a new prototype instance. +

+
+ Rod Johnson + Federico Spinazzi (.NET) +
+ + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Subclasses should use this method to create a new prototype instance. + + + + + Returns the target object. + + The target object. + + If unable to obtain the target object. + + + + + Releases the target object. + + The target object to release. + + + + Invoked by an + after it has set all object properties supplied + (and satisfied the + + and + interfaces). + + +

+ Ensures that the property has been + set to a valid value (i.e. is not or a string + that consists solely of whitespace). +

+
+ + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + +
+ + + Returns a textual representation of this target source instance. + This implementation returns + + + + + Returns a textual representation of this target source instance + + + + + The shared instance for this class (and derived classes). + + + + + The name of the target object to be created on each invocation. + + +

+ This object should be a prototype, or the same instance will always + be obtained from the owning . +

+
+
+ + + The of the target object. + + + + + Is the target source static? + + + if the target source is static. + + + + + The target factory that will be used to perform the lookup + of the object referred to by the + property. + + +

+ Needed so that prototype instances can be created as necessary. +

+
+ + The owning + (will never be ). + + + In case of initialization errors. + + +
+ + + Configuration interface for a pooling invoker. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + The number of active object instances in a pool. + + + + + The number of free object instances in a pool. + + + + + The maximum number of object instances in a pool. + + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Returns the target object (acquired from the pool). + + The target object (acquired from the pool). + + If unable to obtain the target object. + + + + + Gets the mixin. + + + An exposing statistics + about the pool maintained by this object. + + + + + Create the pool. + + + The owning , in + case one needs collaborators from it (normally one's own properties + are sufficient). + + + In the case of errors encountered during the creation of the pool. + + + + + Releases the target object (returns it to the pool). + + + The target object to release (return to the pool). + + + In the case that the could not be released. + + + + + Performs application-defined tasks associated with freeing, releasing, or + resetting unmanaged resources. + + +

+ Disposes of the pool. +

+
+
+ + + The maximum number of object instances in this pool. + + + + + The number of active object instances in this pool. + + + + + The number of free object instances in this pool. + + + + + The target factory that will be used to perform the lookup + of the object referred to by the + + property. + + + The owning + (will never be ). + + + In case of initialization errors. + + + + + + The to be used + when there is no target object, and behavior is supplied by the + advisors. + + +

+ This class is exposed as a singleton. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + The to be used + when there is no target object, and behavior is supplied by the + advisors. + + + + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly visible constructors. +

+
+
+ + + Returns the target object. + + The target object. + + If unable to obtain the target object. + + + + + Releases the target object. + + + + This is a no-op operation in this implementation. + + + The target object to release. + + + + A that represents the current + . + + + A that represents the current + . + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The of the target object. + + + + + Is the target source static? + + +

+ The + instance is static, and this always returns . +

+
+ + if the target source is static. + +
+ + + implementation that caches a + local target object, but allows the target to be swapped while the + application is running + + +

+ If configuring an object of this class in a Spring IoC container, + use constructor injection to supply the intial target. +

+
+ Rod Johnson + Aleksandar Seovic (.Net) +
+ + + Creates a new instance of the + with the initial target. + + + The initial target. May be . + + + + + Returns the target object. + + The target object. + + If unable to obtain the target object. + + + + + Releases the target object. + + +

+ No-op implementation. +

+
+ The target object to release. +
+ + + Swap the target, returning the old target. + + The new target. + The old target. + + If the new target is . + + + + + Determines whether the specified + is equal to the current . + + +

+ Two invoker interceptors are equal if they have the same target or + if the targets are equal. +

+
+ The target source to compare with. + + if this instance is equal to the + specified . + +
+ + + Serves as a hash function for a particular type, suitable for use + in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + The of the target object. + + +

+ Can return . +

+
+
+ + + Is the target source static? + + + if the target source is static. + + + + + Statistics for a thread local . + + Rod Johnson + Federico Spinazzi (.NET) + + + + Gets the number of invocations of the + and + methods. + + + The number of invocations of the + and + methods. + + + + + Gets the number of hits that were satisfied by a thread bound object. + + + The number of hits that were satisfied by a thread bound object. + + + + + Gets the number of thread bound objects created. + + The number of thread bound objects created. + + + + implementation that creates a + new instance of the target object for each request. + + +

+ Can only be used in an object factory. +

+
+ Rod Johnson + Spinazzi Federico (.NET) +
+ + + Returns the target object. + + The target object. + + If unable to obtain the target object. + + + + + Releases the target object. + + +

+ No-op implementation. +

+
+ The target object to release. +
+ + + Is the target source static? + + + because this target source is never static. + + + + + Pooling target source implementation based on the + + + Rod Johnson + Federico Spinazzi + + + + Returns the target object (acquired from the pool). + + + The target object (acquired from the pool). + + + If unable to obtain the target object. + + + + + Creates the pool. + + + The owning , in + case one needs collaborators from it (normally one's own properties + are sufficient). + + + + + + Creates a new instance of an appropriate + implementation. + + +

+ Subclasses can, of course, override this method if they want to + return a different implementation. +

+
+ + An empty . + +
+ + + Releases the target object (returns it to the pool). + + The target object to release (return to the pool). + + In the case that the could not be released. + + + + + Performs application-defined tasks associated with freeing, releasing, or + resetting unmanaged resources. + + +

+ Disposes of the pool. +

+
+
+ + + Creates an instance that can be returned by the pool. + + + An instance that can be returned by the pool. + + + + + + Destroys an instance no longer needed by the pool. + + The instance to be destroyed. + + + + + Ensures that the instance is safe to be returned by the pool. + Returns false if this object should be destroyed. + + The instance to validate. + + if this object is not valid and + should be dropped from the pool, otherwise . + + + + + + Reinitialize an instance to be returned by the pool. + + The instance to be activated. + + + + + Passivates the object. + + The instance returned to the pool. + + + + + The number of active object instances in this pool. + + + + + The number of free object instances in this pool. + + + + + implementation that holds a local + object. + + +

+ This is the default implementation of the + interface used by the AOP + framework. There should be no need to create objects of this class in + application code. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + + for the specified target object. + + The target object to expose. + + If the supplied is + . + + + + + Creates a new instance of the + + for the specified target object. + + The target object to expose. + The type of to expose. + + If the supplied is + . + + + + + Returns the target object. + + The target object. + + If unable to obtain the target object. + + + + + Releases the target object. + + +

+ No-op implementation. +

+
+ The target object to release. +
+ + + Returns a stringified representation of this target source. + + + A stringified representation of this target source. + + + + + Determines whether the specified + is equal to the current . + + The target source to compare with. + + if this instance is equal to the + specified . + + + + + Serves as a hash function for a particular type, suitable for use + in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + The of the target object. + + + + + Is the target source static? + + + because this target source is always static. + + + + + implementation that uses a + threading model in which every thread has its own copy of the target. + + +

+ Alternative to an object pool. +

+

+ Application code is written as to a normal pool; callers can't assume + they will be dealing with the same instance in invocations in different + threads. However, state can be relied on during the operations of a + single thread: for example, if one caller makes repeated calls on the + AOP proxy. +

+

+ This class act both as an introduction and as an interceptor, so it + should be added twice, once as an introduction and once as an + interceptor. +

+
+ Rod Johnson + Federico Spinazzi (.NET) +
+ + + ThreadLocal holding the target associated with the current thread. + + +

+ Unlike most thread local storage which is static, this variable is + meant to be per thread per instance of this class. +

+
+
+ + + The set of managed targets, enabling us to keep track of the + targets we've created. + + + + + Returns the target object. + + +

+ Tries to locate the target from thread local storage. If no target + is found, a target will be obtained and bound to the thread. +

+
+ The target object. + + If unable to obtain the target object. + + +
+ + + Return an introduction advisor mixin that allows the AOP proxy to be + cast to an reference. + + + + + Cleans up this instance's thread storage, and disposes of any + targets as necessary. + + + + + + Increments Invocations and Hits statistics + + The method invocation joinpoint + The result of the call to IJoinpoint.Proceed(), might be intercepted by the interceptor. + if the interceptors or the target-object throws an exception. + + + + Gets the number of invocations of the and + methods. + + + The number of invocations of the and + methods. + + + + + Gets the number of hits that were satisfied by a thread bound object. + + + The number of hits that were satisfied by a thread bound object. + + + + + Gets the number of thread bound objects created. + + The number of thread bound objects created. + + + + AOP Aspect abstraction, holding a list of s + + + Aleksandar Seovic (.NET) + + + + Gets or sets a list of advisors. + + + A list of advisors. + + + + + Advice that executes after a method returns successfully. + + +

+ After returning advice is invoked only on a normal method + return, but not if an exception is thrown. Such advice can see + the return value of the advised method invocation, but cannot change it. +

+

+ Possible uses for this type of advice would include performing access + control checks on the return value of an advised method invocation, the + ubiquitous logging of method invocation return values (useful during + development), etc. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + + + +
+ + + Executes after + returns successfully. + + +

+ Note that the supplied cannot + be changed by this type of advice... use the around advice type + () if you + need to change the return value of an advised method invocation. + The data encapsulated by the supplied + can of course be modified though. +

+
+ + The value returned by the . + + The intecepted method. + The intercepted method's arguments. + The target object. + +
+ + + Superinterface for all before advice. + + +

+ Before advice is advice that executes before a joinpoint, but + which does not have the ability to prevent execution flow proceeding to + the joinpoint (unless it throws an ). +

+

+ Spring.NET only supports method before advice. Although this + is unlikely to change, this API is designed to allow field + before advice in future if desired. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + + + + +
+ + + Subinterface of the AOP Alliance + interface that + allows additional interfaces to be implemented by the interceptor, and + available via a proxy using that interceptor. + + +

+ This is a fundamental AOP concept called introduction. +

+

+ Introductions are often mixins, enabling the building of composite + objects that can achieve many of the goals of multiple inheritance. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Does this + implement the given interface? + + The interface to check. + + if this + + implements the given interface. + + + + + Advice executed before a method is invoked. + + +

+ Such advice cannot prevent the method call proceeding, short of + throwing an . +

+

+ The main advantage of before advice is that there is no + possibility of inadvertently failing to proceed down the interceptor + chain, since there is no need (and indeed means) to invoke the next + interceptor in the call chain. +

+

+ Possible uses for this type of advice would include performing class + invariant checks prior to the actual method invocation, the ubiquitous + logging of method invocations (useful during development), etc. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + + + + +
+ + + The callback before a given method is invoked. + + The method being invoked. + The arguments to the method. + + The target of the method invocation. May be . + + + Thrown when and if this object wishes to abort the call. Any + exception so thrown will be propagated to the caller. + + + + + Simple marker interface for throws advice. + + +

+ There are no methods on this interface, as methods are discovered and + invoked via reflection. Please do see read the API documentation for the + class; + said documention describes in detail the signature of the methods that + implementations of the interface + must adhere to in the specific case of Spring.NET's implementation of + throws advice. +

+

+ There are any number of possible uses for this type of advice. Some + examples would include the ubiquitous logging of any such exceptions, + monitoring the number and type of exceptions and sending emails to + a support desk once certain criteria have been met, wrapping generic + exceptions such as in + exceptions that are more meaningful to your business logic, etc. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) + + + +
+ + + Canonical that matches + all methods. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Canonical instance that matches all methods. + + +

+ It is not dynamic. +

+
+
+ + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly visible + constructors. +

+
+
+ + + Does the supplied satisfy this matcher? + Perform static checking. If this returns false, or if the isRuntime() method + returns false, no runtime check will be made. + + The candidate method. + + The target class (may be , in which case the + candidate class must be taken to be the 's + declaring class). + + + if this this method matches statically. + + + + + + Is there a runtime (dynamic) match for the supplied + ? + + The candidate method. + The target class. + The arguments to the method + + if there is a runtime match. + + + + + A that represents the current + . + + + A that represents the current + . + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + Is this dynamic? + + + if this + is dynamic. + + + + + + Canonical instance that matches + everything. + + Rod Johnson + Aleksandar Seovic (.NET) + + + + Canonical instance that matches everything. + + + + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly + visible constructors. +

+
+
+ + + A that represents the current + . + + + A that represents the current + . + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The for this pointcut. + + + The current . + + + + + The for this pointcut. + + + The current . + + + + + Canonical instances. + + +

+ Only one canonical instance is + provided out of the box. The + matches all classes. +

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Canonical instance that + matches all classes. + + + + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly visible + constructors. +

+
+
+ + + Should the pointcut apply to the supplied + ? + + + The candidate . + + + if the advice should apply to the supplied + + + + + + + A that represents the current + . + + + A that represents the current + . + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + Superclass for all AOP infrastructure exceptions. + + Aleksandar Seovic + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Intercepts the construction of a new object. + + +

+ Such interceptions are nested "on top" of the target. +

+
+
+ + + Implement this method to perform extra treatments before and after + the consruction of a new object. + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The constructor invocation that is being intercepted. + + + The newly created object, which is also the result of the call to + , and might be + replaced by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + A description of an invocation to a constuctor, given to an interceptor + upon constructor-call. + + +

+ A constructor invocation is a joinpoint and can be intercepted by a + constructor interceptor. +

+
+ +
+ + + Gets the constructor invocation that is to be invoked. + + +

+ This property is a friendly implementation of the + property. + It should be used in preference to the + property + because it provides immediate access to the underlying constructor + without the need to resort to a cast. +

+
+ + The constructor invocation that is to be invoked. + +
+ + + Base class for different cache advice implementations that provide + access to common functionality, such as obtaining a cache instance. + + Aleksandar Seovic + + + + Shared logger instance + + + + + Create a new default instance. + + + + + Returns an instance based on the cache name. + + The name of the cache. + + Cache instance for the specified if one + is registered in the application context, or null if it isn't. + + + If there's no cache instance registered for the specified . + + + If the cache instance could not be created. + + + If the cache instance registered does not implement the interface. + + + + + Prepares variables for expression evaluation by packaging all + method arguments into a dictionary, keyed by argument name. + + + Method to get parameters info from. + + + Argument values to package. + + + A dictionary containing all method arguments, keyed by method name. + + + + + Evaluates a SpEL expression as a boolean value. + + + The expression string that should be evaluated. + + + The SpEL expression instance that should be evaluated. + + + The object to evaluate expression against. + + + The expression variables dictionary. + + + The evaluated boolean. + + + If the SpEL expression could not be successfuly resolved to a boolean. + + + + + Retrieves custom attribute for the specified attribute type. + + + Method/Parameter to get attribute from. + + + Attribute type. + + + Attribute instance if one is found, null otherwise. + + + + + Retrieves custom attribute for the specified attribute type. + + + Method/Parameter to get attribute from. + + + Attribute type. + + + Attribute instance if one is found, null otherwise. + + + + + Sets the that this + object runs in. + + + + + Caching aspect implementation. + + + This class encapsulates all the advisors that need to be configured to support + Spring's full caching functionality. + + + + + Aleksandar Seovic + + + + Creates a new instance. + + + + + Gets or sets a list of advisors for this aspect. + + + A list of advisors for this aspect. + + + + + Sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Implementation of a parameter caching advice. + + +

+ This advice can be used to cache the parameter of the method. +

+

+ Information that determines where, how and for how long the return value + will be cached are retrieved from the s + that are defined on the pointcut. +

+

+ Parameter values are cached *after* the target method is invoked in order to + capture any parameter state changes it might make (for example, it is common + to set an object identifier within the save method for the persistent entity). +

+
+ + Aleksandar Seovic +
+ + + Executes after target + returns successfully. + + +

+ Note that the supplied cannot + be changed by this type of advice... use the around advice type + () if you + need to change the return value of an advised method invocation. + The data encapsulated by the supplied + can of course be modified though. +

+
+ + The value returned by the . + + The intecepted method. + The intercepted method's arguments. + The target object. + +
+ + + Convinience advisor implementation that applies + to all the methods that have defined on one or + more of their parameters. + + Aleksandar Seovic + + + + Creates new advisor instance. + + + + + Returns true if any of the parameters of the specified + has applied. + + + Method to check. + + + Type of target object. + + + true if any of the parameters of the specified + has applied; false otherwise. + + + + + Sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Implementation of a result caching advice. + + +

+ This advice can be used to cache the return value of the method. +

+

+ Parameters that determine where, how and for how long the return value + will be cached are retrieved from the and/or + that are defined on the pointcut. +

+
+ + + Aleksandar Seovic +
+ + + Applies caching around a method invocation. + + +

+ This method tries to retrieve an object from the cache, using the supplied + to generate a cache key. If an object is found + in the cache, the cached value is returned and the method call does not + proceed any further down the invocation chain. +

+

+ If object does not exist in the cache, the advised method is called (using + ) + and any return value is cached for the next method invocation. +

+
+ + The method invocation that is being intercepted. + + + A cached object or the result of the + call. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + Obtains return value either from cache or by invoking target method + and caches it if necessary. + + + The method invocation that is being intercepted. + + + Attribute specifying where and how to cache return value. Can be null, + in which case no caching of the result as a whole will be performed + (if the result is collection, individual items could still be cached separately). + + + Variables for expression evaluation. + + + Returns true if the return value was found in cache, false otherwise. + + + Return value for the specified . + + + + + Caches each item from the collection returned by target method. + + + A collection of items to cache. + + + Attributes specifying where and how to cache each item from the collection. + + + Variables for expression evaluation. + + + + + Inner class to help cache null values. + + + + true when other object is of same type. + + + 13 + + + + Convinience advisor implementation that applies + to all the methods that have defined. + + Aleksandar Seovic + + + + Creates new advisor instance. + + + + + Returns true if either or + is applied to the + . + + + Method to check. + + + Type of target object. + + + true if either or + is applied to the + ; false otherwise. + + + + + Sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Implementation of a cache invalidation advice. + + +

+ This advice can be used to evict items from the cache. +

+

+ Information that determines which items should be evicted and from which cache + are retrieved from the s that are defined + on the pointcut. +

+

+ Items are evicted *after* target method is invoked. Return value of the method, + as well as method arguments, can be used to determine a list of keys for the items + that should be evicted (return value will be passed as a context for + expression evaluation, and method + arguments will be passed as variables, keyed by argument name). +

+
+ + Aleksandar Seovic +
+ + + Executes after + returns successfully. + + +

+ Note that the supplied cannot + be changed by this type of advice... use the around advice type + () if you + need to change the return value of an advised method invocation. + The data encapsulated by the supplied + can of course be modified though. +

+
+ + The value returned by the . + + The intecepted method. + The intercepted method's arguments. + The target object. + +
+ + + Convinience advisor implementation that applies + to all the methods that have defined. + + Aleksandar Seovic + + + + Creates new advisor instance. + + + + + Sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Exception advice to perform exception translation, conversion of exceptions to default return values, and + exception swallowing. Configuration is via a DSL like string for ease of use in common cases as well as + allowing for custom translation logic by leveraging the Spring expression language. + + + + The exception handler collection can be filled with either instances of objects that implement the interface + or a string that follows a simple syntax for most common exception management + needs. The source exceptions to perform processing on are listed immediately after the keyword 'on' and can + be comma delmited. Following that is the action to perform, either log, translate, wrap, replace, return, or + swallow. Following the action is a Spring expression language (SpEL) fragment that is used to either create the + translated/wrapped/replaced exception or specify an alternative return value. The variables available to be + used in the expression language fragment are, #method, #args, #target, and #e which are 1) the method that + threw the exception, the arguments to the method, the target object itself, and the exception that was thrown. + Using SpEL gives you great flexibility in creating a translation of an exception that has access to the calling context. + + Common translation cases, wrap and rethrow, are supported with a shorter syntax where you can specify only + the exception text for the new translated exception. If you ommit the exception text a default value will be + used. + The exceptionsHandlers are compared to the thrown exception in the order they are listed. logging + an exception will continue the evaluation process, in all other cases exceution stops at that point and the + appropriate exceptions handler is executed. + + + + on FooException1 log 'My Message, Method Name ' + #method.Name + on FooException1 translate new BarException('My Message, Method Called = ' + #method.Name", #e) + on FooException2,Foo3Exception wrap BarException 'My Bar Message' + on FooException4 replace BarException 'My Bar Message' + on FooException5 return 32 + on FooException6 swallow + + + + + + + Mark Pollack + + + + This is + + + + + Mark Pollack + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Parses the advice expression. + + The advice expression. + An instance of ParsedAdviceExpression + + + + Gets the match using exception constraint expression. + + The advice expression string. + The regex string. + The Match object resulting from the regular expression match. + + + + Override in case you need to initialized non-serialized fields on deserialization. + + + + + Gets or sets the Regex string used to parse advice expressions starting with 'on exception name' and subclass specific actions. + + The regex string to parse advice expressions starting with 'on exception name' and subclass specific actions. + + + + Gets or sets the Regex string used to parse advice expressions starting with 'on exception (constraint)' and subclass specific actions. + + The regex string to parse advice expressions starting with 'on exception (constraint)' and subclass specific actions. + + + + Log instance available to subclasses + + + + + Holds shared handler definition templates + + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Invokes handlers registered for the passed exception and + + The exception to be handled + The that raised this exception. + The output of + + + + Parses the specified handler string, creating an instance of IExceptionHander. + + The handler string. + an instance of an exception handler or null if was not able to correctly parse + handler string. + + + + Creates the exception handler. + + The parsed advice expression. + The exception handler instance + + + + Creates the execute spel exception handler. + + The parsed advice expression. + + + + + Creates the return value exception handler. + + The parsed advice expression. + + + + + Creates the swallow exception hander. + + The parsed advice expression. + + + + + Creates the translation exception handler. + + The exception names. + + + + + Creates the log exception handler. + + The exception names. + Log exception + + + + Parses the wrapped exception expression. + + The action. + The handler string. + + + + + Gets or sets the Regex string used to parse advice expressions starting with 'on exception name' and exception handling actions. + + The regex string to parse advice expressions starting with 'on exception name' and exception handling actions. + + + + Gets or sets the Regex string used to parse advice expressions starting with 'on exception (constraint)' and exception handling actions. + + The regex string to parse advice expressions starting with 'on exception (constraint)' and exception handling actions. + + + + Gets or sets the exception handler. + + The exception handler. + + + + Gets the exception handler dictionary. Allows for registration of a specific handler where the key + is the action type. This makes configuration of a custom exception handler easier, for example + LogExceptionHandler, in that only 'user friendly' properties such as LogName, etc., need to be configured + and not 'user unfriendly' properties such as ConstraintExpressionText and ActionExpressionText. + + The exception handler dictionary. + + + + A specialized dictionary for key value pairs of (string, IExceptionHandler) + + + + + Adds the specified key. + + The key. + The value. + + + + Adds an element with the specified key and value into the . + + The key of the element to add. + The value of the element to add. The value can be null. + + is null. + An element with the same key already exists in the . + or key is not a string or value is not an IExceptionHandler. + The is read-only.-or- The has a fixed size. + + + + Gets the with the specified key. + + + + + + Gets the with the specified key. + + + + + + Executes an abribtrary Spring Expression Language (SpEL) expression as an action when handling an exception. + + + + + An abstract base class providing all necessary functionality for typical IExceptionHandler implementations. + + Mark Pollack + + + + Handles a thrown exception providing calling context. + + Mark Pollack + + + + Determines whether this instance can handle the exception the specified exception. + + The exception. + The call context dictionary. + + true if this instance can handle the specified exception; otherwise, false. + + + + + Handles the exception. + + The call context dictionary. + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + + Gets the source exception names. + + The source exception names. + + + + Gets the source exception types. + + The source exception types. + + + + Gets the translation expression text + + The translation expression text + + + + Gets or sets the constraint expression text. + + The constraint expression text. + + + + Gets a value indicating whether to continue processing. + + true if continue processing; otherwise, false. + + + + The logging instance + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Determines whether this instance can handle the exception the specified exception. + + The exception. + The call context dictionary. + + true if this instance can handle the specified exception; otherwise, false. + + + + + Handles the exception. + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + Gets the source exception names. + + The source exception names. + + + + Gets the source exception types. + + The source exception types. + + + + Gets the action translation expression text + + The action translation expression. + + + + Gets or sets the constraint expression text. + + The constraint expression text. + + + + Gets a value indicating whether to continue processing. + + true if continue processing; otherwise, false. + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Handles the exception. + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + Log the exceptions. Default log nameis "LogExceptionHandler" and log level is Debug + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Handles the exception. + + the calling context dictionary + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + + Gets or sets the name of the log. + + The name of the log. + + + + Gets or sets the log level. + + The log level. + + + + Gets or sets a value indicating whether to log message only, and not pass in the + exception to the logging API + + true if log message only; otherwise, false. + + + + Gets the action translation expression text. Overridden to add approprate settings to + the SpEL expression that does the logging so that it depends on the values of LogLevel and + LogMessageOnly. Those properties must be set to the desired values before calling this method. + + + The action translation expression. + + + + Evaluates the expression for the return value of the method. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Returns the result of evaluating the translation expression. + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + Returns a token to indicate that this exception should be swallowed. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Handles the exception. + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + Translates from one exception to another based. My wrap or replace exception depending on the expression. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Handles the exception. + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + Abstract base class for logging advice + + + + + Mark Pollack + + + + The default ILog instance used to write logging messages. + + + + + The name of the logger instance to use for obtaining from . + + + + + Indicates whether or not proxy type names should be hidden when using dynamic loggers. + + + + + Creates a new advice instance using this advice type's name for logging by default. + + + + + Creates a new advice instance using the given logger by default. + + + + + Adds logging to the method invocation. + + + The method IsInterceptorEnabled is called + as an optimization to determine if logging should be applied. If logging should be + applied, the method invocation is passed to the InvokeUnderLog method for handling. + If not, the method proceeds as normal. + + + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + + + + + Determines whether the interceptor is enabled for the specified invocation, that + is, whether the method InvokeUnderLog is called. + + The default behavior is to check whether the given ILog instance + is enabled by calling IsLogEnabled, whose default behavior is to check if + the TRACE level of logging is enabled. Subclasses + The invocation. + The log to write messages to + + true if [is interceptor enabled] [the specified invocation]; otherwise, false. + + + + + Determines whether the given log is enabled. + + + Default is true when the trace level is enabled. Subclasses may override this + to change the level at which logging occurs, or return true to ignore level + checks. + The log instance to check. + + true if log is for a given log level; otherwise, false. + + + + + Subclasses must override this method to perform any tracing around the supplied + IMethodInvocation. + + + Subclasses are resonsible for ensuring that the IMethodInvocation actually executes + by calling IMethodInvocation.Proceed(). + + By default, the passed-in ILog instance will have log level + "trace" enabled. Subclasses do not have to check for this again, unless + they overwrite the IsInterceptorEnabled method to modify + the default behavior. + + + The method invocation to log + The log to write messages to + The result of the call to IMethodInvocation.Proceed() + + + If any of the interceptors in the chain or the target object itself + throws an exception. + + + + + Gets the appropriate log instance to use for the given IMethodInvocation. + + + If the UseDynamicLogger property is set to true, the ILog instance will be + for the target class of the IMethodInvocation, otherwise the log will be the + default static logger. + + The method invocation being logged. + The ILog instance to use. + + + + Sets the default logger to the given name. + + if null, the default logger is removed. + + + + Override in case you need to initialized non-serialized fields on deserialization. + + + + + Sets a value indicating whether to use a dynamic logger or static logger + + Default is to use a static logger. + + Used to determine which ILog instance should be used to write log messages for + a particular method invocation: a dynamic one for the Type getting called, + or a static one for the Type of the trace interceptor. + + + Specify either this property or LoggerName, not both. + + + true if use dynamic logger; otherwise, false. + + + + Sets the name of the logger to use. + + + The name will be passed to the underlying logging implementation through Common.Logging, + getting interpreted as the log category according to the loggers configuration. + + This can be specified to not log into the category of a Type (whether this + interceptor's class or the class getting called) but rather to a specific named category. + + + Specify either this property or UseDynamicLogger, but not both. + + + The name of the logger. + + + + Sets a value indicating whether hide proxy type names (whenever possible) + when using dynamic loggers, i.e. property UseDynamicLogger is set to true. + + true if [hide proxy type names]; otherwise, false. + + + + Configurable advice for logging. + + + + + Mark Pollack + + + + Flag to indicate if unique identifier should be in the log message. + + + + + Flag to indicate if the execution time should be in the log message. + + + + + Flag to indicate if the method arguments should be in the log message. + + + + + Flag to indicate if the return value should be in the log message. + + + + + The separator string to use for delmiting log message fields. + + + + + The log level to use for logging the entry, exit, exception messages. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + if set to true to use dynamic logger, if + false use static logger. + + + + Initializes a new instance of the class. + + the default logger to use + + + + Subclasses must override this method to perform any tracing around the supplied + IMethodInvocation. + + The method invocation to log + The log to write messages to + + The result of the call to IMethodInvocation.Proceed() + + + Subclasses are resonsible for ensuring that the IMethodInvocation actually executes + by calling IMethodInvocation.Proceed(). + + By default, the passed-in ILog instance will have log level + "trace" enabled. Subclasses do not have to check for this again, unless + they overwrite the IsInterceptorEnabled method to modify + the default behavior. + + + + If any of the interceptors in the chain or the target object itself + throws an exception. + + + + + Determines whether the given log is enabled. + + The log instance to check. + + true if log is for a given log level; otherwise, false. + + + Default is true when the trace level is enabled. Subclasses may override this + to change the level at which logging occurs, or return true to ignore level + checks. + + + + Creates a unique identifier. + + + Default implementation uses Guid.NewGuid(). Subclasses may override to provide an alternative + ID generation implementation. + + A unique identifier + + + + Gets the entry message to log + + The invocation. + The id string. + The entry log message + + + + Gets the exception message. + + The method invocation. + The thown exception. + The execution time span. + The id string. + The exception log message. + + + + Gets the exit log message. + + The method invocation. + The return value. + The execution time span. + The id string. + the exit log message + + + + Appends common information across entry,exit, exception logging + + Add method name and unique identifier if required. + The string buffer building logging message. + The method invocation. + The unique identifier string. + + + + Gets the method argument as argumen name/value pairs. + + The method invocation. + string for logging method argument name and values. + + + + Gets or sets a value indicating whether to log a unique identifier with the log message. + + true if [log unique identifier]; otherwise, false. + + + + Gets or sets a value indicating whether to log execution time. + + true if log execution time; otherwise, false. + + + + Gets or sets a value indicating whether log method arguments. + + true if log method arguments]; otherwise, false. + + + + Gets or sets a value indicating whether log return value. + + true if log return value; otherwise, false. + + + + Gets or sets the seperator string to use for delmiting log message fields. + + The seperator. + + + + Gets or sets the entry log level. + + The entry log level. + + + + This advice is typically applied to service-layer methods in order to validate + method arguments. + + + Each argument that should be validated has to be marked with one or more + s. + If the validation fails, this advice will throw , + thus preventing target method invocation. + + + Damjan Tomic + Aleksandar Seovic + + + + Intercepts method invocation and validates arguments. + + + Method invocation. + + + Method arguments. + + + Target object. + + + If one or more method arguments fail validation. + + + + + Sets the application context to search for validators in. + + + The application context to search for validators in. + + + + + Convinience advisor implementation that applies + to all the methods that have defined on one or + more of their parameters. + + Bruno Baia + + + + Creates new advisor instance. + + + + + Returns true if any of the parameters of the specified + has applied. + + + Method to check. + + + Type of target object. + + + true if any of the parameters of the specified + has applied; false otherwise. + + + + + Sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + This class contains the results of parsing an advice expresion of the form + on exception name [ExceptionName1,ExceptionName2,...] [action] [action expression] + or + on exception [constraint expression] [action] [action expression] + + + + + Mark Pollack + + + + Initializes a new instance of the class. + + The advice expression. + + + + Gets or sets the advice expression. + + The advice expression. + + + + Gets or sets the exception names. + + The exception names. + + + + Gets or sets the constraint expression. + + The constraint expression. + + + + Gets or sets the action expression text. + + The action expression text. + + + + Gets or sets the action text. + + The action text. + + + + Gets or sets a value indicating whether this is success. + + true if success; otherwise, false. + + + + AOP Advice to retry a method invocation on an exception. The retry semantics are defined by a DSL of the + form on exception name [ExceptionName1,ExceptionName2,...] retry [number of times] [delay|rate] [delay time|rate expression]. + For example, on exception name ArithmeticException retry 3x delay 1s + + + + + Mark Pollack + + + + Creates a new RetryAdvice instance, using for delaying retries + + + + + Creates a new RetryAdvice instance, using any arbitrary callback for delaying retries + + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + The method invocation that is being intercepted. + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Parses the specified handler string. + + The handler string. + + + + + Gets the match for action expression. + + The action expression string. + The regex string. + The Match object resulting from the regular expression match. + + + + Override in case you need to initialized non-serialized fields on deserialization. + + + + + Gets or sets the retry expression. + + The retry expression. + + + + Gets or sets the Regex string used to parse advice expressions starting with 'on exception name' and exception handling actions. + + The regex string to parse advice expressions starting with 'on exception name' and exception handling actions. + + + + Gets or sets the Regex string used to parse advice expressions starting with 'on exception (constraint)' and exception handling actions. + + The regex string to parse advice expressions starting with 'on exception (constraint)' and exception handling actions. + + + + The type of the callback that is called for delaying retries. + + + + + Sleeps for the appropriate amount of time for an exception. + + + + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The exception names. + + + + Handles the exception. + + + + The return value from handling the exception, if not rethrown or a new exception is thrown. + + + + + Gets the maximum retry count. + + The maximum retry count. + + + + Gets a value indicating whether this instance is delay based. + + + true if this instance is delay based; otherwise, false. + + + + + Gets or sets the delay time span to sleep after an exception is thrown and a rety is + attempted. + + The delay time span. + + + + Gets or sets the delay rate expression. + + The delay rate expression. + + + diff --git a/Resources/Libraries/Spring.NET/Spring.Core.dll b/Resources/Libraries/Spring.NET/Spring.Core.dll new file mode 100644 index 0000000000000000000000000000000000000000..b2170a4c946e6facea0c1823b78d3f306efc8246 GIT binary patch literal 775168 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

6gI9$`0A|vk+0Ii#oOQVmh~eY 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�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

P?;G)|fl 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 z zPfJgi{FK7S^0FuJ(Rke4?eKZPzB93;{ocOrg|qUvHDo)RS#zG|?tsTTjmO+}?G~1i z>GGpCx|eh{F+rs;=5KsxqfbX|v?a5$TLI^W^I_#jbt?AL*}SSL_SE~fncsh!%ou1p z7u)9b-+QKX}jO0?RuBCsU+I>#p#sw(W<|d$_$SA5;uqOCU7{{Zw9rdg*}xO zpSOThLFSCImx9czxOIt*pyp`a23`-o9mMuey#s6nnOn-<1HKb{0Q^gEJ@_t=u(H41 z+UUE%4|4q;a0mET;KSe+@ay1v!G8hY2R;qHAM|Irp3lsp&gzZvoNyiEW%$#XxrP2N z;J*9`Cxg=|7r(9{nR(lSA3;vB%(jyTse(^}nxp#^I0pPQs5VGGvNOQXfSQ~8EO-t0 zIj|0V2$Zb;8f*qX58e&_4fq<6{JZtzFM!C)?Li>l?mR1ayS)g+;r1f@9r!5zz6O37 z{0_Ji{65ID?7xG%Krgd%gUn)-40Iji#av5fh5pV9{)Cd*6lk@pXGh`VZ6)Sp_$_xD zblCk$r6@xuvu}fvnJqE`UXqR65qJ&;e*+E!{}ZeNp9Lj@--0g%e+R0*{1py_^gMS1!g4EIMW&!vK@C1;$mKp$l1!SHf`%SPML>{Su;LpGlL8Xl;1!Qp!^VHL@<3-fd5j0|AhJ$f1R~SaOi+6$E&+)%bs6~l$xY`rpBqT$Kk2M$ojteK$x?O8 z+q1>%7E`)TmbIW{$uw(LvSbR?$&%?&CrhS4oh+G3ak5+tN|xHAAz5mVhGcm?C|PQc zhGeNd8j_{Ofs*CTpz79g@cEO`RAl1omgmB3z?Xp9e?k3r`!A?hZl8sh*J$!udK)~p zjZPpwod>?o)hEf%k12}FZv*L){Qd%z{In-S^4kbXes2RMzqf;u-#b9bZxbl_@!pY> z-(P}~-@8D`Z!;+Qy&IJL-UCX0e+5c@TR_Q=_X(W*-Umv4?*}Ent)S%h0Z{V$ASn5L z2$cLj0{*$==f_IL<@XuVA^Cj{l>8n7CBMH0CBM&ulHcEelHbFi$!{kp`TZRz`Tafk6!;IIELAN`5~8CBK89%plHUoS6>M8xBf-r-OeE`AHUj z+@3p22=>YNuF|E$e^;P|`+i)V#>(;TM4&$W)>-%(4@?1vg6D&>`z`>-f?Bse8@!0? zbHR(j3Qqj3;H}gO>?xh|FE@-cR^qd9{TR9U`pjJ77)Y3TpnVqw`!c0;JUUM~L03YX z=;*gYyPyNm5oidVeic*;)kEu`EznMAKXe!xgh5aV&4TKn7HB=R6?z!j3q1psVK9t@ zrbD$*J+vCy2yKIQLi?e^P#H$WXlNF+1Zspzb!7y!Ifnfq5|xR$2DXY$Kp8p?(fc9_ zw+WJ8dmgX-#OHj(XTiU4=Xo5v_G9^)9mJz{Z0=6-bzVWf`Z9MSx%fF9e>TyPz~fe9 z0ItB#MaF}7lJrRPOx5_MpW(|A)aCGe6mv*={?go3L`w5ax~FG~K7Qurm$=v0c_mA? z#ud{cUv|aY#ze+NY8&T(`kryzro8Nm@8>`-u2uWFz=g}5`?`*MKEHh9h2L^2lhy8* zKf_zsvk5mGyb3%WtOiGeSA)_wHQ*)Sd=Ni6Bi!vdS_t0?d{^L8-!~q{ny4RtUkYlB zeI?YEtdl;xoxr$}&>Gs%Mra%K2(%A61pRM!YRA@2c81Kx?Z1&a{1;Y-3)=r0{L8OB zkK6wX*UnEkW{ua1#L)(gsBDA(1KktsdA>6yP`#EGwyR~&+PQ}|g?aH`*P>sw|UKDUCH$X5L+}W+h7h@K}**;_x{^V zW5KJEwp-1lp`6;T2G=8?sZcev3~GU1bbnd`YX5fT%C;b~S4P1;P?j3F=WSv7c1|~+ z@4K_7+wIG#Yq!sX`dvD{Z&Q4Y#G^PYT&x$0o#}3U-+N`c1-GJ!v!?lN?IC_U-*hw|lwBzv_1Ee}$f>{QIWDzVBr@R?n#&kASzAYud?}Tg-7`uX11RT-wda zAZ^I)bEPkKd%4v<$8%qO^7$ZrzuV7yAqZ(7m76z~jjg_QCf91W7lT)Wmx48*p40Ej z(suL8SAaKhjbFDXUeDFHS99G6D&AKFyc?X$bwx_wsM7b=CV`rp6ODm17d#qYstB5A z8B5;$NZ|~goetO2>Br@SdOv6k>k<0S+7a%_=D2!}p8DVG&;dJM)B|21$N8^%ZfmA% zLLIs-^7~a@(aDSq>%TYhrPWULRgG$zu01Hc=D-xj{Kf74c;kS0Z`d_0?RV-#w+8ps z2gO@8?8c@3yH7V{R<>j~TDrYW?~h0KIgzEgH8V{|fpq&%ic*`7|9qN0`P}T+dV6D= zSU*kuAEvx&r`g=4Rqo6r+0CW3=@XB!T}<}uyLaxJ9^C)k$o}u2L-twZzJ+iKWB!!x z0bGAAS+CAdx1OuaianPe&~xdsV$W&I?l}-W*O|bb?Ap|dxUUn;!KF5nuIusl+mL?g zNL8;~y#9OEy05I~-S2KrbZ1}e9o1EpOW__aY?{P<4L=*t4E1?V=PEvA(ALdnBz>w` zo}}aVk)T?HsBq@DH}#=+Y4v+=3e)h%Ms`6cDA8axHO8axB60W~I_4_*f@0GET; zf)!{!Kewds0&8vYajxekb7PuA^?h;L^~+qk{pox314lfL=k1_))`QZejUYC5Y9**S ztySPWunDXMv7z1jXynO#x3~>l%l!^;Jt({TO(5f%?AyS5!S{gof!_dM1y-;YUXiLK z&94PD7d9W71C1juSF)#|65PkNdV1+w<#jgr%_M)=`JqotyZ%xB=n~vqqJC>HkFGz> zXXGY=f6cYtAucB_dxuYP__x7?=jzz7l-dd(&W**I1a`XE)MN88Oq~llQ{Cz;dOoP+>G5uh=cVpmyU5R4y{2~=f&Z5YVmYj5aPHnq~lT-$3?`k zE-wzR7t@Tsyo>X~l1FwFw^^=mV@ak*$x8=u)a1qCbzSZ}^*D|@2&3x;@FZ}Bi$mW# zz9fl5_O;h#x%z=gma2l}+6kk2(c!}0n1oZk^7^Sb?^oepyzd9a`_(SIcwd#oA>Lm9 z6rU%13t{NO+&caMW}j52ZS48=E7Lr2Z8Ei+ap%*}QD`KaKBhxUpeATNv=!P3?T4O) zhSuQ+s)d@MEc77s2y_s778=TCk;zasvF8;+pSQ>$Ahy!E5cJ>P*Gv&=2y6FDKsfh#5AOdsWbyr27IkjoBPR<#1>)o} z6j|V^4t-9sI)ISs*u+@b;P)K5AOd2c)j0v`S)@c*wUElSO@9T_aPL<{FzKP=F9Y$ zZ)+DkPtHEq8iJVTo-;3%>EfjwU$3{pb0Iv>!_Pm5v}w*t@`%Im>P;W#to%HX$;HNY zhk{%*{xDaCTuwQfzXzif*<1hM+h^{)9Tj_3V0IBUuEt2hlUPkSkI}lqt%H0$PP;lS z?^}x^hi(mUG@J_B7BcxV<<=DkK zM`9p6buOLGZ_^n`9(ATmdD8#*I+?TcR36q>X>4>7qZ6fjBjoE!I;m?XaZmY?(>O^w z3q9t}IU$W%$zlztzEtBXwJlw1T=oEXL%6;rJZ}ZF{FSj&qTHR4aR>JEOzyI8i+u>? zP-SYoySDRa6t^$a+`g%}93~OpQ2dDhfY2i!;aX|^&13w-O@@}ycdmgpL61QDpd-+b zn^+HpYM^D%@mv`XtnTd$o{&l6e#voq7yjY|-~Pk*wM^e{z?b~mbJK6{e2%$irKH$% z>9@Y>uQv_%`b*_3+ux@n?b5_0ws~$``lfVht;T`a?`!V?CD*~!y1~J>$@al1URIKG z2Xb5g9J0g9|9GeJxA}5gLp&wQ)%`LFF68@n-_>+YTgt*M-*tGw`+i#oN7Xu~c5Utf92U;n$Lgf7qKYPN~ij|!Fv~h zf%0lP8{N9Lj2SlhT?cuYrJelbJ??AJzpjr`-%`P|8^N(4eT>_adlPsi*EiG0KjS^;YimxbqkZ2yQFhEatMzfULFBQG`xtq=)AG2qqoujKZ}ZxcQQVg7 z`_q+C@qPzCtpz-!Cl<;N9hLmrbLk27Kb+U)Y}3NEXYFm_arB(|<4j9)t5n5Yzj0<# zuu*eyM1I&H!$;JZUdic{*x!n9Ubys)`q21Uw~posx=M8?e#Xv#&h7>55x^)^-n5@! z7kY)MlGKwS?}}67uQ*)u>ZO?u?kUVN{O^P==lX|H7|prGVO%=6C%KD^-%-L&;r@lU z`Z_Cqs-w>pwlB7{m9>o%>%w62!|*WoUCR0`fq!aI!(ADAOJ6u9_=U|~)G?)*SL;)i z#G&vOMrl@DCnx2PeH_Zf$~As=cTYQ8vNB!T2T_yhaNp=Tk2nxTUL2X#9c-n@G+r#Lq1h!RUhIwnpe;5arKe=3O5}O zIv*p;^?Rf8;Z|Na_Ha373e!Xwo%JD`?V}Md)rVtvIXQb?`o`T*!ZF8|`o|DX?M8Ls zm~c)YK7Ur9Vl1V8T$}R!>ON%-cbW(He?RqO#`2(3`6fndgH@15RgAj!rEIfnTNS?g zRhllc`ng_$!fE_!?s53fGyc!PTJqQT;Pl-$g|{$f$K3gR&AE~u$=mF&U7-WI-4YCb z4?pde=3IwT*Pf)`3r#_kZhiM|Bk?E>3#W9eo)1adm79Obn=7E&6h2Sp3eF%rkE7?j z$A}PgUurxTFYilot#oL;d;{q?m+Lo#^vl26X6(QH&Q~P5tatT|@Wf&I$m&~-Iu2Ys zhyMh!`$jR@<=4GLfW71I=P!)EmEF!F{13qYapUi5bzS>$SodwNKGYkVznm!}5f?g5 z_xnlw{J4O3VU;N*zsdP8f#<1?oB#KHc>czCMtem1!>8;dA9tL$AHb*lwxCC%eLAJ^ zu{pqwz$buXdJsNm7@q}Q+A4KjXZS)ze|Q}TOyauw6uc^p7voLYf!B5V-C3pZGCf!q z48HMEIsFh`Q;nBuf5-f0wl{KQ)WU|YZuJM855z$e_12KNH${AZ1mDHRmpsmC z>z=ookED0$5XNiw}r3@XMRoZa$ajv4d|znfC{&Xa7~1JCE=C_9>*4eVVbypMF?X$Dh`w3EG_w$a;b-|$N$>MzjSM!|JDARu>I{zO_oD7*u$w$ zH}^EM+;6g6S|Ce2l~Q)rwpRy!p@}<|KZak$?V-&rWwSYUSz|x>j1B|hD$5l36Zo7_ zgpcIEhIAc*Q-9R>>Zse~ms0>Pxg|(k8LBVOB%-l~&n{RzNwsv3p+EiiVC% zW72r2&aTc>lE)_EPVw8C#!I(gMRE>d@i1G9dj*<-Mr3&$rv~7 z#=8V%=aDHDKeghU!A!#EAcao zH?2kAT?(1FdC%9HBo&?VWe*j(p9t71!p8_uie+=$6!7tkEuW;m@QFjA5NjZY=w*^!r+7KF?z>#}$mA zCbA>L&fgMuKhDg3pF_nrQh{+81zEj&qjp>e`SD%u-TZRy)k1O?;CBFcA*i-_5jY&Y z7*sjV0{y;7)m_y!$)MWB{SeRn7%c6^V_fpgwM+eUXX_|#=EBe|{(DEKg4c093|s;# z%_=k1AzhCH*;?iF0b8T8lE}-!%fjtWccauE6grpvwL03BR%M zyfESC#{s!-%EkPC;lfNz_<1`%CyO|Lzs9fh#D9XSPrr3x$GNhw`l~d1`#c?1PxIIG z2Aq&utNxJ51NVNo&d%`qQfEH-bnNH3x1ZC_mgdrRrF--PcNSr!w?>1ffcjRA>X_=z zXmA|YQ^4_{^b-50TwT+1=_l=@x*F8k71x4OPe`rHfHSz3ewhj03tj@Q1N9A@_2A{8 z_JLNQ~I`RFnh~ z0SN&^5U{jf6%{SEXsKFDE4A+Xf-O~Q(V}9dii)iZ){VAku|l{s>${ z__r?n3Venz^Onii2ae1?+VjRP9eDzwC$=2MJfN1Oc|hO#ISk*6f9-tGn(;dM?-SF< zRrhku8B=>RUbkg__v4es3%dr4`QL*_o7Ph zi}1_v_u$vyH{o~To1Me61o%n#CHR&24frkiX6N#(0e&KW4*nMWBlz|B_whUNP0k|@ zz5ri@Ux2>@zXrb_GbOj zJqq9bVr`lH{1|KU%he_Z8oA7O##sBrb4fT(jYLj$#<-2XE*bi4nUm#M<6j}U$wuxd zBj?ArO@~_}=5u}*V@DHSs?h~M06zgg9iPH4$N#_T)TjL3Z<#Yf*#AG{_gFt~=k^%b ztF)hRXHyinFMa6uq!ad`jZRl{N8xkgJneN=<9QRWL+!f*-sU@Q->PN5Zr8d@?+a7h z5qPUN{;sI(qV=bo)@oWK4lwgN?<#@K2%loYdXItLHKc2cgVJ;B`={78)r5Et(7x8= z-^cIx|5;m8IsMp~>$*W$|08*~&Eab@pFPzcq~zA(71y5+$N%s*{PFENy_aM6-{_Cm z15UgB{@*?W7RrXti-pgA@B8y1yFd5sZ7|*0AROBZu|fMR8|+KlmkqY6I+eEL47J~^KK6#7r(zrd$qQ`<)qtbJJP>}<8ti5F;AN@((D7BLbyHQf$$hO80vbs z0FHyh;8dt)+rIv~{?PJ*2wdw!{&Q0sz$un6)lXQO|l3$t%zo(1GLiRSmW?9Z6<^Wk*jv*%*u zZgR&Tgfls=Jy5Rg7u)^VfsFej>4JQpe)$eCd;+*zgPk`saA^4$q z?GX-!r{R@Ge|!PEXU7})!?@1Zp6p?IYYy%(&UJ9Vy0vpo@AQ20>^&xmnco^+kQ3$O z`{4`mCHMvSBo~hVt6YR|{9nkp^dK+0HPTtn|IH!3;`;M@Gq$S_?E84lJ1-Bg_bh00 z8DnWHSFD4A!d*(9S7qgSU&d>d+4fbt-e2T&sJ(ml4dOgo3p)JTYpc_t{VeYmq2nd5 zW14<@!~3gv{#xg&QyxE#*!oHyM~YaHna8_?GLx?gJ{Yt#7o-8vl8xFkoPH*#HJ zW5UN7dF=srNT;E=)@I3L5p$0ji|jQ=JQj68&e|c~7rq&tzPmd9|Kl#~|Mi_Yv=`^y@A&OeU1o1{Dy#pmC6eO$^ZUB~ z3)Xhs#`9>RSp=5q8H4yYenA|@%J_J={@a&5ggjp`?vm|kOwpQ4E*uAcj~$N8vctag zLD|uceRfP~rpX&e+fBPSiPOpJIBN#a=-OXE6qH^#que~OYu8wF$lv>T$@=(Odnlow zOeH??@*e;1IQPre;&9OFXTy+uB!Cgf8;e+=IR*orc4!b{f2_s=dfL#Fe|vu`|? z8cS=vr{{q6PAv8DSx%Q^RW+e3YqHs8mz0)xy|S?#yZ3&bm0jju>J&KEB5C(FWxhJ2 z%>M0%XBC&ti@zboGkxZVrjqsXecjw1)Xkhr=9+bFA@O(N3y8nWrLXuZXBht?!m`UE z;_k%vAiO+?kEt@^&*6bttzn6palE{AJ{gXmNvN)^{Bt1%u0w_G_#JHZMux4-L*b<* z{w+JsWGYWTY^~>XCGTa9aOLOzm1`rrU*D*_S?AN&H^xq+tM@UrCEf=vFG`nSAjfmX zs=X1j%XqO}dYxXKe(mj{XJzF=du+xYO?ff9>NGO_TCFwP8n%8%kmr2Tki3_v4SOsl z-8Q5vdmQ2N^1oq^5;utUQ`wz+7kiA!u*dMya`phGCbW-<wpD#=grl4-gg;=9YrH*pj_Sf0)A$)#@cIjH7vidIPbc47@JhqWsjn-o zmch6h_VvAM)ArdTKOXwE=`OeM<(_}qy+@w!^LZX;2Vv8#iJ?5Up`7cHlZ=n2;}bZ( z7SB2{`q;_)@sVpz*WcMw;H4jaybq64COav*0bk>nPqzep?Me3=huXfT-%4nl2<0o8 zqe|?P&OW>8J%}*gT=NLNjiU6|k>?`PR|c25^p!tN6`|ZEnzp?L&iVPs=W!ir=y{1X zE)CTiT{9z%>2^3`^=C>E>=DWF_b0s!VEAcctyW`~1o9 zmwi4xfBO21<#~@0OS_T;x>8^8z{5VJKIdb?AS8Frf)ba7P8>2eX0$_ z>AUq*I)+_?%JyNLS^B{;PV#D};W@^L3SQGYYIezt3ul;X!8(Vq(H3o{AZknNvf5H8 zyQj7!`8E_(@_!2C)$jLKehcy!5Wh)tJ8r1`s}F_p%KJi&sU7AM|9$*W!ud`{V-wSM zhK%-yl@`-W#&O!`NKTnLV9Lli7q)rTF~eHM`J}e3JQ+LC#*QQYEkQZxY8mpr9DZ!8 z&ba2+!`v4)PImC_Bh4#Lf4m+xLvDPzPh{nJBKciR8j|-iDzobDo*X~FnDMPohweCz z>%7`r*7?3V--F{ycLnLDNVkBnPuH(QVmZ^^P5d3iUqt*)#Q&?yyY#55hw-!PM*Sl^ zpHw$BojbZTMF}q7{A>T&f{oj^aMv7eeHJczs#B-hKOBLtORv|Cu-_+=t^K{yKA2Vg zqMtP{JKFX+GoD~#KXDlQf%n|d% z-P4HQm8f!)j&Zv0ApJ#9{c{RbHBE(w!&2BDPKS+Y-Fo-^Aw0>eZ&x*^Rr-C`6~wXo z2s!Ef2=&)xc)1GXrH294=$QvKXXrkQ%FVNf=3S=P%aoTP#XKwb4R|W&6(8Fgj)s>J zw(sX}OS{kKh@Lw;1wQ~koI39r4di}AJC6B0%I5akJ+2E^b|b%pG{Zb8tY<8*gYBTg zM?>XVb+DB1NWIko*TUHTB--8SCLHRt*T=~^zfT&WPKBlOW+bjifNfk@ZBFO4uDQ$Tl-2iK&Jmom*LZO|3;Wwcq`~xN zzL~6c^(bMrtH;f8eHTs7i^lzCQ;xqL%Q4qxMAcruc~^=4UV~hHsNXI$gUYM=`C7uV z+q1BzJFYUUBdm7xJRAnsL;6(oA}oO~!I|)7NE>o8T?(_>bW4 z2;T|cgp|p|r%dMi#ZSS_9Dl(bN0<3-@vHECjw2I&0N;ZjLVUCZ{ssOK{vE1ZU%;(| zzl5Ja{RU$jYzqGhTf@J>qv3Yg1AY!0V^6&|SFR~f&*)vQ@!y4nbuaHE`iq|Z)bqWJ zinylSB{_s=KkeUo2kcnV=j>pBXr_w(vIwt6O5y+Y^oJ>?T!9Nj}a7q4$! z+3#(yC62uY<5^4z;10sCGJo0cAgg`uq6`|7`0YumDf}9$?d0Uxwvz`t5SEQP!Fq(d z!TL~j-TbELKlRs~Z0pz<4XLSv&Z}sW-Ekh~Wv6T1(M%ixZ z@kI4!uVr%5*F#M>wn4(U7U)wsT0)iMFsO1+U#1*wV0*&(Q2A~LRRbzdKNlVdS!089dP-|VxIX`xB zJ@3}|^lAQPl%GU>~p87$RZvfO7b~5Y=Plak-1L4VVFf4$> z;7B+es-8wb<~dU?wG)LegyZ3CsNYjCPnd5LUjfe|tUfvss&AePSHel~ekgghG1=)Q z$ZfUME3g>80jIz}xbyG3@LypG#}Aa$1ludOHh9rt#`Qj6Ag%JIbMLtE@= z!oIFF&)W52j#-21r0PWNL5_Pd=`p{N3$si#-#ON}IhXV5LzVD&cnOq7*-CXJdDYQE z*dbkpeDbRN7vR-Lx)Vcf#6I8nIe%+JufmimUVKD)8pp5VeP@S4{f@-0 zF&1L4_Wh!ovd&9g`FJ19;CVB2n<}kVI#tm4)c=HT-YYS^ zvUo~aX8+p?D z_4G4)oaL45PnDK+%Z}GI-?qS7X>EFDj=T(>QOR~MIk3;e?sY%vW(C!cwZBlkXCw~X z<1-S=+*nZ{1X?{k6A#PrTXg70 z;bzRMK{@>Wvvp2~)^OgvjE(}YqqwAG@=)G+Uomc8S?Rt#+vRQM@8k5UYc+(rUP0Gc zURMPlOuM8sRL6>F@1K?M`h3||Cg|IUzUf|{Dcgb>m9}Wr(&fw6#7#_L*99=rUa0Ykg zs-w%do23c5-a^-b54v&El`l|NBYnFP^u3L~HeR2~W?sE(Up6B<)TDf64V6M>n|TL) z-Ml_mzEEXN^leViw;6r+?v|dm$6sl-OKnM`Y!SMd>J!UR;!F&=RFBJ-$&;XuQRiZHL|O} zrrT?}zAp!0T06_1F?0)iiH_BAeCeBi^>T2k&0a zkI?tD*XPQarLtN&{hVKxpmPg4H+r3>jP%CBLDkaZ*G+FG==mdhKJGF0g z)aEHJoDctmt{q;N$~3-o*4T>DlA)LIKqO!GW7@BlPTxk?CFuM!I_o}^IbS5Gt(IQj zMtf=V4HuSmD|%aby{4=S%T-oBVQ3aOHEE;wB&q;oS6Qtx`Znudm>ZUH8#;@;&Y+Cr=S`hjT3S-$ zHoHI@rCDv~Q*>5%otfnf)mE#le$08_={>-zH~;<>y^Foxa&~&mrd0L%r2lPeK{KnM zMWE+z=(*bKDW1bip-ZY&7O&%;1RdMav7#1rG}28~oa=h#@6XWjnAb6tcPjG|_v-X( zUniAL$3Z4_`_Jd-__fzjQ970D=n9>wiJr|)&ntnRzoX|>uV<>APphlP&o?7nr5_pS z*@2#w54-W$={b|ns+U!>OkUS2r>jGt>kD-Ksup$m@xDV#tHfPGo4`NN^^w=bp7oI8 zxuxTIYdt@qxrFVNYSovY*H$Fx`zQK7*^|CPy_CPWY;HC6`u3RH%9hhDsZC%fdOr*G z&MuobtGs&U^Lomhp2k+4`S)Mw`O@p*_t9(sS6h#-x6MvZSa1JE&w-D)_NaO@-FU+6 zvBl<<_SLF4-zG=sW*jcG-+$0|NT6>RQ)M~7%uu}Q^l7haRf4Wv=xQ72I<0)pyvo7z zF1(N-q$axZ^-v2gwBwiPIyzfdHNMxJz1O$Y>2g~-M(h5*XHcYu{pv$+z9ZpwR zUtgoEpVvkEFq<0WqB{2TdM4?HIxf`1?r+_KK#y*;C{A_s_%^ZL=?Uv82R&m$J-Y8? zf89_mUB|d@4s@}PS(s<_lyA8M&~>)gRn2P`Z?kPKeLctHT^-WD&8I($Z(g|dik`LX zO8nJ$#rJXa?4)F$45o3OjdW7>8BXnkgy;3!jUn9W)78n|KQn3T*0*K9P8r))+5_eM zol6;xc+`zQvx+Nba;!Ra?scqkI>P>vhmPZ89hFn3*GxyNBUFm`eQ)}^E;{j{yo zU3!YI_7%pTL0Ijox^2t%k4Ict!g_B&S$>&O7WQP&SDp6d^|Z<-0bIDwIuJe2)v}&c zzEQ(dBe83Uo{uy1j4LjmR=quDU!JW_kK0N&${L}k&1304Nq?!ip0Vw0Ih;BZXpEkY zUJnCNnKsOE)u|uf|06x5h3jZx{yhjiL%kmEtLvcJ^aS#>0k63Jd{Ud{`C;Pk-ge75 zQPXxi-Q_oIw+EBoi+p~W-zOAL89(FFn$`10rze~Xo1mw{>tSxMi5_qNUPsBgnR7co z+NitG>zPwrJ_Ebeq>gWKIu5a_%)d?1aaAqo@N0)$*TKUz%Ax4E$?K>vx9W!K7Me0p zo$`2HbDXXdgYq;(*X{oUx;7{1YL2eWnY!F9v+9-0k1YkR6B+}#vb8{0i^tvAQc-## zzaN@jUHf@G4>&z~=Fhv9=vfl$p%>W&a&_v->uKf`gx6`U(DP6&>sgeb=P>j6wbQXM(7|u- z>n`>>bPZh#dlFt>7Zx#c;kexveP4$9YVlfnxziW6y(7?<_k^<{<*Vtnv~TCT5_BDj zuBL&m+PDrZIojH=nT7c`A3a9~dTMeV==ZhXbb7*l#dhd9A=DFJ2M#GKo;z2WsZN{s z?PJ6-woqaFXphc8**eX|RrTi(udmm!R-b*c+WvhM`cCuuD*0BS-xp(|*E3IA0~IQt z$V$$~_1B3{1?&1s*~e9equW# z9w;}?71{jVfwJmDAvp@|p{)H7*npRukE^m&a$r4PWw|jZi;`mNF}=*twQy~f#rL)8 zt}JOK=Ym5%ZsWkRC5B4v9dx4%cX+3;+t5oldDX-Ld*`rCF?&C0vZDSusvzZ|dl zK8|nGz0>(Kzh5=KyY5cByTIBUq z<}Z_$c~}3b z$Ta2H2&i%3G?)*mpOlss7eF<`BG?ZW!y%B1$y6PFH&%yHr4GN7sl#tt>O`IJEu&oC zI+Dw8Vf1}!<$D6&K1Z7q4dQRPJUlv$DGhGFk2>Cnq+eOv(Gsu%iZkcMEyoBw2OUSFj^E&!dKdNmrvB*k`LxduCd=LKj-?j9#6X6v)h z*U02efGJ!WVwf&oS5A{?Xz*oat}K>F}r=*XWNqHRyjE_yS>lQ!e)-99&#EXNwy$cc?<*L`T&Ud}!PmMpi{$%zf=x9Uk= z&OXPLEcc9)6C3lcfC7HQ=;iElSjlqFJ2|l-V~a)#FK3^pN|t-U$%*gjFRPEcXDEAPt9|SY3zCz#{v8; zmxFI*{<7cP>+IUd0FK$`d~#UxSyu;W43>L`wClrnq2}WEU@pIk&5N3)=XIrFpW{hR z<0F^GA6*)MPDn%g>~lIfk>+MO<=xNOe?g`R;cZ6thz#BK*_-6|4{s;F))b#XttqJg zR4%`M*Sf*4OWx$TeXb@adWFB`q>K7D?jKHeCzK8T4ckHeR`)2y$ca+g7d-$Lz+8Ab z)cHbKpYUX;-^H_DiWxsEl=fgWs}D`t**K9;~pM& z0`mC1d|h{Ex-NB*OU>o+UJ|W?4RYYb-hf0@6B|`291|v(N0r-}FjKucJ#(zo(a-^!xcZy;IWZb>N_VE+=`dd@ORg zZmq1i_L-XGxZO?McBY>zu6+(B`TfxP{k+zYeoU~>vgAZ+Cvsu?JCV4JICheeX`PXG z`)o>beoi&WE+jcF@2n^9ZPIb=a~;Wf7;WOVNSD(-my!IP z9{tw89_7?;{c~w|z75Hi_8E)h{OBD3>Ql0%;@amVlH*>G71uuNkev6aCa$$#8R^<* z75F_lf6FPaMfwA$_XFg@i(o^@`&iac5RbdzT=7Gr=cshsvCk+Zx1E*5Rek)#$Q+t(JE|-D+(GhqaVPN` z5a({#7TyarUfgHWX+?g=li!0f(zDMPB&YWfa;l3*TzZeW^d2|q9YK0SGSXX2T>HF0 z4r>eRl%ECe@1G;5a;=6st~yiudXjK!xCR~%pN74m;`Mht8LlO)zH}fqm$T#daCk89 zBx^^lv`Lpu?b1FEkZj|1q@}z(XVPSshLWhy$;Qt;YUh0QKRNXUKgPdEeC7QmC>#G4 z%Em97bY$ak88%UR_C7xE1LAMFFum81Ys#@ruq*r>>7POhWv$SJ+gjC|Y=l%~Cxojlfk;o^Tz zJn69aqvJ6&oR4-9S8ebsBNO)x>A1?3)vu$%{@myQl_}o0u=k3Sb?_Qqqk~tdB9osk zzs9B8oeqs@a(Q^!S&sL++jRt#J=I^#dV;X}MZQT-{ZK7Ovhi9#Y1{j}Ib6M37pAT6 ztg4-K&Pw}Om-cb#w7VJMyl7xL-fzEp0je$af_8K37@ZHn-(D-WaujWKo+TP2}fCR_@qz$;)0)VjHe{$lr3I{^_Kn_Avu$9WfKC4$Gj%b?Mi9F^BMZ z@M5Sm=R)bOO25it@5LsMBlAf|`WKk=;_*y!c~96eF=?&3i1@1aZyLGGxy9ZeO|JLL zo!k{hF1|j}7;Nu%@_iKkmJ7$=tBJ2`tZSg!@Dd~6g!0E@pYm+)WyaTO;dr(b8I|RF zBRe?VMkHtNM<(0o2I9*`HyXK)X*u;fd#^BuT@CBPes>G;WuseR8~8)0G3v+gSa=)E zWv@J!J=Z+O{yg@x^VmVq*sL~Z@6F|y`*Z|}7tgi&-f$Db_rs=8-x*e)e%PdWl1r~! zIz5fq_Fh`@8cg3E&SiIBx{L7kK35Jc+&bA_<&}GixU#F-rt+k36RS>iyrpA4{3YRV zJ<^eVdVOQsk6S9Ey)PBNUotG?GstU=^(<7I_%$32*Fig8HN__J*sJvHJ*4FH)+48K zya)%v-?;Q%GU?g0l&;U8Y-aBXxo=Pr4(GW)Am`(5=bXK-lM~&~-*T##E#@zC?+{y< zch8%$92eQPzzmY=!g1DiW^F@TOsOyQfWu%J+W;~$%rLG{% zSZLmt#@Ly$dOtq!fN4tIKNc!;CU>9{xuKN5dB zUhzhfQv5CFahj-b`d-W0DZH}_zXM;N3#)v5FMJ`s2)_Wo9RC1*1AYr$FJo(k?}s0Y zpN>!ASKwFSH{rM8o0RemReT}71iuu22YwxXGkzDo*@fuC7vksOm*5}3ufuP}N7Go( z;|Ji2@C)!O@T>5f@jLL%xX9~@AB&%kUyNUYUya|0-+^y513mac{2cre`~&!P_$~Nd z_P%J89s%-1^)nk9sW)Hc6@y(3<~egJ*~z6`$@zXHDo zzX`ts--wstb-@qBPsGo`FTtAI z3EacC{&HQF*7uo%^T^*5S^3+S=LJ+gHL_dgqQG;hU#G7 zzYEFCpVe0UcXrmfwla{kz5AH5Eb?U;S2~S1yOmZH&gNZyCH`%4?oH_x7XJHkCz#v0RIcAIB+dir6&-pLG@2%GNINd9J&{D&b=gL^JhKpNzbZSAToK zmB-gdD9igdP1)KiI+mzocOdd76eD=6`{Caxd ze?OY7Pv3Ww3-xV7Urv$hhtfBstfE&9_4()V)~GY%x>%ThKSf`?P@nCrrj*Ppq zrPllHpw|1kR@8cb5Tre^XR7b`o{lfT_lW%af3-(p`#$Rx{+836SEN61^c6FQ}=F>)QfydM|r(o_cETu3Wv&Wt_A9FDKoPb=|U9LO53b zX1}h`q-E1?%5jBt?Z@?5>KHf{QdXmzYZh~!YY_9z1MO>IH}W!`Yg-*vz3Sb{y~qz1 z!*$_Jtc|&+;PcgiW46ubq}wJ#hPwk{zqx#96yKAx?KL@WDY|{!5u{<;5bHwzmZNE< z_p~dB+mJ8=fw{(=2b&XK1noDI_3mcvuNS7j0sGkL%9$N2B0lKc3f~=HgkOMPiC>L> z6TcnbWC6PI1^EA$ob2q^f16yv)xNzO%{PdTemZ&mr*^8i{(Lz9@6ETM_w+s2+E@qp zGWB!SslMsm7|PT=t4#Z{W|U3rcxC6@6$v`V5~qJH>hSaWZN3oj40H_kI)=yJ1Y1dd zG>yvD+1F8&ed&{P-dC@r5iOP`P8aHKVp+Gluv2Cqq-#``pUoYut2%ZkJAxOlg7 zJooSY++v@n_Vuf|g}K4C@8oL&MoKfcbcPMM_vgn-$=NoRd>^c<`_{GQpa#*A8FIGW zB+D_5UtXWIwb#@D3weDTIA-fQ$J9GP?m9-%TK$0=Wa4w50jdEEg{|Q**d8(ln>j;s zOHab1pk@WlC3rKJoC(h$d_EipFNEXaY^b?Jd*Z}NT@KG7pL%vr@8&-w8i?=4_}riU zxO^AxPPhmDbo|NA4~7Gf8Ic~x3-2W{Tt0phWAhyR68sAMD*Sr<`}iIB|8x6p0rfAx z4qT>=gbT<2qYmUdQsdnCpY=Oa^=rxNo3)bh@xpoF6uraRyw$gq_AV-6sHweX&K(}o9)pHOv1!jC>6K)L!T5Bxc{c!s`k zP{qscT}0%(&SAw|$M!+5+eYgmozS{M2KvQ4@`#tjXo(T>FF?sc)g99LRatf9BK zY|I?qX@&Vr@4;Nm`bV0{W zwWwpd(-D^AXms3Gi#j$Wl;aq5JXDK1x;rC<YL}=@EwqCHo>-O zUAu9qr5okxbW2&Bt1s2GKkd*)3~sPdVE;ajG7omTBW193u0FM6%1!%>)*_?$K90(* z;U*`Yzs!9?ZHm3 z9Jk8Tt{e5a*y%R)sc+zLR(9D*-kKq!_&$#8qOu*3oYvB`jlF4AL;Je zh&=?np27IF%b%|QRiB~k!ggrR18BXZ4X^ogLd$bs5Ul)TaI&56cfCVcfeG z=HKJ7>8DONH#nxvn93|#F*NQh#8Mdx$!8JrlJ)U@f2fnTZ>If@!3L_n@O**_V@l~* zijFSmI1icQC&q1Cb_~;?U-b9(_qLSmBxGgF6;4*;jcggp*3_1M{$Az=@T*AQyYATX zH%@mnhedF?>}c(G3wfJ_jN={;o&Cb|>13S&WVa2ZJ(09k_IBsQ?MQYD zWoue?-;UmIqJ%TsQ4h*K#_9I$XyWY5hNQeMC!Y@>uXg0)dpmF+Jv}dkcIf8p5T1AK zC_{yB6VkH@J(cKDTe`vJOL}CJFdf=b4?oEIwj|kmkd-~Z3hb%26w20?J-fR_;5(%6 zT~F-Ul?_HS{JFvoDlf_Cm@4NM^0^DEN!G{r_ROoop5gf<6`?&lpkp0gW85s4FK^E< z9of@QJl>v?-HDey-*U3PZ-%n9WlwW623>atbH@qTv)*~mo)zf}hTZJhi@GS}5=gQ> zzRH&@(~+#rJX4{?vvVRMBta^O^nDuN}klUaf0N zM)y{9uiysjiRe0LN^DoHlR{bgYtQUHC)qcV?MvJdfvoy#wrqBvlWa4}EWMWnvg)td zve|u3vLldHeKwqG^Q`(*e+^}8t3Fp9PQo~@Bhs!f^*O-lj^@mspE3WDw-hpp@8hUG zC46AIJ~Qh}=aqbT-X&|Q%gleIJA!o2Bi^^1Zpo>xLOJT{gzT|qHL{D4)tcdulGtXd zt5CM4HuH1XvbH3Q`$J%}e%S0(r#qTgUR<#-WBFy;<7)Ca30cYcxGJOiLc_G}lIO7a ze5P$XIopQkv(%?;yaW9Yw6X2-R+m?A<4|5U&K{E`yA@gW2mLNVMVG8>oGqI@CQG&h zS1aCFkRM`!uSeZsYTrb$g7f+wlBu>fL~+JZvNni^+rf!N_TGKTsbE)2OMf z{JoOp`PM{316!Sltrj}nwjcO)l${UOlD{J4B;(`xKG3)dJH_WS?d1DFc;55@uR5^N zPW0vAe2`h$e!aRyA9b>k^Lf&RUgQf&7R{W+l6vVZ?EZ@eIQ#ldybdv zBxKbGu6MG&4}`Kctye$CcWsX%TzySC&YeWPKJ9czbM+B7-G_4fKlxk(x3lqm9NARj z2USt0@%hX;^>ci9KCL#W&kg8ai|!{FOkQ#MQ+rUG&ycm>f^(m}?A4vqW=tM|>>B)d z!atg6>qXb7s?$(@@+>Q(wXt6xOZN_BRWIM4756udYoTmS>&4&iT5uEzKbt3tk40)a0A@}NAnL3SB_6yeXEyl>N?{N!0y#w`S~S0pOJJh9xWjKv81o{@p&#EzV1T#%)0B9uDdspFGT)K z$~D)?`??F|8IO!iI37v&Vq|6iDHXB(a|wsCHMPI*Lj_$(7#G_ARP6sfr<=WU?zjxg zs06jowdAo0vXb+0tEvOvhr)8~p1iFH>DYyiH!+0j;SQIds_UV550yvqMaXW#s~+@w zOOoNOCw4pv^FSXmGGRSPcO%NDdboe?|6D!z`Fg@JD8jwMSnu6H>S43f9r2xoQtsGH zEwyDELEiF_QG6dq_OFj{({vx${W?T@C`spK0AGLc`OH4#=kxGkllix zOt^7n+#c#?$xohTWy1C#-EFY9+QX%n#OQjwNB-rxxblL9~bao$iQ_ zEtD>>?-ZA9CX%-a$SA&#GI}n8p_G0*?UWpeZa|{%Cp

3%UQ*r+v)2Nb3BlR%dxgaT=dhe6#ru&k@ymtGa6CEdQEvE*6_F+skRa zqxtP(ms&ZhuSg$YTk2Zvs?JMYAJvD{N9$v9FUx(b%0ZuzaYOo?dM{;bId*H^&&uDn za-bbn_E~iro64a+vc8x1b1W<3csQ4@w^e&2_1(7Gy!T`YK9sLDe=g76<=9h>W8^qn zj-_(^`}4nl3$*wD{dte8`9%9TH|m)6*$({skFR|H@8GIA{2*!b<&szB(`?n;udYjN#ozR; zI`^w|iTiyueU;x%RK0Iyei=i)5*t)yt60fWDSMgNuE~08dyV$I;a0t|R#AJCizSc5 zFgo^P9<}CBw@!PWfK0Zko?^PH{@ine;nNpHMZIE8qQ=>8Gd8PxQsvRsT+ef;xm-Er zXK%5&S!?^_0_O!?D+^ZV{)|-Y8p)^fXm+Z;%GKMew)=`$tkyOw(`9YJwo!Ri8?>hd zRuk3OV`dp z?k(;!SB*vg_c6|I|2JM=J%% z=LuD;DIn|-sx|7d!jMqKK*K^6;E*-d(o2Plh0BG??{&f@A`7HU^;>BwE~tJVZ(ljo zZ%v*iM@q)xgIl`J)?cKo8Yja&u4~=z%8zQ_>(xKxvsC`CbwKO8_tjeED$&dNsd#QHZYq0@rDEG5^%XyApKKFJtMj4!_f}H(D<$m+IeJ#C zRpv@6?!%SeM>z5*t;9`rT9Y(bhRj4^h1u@3P-4Ynlh;cu9`;<@j8VO@ATrJUQmbaf%#EvT{>2s|G&*xZIt}&>*&|Mri=~5W@oJonJ2ZsH~L>GM|%fg z&9;lNp_H?SR?hc>QFnhNus}N9cPU33OVBne*Uar>iR$}mEICc6-g#M9-d<7pwv_|t zyE31;%d~a*8Dg)V-D|d}^UB|(YqwS7NT-ZZ+WmUY9=KnXuWRI9yi<-R<#=6=59R21 zebxK3{rYQrDXZkwK0WgLcoQ3a{r>MwF;cc#di(nCLW%9Vj$5)=p3ic@GkY!{!L}Z? zu9CF#?C`nr?FtJ*r|&%bc=^*NdGo7h&s}y?|J!-?Arh~QEDrW83`UkL4lLMt_A!yu z7lh7`>o<4N4}%MPPTza)fb$IJUXJcP_6+W}kL=&o{q}8QNNSwH=U?}kTHjEy7WGka z1?_Wyw9PEjs%`Ua?j_Z>?dzC1>gJJ;%mphx2a1hZD?{yNz4BMDfwO|jK&@lczEu4! zsLG?+Y4iABR-MONzhAD#LTw$hGF|cq&pk`|RQ360=YX}pb`I)ZRr^%j3%b^Qq5P@4 zO_ixWo5^z)6$6rEspvkWr#fO@kwvoJQo)tgh z!?B8w<)TMh=vK6)itk?_hx*thkDBjfPHW8}PT>wB%ly1l{@vOaA0Slo!9l|PL@(=s z)^o!%g_5>ZFVFAv5*?T&y>^zIk)rxQ-d)nRSkWi9i?xzk7Mn`{+gXk|a-1l~IdWVh z$NyiS_WnPgmDr%IGPg+V@-tZ|v~K_J@cvg?@~eAF`%aN}>D$;=#;szrjy$YumBHTy zXuUt-k*MsF#fugkx?s`yyYwwoyQXh;Zz6{C)v|A9AKtF5Z21o3SzX_-Y}Mc1m%Qqk zuJWPfQ~gc3yk$jyllK@FhvemlP(bOwZJ*NWeN+dYA8o;LL7N|x&q1m8f#0m&tzlB- z`7Ujz#lP0!Evov5_PJf^aDr9`&$+E{hfry%on}j&e2@XQjhk# zwXOYRUEK1czL#9RZ=%MHlUbJb%&XmA{;pO2Zv4CNDYZ7 OUE59S9eGKZ6{;%eB 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%0D0Ju7;o3` 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%0A{emSK`E9>sxfTDr0)AdY32Vxf-h|sE64M|FvY@W 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 + + + Spring.Core + + + +

+ An abstract implementation that can + be used as base class for concrete implementations. + + Aleksandar Seovic + Erich Eichinger + + + + Defines a contract that all cache implementations have to fulfill. + + Aleksandar Seovic + Erich Eichinger + + + + Retrieves an item from the cache. + + + Item key. + + + Item for the specified , or null. + + + + + Removes an item from the cache. + + + Item key. + + + + + Removes collection of items from the cache. + + + Collection of keys to remove. + + + + + Removes all items from the cache. + + + + + Inserts an item into the cache. + + + Items inserted using this method have no expiration time + and default cache priority. + + + Item key. + + + Item value. + + + + + Inserts an item into the cache. + + + Items inserted using this method have default cache priority. + + + Item key. + + + Item value. + + + Item's time-to-live. + + + + + Gets the number of items in the cache. + + + + + Gets a collection of all cache item keys. + + + + + Retrieves an item from the cache. + + + Item key. + + + Item for the specified , or null. + + + + + Removes an item from the cache. + + + Item key. + + + + + Removes collection of items from the cache. + + + Collection of keys to remove. + + + + + Removes all items from the cache. + + + + + Inserts an item into the cache. + + + Items inserted using this method use the default + + + Item key. + + + Item value. + + + + + Inserts an item into the cache. + + + If equals , + or is true, this cache + instance's value will be applied. + + + Item key. + + + Item value. + + + Item's time-to-live (TTL). + + + + + Actually does the cache implementation specific insert operation into the cache. + + + Items inserted using this method have default cache priority. + + + Item key. + + + Item value. + + + Item's time-to-live (TTL). + + + + + Gets/Set the Default time-to-live (TTL) for items inserted into this cache. + Used by + + + + + Gets/Sets a value, whether the this cache instance's + shall be applied to all items, regardless of their individual TTL + when is called. + + + + + Gets the number of items in the cache. + + + May be overridden by subclasses for cache-specific efficient implementation. + + + + + Gets a collection of all cache item keys. + + + + + Abstract base class containing shared properties for all cache attributes. + + Aleksandar Seovic + + + + The instance used to parse values. + + + + + + + Creates an attribute instance. + + + + + Creates an attribute instance. + + + The name of the cache to use. + + + An expression string that should be evaluated in order to determine + the cache key for the item. + + The cache key cannot evaluate be null or an empty string. + + + + Gets or sets the name of the cache to use. + + + The name of the cache to use. + + + + + Gets or sets a SpEL expression that should be evaluated in order + to determine the cache key for the item. + + + An expression string that should be evaluated in order to determine + the cache key for the item. + + + + + Gets an expression instance that should be evaluated in order + to determine the cache key for the item. + + + An expression instance that should be evaluated in order to determine + the cache key for the item. + + + + + Gets or sets a SpEL expression that should be evaluated in order + to determine whether the item should be cached. + + + An expression string that should be evaluated in order to determine + whether the item should be cached. + + + + + Gets an expression instance that should be evaluated in order + to determine whether the item should be cached. + + + An expression instance that should be evaluated in order to determine + whether the item should be cached. + + + + + The amount of time an object should remain in the cache. + + + If no TTL is specified, the default TTL defined by the + cache's policy will be applied. + + + The amount of time object should remain in the cache + formatted to be recognizable by . + + + + + The amount of time an object should remain in the cache (in seconds). + + + If no TTL is specified, the default TTL defined by the + cache's policy will be applied. + + + The amount of time object should remain in the cache (in seconds). + + + + + This attribute should be used to mark methods whose argument(s) + need to be cached. + + +

+ This attribute allows application developers to specify that an argument + of the method should be cached, but it will not do any caching by itself. +

+

+ In order to actually cache the result, an application developer + must apply a Spring.Aspects.Cache.CacheParameterAdvice to + all of the members that have this attribute defined. +

+

+ You can specify this attribute multiple times on the same method in order to + cache several method parameters. +

+
+ Aleksandar Seovic +
+ + + Creates an attribute instance. + + + + + Creates an attribute instance. + + + The name of the cache to use. + + + An expression string that should be evaluated in order to determine + the cache key for the item. + + + + + This attribute should be used to mark methods whose result + needs to be cached. + + +

+ This attribute allows application developers to mark that a result + of the method invocation should be cached, but it will not do any + caching by itself. +

+

+ In order to actually cache the result, an application developer + must apply a Spring.Aspects.Cache.CacheResultAdvice to + all of the members that have this attribute defined. +

+
+ Aleksandar Seovic +
+ + + Creates an attribute instance. + + + + + Creates an attribute instance. + + + The name of the cache to use. + + + An expression string that should be evaluated in order to determine + the cache key for the item. + + + + + This attribute should be used with methods that return an + in order to cache each item separately. + + +

+ This attribute allows application developers to specify that each item + from the collection returned by the method should be cached, + but it will not do any caching by itself. +

+

+ In order to actually cache the result, an application developer + must apply a Spring.Aspects.Cache.CacheResultAdvice to + all of the members that have this attribute defined. +

+
+ Aleksandar Seovic +
+ + + Creates an attribute instance. + + + + + Creates an attribute instance. + + + The name of the cache to use. + + + An expression string that should be evaluated in order to determine + the cache key for the item. + + + + + This attribute should be used to mark method that should + invalidate one or more cache items when invoked. + + +

+ This attribute allows application developers to specify that some + cache items should be evicted from cache when the method is invoked, + but it will not do any eviction by itself. +

+

+ In order to actually evict cache items, an application developer + must apply a Spring.Aspects.Cache.InvalidateCacheAdvice to + all of the members that have this attribute defined. +

+
+ Aleksandar Seovic +
+ + + Creates an attribute instance. + + + + + Creates an attribute instance. + + + The name of the cache to use. + + + + + Gets or sets the name of the cache to use. + + + The name of the cache to use. + + + + + Gets or sets a SpEL expression that should be evaluated in order + to determine the keys for the items that should be evicted. + + + An expression string that should be evaluated in order + to determine the keys for the items that should be evicted. + + + + + Gets an expression instance that should be evaluated in order + to determine the keys for the items that should be evicted. + + + An expression instance that should be evaluated in order + to determine the keys for the items that should be evicted. + + + + + Gets or sets a SpEL expression that should be evaluated in order + to determine whether items should be evicted. + + + An expression string that should be evaluated in order to determine + whether items should be evicted. + + + + + Gets an expression instance that should be evaluated in order + to determine whether items should be evicted. + + + An expression instance that should be evaluated in order to determine + whether items should be evicted. + + + + + A simple implementation backed by a dictionary that + never expires cache items. + + Aleksandar Seovic + + + + Retrieves an item from the cache. + + + Item key. + + + Item for the specified , or null. + + + + + Removes an item from the cache. + + + Item key. + + + + + Removes collection of items from the cache. + + + Collection of keys to remove. + + + + + Removes all items from the cache. + + + + + Inserts an item into the cache. + + + Item key. + + + Item value. + + + Item's time-to-live (TTL) in milliseconds. + + + + + Gets the number of items in the cache. + + + + + Gets a collection of all cache item keys. + + + + +

DictionarySet is an abstract class that supports the creation of new Set + types where the underlying data store is an IDictionary instance.

+ +

You can use any object that implements the IDictionary interface to hold set data. + You can define your own, or you can use one of the objects provided in the Framework. + The type of IDictionary you choose will affect both the performance and the behavior + of the Set using it.

+ +

To make a Set typed based on your own IDictionary, simply derive a + new class with a constructor that takes no parameters. Some Set implmentations + cannot be defined with a default constructor. If this is the case for your class, + you will need to override Clone() as well.

+ +

It is also standard practice that at least one of your constructors takes an ICollection or + an ISet as an argument.

+
+
+ +

A collection that contains no duplicate elements. This class models the mathematical + Set abstraction, and is the base class for all other Set implementations. + The order of elements in a set is dependant on (a)the data-structure implementation, and + (b)the implementation of the various Set methods, and thus is not guaranteed.

+ +

None of the Set implementations in this library are guranteed to be thread-safe + in any way unless wrapped in a SynchronizedSet.

+ +

The following table summarizes the binary operators that are supported by the Set class.

+ + + Operation + Description + Method + Operator + + + Union (OR) + Element included in result if it exists in either A OR B. + Union() + | + + + Intersection (AND) + Element included in result if it exists in both A AND B. + InterSect() + & + + + Exclusive Or (XOR) + Element included in result if it exists in one, but not both, of A and B. + ExclusiveOr() + ^ + + + Minus (n/a) + Take all the elements in A. Now, if any of them exist in B, remove + them. Note that unlike the other operators, A - B is not the same as B - A. + Minus() + - + + +
+
+ + +

A collection that contains no duplicate elements. This interface models the mathematical + Set abstraction. + The order of elements in a set is dependant on (a)the data-structure implementation, and + (b)the implementation of the various Set methods, and thus is not guaranteed.

+ +

None of the Set implementations in this library are guranteed to be thread-safe + in any way unless wrapped in a SynchronizedSet.

+ +

The following table summarizes the binary operators that are supported by the Set class.

+ + + Operation + Description + Method + + + Union (OR) + Element included in result if it exists in either A OR B. + Union() + + + Intersection (AND) + Element included in result if it exists in both A AND B. + InterSect() + + + Exclusive Or (XOR) + Element included in result if it exists in one, but not both, of A and B. + ExclusiveOr() + + + Minus (n/a) + Take all the elements in A. Now, if any of them exist in B, remove + them. Note that unlike the other operators, A - B is not the same as B - A. + Minus() + + +
+
+ + + Performs a "union" of the two sets, where all the elements + in both sets are present. That is, the element is included if it is in either a or b. + Neither this set nor the input set are modified during the operation. The return value + is a Clone() of this set with the extra elements added in. + + A collection of elements. + A new Set containing the union of this Set with the specified collection. + Neither of the input objects is modified by the union. + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. That is, the element is included if it exists in + both sets. The Intersect() operation does not modify the input sets. It returns + a Clone() of this set with the appropriate elements removed. + + A set of elements. + The intersection of this set with a. + + + + Performs a "minus" of set b from set a. This returns a set of all + the elements in set a, removing the elements that are also in set b. + The original sets are not modified during this operation. The result set is a Clone() + of this Set containing the elements from the operation. + + A set of elements. + A set containing the elements from this set with the elements in a removed. + + + + Performs an "exclusive-or" of the two sets, keeping only the elements that + are in one of the sets, but not in both. The original sets are not modified + during this operation. The result set is a Clone() of this set containing + the elements from the exclusive-or operation. + + A set of elements. + A set containing the result of a ^ b. + + + + Returns if the set contains all the elements in the specified collection. + + A collection of objects. + if the set contains all the elements in the specified collection, otherwise. + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + is the object was added, if it was already present. + + + + Adds all the elements in the specified collection to the set if they are not already present. + + A collection of objects to add to the set. + is the set changed as a result of this operation, if not. + + + + Remove all the specified elements from this set, if they exist in this set. + + A collection of elements to remove. + if the set was modified as a result of this operation. + + + + Retains only the elements in this set that are contained in the specified collection. + + Collection that defines the set of elements to be retained. + if this set changed as a result of this operation. + + + + Returns if this set contains no elements. + + + + + A collection that contains no duplicate elements. + + +

+ This interface models the mathematical + abstraction. The order of + elements in a set is dependant on (a)the data-structure implementation, and + (b)the implementation of the various + methods, and thus is not + guaranteed. +

+

+ overrides the + method to test for "equivalency": + whether the two sets contain the same elements. The "==" and "!=" + operators are not overridden by design, since it is often desirable to + compare object references for equality. +

+

+ Also, the method is not + implemented on any of the set implementations, since none of them are + truly immutable. This is by design, and it is the way almost all + collections in the .NET framework function. So as a general rule, don't + store collection objects inside + instances. You would typically want to use a keyed + instead. +

+

+ None of the implementations in + this library are guaranteed to be thread-safe in any way unless wrapped + in a . +

+

+ The following table summarizes the binary operators that are supported + by the class. +

+ + + Operation + Description + Method + + + Union (OR) + + Element included in result if it exists in either A OR + B. + + Union() + + + Intersection (AND) + + Element included in result if it exists in both A AND + B. + + InterSect() + + + Exclusive Or (XOR) + + Element included in result if it exists in one, but not both, + of A and B. + + ExclusiveOr() + + + Minus (n/a) + + Take all the elements in A. Now, if any of them exist in + B, remove them. Note that unlike the other operators, + A - B is not the same as B - A. + + Minus() + + +
+
+ + + Performs a "union" of the two sets, where all the elements + in both sets are present. + + +

+ That is, the element is included if it is in either + or this set. Neither this set nor the input + set are modified during the operation. The return value is a + clone of this set with the extra elements added in. +

+
+ A collection of elements. + + A new containing the union of + this with the specified + collection. Neither of the input objects is modified by the union. + +
+ + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. + + +

+ That is, the element is included if it exists in both sets. The + Intersect() operation does not modify the input sets. It + returns a clone of this set with the appropriate elements + removed. +

+
+ A set of elements. + + The intersection of this set with . + +
+ + + Performs a "minus" of this set from the + set. + + +

+ This returns a set of all the elements in set + , removing the elements that are also in + this set. The original sets are not modified during this operation. + The result set is a clone of this + containing the elements from + the operation. +

+
+ A set of elements. + + A set containing the elements from this set with the elements in + removed. + +
+ + + Performs an "exclusive-or" of the two sets, keeping only those + elements that are in one of the sets, but not in both. + + +

+ The original sets are not modified during this operation. The + result set is a clone of this set containing the elements + from the exclusive-or operation. +

+
+ A set of elements. + + A set containing the result of + ^ this. + +
+ + + Returns if this set contains the specified + element. + + The element to look for. + + if this set contains the specified element. + + + + + Returns if the set contains all the + elements in the specified collection. + + A collection of objects. + + if the set contains all the elements in the + specified collection. + + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + + is the object was added, + if the object was already present. + + + + + Adds all the elements in the specified collection to the set if + they are not already present. + + A collection of objects to add to the set. + + is the set changed as a result of this + operation. + + + + + Removes the specified element from the set. + + The element to be removed. + + if the set contained the specified element. + + + + + Remove all the specified elements from this set, if they exist in + this set. + + A collection of elements to remove. + + if the set was modified as a result of this + operation. + + + + + Retains only the elements in this set that are contained in the + specified collection. + + + The collection that defines the set of elements to be retained. + + + if this set changed as a result of this + operation. + + + + + Removes all objects from this set. + + + + + Returns if this set contains no elements. + + + + + Performs a "union" of the two sets, where all the elements + in both sets are present. That is, the element is included if it is in either a or b. + Neither this set nor the input set are modified during the operation. The return value + is a Clone() of this set with the extra elements added in. + + A collection of elements. + A new Set containing the union of this Set with the specified collection. + Neither of the input objects is modified by the union. + + + + Performs a "union" of two sets, where all the elements + in both are present. That is, the element is included if it is in either a or b. + The return value is a Clone() of one of the sets (a if it is not ) with elements of the other set + added in. Neither of the input sets is modified by the operation. + + A set of elements. + A set of elements. + A set containing the union of the input sets. if both sets are . + + + + Performs a "union" of two sets, where all the elements + in both are present. That is, the element is included if it is in either a or b. + The return value is a Clone() of one of the sets (a if it is not ) with elements of the other set + added in. Neither of the input sets is modified by the operation. + + A set of elements. + A set of elements. + A set containing the union of the input sets. if both sets are . + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. That is, the element is included if it exists in + both sets. The Intersect() operation does not modify the input sets. It returns + a Clone() of this set with the appropriate elements removed. + + A set of elements. + The intersection of this set with a. + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. That is, the element is included only if it exists in + both a and b. Neither input object is modified by the operation. + The result object is a Clone() of one of the input objects (a if it is not ) containing the + elements from the intersect operation. + + A set of elements. + A set of elements. + The intersection of the two input sets. if both sets are . + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. That is, the element is included only if it exists in + both a and b. Neither input object is modified by the operation. + The result object is a Clone() of one of the input objects (a if it is not ) containing the + elements from the intersect operation. + + A set of elements. + A set of elements. + The intersection of the two input sets. if both sets are . + + + + Performs a "minus" of set b from set a. This returns a set of all + the elements in set a, removing the elements that are also in set b. + The original sets are not modified during this operation. The result set is a Clone() + of this Set containing the elements from the operation. + + A set of elements. + A set containing the elements from this set with the elements in a removed. + + + + Performs a "minus" of set b from set a. This returns a set of all + the elements in set a, removing the elements that are also in set b. + The original sets are not modified during this operation. The result set is a Clone() + of set a containing the elements from the operation. + + A set of elements. + A set of elements. + A set containing A - B elements. if a is . + + + + Performs a "minus" of set b from set a. This returns a set of all + the elements in set a, removing the elements that are also in set b. + The original sets are not modified during this operation. The result set is a Clone() + of set a containing the elements from the operation. + + A set of elements. + A set of elements. + A set containing A - B elements. if a is . + + + + Performs an "exclusive-or" of the two sets, keeping only the elements that + are in one of the sets, but not in both. The original sets are not modified + during this operation. The result set is a Clone() of this set containing + the elements from the exclusive-or operation. + + A set of elements. + A set containing the result of a ^ b. + + + + Performs an "exclusive-or" of the two sets, keeping only the elements that + are in one of the sets, but not in both. The original sets are not modified + during this operation. The result set is a Clone() of one of the sets + (a if it is not ) containing + the elements from the exclusive-or operation. + + A set of elements. + A set of elements. + A set containing the result of a ^ b. if both sets are . + + + + Performs an "exclusive-or" of the two sets, keeping only the elements that + are in one of the sets, but not in both. The original sets are not modified + during this operation. The result set is a Clone() of one of the sets + (a if it is not ) containing + the elements from the exclusive-or operation. + + A set of elements. + A set of elements. + A set containing the result of a ^ b. if both sets are . + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + is the object was added, if it was already present. + + + + Adds all the elements in the specified collection to the set if they are not already present. + + A collection of objects to add to the set. + is the set changed as a result of this operation, if not. + + + + Removes all objects from the set. + + + + + Returns if this set contains the specified element. + + The element to look for. + if this set contains the specified element, otherwise. + + + + Returns if the set contains all the elements in the specified collection. + + A collection of objects. + if the set contains all the elements in the specified collection, otherwise. + + + + Removes the specified element from the set. + + The element to be removed. + if the set contained the specified element, otherwise. + + + + Remove all the specified elements from this set, if they exist in this set. + + A collection of elements to remove. + if the set was modified as a result of this operation. + + + + Retains only the elements in this set that are contained in the specified collection. + + Collection that defines the set of elements to be retained. + if this set changed as a result of this operation. + + + + Returns a clone of the Set instance. This will work for derived Set + classes if the derived class implements a constructor that takes no arguments. + + A clone of this object. + + + + Copies the elements in the Set to an array. The type of array needs + to be compatible with the objects in the Set, obviously. + + An array that will be the target of the copy operation. + The zero-based index where copying will start. + + + + Gets an enumerator for the elements in the Set. + + An IEnumerator over the elements in the Set. + + + + Performs CopyTo when called trhough non-generic ISet (ICollection) interface + + + + + + + Performs Union when called trhough non-generic ISet interface + + + + + + + Performs Minus when called trhough non-generic ISet interface + + + + + + + Performs Intersect when called trhough non-generic ISet interface + + + + + + + Performs ExclusiveOr when called trhough non-generic ISet interface + + + + + + + Returns if this set contains no elements. + + + + + The number of elements currently contained in this collection. + + + + + Returns if the Set is synchronized across threads. Note that + enumeration is inherently not thread-safe. Use the SyncRoot to lock the + object during enumeration. + + + + + An object that can be used to synchronize this collection to make it thread-safe. + When implementing this, if your object uses a base object, like an IDictionary, + or anything that has a SyncRoot, return that object instead of "this". + + + + + Indicates whether the given instance is read-only or not + + + if the ISet is read-only; otherwise, . + In the default implementation of Set, this property always returns false. + + + + + Provides the storage for elements in the Set, stored as the key-set + of the IDictionary object. Set this object in the constructor + if you create your own Set class. + + + + + Adds the specified element to this set if it is not already present. + + The to add to the set. + is the object was added, if it was already present. + + + + Adds all the elements in the specified collection to the set if they are not already present. + + A collection of objects to add to the set. + is the set changed as a result of this operation, if not. + + + + Removes all objects from the set. + + + + + Returns if this set contains the specified element. + + The element to look for. + if this set contains the specified element, otherwise. + + + + Returns if the set contains all the elements in the specified collection. + + A collection of objects. + if the set contains all the elements in the specified collection, otherwise. + + + + Removes the specified element from the set. + + The element to be removed. + if the set contained the specified element, otherwise. + + + + Remove all the specified elements from this set, if they exist in this set. + + A collection of elements to remove. + if the set was modified as a result of this operation. + + + + Retains only the elements in this set that are contained in the specified collection. + + Collection that defines the set of elements to be retained. + if this set changed as a result of this operation. + + + + Copies the elements in the Set to an array of T. The type of array needs + to be compatible with the objects in the Set, obviously. + + An array that will be the target of the copy operation. + The zero-based index where copying will start. + + + + Gets an enumerator for the elements in the Set. + + An IEnumerator over the elements in the Set. + + + + Copies the elements in the Set to an array. The type of array needs + to be compatible with the objects in the Set, obviously. Needed for + non-generic ISet methods implementation + + An array that will be the target of the copy operation. + The zero-based index where copying will start. + + + + The placeholder object used as the value for the IDictionary instance. + + + There is a single instance of this object globally, used for all Sets. + + + + + Returns if this set contains no elements. + + + + + The number of elements contained in this collection. + + + + + None of the objects based on DictionarySet are synchronized. Use the + SyncRoot property instead. + + + + + Returns an object that can be used to synchronize the Set between threads. + + + + + Indicates wether the Set is read-only or not + + + + + Implements a Set based on a Dictionary (which is equivalent of + non-genric HashTable) This will give the best lookup, add, and remove + performance for very large data-sets, but iteration will occur in no particular order. + + + + + Creates a new set instance based on a Dictinary. + + + + + Creates a new set instance based on a Dictinary and + initializes it based on a collection of elements. + + A collection of elements that defines the initial set contents. + + + +

Implements an immutable (read-only) Set wrapper.

+

Although this is advertised as immutable, it really isn't. Anyone with access to the + basisSet can still change the data-set. So GetHashCode() is not implemented + for this Set, as is the case for all Set implementations in this library. + This design decision was based on the efficiency of not having to Clone() the + basisSet every time you wrap a mutable Set.

+
+
+ + + Constructs an immutable (read-only) Set wrapper. + + The Set that is wrapped. + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + nothing + is always thrown + + + + Adds all the elements in the specified collection to the set if they are not already present. + + A collection of objects to add to the set. + nothing + is always thrown + + + + Removes all objects from the set. + + is always thrown + + + + Returns if this set contains the specified element. + + The element to look for. + if this set contains the specified element, otherwise. + + + + Returns if the set contains all the elements in the specified collection. + + A collection of objects. + if the set contains all the elements in the specified collection, otherwise. + + + + Removes the specified element from the set. + + The element to be removed. + nothing + is always thrown + + + + Remove all the specified elements from this set, if they exist in this set. + + A collection of elements to remove. + nothing + is always thrown + + + + Retains only the elements in this set that are contained in the specified collection. + + Collection that defines the set of elements to be retained. + nothing + is always thrown + + + + Copies the elements in the Set to an array of T. The type of array needs + to be compatible with the objects in the Set, obviously. + + An array that will be the target of the copy operation. + The zero-based index where copying will start. + + + + Gets an enumerator for the elements in the Set. + + An IEnumerator over the elements in the Set. + + + + Returns a clone of the Set instance. + + A clone of this object. + + + + Performs a "union" of the two sets, where all the elements + in both sets are present. That is, the element is included if it is in either a or b. + Neither this set nor the input set are modified during the operation. The return value + is a Clone() of this set with the extra elements added in. + + A collection of elements. + A new Set containing the union of this Set with the specified collection. + Neither of the input objects is modified by the union. + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. That is, the element is included if it exists in + both sets. The Intersect() operation does not modify the input sets. It returns + a Clone() of this set with the appropriate elements removed. + + A set of elements. + The intersection of this set with a. + + + + Performs a "minus" of set b from set a. This returns a set of all + the elements in set a, removing the elements that are also in set b. + The original sets are not modified during this operation. The result set is a Clone() + of this Set containing the elements from the operation. + + A set of elements. + A set containing the elements from this set with the elements in a removed. + + + + Performs an "exclusive-or" of the two sets, keeping only the elements that + are in one of the sets, but not in both. The original sets are not modified + during this operation. The result set is a Clone() of this set containing + the elements from the exclusive-or operation. + + A set of elements. + A set containing the result of a ^ b. + + + + Performs CopyTo when called trhough non-generic ISet (ICollection) interface + + + + + + + Performs Union when called trhough non-generic ISet interface + + + + + + + Performs Minus when called trhough non-generic ISet interface + + + + + + + Performs Intersect when called trhough non-generic ISet interface + + + + + + + Performs ExclusiveOr when called trhough non-generic ISet interface + + + + + + + Returns if this set contains no elements. + + + + + The number of elements contained in this collection. + + + + + Returns an object that can be used to synchronize use of the Set across threads. + + + + + Returns an object that can be used to synchronize the Set between threads. + + + + + Indicates that the given instance is read-only + + + + + Implements an ordered Set based on a dictionary. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A collection of elements that defines the initial set contents. + + + + Represents a read only wrapper around a generic IDictionary. The design pattern + mirrors ReadOnlyCollection, and follows the apparent pattern that write operations + do not throw an exception, but simply make no change to the underlying collection. + + Originally put into the public domain. + http://www.simple-talk.com/community/forums/thread/2263.aspx + + + + Original from Public Domain + Mark Pollack (.NET) + + + + Inner storage for ReadOnlyDictionary + + + + + Easy access to non-generic dictionary API + + + + + Initializes a new instance of the class. + + The dictionary to wrap. + + + + Add does not change a read only Dictionary + + The object to use as the key of the element to add. + The object to use as the value of the element to add. + The is read-only. + + + + Determines whether the contains an element with the specified key. + + The key to locate in the . + + true if the contains an element with the key; otherwise, false. + + key is null. + + + + Remove does not change a read only Dictionary, will throw an exception. + + The is read-only. + + + + Tries the get value. + + The key. + The value. + + + + + Add does not change a read only Dictionary + + The object to add to the . + The is read-only. + + + + Clear does not change a read only Dictionary. + + The is read-only. + + + + Determines whether the contains a specific value. + + The object to locate in the . + + true if item is found in the ; otherwise, false. + + + + + Copies the elements of the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in array at which copying begins. + arrayIndex is less than 0. + array is null. + array is multidimensional.-or-arrayIndex is equal to or greater than the length of array.-or-The number of elements in the source is greater than the available space from arrayIndex to the end of the destination array.-or-Type T cannot be cast automatically to the type of the destination array. + + + + Remove does not change a read only Dictionary. Throws an exception + + The object to remove from the . + + true if item was successfully removed from the ; otherwise, false. This method also returns false if item is not found in the original . + + The is read-only. + + + + Returns an enumerator that iterates through the collection. + + + A that can be used to iterate through the collection. + + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Add does not change a read only Dictionary. Throws an exception. + + The to use as the key of the element to add. + The to use as the value of the element to add. + The is read-only.-or- The has a fixed size. + + + + Determines whether the object contains an element with the specified key. + + The key to locate in the object. + + true if the contains an element with the key; otherwise, false. + + key is null. + + + + Returns an object for the object. + + + An object for the object. + + + + + Remove does not change a read only Dictionary. Throws an exception. + + The key of the element to remove. + The object is read-only.-or- The has a fixed size. + + + + Copies the elements of the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in array at which copying begins. + array is null. + index is less than zero. + array is multidimensional.-or- index is equal to or greater than the length of array.-or- The number of elements in the source is greater than the available space from index to the end of the destination array. + The type of the source cannot be cast automatically to the type of the destination array. + + + + Runs when the entire object graph has been deserialized. + + The object that initiated the callback. The functionality for this parameter is not currently implemented. + + + + Populates a with the data needed to serialize the target object. + + The to populate with data. + The destination (see ) for this serialization. + The caller does not have the required permission. + + + + Gets a read only containing the keys of the . + + + An containing the keys of the object that implements . + + + + Gets an containing the values in the . + + + An containing the values in the object that implements . + + + + Gets the value with the specified key. + Set will throw an exception + + + + + Gets the number of elements contained in the . + + + The number of elements contained in the . + + + + Gets a value indicating whether the is read-only. + + + true if the is read-only; otherwise, false. + + + + Gets a value indicating whether the object has a fixed size. + + + true if the object has a fixed size; otherwise, false. + + + + Gets an containing the keys of the . + + + An containing the keys of the object that implements . + + + + Gets an containing the values in the . + + + An containing the values in the object that implements . + + + + Gets the with the specified key. Set throws an exception. + + + The is read-only. + if try to set value + + + + Gets a value indicating whether access to the is synchronized (thread safe). + + + true if access to the is synchronized (thread safe); otherwise, false. + + + + Gets an object that can be used to synchronize access to the . + + + An object that can be used to synchronize access to the . + + + + Implements a Set based on a sorted tree. This gives good performance for operations on very + large data-sets, though not as good - asymptotically - as a HashedSet. However, iteration + occurs in order. Elements that you put into this type of collection must implement IComparable, + and they must actually be comparable. You can't mix string and int values, for example. + + + + + Creates a new set instance based on a sorted tree. + + + + + Creates a new set instance based on a sorted tree. + + The to use for sorting. + + + + Creates a new set instance based on a sorted tree and + initializes it based on a collection of elements. + + A collection of elements that defines the initial set contents. + + + + Creates a new set instance based on a sorted tree and + initializes it based on a collection of elements. + + A collection of elements that defines the initial set contents. + + + + Creates a new set instance based on a sorted tree and + initializes it based on a collection of elements. + + A collection of elements that defines the initial set contents. + The to use for sorting. + + + +

Implements a thread-safe Set wrapper. The implementation is extremely conservative, + serializing critical sections to prevent possible deadlocks, and locking on everything. + The one exception is for enumeration, which is inherently not thread-safe. For this, you + have to lock the SyncRoot object for the duration of the enumeration.

+
+
+ + + Constructs a thread-safe Set wrapper. + + The Set object that this object will wrap. + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + is the object was added, if it was already present. + + + + Adds all the elements in the specified collection to the set if they are not already present. + + A collection of objects to add to the set. + is the set changed as a result of this operation, if not. + + + + Removes all objects from the set. + + + + + Returns if this set contains the specified element. + + The element to look for. + if this set contains the specified element, otherwise. + + + + Returns if the set contains all the elements in the specified collection. + + A collection of objects. + if the set contains all the elements in the specified collection, otherwise. + + + + Removes the specified element from the set. + + The element to be removed. + if the set contained the specified element, otherwise. + + + + Remove all the specified elements from this set, if they exist in this set. + + A collection of elements to remove. + if the set was modified as a result of this operation. + + + + Retains only the elements in this set that are contained in the specified collection. + + Collection that defines the set of elements to be retained. + if this set changed as a result of this operation. + + + + Copies the elements in the Set to an array. The type of array needs + to be compatible with the objects in the Set, obviously. + + An array that will be the target of the copy operation. + The zero-based index where copying will start. + + + + Enumeration is, by definition, not thread-safe. Use a lock on the SyncRoot + to synchronize the entire enumeration process. + + + + + + Returns a clone of the Set instance. + + A clone of this object. + + + + Performs CopyTo when called trhough non-generic ISet (ICollection) interface + + + + + + + Returns if this set contains no elements. + + + + + The number of elements contained in this collection. + + + + + Returns , indicating that this object is thread-safe. The exception to this + is enumeration, which is inherently not thread-safe. Use the SyncRoot object to + lock this object for the entire duration of the enumeration. + + + + + Returns an object that can be used to synchronize the Set between threads. + + + + + Indicates whether given instace is read-only or not + + + + + This class provides skeletal implementations of some + operations. + + +

+ The implementations in this class are appropriate when the base + implementation does not allow elements. The methods + , + , and + are based on + the , + , and + methods + respectively but throw exceptions instead of indicating failure via + or returns. +

+ An implementation that extends this class must + minimally define a method + which does + not permit the insertion of elements, along with methods + , and + . Typically, + additional methods will be overridden as well. If these requirements + cannot be met, consider instead subclassing + }. +

+
+ Doug Lea + Griffin Caprio (.NET) +
+ + + A collection designed for holding elements prior to processing. + + +

+ Besides basic operations, + queues provide additional insertion, extraction, and inspection + operations. +

+

+ Each of these methods exists in two forms: one throws + an exception if the operation fails, the other returns a special + value (either or , depending on the + operation). The latter form of the insert operation is designed + specifically for use with capacity-restricted + implementations; in most implementations, insert operations cannot + fail. +

+

+ Queues typically, but do not necessarily, order elements in a + FIFO (first-in-first-out) manner. Among the exceptions are + priority queues, which order elements according to a supplied + comparator, or the elements' natural ordering, and LIFO queues (or + stacks) which order the elements LIFO (last-in-first-out). + Whatever the ordering used, the head of the queue is that + element which would be removed by a call to + or + . In a FIFO queue, all new + elements are inserted at the tail of the queue. Other kinds of queues may + use different placement rules. Every implementation + must specify its ordering properties. +

+

+ The method inserts an + element if possible, otherwise returning . This differs from the + method, which can fail to + add an element only by throwing an exception. The + method is designed for + use when failure is a normal, rather than exceptional occurrence, for example, + in fixed-capacity (or "bounded" queues. +

+

+ The + methods remove and + return the head of the queue. Exactly which element is removed from the + queue is a function of the queue's ordering policy, which differs from + implementation to implementation. The + and + methods differ only in their + behavior when the queue is empty: the + method throws an exception, + while the method returns + . +

+

+ The and + methods return, but do + not remove, the head of the queue. +

+

+ The interface does not define the blocking queue + methods, which are common in concurrent programming. +

+

+ implementations generally do not allow insertion + of elements, although some implementations, such as + a linked list, do not prohibit the insertion of . + Even in the implementations that permit it, should + not be inserted into a , as is also + used as a special return value by the + method to + indicate that the queue contains no elements. +

+

+ implementations generally do not define + element-based versions of methods + and , but instead inherit the + identity based versions from the class object, because element-based equality + is not always well-defined for queues with the same elements but different + ordering properties. +

+

+ Based on the back port of JCP JSR-166. +

+
+ Doug Lea + Griffin Caprio (.NET) +
+ + + Inserts the specified element into this queue if it is possible to do so + immediately without violating capacity restrictions, returning + upon success and throwing an + if no space is + currently available. + + + The element to add. + + + if successful. + + + If the element cannot be added at this time due to capacity restrictions. + + + If the class of the supplied prevents it + from being added to this queue. + + + If the specified element is and this queue does not + permit elements. + + + If some property of the supplied prevents + it from being added to this queue. + + + + + Inserts the specified element into this queue if it is possible to do + so immediately without violating capacity restrictions. + + +

+ When using a capacity-restricted queue, this method is generally + preferable to , + which can fail to insert an element only by throwing an exception. +

+
+ + The element to add. + + + if the element was added to this queue. + + + If the element cannot be added at this time due to capacity restrictions. + + + If the supplied is + . + + + If some property of the supplied prevents + it from being added to this queue. + +
+ + + Retrieves and removes the head of this queue. + + +

+ This method differs from + only in that it throws an exception if this queue is empty. +

+
+ + The head of this queue + + if this queue is empty +
+ + + Retrieves and removes the head of this queue, + or returns if this queue is empty. + + + The head of this queue, or if this queue is empty. + + + + + Retrieves, but does not remove, the head of this queue. + + +

+ This method differs from + only in that it throws an exception if this queue is empty. +

+
+ + The head of this queue. + + If this queue is empty. +
+ + + Retrieves, but does not remove, the head of this queue, + or returns if this queue is empty. + + + The head of this queue, or if this queue is empty. + + + + + Returns if there are no elements in the , otherwise. + + + + + Creates a new instance of the class. + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+
+ + + Inserts the specified element into this queue if it is possible + to do so immediately without violating capacity restrictions. + + + The element to add. + + + if successful. + + + If the element cannot be added at this time due to capacity restrictions. + + + + + Retrieves and removes the head of this queue. + + +

+ This method differs from + only in that + it throws an exception if this queue is empty. +

+
+ + The head of this queue + + + If this queue is empty. + +
+ + + Retrieves, but does not remove, the head of this queue. + + +

+ This method differs from + only in that it throws an exception if this queue is empty. +

+

+ ALso note that this implementation returns the result of + unless the queue + is empty. +

+
+ The head of this queue. + + If this queue is empty. + +
+ + + Removes all of the elements from this queue. + + +

+ The queue will be empty after this call returns. +

+

+ This implementation repeatedly invokes + until it + returns . +

+
+
+ + + Adds all of the elements in the supplied + to this queue. + + +

+ Attempts to + + of a queue to itself result in . + Further, the behavior of this operation is undefined if the specified + collection is modified while the operation is in progress. +

+

+ This implementation iterates over the specified collection, + and adds each element returned by the iterator to this queue, in turn. + An exception encountered while trying to add an element (including, + in particular, a element) may result in only some + of the elements having been successfully added when the associated + exception is thrown. +

+
+ + The collection containing the elements to be added to this queue. + + + if this queue changed as a result of the call. + + + If the supplied or any one of its elements are . + + + If the collection is the current or + the collection size is greater than the queue capacity. + +
+ + + Inserts the specified element into this queue if it is possible to do + so immediately without violating capacity restrictions. + + +

+ When using a capacity-restricted queue, this method is generally + preferable to , + which can fail to insert an element only by throwing an exception. +

+
+ + The element to add. + + + if the element was added to this queue. + + + If the element cannot be added at this time due to capacity restrictions. + + + If the supplied is + . + + + If some property of the supplied prevents + it from being added to this queue. + +
+ + + Retrieves, but does not remove, the head of this queue, + or returns if this queue is empty. + + + The head of this queue, or if this queue is empty. + + + + + Retrieves and removes the head of this queue, + or returns if this queue is empty. + + + The head of this queue, or if this queue is empty. + + + + + Copies the elements of the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in array at which copying begins. + array is null. + index is less than zero. + array is multidimensional.-or- index is equal to or greater than the length of array.-or- The number of elements in the source is greater than the available space from index to the end of the destination array. + The type of the source cannot be cast automatically to the type of the destination array. 2 + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Returns if there are no elements in the , otherwise. + + + + + Returns the current capacity of this queue. + + + + + Gets the number of elements contained in the . + + + The number of elements contained in the . + + + + + Gets an object that can be used to synchronize access to the . + + + An object that can be used to synchronize access to the . + + + + + Gets a value indicating whether access to the is synchronized (thread safe). + + + true if access to the is synchronized (thread safe); otherwise, false. + + + + + Provides a performance improved hashtable with case-insensitive (string-only! based) key handling. + + Erich Eichinger + + + + Creates a case-insensitive hashtable using . + + + + + Creates a case-insensitive hashtable using the given . + + the to calculate the hashcode + + + + Creates a case-insensitive hashtable using the given , initially + populated with entries from another dictionary. + + the dictionary to copy entries from + the to calculate the hashcode + + + + Initializes a new, empty instance of the class that is serializable using the specified and objects. + + A object containing the source and destination of the serialized stream associated with the . + A object containing the information required to serialize the object. + info is null. + + + + Implements the interface and returns the data needed to serialize the . + + + A object containing the source and destination of the serialized stream associated with the . + A object containing the information required to serialize the . + info is null. + + + + Calculate the hashcode of the given string key, using the configured culture. + + + + + + + Compares two keys + + + + + Creates a shallow copy of the current instance. + + + + + is an + class that supports the creation of new + types where the underlying data + store is an instance. + + +

+ You can use any object that implements the + interface to hold set + data. You can define your own, or you can use one of the objects + provided in the framework. The type of + you + choose will affect both the performance and the behavior of the + using it. +

+

+ This object overrides the method, + but not the method, because + the class is mutable. + Therefore, it is not safe to use as a key value in a dictionary. +

+

+ To make a typed based on your + own , simply derive a new + class with a constructor that takes no parameters. Some + implmentations cannot be defined + with a default constructor. If this is the case for your class, you + will need to override clone as well. +

+

+ It is also standard practice that at least one of your constructors + takes an or an + as an argument. +

+
+ +
+ + + A collection that contains no duplicate elements. + + + + + + Performs a "union" of the two sets, where all the elements + in both sets are present. + + A collection of elements. + + A new containing the union of + this with the specified + collection. Neither of the input objects is modified by the union. + + + + + + Performs a "union" of two sets, where all the elements in both are + present. + + +

+ That is, the element is included if it is in either + or . The return + value is a clone of one of the sets ( + if it is not ) with elements of the other set + added in. Neither of the input sets is modified by the operation. +

+
+ A set of elements. + A set of elements. + + A set containing the union of the input sets; + if both sets are . + +
+ + + Performs a "union" of two sets, where all the elements in both are + present. + + A set of elements. + A set of elements. + + A set containing the union of the input sets; + if both sets are . + + + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. + + A set of elements. + + The intersection of this set with . + + + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. + + +

+ That is, the element is included only if it exists in both + and . Neither input + object is modified by the operation. The result object is a + clone of one of the input objects ( + if it is not ) containing the elements from + the intersect operation. +

+
+ A set of elements. + A set of elements. + + The intersection of the two input sets; if + both sets are . + +
+ + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. + + A set of elements. + A set of elements. + + The intersection of the two input sets; if + both sets are . + + + + + + Performs a "minus" of this set from the + set. + + A set of elements. + + A set containing the elements from this set with the elements in + removed. + + + + + + Performs a "minus" of set from set + . + + +

+ This returns a set of all the elements in set + , removing the elements that are also in + set . The original sets are not modified + during this operation. The result set is a clone of set + containing the elements from the operation. +

+
+ A set of elements. + A set of elements. + + A set containing + - elements. + if is + . + +
+ + + Performs a "minus" of set from set + . + + A set of elements. + A set of elements. + + A set containing + - elements. + if is + . + + + + + + Performs an "exclusive-or" of the two sets, keeping only those + elements that are in one of the sets, but not in both. + + A set of elements. + + A set containing the result of + ^ this. + + + + + + Performs an "exclusive-or" of the two sets, keeping only those + elements that are in one of the sets, but not in both. + + +

+ The original sets are not modified during this operation. The + result set is a clone of one of the sets ( + if it is not ) + containing the elements from the exclusive-or operation. +

+
+ A set of elements. + A set of elements. + + A set containing the result of + ^ . + if both sets are . + +
+ + + Performs an "exclusive-or" of the two sets, keeping only those + elements that are in one of the sets, but not in both. + + A set of elements. + A set of elements. + + A set containing the result of + ^ . + if both sets are . + + + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + + is the object was added, + if the object was already present. + + + + + Adds all the elements in the specified collection to the set if + they are not already present. + + A collection of objects to add to the set. + + is the set changed as a result of this + operation. + + + + + Removes all objects from this set. + + + + + Returns if this set contains the specified + element. + + The element to look for. + + if this set contains the specified element. + + + + + Returns if the set contains all the + elements in the specified collection. + + A collection of objects. + + if the set contains all the elements in the + specified collection. + + + + + Removes the specified element from the set. + + The element to be removed. + + if the set contained the specified element. + + + + + Remove all the specified elements from this set, if they exist in + this set. + + A collection of elements to remove. + + if the set was modified as a result of this + operation. + + + + + Retains only the elements in this set that are contained in the + specified collection. + + + The collection that defines the set of elements to be retained. + + + if this set changed as a result of this + operation. + + + + + Returns a clone of the + instance. + + +

+ This will work for derived + classes if the derived class implements a constructor that takes no + arguments. +

+
+ A clone of this object. +
+ + + Copies the elements in the to + an array. + + +

+ The type of array needs to be compatible with the objects in the + , obviously. +

+
+ + An array that will be the target of the copy operation. + + + The zero-based index where copying will start. + +
+ + + Gets an enumerator for the elements in the + . + + + An over the elements + in the . + + + + + This method will test the + against another for + "equality". + + +

+ In this case, "equality" means that the two sets contain the same + elements. The "==" and "!=" operators are not overridden by design. + If you wish to check for "equivalent" + instances, use + Equals(). If you wish to check to see if two references are + actually the same object, use "==" and "!=". +

+
+ + A object to compare to. + + + if the two sets contain the same elements. + +
+ + + Gets the hashcode for the object. + + + + + Returns if this set contains no elements. + + + + + The number of elements currently contained in this collection. + + + + + Returns if the + is synchronized across + threads. + + +

+ Note that enumeration is inherently not thread-safe. Use the + to lock the object during enumeration. +

+
+
+ + + An object that can be used to synchronize this collection to make + it thread-safe. + + +

+ When implementing this, if your object uses a base object, like an + , or anything that has + a SyncRoot, return that object instead of "this". +

+
+ + An object that can be used to synchronize this collection to make + it thread-safe. + +
+ + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + + is the object was added, + if the object was already present. + + + + + Adds all the elements in the specified collection to the set if + they are not already present. + + A collection of objects to add to the set. + + is the set changed as a result of this + operation. + + + + + Removes all objects from this set. + + + + + Returns if this set contains the specified + element. + + The element to look for. + + if this set contains the specified element. + + + + + Returns if the set contains all the + elements in the specified collection. + + A collection of objects. + + if the set contains all the elements in the + specified collection; also if the + supplied is . + + + + + Removes the specified element from the set. + + The element to be removed. + + if the set contained the specified element. + + + + + Remove all the specified elements from this set, if they exist in + this set. + + A collection of elements to remove. + + if the set was modified as a result of this + operation. + + + + + Retains only the elements in this set that are contained in the + specified collection. + + + The collection that defines the set of elements to be retained. + + + if this set changed as a result of this + operation. + + + + + Copies the elements in the to + an array. + + +

+ The type of array needs to be compatible with the objects in the + , obviously. +

+
+ + An array that will be the target of the copy operation. + + + The zero-based index where copying will start. + +
+ + + Gets an enumerator for the elements in the + . + + + An over the elements + in the . + + + + + Provides the storage for elements in the + , stored as the key-set + of the object. + + +

+ Set this object in the constructor if you create your own + class. +

+
+
+ + + The placeholder object used as the value for the + instance. + + + There is a single instance of this object globally, used for all + s. + + + + + Returns if this set contains no elements. + + + + + The number of elements currently contained in this collection. + + + + + Returns if the + is synchronized across + threads. + + + + + + An object that can be used to synchronize this collection to make + it thread-safe. + + + An object that can be used to synchronize this collection to make + it thread-safe. + + + + + + Implements an based on a + hash table. + + +

+ This will give the best lookup, add, and remove performance for very + large data-sets, but iteration will occur in no particular order. +

+
+ +
+ + + Creates a new instance of the class. + + + + + Creates a new instance of the class, and + initializes it based on a collection of elements. + + + A collection of elements that defines the initial set contents. + + + + + Implements an that automatically + changes from a list based implementation to a hashtable based + implementation when the size reaches a certain threshold. + + +

+ This is good if you are unsure about whether you data-set will be tiny + or huge. +

+ + Because this uses a dual implementation, iteration order is not + guaranteed! + +
+ +
+ + + Creates a new set instance based on either a list or a hash table, + depending on which will be more efficient based on the data-set + size. + + + + + Initializes a new instance of the class with a given capacity + + The size. + + + + Creates a new set instance based on either a list or a hash table, + depending on which will be more efficient based on the data-set + size, and initializes it based on a collection of elements. + + + A collection of elements that defines the initial set contents. + + + + + Implements an immutable (read-only) + wrapper. + + +

+ Although this class is advertised as immutable, it really isn't. + Anyone with access to the wrapped + can still change the data. So + is not implemented for this , as + is the case for all + implementations in this library. This design decision was based on the + efficiency of not having to clone the wrapped + every time you wrap a mutable + . +

+
+
+ + + Constructs an immutable (read-only) + wrapper. + + + The that is to be wrapped. + + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + + is the object was added, + if the object was already present. + + + + + + Adds all the elements in the specified collection to the set if + they are not already present. + + A collection of objects to add to the set. + + is the set changed as a result of this + operation. + + + + + + Removes all objects from this set. + + + + + + Returns if this set contains the specified + element. + + The element to look for. + + if this set contains the specified element. + + + + + Returns if the set contains all the + elements in the specified collection. + + A collection of objects. + + if the set contains all the elements in the + specified collection. + + + + + Removes the specified element from the set. + + The element to be removed. + + if the set contained the specified element. + + + + + + Remove all the specified elements from this set, if they exist in + this set. + + A collection of elements to remove. + + if the set was modified as a result of this + operation. + + + + + + Retains only the elements in this set that are contained in the + specified collection. + + + The collection that defines the set of elements to be retained. + + + if this set changed as a result of this + operation. + + + + + + Copies the elements in the to + an array. + + +

+ The type of array needs to be compatible with the objects in the + , obviously. +

+
+ + An array that will be the target of the copy operation. + + + The zero-based index where copying will start. + +
+ + + Gets an enumerator for the elements in the + . + + + An over the elements + in the . + + + + + Returns a clone of the + instance. + + A clone of this object. + + + + Performs a "union" of the two sets, where all the elements + in both sets are present. + + A collection of elements. + + A new containing the union of + this with the specified + collection. Neither of the input objects is modified by the union. + + + + + + Performs an "intersection" of the two sets, where only the elements + that are present in both sets remain. + + A set of elements. + + The intersection of this set with . + + + + + + Performs a "minus" of this set from the + set. + + A set of elements. + + A set containing the elements from this set with the elements in + removed. + + + + + + Performs an "exclusive-or" of the two sets, keeping only those + elements that are in one of the sets, but not in both. + + A set of elements. + + A set containing the result of + ^ this. + + + + + + Returns if this set contains no elements. + + + + + The number of elements currently contained in this collection. + + + + + Returns if the + is synchronized across + threads. + + +

+ Note that enumeration is inherently not thread-safe. Use the + to lock the object during enumeration. +

+
+
+ + + An object that can be used to synchronize this collection to make + it thread-safe. + + + An object that can be used to synchronize this collection to make + it thread-safe. + + + + + Simple linked list implementation. + + Simon White + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class that contains all + elements of the specified list. + + + A list of elements that defines the initial contents. + + + + + Removes the object at the specified index. + + The lookup index. + + If the specified is greater than the + number of objects within the list. + + + + + Inserts an object at the specified index. + + The lookup index. + The object to be inserted. + + If the specified is greater than the + number of objects within the list. + + + + + Removes the first instance of the specified object found. + + The object to remove + + + + Returns if this list contains the specified + element. + + The element to look for. + + if this list contains the specified element. + + + + + Removes all objects from the list. + + + + + Returns the index of the first instance of the specified + found. + + The object to search for + + The index of the first instance found, or -1 if the element was not + found. + + + + + Adds the specified object to the end of the list. + + The object to add + The index that the object was added at. + + + + Adds all of the elements of the supplied + list to the end of this list. + + The list of objects to add. + + + + Checks whether the list can be modified. + + + If the list cannot be modified. + + + + + Validates the specified index. + + The lookup index. + + If the index is invalid. + + + + + Returns the node at the specified index. + + The lookup index. + The node at the specified index. + + If the specified is greater than the + number of objects within the list. + + + + + Returns the node (and index) of the first node that contains + the specified value. + + The value to search for. + + The node, or if not found. + + + + + Removes the specified node. + + The node to be removed. + + + + Copies the elements in this list to an array. + + +

+ The type of array needs to be compatible with the objects in this + list, obviously. +

+
+ + An array that will be the target of the copy operation. + + + The zero-based index where copying will start. + + + If the supplied is . + + + If the supplied is less than zero + or is greater than the length of . + + + If the supplied is of insufficient size. + +
+ + + Gets an enumerator for the elements in the + . + + +

+ Enumerators are fail fast. +

+
+ + An over the elements + in the . + +
+ + + Is list read only? + + + if the list is read only. + + + + + Returns the node at the specified index. + + +

+ This is the indexer for the + class. +

+
+ +
+ + + Is the list a fixed size? + + + if the list is a fixed size list. + + + + + Returns if the list is synchronized across + threads. + + + + This implementation always returns . + +

+ Note that enumeration is inherently not thread-safe. Use the + to lock the object during enumeration. +

+
+
+ + + The number of objects within the list. + + + + + An object that can be used to synchronize this + to make it thread-safe. + + + An object that can be used to synchronize this + to make it thread-safe. + + + + + Implements a based on a list. + + +

+ Performance is much better for very small lists than either + or . + However, performance degrades rapidly as the data-set gets bigger. Use a + instead if you are not sure your data-set + will always remain very small. Iteration produces elements in the order they were added. + However, element order is not guaranteed to be maintained by the various + mathematical operators. +

+
+
+ + + Creates a new set instance based on a list. + + + + + Creates a new set instance based on a list and initializes it based on a + collection of elements. + + + A collection of elements that defines the initial set contents. + + + + + Thrown when an element is requested from an empty . + + Griffin Caprio + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + An unbounded priority based on a priority + heap. This queue orders elements according to an order specified + at construction time, which is specified either according to their + natural order (see , or according to a + , depending on which constructor is + used. A priority queue does not permit elements. + A priority queue relying on natural ordering also does not + permit insertion of non-comparable objects (doing so will result + . + +

+ The head of this queue is the lowest element + with respect to the specified ordering. If multiple elements are + tied for lowest value, the head is one of those elements -- ties are + broken arbitrarily. + +

+ A priority queue is unbounded, but has an internal + capacity governing the size of an array used to store the + elements on the queue. It is always at least as large as the queue + size. As elements are added to a priority queue, its capacity + grows automatically. The details of the growth policy are not + specified. + +

+ This class and its enumerator implement all of the + optional methods of the and + interfaces. + The enumerator provided in method + is not guaranteed to traverse the elements of the PriorityQueue in any + particular order. + +

+ Note that this implementation is NOT synchronized. + Multiple threads should not access a + instance concurrently if any of the threads modifies the list + structurally. Instead, use the thread-safe PriorityBlockingQueue. +

+ Josh Bloch + Griffin Caprio (.NET) +
+ + + Priority queue represented as a balanced binary heap: the two children + of queue[n] are queue[2*n] and queue[2*n + 1]. The priority queue is + ordered by comparator, or by the elements' natural ordering, if + comparator is null: For each node n in the heap and each descendant d + of n, n <= d. + + The element with the lowest value is in queue[1], assuming the queue is + nonempty. (A one-based array is used in preference to the traditional + zero-based array to simplify parent and child calculations.) + + queue.length must be >= 2, even if size == 0. + + + + The number of elements in the priority queue. + + + + The comparator, or null if priority queue uses elements' + natural ordering. + + + + + The number of times this priority queue has been + structurally modified. + + + + + Creates a with the default initial capacity + (11) that orders its elements according to their natural + ordering (using ). + + + + + Creates a with the specified initial capacity + that orders its elements according to their natural ordering + (using ). + + the initial capacity for this priority queue. + + if is less than 1. + + + + Creates a with the specified initial capacity + that orders its elements according to the specified comparator. + + the initial capacity for this priority queue. + the comparator used to order this priority queue. + If then the order depends on the elements' natural ordering. + + if is less than 1. + + + + Creates a containing the elements in the + specified collection. The priority queue has an initial + capacity of 110% of the size of the specified collection or 1 + if the collection is empty. If the specified collection is an + instance of a , the priority queue will be sorted + according to the same comparator, or according to its elements' + natural order if the collection is sorted according to its + elements' natural order. Otherwise, the priority queue is + ordered according to its elements' natural order. + + the collection whose elements are to be placed into this priority queue. + if elements of cannot be + compared to one another according to the priority queue's ordering + if or any element with it is + + + + + + Common code to initialize underlying queue array across + constructors below. + + + + + Performs an unsigned bitwise right shift with the specified number + + Number to operate on + Ammount of bits to shift + The resulting number from the shift operation + + + + Establishes the heap invariant assuming the heap + satisfies the invariant except possibly for the leaf-node indexed by k + (which may have a nextExecutionTime less than its parent's). + + + This method functions by "promoting" queue[k] up the hierarchy + (by swapping it with its parent) repeatedly until queue[k] + is greater than or equal to its parent. + + + + + Establishes the heap invariant (described above) in the subtree + rooted at k, which is assumed to satisfy the heap invariant except + possibly for node k itself (which may be greater than its children). + + + This method functions by "demoting" queue[k] down the hierarchy + (by swapping it with its smaller child) repeatedly until queue[k] + is less than or equal to its children. + + + + + Establishes the heap invariant in the entire tree, + assuming nothing about the order of the elements prior to the call. + + + + + Returns the of or - 1, + whichever is smaller. + + base size + percentage to return + of + + + + Initially fill elements of the queue array under the + knowledge that it is sorted or is another , in which + case we can just place the elements in the order presented. + + + + + Initially fill elements of the queue array that is not to our knowledge + sorted, so we must rearrange the elements to guarantee the heap + invariant. + + + + + Removes and returns element located at from queue. (Recall that the queue + is one-based, so 1 <= i <= size.) + + + Normally this method leaves the elements at positions from 1 up to i-1, + inclusive, untouched. Under these circumstances, it returns . + Occasionally, in order to maintain the heap invariant, it must move + the last element of the list to some index in the range [2, i-1], + and move the element previously at position (i/2) to position i. + Under these circumstances, this method returns the element that was + previously at the end of the list and is now at some position between + 2 and i-1 inclusive. + + + + Resize array, if necessary, to be able to hold given index + + + + Inserts the specified element into this queue if it is possible to do + so immediately without violating capacity restrictions. + + +

+ When using a capacity-restricted queue, this method is generally + preferable to , + which can fail to insert an element only by throwing an exception. +

+
+ + The element to add. + + + if the element was added to this queue. + + + if the specified element cannot be compared + with elements currently in the priority queue according + to the priority queue's ordering. + + + If the element cannot be added at this time due to capacity restrictions. + + + If the supplied is + and this queue does not permit + elements. + + + If some property of the supplied prevents + it from being added to this queue. + +
+ + + Retrieves, but does not remove, the head of this queue, + or returns if this queue is empty. + + + The head of this queue, or if this queue is empty. + + + + + Inserts the specified element into this queue if it is possible to do so + immediately without violating capacity restrictions, returning + upon success and throwing an + if no space is + currently available. + + + The element to add. + + + if successful. + + + If the element cannot be added at this time due to capacity restrictions. + + + If the specified element is and this queue does not + permit elements. + + + If some property of the supplied prevents + it from being added to this queue. + + + if the specified element cannot be compared + with elements currently in the priority queue according + to the priority queue's ordering. + + + + + Removes a single instance of the specified element from this + queue, if it is present. + + + + + Returns an over the elements in this queue. + The enumeratoar does not return the elements in any particular order. + + an enumerator over the elements in this queue. + + + + Removes all elements from the priority queue. + The queue will be empty after this call returns. + + + + + Retrieves and removes the head of this queue, + or returns if this queue is empty. + + + The head of this queue, or if this queue is empty. + + + + + Queries the queue to see if it contains the specified + + element to look for. + if the queue contains the , + otherwise. + + + Returns the comparator used to order this collection, or + if this collection is sorted according to its elements natural ordering + (using ). + + + the comparator used to order this collection, or + if this collection is sorted according to its elements natural ordering. + + + + + Save the state of the instance to a stream (that + is, serialize it). + + The length of the array backing the instance is + emitted (int), followed by all of its elements (each an + ) in the proper order. + + the stream + the context + + + + Reconstitute the instance from a stream (that is, + deserialize it). + + the stream + the context + + + + Copies the elements of the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in array at which copying begins. + array is null. + index is less than zero. + array is multidimensional.-or- index is equal to or greater than the length of array.-or- The number of elements in the source is greater than the available space from index to the end of the destination array. + The type of the source cannot be cast automatically to the type of the destination array. 2 + + + + Copies the elements of the to an , starting at index 0. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + array is null. + index is less than zero. + array is multidimensional.-or- index is equal to or greater than the length of array.-or- The number of elements in the source is greater than the available space from index to the end of the destination array. + The type of the source cannot be cast automatically to the type of the destination array. 2 + + + + Gets the Capacity of this queue. Will equal + + + + + Returns the queue count. + + + + + Gets an object that can be used to synchronize access to the . + + + An object that can be used to synchronize access to the . + + + + + Gets a value indicating whether access to the is synchronized (thread safe). + + + true if access to the is synchronized (thread safe); otherwise, false. + + + + + Returns if there are no elements in the , otherwise. + + + + + Index (into queue array) of element to be returned by subsequent call to next. + + + + + Implements an based on a sorted + tree. + + +

+ This gives good performance for operations on very large data-sets, + though not as good - asymptotically - as a + . However, iteration occurs + in order. +

+

+ Elements that you put into this type of collection must implement + , and they must actually be comparable. + You can't mix and + values, for example. +

+

+ This implementation does + not support elements that are . +

+
+ +
+ + + Creates a new set instance based on a sorted tree. + + + + + Creates a new set instance based on a sorted tree using for ordering. + + + + + Creates a new set instance based on a sorted tree and initializes + it based on a collection of elements. + + + A collection of elements that defines the initial set contents. + + + + + Synchronized that should be returned by synchronized + dictionary implementations in order to ensure that the enumeration is thread safe. + + Aleksandar Seovic + + + + Synchronized that should be returned by synchronized + collections in order to ensure that the enumeration is thread safe. + + Aleksandar Seovic + + + + Synchronized that, unlike hashtable created + using method, synchronizes + reads from the underlying hashtable in addition to writes. + + +

+ In addition to synchronizing reads, this implementation also fixes + IEnumerator/ICollection issue described at + http://msdn.microsoft.com/en-us/netframework/aa570326.aspx + (search for SynchronizedHashtable for issue description), by implementing + interface explicitly, and returns thread safe enumerator + implementations as well. +

+

+ This class should be used whenever a truly synchronized + is needed. +

+
+ Aleksandar Seovic +
+ + + Initializes a new instance of + + + + + Initializes a new instance of + + + + + Initializes a new instance of , copying inital entries from + handling keys depending on . + + + + + Creates a instance that + synchronizes access to the underlying . + + the hashtable to be synchronized + + + + Creates a wrapper that synchronizes + access to the passed . + + the hashtable to be synchronized + + + + Adds an element with the provided key and value to the object. + + The to use as the value of the element to add. + The to use as the key of the element to add. + An element with the same key already exists in the object. + key is null. + The is read-only.-or- The has a fixed size. 2 + + + + Removes all elements from the object. + + The object is read-only. 2 + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Determines whether the object contains an element with the specified key. + + + true if the contains an element with the key; otherwise, false. + + The key to locate in the object. + key is null. 2 + + + + Returns, whether this contains an entry with the specified . + + The key to look for + , if this contains an entry with this + + + + Returns, whether this contains an entry with the specified . + + The valúe to look for + , if this contains an entry with this + + + + Copies the elements of the to an , starting at a particular index. + + The one-dimensional that is the destination of the elements copied from . The must have zero-based indexing. + The zero-based index in array at which copying begins. + array is null. + The type of the source cannot be cast automatically to the type of the destination array. + index is less than zero. + array is multidimensional.-or- index is equal to or greater than the length of array.-or- The number of elements in the source is greater than the available space from index to the end of the destination array. 2 + + + + Returns an object for the object. + + + An object for the object. + + + + + Removes the element with the specified key from the object. + + The key of the element to remove. + The object is read-only.-or- The has a fixed size. + key is null. 2 + + + + Returns an enumerator that iterates through a collection. + + + An object that can be used to iterate through the collection. + + + + + Gets a value indicating whether the object is read-only. + + + true if the object is read-only; otherwise, false. + + + + + Gets a value indicating whether the object has a fixed size. + + + true if the object has a fixed size; otherwise, false. + + + + + Gets a value indicating whether access to the is synchronized (thread safe). + + + true if access to the is synchronized (thread safe); otherwise, false. + + + + + Gets an object containing the keys of the object. + + + An object containing the keys of the object. + + + + + Gets an object containing the values in the object. + + + An object containing the values in the object. + + + + + Gets an object that can be used to synchronize access to the . + + + An object that can be used to synchronize access to the . + + + + + Gets the number of elements contained in the . + + + The number of elements contained in the . + + + + + Gets or sets the element with the specified key. + + + The element with the specified key. + + The key of the element to get or set. + The property is set and the object is read-only.-or- The property is set, key does not exist in the collection, and the has a fixed size. + key is null. 2 + + + + Implements a thread-safe wrapper. + + +

+ The implementation is extremely conservative, serializing critical + sections to prevent possible deadlocks, and locking on everything. The + one exception is for enumeration, which is inherently not thread-safe. + For this, you have to lock the SyncRoot object for the + duration of the enumeration. +

+
+ +
+ + + Constructs a thread-safe + wrapper. + + + The object that this object + will wrap. + + + If the supplied ecposes a + SyncRoot value. + + + + + Adds the specified element to this set if it is not already present. + + The object to add to the set. + + is the object was added, + if the object was already present. + + + + + Adds all the elements in the specified collection to the set if + they are not already present. + + A collection of objects to add to the set. + + is the set changed as a result of this + operation. + + + + + Removes all objects from this set. + + + + + Returns if this set contains the specified + element. + + The element to look for. + + if this set contains the specified element. + + + + + Returns if the set contains all the + elements in the specified collection. + + A collection of objects. + + if the set contains all the elements in the + specified collection; also if the + supplied is . + + + + + Removes the specified element from the set. + + The element to be removed. + + if the set contained the specified element. + + + + + Remove all the specified elements from this set, if they exist in + this set. + + A collection of elements to remove. + + if the set was modified as a result of this + operation. + + + + + Retains only the elements in this set that are contained in the + specified collection. + + + The collection that defines the set of elements to be retained. + + + if this set changed as a result of this + operation. + + + + + Copies the elements in the to + an array. + + +

+ The type of array needs to be compatible with the objects in the + , obviously. +

+
+ + An array that will be the target of the copy operation. + + + The zero-based index where copying will start. + +
+ + + Gets an enumerator for the elements in the + . + + + An over the elements + in the . + + + + + Returns a clone of the instance. + + A clone of this object. + + + + Returns if this set contains no elements. + + + + + The number of elements currently contained in this collection. + + + + + Returns if the + is synchronized across + threads. + + + + + + An object that can be used to synchronize this collection to make + it thread-safe. + + + An object that can be used to synchronize this collection to make + it thread-safe. + + + + + + Simple listener that logs application events to the console. + + +

+ Intended for use during debugging only. +

+
+ Rod Johnson + Griffin Caprio (.NET) + +
+ + + A listener for application events. + + Rod Johnson + Griffin Caprio (.NET) + + + + Handle an application event. + + + The source of the event. + + + The event that is to be handled. + + + + + Creates a new instance of the + class. + + + + + Handle an application event. + + + The source of the event. + + + The event that is to be handled. + + + + + Event object sent to listeners registered with an + to inform them of + context lifecycle events. + + Griffin Caprio (.NET) + + + + + + + Encapsulates the data associated with an event raised by an + . + + Rod Johnson + Mark Pollack (.NET) + Griffin Caprio (.NET) + + + + + Creates a new instance of the + class. + + + + + The date and time when the event occured. + + + The date and time when the event occured. + + + + + The system time in milliseconds when the event happened. + + + The system time in milliseconds when the event happened. + + + + + Creates a new instance of the ContextEventArgs class to represent the + supplied context event. + + The type of context event. + + + + Returns a string representation of this object. + + A string representation of this object. + + + + The event type. + + + + + The various context event types. + + + + + The event type when the context is refreshed or created. + + + + + The event type when the context is closed. + + + + + Event object sent to listeners registered with an + to inform them of + context lifecycle event. + + + + + Event object sent to listeners registered with an + to inform them of + context lifecycle event. + + + + + Partial implementation of the + interface. + + +

+ Does not mandate the type of storage used for configuration, but does + implement common functionality. Uses the Template Method design + pattern, requiring concrete subclasses to implement + methods. +

+

+ In contrast to a plain vanilla + , an + is supposed + to detect special objects defined in its object factory: therefore, + this class automatically registers + s, + s + and s that are + defined as objects in the context. +

+

+ An may be also supplied as + an object in the context, with the special, well-known-name of + "messageSource". Else, message resolution is delegated to the + parent context. +

+
+ Rod Johnson + Juergan Hoeller + Griffin Caprio (.NET) + + +
+ + + Configurable implementation of the + interface. + + +

+ This implementation + supports the configuration of resource access protocols and the + corresponding .NET types that know how to handle those protocols. +

+

+ Basic protocol-to-resource type mappings are also defined by this class, + while others can be added either internally, by application contexts + extending this class, or externally, by the end user configuring the + context. +

+

+ Only one resource type can be defined for each protocol, but multiple + protocols can map to the same resource type (for example, the + "http" and "ftp" protocols both map to the + type. The protocols that are + mapped by default can be found in the following list. +

+

+ + + assembly + + + config + + + file + + + http + + + https + + +

+
+ Aleksandar Seovic + + + +
+ + + Describes an object that can load + s. + + +

+ An implementation is + generally required to support the functionality described by this + interface. +

+

+ The class is a + standalone implementation that is usable outside an + ; the aforementioned + class is also used by the + class. +

+
+ Juergen Hoeller + Mark Pollack (.NET) + + + +
+ + + Return an handle for the + specified resource. + + +

+ The handle should always be a reusable resource descriptor; this + allows one to make repeated calls to the underlying + . +

+

+

    +
  • + Must support fully qualified URLs, e.g. "file:C:/test.dat". +
  • +
  • + Should support relative file paths, e.g. "test.dat" (this will be + implementation-specific, typically provided by an + implementation). +
  • +
+

+ + An handle does not imply an + existing resource; you need to check the value of an + 's + property to determine + conclusively whether or not the resource actually exists. + +
+ The resource location. + + An appropriate handle. + + + + +
+ + + The separator between the protocol name and the resource name. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class using the specified default protocol for unqualified resources. + + + + + Returns a that has been + mapped to the protocol of the supplied . + + The name of the resource. + + A new instance for the + supplied . + + + If a + mapping does not exist for the supplied . + + + In the case of any errors arising from the instantiation of the + returned instance. + + + + + + Checks that the supplied starts + with one of the protocol names currently mapped by this + instance. + + The name of the resource. + + if the supplied + starts with one of the known + protocols; if not, or if the supplied + is itself . + + + + + Extracts the protocol name from the supplied + . + + The name of the resource. + + The extracted protocol name or if the + supplied is unqualified (or + is itself ). + + + + + The default protocol to use for unqualified resources. + + +

+ The initial value is "file". +

+
+
+ + + Provides the means to configure an application context in addition to + the methods exposed on the + interface. + + +

+ This interface is to be implemented by most (if not all) + implementations. +

+

+ Configuration and lifecycle methods are encapsulated here to avoid + making them obvious to + client code. +

+

+ Calling will close this + application context, releasing all resources and locks that the + implementation might hold. This includes disposing all cached + singleton objects. +

+ + does not invoke the + attendant on any parent + context. + +
+ Juergen Hoeller + Mark Pollack (.NET) + + +
+ + + The central interface to Spring.NET's IoC container. + + +

+ implementations + provide: + + + + Object factory functionality inherited from the + + and + interfaces. + + + + + The ability to resolve messages, supporting internationalization. + Inherited from the + interface. + + + + + The ability to load file resources in a generic fashion. + Inherited from the + interface. + + + + + Acts an an event registry for supporting loosely coupled eventing + between objecs. Inherited from the + interface. + + + + + The ability to raise events related to the context lifecycle. Inherited + from the + interface. + + + + + Inheritance from a parent context. Definitions in a descendant context + will always take priority. + + + +

+

+ In addition to standard object factory lifecycle capabilities, + implementations need + to detect + , + , and + objects and supply + their attendant dependencies accordingly. +

+

+ This interface is the central client interface in Spring.NET's IoC + container implementation. As such it does inherit a quite sizeable + number of interfaces; implementations are strongly encouraged to use + composition to satisfy each of the inherited interfaces (where + appropriate of course). +

+
+ Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + +
+ + + Extension of the interface + to be implemented by object factories that can enumerate all their object instances, + rather than attempting object lookup by name one by one as requested by clients. + + +

+ implementations that preload + all their objects (for example, DOM-based XML factories) may implement this + interface. This interface is discussed in + "Expert One-on-One J2EE Design and Development", by Rod Johnson. +

+

+ If this is an , + the return values will not take any + hierarchy into account, but + will relate only to the objects defined in the current factory. + Use the helper class to + get all objects. +

+

+ With the exception of + , + the methods and properties in this interface are not designed for frequent + invocation. Implementations may be slow. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + The root interface for accessing a Spring.NET IoC container. + + + + This is the basic client view of a Spring.NET IoC container; further interfaces + such as and + + are available for specific purposes such as enumeration and configuration. + + + This is the root interface to be implemented by objects that can hold a number + of object definitions, each uniquely identified by a + name. An independent instance of any of these objects can be obtained + (the Prototype design pattern), or a single shared instance can be obtained + (a superior alternative to the Singleton design pattern, in which the instance is a + singleton in the scope of the factory). Which type of instance + will be returned depends on the object factory configuration - the API is the same. + The Singleton approach is more useful and hence more common in practice. + + + The point of this approach is that the IObjectFactory is a central registry of + application components, and centralizes the configuring of application components + (no more do individual objects need to read properties files, for example). + See chapters 4 and 11 of "Expert One-on-One J2EE Design and Development" for a + discussion of the benefits of this approach. + + + Normally an IObjectFactory will load object definitions stored in a configuration + source (such as an XML document), and use the + namespace to configure the objects. However, an implementation could simply return + .NET objects it creates as necessary directly in .NET code. There are no + constraints on how the definitions could be stored: LDAP, RDBMS, XML, properties + file etc. Implementations are encouraged to support references amongst objects, + to either Singletons or Prototypes. + + + In contrast to the methods in + , all of the methods + in this interface will also check parent factories if this is an + . If an object is + not found in this factory instance, the immediate parent is asked. Objects in + this factory instance are supposed to override objects of the same name in any + parent factory. + + + Object factories are supposed to support the standard object lifecycle interfaces + as far as possible. The maximum set of initialization methods and their standard + order is: + + + + + + 's + property. + + + + + 's + property. + + + + + + (only applicable if running within an ). + + + + + The + + method of + s. + + + + + 's + method. + + + + + A custom init-method definition. + + + + + The + + method of + s. + + + + +

+ + On shutdown of an object factory, the following lifecycle methods apply: + + + + + + 's + method. + + + + + A custom destroy-method definition. + + + + + + Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + + +

+ Is this object a singleton? + + + + That is, will + always return the same object? + + + Will ask the parent factory if the object cannot be found in this factory + instance. + + + The name of the object to query. + True if the named object is a singleton. + + If there's no such object definition. + +
+ + + Determines whether the specified object name is prototype. That is, will GetObject + always return independent instances? + + This method returning false does not clearly indicate a singleton object. + It indicated non-independent instances, which may correspond to a scoped object as + well. use the IsSingleton property to explicitly check for a shared + singleton instance. + Translates aliases back to the corresponding canonical object name. Will ask the + parent factory if the object can not be found in this factory instance. + + + + The name of the object to query + + true if the specified object name will always deliver independent instances; otherwise, false. + + if there is no object with the given name. + + + + Does this object factory contain an object with the given name? + + + + The concrete lookup strategy depends on the implementation. E.g. s + will also search their parent factory if a name isn't found . + + + The name of the object to query. + True if an object with the given name is defined. + + + + Return the aliases for the given object name, if defined. + + + + Will ask the parent factory if the object cannot be found in this factory + instance. + + + The object name to check for aliases. + The aliases, or an empty array if none. + + If there's no such object definition. + + + + + Return an instance (possibly shared or independent) of the given object name. + + + + This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. + + + Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. + + + Will ask the parent factory if the object cannot be found in this factory + instance. + + + The name of the object to return. + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + + + Return an instance (possibly shared or independent) of the given object name. + + + + This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. + + + Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. + + + Will ask the parent factory if the object cannot be found in this factory + instance. + + + The name of the object to return. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. If there is no factory method and the + arguments are not null, then match the argument values by type and + call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the supplied is . + + + + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + + + Return an instance (possibly shared or independent) of the given object name. + + + + Provides a measure of type safety by throwing an exception if the object is + not of the required . + + + This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. + + + Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. + + + Will ask the parent factory if the object cannot be found in this factory + instance. + + + The name of the object to return. + + the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + + + Determine the type of the object with the given name. + + + + More specifically, checks the type of object that + would return. + For an , returns the type + of object that the creates. + + + The name of the object to query. + + The type of the object or if not determinable. + + + + + Determines whether the object with the given name matches the specified type. + + More specifically, check whether a GetObject call for the given name + would return an object that is assignable to the specified target type. + Translates aliases back to the corresponding canonical bean name. + Will ask the parent factory if the bean cannot be found in this factory instance. + + The name of the object to query. + Type of the target to match against. + + true if the object type matches; otherwise, false + if it doesn't match or cannot be determined yet. + + Ff there is no object with the given name + + + + + Return an unconfigured(!) instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + The unconfigured(!) instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + This method will only instantiate the requested object. It does NOT inject any dependencies! + + + + + Injects dependencies into the supplied instance + using the named object definition. + + + + In addition to being generally useful, typically this method is used to provide + dependency injection functionality for objects that are instantiated outwith the + control of a developer. A case in point is the way that the current (1.1) + ASP.NET classes instantiate web controls... the instantiation takes place within + a private method of a compiled page, and thus cannot be hooked into the + typical Spring.NET IOC container lifecycle for dependency injection. + + + + The following code snippet assumes that the instantiated factory instance + has been configured with an object definition named + 'ExampleNamespace.BusinessObject' that has been configured to set the + Dao property of any ExampleNamespace.BusinessObject instance + to an instance of an appropriate implementation... + + namespace ExampleNamespace + { + public class BusinessObject + { + private IDao _dao; + + public BusinessObject() {} + + public IDao Dao + { + get { return _dao; } + set { _dao = value; } + } + } + } + + with the corresponding driver code looking like so... + + IObjectFactory factory = GetAnIObjectFactoryImplementation(); + BusinessObject instance = new BusinessObject(); + factory.ConfigureObject(instance, "object_definition_name"); + // at this point the dependencies for the 'instance' object will have been resolved... + + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + If there is no object definition for the supplied . + + + If any of the target object's dependencies could not be created. + + + + + Determine whether this object factory treats object names case-sensitive or not. + + + + + Return an instance (possibly shared or independent) of the given object name. + + + + This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. + + + Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. + + + Will ask the parent factory if the object cannot be found in this factory + instance. + + + This is the indexer for the + interface. + + + The name of the object to return. + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + + + Check if this object factory contains an object definition with the given name. + + +

+ Does not consider any hierarchy this factory may participate in. +

+ + Ignores any singleton objects that have been registered by other means + than object definitions. + +
+ The name of the object to look for. + + if this object factory contains an object + definition with the given name. + +
+ + + Return the names of all objects defined in this factory. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + +

+ Does consider objects created by s, + or rather it considers the type of objects created by + (which means that + s will be instantiated). +

+

+ Does not consider any hierarchy this factory may participate in. +

+
+ + The (class or interface) to match, or + for all object names. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + +
+ + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + +

+ Does consider objects created by s, + or rather it considers the type of objects created by + (which means that + s will be instantiated). +

+

+ Does not consider any hierarchy this factory may participate in. + Use + to include beans in ancestor factories too. + <p>Note: Does <i>not</i> ignore singleton objects that have been registered + by other means than bean definitions. +

+
+ + The (class or interface) to match, or + for all object names. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + +
+ + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + +

+ This version of the + method matches all kinds of object definitions, be they singletons, prototypes, or + s. Typically, the results + of this method call will be the same as a call to + IListableObjectFactory.GetObjectsOfType(type,true,true) . +

+
+ + The (class or interface) to match. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + +
+ + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + + The (class or interface) to match. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + + + + + Return the number of objects defined in the factory. + + + The number of objects defined in the factory. + + + + + Sub-interface implemented by object factories that can be part + of a hierarchy. + + Rod Johnson + Rick Evans (.NET) + + + + Determines whether the local object factory contains a bean of the given name, + ignoring object defined in ancestor contexts, also resolving a given alias if necessary. + This is an alternative to ContainsObject, ignoring an object + of the given name from an ancestor object factory. + + The name of the object to query. + + true if objects with the specified name is defined in the local factory; otherwise, false. + + + + + Return the parent object factory, or + if this factory does not have a parent. + + + The parent object factory, or + if this factory does not have a parent. + + + + + Describes an object that can resolve messages. + + +

+ This enables the parameterization and internationalization of messages. +

+

+ Spring.NET provides one out-of-the-box implementation for production + use: +

    +
  • .
  • +
+

+
+ Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + Aleksandar Seovic (.NET) + +
+ + + Resolve the message identified by the supplied + . + + +

+ If the lookup is not successful, implementations are permitted to + take one of two actions. +

+ + + Throw an exception. + + + + Return the supplied as is. + + + +
+ The name of the message to resolve. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + +
+ + + Resolve the message identified by the supplied + . + + +

+ If the lookup is not successful, implementations are permitted to + take one of two actions. +

+ + + Throw an exception. + + + + Return the supplied as is. + + + +
+ The name of the message to resolve. + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + +
+ + + Resolve the message identified by the supplied + . + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. +

+ If the lookup is not successful, implementations are permitted to + take one of two actions. +

+ + + Throw an exception. + + + + Return the supplied as is. + + + +
+ The name of the message to resolve. + + The that represents + the culture for which the resource is localized. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + +
+ + + Resolve the message identified by the supplied + . + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. +

+ If the lookup is not successful, implementations are permitted to + take one of two actions. +

+ + + Throw an exception. + + + + Return the supplied as is. + + + +
+ The name of the message to resolve. + + The that represents + the culture for which the resource is localized. + + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + +
+ + + Resolve the message identified by the supplied + . + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. +

+ If the lookup is not successful, implementations are permitted to + take one of two actions. +

+ + + Throw an exception. + + + + Return the supplied as is. + + + +
+ The name of the message to resolve. + The default message if name is not found. + + The that represents + the culture for which the resource is localized. + + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + +
+ + + Resolve the message using all of the attributes contained within + the supplied + argument. + + + The value object storing those attributes that are required to + properly resolve a message. + + + The that represents + the culture for which the resource is localized. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + Gets a localized resource object identified by the supplied + . + + +

+ This method must use the + + value to obtain a resource. +

+

+ Examples of resources that may be resolved by this method include + (but are not limited to) objects such as icons and bitmaps. +

+
+ + The name of the resource object to resolve. + + + The resolved object, or if not found. + +
+ + + Gets a localized resource object identified by the supplied + . + + +

+ Examples of resources that may be resolved by this method include + (but are not limited to) objects such as icons and bitmaps. +

+
+ + The name of the resource object to resolve. + + + The with which the + resource is associated. + + + The resolved object, or if not found. + +
+ + + Applies resources to object properties. + + +

+ Resource key names are of the form objectName.propertyName. +

+
+ + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + +
+ + + Encapsulates event publication functionality. + + +

+ Serves as a super-interface for the + interface. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Publishes an application context event. + + + The source of the event. May be . + + + The event that is to be raised. + + + + + A registry that manages subscriptions to and the + publishing of events. + + Griffin Caprio + + + + Publishes all events of the source object. + + + The source object containing events to publish. + + + + + Subscribes to all events published, if the subscriber + implements compatible handler methods. + + The subscriber to use. + + + + Subscribes to the published events of all objects of a given + , if the subscriber implements + compatible handler methods. + + The subscriber to use. + + The target to subscribe to. + + + + + Unsubscribes to all events published, if the subscriber + implmenets compatible handler methods. + + The subscriber to use + + + + Unsubscribes to the published events of all objects of a given + , if the subscriber implements + compatible handler methods. + + The subscriber to use. + + The target to unsubscribe from + + + + + Raised in response to an application context event. + + + + + Returns the date and time this context was loaded. + + +

+ This is to be set immediately after an + has been + instantiated and its configuration has been loaded. Implementations + are permitted to update this value if the context is reset or + refreshed in some way. +

+
+ + The representing when this context + was loaded. + + +
+ + + Gets the parent context, or if there is no + parent context. + + +

+ If the parent context is , then this context + is the root of any context hierarchy. +

+
+ + The parent context, or if there is no + parent. + +
+ + + Gets and sets a name for this context. + + + A name for this context. + + + + + Interface defining methods for start/stop lifecycle control. + The typical use case for this is to control asynchronous processing. + + + + Can be implemented by both components (typically a Spring object defined in + a spring and containers + (typically a spring . Containers will + propagate start/stop signals to all components that apply. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Starts this component. + + Should not throw an exception if the component is already running. + In the case of a container, this will propagate the start signal + to all components that apply. + + + + + Stops this component. + + + Should not throw an exception if the component isn't started yet. + In the case of a container, this will propagate the stop signal + to all components that apply. + + + + + Gets a value indicating whether this component is currently running. + + + In the case of a container, this will return true + only if all components that apply are currently running. + + + true if this component is running; otherwise, false. + + + + + Add an + + that will get applied to the internal object factory of this + application context on refresh, before any of the object + definitions are evaluated. + + +

+ To be invoked during context configuration. +

+
+ + The factory processor to register. + + +
+ + + Load or refresh the persistent representation of the configuration, + which might an XML file, properties file, or relational database schema. + + + If the configuration cannot be loaded. + + + If the object factory could not be initialized. + + + + + Return the internal object factory of this application context. + + +

+ Can be used to access specific functionality of the factory. +

+ + This is just guaranteed to return an instance that is not + after the context has been refreshed + at least once. + + + Do not use this to post-process the object factory; singletons + will already have been instantiated. Use an + + to intercept the object factory setup process before objects even + get touched. + +
+ +
+ + + Sets the parent of this application context. + + + + The parent should not be changed: it should only be set + outside a constructor if it isn't available when an instance of + this class is created. + + + + The parent context. + + + + + Interface for registries that hold object definitions, i.e. + + and + + instances. + + +

+ Typically implemented by object factories that work with the + + hierarchy internally. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Determine whether the given object name is already in use within this registry, + i.e. whether there is a local object or alias registered under this name. + + + + + Return the names of all objects defined in this registry. + + + The names of all objects defined in this registry, or an empty array + if none defined + + + + + Check if this registry contains a object definition with the given name. + + + The name of the object to look for. + + + True if this object factory contains an object definition with the + given name. + + + + + Returns the + + for the given object name. + + + The name of the object to find a definition for. + + + The for + the given name (never null). + + + If the object definition cannot be resolved. + + + In case of errors. + + + + + Register a new object definition with this registry. + Must support + + and . + + + The name of the object instance to register. + + + The definition of the object instance to register. + + +

+ Must support + and + . +

+
+ + If the object definition is invalid. + +
+ + + Return the aliases for the given object name, if defined. + + the object name to check for aliases + + +

+ Will ask the parent factory if the object cannot be found in this + factory instance. +

+
+ + The aliases, or an empty array if none. + + + If there's no such object definition. + +
+ + + Given a object name, create an alias. We typically use this method to + support names that are illegal within XML ids (used for object names). + + + The name of the object. + + + The alias that will behave the same as the object name. + + + If there is no object with the given name. + + + If the alias is already in use. + + + + + Return the number of objects defined in the registry. + + + The number of objects defined in the registry. + + + + + Name of the .Net config section that contains Spring.Net context definition. + + + + + Default name of the root context. + + + + + The special, well-known-name of the default + in the context. + + +

+ If no can be found + in the context using this lookup key, then message resolution + will be delegated to the parent context (if any). +

+
+
+ + + The special, well-known-name of the default + in the context. + + +

+ If no can be found + in the context using this lookup key, then a default + will be used. +

+
+
+ + + The instance for this class. + + + + + The instance we delegate + our implementation of said interface to. + + + + + The instance we + delegate our implementation of said interface to. + + + + + Creates a new instance of the + with no parent context. + + +

+ This is an class, and as such exposes + no public constructors. +

+
+
+ + + Creates a new instance of the + with no parent context. + + +

+ This is an class, and as such exposes + no public constructors. +

+
+ Flag specifying whether to make this context case sensitive or not. +
+ + + Creates a new instance of the + with the supplied parent context. + + +

+ This is an class, and as such exposes + no public constructors. +

+
+ The application context name. + Flag specifying whether to make this context case sensitive or not. + The parent application context. +
+ + + Adds the given to the list of standard + processors being added to the underlying + + + Each time is called on this context, the context ensures, that + all default s are registered with the underlying . + + The instance. + + + + Closes this context and disposes of any resources (such as + singleton objects in the wrapped + ). + + + + + Subclasses must implement this method to perform the actual + configuration loading. + + +

+ This method is invoked by + , + before any other initialization occurs. +

+
+ + In the case of errors encountered while refreshing the object factory. + +
+ + + Returns the internal object factory of the parent context if it implements + ; else, + returns the parent context itself. + + + The parent context's object factory, or the parent itself. + + + + + Raises an application context event. + + + Any arguments to the event. May be . + + + + + Raises an application context event. + + + The source of the event. + + + Any arguments to the event. May be . + + + + + Create the strategy to be used + + + + + Modify the application context's internal object factory after its standard + initialization. + + +

+ All object definitions will have been loaded, but no objects + will have been instantiated yet. This allows for the registration + of special + s + in certain + implementations. +

+
+ + The object factory used by the application context. + + + In the case of errors. + . +
+ + + Template method which can be overridden to add context-specific + work before the underlying object factory gets refreshed. + + + + + Template method which can be overridden to add context-specific + refresh work. + + +

+ Called on initialization of special objects, before instantiation + of singletons. +

+
+
+ + + Template method which can be overridden to add context-specific + work after the context was refreshed but before the + event gets raised. + + + + + Instantiate and invoke all registered + + objects, respecting any explicit ordering. + + + + Must be called before singleton instantiation. + + + In the case of errors. + + + + Resets the well-known ObjectPostProcessorChecker that logs an info + message when an object is created during IObjectPostProcessor + instantiation, i.e. when an object is not eligible for being + processed by all IObjectPostProcessors. + + + + + Initializes the default event registry for this context. + + + + + Returns the internal message source of the parent context if said + parent context is an , else + simply the parent context itself. + + + The internal message source of the parent context if said + parent context is an , else + simply the parent context itself. + + + + + Initializes the default message source for this context. + + +

+ Uses any parent context's message source if one is not available + in this context. +

+
+
+ + + Add a new + that will get applied to the internal object factory of this application context + on refresh, before any of the object definitions are evaluated. + + + The factory processor to register. + + + + + Load or refresh the persistent representation of the configuration, + which might an XML file, properties file, or relational database schema. + + + If the configuration cannot be loaded. + + + If the object factory could not be initialized. + + + + + Registers well-known s and + preregisters well-known dependencies using + + the raw object factory as returned from + + + + Ensures, that predefined ObjectPostProcessors are registered with this ObjectFactory + + + + + + Starts this component. + + Should not throw an exception if the component is already running. + In the case of a container, this will propagate the start signal + to all components that apply. + + + + + Stops this component. + + + Should not throw an exception if the component isn't started yet. + In the case of a container, this will propagate the stop signal + to all components that apply. + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the names of all objects defined in this factory. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + Whether to search parent object factories. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + + The (class or interface) to match. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + + + + + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + + The (class or interface) to match. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + + + + + + Check if this object factory contains an object definition with the given name. + + The name of the object to look for. + + True if this object factory contains an object definition with the given name. + + + + + + Does this object factory contain an object with the given name? + + The name of the object to query. + + if an object with the given name is defined. + + + + + + Return the aliases for the given object name, if defined. + + The object name to check for aliases. + The aliases, or an empty array if none. + + If there's no such object definition. + + + + + + Return an unconfigured(!) instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + The unconfigured(!) instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + This method will only instantiate the requested object. It does NOT inject any dependencies! + + + + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + + + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + + + + Return an instance (possibly shared or independent) of the given object name. + + +

+ This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. +

+

+ Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. +

+

+ Will ask the parent factory if the object cannot be found in this factory + instance. +

+
+ The name of the object to return. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. If there is no factory method and the + arguments are not null, then match the argument values by type and + call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the supplied is . + +
+ + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + + + Is this object a singleton? + + The name of the object to query. + True if the named object is a singleton. + + If there's no such object definition. + + + + + + Determines whether the specified object name is prototype. That is, will GetObject + always return independent instances? + + The name of the object to query + + true if the specified object name will always deliver independent instances; otherwise, false. + + This method returning false does not clearly indicate a singleton object. + It indicated non-independent instances, which may correspond to a scoped object as + well. use the IsSingleton property to explicitly check for a shared + singleton instance. + Translates aliases back to the corresponding canonical object name. Will ask the + parent factory if the object can not be found in this factory instance. + + + if there is no object with the given name. + + + + Determines whether the object with the given name matches the specified type. + + More specifically, check whether a GetObject call for the given name + would return an object that is assignable to the specified target type. + Translates aliases back to the corresponding canonical bean name. + Will ask the parent factory if the bean cannot be found in this factory instance. + + The name of the object to query. + Type of the target to match against. + + true if the object type matches; otherwise, false + if it doesn't match or cannot be determined yet. + + Ff there is no object with the given name + + + + + Determine the of the object with the + given name. + + The name of the object to query. + + The of the object, or + if not determinable. + + + + + + Injects dependencies into the supplied instance + using the named object definition. + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + + + + Injects dependencies into the supplied instance + using the supplied . + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + An object definition that should be used to configure object. + + + + + + Determines whether the local object factory contains a bean of the given name, + ignoring object defined in ancestor contexts. + This is an alternative to ContainsObject, ignoring an object + of the given name from an ancestor object factory. + + + + + The name of the object to query. + + true if objects with the specified name is defined in the local factory; otherwise, false. + + + + + Determine whether the given object name is already in use within this context, + i.e. whether there is a local object. May be override by subclasses, the default + implementation simply returns + + + + + Register a new object definition with this registry. + Must support + + and . + + The name of the object instance to register. + The definition of the object instance to register. + +

+ Must support + and + . +

+
+ + If the object definition is invalid. + +
+ + + Given a object name, create an alias. We typically use this method to + support names that are illegal within XML ids (used for object names). + + The name of the object. + The alias that will behave the same as the object name. + + If there is no object with the given name. + + + If the alias is already in use. + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The that represents + the culture for which the resource is localized. + + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If no message could be resolved. + + + If the supplied is . + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + The default message. + + The that represents + the culture for which the resource is localized. + + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If no message could be resolved. + + + If the supplied is . + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The resolved message if the lookup was successful. + + + If no message could be resolved. + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful. + + + If no message could be resolved. + + + If the supplied is . + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The that represents + the culture for which the resource is localized. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If no message could be resolved. + + + If the supplied is . + + + + + + Resolve the message using all of the attributes contained within + the supplied + argument. + + + The value object storing those attributes that are required to + properly resolve a message. + + + The that represents + the culture for which the resource is localized. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The with which the + resource is associated. + + + The resolved object, or if not found. + + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The resolved object, or if not found. + + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The with which the + resource is associated. + + + The resolved object, or if not found. + + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The resolved object, or if not found. + + + + + + Applies resources to object properties. + + + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + + + + + + Publishes all events of the source object. + + + The source object containing events to publish. + + + + + + Subscribes to all events published, if the subscriber + implements compatible handler methods. + + The subscriber to use. + + + + + Subscribes to published events of a all objects of a given + , if the subscriber implements + compatible handler methods. + + The subscriber to use. + + The target to subscribe to. + + + + + + Unsubscribes to all events published, if the subscriber + implmenets compatible handler methods. + + The subscriber to use + + + + Unsubscribes to the published events of all objects of a given + , if the subscriber implements + compatible handler methods. + + The subscriber to use. + + The target to unsubscribe from + + + + + Publishes an application context event. + + +

+ +

+
+ + The source of the event. May be . + + + The event that is to be raised. + + +
+ + + An object that can be used to synchronize access to the + + + + + Set the to be used by this context. + + + + + The timestamp when this context was first loaded. + + + The timestamp (milliseconds) when this context was first loaded. + + + + + Gets a flag indicating whether context should be case sensitive. + + true if object lookups are case sensitive; otherwise, false. + + + + The for this context. + + + If the context has not been initialized yet. + + + + + The for this context. + + + If the context has not been initialized yet. + + + + + Returns the list of the + s + that will be applied to the objects created with this factory. + + +

+ The elements of this list are instances of implementations of the + + interface. +

+
+ + The list of the + s + that will be applied to the objects created with this factory. + +
+ + + Return the internal object factory of this application context. + + + + + Gets the parent context, or if there is no + parent context. + + + The parent context, or if there is no + parent. + + + + + + Gets a value indicating whether this component is currently running. + + + true if this component is running; otherwise, false. + + + In the case of a container, this will return true + only if all components that apply are currently running. + + + + + Gets a dictionary of all singleton beans that implement the + ILifecycle interface in this context. + + A dictionary of ILifecycle objects with object name as key. + + + + Raised in response to an implementation-dependant application + context event. + + + + + The date and time this context was first loaded. + + + The representing when this context + was first loaded. + + + + + A name for this context. + + + A name for this context. + + + + + Return the number of objects defined in the factory. + + + The number of objects defined in the factory. + + + + + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + + + + Return the parent object factory, or if there is none. + + + The parent object factory, or if there is none. + + + + + + Allows for custom modification of new object instances, e.g. + checking for marker interfaces or wrapping them with proxies. + + +

+ Application contexts can auto-detect + + objects in their object definitions and apply them before any other + objects get created. Plain object factories allow for programmatic + registration of post-processors. +

+

+ Typically, post-processors that populate objects via marker interfaces + or the like will implement + , + and post-processors that wrap objects with proxies will normally implement + . +

+
+ Juergen Hoeller + Aleksandar Seovic (.NET) + +
+ + + Apply this + to the given new object instance before any object initialization callbacks. + + +

+ The object will already be populated with property values. + The returned object instance may be a wrapper around the original. +

+
+ + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + +
+ + + Apply this to the + given new object instance after any object initialization callbacks. + + +

+ The object will already be populated with property values. The returned object + instance may be a wrapper around the original. +

+
+ + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + +
+ + + Interface that can be implemented by objects that should be orderable, e.g. in an + . + + +

+ The actual order can be interpreted as prioritization, the first object (with the + lowest order value) having the highest priority. +

+
+ Juergen Hoeller + Aleksandar Seovic (.Net) +
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+ + + Abstract implementation of the interface, + implementing common handling of message variants, making it easy + to implement a specific strategy for a concrete . + + +

Subclasses must implement the abstract ResolveObject + method.

+

Note: By default, message texts are only parsed through + String.Format if arguments have been passed in for the message. In case + of no arguments, message texts will be returned as-is. As a consequence, + you should only use String.Format escaping for messages with actual + arguments, and keep all other messages unescaped. +

+

Supports not only IMessageSourceResolvables as primary messages + but also resolution of message arguments that are in turn + IMessageSourceResolvables themselves. +

+

This class does not implement caching of messages per code, thus + subclasses can dynamically change messages over time. Subclasses are + encouraged to cache their messages in a modification-aware fashion, + allowing for hot deployment of updated messages. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + Harald Radi (.NET) + + + +
+ + + Sub-interface of to be + implemented by objects that can resolve messages hierarchically. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + + The parent message source used to try and resolve messages that + this object can't resolve. + + +

+ If the value of this property is then no + further resolution is possible. +

+
+
+ + + holds the logger instance shared with subclasses. + + + + + Initializes this instance. + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the lookup is not successful throw NoSuchMessageException + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + The that represents + the culture for which the resource is localized. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. +

+ If the lookup is not successful, implementations are permitted to + take one of two actions. +

+ If the lookup is not successful throw NoSuchMessageException +
+
+ + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the lookup is not successful throw NoSuchMessageException + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + The that represents + the culture for which the resource is localized. + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. +

+ If the lookup is not successful throw NoSuchMessageException. +

+
+
+ + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + The default message if name is not found. + The that represents + the culture for which the resource is localized. + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. +

+ If the lookup is not successful throw NoSuchMessageException +

+
+
+ + + Resolve the message using all of the attributes contained within + the supplied + argument. + + The value object storing those attributes that are required to + properly resolve a message. + The that represents + the culture for which the resource is localized. + + The resolved message if the lookup was successful. + + + If the message could not be resolved. + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The resolved object, or if not found. + + + + + + Gets a localized resource object identified by the supplied + . + + + Note that the fallback behavior based on CultureInfo seem to + have a bug that is fixed by installed .NET 1.1 Service Pack 1. + + + The name of the resource object to resolve. + + + The with which the + resource is associated. + + + The resolved object, or if not found. If + the resource name resolves to null, then in .NET 1.1 the return + value will be String.Empty whereas in .NET 2.0 it will return + null. + + + + + + Applies resources to object properties. + + + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + + + + + Resolve the given code and arguments as message in the given culture, + returning null if not found. Does not fall back to the code + as default message. Invoked by GetMessage methods. + + The code to lookup up, such as 'calculator.noRateSet'. + array of arguments that will be filled in for params + within the message. + The with which the + resource is associated. + + The resolved message if the lookup was successful. + + + + + Try to retrieve the given message from the parent MessageSource, if any. + + The code to lookup up, such as 'calculator.noRateSet'. + array of arguments that will be filled in for params + within the message. + The with which the + resource is associated. + + The resolved message if the lookup was successful. + + + + + Return a fallback default message for the given code, if any. + + + Default is to return the code itself if "UseCodeAsDefaultMessage" + is activated, or return no fallback else. In case of no fallback, + the caller will usually receive a NoSuchMessageException from GetMessage + + The code to lookup up, such as 'calculator.noRateSet'. + The default message to use, or null if none. + + + + Renders the default message string. The default message is passed in as specified by the + caller and can be rendered into a fully formatted default message shown to the user. + + Default implementation passed he String for String.Format resolving any + argument placeholders found in them. Subclasses may override this method to plug + in custom processing of default messages. + + The default message. + The array of agruments that will be filled in for parameter + placeholders within the message, or null if none. + The with which the + resource is associated. + The rendered default message (with resolved arguments) + + + + Format the given default message String resolving any + agrument placeholders found in them. + + The message to format. + The array of agruments that will be filled in for parameter + placeholders within the message, or null if none. + The with which the + resource is associated. + The formatted message (with resolved arguments) + + + + Search through the given array of objects, find any + MessageSourceResolvable objects and resolve them. + + + Allows for messages to have MessageSourceResolvables as arguments. + + + The array of arguments for a message. + The with which the + resource is associated. + An array of arguments with any IMessageSourceResolvables resolved + + + + Gets the specified resource (e.g. Icon or Bitmap). + + The name of the resource to resolve. + + The to resolve the + code for. + + The resource if found. otherwise. + + + + Applies resources from the given name on the specified object. + + + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + + + + + Subclasses must implement this method to resolve a message. + + The code to lookup up, such as 'calculator.noRateSet'. + The with which the + resource is associated. + The resolved message from the backing store of message data. + + + + Resolves an object (typically an icon or bitmap). + + +

+ Subclasses must implement this method to resolve an object. +

+
+ The code of the object to resolve. + + The to resolve the + code for. + + + The resolved object or if not found. + +
+ + + Applies resources to object properties. + + +

+ Subclasses must implement this method to apply resources + to an arbitrary object. +

+
+ + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + +
+ + Gets or Sets a value indicating whether to use the message code as + default message instead of throwing a NoSuchMessageException. + Useful for development and debugging. Default is "false". + + +

Note: In case of a IMessageSourceResolvable with multiple codes + (like a FieldError) and a MessageSource that has a parent MessageSource, + do not activate "UseCodeAsDefaultMessage" in the parent: + Else, you'll get the first code returned as message by the parent, + without attempts to check further codes.

+

To be able to work with "UseCodeAsDefaultMessage" turned on in the parent, + AbstractMessageSource contains special checks + to delegate to the internal GetMessageInternal method if available. + In general, it is recommended to just use "UseCodeAsDefaultMessage" during + development and not rely on it in production in the first place, though.

+

Alternatively, consider overriding the GetDefaultMessage + method to return a custom fallback message for an unresolvable code.

+
+ + true if use the message code as default message instead of + throwing a NoSuchMessageException; otherwise, false. + +
+ + + The parent message source used to try and resolve messages that + this object can't resolve. + + + +

+ If the value of this property is then no + further resolution is possible. +

+
+
+ + + Convenient abstract superclass for + implementations that + draw their configuration from XML documents containing object + definitions as understood by an + . + + Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes + no public constructors. +

+
+
+ + + Creates a new instance of the + class + with the given parent context. + + +

+ This is an class, and as such exposes + no public constructors. +

+
+ The application context name. + Flag specifying whether to make this context case sensitive or not. + The parent context. +
+ + + Instantiates and populates the underlying + with the object + definitions yielded up by the + method. + + + In the case of errors encountered while refreshing the object factory. + + + In the case of errors encountered reading any of the resources + yielded by the method. + + + + + + Initialize the object definition reader used for loading the object + definitions of this context. + + +

+ The default implementation of this method is a no-op; i.e. it does + nothing. Can be overridden in subclasses to provide custom + initialization of the supplied + ; for example, a derived + class may want to turn off XML validation. +

+
+ + The object definition reader used by this context. + +
+ + + Load the object definitions with the given + . + + +

+ The lifecycle of the object factory is handled by + ; + therefore this method is just supposed to load and / or register + object definitions. +

+
+ + The reader containing object definitions. + + In case of object registration errors. + + + In the case of errors encountered reading any of the resources + yielded by either the or + the methods. + +
+ + + Loads the object definitions into the given object factory, typically through + delegating to one or more object definition readers. + + The object factory to lead object definitions into + + + + + + Create a new reader instance for importing object definitions into the specified . + + the to be associated with the reader + a new instance. + + + + Customizes the internal object factory used by this context. + + Called for each attempt. +

+ The default implementation is empty. Can be overriden in subclassses to customize + DefaultListableBeanFatory's standard settings. +

+ The newly created object factory for this context +
+ + + Create an internal object factory for this context. + + +

+ Called for each attempt. + This default implementation creates a + + with the internal object factory of this context's parent serving + as the parent object factory. Can be overridden in subclasse,s + for example to customize DefaultListableBeanFactory's settings. +

+
+ The object factory for this context. +
+ + + Determine whether the given object name is already in use within this context's object factory, + i.e. whether there is a local object or alias registered under this name. + + + + + An array of resource locations, referring to the XML object + definition files that this context is to be built with. + + +

+ Examples of the format of the various strings that would be + returned by accessing this property can be found in the overview + documentation of with the + class. +

+
+ + An array of resource locations, or if none. + +
+ + + An array of resources that this context is to be built with. + + +

+ Examples of the format of the various strings that would be + returned by accessing this property can be found in the overview + documentation of with the + class. +

+
+ + An array of s, or if none. + +
+ + + Subclasses must return their internal object factory here. + + + The internal object factory for the application context. + + + + + + + implementation that passes the application context to object that + implement the + , + , and + interfaces. + + +

+ If an object's class implements more than one of the + , + , and + interfaces, then the + order in which the interfaces are satisfied is as follows... + + + + + + + + + + + +

+

+ Application contexts will automatically register this with their + underlying object factory. Applications should thus never need to use + this class directly. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + The that this + instance will work with. + + + + + Apply this + to the given new object instance before any object + initialization callbacks. + + + The new object instance. + + + The name of the object. + + + The the object instance to use, either the original or a wrapped one. + + + In case of errors. + + + + + + Apply this to the + given new object instance after any object initialization + callbacks. + + + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + + + + + + Convenient superclass for application objects that want to be aware of + the application context, e.g. for custom lookup of collaborating object + or for context-specific resource access. + + +

+ It saves the application context reference and provides an + initialization callback method. Furthermore, it offers numerous + convenience methods for message lookup. +

+

+ There is no requirement to subclass this class: it just makes things + a little easier if you need access to the context, e.g. for access to + file resources or to the message source. Note that many application + objects do not need to be aware of the application context at all, + as they can receive collaborating objects via object references. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) +
+ + + To be implemented by any object that wishes to be notified + of the that it runs in. + + +

+ Implementing this interface makes sense when an object requires access + to a set of collaborating objects. Note that configuration via object + references is preferable to implementing this interface just for object + lookup purposes. +

+

+ This interface can also be implemented if an object needs access to + file resources, i.e. wants to call + , or access to + the . However, it is + preferable to implement the more specific + + interface to receive a reference to the + object in that scenario. +

+

+ Note that dependencies can also + be exposed as object properties of the + type, populated via strings with + automatic type conversion performed by an object factory. This obviates + the need for implementing any callback interface just for the purpose + of accessing a specific file resource. +

+

+ + is a convenience implementation of this interface for your + application objects. +

+

+ For a list of all object lifecycle methods, see the overview for the + interface. +

+
+ Rod Johnson + Mark Pollack (.NET) + + + +
+ + + Sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+ + The that this + object runs in. + +
+ + + Intializes the wrapped + . + + +

+ This is a template method that subclasses can override for custom + initialization behavior. +

+

+ Gets called by the + + instance directly after setting the context instance. +

+ + Does not get called on reinitialization of the context. + +
+ + In the case of any initialization errors. + + + If thrown by application context methods. + +
+ + + The context class that any context passed to the + + must be an instance of. + + + The + . + + + + + Return a for the + application context used by this object, for easy message access. + + + + + Gets or sets the that this + object runs in. + + + When passed an unexpected + implementation + instance that is not compatible with the + defined by the value of the + . + property. Also, thrown when trying to re-initialize with a + different than was + originally used. + + + If thrown by any application context methods. + + + + + + + Creates an instance + using context definitions supplied in a custom configuration and + configures the with that instance. + + + Implementations of the + interface must provide the following two constructors: + + + + A constructor that takes a string array of resource locations. + + + + + A constructor that takes a reference to a parent application context + and a string array of resource locations (and in that order). + + + +

+ Note that if the type attribute is not present in the declaration + of a particular context, then a default + + is assumed. This default + + is currently the + ; please note the exact + of this default is an + implementation detail, that, while unlikely, may do so in the future. + to +

+
+ +

+ This is an example of specifying a context that reads its resources from + an embedded Spring.NET XML object configuration file... +

+ + + + +
+ + + + + + + + + +

+ This is an example of specifying a context that reads its resources from + a custom configuration section within the same application / web + configuration file and uses case insensitive object lookups. +

+

+ Please note that you must adhere to the naming + of the various sections (i.e. '<sectionGroup name="spring">' and + '<section name="context">'. +

+ + + + +
+
+ + + + + + + + + + + + +

+ And this is an example of specifying a hierarchy of contexts. The + hierarchy in this case is only a simple parent->child hierarchy, but + hopefully it illustrates the nesting of context configurations. This + nesting of contexts can be arbitrarily deep, and is one way... child + contexts know about their parent contexts, but parent contexts do not + know how many child contexts they have (if any), or have references + to any such child contexts. +

+ + + + +
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Mark Pollack + Aleksandar Seovic + Rick Evans + + + + + Creates an instance + using the context definitions supplied in a custom + configuration section. + + +

+ This instance is + also used to configure the . +

+
+ + The configuration settings in a corresponding parent + configuration section. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is . + + + The for the section. + + + An instance + populated with the object definitions supplied in the configuration + section. + +
+ + + Create all child-contexts in the given for the given context. + + The parent context to use + The current configContext + The list of child context elements + + + + Instantiates a new context. + + + + + Gets the context's name specified in the name attribute of the context element. + + The current configContext + The context element + + + + Extracts the context-type from the context element. + If none is specified, returns the parent's type. + + + + + Extracts the case-sensitivity attribute from the context element + + + + + Gets the context specified in the type + attribute of the context element. + + +

+ If this attribute is not defined it defaults to the + type. +

+
+ + If the context type does not implement the + interface. + +
+ + + Returns the array of resources containing object definitions for + this context. + + + + + Returns the array of child contexts for this context. + + + + + The of + created if no type attribute is specified on a context element. + + + + + + Get the context's case-sensitivity to use if none is specified + + +

+ Derived handlers may override this property to change their default case-sensitivity. +

+

+ Defaults to 'true'. +

+
+
+ + + Specifies, whether the instantiated context will be automatically registered in the + global . + + + + + Returns if the context should be lazily + initialized. + + + + + Constants defining the structure and values associated with the + schema for laying out Spring.NET contexts in XML. + + + + + Defines a single + . + + + + + Specifies a context name. + + + + + Specifies if context should be case sensitive or not. Default is true. + + + + + Specifies a . + + +

+ Does not have to be fully assembly qualified, but its generally regarded + as better form if the names of one's objects + are specified explicitly. +

+
+
+ + + Specifies whether context should be lazy initialized. + + + + + Defines an + + + + + Specifies the URI for an + . + + + + + Provides access to a central registry of + s. + + +

+ A singleton implementation to access one or more application contexts. Application + context instances are cached. +

+

Note that the use of this class or similar is unnecessary except (sometimes) for + a small amount of glue code. Excessive usage will lead to code that is more tightly + coupled, and harder to modify or test. Consider refactoring your code to use standard + Dependency Injection techniques or implement the interface IApplicationContextAware to + obtain a reference to an application context.

+
+ Mark Pollack + Aleksandar Seovic + +
+ + + The shared instance for this class (and derived classes). + + + + + Creates a new instance of the ContextRegistry class. + + +

+ Explicit static constructor to tell C# compiler + not to mark type as beforefieldinit. +

+
+
+ + + Registers an instance of an + . + + +

+ This is usually called via a + inside a .NET + application configuration file. +

+
+ The application context to be registered. + + If a context has previously been registered using the same name + +
+ + + Handles events raised by an application context. + + + + + + + Removes the context from the registry + + + Has no effect if the context wasn't registered + + ´the context to remove from the registry + + + + Returns the root application context. + + +

+ The first call to GetContext will create the context + as specified in the .NET application configuration file + under the location spring/context. +

+
+ The root application context. +
+ + + Returns context based on specified name. + + +

+ The first call to GetContext will create the context + as specified in the .NET application configuration file + under the location spring/context. +

+
+ The context name. + The specified context, or null, if context with that name doesn't exists. + + If the context name is null or empty + +
+ + + Removes all registered + s from this + registry. + + + Raises the event while still holding a lock on + + + + + Allows to check, if a context is already registered + + The context name. + true, if the context is already registered. false otherwise + + + + This event is fired, if ContextRegistry.Clear() is called.
+ Clients may register to get informed +
+ + This event is fired while still holding a lock on the Registry.
+ 'sender' parameter is sent as typeof(ContextRegistry), EventArgs are not used +
+
+ + + Gets an object that should be used to synchronize access to ContextRegistry + from the calling code. + + + + + Default implementation of the + interface. + + +

+ Provides easy ways to store all the necessary values needed to resolve + messages from an . +

+
+ Juergen Hoeller + Griffin Caprio (.NET) + +
+ + + Describes objects that are suitable for message resolution in a + . + + +

+ Spring.NET's own validation error classes implement this interface. +

+
+ Juergen Hoeller + Mark Pollack (.NET) + + +
+ + + Return the codes to be used to resolve this message, in the order + that they are to be tried. + + +

+ The last code will therefore be the default one. +

+
+ + A array of codes which are associated + with this message. + +
+ + + Return the array of arguments to be used to resolve this message. + + + An array of objects to be used as parameters to replace + placeholders within the message text. + + + + + Return the default message to be used to resolve this message. + + + The default message, or if there is no + default. + + + + + Creates a new instance of the + class + using a single code. + + The message code to be resolved. + + + + Initializes a new instance of the class. + + The codes to be used to resolve this message + + + + Creates a new instance of the + class + using multiple codes. + + The message codes to be resolved. + + The arguments used to resolve the supplied . + + + + + Creates a new instance of the + class + using multiple codes and a default message. + + The message codes to be resolved. + + The arguments used to resolve the supplied . + + + The default message used if no code could be resolved. + + + + + Creates a new instance of the + class + from another resolvable. + + +

+ This is the copy constructor for the + class. +

+
+ + The to be copied. + + + If the supplied is . + +
+ + + Returns a representation of this + . + + + A representation of this + . + + + + + Calls the visit method on the supplied + to output a version of this class. + + The visitor to use. + + A representation of this + . + + + + + Return the codes to be used to resolve this message, in the order + that they are to be tried. + + + A array of codes which are associated + with this message. + + + + + + Return the array of arguments to be used to resolve this message. + + + An array of objects to be used as parameters to replace + placeholders within the message text. + + + + + + Return the default code for this resolvable. + + + The default code of this resolvable; this will be the last code in + the codes array, or if this instance has no + codes. + + + + + + Return the default message to be used to resolve this message. + + + The default message, or if there is no + default. + + + + + + Default section handler that can handle any configuration section. + + +

+ Simply returns the configuration section as an . +

+
+ Aleksandar Seovic +
+ + + Returns the configuration section as an + + + The configuration settings in a corresponding parent + configuration section. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is a null reference. + + + The for the section. + + Config section as XmlElement. + + + + Empty implementation that + simply delegates all method calls to it's parent + . + + +

+ If no parent is available, + no messages will be resolved (and a + will be thrown). +

+

+ Used as placeholder by the + class, + if the context definition doesn't define its own + . Not intended for direct use + in applications. +

+
+ Juergan Hoeller + Rick Evans (.NET) + +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The parent message source used to try and resolve messages that + this object can't resolve. + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The that represents + the culture for which the resource is localized. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + + The that represents + the culture for which the resource is localized. + + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + + Resolve the message identified by the supplied + . + + The name of the message to resolve. + The default message. + + The that represents + the culture for which the resource is localized. + + + The array of arguments that will be filled in for parameters within + the message, or if there are no parameters + within the message. Parameters within a message should be + referenced using the same syntax as the format string for the + method. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + + + + Resolve the message using all of the attributes contained within + the supplied + argument. + + + The value object storing those attributes that are required to + properly resolve a message. + + + The that represents + the culture for which the resource is localized. + + + The resolved message if the lookup was successful (see above for + the return value in the case of an unsuccessful lookup). + + + If the message could not be resolved. + + + If the message could not be resolved. + + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The resolved object, or if not found. + + + + + + Gets a localized resource object identified by the supplied + . + + + The name of the resource object to resolve. + + + The with which the + resource is associated. + + + The resolved object, or if not found. + + + + + + Applies resources to object properties. + + + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + + + + + + The parent message source used to try and resolve messages that + this object can't resolve. + + + + + + Generic ApplicationContext implementation that holds a single internal + instance and does not + assume a specific object definition format. + + + Implements the interface in order + to allow for aplying any object definition readers to it. + Typical usage is to register a variety of object definitions via the + interface and then call + to initialize those + objects with application context semantics (handling + , auto-detecting + ObjectFactoryPostProcessors, etc). + + In contrast to other IApplicationContext implementations that create a new internal + IObjectFactory instance for each refresh, the internal IObjectFactory of this context + is available right from the start, to be able to register object definitions on it. + may only be called once + Usage examples + + GenericApplicationContext ctx = new GenericApplicationContext(); + // register your objects and object definitions + ctx.RegisterObjectDefinition(...) + ctx.Refresh(); + + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + if set to true names in the context are case sensitive. + + + + Initializes a new instance of the class. + + The object factory instance to use for this context. + + + + Initializes a new instance of the class. + + The parent application context. + + + + Initializes a new instance of the class. + + The name of the application context. + if set to true names in the context are case sensitive. + The parent application context. + + + + Initializes a new instance of the class. + + The object factory to use for this context + The parent applicaiton context. + + + + Initializes a new instance of the class. + + The name of the application context. + if set to true names in the context are case sensitive. + The parent application context. + The object factory to use for this context + + + + Do nothing operation. We hold a single internal ObjectFactory and rely on callers + to register objects throug our public methods (or the ObjectFactory's). + + + In the case of errors encountered while refreshing the object factory. + + + + + Determines whether the given object name is already in use within this factory, + i.e. whether there is a local object or alias registered under this name or + an inner object created with this name. + + + + + Return the internal object factory of this application context. + + + + + + Gets the underlying object factory of this context, available for + registering object definitions. + + You need to call Refresh to initialize the + objects factory and its contained objects with application context + semantics (autodecting IObjectFactoryPostProcessors, etc). + The internal object factory (as DefaultListableObjectFactory). + + + + Helper class for easy access to messages from an + , providing various + overloaded GetMessage methods. + + +

+ Available from + , but also + reusable as a standalone helper to delegate to in application objects. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) + + +
+ + + Creates a new instance of the + class + that uses the current + for all locale specific lookups. + + + The to use to locate messages. + + + + + Creates a new instance of the + class + + + The to use to locate + messages. + + + The to use for + locale specific messages. + + + + + Retrieve the message for the given code and the default + . + + The code of the message. + The message. + + + + Retrieve the message for the given code and the given + . + + The code of the message. + + The to use for + lookups. + + The message. + + + + Retrieve the message for the given code and the default + . + + The code of the message. + + The arguments for the message, or if none. + + The message. + + If the message could not be found. + + + + + Retrieve the message for the given code and the given + . + + The code of the message. + + The to use for + lookups. + + + The arguments for the message, or if none. + + The message. + + If the message could not be found. + + + + + Retrieve a mesage using the given + . + + + The . + + The message. + + If the message could not be found. + + + + + Retrieve a mesage using the given + in the given + . + + + The . + + + The to use for + lookups. + + The message + + If the message could not be found. + + + + + Visitor class to represent + instances. + + +

+ Used in the first instance to supply stringified versions of + instances. +

+

+ Other methods can be added here to return different representations, + including XML, CSV, etc.. +

+
+ Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Outputs the supplied + as a nicely formatted . + + + The to output. + + + + + Configuration section handler for the (recommended, Spring.NET standard) parsers + config section. + + +

+ Spring.NET allows the registration of custom configuration parsers that + can be used to create simplified configuration schemas that better + describe object definitions. +

+

+ For example, Spring.NET uses this facility internally in order to + define simplified schemas for various AOP, Data and Services definitions. +

+
+ +

+ The following example shows how to configure both this section handler + and how to define custom configuration parsers within a Spring.NET + config section. +

+ + + + +
+ + + + + + + ... + + ... + + + + + Aleksandar Seovic + + + + + Registers parsers specified in the (recommended, Spring.NET standard) + parsers config section with the . + + + The configuration settings in a corresponding parent + configuration section. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is . + + + The for the section. + + + This method always returns , because parsers + are registered as a side-effect of this object's execution and there + is thus no need to return anything. + + + + + An that doesn't do a whole lot. + + +

+ is an implementation of + the NullObject pattern. It should be used in those situations where a + needs to be passed (say to a + method) but where the resolution of messages is not required. +

+

+ There should not (typically) be a need to instantiate instances of this class; + does not maintan any state + and the instance is + thus safe to pass around. +

+
+ Aleksandar Seovic +
+ + + The canonical instance of the + class. + + + + + Creates a new instance of the class. + + +

+ Consider using + instead. +

+
+
+ + + Simply returns the supplied message as-is. + + The code of the message to resolve. + + The to resolve the + code for. + + + The supplied message as-is. + + + + + Always returns . + + The code of the object to resolve. + + The to resolve the + code for. + + + (always). + + + + + Does nothing. + + + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + + + + + Handler for Spring.NET resourceHandlers config section. + + +

+ Spring allows registration of custom resource handlers that can be used to load + object definitions from. +

+

+ For example, if you wanted to store your object definitions in a database instead + of in the config file, you could write a custom implementation + and register it with Spring using 'db' as a protocol name. +

+

+ Afterwards, you would simply specify resource URI within the context config element + using your custom resource handler. +

+
+ +

+ The following example shows how to configure both this section handler, + how to define custom resource within Spring config section, and how to load + object definitions using custom resource handler: +

+ + + + +
+ + + + + + + + + + + + + + Aleksandar Seovic + + + + + Registers resource handlers that are specified in + the resources config section with the . + + + The configuration settings in a corresponding parent + configuration section. Ignored. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is . + + + The for the section. + + + This method always returns null, because resource handlers are registered + as a sideffect of its execution and there is no need to return anything. + + + + + An implementation that + accesses resources from .resx / .resource files. + + Note that for the method + GetResourceObject if the resource name resolves to null, then in + .NET 1.1 the return value will be String.Empty whereas + in .NET 2.0 it will return null. + Griffin Caprio (.NET) + Mark Pollack (.NET) + Aleksandar Seovic (.NET) + + + + Defines a simple initialization callback for objects that need to to some + post-initialization logic after all of their dependencies have been injected. + + +

+ An implementation of the + + method might perform some additional custom initialization (over and above that + performed by the constructor), or merely check that all mandatory properties + have been set (this last example is a very typical use case of this interface). +

+ + The use of the + interface + by non-Spring.NET framework code can be avoided (and is generally + discouraged). The Spring.NET container provides support for a generic + initialization method given to the object definition in the object + configuration store (be it XML, or a database, etc). This requires + slightly more configuration (one attribute-value pair in the case of + XML configuration), but removes any dependency on Spring.NET from the + class definition. + +
+ Rod Johnson + Rick Evans (.NET) + +
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Creates a new instance of the + class. + + + + + Resolves a given code by searching through each assembly name in + the base names array. + + The code to resolve. + + The to use for lookups. + + The message from the resource set. + + + + Resolves a given code by searching through each assembly name in the array. + + The code to resolve. + + The to use for lookups. + + The object from the resource set. + + + + Uses a System.ComponentModel.ComponentResourceManager + to apply resources to object properties. + Resource key names are of the form objectName.propertyName + + + This feature is not currently supported on version 1.0 of the .NET platform. + + + An object that contains the property values to be applied. + + + The base name of the object to use for the key lookup. + + + The to use for lookups. + If , uses the + value. + + + This feature is not currently supported on version 1.0 of the .NET platform. + + + + + Resolves a code into an object given a base name. + + The to search. + The code to resolve. + + The to use for lookups. + + The object from the resource file. + + + + Returns a representation of the + . + + A representation of the + . + + + + Invoked by an + after it has set all object properties supplied. + + +

+ The list may contain objects of type or + . types + are converted to instances using the notation + resourcename, assembly partial name. +

+
+ + If the conversion from a to a + can't be performed. + +
+ + + The collection of s + in this . + + + + + that allows concrete registration of + objects and messages in code, rather than from external configuration sources. + + +

+ Mainly useful for testing. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the StaticApplicationContext class. + + + + + Creates a new instance of the StaticApplicationContext class. + + The parent application context. + + + + Creates a new, named instance of the StaticApplicationContext class. + + the context name + The parent application context. + + + + Do nothing: we rely on callers to update our public methods. + + + + + Register a singleton object with the default object factory. + + The name of the object. + The of the object. + The property values for the singleton instance. + + + + Registers a prototype object with the default object factory. + + The name of the prototype object. + The of the prototype object. + The property values for the prototype instance. + + + + Associate the given message with the given code. + + The lookup code. + + The that the message should be found within. + + The message associated with the lookup code. + + + + Simple implementation of + that allows messages to be held in an object and added programmatically. + + +

+ Mainly useful for testing. +

+

+ This supports internationalization. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + +
+ + + Creates a new instance of the + class. + + + + + Returns a format string. + + The code of the message to resolve. + + The to resolve the + code for. + + + A format string or if not found. + + + + + + Resolves an object (typically an icon or bitmap). + + The code of the object to resolve. + + The to resolve the + code for. + + + The resolved object or if not found. + + + + + + Applies resources to object properties. + + +

+ Uses a System.ComponentModel.ComponentResourceManager + internally to apply resources to object properties. Resource key + names are of the form objectName.propertyName. +

+

+ This feature is not currently supported on version 1.0 of the .NET platform. +

+
+ + An object that contains the property values to be applied. + + + The base name of the object to use for key lookup. + + + The with which the + resource is associated. + + + This feature is not currently supported on version 1.0 of the .NET platform. + + +
+ + + Associate the supplied with the + supplied . + + The lookup code. + + The to resolve the + code for. + + + The message format associated with this lookup code. + + + + + Associate the supplied with the + supplied . + + The lookup code. + + The to resolve the + code for. + + + The object associated with this lookup code. + + + + + Returns a representation of this + message source. + + + A containing all of this message + source's messages. + + + + + Configuration section handler for the Spring.NET typeAliases + config section. + + +

+ Type aliases can be used instead of fully qualified type names anywhere + a type name is expected in a Spring.NET configuration file. +

+

+ This includes type names specified within an object definition, as well + as values of the properties or constructor arguments that expect + instances. +

+
+ +

+ The following example shows how to configure both this section handler and + how to define type aliases within a Spring.NET config section: +

+ + + + +
+ + + + + + + ... + + ... + + + + + Aleksandar Seovic + + + + + Populates using values specified in + the typeAliases config section. + + + The configuration settings in a corresponding parent + configuration section. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is . + + + The for the section. + + + This method always returns , because the + is populated as a side-effect of this + object's execution and thus there is no need to return anything. + + + + + Configuration section handler for the Spring.NET typeConverters + config section. + + +

+ Type converters are used to convert objects from one type into another + when injecting property values, evaluating expressions, performing data + binding, etc. +

+

+ They are a very powerful mechanism as they allow Spring.NET to automatically + convert string-based property values from the configuration file into the appropriate + type based on the target property's type or to convert string values submitted + via a web form into a type that is used by your data model when Spring.NET data + binding is used. Because they offer such tremendous help, you should always provide + a type converter implementation for your custom types that you want to be able to use + for injected properties or for data binding. +

+

+ The standard .NET mechanism for specifying type converter for a particular type is + to decorate the type with a , passing the type + of the -derived class as a parameter. +

+

+ This mechanism will still work and is a preferred way of defining type converters if + you control the source code for the type that you want to define a converter for. However, + this configuration section allows you to specify converters for the types that you don't + control and it also allows you to override some of the standard type converters, such as + the ones that are defined for some of the types in the .NET Base Class Library. +

+
+ +

+ The following example shows how to configure both this section handler and + how to define type converters within a Spring.NET config section: +

+ + + + +
+ + + + + + + ... + + ... + + + + + Aleksandar Seovic + + + + + Populates using values specified in + the typeConverters config section. + + + The configuration settings in a corresponding parent + configuration section. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is . + + + The for the section. + + + This method always returns , because the + is populated as a side-effect of + its execution and thus there is no need to return anything. + + + + + An implementation that + reads context definitions from XML based resources. + + +

+ Currently, the resources that are supported are the file, + http, ftp, config and assembly resource + types. +

+

+ You can provide custom implementations of the + interface and and register them + with any that inherits + from the + + interface. +

+ + In case of multiple config locations, later object definitions will + override ones defined in previously loaded resources. This can be + leveraged to deliberately override certain object definitions via an + extra XML file. + +
+ +

+ Find below some examples of instantiating an + using a + variety of different XML resources. +

+ + // an XmlApplicationContext that reads its object definitions from an + // XML file that has been embedded in an assembly... + IApplicationContext context = new XmlApplicationContext + ( + "assembly://AssemblyName/NameSpace/ResourceName" + ); + + // an XmlApplicationContext that reads its object definitions from a + // number of disparate XML resources... + IApplicationContext context = new XmlApplicationContext + ( + // from an XML file that has been embedded in an assembly... + "assembly://AssemblyName/NameSpace/ResourceName", + // and from a (relative) filesystem-based resource... + "file://Objects/services.xml", + // and from an App.config / Web.config resource... + "config://spring/objects" + ); + +
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + + + +
+ + + Initializes a new instance of the XmlApplicationContext class. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations. + + The created context will be case sensitive. + + Any number of XML based object definition resource locations. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations. + + Flag specifying whether to make this context case sensitive or not. + + Any number of XML based object definition resource locations. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + + Any number of XML based object definition resource locations. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations, + with the given . + + + The parent context (may be ). + + + Any number of XML based object definition resource locations. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations, + with the given . + + Flag specifying whether to make this context case sensitive or not. + + The parent context (may be ). + + + Any number of XML based object definition resource locations. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations, + with the given . + + The application context name. + Flag specifying whether to make this context case sensitive or not. + + The parent context (may be ). + + + Any number of XML based object definition resource locations. + + + + + Creates a new instance of the + class, + loading the definitions from the supplied XML resource locations, + with the given . + + + This constructor is meant to be used by derived classes. By passing =false, it is + the responsibility of the deriving class to call to initialize the context instance. + + if true, is called automatically. + The application context name. + Flag specifying whether to make this context case sensitive or not. + + The parent context (may be ). + + + Any number of XML based object definition resource locations. + + + + + An array of resource locations, referring to the XML object + definition files with which this context is to be built. + + + An array of resource locations, or if none. + + + + + + An array of resources instances with which this context is to be built. + + + An array of s, or if none. + + + + + + Encapsulates arguments to the class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + + + + Initializes a new instance of the XmlApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + if set to true [case sensitive]. + if set to true [refresh]. + + + Exception thrown during application context initialization. + Rod Johnson + Mark Pollack (.NET) + + + + Thrown on an unrecoverable problem encountered in the + objects namespace or sub-namespaces, e.g. bad class or field. + + Rod Johnson + Mark Pollack (.NET) + + + + Superclass for all exceptions thrown in the Objects namespace and sub-namespaces. + + Rod Johnson + Mark Pollack (.NET) + + + Creates a new instance of the ObjectsException class. + + + + Creates a new instance of the ObjectsException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the ObjectsException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectsException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the FatalObjectException class. + + + + + Creates a new instance of the FatalObjectException class with the + specified message. + + + A message about the exception. + + + + + Creates a new instance of the FatalObjectException class with the + specified message. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the FatalObjectException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Marks an interface as being an application event listener. + + Griffin Caprio + + + + + Creates a new instance of the + class. + + + + + The callback for application events. + + + + + To be implemented by any object that wishes to be notified + of the associated with it. + + +

+ In the current implementation, the + will typically be the + associated that + spawned the implementing object. +

+

+ The can usually also be + passed on as an object reference to arbitrary object properties or + constructor arguments, because a + is typically defined as an + object with the well known name "messageSource" in the + associated application context. +

+
+ Juergen Hoeller + Rick Evans (.NET) + +
+ + + Sets the associated + with this object. + + +

+ Invoked after population of normal object properties but + before an initializing callback such as the + + method of the + interface + or a custom init-method. +

+

+ It is also invoked before the + + property of any + + implementation. +

+
+ + The associated + with this object. + +
+ + + Interface to be implemented by any object that wishes to be notified + of the (typically the + ) that it runs in. + + +

+ Note that dependencies can also + be exposed as object properties of type + , populated via strings with + automatic type conversion by the object factory. This obviates the + need for implementing any callback interface just for the purpose of + accessing a specific resource. +

+

+ You typically need an + when your application object has to access a variety of file resources + whose names are calculated. A good strategy is to make the object use + a default resource loader but still implement the + interface to allow + for overriding when running in an + . +

+
+ Juergen Hoeller + Mark Pollack (.NET) + + + +
+ + + Sets the + that this object runs in. + + +

+ Invoked after population of normal objects properties but + before an init callback such as + 's + + or a custom init-method. Invoked before setting + 's + + property. +

+
+
+ + + Thrown when a message cannot be resolved. + + Rod Johnson + Mark Pollack (.NET) + + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being + thrown. + + + The + that contains contextual information about the source or + destination. + + + + + Creates a new instance of the + class. + + + The code that could not be resolved for given culture. + + + The that was used + to search for the code. + + + + + Creates a new instance of the + class. + + + The code that could not be resolved for the current UI culture. + + + + + Convenience base class for + implementations, pre-implementing typical behavior. + + +

+ The method will + check whether a or + can be opened; + will always return + ; + and + throw an exception; + and will + return the value of the + property. +

+
+ Juergen Hoeller + Rick Evans (.NET) + Aleksandar Seovic (.NET) + +
+ + + The central abstraction for Spring.NET's access to resources such as + s. + + +

+ This interface encapsulates a resource descriptor that abstracts away + from the underlying type of resource; possible resource types include + files, memory streams, and databases (this list is not exhaustive). +

+

+ A can definitely be opened and accessed + for every such resource; if the resource exists in a physical form (for + example, the resource is not an in-memory stream or one that has been + extracted from an assembly or ZIP file), a or + can also be accessed. The actual + behavior is implementation-specific. +

+

+ This interface, when used in tandem with the + interface, forms the backbone of + Spring.NET's resource handling. Third party extensions or libraries + that want to integrate external resources with Spring.NET's IoC + container are encouraged expose such resources via this abstraction. +

+

+ Interfaces cannot obviously mandate implementation, but derived classes + are strongly encouraged to expose a constructor that takes a + single as it's sole argument (see example). + Exposing such a constructor will make your custom + implementation integrate nicely + with the class. +

+
+ Juergen Hoeller + Rick Evans (.NET) + + +
+ + + Simple interface for objects that are sources for + s. + + +

+ This is the base interface for the abstraction encapsulated by + Spring.NET's interface. +

+
+ Juergen Hoeller + Rick Evans (.NET) + +
+ + + Return an for this resource. + + + + Clients of this interface must be aware that every access of this + property will create a fresh ; + it is the responsibility of the calling code to close any such + . + + + + An . + + + If the stream could not be opened. + + + + + Creates a resource relative to this resource. + + + The path (always resolved as relative to this resource). + + + The relative resource. + + + If the relative resource could not be created from the supplied + path. + + + If the resource does not support the notion of a relative path. + + + + + Does this resource represent a handle with an open stream? + + +

+ If , the + cannot be read multiple times, and must be read and then closed to + avoid resource leaks. +

+

+ Will be for all usual resource descriptors. +

+
+ + if this resource represents a handle with an + open stream. + + +
+ + + Returns the handle for this resource. + + +

+ For safety, always check the value of the + property prior to + accessing this property; resources that cannot be exposed as + a will typically return + from a call to the + property. +

+
+ + The handle for this resource. + + + If the resource is not available or cannot be exposed as a + . + + + +
+ + + Returns a handle for this resource. + + +

+ For safety, always check the value of the + property prior to + accessing this property; resources that cannot be exposed as + a will typically return + from a call to the + property. +

+
+ + The handle for this resource. + + + If the resource is not available on a filesystem, or cannot be + exposed as a handle. + + + +
+ + + Returns a description for this resource. + + +

+ The description is typically used for diagnostics and other such + logging when working with the resource. +

+

+ Implementations are also encouraged to return this value from their + method. +

+
+ + A description for this resource. + +
+ + + Does this resource actually exist in physical form? + + +

+ An example of a resource that physically exists would be a + file on a local filesystem. An example of a resource that does not + physically exist would be an in-memory stream. +

+
+ + if this resource actually exists in physical + form (for example on a filesystem). + + + +
+ + + The default special character that denotes the base (home, or root) + path. + + +

+ Will be resolved (by those + implementations that support it) to the home (or root) path for + the specific implementation. +

+

+ For example, in the case of a web application this will (probably) + resolve to the virtual directory of said web application. +

+
+
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+ + A string representation of the resource. + + + If the supplied is + or contains only whitespace character(s). + +
+ + + Strips any protocol name from the supplied + . + + +

+ If the supplied does not + have any protocol associated with it, then the supplied + will be returned as-is. +

+
+ + + GetResourceNameWithoutProtocol("http://www.mycompany.com/resource.txt"); + // returns www.mycompany.com/resource.txt + + + + The name of the resource. + + + The name of the resource without the protocol name. + +
+ + + Resolves the supplied to its value + sans any leading protocol. + + + The name of the resource. + + + The name of the resource without the protocol name. + + + + + + Resolves the presence of the + value + in the supplied into a path. + + +

+ The default implementation simply returns the supplied + as is. +

+
+ + The name of the resource. + + + The string that is a placeholder for a base path. + + + The name of the resource with any + value having been resolved into an actual path. + +
+ + + This implementation returns the + of this resource. + + + + + + Determines whether the specified is + equal to the current . + + +

+ This implementation compares values. +

+
+ +
+ + + Serves as a hash function for a particular type, suitable for use + in hashing algorithms and data structures like a hash table. + + +

+ This implementation returns the hashcode of the + property. +

+
+ +
+ + + Factory Method. Create a new instance of the current resource type using the given resourceName + + + + + The ResourceLoader to be used for resolving relative resources + + + + + Does the supplied relative ? + + + The name of the resource to test. + + + if resource name is relative; + otherwise . + + + + + Creates a new resource that is relative to this resource based on the + supplied . + + +

+ This method can accept either a fully qualified resource name or a + relative resource name as it's parameter. +

+

+ A fully qualified resource is one that has a protocol prefix and + all elements of the resource name. All other resources are treated + as relative to this resource, and the following rules are used to + locate a relative resource: +

+ + + If the starts with '..', + the current resource path is navigated backwards before the + is concatenated to the current + of + this resource. + + + If the starts with '/', the + current resource path is ignored and a new resource name is + appended to the + of + this resource. + + + If the starts with '.' or a + letter, a new path is appended to the current + of + this resource. + + +
+ + The name of the resource to create. + + The relative resource. + + If the process of resolving the relative resource yielded an + invalid URI. + + + If this resource does not support the resolution of relative + resources (as determined by the value of the + + property). + + +
+ + + Calculates a new resource path based on the supplied + . + + + The relative path to evaluate. + + The newly calculated resource path. + + + + The special character that denotes the base (home, or root) + path. + + +

+ Will be resolved (by those + implementations that support it) to the home (or root) path for + the specific implementation. +

+

+ For example, in the case of a web application this will (probably) + resolve to the virtual directory of said web application. +

+
+ +
+ + + Return an for this resource. + + + An . + + + If the stream could not be opened. + + + + + + Returns a description for this resource. + + + A description for this resource. + + + + + + Returns the protocol associated with this resource (if any). + + +

+ The value of this property may be if no + protocol is associated with the resource type (for example if the + resource is a memory stream). +

+
+ + The protocol associated with this resource (if any). + +
+ + + Does this resource represent a handle with an open stream? + + +

+ This, the default implementation, always returns + . +

+
+ + if this resource represents a handle with an + open stream. + + +
+ + + Returns the handle for this resource. + + + + + + Returns a handle for this resource. + + +

+ This, the default implementation, always throws a + , assuming that the + resource cannot be resolved to an absolute file path. +

+
+ + The handle for this resource. + + + This implementation always throws a + . + + + +
+ + + Does this resource actually exist in physical form? + + +

+ This implementation checks whether a + can be opened, falling back to whether a + can be opened. +

+

+ This will cover both directories and content resources. +

+

+ This implementation will also return if + permission to the (file's) path is denied. +

+
+ + if this resource actually exists in physical + form (for example on a filesystem). + + + +
+ + + Does this support relative + resource retrieval? + + +

+ This property is generally to be consulted prior to attempting + to attempting to access a resource that is relative to this + resource (via a call to + ). +

+

+ This, the default implementation, always returns + . +

+
+ + if this + supports relative resource + retrieval. + +
+ + + Gets the root location of the resource. + + +

+ Where root resource can be taken to mean that part of the resource + descriptor that doesn't change when a relative resource is looked + up. Examples of such a root location would include a drive letter, + a web server name, an assembly name, etc. +

+
+ + The root location of the resource. + + + This, the default implementation, always throws a + . + +
+ + + Gets the current path of the resource. + + +

+ An example value of this property would be the name of the + directory containing a filesystem based resource. +

+
+ + The current path of the resource. + + + This, the default implementation, always throws a + . + +
+ + + Gets those characters that are valid path separators for the + resource type. + + +

+ An example value of this property would be the + and + values for a + filesystem based resource. +

+

+ Any derived classes that override this method are expected to + return a new array for each access of this property. +

+
+ + Those characters that are valid path separators for the resource + type. + + + This, the default implementation, always throws a + . + +
+ + + An implementation for + resources stored within assemblies. + + +

+ This implementation expects any resource name passed to the + constructor to adhere to the following format: +

+

+ assembly://assemblyName/namespace/resourceName +

+
+ Aleksandar Seovic (.NET) + Federico Spinazzi (.NET) +
+ + + Creates a new instance of the + class. + + + The name of the assembly resource. + + + If the supplied did not conform + to the expected format. + + + If the assembly specified in the supplied + was loaded twice with two + different evidences. + + + If the assembly specified in the supplied + could not be found. + + + If the caller does not have the required permission to load + the assembly specified in the supplied + . + + + + + + Does the supplied relative ? + + + The name of the resource to test. + + + if resource name is relative; + otherwise . + + + + + Return an for this resource. + + + An . + + + If the stream could not be opened. + + + If the caller does not have the required permission to load + the underlying assembly's manifest. + + + + + + + Does the embedded resource specified in the value passed to the + constructor exist? + + + if this resource actually exists in physical + form (for example on a filesystem). + + + + + + + + Does this support relative + resource retrieval? + + +

+ This implementation does support relative resource retrieval, and + so will always return . +

+
+ + if this + supports relative resource + retrieval. + + +
+ + + Gets the root location of the resource (the assembly name in this + case). + + + The root location of the resource. + + + + + + Gets the current path of the resource (the namespace in which the + target resource was embedded in this case). + + + The current path of the resource. + + + + + + Gets those characters that are valid path separators for the + resource type. + + + Those characters that are valid path separators for the resource + type. + + + + + + Returns a description for this resource. + + + A description for this resource. + + + + + + Returns the handle for this resource. + + + + + + Used when retrieving information from the standard .NET configuration + files (App.config / Web.config). + + +

+ If created with the name of a configuration section, then all methods + aside from the description return , + , or throw an exception. If created with an + , then the + property + will return a corresponding to parse. +

+
+ Mark Pollack + Rick Evans +
+ + + Creates new instance of the + class. + + + The actual XML configuration section. + + + If the supplied is . + + + + + Creates new instance of the + class. + + + The name of the configuration section. + + + If the supplied is + or contains only whitespace character(s). + + + + + Returns the handle for this resource. + + +

+ This implementation always returns . +

+
+ + . + + +
+ + + Returns a handle for this resource. + + +

+ This implementation always returns . +

+
+ + . + + +
+ + + Returns a description for this resource (the name of the + configuration section in this case). + + + A description for this resource. + + + + + + Does this resource actually exist in physical form? + + +

+ This implementation always returns . +

+
+ + + + + +
+ + + Return an for this resource. + + + An . + + + If the stream could not be opened. + + + + + + Exposes the actual for the + configuration section. + + +

+ Introduced to accomodate line info tracking during parsing. +

+
+
+ + + Holder that combines with a specific encoding to be used for reading + from the resource + + Juergen Hoeller + Erich Eichinger (.NET) + + + + Create an encoded resource, autodetecting the encoding from the resource stream. + + + + + + Create an encoded resource, autodetecting the encoding from the resource stream. + + the resource to read from. Must not be null + whether to autoDetect encoding from byte-order marks () + + + + Create an encoded resource using the specified encoding. + + the resource to read from. Must not be null + the encoding to use. If null, encoding will be autodetected. + whether to autoDetect encoding from byte-order marks () + + + + + + + + + + Determine whether equals this instance. + + + true if obj is an and both + , and are equal. + + + + + Calculate the unique hash code for this instance. + + + + + + Get a textual description of the resource. + + + + + Get the underlying resource + + + + + Get the encoding to use for reading, if any. May be null + + + + + whether to autoDetect encoding from byte-order marks () + + + + + A backed resource. + + +

+ Supports resolution as both a and a + . +

+

+ Also supports the use of the ~ character. If the ~ character + is the first character in a resource path (sans protocol), the ~ + character will be replaced with the value of the + System.AppDomain.CurrentDomain.BaseDirectory property (an example of + this can be seen in the examples below). +

+
+ +

+ Consider the example of an application that is running (has been launched + from) the C:\App\ directory. The following resource paths will map + to the following resources on the filesystem... +

+ + strings.txt C:\App\strings.txt + ~/strings.txt C:\App\strings.txt + file://~/strings.txt C:\App\strings.txt + file://~/../strings.txt C:\strings.txt + ../strings.txt C:\strings.txt + ~/../strings.txt C:\strings.txt + + // note that only a leading ~ character is resolved to the executing directory... + stri~ngs.txt C:\App\stri~ngs.txt + +
+ Juergen Hoeller + Leonardo Susatyo (.NET) + Aleksandar Seovic (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The name of the file system resource. + + + If the supplied is + or contains only whitespace character(s). + + + + + Creates a new instance of the + class. + + + The name of the file system resource. + + + Supresses initialization of this instance. Used from derived classes. + + + If the supplied is + or contains only whitespace character(s). + + + + + Initializes this instance. + + + + + + Resolves the handle + for the supplied . + + + The name of the file system resource. + + + The handle for this resource. + + + + + Resolves the root location for the supplied . + + + The name of the file system resource. + + + The root location of the resource. + + + + + Resolves the path for the supplied . + + + The name of the file system resource. + + + The current path of the resource. + + + + + Resolves the presence of the + value + in the supplied into a path. + + + The name of the resource. + + + The string that is a placeholder for a base path. + + + The name of the resource with any + value having been resolved into an actual path. + + + + + Does the supplied relative ? + + + The name of the resource to test. + + + if resource name is relative; + otherwise . + + + + + Returns the underlying handle for + this resource. + + + The handle for this resource. + + + + + + Does this support relative + resource retrieval? + + +

+ This implementation does support relative resource retrieval, and + so will always return . +

+
+ + if this + supports relative resource + retrieval. + + +
+ + + Gets the root location of the resource (a drive or UNC file share + name in this case). + + + The root location of the resource. + + + + + + Gets the current path of the resource. + + + The current path of the resource. + + + + + + Gets those characters that are valid path separators for the + resource type. + + + Those characters that are valid path separators for the resource + type. + + + + + + + Return an for this resource. + + + An . + + + If the stream could not be opened. + + + If the underlying file could not be found. + + + + + + Returns a description for this resource. + + + A description for this resource. + + + + + + Returns the handle for this resource. + + + The handle for this resource. + + + If the resource is not available or cannot be exposed as a + . + + + + + + adapter implementation for a + . + + +

+ Should only be used if no other + implementation is applicable. +

+

+ In contrast to other + implementations, this is an adapter for an already opened + resource - the + therefore always returns . Do not use this class + if you need to keep the resource descriptor somewhere, or if you need + to read a stream multiple times. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + + The input to use. + + + Where the input comes from. + + + If the supplied is + . + + + + + The input to use. + + + If the underlying has already + been read. + + + + + Returns a description for this resource. + + + A description for this resource. + + + + + + This implementation always returns true + + + + + This implemementation always returns true + + + + + Custom type converter for instances. + + +

+ A resource path may contain placeholder variables of the form ${...} + that will be expended to environment variables. +

+

+ Currently only supports conversion from a + instance. +

+
+ +

+ On Win9x boxes, this resource path, ${userprofile}\objects.xml will + be expanded at runtime with the value of the 'userprofile' environment + variable substituted for the '${userprofile}' portion of the path. +

+ + // assuming a user called Rick, running on a plain vanilla Windows XP setup... + // this resource path... + + ${userprofile}\objects.xml + + // will become (after expansion)... + + C:\Documents and Settings\Rick\objects.xml + +
+ Mark Pollack + + +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class using the specified resourceLoader. + + the underlying IResourceLoader to be used to resolve resources + + + + Returns whether this converter can convert an object of one + to a + + + A + that provides a format context. + + + A that represents the + you want to convert from. + + + if the conversion is possible. + + + + + Convert from a string value to a + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + An if successful. + + + If the resource name objectained form the supplied + is malformed. + + + In the case of any errors arising from the instantiation of the + returned instance. + + + + + Resolve the given path, replacing placeholder values with + corresponding property values if necessary. + + +

+ This implementation resolves environment variables only. +

+
+ The original resource path. + The resolved resource path. +
+ + + Return the used to + resolve the string. + + + The used to resolve + the string. + + + + + Registry class that allows users to register and retrieve protocol handlers. + + + + Resource handler is an implementation of interface + that should be used to process resources with the specified protocol. + + + They are used throughout the framework to access resources from various + sources. For example, application context loads object definitions from the resources + that are processed using one of the registered resource handlers. + + Following resource handlers are registered by default: + + + Protocol + Handler Type + Description + + + config + + Resolves the resources by loading specified configuration section from the standard .NET config file. + + + file + + Resolves filesystem resources. + + + http + + Resolves remote web resources. + + + https + + Resolves remote web resources via HTTPS. + + + ftp + + Resolves ftp resources. + + + assembly + + Resolves resources that are embedded into an assembly. + + + web + Spring.Core.IO.WebResource, Spring.Web* + Resolves resources relative to the web application's virtual directory. + + + * only available in web applications. + + Users can create and register their own protocol handlers by implementing interface + and mapping custom protocol name to that implementation. See for details + on how to register custom protocol handler. + + + Aleksandar Seovic + + + + Name of the .Net config section that contains definitions + for custom resource handlers. + + + + + Registers standard and user-configured resource handlers. + + + + + Returns resource handler for the specified protocol name. + + + + This method returns object that should be used + to create an instance of the -derived type by passing + resource location as a parameter. + + + Name of the protocol to get the handler for. + Resource handler constructor for the specified protocol name. + If is null. + + + + Returns true if a handler is registered for the specified protocol, + false otherwise. + + Name of the protocol. + + true if a handler is registered for the specified protocol, false otherwise. + + If is null. + + + + Registers resource handler and maps it to the specified protocol name. + + +

+ If the mapping already exists, the existing mapping will be + silently overwritten with the new mapping. +

+
+ + The protocol to add (or override). + + + The type name of the concrete implementation of the + interface that will handle + the specified protocol. + + + If the supplied is + or contains only whitespace character(s); or + if the supplied is + . + + + If the supplied is not a + that derives from the + interface; or (having passed + this first check), the supplied + does not expose a constructor that takes a single + parameter. + +
+ + + Registers resource handler and maps it to the specified protocol name. + + +

+ If the mapping already exists, the existing mapping will be + silently overwritten with the new mapping. +

+
+ + The protocol to add (or override). + + + The concrete implementation of the + interface that will handle + the specified protocol. + + + If the supplied is + or contains only whitespace character(s); or + if the supplied is + . + + + If the supplied is not a + that derives from the + interface; or (having passed + this first check), the supplied + does not expose a constructor that takes a single + parameter. + +
+ + + Allows to create any arbitrary Url format + + + + + A adapter implementation encapsulating a simple string. + + Erich Eichinger + + + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + + + + Get the to + for accessing this resource. + + + + + Returns a description for this resource. + + + A description for this resource. + + + + + + This implementation always returns true + + + + + This implemementation always returns true + + + + + Gets the encoding used to create a byte stream of the string. + + + + + Gets the content encapsulated by this . + + + + + A backed resource + on top of + + +

+ Obviously supports resolution as a , and also + as a in the case of the "file:" + protocol. +

+
+ +

+ Some examples of the strings that can be used to initialize a new + instance of the class + include... + + + file:///Config/objects.xml + + + http://www.mycompany.com/services.txt + + +

+
+ Juergen Hoeller + Leonardo Susatyo (.NET) + Aleksandar Seovic (.NET) + + + +
+ + + Creates a new instance of the + class. + + +

+ Some examples of the values that the + can typically be expected to hold include... + + + file:///Config/objects.xml + + + http://www.mycompany.com/services.txt + + +

+
+ + A string representation of the resource. + +
+ + + Does the supplied relative ? + + + The name of the resource to test. + + + if resource name is relative; + otherwise . + + + + + Returns the instance + used for the resource resolution. + + + A instance. + + + + + + + Return an for this resource. + + + An . + + + If the stream could not be opened. + + + + + + Returns the handle for this resource. + + + The handle for this resource. + + + If the resource is not available or cannot be exposed as a + . + + + + + + Returns a handle for this resource. + + + The handle for this resource. + + + If the resource is not available on a filesystem. + + + + + + Does this support relative + resource retrieval? + + +

+ This implementation does support relative resource retrieval, and + so will always return . +

+
+ + if this + supports relative resource + retrieval. + + +
+ + + Gets the root location of the resource. + + + The root location of the resource. + + + + + + Gets the current path of the resource. + + + The current path of the resource. + + + + + + Gets those characters that are valid path separators for the + resource type. + + + Those characters that are valid path separators for the resource + type. + + + + + + Returns a description for this resource. + + + A description for this resource. + + + + + + Converts string representation of a credential for Web client authentication + into an instance of . + + +

+ Find below some examples of the XML formatted strings that this + converter will sucessfully convert. +

+ + + + + + +
+ Bruno Baia +
+ + + Can we convert from the sourcetype + to a instance ? + + +

+ Currently only supports conversion from a instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + if the conversion is possible. +
+ + + Convert from a value to an + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A instance if successful. + + + + + A custom for any + primitive numeric type such as , + , , etc. + + +

+ Can use a given for + (locale-specific) parsing and rendering. +

+

+ This is not meant to be used as a system + but rather as a + locale-specific number converter within custom controller code, to + parse user-entered number strings into number properties of objects, + and render them in a UI form. +

+
+ Juergen Hoeller + Simon White (.NET) +
+ + + Creates a new instance of the + class. + + + The primitive numeric to convert to. + + + The to use for + (locale-specific) parsing and rendering + + + Is an empty string allowed to be converted? If + , an empty string value will be converted to + numeric 0. + + Id the supplied is not a primitive + . + + + + + + Returns whether this converter can convert an object of one + to a + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + + if the conversion is possible. + +
+ + + Converts the specified object (a string) to the required primitive + type. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + A primitive representation of the string value. + + + + Converter for instances. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Returns whether this converter can convert an object of one + to a + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + True if the conversion is possible. +
+ + + Convert from a string value to a instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A if successful. + + + + + Custom implementation for + objects. + + +

+ Handles conversion from an XML formatted string to a + object + (see below for an example of the expected XML format). +

+

+ This converter must be registered before it will be available. Standard + converters in this namespace are automatically registered by the + class. +

+
+ +

+ Find below some examples of the XML formatted strings that this + converter will sucessfully convert. Note that the name of the top level + (document) element is quite arbitrary... it is only the content that + matters (and which must be in the format + <add key="..." value="..."/>. For your continued sanity + though, you may wish to standardize on the top level name of + 'dictionary' (although you are of course free to not do so). +

+ + + + + + +

+ The following example uses a different top level (document) element + name, but is equivalent to the first example. +

+ + + + + + +
+ Rod Johnson + Juergen Hoeller + Simon White (.NET) +
+ + + Creates a new instance of the + class. + + + + + Returns whether this converter can convert an object of one + to a + + + +

+ Currently only supports conversion from an + XML formatted instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + True if the conversion is possible. +
+ + + Convert from a string value to a + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A + if successful. + + + + + Converts string representation of a regular expression into an instance of . + + Aleksandar Seovic + + + + Can we convert from the sourcetype to a ? + + +

+ Currently only supports conversion from a instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + if the conversion is possible. +
+ + + Convert from a value to an + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A if successful. + + + + + Converts string representation of the registry key + into instance. + + Aleksandar Seovic + + + + Can we convert from a the sourcetype to a ? + + +

+ Currently only supports conversion from a instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + if the conversion is possible. +
+ + + Convert from a value to an + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A array if successful. + + + + + Generates partial registry key name. + + + Key elements. + + + Index of the last element to use. + + + Friendly key name containing key element from + 0 to , inclusive. + + + + + Returns for the specified + root hive name. + + + Root hive name. + + + Registry key for the specified name. + + + + + Converts a two part string, (resource name, assembly name) + to a ResourceManager instance. + + + + + This constant represents the name of the folder/assembly containing global resources. + + + + + Creates a new instance of the + class. + + + + + Returns whether this converter can convert an object of one + to a + + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + True if the conversion is possible. +
+ + + Convert from a string value to a + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A + if successful. + + If the specified does not denote a valid resource + + + + Converter for from a comma separated + list of RBG values. + + +

+ Please note that this class does not implement converting + to a comma separated list of RBG values from a + . +

+
+ Federico Spinazzi +
+ + + Returns whether this converter can convert an object of one + to a + . + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + if the conversion is possible. +
+ + + Converts the specified object (a string) a + instance. + + + A + that provides a format context. + + + The to use + as the current culture: currently ignored. + + + The value that is to be converted, in "R,G,B", "A,R,G,B", or + symbolic color name (). + + + A representation of the string value. + + + If the input string is not in a supported format, or is not one of the + predefined system colors (). + + + + + A custom for + runtime type references. + + +

+ Currently only supports conversion to and from a + . +

+
+ Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + + + + Returns whether this converter can convert an object of one + to the + of this converter. + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + True if the conversion is possible. +
+ + + Returns whether this converter can convert the object to the specified + . + + + A + that provides a format context. + + + A that represents the + you want to convert to. + + True if the conversion is possible. + + + + Converts the given value to the type of this converter. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + An that represents the converted value. + + + + + Converts the given value object to the specified type, + using the specified context and culture information. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + The to convert the + parameter to. + + + An that represents the converted value. + + + + + Converter for to directly set a + property. + + Jurgen Hoeller + Mark Pollack (.NET) + + + + Create a new StreamConverter using the default + . + + + + + Create a new StreamConverter using the given + . + + + The to use. + + + + Returns whether this converter can convert an object of one + to a + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + True if the conversion is possible. +
+ + + Convert from a string value to a instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A if successful. + + + + + Converts a separated to a + array. + + +

+ Defaults to using the , (comma) as the list separator. Note that the value + of the current is + not used. +

+

+ If you want to provide your own list separator, you can set the value of the + + property to the value that you want. Please note that this value will be used + for all future conversions in preference to the default list separator. +

+

+ Please note that the individual elements of a string will be passed + through as is (i.e. no conversion or trimming of surrounding + whitespace will be performed). +

+

+ This should be + automatically registered with any + implementations. +

+
+ + + public class StringArrayConverterExample + { + public static void Main() + { + StringArrayConverter converter = new StringArrayConverter(); + + string csvWords = "This,Is,It"; + string[] frankBoothWords = converter.ConvertFrom(csvWords); + + // the 'frankBoothWords' array will have 3 elements, namely + // "This", "Is", "It". + + // please note that extraneous whitespace is NOT trimmed off + // in the current implementation... + string csv = " Cogito ,ergo ,sum "; + string[] descartesWords = converter.ConvertFrom(csv); + + // the 'descartesWords' array will have 3 elements, namely + // " Cogito ", "ergo ", "sum ". + // notice how the whitespace has NOT been trimmed. + } + } + + + +
+ + + Can we convert from a the sourcetype to a array? + + +

+ Currently only supports conversion from a instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + if the conversion is possible. +
+ + + Convert from a value to a + array. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A array if successful. + + + + + The value that will be used as the list separator when performing + conversions. + + + A 'single' string character that will be used as the list separator + when performing conversions. + + + If the supplied value is not and is an empty + string, or has more than one character. + + + + + Base parser for custom specifiers. + + + + + Convert int value to a Timespan based on the specifier + + + + + + + Check if the string contains the specifier and + + + + + + + Specifier + + + + + Recognize 10d as ten days + + + + + Parse value as days + + Timespan in days + + + + + Day specifier: d + + + + + Recognize 10h as ten hours + + + + + Parse value as hours + + Timespan in hours + + + + + Hour specifier: h + + + + + Recognize 10m as ten minutes + + + + + Parse value as minutes + + Timespan in minutes + + + + + Minute specifier: m + + + + + Recognize 10s as ten seconds + + + + + Parse value as seconds + + Timespan in seconds + + + + + Second specifier: s + + + + + Recognize 10ms as ten milliseconds + + + + + Parse value as milliseconds + + Timespan in milliseconds + + + + + Millisecond specifier: ms + + + + + Converter for instances. + + Bruno Baia + Roberto Paterlini + + + + Creates a new instance of the + class. + + + + + Convert from a string value to a instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A if successful. + + + + + Utility methods that are used to convert objects from one type into another. + + Aleksandar Seovic + + + + Convert the value to the required (if necessary from a string). + + The proposed change value. + + The we must convert to. + + Property name, used for error reporting purposes... + + If there is an internal error. + + The new value, possibly the result of type conversion. + + + + Utility method to create a property change event. + + + The full name of the property that has changed. + + The property old value + The property new value + + A new . + + + + + Determines if a Type implements a specific generic interface. + + Candidate to evaluate. + The to test for in the Candidate . + if a match, else + + + + Registry class that allows users to register and retrieve type converters. + + Aleksandar Seovic + + + + Name of the .Net config section that contains Spring.Net type aliases. + + + + + Registers standard and configured type converters. + + + + + Returns for the specified type. + + Type to get the converter for. + a type converter for the specified type. + If is null. + + + + Registers for the specified type. + + Type to register the converter for. + Type converter to register. + If either of arguments is null. + + + + Registers for the specified type. + + + This is a convinience method that accepts the names of both + type to register converter for and the converter itself, + resolves them using , creates an + instance of type converter and calls overloaded + method. + + Type name of the type to register the converter for (can be a type alias). + Type name of the type converter to register (can be a type alias). + If either of arguments is null or empty string. + + If either of arguments fails to resolve to a valid . + + + If type converter does not derive from or if it cannot be instantiated. + + + + + Converts between instances of and their string representations. + + Erich Eichinger + + + + Can we convert from the sourcetype to a ? + + +

+ Currently only supports conversion from a instance. +

+
+ + A that provides a format context. + + + A that represents the you want to convert from. + + if the conversion is possible. +
+ + + Convert from a value to an instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A if successful, otherwise. + + The conversion cannot be performed. + + + + Returns whether this converter can convert the object to the specified type, using the specified context. + + An that provides a format context. + A that represents the type you want to convert to. + + true if this converter can perform the conversion; otherwise, false. + + + At the moment only conversion to string is supported. + + + + + Converts the given value object to the specified type, using the specified context and culture information. + + + + An that represents the converted value. + + + A . If null is passed, the current culture is assumed. + An that provides a format context. + The to convert the value parameter to. + The to convert. + The conversion cannot be performed. + The destinationType parameter is null. + + + + Converter for instances. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Returns whether this converter can convert an object of one + to a + + +

+ Currently only supports conversion from a + instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + True if the conversion is possible. +
+ + + Convert from a string value to a instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A if successful. + + + + + Resolves (instantiates) a by it's (possibly + assembly qualified) name, and caches the + instance against the type name. + + Rick Evans + Bruno Baia + Erich Eichinger + + + + Resolves a by name. + + +

+ The rationale behind the creation of this interface is to centralise + the resolution of type names to instances + beyond that offered by the plain vanilla + method call. +

+
+ Rick Evans +
+ + + Resolves the supplied to a + + instance. + + + The (possibly partially assembly qualified) name of a + . + + + A resolved instance. + + + If the supplied could not be resolved + to a . + + + + + The cache, mapping type names ( instances) against + instances. + + + + + Creates a new instance of the class. + + + The that this instance will delegate + actual resolution to if a + cannot be found in this instance's cache. + + + If the supplied is . + + + + + Resolves the supplied to a + + instance. + + + The (possibly partially assembly qualified) name of a + . + + + A resolved instance. + + + If the supplied could not be resolved + to a . + + + + + Holder for the generic arguments when using type parameters. + + +

+ Type parameters can be applied to classes, interfaces, + structures, methods, delegates, etc... +

+
+
+ + + The generic arguments prefix. + + + + + The generic arguments suffix. + + + + + The generic arguments prefix. + + + + + The generic arguments suffix. + + + + + The character that separates a list of generic arguments. + + + + + Creates a new instance of the GenericArgumentsHolder class. + + + The string value to parse looking for a generic definition + and retrieving its generic arguments. + + + + + Returns the array declaration portion of the definition, e.g. "[,]" + + + + + + Returns an array of unresolved generic arguments types. + + +

+ A empty string represents a type parameter that + did not have been substituted by a specific type. +

+
+ + An array of strings that represents the unresolved generic + arguments types or an empty array if not generic. + +
+ + + The (unresolved) generic type name portion + of the original value when parsing a generic type. + + + + + The (unresolved) generic method name portion + of the original value when parsing a generic method. + + + + + Is the string value contains generic arguments ? + + +

+ A generic argument can be a type parameter or a type argument. +

+
+
+ + + Is generic arguments only contains type parameters ? + + + + + Is this an array type definition? + + + + + Resolves a generic by name. + + Bruno Baia + + + + Resolves a by name. + + Rick Evans + Aleksandar Seovic + Bruno Baia + + + + Resolves the supplied to a + instance. + + + The unresolved (possibly partially assembly qualified) name + of a . + + + A resolved instance. + + + If the supplied could not be resolved + to a . + + + + + Uses + to load an and then the attendant + referred to by the + parameter. + + +

+ is + deprecated in .NET 2.0, but is still used here (even when this class is + compiled for .NET 2.0); + will + still resolve (non-.NET Framework) local assemblies when given only the + display name of an assembly (the behaviour for .NET Framework assemblies + and strongly named assemblies is documented in the docs for the + method). +

+
+ + The assembly and type to be loaded. + + + A , or . + + + + +
+ + + Uses + to load the attendant referred to by + the parameter. + + + The type to be loaded. + + + A , or . + + + + + Creates a new instance + from the given + + + + + Creates a new instance + from the given with the given inner + + + + + Resolves the supplied generic to a + instance. + + + The unresolved (possibly generic) name of a . + + + A resolved instance. + + + If the supplied could not be resolved + to a . + + + + + Holds data about a and it's + attendant . + + + + + The string that separates a name + from the name of it's attendant + in an assembly qualified type name. + + + + + Creates a new instance of the TypeAssemblyHolder class. + + + The unresolved name of a . + + + + + The (unresolved) type name portion of the original type name. + + + + + The (unresolved, possibly partial) name of the attandant assembly. + + + + + Is the type name being resolved assembly qualified? + + + + + Provides access to a central registry of aliased s. + + +

+ Simplifies configuration by allowing aliases to be used instead of + fully qualified type names. +

+

+ Comes 'pre-loaded' with a number of convenience alias' for the more + common types; an example would be the 'int' (or 'Integer' + for Visual Basic.NET developers) alias for the + type. +

+
+ Aleksandar Seovic + +
+ + + Name of the .Net config section that contains Spring.Net type aliases. + + + + + The alias around the 'int' type. + + + + + The alias around the 'Integer' type (Visual Basic.NET style). + + + + + The alias around the 'int[]' array type. + + + + + The alias around the 'Integer()' array type (Visual Basic.NET style). + + + + + The alias around the 'decimal' type. + + + + + The alias around the 'Decimal' type (Visual Basic.NET style). + + + + + The alias around the 'decimal[]' array type. + + + + + The alias around the 'Decimal()' array type (Visual Basic.NET style). + + + + + The alias around the 'char' type. + + + + + The alias around the 'Char' type (Visual Basic.NET style). + + + + + The alias around the 'char[]' array type. + + + + + The alias around the 'Char()' array type (Visual Basic.NET style). + + + + + The alias around the 'long' type. + + + + + The alias around the 'Long' type (Visual Basic.NET style). + + + + + The alias around the 'long[]' array type. + + + + + The alias around the 'Long()' array type (Visual Basic.NET style). + + + + + The alias around the 'short' type. + + + + + The alias around the 'Short' type (Visual Basic.NET style). + + + + + The alias around the 'short[]' array type. + + + + + The alias around the 'Short()' array type (Visual Basic.NET style). + + + + + The alias around the 'unsigned int' type. + + + + + The alias around the 'unsigned long' type. + + + + + The alias around the 'ulong[]' array type. + + + + + The alias around the 'uint[]' array type. + + + + + The alias around the 'unsigned short' type. + + + + + The alias around the 'ushort[]' array type. + + + + + The alias around the 'double' type. + + + + + The alias around the 'Double' type (Visual Basic.NET style). + + + + + The alias around the 'double[]' array type. + + + + + The alias around the 'Double()' array type (Visual Basic.NET style). + + + + + The alias around the 'float' type. + + + + + The alias around the 'Single' type (Visual Basic.NET style). + + + + + The alias around the 'float[]' array type. + + + + + The alias around the 'Single()' array type (Visual Basic.NET style). + + + + + The alias around the 'DateTime' type. + + + + + The alias around the 'DateTime' type (C# style). + + + + + The alias around the 'DateTime' type (Visual Basic.NET style). + + + + + The alias around the 'DateTime[]' array type. + + + + + The alias around the 'DateTime[]' array type. + + + + + The alias around the 'DateTime()' array type (Visual Basic.NET style). + + + + + The alias around the 'bool' type. + + + + + The alias around the 'Boolean' type (Visual Basic.NET style). + + + + + The alias around the 'bool[]' array type. + + + + + The alias around the 'Boolean()' array type (Visual Basic.NET style). + + + + + The alias around the 'string' type. + + + + + The alias around the 'string' type (Visual Basic.NET style). + + + + + The alias around the 'string[]' array type. + + + + + The alias around the 'string[]' array type (Visual Basic.NET style). + + + + + The alias around the 'object' type. + + + + + The alias around the 'object' type (Visual Basic.NET style). + + + + + The alias around the 'object[]' array type. + + + + + The alias around the 'object[]' array type (Visual Basic.NET style). + + + + + The alias around the 'int?' type. + + + + + The alias around the 'int?[]' array type. + + + + + The alias around the 'decimal?' type. + + + + + The alias around the 'decimal?[]' array type. + + + + + The alias around the 'char?' type. + + + + + The alias around the 'char?[]' array type. + + + + + The alias around the 'long?' type. + + + + + The alias around the 'long?[]' array type. + + + + + The alias around the 'short?' type. + + + + + The alias around the 'short?[]' array type. + + + + + The alias around the 'unsigned int?' type. + + + + + The alias around the 'unsigned long?' type. + + + + + The alias around the 'ulong?[]' array type. + + + + + The alias around the 'uint?[]' array type. + + + + + The alias around the 'unsigned short?' type. + + + + + The alias around the 'ushort?[]' array type. + + + + + The alias around the 'double?' type. + + + + + The alias around the 'double?[]' array type. + + + + + The alias around the 'float?' type. + + + + + The alias around the 'float?[]' array type. + + + + + The alias around the 'bool?' type. + + + + + The alias around the 'bool?[]' array type. + + + + + Registers standard and user-configured type aliases. + + + + + Registers an alias for the specified . + + +

+ This overload does eager resolution of the + referred to by the parameter. It will throw a + if the referred + to by the parameter cannot be resolved. +

+
+ + A string that will be used as an alias for the specified + . + + + The (possibly partially assembly qualified) name of the + to register the alias for. + + + If either of the supplied parameters is or + contains only whitespace character(s). + + + If the referred to by the supplied + cannot be loaded. + +
+ + + Registers short type name as an alias for + the supplied . + + + The to register. + + + If the supplied is . + + + + + Registers an alias for the supplied . + + + The alias for the supplied . + + + The to register the supplied under. + + + If the supplied is ; or if + the supplied is or + contains only whitespace character(s). + + + + + Resolves the supplied to a . + + + The alias to resolve. + + + The the supplied was + associated with, or if no + was previously registered for the supplied . + + + If the supplied is or + contains only whitespace character(s). + + + + + Returns a flag specifying whether TypeRegistry contains + specified alias or not. + + + Alias to check. + + + true if the specified type alias is registered, + false otherwise. + + + + + Helper methods with regard to type resolution. + + +

+ Not intended to be used directly by applications. +

+
+ Bruno Baia +
+ + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Resolves the supplied type name into a + instance. + + +

+ If you require special resolution, do + not use this method, but rather instantiate + your own . +

+
+ + The (possibly partially assembly qualified) name of a + . + + + A resolved instance. + + + If the type cannot be resolved. + +
+ + + Resolves a string array of interface names to + a array. + + + An array of valid interface names. Each name must include the full + interface and assembly name. + + An array of interface s. + + If any of the interfaces can't be loaded. + + + If any of the s specified is not an interface. + + + If (or any of its elements ) is + . + + + + + Match a method against the given pattern. + + the pattern to match against. + the method to match. + + if the method matches the given pattern; otherwise . + + + If the supplied is invalid. + + + + + Exception thrown when the ObjectFactory cannot load the specified type of a given object. + + Mark Pollack + + + + Thrown on an unrecoverable problem encountered in the + objects namespace or sub-namespaces, e.g. bad class or field. + + Rod Johnson + Mark Pollack (.NET) + + + + Superclass for all exceptions thrown in the Objects namespace and sub-namespaces. + + Rod Johnson + Mark Pollack (.NET) + + + Creates a new instance of the ObjectsException class. + + + + Creates a new instance of the ObjectsException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the ObjectsException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectsException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the FatalObjectException class. + + + + + Creates a new instance of the FatalObjectException class with the + specified message. + + + A message about the exception. + + + + + Creates a new instance of the FatalObjectException class with the + specified message. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the FatalObjectException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The resource description that the object definition came from. + Name of the object requested + Name of the object type. + The root cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + Gets he name of the object we are trying to load. + + The name of the object. + + + + Gets the name of the object type we are trying to load. + + The name of the object type. + + + + Gets the resource description that the object definition came from + + The resource description. + + + + A implementation that represents + a composed collection of instances. + + + + + The criteria for an arbitrary filter. + + Rick Evans + + + + Does the supplied satisfy the criteria + encapsulated by this instance? + + + The datum to be checked by this criteria instance. + + + if the supplied + satisfies the criteria encapsulated by this instance; + if not, or the supplied + is . + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A user-defined (child) criteria that will be composed into this instance. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The data to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + Adds the supplied into the criteria + composed within this instance. + + + The to be added. + + + + + The list of composing this + instance. + + + + + Factory class to conceal any default implementation. + + Rod Johnson + Simon White (.NET) + + + + Creates a new instance of the + implementation provided by this factory. + + + A new instance of the + implementation provided by this factory. + + + + + Interface to be implemented by objects that can return information about + the current call stack. + + +

+ Useful in AOP (as an expression of the AspectJ cflow concept) but not AOP-specific. +

+
+ Rod Johnson + Aleksandar Seovic (.Net) +
+ + + Detects whether the caller is under the supplied , + according to the current stacktrace. + + + The to look for. + + + if the caller is under the supplied . + + + + + Detects whether the caller is under the supplied + and , according to the current stacktrace. + + + The to look for. + + The name of the method to look for. + + if the caller is under the supplied + and . + + + + + Does the current stack trace contain the supplied ? + + The token to match against. + + if the current stack trace contains the supplied + . + + + + + Creates a new instance of the + class. + + + + + Detects whether the caller is under the supplied , + according to the current stacktrace. + + + + + + Detects whether the caller is under the supplied + and , according to the current stacktrace. + + +

+ Matches the whole method name. +

+
+ +
+ + + Does the current stack trace contain the supplied ? + + +

+ This leaves it up to the caller to decide what matches, but is obviously less of + an abstraction because the caller must know the exact format of the underlying + stack trace. +

+
+ +
+ + + Provides methods to support various naming and other conventions used throughout the framework. + Mainly for internal use within the framework. + + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + + + Convert Strings in attribute name format (lowercase, hyphens separating words) + into property name format (camel-cased). For example, transaction-manager is + converted into transactionManager. + + + + + Convenience class that exposes a signature that matches the + delegate. + + +

+ Useful when filtering members via the + mechanism. +

+
+ Rick Evans +
+ + + Creates a new instance of the + class. + + + + + Returns true if the supplied instance + satisfies the supplied (which must be an + implementation). + + + The instance that will be checked to see if + it matches the supplied . + + + The criteria against which to filter the supplied + instance. + + + True if the supplied instance + satisfies the supplied (which must be an + implementation); false if not or the + supplied is not an + implementation or is null. + + + + + Interface that can be implemented by exceptions etc that are error coded. + + +

+ The error code is a , rather than a number, so it can + be given user-readable values, such as "object.failureDescription". +

+
+ Rod Johnson + Aleksandar Seovic (.Net) +
+ + + Return the error code associated with this failure. + + +

+ The GUI can render this anyway it pleases, allowing for I18n etc. +

+
+ + The error code associated with this failure, + or the empty string instance if not error-coded. + +
+ + + Thrown in response to referring to an invalid property (most often via reflection). + + Rick Evans + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + The that is (or rather was) the source of the + offending property. + + + The name of the offending property. + + + + + Creates a new instance of the + class. + + + The that is (or rather was) the source of the + offending property. + + + The name of the offending property. + + + A message about the exception. + + + + + Creates a new instance of the InvalidPropertyException class. + + + The that is (or rather was) the source of the + offending property. + + + The name of the offending property. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The that is (or rather was) the source of the + offending property. + + + + + The name of the offending property. + + + + + Extension of the interface, expressing a 'priority' + ordering: Order values expressed by IPriorityOrdered objects always + apply before order values of 'plain' Ordered values. + + + This is primarily a special-purpose interface, used for objects + where it is particularly important to determine 'prioritized' + objects first, without even obtaining the remaining objects. + A typical example: Prioritized post-processors in a Spring + + + IPriorityOrdered post-processor objects are initialized in + a special phase, ahead of other post-processor objects. + + Juergen Hoeller + Mark Pollack (.NET) + + + + + + + Criteria that is satisfied if the of each of the + arguments matches each of the parameter s of a given + . + + +

+ If no array is passed to the overloaded constructor, + any method that has no parameters will satisfy an instance of this + class. The same effect could be achieved by passing the + array to the overloaded constructor. +

+
+ Rick Evans + Bruno Baia +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + +

+ If the supplied array is null, then this + constructor uses the array. +

+
+ + The array that this criteria will use to + check parameter s. + +
+ + + Does the supplied satisfy the criteria encapsulated by + this instance? + + +

+ This implementation respects the inheritance chain of any parameter + s... i.e. methods that have a base type (or + interface) that is assignable to the in the + same corresponding index of the parameter types will satisfy this + criteria instance. +

+
+ The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + +
+ + + Criteria that is satisfied if the number of generic arguments to a given + matches an arbitrary number. + + +

+ This class supports checking the generic arguments count of both + generic methods and constructors. +

+
+ Bruno Baia +
+ + + Creates a new instance of the + class. + + +

+ This constructor sets the + + property to zero (0). +

+
+
+ + + Creates a new instance of the + class. + + + The number of generic arguments that a + must have to satisfy this criteria. + + + If the supplied is less + than zero. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + The number of generic arguments that a + must have to satisfy this criteria. + + + If the supplied value is less than zero. + + + + + Thrown when a method (typically a property getter or setter invoked via reflection) + throws an exception, analogous to a . + + Rod Johnson + Mark Pollack (.NET) + + + + Superclass for exceptions related to a property access, such as a + mismatch or a target invocation exception. + + Rod Johnson + Mark Pollack (.NET) + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + Create a new instance of the PropertyAccessException class. + + + A message about the exception. + + Describes the change attempted on the property. + + + + Create a new instance of the PropertyAccessException class. + + + A message about the exception. + + Describes the change attempted on the property. + + The root exception that is being wrapped. + + + + + Creates a new instance of the PropertyAccessException class. + + + + + Creates a new instance of the PropertyAccessException class. + + + A message about the exception. + + + + + Creates a new instance of the PropertyAccessExceptionsException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the PropertyAccessExceptionsException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Returns the PropertyChangeEventArgs that resulted in the problem. + + + + + The string error code used to classify the error. + + + + + Creates a new instance of the MethodInvocationException class. + + + + + Creates a new instance of the MethodInvocationException class. + + + A message about the exception. + + + + + Creates a new instance of the MethodInvocationException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Constructor to use when an exception results from a + . + + + The raised by the invoked property. + + + The that + resulted in an exception. + + + + + Creates a new instance of the MethodInvocationException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + The error code string for this exception. + + + + + Criteria that is satisfied if the method Name of an + instance matches a + supplied string pattern. + + + + Supports the following simple pattern styles: + "xxx*", "*xxx" and "*xxx*" matches, as well as direct equality. + + + Bruno Baia + + + + Creates a new instance of the + class. + + +

+ This constructor sets the + + property to * (any method name). +

+
+
+ + + Creates a new instance of the + class. + + The pattern that names + must match against in order to satisfy this criteria. + + If the supplied is null or resolve to an empty string. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + The number of parameters that a + must have to satisfy this criteria. + + + If the supplied value is null or resolve to an empty string. + + + + + Helper class that encapsulates the specification of a method parameter, i.e. + a MethodInfo or ConstructorInfo plus a parameter index. + Useful as a specification object to pass along. + + Juergen Hoeller + Rob Harrop + Mark Pollack (.NET) + + + + Initializes a new instance of the class for the given + MethodInfo. + + The MethodInfo to specify a parameter for. + Index of the parameter. + + + + Initializes a new instance of the class. + + The ConstructorInfo to specify a parameter for. + Index of the parameter. + + + + Create a new MethodParameter for the given method or donstructor. + This is a convenience constructor for scenarios where a + Method or Constructor reference is treated in a generic fashion. + + The method or constructor to specify a parameter for. + Index of the parameter. + the corresponding MethodParameter instance + + + + Parameters the name of the method/constructor parameter. + + the parameter name. + + + + Gets the type of the method/constructor parameter. + + The type of the parameter. (never null) + + + + Gets the wrapped MethodInfo, if any. Note Either MethodInfo or ConstructorInfo is available. + + The MethodInfo, or null if none. + + + + Gets wrapped ConstructorInfo, if any. Note Either MethodInfo or ConstructorInfo is available. + + The ConstructorInfo, or null if none + + + + Criteria that is satisfied if the number of parameters to a given + matches an arbitrary number. + + +

+ This class supports checking the parameter count of both methods and + constructors. +

+

+ Default parameters, etc need to taken into account. +

+
+ Rick Evans +
+ + + Creates a new instance of the + class. + + +

+ This constructor sets the + + property to zero (0). +

+
+
+ + + Creates a new instance of the + class. + + + The number of parameters that a + must have to satisfy this criteria. + + + If the supplied is less + than zero. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + The number of parameters that a + must have to satisfy this criteria. + + + If the supplied value is less than zero. + + + + + Criteria that is satisfied if the of each of the + parameters of a given matches each + of the parameter s of a given + . + + +

+ If no array is passed to the overloaded constructor, + any method that has no parameters will satisfy an instance of this + class. The same effect could be achieved by passing the + array to the overloaded constructor. +

+
+ Rick Evans + Bruno Baia +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + +

+ If the supplied array is null, then this + constructor uses the array. +

+
+ + The array that this criteria will use to + check parameter s. + +
+ + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + Criteria that is satisfied if the return of a given + matches a given . + + Rick Evans + + + + The return to match against if no + is provided explictly. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The that the return type of a given + must match in order to satisfy + this criteria. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + The that the return type of a given + must match in order to satisfy + this criteria. + + + + + Thrown in response to a failed attempt to read a property. + + +

+ Typically thrown when attempting to read the value of a write-only + property via reflection. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + The that is (or rather was) the source of the + offending property. + + + The name of the offending property. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Thrown in response to a failed attempt to write a property. + + Mark Pollack (.NET) + + + + Creates a new instance of the NotWritablePropertyException class. + + + + + Creates a new instance of the NotWritablePropertyException class. + + + A message about the exception. + + + + + Creates a new instance of the NotWritablePropertyException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the NotWritablePropertyException class. + + + The that is (or rather was) the source of the + offending property. + + + The name of the offending property. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the NotWritablePropertyException class + summarizing what property was not writable. + + + The name of the property that is not writable. + + + The in which the property is not writable. + + + + + Creates new NotWritablePropertyException with a root cause. + + + The name of the property that is not writable. + + + The in which the property is not writable. + + + The root cause indicating why the property was not writable. + + + + + Creates a new instance of the NotWritablePropertyException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Thrown in response to encountering a value + when traversing a nested path expression. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The of the object where the property was not found. + + The name of the property not found. + + + + Creates a new instance of the + class. + + + The of the object where the property was not found. + + The name of the property not found. + A message about the exception. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The name of the offending property. + + + + + The of the class where the property was last looked for. + + + + + Comparator implementation for objects, sorting by + order value ascending (resp. by priority descending). + + +

+ Non- objects are treated as greatest order values, + thus ending up at the end of a list, in arbitrary order (just like same order values of + objects). +

+
+ Juergen Hoeller + Aleksandar Seovic (.Net) +
+ + + Compares two objects and returns a value indicating whether one is less than, + equal to or greater than the other. + + +

+ Uses direct evaluation instead of + to avoid unnecessary boxing. +

+
+ The first object to compare. + The second object to compare. + + -1 if first object is less then second, 1 if it is greater, or 0 if they are equal. + +
+ + + Handle the case when both objects have equal sort order priority. By default returns 0, + but may be overriden for handling special cases. + + The first object to compare. + The second object to compare. + + -1 if first object is less then second, 1 if it is greater, or 0 if they are equal. + + + + + Provides additional data for the PropertyChanged event. + + +

+ Provides some additional properties over and above the name of the + property that has changed (which is inherited from the + base class). + This allows calling code to determine whether or not a property has + actually changed (i.e. a PropertyChanged event may have been + raised, but the value itself may be equivalent). +

+
+ +
+ + + Create a new instance of the + class. + + + The name of the property that was changed. + The old value of the property. + the new value of the property. + + + + Get the old value for the property. + + + + + + Get the new value of the property. + + + + + + A base class for all + implementations that are regular expression based. + + Rick Evans + + + + The default pattern... matches absolutely anything. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The regular expression pattern to be applied. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + Convenience method that calls the + + on the supplied . + + The input to match against. + True if the matches. + + + + The regular expression pattern to be applied. + + + + + The regular expression options to be applied. + + + + + The regular expression to be applied. + + + + + Criteria that is satisfied if the Name property of an + instance matches a + supplied regular expression pattern. + + Rick Evans + + + + The default event name pattern... matches pretty much any event name. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The pattern that names + must match against in order to satisfy this criteria. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + Criteria that is satisfied if the Name property of an + instance matches a + supplied regular expression pattern. + + Rick Evans + + + + The default method name pattern... matches pretty much any method name. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The pattern that names + must match against in order to satisfy this criteria. + + + + + Does the supplied satisfy the criteria encapsulated by + this instance? + + The datum to be checked by this criteria instance. + + True if the supplied satisfies the criteria encapsulated + by this instance; false if not or the supplied is null. + + + + + Exception thrown on a mismatch when trying to set a property + or resolve an argument to a method invocation. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Creates a new instance of the TypeMismatchException class. + + + + + Creates a new instance of the TypeMismatchException class. + + + A message about the exception. + + + + + Creates a new instance of the TypeMismatchException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the TypeMismatchException class describing the + property and required type that could not used to set a property on the target object. + + + The description of the property that was to be changed. + + The target conversion type. + + + + Creates a new instance of the TypeMismatchException class describing the + property, required type, and underlying exception that could not be used + to set a property on the target object. + + + The description of the property that was to be changed. + + The target conversion type. + The underlying exception. + + + + Creates a new instance of the TypeMismatchException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + The string error code used to classify the exception. + + + + + Abstract base class for implementations. + + Aleksandar Seovic + + + + An interface that defines the methods that have to be implemented by all data bindings. + + Aleksandar Seovic + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Sets error message that should be displayed in the case + of a non-fatal binding error. + + + Resource ID of the error message. + + + List of error providers message should be added to. + + + + + The name of the always filled error provider + + + + + Gets or sets a flag specifying whether this binding is valid. + + + true if this binding evaluated without errors; + false otherwise. + + + + + Marks this binding's state as invalid for this validationErrors collection. + Returns false if is null. + + + false, if validationErrors is null + + + + Initializes a new instance of the class. + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Sets error message that should be displayed in the case + of a non-fatal binding error. + + + Resource ID of the error message. + + + List of error providers message should be added to. + + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . 2 + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets the unique ID of this binding instance. + + + + + Gets or sets the . + + The binding direction. + + + + Gets the error message. + + The error message. + + + + Gets the error providers. + + + + + Abstract base class for simple, one-to-one implementations. + + Aleksandar Seovic + + + + Initialize a new instance of without any + + + + + Initialize a new instance of with the + specified . + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Concrete implementation if source to target binding. + + + The source object. + + + The target object. + + + Variables that should be used during expression evaluation. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Concrete implementation of target to source binding. + + + The source object. + + + The target object. + + + Variables that should be used during expression evaluation. + + + + + Gets the source value for the binding. + + + Source object to extract value from. + + + Variables for expression evaluation. + + + The source value for the binding. + + + + + Sets the source value for the binding. + + + The source object to set the value on. + + + The value to set. + + + Variables for expression evaluation. + + + + + Gets the target value for the binding. + + + Source object to extract value from. + + + Variables for expression evaluation. + + + The target value for the binding. + + + + + Sets the target value for the binding. + + + The target object to set the value on. + + + The value to set. + + + Variables for expression evaluation. + + + + + Gets or sets the to use. + + The formatter to use. + + + + Base implementation of the . + + Aleksandar Seovic + + + + An interface that has to be implemented by all data binding containers. + + Aleksandar Seovic + + + + Adds the binding. + + + Binding definition to add. + + + Added instance. + + + + + Adds the binding with a default + binding direction of . + + + This is a convinience method for adding SimpleExpressionBinding, + one of the most often used binding types, to the bindings list. + + + The source expression. + + + The target expression. + + + Added instance. + + + + + Adds the binding. + + + This is a convinience method for adding SimpleExpressionBinding, + one of the most often used binding types, to the bindings list. + + + The source expression. + + + The target expression. + + + Binding direction. + + + Added instance. + + + + + Adds the binding with a default + binding direction of . + + + This is a convinience method for adding SimpleExpressionBinding, + one of the most often used binding types, to the bindings list. + + + The source expression. + + + The target expression. + + + to use for value formatting and parsing. + + + Added instance. + + + + + Adds the binding. + + + This is a convinience method for adding SimpleExpressionBinding, + one of the most often used binding types, to the bindings list. + + + The source expression. + + + The target expression. + + + Binding direction. + + + to use for value formatting and parsing. + + + Added instance. + + + + + Gets a value indicating whether this data binding container + has bindings. + + + true if this data binding container has bindings; + false otherwise. + + + + + Creates a new instance of . + + + + + Adds the binding. + + + Binding definition to add. + + + Added instance. + + + + + Adds the binding with a default + binding direction of . + + + The source expression. + + + The target expression. + + + Added instance. + + + + + Adds the binding. + + + The source expression. + + + The target expression. + + + Binding direction. + + + Added instance. + + + + + Adds the binding with a default + binding direction of . + + + The source expression. + + + The target expression. + + + to use for value formatting and parsing. + + + Added instance. + + + + + Adds the binding. + + + The source expression. + + + The target expression. + + + Binding direction. + + + to use for value formatting and parsing. + + + Added instance. + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Implemented as a NOOP for containers. + of a non-fatal binding error. + + + Resource ID of the error message. + + + List of error providers message should be added to. + + + + + Gets a list of bindings for this container. + + + A list of bindings for this container. + + + + + Gets a value indicating whether this instance has bindings. + + + true if this instance has bindings; otherwise, false. + + + + + BaseBindingManager keeps track of all registered bindings and + represents an entry point for the binding and unbinding process. + + Aleksandar Seovic + + + + Initializes a new instance of the class. + + + + + Enumeration that defines possible values for data binding direction. + + Aleksandar Seovic + + + + Specifies that value from the control property should be bound to a data model. + + + + + Specifies that value from the data model should be bound to control property. + + + + + Specifies that binding is bidirectional. + + + + + Represents an ErrorMessage specific to a binding instance. + + Erich Eichinger + + + + Represents a single validation error message. + + Aleksandar Seovic + Goran Milosavljevic + + + + Default constructor. + + + + + Initializes a new instance of the class. + + Error message resource identifier. + Parameters that should be used for message resolution. + + + + Initializes a new instance of the class copying values from another instance. + + Another Error message instance to copy values from. + + + + This property is reserved, apply the + + to the class instead. + + + An + that describes the XML representation of the object that + is produced by the + + method and consumed by the + + method. + + + + + + Generates an object from its XML representation. + + + The stream + from which the object is deserialized. + + + + + Converts an object into its XML representation. + + + The stream + to which the object is serialized. + + + + + Resolves the message against specified . + + Message source to resolve this error message against. + Resolved error message. + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . 2 + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets or sets the resource identifier for this message. + + The resource identifier for this message. + + + + Gets or sets the message parameters. + + The message parameters. + + + + Initializes a new instance of the class. + + the id of the binding this error message is associated with + the message id + optional parameters to this message + + + + Generates an object from its XML representation. + + + The stream + from which the object is deserialized. + + + + + Converts an object into its XML representation. + + + The stream + to which the object is serialized. + + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . 2 + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Get the ID of the binding this message instance relates to. + + + + + Interface that should be implemented by data bound objects, such as + web pages, user controls, windows forms, etc. + + Aleksandar Seovic + + + + Gets the binding manager. + + The binding manager. + + + + implementation that allows + data binding between collections that implement + interface. + + Aleksandar Seovic + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Simple, expression-based implementation of that + binds source to target one-to-one. + + Aleksandar Seovic + + + + Initializes a new instance of the class. + + + The source expression. + + + The target expression. + + + + + Initializes a new instance of the class. + + + The source expression. + + + The target expression. + + + The formatter to use. + + + + + Gets the source value for the binding. + + + Source object to extract value from. + + + Variables for expression evaluation. + + + The source value for the binding. + + + + + Sets the source value for the binding. + + + The source object to set the value on. + + + The value to set. + + + Variables for expression evaluation. + + + + + Gets the target value for the binding. + + + Source object to extract value from. + + + Variables for expression evaluation. + + + The target value for the binding. + + + + + Sets the target value for the binding. + + + The target object to set the value on. + + + The value to set. + + + Variables for expression evaluation. + + + + + Gets the source expression. + + The source expression. + + + + Gets the target expression. + + The target expression. + + + + Minimal AST node interface used by ANTLR AST generation and tree-walker. + + + + + Add a (rightmost) child to this node + + + + + + Get the first child of this node; null if no children + + + + + Get the next sibling in line after this one + + + + + Get the token text for this node + + + + + + Get number of children of this node; if leaf, returns 0 + + Number of children + + + + Set the first child of a node. + + + + + + Set the next sibling after this one. + + + + + + Set the token text for this node + + + + + + Set the token type for this node + + + + + + Get the token type for this node + + + + + Event type. + + + + Used for creating Token instances. + + + Used for caching lookahead characters. + + + + This method is executed by ANTLR internally when it detected an illegal + state that cannot be recovered from. + The previous implementation of this method called + and writes directly to , which is usually not + appropriate when a translator is embedded into a larger application. + + Error message. + + + + A creator of Token object instances. + + + + This class and it's sub-classes exists primarily as an optimization + of the reflection-based mechanism(s) previously used exclusively to + create instances of Token objects. + + + Since Lexers in ANTLR use a single Token type, each TokenCreator can + create one class of Token objects (that's why it's not called TokenFactory). + + + + + + Constructs a instance. + + + + + Returns the fully qualified name of the Token type that this + class creates. + + + + + The fully qualified name of the Token type to create. + + + + + Type object used as a template for creating tokens by reflection. + + + + + Returns the fully qualified name of the Token type that this + class creates. + + + + + Constructs a instance. + + + + + Returns the fully qualified name of the Token type that this + class creates. + + + + This type was created in VisualAge. + + + + Report exception errors caught in nextToken() + + + + Parser error-reporting function can be overridden in subclass + + + + Parser warning-reporting function can be overridden in subclass + + + + + Represents a stream of characters fed to the lexer from that can be rewound + via mark()/rewind() methods. + + + + A dynamic array is used to buffer up all the input characters. Normally, + "k" characters are stored in the buffer. More characters may be stored + during guess mode (testing syntactic predicate), or when LT(i>k) is referenced. + Consumption of characters is deferred. In other words, reading the next + character is not done by conume(), but deferred until needed by LA or LT. + + + + + This should NOT be called from anyone other than ParserEventSupport! + + + + This should NOT be called from anyone other than ParserEventSupport! + + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "CharConsumed" event. + + Event source object + Event data object + + + + Handle the "CharLA" event. + + Event source object + Event data object + + + + Handle the "Mark" event. + + Event source object + Event data object + + + + Handle the "Rewind" event. + + Event source object + Event data object + + + charBufferConsume method comment. + + + + charBufferLA method comment. + + + + + @deprecated as of 2.7.2. This method calls System.exit() and writes + directly to stderr, which is usually not appropriate when + a parser is embedded into a larger application. Since the method is + static, it cannot be overridden to avoid these problems. + ANTLR no longer uses this method internally or in generated code. + + + + + + Specify an object with support code (shared by Parser and TreeParser. + Normally, the programmer does not play with this, using + instead. + + + + + + Specify the type of node to create during tree building. + + Fully qualified AST Node type name. + + + + Specify the type of node to create during tree building. + use now to be consistent with + Token Object Type accessor. + + Fully qualified AST Node type name. + + + + + + + + Get another token object from the token stream + + + + Return the token type of the ith token of lookahead where i=1 + is the current token being examined by the parser (i.e., it + has not been matched yet). + + + + Make sure current lookahead symbol matches token type t. + Throw an exception upon mismatch, which is catch by either the + error handler or by the syntactic predicate. + + + + Make sure current lookahead symbol matches the given set + Throw an exception upon mismatch, which is catch by either the + error handler or by the syntactic predicate. + + + + Parser error-reporting function can be overridden in subclass + + + + Parser error-reporting function can be overridden in subclass + + + + Parser warning-reporting function can be overridden in subclass + + + + User can override to do their own debugging + + + + This should NOT be called from anyone other than ParserEventSupport! + + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "ReportError" event. + + Event source object + Event data object + + + + Handle the "ReportWarning" event. + + Event source object + Event data object + + + This should NOT be called from anyone other than ParserEventSupport! + + + + A class to assist in firing parser events + NOTE: I intentionally _did_not_ synchronize the event firing and + add/remove listener methods. This is because the add/remove should + _only_ be called by the parser at its start/end, and the _same_thread_ + should be performing the parsing. This should help performance a tad... + + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "EnterRule" event + + Event source object + Event data object + + + + Handle the "ExitRule" event + + Event source object + Event data object + + + + Handle the "Consume" event. + + Event source object + Event data object + + + + Handle the "ParserLA" event. + + Event source object + Event data object + + + + Handle the "Match" event. + + Event source object + Event data object + + + + Handle the "MatchNot" event. + + Event source object + Event data object + + + + Handle the "MisMatch" event. + + Event source object + Event data object + + + + Handle the "MisMatchNot" event. + + Event source object + Event data object + + + + Handle the "ReportError" event. + + Event source object + Event data object + + + + Handle the "ReportWarning" event. + + Event source object + Event data object + + + + Handle the "SemPreEvaluated" event. + + Event source object + Event data object + + + + Handle the "SynPredFailed" event. + + Event source object + Event data object + + + + Handle the "SynPredStarted" event. + + Event source object + Event data object + + + + Handle the "SynPredSucceeded" event. + + Event source object + Event data object + + + This should NOT be called from anyone other than ParserEventSupport! + + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "Match" event. + + Event source object + Event data object + + + + Handle the "MatchNot" event. + + Event source object + Event data object + + + + Handle the "MisMatch" event. + + Event source object + Event data object + + + + Handle the "MisMatchNot" event. + + Event source object + Event data object + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "EnterRule" event + + Event source object + Event data object + + + + Handle the "ExitRule" event + + Event source object + Event data object + + + This should NOT be called from anyone other than ParserEventSupport! + + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "Consume" event. + + Event source object + Event data object + + + + Handle the "ParserLA" event. + + Event source object + Event data object + + + + Specifies the behaviour required (i.e. parser modifications) + specifically to support parse tree debugging and derivation. + + + + Override the standard matching and rule entry/exit routines + to build parse trees. This class is useful for 2.7.3 where + you can specify a superclass like + + + class TinyCParser extends Parser(ParseTreeDebugParser); + + + + + + Each new rule invocation must have it's own subtree. Tokens are + added to the current root so we must have a stack of subtree roots. + + + + + Track most recently created parse subtree so that when parsing + is finished, we can get to the root. + + + + + For every rule replacement with a production, we bump up count. + + + + + Adds LT(1) to the current parse subtree. + + + + Note that the match() routines add the node before checking for + correct match. This means that, upon mismatched token, there + will a token node in the tree corresponding to where that token + was expected. For no viable alternative errors, no node will + be in the tree as nothing was matched() (the lookahead failed + to predict an alternative). + + + + + + Create a rule node, add to current tree, and make it current root + + + + + + Pop current root; back to adding to old root + + + + + A class to assist in firing parser events + NOTE: I intentionally _did_not_ synchronize the event firing and + add/remove listener methods. This is because the add/remove should + _only_ be called by the parser at its start/end, and the _same_thread_ + should be performing the parsing. This should help performance a tad... + + + + This should NOT be called from anyone other than ParserEventSupport! + + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "SemPreEvaluated" event. + + Event source object + Event data object + + + + Provides an abstract base for implementing subclasses. + + + + This abstract class is provided to make it easier to create s. + You should extend this base class rather than creating your own. + + + + + + Handle the "Done" event. + + Event source object + Event data object + + + + Handle the "SynPredFailed" event. + + Event source object + Event data object + + + + Handle the "SynPredStarted" event. + + Event source object + Event data object + + + + Handle the "SynPredSucceeded" event. + + Event source object + Event data object + + + This should NOT be called from anyone other than ParserEventSupport! + + + + + AST Support code shared by TreeParser and Parser. + + + + We use delegation to share code (and have only one + bit of code to maintain) rather than subclassing + or superclassing (forces AST support code to be + loaded even when you don't want to do AST stuff). + + + Typically, is used to specify the + homogeneous type of node to create, but you can override + to make heterogeneous nodes etc... + + + + + + Constructs an ASTFactory with the default AST node type of + . + + + + + Constructs an ASTFactory and use the specified AST node type + as the default. + + + Name of default AST node type for this factory. + + + + + Constructs an ASTFactory and use the specified AST node type + as the default. + + + MetaType of default AST node type for this factory. + + + + + Stores the Type of the default AST node class to be used during tree construction. + + + + + Stores the mapping between custom AST NodeTypes and their NodeTypeName/NodeTypeClass + and ASTNodeCreator. + + + + + Stores the mapping between AST node typenames and their token ID. + + + + + Specify an "override" for the type created for + the specified Token type. + + + This method is useful for situations that ANTLR cannot oridinarily deal + with (i.e., when you create a token based upon a nonliteral token symbol + like #[LT(1)]. This is a runtime value and ANTLR cannot determine the token + type (and hence the AST) statically. + + Token type to override. + + Fully qualified AST typename (or null to specify + the factory's default AST type). + + + + + Register an AST Node Type for a given Token type ID. + + The Token type ID. + The AST Node Type to register. + + + + Register an ASTNodeCreator for a given Token type ID. + + The Token type ID. + The creater to register. + + + + Register an ASTNodeCreator to be used for creating node by default. + + The ASTNodeCreator. + + + + Pre-expands the internal list of TokenTypeID-to-ASTNodeType mappings + to the specified size. + This is primarily a convenience method that can be used to prevent + unnecessary and costly re-org of the mappings list. + + Maximum Token Type ID. + + + + Add a child to the current AST + + The AST to add a child to + The child AST to be added + + + + Creates a new uninitialized AST node. Since a specific AST Node Type + wasn't indicated, the new AST node is created using the current default + AST Node type - + + An uninitialized AST node object. + + + + Creates and initializes a new AST node using the specified Token Type ID. + The used for creating this new AST node is + determined by the following: + + the current TokenTypeID-to-ASTNodeType mapping (if any) or, + the otherwise + + + Token type ID to be used to create new AST Node. + An initialized AST node object. + + + + Creates and initializes a new AST node using the specified Token Type ID. + The used for creating this new AST node is + determined by the following: + + the current TokenTypeID-to-ASTNodeType mapping (if any) or, + the otherwise + + + Token type ID to be used to create new AST Node. + Text for initializing the new AST Node. + An initialized AST node object. + + + + Creates a new AST node using the specified AST Node Type name. Once created, + the new AST node is initialized with the specified Token type ID and string. + The used for creating this new AST node is + determined solely by ASTNodeTypeName. + The AST Node type must have a default/parameterless constructor. + + Token type ID to be used to create new AST Node. + Text for initializing the new AST Node. + Fully qualified name of the Type to be used for creating the new AST Node. + An initialized AST node object. + + + + Creates a new AST node using the specified AST Node Type name. + + Token instance to be used to initialize the new AST Node. + + Fully qualified name of the Type to be used for creating the new AST Node. + + A newly created and initialized AST node object. + + Once created, the new AST node is initialized with the specified Token + instance. The used for creating this new AST + node is determined solely by ASTNodeTypeName. + The AST Node type must have a default/parameterless constructor. + + + + + Creates and initializes a new AST node using the specified AST Node instance. + the new AST node is initialized with the specified Token type ID and string. + The used for creating this new AST node is + determined solely by aNode. + The AST Node type must have a default/parameterless constructor. + + AST Node instance to be used for creating the new AST Node. + An initialized AST node object. + + + + Creates and initializes a new AST node using the specified Token instance. + The used for creating this new AST node is + determined by the following: + + the current TokenTypeID-to-ASTNodeType mapping (if any) or, + the otherwise + + + Token instance to be used to create new AST Node. + An initialized AST node object. + + + + Returns a copy of the specified AST Node instance. The copy is obtained by + using the method Clone(). + + AST Node to copy. + An AST Node (or null if t is null). + + + + Duplicate AST Node tree rooted at specified AST node and all of it's siblings. + + Root of AST Node tree. + Root node of new AST Node tree (or null if t is null). + + + + Duplicate AST Node tree rooted at specified AST node. Ignore it's siblings. + + Root of AST Node tree. + Root node of new AST Node tree (or null if t is null). + + + + Make a tree from a list of nodes. The first element in the + array is the root. If the root is null, then the tree is + a simple list not a tree. Handles null children nodes correctly. + For example, build(a, b, null, c) yields tree (a b c). build(null,a,b) + yields tree (nil a b). + + List of Nodes. + AST Node tree. + + + + Make a tree from a list of nodes, where the nodes are contained + in an ASTArray object. + + List of Nodes. + AST Node tree. + + + + Make an AST the root of current AST. + + + + + + + Sets the global default AST Node Type for this ASTFactory instance. + This method also attempts to load the instance + for the specified typename. + + Fully qualified AST Node Type name. + + + + To change where error messages go, can subclass/override this method + and then setASTFactory in Parser and TreeParser. This method removes + a prior dependency on class antlr.Tool. + + + + + + A creator of AST node instances. + + + + This class and it's sub-classes exists primarily as an optimization + of the reflection-based mechanism(s) previously used exclusively to + create instances of AST node objects. + + + Parsers and TreeParsers already use the ASTFactory class in ANTLR whenever + they need to create an AST node objeect. What this class does is to support + performant extensibility of the basic ASTFactory. The ASTFactory can now be + extnded as run-time to support more new AST node types without using needing + to use reflection. + + + + + + Constructs an instance. + + + + + Returns the fully qualified name of the AST type that this + class creates. + + + + + Summary description for ASTVisitor. + + + + + Get number of children of this node; if leaf, returns 0 + + Number of children + + + + Small buffer used to avoid reading individual chars + + + + + Small buffer used to avoid reading individual chars + + + + + Constructs a instance. + + + + + Returns the fully qualified name of the AST type that this + class creates. + + + + + Constructs a instance. + + + + + Returns the fully qualified name of the AST type that this + class creates. + + + + + A token is minimally a token type. Subclasses can add the text matched + for the token and line info. + + + + + Constructs a instance. + + + + + Returns the fully qualified name of the Token type that this + class creates. + + + + + Constructs a instance. + + + + + Returns the fully qualified name of the Token type that this + class creates. + + + + + Summary description for DumpASTVisitor. + + Simple class to dump the contents of an AST to the output + + + + Append a char to the msg buffer. If special, then show escaped version + + Message buffer + Char to append + + + + Walk parse tree and return requested number of derivation steps. + If steps less-than 0, return node text. If steps equals 1, return derivation + string at step. + + derivation steps + + + + + Get derivation and return how many you did (less than requested for + subtree roots. + + string buffer + derivation steps + + + + + Do a step-first walk, building up a buffer of tokens until + you've reached a particular step and print out any rule subroots + insteads of descending. + + derivation buffer + derivation steps + + + + + This token stream tracks the *entire* token stream coming from + a lexer, but does not pass on the whitespace (or whatever else + you want to discard) to the parser. + + + + This class can then be asked for the ith token in the input stream. + Useful for dumping out the input stream exactly after doing some + augmentation or other manipulations. Tokens are index from 0..n-1 + + + You can insert stuff, replace, and delete chunks. Note that the + operations are done lazily--only if you convert the buffer to a + string. This is very efficient because you are not moving data around + all the time. As the buffer of tokens is converted to strings, the + toString() method(s) check to see if there is an operation at the + current index. If so, the operation is done and then normal string + rendering continues on the buffer. This is like having multiple Turing + machine instruction streams (programs) operating on a single input tape. :) + + + Since the operations are done lazily at toString-time, operations do not + screw up the token index values. That is, an insert operation at token + index i does not change the index values for tokens i+1..n-1. + + + Because operations never actually alter the buffer, you may always get + the original token stream back without undoing anything. Since + the instructions are queued up, you can easily simulate transactions and + roll back any changes if there is an error just by removing instructions. + For example, + + For example: + + TokenStreamRewriteEngine rewriteEngine = new TokenStreamRewriteEngine(lexer); + JavaRecognizer parser = new JavaRecognizer(rewriteEngine); + ... + rewriteEngine.insertAfter("pass1", t, "foobar");} + rewriteEngine.insertAfter("pass2", u, "start");} + System.Console.Out.WriteLine(rewriteEngine.ToString("pass1")); + System.Console.Out.WriteLine(rewriteEngine.ToString("pass2")); + + + + You can also have multiple "instruction streams" and get multiple + rewrites from a single pass over the input. Just name the instruction + streams and use that name again when printing the buffer. This could be + useful for generating a C file and also its header file--all from the + same buffer. + + + If you don't use named rewrite streams, a "default" stream is used. + + + Terence Parr, parrt@cs.usfca.edu + University of San Francisco + February 2004 + + + + + + Track the incoming list of tokens + + + + + You may have multiple, named streams of rewrite operations. + I'm calling these things "programs." + Maps string (name) -> rewrite (List) + + + + + Map string (program name) -> Integer index + + + + + track index of tokens + + + + + Who do we suck tokens from? + + + + + Which (whitespace) token(s) to throw out + + + + + Rollback the instruction stream for a program so that + the indicated instruction (via instructionIndex) is no + longer in the stream. + + + UNTESTED! + + + + + + + Reset the program so that no instructions exist + + + + + + If op.index > lastRewriteTokenIndexes, just add to the end. + Otherwise, do linear + + + + + + Execute the rewrite operation by possibly adding to the buffer. + + rewrite buffer + The index of the next token to operate on. + + + + This token tracks it's own index 0..n-1 relative to the beginning + of the stream. It is designed to work with + in TokenStreamRewriteEngine.cs + + + + + Index into token array indicating position in input stream + + + + + @deprecated as of 2.7.2. This method calls System.exit() and writes + directly to stderr, which is usually not appropriate when + a parser is embedded into a larger application. Since the method is + static, it cannot be overridden to avoid these problems. + ANTLR no longer uses this method internally or in generated code. + + + + + + Implementation of the average aggregator. + + Aleksandar Seovic + + + + Defines an interface that should be implemented + by all collection processors and aggregators. + + + + + Processes a list of source items and returns a result. + + + The source list to process. + + + An optional processor arguments array. + + + The processing result. + + + + + Returns the average of the numeric values in the source collection. + + + The source collection to process. + + + Ignored. + + + The average of the numeric values in the source collection. + + + + + Converts all elements in the input list to a given target type. + + Erich Eichinger + + + + Processes a list of source items and returns a result. + + + The source list to process. + + + An optional processor arguments array. + + + The processing result. + + + + + Implementation of the count aggregator. + + Aleksandar Seovic + + + + Returns the number of items in the source collection. + + + The source collection to process. + + + Ignored. + + + The number of items in the source collection, + or zero if the collection is empty or null. + + + + + Converts a string literal to a instance. + + Erich Eichinger + + + + + Erich Eichinger + + + + Implementation of the distinct processor. + + Aleksandar Seovic + + + + Returns distinct items from the collection. + + + The source collection to process. + + + 0: boolean flag specifying whether to include null + in the results or not. Default is false, which means that + null values will not be included in the results. + + + A collection containing distinct source collection elements. + + + If there is more than one argument, or if the single optional argument + is not Boolean. + + + + + Implementation of the maximum aggregator. + + Aleksandar Seovic + + + + Returns the largest item in the source collection. + + + The source collection to process. + + + Ignored. + + + The largest item in the source collection. + + + + + Implementation of the minimum aggregator. + + Aleksandar Seovic + + + + Returns the smallest item in the source collection. + + + The source collection to process. + + + Ignored. + + + The smallest item in the source collection. + + + + + Implementation of the non-null processor. + + Aleksandar Seovic + + + + Returns non-null items from the collection. + + + The source collection to process. + + + Ignored. + + + A collection containing non-null source collection elements. + + + + + Implementation of the 'order by' processor. + + Aleksandar Seovic + Erich Eichinger + + + + Sorts the source collection using custom sort criteria. + + + Please note that your compare function needs to take care about + proper conversion of types to be comparable! + + + The source collection to sort. + + + Sort criteria to use. + + + A sorted array containing collection elements. + + + + + Reverts order of elements in the list + + Erich Eichinger + + + + Processes a list of source items and returns a result. + + + The source list to process. + + + An optional processor arguments array. + + + The processing result. + + + + + Implementation of the sort processor. + + Aleksandar Seovic + + + + Sorts the source collection. + + + Please not that this processor requires that collection elements + are of a uniform type and that they implement + interface. +

+ If you want to perform custom sorting based on element properties + you should consider using instead. + + + The source collection to sort. + + + Ignored. + + + An array containing sorted collection elements. + + + If collection is not empty and it is + neither nor . + + + +

+ Implementation of the sum aggregator. + + Aleksandar Seovic +
+ + + Returns the sum of the numeric values in the source collection. + + + The source collection to process. + + + Ignored. + + + The sum of the numeric values in the source collection. + + + + + Represents parsed method node in the navigation expression. + + Aleksandar Seovic + + + + Base type for nodes that accept arguments. + + Aleksandar Seovic + + + + Base type for all expression nodes. + + Aleksandar Seovic + + + + For internal purposes only. Use for expression node implementations. + + + This class is only required to enable serialization of parsed Spring expressions since antlr.CommonAST + unfortunately is not marked as [Serializable].
+
+ Note:Since SpringAST implements , deriving classes + have to explicitely override if they need to persist additional + data during serialization. +
+
+ + + The global SpringAST node factory + + + + + Create an instance + + + + + Create an instance from a token + + + + + initialize this instance from an AST + + + + + initialize this instance from an IToken + + + + + initialize this instance from a token type number and a text + + + + + sets the text of this node + + + + + gets the text of this node + + + + + Create a new instance from SerializationInfo + + + + + populate SerializationInfo from this instance + + + + + gets or sets the token type of this node + + + + + gets or sets the text of this node + + + + + Interface that all navigation expression nodes have to implement. + + Aleksandar Seovic + + + + Returns expression value. + + Value of the expression. + + + + Returns expression value. + + Object to evaluate expression against. + Value of the expression. + + + + Returns expression value. + + Object to evaluate expression against. + Expression variables map. + Value of the expression. + + + + Sets expression value. + + Object to evaluate expression against. + New value for the last node of the expression. + + + + Sets expression value. + + Object to evaluate expression against. + Expression variables map. + New value for the last node of the expression. + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns node's value. + + Node's value. + + + + Returns node's value for the given context. + + Object to evaluate node against. + Node's value. + + + + Returns node's value for the given context. + + Object to evaluate node against. + Expression variables map. + Node's value. + + + + Returns node's value for the given context. + + Node's value. + + + + Evaluates this node for the given context, switching local variables map to the ones specified in . + + + + + Sets node's value for the given context. + + Object to evaluate node against. + New value for this node. + + + + Sets node's value for the given context. + + Object to evaluate node against. + Expression variables map. + New value for this node. + + + + Sets node's value for the given context. + + +

+ This is a default implementation of Set method, which + simply throws . +

+

+ This was done in order to avoid redundant Set method implementations, + because most of the node types do not support value setting. +

+
+
+ + + Returns a string representation of this node instance. + + + + + Evaluates this node, switching local variables map to the ones specified in . + + + + + Holds the state during evaluating an expression. + + + + + Gets/Sets the root context of the current evaluation + + + + + Gets/Sets the current context of the current evaluation + + + + + Gets/Sets global variables of the current evaluation + + + + + Gets/Sets local variables of the current evaluation + + + + + Initializes a new EvaluationContext instance. + + The root context for this evaluation + dictionary of global variables used during this evaluation + + + + Switches current ThisContext. + + + + + Switches current LocalVariables. + + + + + Gets the type of the + + + + + Create a new instance + + + + + Create a new instance + + + + + Append an argument node to the list of child nodes + + + + + + Create a new instance from SerializationInfo + + + + + Initializes the node. + + + + + Asserts the argument count. + + The required count. + + + + Resolves the arguments. + + Current expression evaluation context. + An array of argument values + + + + Resolves the named arguments. + + Current expression evaluation context. + A dictionary of argument name to value mappings. + + + + Resolves the argument. + + Argument position. + Current expression evaluation context. + Resolved argument value. + + + + Resolves the argument without ensuring was called. + + Argument position. + Current expression evaluation context. + Resolved argument value. + + + + Resolves the named argument. + + Argument name. + Current expression evaluation context. + Resolved named argument value. + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Creates new instance of the type defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed assignment node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Assigns value of the right operand to the left one. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed attribute node in the navigation expression. + + Aleksandar Seovic + + + + Represents parsed method node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Creates new instance of the type defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Determines the type of object that should be instantiated. + + + The type name to resolve. + + + The type of object that should be instantiated. + + + If the type cannot be resolved. + + + + + Initializes this node by caching necessary constructor and property info. + + + + + + + Sets the named arguments (properties). + + Instance to set property values on. + Argument (property) name to value mappings. + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Tries to determine attribute type based on the specified + attribute type name. + + + Attribute type name to resolve. + + + Resolved attribute type. + + + If type cannot be resolved. + + + + + Base class for binary operators. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance with the supplied operands + + + + + + + Create a new instance from SerializationInfo + + + + + Evaluate the left operand + + + + + Evaluate the left operand + + + + + Gets the left operand. + + The left operand. + + + + Gets the right operand. + + The right operand. + + + + Represents parsed boolean literal node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the boolean literal node. + + + This is the entrypoint into evaluating this expression. + + Node's value. + + + + Represents parsed default node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns left operand if it is not null, or the right operand if it is. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Container object for the parsed expression. + + +

+ Preparing this object once and reusing it many times for expression + evaluation can result in significant performance improvements, as + expression parsing and reflection lookups are only performed once. +

+
+ Aleksandar Seovic +
+ + + Initializes a new instance of the class + by parsing specified expression string. + + Expression to parse. + + + + Registers lambda expression under the specified . + + Function name to register expression as. + Lambda expression to register. + Variables dictionary that the function will be registered in. + + + + Initializes a new instance of the class + by parsing specified primary expression string. + + Primary expression to parse. + + + + Initializes a new instance of the class + by parsing specified property expression string. + + Property expression to parse. + + + + Initializes a new instance of the class. + + + + + Create a new instance from SerializationInfo + + + + + Evaluates this expression for the specified root object and returns + value of the last node. + + Context to evaluate expressions against. + Current expression evaluation context. + Value of the last node. + + + + Evaluates this expression for the specified root object and sets + value of the last node. + + Context to evaluate expressions against. + Current expression evaluation context. + Value to set last node to. + If navigation expression is empty. + + + + Evaluates this expression for the specified root object and returns + of the last node, if possible. + + Context to evaluate expression against. + Expression variables map. + Value of the last node. + + + + Contains a list of reserved variable names. + You must not use any variable names with the reserved prefix! + + + + + Variable Names using this prefix are reserved for internal framework use + + + + + variable name of the currently processed object factory, if any + + + + + Converts string representation of expression into an instance of . + + Aleksandar Seovic + + + + Can we convert from a the sourcetype to a ? + + +

+ Currently only supports conversion from a instance. +

+
+ + A + that provides a format context. + + + A that represents the + you want to convert from. + + if the conversion is possible. +
+ + + Convert from a value to an + instance. + + + A + that provides a format context. + + + The to use + as the current culture. + + + The value that is to be converted. + + + A array if successful. + + + + + Utility class that enables easy expression evaluation. + + +

+ This class allows users to get or set properties, execute methods, and evaluate + logical and arithmetic expressions. +

+

+ Methods in this class parse expression on every invocation. + If you plan to reuse the same expression many times, you should prepare + the expression once using the static method, + and then call to evaluate it. +

+

+ This can result in significant performance improvements as it avoids expression + parsing and node resolution every time it is called. +

+

+

+
+ Aleksandar Seovic +
+ + + Parses and evaluates specified expression. + + Root object. + Expression to evaluate. + Value of the last node in the expression. + + + + Parses and evaluates specified expression. + + Root object. + Expression to evaluate. + Expression variables map. + Value of the last node in the expression. + + + + Parses and specified expression and sets the value of the + last node to the value of the newValue parameter. + + Root object. + Expression to evaluate. + Value to set last node to. + + + + Parses and specified expression and sets the value of the + last node to the value of the newValue parameter. + + Root object. + Expression to evaluate. + Expression variables map. + Value to set last node to. + + + + Represents parsed expression list node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a result of the last expression in a list. + + Context to evaluate expressions against. + Current expression evaluation context. + Result of the last expression in a list + + + + Represents parsed function node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Evaluates function represented by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Result of the function evaluation. + + + + Represents parsed hexadecimal integer literal node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the hexadecimal integer literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed indexer node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns node's value for the given context. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Sets node's value for the given context. + + Context to evaluate expressions against. + Current expression evaluation context. + New value for this node. + + + + Utility method that is needed by ObjectWrapper and AbstractAutowireCapableObjectFactory. + + Context to resolve property against. + Expression variables map. + PropertyInfo for this node. + + + + Represents parsed integer literal node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the integer literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents lambda expression. + + Aleksandar Seovic + + + + caches argumentNames of this instance + + + + + caches body expression of this lambda function + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Assigns value of the right operand to the left one. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Evaluates this node, switching local variables map to the ones specified in . + + + + + Gets argument names for this lambda expression. + + + + + Represents parsed list initializer node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Creates new instance of the list defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents local function node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Evaluates function represented by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Result of the function evaluation. + + + + Represents parsed variable node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns value of the local variable represented by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Sets value of the local variable represented by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + New value for this node. + + + + Represents parsed map entry node. + + Aleksandar Seovic + + + + Creates a new instance of . + + + + + Create a new instance from SerializationInfo + + + + + Creates new instance of the map entry defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed map initializer node in the navigation expression. + + Aleksandar Seovic + + + + Creates a new instance of . + + + + + Create a new instance from SerializationInfo + + + + + Creates new instance of the map defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed method node in the navigation expression. + + Aleksandar Seovic + + + + Static constructor. Initializes a map of special collection processor methods. + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns node's value for the given context. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Gets the best method given the name, argument values, for a given type. + + The type on which to search for the method. + Name of the method. + The binding flags. + The arg values. + Best matching method or null if none found. + + + + Represents parsed named argument node in the expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns the value of the named argument defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed null literal node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the null literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents arithmetic addition operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the arithmetic addition operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents AND operator (both, bitwise and logical). + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical AND operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical BETWEEN operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical IN operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + + true if the left operand is contained within the right operand, false otherwise. + + + + + Represents arithmetic division operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the arithmetic division operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical equality operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical equality operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical "greater than" operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical "greater than" operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical "greater than or equal" operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical "greater than or equal" operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical IN operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical IN operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + + true if the left operand is contained within the right operand, false otherwise. + + + + + Represents logical IS operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical IS operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + + true if the left operand is contained within the right operand, false otherwise. + + + + + Represents logical "less than" operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical "less than" operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical "less than or equal" operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical "less than or equal" operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents VB-style logical LIKE operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical LIKE operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + + true if the left operand matches the right operand, false otherwise. + + + + + Represents logical MATCHES operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical MATCHES operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + + true if the left operand matches the right operand, false otherwise. + + + + + Represents arithmetic modulus operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the arithmetic modulus operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents arithmetic multiplication operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the arithmetic multiplication operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents NOT operator (both, bitwise and logical). + + Aleksandar Seovic + + + + Base class for unary operators. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Gets the operand. + + The operand. + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical NOT operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents logical inequality operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical inequality operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents OR operator (both, bitwise and logical). + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical OR operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents arithmetic exponent operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the arithmetic exponent operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents arithmetic subtraction operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the arithmetic subtraction operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents unary minus operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the unary plus operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents unary plus operator. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the unary plus operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + + Erich Eichinger + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the logical AND operator node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed projection node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a containing results of evaluation + of projection expression against each node in the context. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents node that navigates to object's property or public field. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Initializes the node. + + The parent. + + + + Attempts to resolve property or field. + + + Type to search for a property or a field. + + + Property or field name. + + + Binding flags to use. + + + Resolved property or field accessor, or null + if specified cannot be resolved. + + + + + Returns node's value for the given context. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Sets node's value for the given context. + + Context to evaluate expressions against. + Current expression evaluation context. + New value for this node. + + + + Retrieves property or field value. + + Context to evaluate expressions against. + Current expression evaluation context. + Property or field value. + + + + Sets property value, doing any type conversions that are necessary along the way. + + Context to evaluate expressions against. + Current expression evaluation context. + New value for this node. + + + + Sets property or field value using either dynamic or standard reflection. + + Object to evaluate node against. + New value for this node, converted to appropriate type. + + + + In the case of read only collections or custom collections that are not assignable from + IList, try to add to the collection. + + Context to evaluate expressions against. + Current expression evaluation context. + New value for this node. + true if was able add to IList, IDictionary, or ISet + + + + Utility method that is needed by ObjectWrapper and AbstractAutowireCapableObjectFactory. + We try as hard as we can, but there are instances when we won't be able to obtain PropertyInfo... + + Context to resolve property against. + PropertyInfo for this node. + + + + Gets a value indicating whether this node represents a property. + + + true if this node is a property; otherwise, false. + + + + + Gets a value indicating whether this node represents a field. + + + true if this node is a field; otherwise, false. + + + + + Represents parsed named argument node in the expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns the value of the named argument defined by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Overrides getText to allow easy way to get fully + qualified identifier. + + + Fully qualified identifier as a string. + + + + + Represents parsed real literal node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the real literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents a reference to a Spring-managed object. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the integer literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed selection node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns the first context item that matches selection expression. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed selection node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns the last context item that matches selection expression. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed selection node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a containing results of evaluation + of selection expression against each node in the context. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed string literal node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the string literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Exception thrown when detecting invalid SpEL syntax + + Erich Eichinger + + + + TODO + + + + + TODO + + + + + + + + + + + + + + + + + + + + Gets a message that provides details on the syntax error. + + + + + The expression that caused the error + + + + + Represents ternary expression node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns a value for the string literal node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Represents parsed type node in the navigation expression. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns node's value for the given context. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Overrides getText to allow easy way to get fully + qualified typename. + + + Fully qualified typename as a string. + + + + + Represents parsed variable node. + + Aleksandar Seovic + + + + Create a new instance + + + + + Create a new instance from SerializationInfo + + + + + Returns value of the variable represented by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + Node's value. + + + + Sets value of the variable represented by this node. + + Context to evaluate expressions against. + Current expression evaluation context. + New value for this node. + + + + Implementation of that can be used to + format and parse boolean values. + + Erich Eichinger + + + + Interface that should be implemented by all formatters. + + + + Formatters assume that source value is a string, and make no assumptions + about the target value's type, which means that Parse method can return + object of any type. + + + Aleksandar Seovic + + + + Formats the specified value. + + The value to format. + Formatted . + + + + Parses the specified value. + + The value to parse. + Parsed . + + + + Initializes a new instance of the class + using default values + + + + + Initializes a new instance of the class + + + + + Formats the specified boolean value. + + The value to format. + Formatted boolean value. + If is null. + If is not of type . + + + + Parses the specified boolean value according to settings of and + + The boolean value to parse. + Parsed boolean value as a . + If does not match or . + + + + Set/Get value to control casesensitivity of + + + Defaults to true + + + + + Set/Get value to recognize as boolean "true" value + + + Defaults to + + + + + Set/Get value to recognize as boolean "false" value + + + Defaults to + + + + + Implementation of that can be used to + format and parse currency values. + + + + CurrencyFormatter uses currency related properties of the + to format and parse currency values. + + + If you use one of the constructors that accept culture as a parameter + to create an instance of CurrencyFormatter, default NumberFormatInfo + for the specified culture will be used. + + + You can also use properties exposed by the CurrencyFormatter in order + to override some of the default currency formatting parameters. + + + Aleksandar Seovic + + + + Initializes a new instance of the class + using default for the current thread's culture. + + + + + Initializes a new instance of the class + using default for the specified culture. + + The culture name. + + + + Initializes a new instance of the class + using default for the specified culture. + + The culture. + + + + Initializes a new instance of the class + using specified . + + + The instance that defines how + currency values are formatted. + + + + + Formats the specified currency value. + + The value to format. + Formatted currency . + If is null. + If is not a number. + + + + Parses the specified currency value. + + The currency value to parse. + Parsed currency value as a . + + + + Gets or sets the currency decimal digits. + + The currency decimal digits. + + + + + Gets or sets the currency decimal separator. + + The currency decimal separator. + + + + + Gets or sets the currency group sizes. + + The currency group sizes. + + + + + Gets or sets the currency group separator. + + The currency group separator. + + + + + Gets or sets the currency symbol. + + The currency symbol. + + + + + Gets or sets the currency negative pattern. + + The currency negative pattern. + + + + + Gets or sets the currency positive pattern. + + The currency positive pattern. + + + + + Implementation of that can be used to + format and parse values. + + + + DateTimeFormatter uses properties of the + to format and parse values. + + + If you use one of the constructors that accept culture as a parameter + to create an instance of DateTimeFormatter, default DateTimeFormatInfo + for the specified culture will be used. + + + You can also use properties exposed by the DateTimeFormatter in order + to override some of the default formatting parameters. + + + Aleksandar Seovic + + + + Initializes a new instance of the class + using default for the current thread's culture. + + Date/time format string. + + + + Initializes a new instance of the class + using default for the specified culture. + + Date/time format string. + The culture name. + + + + Initializes a new instance of the class + using default for the specified culture. + + Date/time format string. + The culture. + + + + Formats the specified value. + + The value to format. + Formatted value. + If is null. + If is not an instance of . + + + + Parses the specified value. + + The string to parse. + Parsed value. + + + + Provides base functionality for filtering values before they actually get parsed/formatted. + + Erich Eichinger + + + + Creates a new instance of this FilteringFormatter. + + an optional underlying formatter + + If no underlying formatter is specified, the values + get passed through "as-is" after being filtered + + + + + Parses the specified value. + + The value to parse. + Parsed . + + + + Formats the specified value. + + The value to format. + Formatted . + + + + Allows to rewrite a value before it gets parsed by the underlying formatter + + + + + Allows to change a value before it gets formatted by the underlying formatter + + + + + Implementation of that can be used to + format and parse floating point numbers. + + + + This formatter allows you to format and parse numbers that conform + to number style (leading and trailing + white space, leading sign, decimal point, exponent). + + + Aleksandar Seovic + + + + Default format string. + + + + + Initializes a new instance of the class, + using default format string of '{0:F}' and current thread's culture. + + + + + Initializes a new instance of the class, + using specified format string and current thread's culture. + + The format string. + + + + Initializes a new instance of the class, + using default format string of '{0:F}' and specified culture. + + The culture. + + + + Initializes a new instance of the class, + using specified format string and current thread's culture. + + The format string. + The culture name. + + + + Initializes a new instance of the class, + using specified format string and culture. + + The format string. + The culture. + + + + Formats the specified float value. + + The value to format. + Formatted floating point number. + If is null. + If is not a number. + + + + Parses the specified float value. + + The float value to parse. + Parsed float value as a . + + + + Replaces input strings with a given default value, + if they are null or contain whitespaces only, + + Erich Eichinger + + + + Creates a new instance of this HasTextFilteringFormatter using null as default value. + + an optional underlying formatter + + If no underlying formatter is specified, the values + get passed through "as-is" after being filtered + + + + + Creates a new instance of this HasTextFilteringFormatter. + + the default value to be returned, if input text doesn't contain text + an optional underlying formatter + + If no underlying formatter is specified, the values + get passed through "as-is" after being filtered + + + + + If value contains no text, it will be replaced by a defaultValue. + + + + + Implementation of that can be used to + format and parse integer numbers. + + + + This formatter allows you to format and parse numbers that conform + to number style (leading and trailing + white space, leading sign). + + + Aleksandar Seovic + + + + Initializes a new instance of the class, + using default format string of '{0:D}'. + + + + + Initializes a new instance of the class, + using specified format string. + + + + + Formats the specified integer value. + + The value to format. + Formatted integer number. + If is null. + If is not an integer number. + + + + Parses the specified integer value. + + The integer value to parse. + Parsed number value as a . + + + + Implementation of that simply calls . + + + This formatter is a no-operation implementation. + + Erich Eichinger + + + + Initializes a new instance of the class. + + + + + Converts the passed value to a string by calling . + + The value to convert. + to string converted value. + + + + Returns the passed string "as is". + + The value to return. + The value passed into this method. + + + + Implementation of that can be used to + format and parse numbers. + + + + NumberFormatter uses number-related properties of the + to format and parse numbers. + + + This formatter works with both integer and decimal numbers and allows + you to format and parse numbers that conform to + number style (leading and trailing white space and/or sign, thousands separator, + decimal point) + + + If you use one of the constructors that accept culture as a parameter + to create an instance of NumberFormatter, default NumberFormatInfo + for the specified culture will be used. + + + You can also use properties exposed by the NumberFormatter in order + to override some of the default number formatting parameters. + + + Aleksandar Seovic + + + + Initializes a new instance of the class + using default for the current thread's culture. + + + + + Initializes a new instance of the class + using default for the specified culture. + + The culture name. + + + + Initializes a new instance of the class + using default for the specified culture. + + The culture. + + + + Initializes a new instance of the class + using specified . + + + The instance that defines how + numbers are formatted and parsed. + + + + + Formats the specified number value. + + The value to format. + Formatted number . + If is null. + If is not a number. + + + + Parses the specified number value. + + The number value to parse. + Parsed number value as a . + + + + Gets or sets the number of decimal digits. + + The number of decimal digits. + + + + + Gets or sets the decimal separator. + + The decimal separator. + + + + + Gets or sets the number group sizes. + + The number group sizes. + + + + + Gets or sets the number group separator. + + The number group separator. + + + + + Gets or sets the negative pattern. + + The number negative pattern. + + + + + Implementation of that can be used to + format and parse numbers. + + + + PercentFormatter uses percent-related properties of the + to format and parse percentages. + + + If you use one of the constructors that accept culture as a parameter + to create an instance of PercentFormatter, default NumberFormatInfo + for the specified culture will be used. + + + You can also use properties exposed by the PercentFormatter in order + to override some of the default number formatting parameters. + + + Aleksandar Seovic + + + + Initializes a new instance of the class + using default for the current thread's culture. + + + + + Initializes a new instance of the class + using default for the specified culture. + + The culture name. + + + + Initializes a new instance of the class + using default for the specified culture. + + The culture. + + + + Initializes a new instance of the class + using specified . + + + The instance that defines how + numbers are formatted and parsed. + + + + + Formats the specified percentage value. + + The value to format. + Formatted percentage. + If is null. + If is not a number. + + + + Parses the specified percentage value. + + The percentage value to parse. + Parsed percentage value as a . + + + + Gets or sets the number of decimal digits. + + The number of decimal digits. + + + + + Gets or sets the decimal separator. + + The decimal separator. + + + + + Gets or sets the percent group sizes. + + The percent group sizes. + + + + + Gets or sets the percent group separator. + + The percent group separator. + + + + + Gets or sets the negative pattern. + + The percent negative pattern. + + + + + Gets or sets the positive pattern. + + The percent positive pattern. + + + + + Gets or sets the percent symbol. + + The percent symbol. + + + + + Gets or sets the per mille symbol. + + The per mille symbol. + + + + + Loads a list of resources that should be applied from the .NET . + + +

+ This implementation will iterate over all resource managers + within the message source and return a list of all the resources whose name starts with '$this'. +

+

+ All other resources will be ignored, but you can retrieve them by calling one of + GetMessage methods on the message source directly. +

+
+ Aleksandar Seovic +
+ + + Abstract base class that all localizers should extend + + +

+ This class contains the bulk of the localizer logic, including implementation + of the ApplyResources methods that are defined in + interface. +

+

+ All specific localizers need to do is inherit this class and implement + GetResources method that will return a list of + objects that should be applied to a specified target. +

+

+ Custom implementations can use whatever type of resource storage they want, + such as standard .NET resource sets, custom XML files, database, etc. +

+
+ Aleksandar Seovic +
+ + + Defines an interface that localizers have to implement. + + +

+ Localizers are used to automatically apply resources to object's members + using reflection. +

+
+ Aleksandar Seovic +
+ + + Applies resources of the specified culture to the specified target object. + + Target object to apply resources to. + instance to retrieve resources from. + Resource culture to use for resource lookup. + + + + Applies resources to the specified target object, using current thread's culture to resolve resources. + + Target object to apply resources to. + instance to retrieve resources from. + + + + Gets or sets the resource cache instance. + + The resource cache instance. + + + + Applies resources of the specified culture to the specified target object. + + Target object to apply resources to. + instance to retrieve resources from. + Resource culture to use for resource lookup. + + + + Applies resources to the specified target object, using current thread's uiCulture to resolve resources. + + Target object to apply resources to. + instance to retrieve resources from. + + + + Returns a list of instances that should be applied to the target. + + Target to get a list of resources for. + instance to retrieve resources from. + Resource locale. + A list of resources to apply. + + + + Loads resources from the storage and creates a list of instances that should be applied to the target. + + Target to get a list of resources for. + instance to retrieve resources from. + Resource locale. + A list of resources to apply. + + + + Gets or sets the resource cache instance. + + The resource cache instance. + + + + Loads resources from the storage and creates a list of instances that should be applied to the target. + + + This feature is not currently supported on version 1.0 of the .NET platform. + + Target to get a list of resources for. + instance to retrieve resources from. + Resource locale. + A list of resources to apply. + + + + implementation + that simply returns the + value of the + + property (if said property value is not ), or the + of the current thread if it is + . + + Aleksandar Seovic + + + + Strategy interface for + resolution. + + Aleksandar Seovic + + + + Resolves the + from some context. + + +

+ The 'context' is determined by the appropriate implementation class. + An example of such a context might be a thread local bound + , or a + sourced from an HTTP + session. +

+
+ + The that should be used + by the caller. + +
+ + + Sets the . + + +

+ This is an optional operation and does not need to be implemented + such that it actually does anything useful (i.e. it can be a no-op). +

+
+ + The new or + to clear the current . + +
+ + + Returns the default . + + +

+ It tries to get the + from the value of the + + property and falls back to the of the + current thread if the + + is . +

+
+ + The default + +
+ + + Resolves the + from some context. + + +

+ The 'context' in this implementation is the + value of the + + property (if said property value is not ), or the + of the current thread if it is + . +

+
+ + The that should be used + by the caller. + +
+ + + Sets the . + + + The new or + to clear the current . + + + + + + + The default . + + + The default . + + + + + Abstract base class that all resource cache implementations should extend. + + Aleksandar Seovic + + + + Defines an interface that resource cache adapters have to implement. + + Aleksandar Seovic + + + + Gets the list of resources from cache. + + Target to get a list of resources for. + Resource culture. + A list of cached resources for the specified target object and culture. + + + + Puts the list of resources in the cache. + + Target to cache a list of resources for. + Resource culture. + A list of resources to cache. + A list of cached resources for the specified target object and culture. + + + + Gets the list of resources from the cache. + + Target to get a list of resources for. + Resource culture. + A list of cached resources for the specified target object and culture. + + + + Puts the list of resources in the cache. + + Target to cache a list of resources for. + Resource culture. + A list of resources to cache. + A list of cached resources for the specified target object and culture. + + + + Crates resource cache key for the specified target object and culture. + + Target object to apply resources to. + Resource culture to use for resource lookup. + + + + Gets the list of resources from cache. + + Cache key to use for lookup. + A list of cached resources for the specified target object and culture. + + + + Puts the list of resources in the cache. + + Cache key to use for the specified resources. + A list of resources to cache. + A list of cached resources for the specified target object and culture. + + + + Resource cache implementation that doesn't cache resources. + + Aleksandar Seovic + + + + Gets the list of resources from cache. + + Cache key to use for lookup. + Always returns null. + + + + Puts the list of resources in the cache. + + Cache key to use for the specified resources. + A list of resources to cache. + + + + Holds mapping between control property and it's value + as read from the resource file. + + Aleksandar Seovic + + + + Creates instance of resource mapper. + + Target property. + Resource value. + + + + Gets parsed target property expression. See + for more information on object navigation expressions. + + + + + Value of the resource that target property should be set to. + + + + + Utility class to aid in the manipulation of events and delegates. + + Griffin Caprio + + + + Returns a new instance of the requested . + + +

+ Often used to wire subscribers to event publishers. +

+
+ + The of delegate to create. + + + The target subscriber object that contains the delegate implementation. + + + referencing the delegate method on the subscriber. + + + A delegate handler that can be added to an events list of handlers, or called directly. + +
+ + + Queries the input type for a signature matching the input + signature. + + + Typically used to query a potential subscriber to see if they implement an event handler. + + to match against + to query + + matching input + signature, or if there is no match. + + + + + Creates a new instance of the EventManipulationUtilities class. + + +

+ This is a utility class, and as such has no publicly visible constructors. +

+
+
+ + + Default implementation of the + interface. + + Griffin Caprio + + + + Creates a new instance of the EventRegistry class. + + + + + Adds the input object to the list of publishers. + + + This publishes all events of the source object to any object + wishing to subscribe + + The source object to publish. + + + + Subscribes to all events published, if the subscriber implements + compatible handler methods. + + The subscriber to use. + + + + Subscribes to published events of all objects of a given type, if the + subscriber implements compatible handler methods. + + The subscriber to use. + + The target to subscribe to. + + + + + Unsubscribes to all events published, if the subscriber + implmenets compatible handler methods. + + The subscriber to use + + + + Unsubscribes to the published events of all objects of a given + , if the subscriber implements + compatible handler methods. + + The subscriber to use. + The target to unsubscribe from + + + + The list of event publishers. + + The list of event publishers. + + + + To be implemented by any object that wishes to receive a reference to + an . + + +

+ This interface only applies to objects that have been instantiated + within the context of an + . This interface does + not typically need to be implemented by application code, but is rather + used by classes internal to Spring.NET. +

+
+ Mark Pollack + Rick Evans +
+ + + Set the + associated with the + that created this + object. + + +

+ This property will be set by the relevant + after all of this + object's dependencies have been resolved. This object can use the + supplied + immediately to publish or subscribe to one or more events. +

+
+
+ + + Marks a property as being 'required': that is, the setter property + must be configured to be dependency-injected with a value. + + Consult the SDK documentation for , + which, by default, checks for the presence of this annotation. + + Rob Harrop + Mark Pollack + + + + A implementation that enforces required properties to have been configured. + Required properties are detected through an attribute, by default, Spring's + attribute. + + + The motivation for the existence of this IObjectPostProcessor is to allow + developers to annotate the setter properties of their own classes with an + arbitrary attribute to indicate that the container must check + for the configuration of a dependency injected value. This neatly pushes + responsibility for such checking onto the container (where it arguably belongs), + and obviates the need (in part) for a developer to code a method that + simply checks that all required properties have actually been set. + + Please note that an 'init' method may still need to implemented (and may + still be desirable), because all that this class does is enforce that a + 'required' property has actually been configured with a value. It does + not check anything else... In particular, it does not check that a + configured value is not null. + + + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + + + + Adapter that implements all methods on + as no-ops, which will not change normal processing of each object instantiated + by the container. Subclasses may override merely those methods that they are + actually interested in. + + + Note that this base class is only recommendable if you actually require + functionality. If all you need + is plain functionality, prefer a straight + implementation of that (simpler) interface. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Extension of the interface, + adding a callback for predicting the eventual type of a processed object. + + This interface is a special purpose interface, mainly for + internal use within the framework. In general, application-provided + post-processors should simply implement the plain + interface or derive from the + class. New methods might be added to this interface even in point releases. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Subinterface of + + that adds a before-instantiation callback and a callback after instantiation but before + explicit properties are set or autowiring occurs. + + + + Typically used to suppress default instantiation for specific target objects, + for example to create proxies with special Spring.Aop.ITargetSources (pooling targets, + lazily initializing targets, etc), or to implement additional injection strategies such as field + injection. + + + This interface is a special purpose interface, mainly for internal use within the framework. + It is recommended to implement the plain interface as far as + possible, or to derive from in order to be shielded + from extension to this interface. + + + Juergen Hoeller + Rick Evans (.NET) + + + + Apply this + + before the target object gets instantiated. + + +

+ The returned object may be a proxy to use instead of the target + object, effectively suppressing the default instantiation of the + target object. +

+

+ If the object is returned by this method is not + , the object creation process will be + short-circuited. The returned object will not be processed any + further; in particular, no further + + callbacks will be applied to it. This mechanism is mainly intended + for exposing a proxy instead of an actual target object. +

+

+ This callback will only be applied to object definitions with an + object class. In particular, it will not be applied to + objects with a "factory-method" (i.e. objects that are to be + instantiated via a layer of indirection anyway). +

+
+ + The of the target object that is to be + instantiated. + + + The name of the target object. + + + The object to expose instead of a default instance of the target + object. + + + In the case of any errors. + + + +
+ + + Perform operations after the object has been instantiated, via a constructor or factory method, + but before Spring property population (from explicit properties or autowiring) occurs. + + The object instance created, but whose properties have not yet been set + Name of the object. + true if properties should be set on the object; false if property population + should be skipped. Normal implementations should return true. Returning false will also + prevent any subsequent InstantiationAwareObjectPostProcessor instances from being + invoked on this object instance. + + + + Post-process the given property values before the factory applies them + to the given object. + + Allows for checking whether all dependencies have been + satisfied, for example based on a "Required" annotation on bean property setters. + Also allows for replacing the property values to apply, typically through + creating a new MutablePropertyValues instance based on the original PropertyValues, + adding or removing specific values. + + + The property values that the factory is about to apply (never null). + he relevant property infos for the target object (with ignored + dependency types - which the factory handles specifically - already filtered out) + The object instance created, but whose properties have not yet + been set. + Name of the object. + The actual property values to apply to the given object (can be the + passed-in PropertyValues instances0 or null to skip property population. + + + + Predicts the type of the object to be eventually returned from this + processors callback. + + The raw Type of the object. + Name of the object. + The type of the object, or null if not predictable. + in case of errors + + + + Determines the candidate constructors to use for the given object. + + The raw Type of the object. + Name of the object. + The candidate constructors, or null if none specified + in case of errors + + + + Predicts the type of the object to be eventually returned from this + processors PostProcessBeforeInstantiation callback. + + The raw Type of the object. + Name of the object. + The type of the object, or null if not predictable. + in case of errors + + + + Determines the candidate constructors to use for the given object. + + The raw Type of the object. + Name of the object. + The candidate constructors, or null if none specified + in case of errors + + + + Apply this + + before the target object gets instantiated. + + +

+ The returned object may be a proxy to use instead of the target + object, effectively suppressing the default instantiation of the + target object. +

+

+ If the object is returned by this method is not + , the object creation process will be + short-circuited. The returned object will not be processed any + further; in particular, no further + + callbacks will be applied to it. This mechanism is mainly intended + for exposing a proxy instead of an actual target object. +

+

+ This callback will only be applied to object definitions with an + object class. In particular, it will not be applied to + objects with a "factory-method" (i.e. objects that are to be + instantiated via a layer of indirection anyway). +

+
+ + The of the target object that is to be + instantiated. + + + The name of the target object. + + + The object to expose instead of a default instance of the target + object. + + + In the case of any errors. + + + +
+ + + Perform operations after the object has been instantiated, via a constructor or factory method, + but before Spring property population (from explicit properties or autowiring) occurs. + + The object instance created, but whose properties have not yet been set + Name of the object. + true if properties should be set on the object; false if property population + should be skipped. Normal implementations should return true. Returning false will also + prevent any subsequent InstantiationAwareObjectPostProcessor instances from being + invoked on this object instance. + + + + Post-process the given property values before the factory applies them + to the given object. + + Allows for checking whether all dependencies have been + satisfied, for example based on a "Required" annotation on bean property setters. + Also allows for replacing the property values to apply, typically through + creating a new MutablePropertyValues instance based on the original PropertyValues, + adding or removing specific values. + + + The property values that the factory is about to apply (never null). + he relevant property infos for the target object (with ignored + dependency types - which the factory handles specifically - already filtered out) + The object instance created, but whose properties have not yet + been set. + Name of the object. + The actual property values to apply to the given object (can be the + passed-in PropertyValues instances0 or null to skip property population. + + + + Apply this + to the given new object instance before any object initialization callbacks. + + +

+ The object will already be populated with property values. + The returned object instance may be a wrapper around the original. +

+
+ + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + +
+ + + Apply this to the + given new object instance after any object initialization callbacks. + + +

+ The object will already be populated with property values. The returned object + instance may be a wrapper around the original. +

+
+ + The new object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + In case of errors. + +
+ + + Cache for validated object names, skipping re-validation for the same object + + + + + Post-process the given property values before the factory applies them + to the given object. Checks for the attribute specified by this PostProcessor's RequiredAttributeType. + + The property values that the factory is about to apply (never null). + The relevant property infos for the target object (with ignored + dependency types - which the factory handles specifically - already filtered out) + The object instance created, but whose properties have not yet + been set. + Name of the object. + + The actual property values to apply to the given object (can be the + passed-in PropertyValues instances or null to skip property population. + + If a required property value has not been specified + in the configuration metadata. + + + + Determines whether the supplied property is required to have a value, that is to be dependency injected. + + + This implementation looks for the existence of a "required" attribute on the supplied PropertyInfo and that + the property has a setter method. + + The target PropertyInfo + + true if the supplied property has been marked as being required;; otherwise, false if + not or if the supplied property does not have a setter method + + + + + Builds an exception message for the given list of invalid properties. + + The list of names of invalid properties. + Name of the object. + The exception message + + + + Sets the type of the required attribute, to be used on a property setter + + + The default required attribute type is the Spring-provided attribute. + This setter property exists so that developers can provide their own + (non-Spring-specific) annotation type to indicate that a property value is required. + + The type of the required attribute. + + + + Base class that provides common functionality needed for several IObjectFactoryPostProcessor + implementations + + Mark Pollack + + + + Allows for custom modification of an application context's object + definitions, adapting the object property values of the context's + underlying object factory. + + +

+ Application contexts can auto-detect + IObjectFactoryPostProcessor objects in their object definitions and + apply them before any other objects get created. +

+

+ Useful for custom config files targeted at system administrators that + override object properties configured in the application context. +

+

+ See PropertyResourceConfigurer and its concrete implementations for + out-of-the-box solutions that address such configuration needs. +

+
+ Juergen Hoeller + Rick Evans (.Net) +
+ + + Modify the application context's internal object factory after its + standard initialization. + + +

+ All object definitions will have been loaded, but no objects will have + been instantiated yet. This allows for overriding or adding properties + even to eager-initializing objects. +

+
+ + The object factory used by the application context. + + + In case of errors. + +
+ + + Modify the application context's internal object factory after its + standard initialization. + + The object factory used by the application context. + +

+ All object definitions will have been loaded, but no objects will have + been instantiated yet. This allows for overriding or adding properties + even to eager-initializing objects. +

+
+ + In case of errors. + +
+ + + Resolves the supplied into a + instance. + + The object that is to be resolved into a + instance. + The error context source. + The error context string. + A resolved . + +

+ This (default) implementation supports resolving + s and s. + Only override this method if you want to key your type alias + on something other than s + and s. +

+
+ + If the supplied is , + or the supplied cannot be resolved. + +
+ + + Return the order value of this object, with a higher value meaning + greater in terms of sorting. + + The order value. + + + + + Simple template superclass for + implementations that allows for the creation of a singleton or a prototype + instance (depending on a flag). + + + If the value of the + + property is (this is the default), this class + will create a single instance of it's object upon initialization and + subsequently return the singleton instance; else, this class will + create a new instance each time (prototype mode). Subclasses must + implement the + + template method to actually create objects. + + Juergen Hoeller + Keith Donald + Simon White (.NET) + + + + Interface to be implemented by objects used within an + that are themselves + factories. + + +

+ If an object implements this interface, it is used as a factory, + not directly as an object. s + can support singletons and prototypes + ()... + please note that an + itself can only ever be a singleton. It is a logic error to configure an + itself to be a prototype. +

+ + An object that implements this interface cannot be used as a normal object. + +
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + + If this method is being called in the context of an enclosing IoC container and + returns , the IoC container will consider this factory + object as not being fully initialized and throw a corresponding (and most + probably fatal) exception. + + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + + Return the of object that this + creates, or + if not known in advance. + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + Invoked by an + after it has injected all of an object's dependencies. + + + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + + + Template method that subclasses must override to construct + the object returned by this factory. + + + Invoked once immediately after the initialization of this + in the case of + a singleton; else, on each call to the + + method. + + + If an exception occured during object creation. + + + A distinct instance of the object created by this factory. + + + + + Performs cleanup on any cached singleton object. + + +

+ Only makes sense in the context of a singleton object. +

+
+ + +
+ + + Is the object managed by this factory a singleton or a prototype? + + +

+ Please note that changing the value of this property after + this factory object instance has been created by an enclosing + Spring.NET IoC container really is a programming error. This + property should really only be set once, prior to the invocation + of the + + callback method. +

+
+ +
+ + + Return the of object that this + creates, or + if not known in advance. + + + + + + The various autowiring modes. + + Rick Evans + + + + Do not autowire. + + + + + Autowire by name. + + + + + Autowire by . + + + + + Autowiring by constructor. + + + + + The autowiring strategy is to be determined by introspection + of the object's . + + + + + Implementation of that + resolves variable name against command line arguments. + + Aleksandar Seovic + + + + Defines contract that different variable sources have to implement. + + +

+ The "variable sources" are objects containing name-value pairs + that allow a variable value to be retrieved for the given name.

+

+ Out of the box, Spring.NET supports a number of variable sources, + that allow users to obtain variable values from .NET config files, + Java-style property files, environment, registry, etc.

+

+ Users can always write their own variable sources implementations, + that will allow them to load variable values from the database or + other proprietary data source.

+
+ + + + + + + Aleksandar Seovic +
+ + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Default constructor. + Initializes command line arguments from the environment. + + + + + Constructor that allows arguments to be passed externally. + Useful for testing. + + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Initializes command line arguments dictionary. + + + + + Gets or sets a prefix that should be used to + identify arguments to extract values from. + + + A prefix that should be used to identify arguments + to extract values from. Defaults to slash ("/"). + + + + + Gets or sets a character that should be used to + separate argument name from its value. + + + A character that should be used to separate argument + name from its value. Defaults to colon (":"). + + + + + Implementation of that + resolves variable name against name-value sections in + the standard .NET configuration file. + + Aleksandar Seovic + + + + Initializes a new instance of + + + + + Initializes a new instance of from the given + + + + + Initializes a new instance of from the given + + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Initializes properties based on the specified + property file locations. + + + + + Gets or sets a list of section names variables should be loaded from. + + + All sections specified need to be handled by the + in order to be processed successfully. + + + A list of section names variables should be loaded from. + + + + + Convinience property. Gets or sets a single section + to read properties from. + + + The section specified needs to be handled by the + in order to be processed successfully. + + + A section to read properties from. + + + + + Implementation of that + resolves variable name against provided variables. + + + Variable name resolution is case insensitive. + + Bruno Baia + + + + Initializes a new instance of . + + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Gets or sets variables. + + + + + Various utility methods for .NET style .config files. + + +

+ Currently supports reading custom configuration sections and returning them as + objects. +

+
+ Simon White + Mark Pollack +
+ + + Initializes the type members + + + + + Reads the specified configuration section into a + . + + The resource to read. + The section name. + + A newly populated + . + + + If any errors are encountered while attempting to open a stream + from the supplied . + + + If any errors are encountered while loading or reading (this only applies to + v1.1 and greater of the .NET Framework) the actual XML. + + + If any errors are encountered while loading or reading (this only applies to + v1.0 of the .NET Framework). + + + If the configuration section was otherwise invalid. + + + + + Reads the specified configuration section into the supplied + . + + The resource to read. + The section name. + + The collection that is to be populated. May be + . + + + A newly populated + . + + + If any errors are encountered while attempting to open a stream + from the supplied . + + + If any errors are encountered while loading or reading (this only applies to + v1.1 and greater of the .NET Framework) the actual XML. + + + If any errors are encountered while loading or reading (this only applies to + v1.0 of the .NET Framework). + + + If the configuration section was otherwise invalid. + + + + + Reads the specified configuration section into the supplied + . + + The resource to read. + The section name. + + The collection that is to be populated. May be + . + + + If a key already exists, is its value to be appended to the current + value or replaced? + + + The populated + . + + + If any errors are encountered while attempting to open a stream + from the supplied . + + + If any errors are encountered while loading or reading (this only applies to + v1.1 and greater of the .NET Framework) the actual XML. + + + If any errors are encountered while loading or reading (this only applies to + v1.0 of the .NET Framework). + + + If the configuration section was otherwise invalid. + + + + + Read from the specified configuration from the supplied XML + into a + . + + + + Does not support section grouping. The supplied XML + must already be loaded. + + + + The to read from. + + + The configuration section name to read. + + + A newly populated + . + + + If any errors are encountered while reading (this only applies to + v1.1 and greater of the .NET Framework). + + + If any errors are encountered while reading (this only applies to + v1.0 of the .NET Framework). + + + If the configuration section was otherwise invalid. + + + + + Returns the section from the specified resource with the given section name + + + + + Returns the section from the specified resource with the given section name. Use + in case no section handler is specified. + + + + + Returns the typed section from the specified resource with the given section name + + + + + Returns the section from the specified resource with the given section name. Use + in case no section handler is specified. + + + + + Returns the typed result of evaluating the specified . + + if the result's type does not match the expected type + + + + Reads the specified configuration section from the given + + + + + + + + Reads the specified configuration section from the given + + + + + + + + + Determine the configuration section handler type + + + + + Populates the supplied with values from + a .NET application configuration file. + + + The + to add any key-value pairs to. + + + The configuration section name in the a .NET application configuration + file. + + + If a key already exists, is its value to be appended to the current + value or replaced? + + + if the supplied + was found. + + + + + Creates a new instance of the ConfigurationReader class. + + +

+ This is a utility class, and as such has no publicly visible + constructors. +

+
+
+ + + Implementation of that + resolves variable name connection strings defined in + the standard .NET configuration file. + + +

+ When the <connectionStrings> configuration section is processed by this class, + two variables are defined for each connection string: one for connection string and + the second one for the provider name.

+

+ Variable names are generated by appending '.connectionString' and '.providerName' + literals to the value of the name attribute of the connection string element. + For example:

+
+            
+               
+            
+            
+

+ will result in two variables being created: myConn.connectionString and myConn.providerName. + You can reference these variables within your object definitions, just like any other variable.

+
+ Aleksandar Seovic +
+ + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Initializes properties based on the specified + property file locations. + + + + + Holder for constructor argument values for an object. + + +

+ Supports values for a specific index or parameter name (case + insensitive) in the constructor argument list, and generic matches by + . +

+
+ Juergen Hoeller + Rick Evans (.NET) + +
+ + + Can be used as an argument filler for the + + overload when one is not looking for an argument by index. + + + + + Creates a new instance of the + + class. + + + + + Creates a new instance of the + + class. + + + The + to be used to populate this instance. + + + + + Copy all given argument values into this object. + + + The + to be used to populate this instance. + + + + + Add argument value for the given index in the constructor argument list. + + + The index in the constructor argument list. + + + The argument value. + + + + + Add argument value for the given index in the constructor argument list. + + The index in the constructor argument list. + The argument value. + + The of the argument + . + + + + + Add argument value for the given name in the constructor argument list. + + The name in the constructor argument list. + The argument value. + + If the supplied is + or is composed wholly of whitespace. + + + + + Get argument value for the given index in the constructor argument list. + + The index in the constructor argument list. + + The required of the argument. + + + The + + for the argument, or if none set. + + + + + Get argument value for the given name in the constructor argument list. + + The name in the constructor argument list. + + The + + for the argument, or if none set. + + + + + Does this set of constructor arguments contain a named argument matching the + supplied name? + + + + The comparison is performed in a case-insensitive fashion. + + + The named argument to look up. + + if this set of constructor arguments + contains a named argument matching the supplied + name. + + + + + Add generic argument value to be matched by type. + + + The argument value. + + + + + Add generic argument value to be matched by type. + + The argument value. + + The of the argument + . + + + + + Look for a generic argument value that matches the given + . + + + The to match. + + + The + + for the argument, or if none set. + + + + + Look for a generic argument value that matches the given + . + + + The to match. + + + A of + + objects that have already been used in the current resolution + process and should therefore not be returned again; this allows one + to return the next generic argument match in the case of multiple + generic argument values of the same type. + + + The + + for the argument, or if none set. + + + + + Look for an argument value that either corresponds to the given index + in the constructor argument list or generically matches by + . + + + The index in the constructor argument list. + + + The to match. + + + The + + for the argument, or if none is set. + + + + + Look for an argument value that either corresponds to the given index + in the constructor argument list or generically matches by + . + + + The index in the constructor argument list. + + + The to match. + + + A of + + objects that have already been used in the current resolution + process and should therefore not be returned again; this allows one + to return the next generic argument match in the case of multiple + generic argument values of the same type. + + + The + + for the argument, or if none is set. + + + + + Look for an argument value that either corresponds to the given index + in the constructor argument list or generically matches by + . + + + The name of the argument in the constructor argument list. May be + , in which case generic matching by + is assumed. + + + The to match. + + + The + + for the argument, or if none is set. + + + + + Look for an argument value that either corresponds to the given index + in the constructor argument list or generically matches by + . + + + The name of the argument in the constructor argument list. May be + , in which case generic matching by + is assumed. + + + The to match. + + + A of + + objects that have already been used in the current resolution + process and should therefore not be returned again; this allows one + to return the next generic argument match in the case of multiple + generic argument values of the same type. + + + The + + for the argument, or if none is set. + + + + + Look for an argument value that either corresponds to the given index + in the constructor argument list, or to the named argument, or + generically matches by . + + + The index of the argument in the constructor argument list. May be + negative, to denote the fact that we are not looking for an + argument by index (see + . + + + The name of the argument in the constructor argument list. May be + . + + + The to match. + + + A of + + objects that have already been used in the current resolution + process and should therefore not be returned again; this allows one + to return the next generic argument match in the case of multiple + generic argument values of the same type. + + + The + + for the argument, or if none is set. + + + + + Return the map of indexed argument values. + + + An with + indices as keys and + s + as values. + + + + + Return the map of named argument values. + + + An with + named arguments as keys and + s + as values. + + + + + Return the set of generic argument values. + + + A of + s. + + + + + Return the number of arguments held in this instance. + + + + + Returns true if this holder does not contain any argument values, + neither indexed ones nor generic ones. + + + + + Holder for a constructor argument value, with an optional + attribute indicating the target + of the actual constructor argument. + + + + + Creates a new instance of the ValueHolder class. + + + The value of the constructor argument. + + + + + Creates a new instance of the ValueHolder class. + + + The value of the constructor argument. + + + The of the argument + . Can also be one of the common + aliases (int, bool, + float, etc). + + + + + A that represents the current + . + + + A that represents the current + . + + + + + Gets and sets the value for the constructor argument. + + +

+ Only necessary for manipulating a registered value, for example in + s. +

+
+
+ + + Return the of the constructor + argument. + + + + + + implementation that allows for convenient registration of custom + s. + + + + The use of this class is typically not required; the .NET + mechanism of associating a + with a + via the use of the + is the + recommended (and standard) way. This class primarily exists to cover + those cases where third party classes to which one does not have the + source need to be exposed to the type conversion mechanism. + +

+ Because the + + class implements the + + interface, instances of this class that have been exposed in the + scope of an + will + automatically be picked up by the application context and made + available to the IoC container whenever type conversion is required. If + one is using a + + object definition within the scope of an + , no such automatic + pickup of the + + is performed (custom converters will have to be added manually using the + + method). For most application scenarios, one will get better + mileage using the + abstraction. +

+
+ +

+ The following examples all assume XML based configuration, and use + inner object definitions to define the custom + objects (nominally to + avoid polluting the object name space, but also because the + configuration simply reads better that way). +

+ + + + + + + + + + + + + + + + +

+ The following example illustrates a complete (albeit naieve) use case + for this class, including a custom + implementation, said + converters domain class, and the XML configuration that hooks the + converter in place and makes it available to a Spring.NET container for + use during object resolution. +

+

+ The domain class is a simple data-only object that contains the data + required to send an email message (such as the host and user account + name). A developer would prefer to use a string of the form + UserName=administrator,Password=r1l0k1l3y,Host=localhost to + configure the mail settings and just let the container take care of the + conversion. +

+ + namespace ExampleNamespace + { + public sealed class MailSettings + { + private string _userName; + private string _password; + private string _host; + + public string Host + { + get { return _host; } + set { _host = value; } + } + + public string UserName + { + get { return _userName; } + set { _userName = value; } + } + + public string Password + { + get { return _password; } + set { _password = value; } + } + } + + public sealed class MailSettingsConverter : TypeConverter + { + public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType) + { + if (typeof (string) == sourceType) + { + return true; + } + return base.CanConvertFrom(context, sourceType); + } + + public override object ConvertFrom(ITypeDescriptorContext context, CultureInfo culture, object value) + { + string text = value as string; + if(text != null) + { + MailSettings mailSettings = new MailSettings(); + string[] tokens = text.Split(','); + for (int i = 0; i < tokens.Length; ++i) + { + string token = tokens[i]; + string[] settings = token.Split('='); + typeof(MailSettings).GetProperty(settings[0]) + .SetValue(mailSettings, settings[1], null); + } + return mailSettings; + } + return base.ConvertFrom(context, culture, value); + } + } + + // a very naieve class that uses the MailSettings class... + public sealed class ExceptionLogger + { + private MailSettings _mailSettings; + + public MailSettings MailSettings { + { + set { _mailSettings = value; } + } + + public void Log(object value) + { + Exception ex = value as Exception; + if(ex != null) + { + // use _mailSettings instance... + } + } + } + } + +

+ The attendant XML configuration for the above classes would be... +

+ + + + + + + + + + + + + + + + Juergen Hoeller + Simon White (.NET) + + + + + + + Registers any custom converters with the supplied + . + + + The object factory to register the converters with. + + + In case of errors. + + + + + Resolves the supplied into a + instance. + + + The object that is to be resolved into a + instance. + + + A resolved instance. + + + If the supplied is , + or the supplied cannot be resolved. + + + + + The custom converters to register. + + +

+ The uses the type name + of the class that requires conversion as the key, and an + instance of the + that will effect + the conversion. Alternatively, the actual + of the class that requires conversion + can be used as the key. +

+
+ +

+ + IDictionary converters = new Hashtable(); + converters.Add( "System.Date", new MyCustomDateConverter() ); + // a System.Type instance can also be used as the key... + converters.Add( typeof(Color), new MyCustomRBGColorConverter() ); + +

+
+
+ + + implementation that + creates delegates. + + +

+ Supports the creation of s for both + instance and methods. +

+
+ Rick Evans +
+ + + Callback method called once all factory properties have been set. + + + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + + + + + Creates the delegate. + + + If an exception occured during object creation. + + The object returned by this factory. + + + + + The of + created by this factory. + + +

+ Returns the + if accessed prior to the method + being called. +

+
+
+ + + The of the + created by this factory. + + + + + The name of the method that is to be invoked by the created + delegate. + + + + + The target if the + refers to a method. + + + + + The target object if the + refers to an instance method. + + + + + A generic implementation of an , that delegates post processing to a passed delegate + + + This comes in handy when you want to perform specific tasks on an object factory, e.g. doing special initialization. + + + The example below is taken from a unit test. The snippet causes 'someObject' to be registered each time is called on + the context instance: + + IConfigurableApplicationContext ctx = new XmlApplicationContext(false, "name", false, null); + ctx.AddObjectFactoryPostProcessor(new DelegateObjectFactoryConfigurer( of => + { + of.RegisterSingleton("someObject", someObject); + })); + + + Erich Eichinger + + + + Get or Set the handler to delegate configuration to + + + + + Descriptor for a specific dependency that is about to be injected. + Wraps a constructor parameter, a method parameter or a field, + allowing unified access to their metadata. + + Juergen Hoeller + Mark Pollack + + + + Initializes a new instance of the class for a method or constructor parameter. + Considers the dependency as 'eager' + + The MethodParameter to wrap. + if set to true if the dependency is required. + + + + Initializes a new instance of the class for a method or a constructor parameter. + + The MethodParameter to wrap. + if set to true the dependency is required. + if set to true the dependency is 'eager' in the sense of + eagerly resolving potential target objects for type matching. + + + + Gets a value indicating whether this dependency is required. + + true if required; otherwise, false. + + + + Determine the declared (non-generic) type of the wrapped parameter/field. + + The type of the dependency (never null + + + + Gets a value indicating whether this is eager in the sense of + eagerly resolving potential target beans for type matching. + + true if eager; otherwise, false. + + + + Gets the wrapped MethodParameter, if any. + + The method parameter. + + + + Simple factory for shared instances. + + Juergen Hoeller + Simon White (.NET) + + + + Constructs a new instance of the target dictionary. + + The new instance. + + + + Set the source . + + +

+ This value will be used to populate the + returned by this factory. +

+
+
+ + + Set the of the + implementation to use. + + +

+ The default is the . +

+
+ + If the value is . + + + If the value is an . + + + If the value is an interface. + +
+ + + The of objects created by this factory. + + + Always returns the . + + + + + A very simple, hashtable-based implementation of + + Erich Eichinger + + + + Creates a new, empty variable source + + + + + Creates a new, empty and case-insensitive variable source + + + + + Create a new variable source from a list of paired string values. + + + + The example below shows, how the dictionary is filled with { 'key1', 'value1' }, { 'key2', 'value2' } pairs: + + new DictionaryVariableSource( new string[] { "key1", "value1", "key2", "value2" } ) + + + + the argument list containing pairs, or null + + + + Initializes a new instance of the DictionaryVariableSource class. + + + + + Creates a new variable source, reading values from another dictionary + and converting them to strings if necessary + + + + + Adds a key/value pair + + this dictionary. allows for fluent config + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Performs a variable name lookup + + + + + Specifies how instances of the + + class must apply environment variables when replacing values. + + Mark Pollack + + + + Never replace environment variables. + + + + + If properties are not specified via a resource, + then resolve using environment variables. + + + + + Apply environment variables first before applying properties from a + resource. + + + + + Implementation of that + resolves variable name against environment variables. + + Aleksandar Seovic + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Holder for event handler values for an object. + + Rick Evans (.NET) + + + + The empty array of s. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The + to be used to populate this instance. + + + + + Copy all given argument values into this object. + + + The + to be used to populate this instance. + + + + + Adds the supplied handler to the collection of event handlers. + + The handler to be added. + + + + The mapping of event names to an + of + s. + + + + + Gets the of events + that have handlers associated with them. + + + + + Gets the of + s for the supplied + event name. + + + + + Immutable placeholder class used for the value of a + object when it's a reference + to a Spring that should be evaluated at runtime. + + Aleksandar Seovic + + + + Creates a new instance of the + + class. + + The expression to resolve. + + + + Returns a string representation of this instance. + + A string representation of this instance. + + + + Gets or sets the expression string. Setting the expression string will cause + the expression to be parsed. + + The expression string. + + + + Return the expression. + + + + + Properties for this expression node. + + + + + implementation that + retrieves a static or non-static public field value. + + +

+ Typically used for retrieving public constants. +

+
+ +

+ The following example retrieves the field value... +

+ + + + + + +

+ The previous example could also have been written using the convenience + + property, like so... +

+ + + + + +

+ This class also implements the + interface + (). + If the id (or name) of one's + + object definition is set to the + of the field to be retrieved, then the id (or + name) of one's object definition will be used for the name of the + field lookup. See below for an example of this + concise style of definition. +

+ + + + + + + +

+ The usage for retrieving instance fields is similar. No example is shown + because public instance fields are generally bad practice; but if + you have some legacy code that exposes public instance fields, or if you + just really like coding public instance fields, then you can use this + implementation to + retrieve such field values. +

+ + Juergen Hoeller + Rick Evans (.NET) + + + + Interface to be implemented by objects that wish to be aware of their object + name in an . + + +

+ Note that most objects will choose to receive references to collaborating + objects via respective properties. +

+

+ For a list of all object lifecycle methods, see the + API documentation. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Set the name of the object in the object factory that created this object. + + + The name of the object in the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Invoked by an + after it has set all object properties supplied + (and satisfied + and ApplicationContextAware). + + +

+ This method allows the object instance to perform initialization only + possible when all object properties have been set and to throw an + exception in the event of misconfiguration. +

+
+ + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + +
+ + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + + + The of the + field to be retrieved. + + + + + Set the name of the object in the object factory that created this object. + + + The name of the object in the factory. + + +

+ In the context of the + + class, the + + value will be interepreted as the value of the + + property if no value has been explicitly assigned to the + + property. This allows for concise object definitions with just an id or name; + see the class documentation for + + for an example of this style of usage. +

+
+
+ + + The name of the field the value of which is to be retrieved. + + +

+ If the + + has been set (and is not ), then the value of this property + refers to an instance field name; it otherwise refers to a + field name. +

+
+
+ + + The object instance on which the field is defined. + + + + + The on which the field is defined. + + + + + The of object that this + creates, or + if not known in advance. + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + Extension of the + interface to be implemented by object factories that are capable of + autowiring and expose this functionality for existing object instances. + + Juergen Hoeller + Rick Evans (.NET) + + + + Create a new object instance of the given class with the specified + autowire strategy. + + + The of the object to instantiate. + + + The desired autowiring mode. + + + Whether to perform a dependency check for objects (not applicable to + autowiring a constructor, thus ignored there). + + The new object instance. + + If the wiring fails. + + + + + + Autowire the object properties of the given object instance by name or + . + + + The existing object instance. + + + The desired autowiring mode. + + + Whether to perform a dependency check for the object. + + + If the wiring fails. + + + + + + Apply s + to the given existing object instance, invoking their + + methods. + + +

+ The returned object instance may be a wrapper around the original. +

+
+ + The existing object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + If any post-processing failed. + + +
+ + + Apply s + to the given existing object instance, invoking their + + methods. + + +

+ The returned object instance may be a wrapper around the original. +

+
+ + The existing object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + If any post-processing failed. + + +
+ + + Resolve the specified dependency against the objects defined in this factory. + + The descriptor for the dependency. + Name of the object which declares the present dependency. + A list that all names of autowired object (used for + resolving the present dependency) are supposed to be added to. + the resolved object, or null if none found + if dependency resolution failed + + + + Extension of the interface + that injects dependencies into the object managed by the factory. + + Bruno Baia + + + + Gets the template object definition that should be used + to configure the instance of the object managed by this factory. + + + + + SPI interface to be implemented by most if not all listable object factories. + + +

+ Allows for framework-internal plug'n'play, e.g. in + . +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Configuration interface to be implemented by most if not all object + factories. + + +

+ Provides the means to configure an object factory in addition to the + object factory client methods in the + interface. +

+

+ Allows for framework-internal plug'n'play even when needing access to object + factory configuration methods. +

+

+ When disposed, it will destroy all cached singletons in this factory. Call + when you want to shutdown + the factory. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Interface that defines a registry for shared object instances. + + + Can be implemented by + implementations in order to expose their singleton management facility + in a uniform manner. + + The interface extends this interface. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Registers the given existing object as singleton in the object registry, + under the given object name. + + + + The given instance is supposed to be fully initialized; the registry + will not perform any initialization callbacks (in particular, it won't + call IInitializingObject's AfterPropertiesSet method). + The given instance will not receive any destruction callbacks + (like IDisposable's Dispose method) either. + + + If running within a full IObjectFactory: Register an object definition + instead of an existing instance if your object is supposed to receive + initialization and/or destruction callbacks. + + + Typically invoked during registry configuration, but can also be used + for runtime registration of singletons. As a consequence, a registry + implementation should synchronize singleton access; it will have to do + this anyway if it supports a BeanFactory's lazy initialization of singletons. + + + Name of the object. + The singleton object. + + + + + + Return the (raw) singleton object registered under the given name. + + + + Only checks already instantiated singletons; does not return an Object + for singleton object definitions which have not been instantiated yet. + + + The main purpose of this method is to access manually registered singletons + . Can also be used to access a singleton + defined by an object definition that already been created, in a raw fashion. + + + Name of the object to look for. + the registered singleton object, or null if none found + + + + + Check if this registry contains a singleton instance with the given name. + + + + Only checks already instantiated singletons; does not return true + for singleton bean definitions which have not been instantiated yet. + + + The main purpose of this method is to check manually registered singletons + . Can also be used to check whether a + singleton defined by an object definition has already been created. + + + To check whether an object factory contains an object definition with a given name, + use ListableBeanFactory's ContainsObjectDefinition. Calling both + ContainsObjectDefinition and ContainsSingleton answers + whether a specific object factory contains an own object with the given name. + + + Use IObjectFactory's ContainsObject for general checks whether the + factory knows about an object with a given name (whether manually registered singleton + instance or created by bean definition), also checking ancestor factories. + + + Name of the object to look for. + + true if this bean factory contains a singleton instance with the given name; otherwise, false. + + + + + + + + Gets the names of singleton objects registered in this registry. + + + + Only checks already instantiated singletons; does not return names + for singleton bean definitions which have not been instantiated yet. + + + The main purpose of this method is to check manually registered singletons + . Can also be used to check which + singletons defined by an object definition have already been created. + + + The list of names as String array (never null). + + + + + + + Gets the number of singleton beans registered in this registry. + + + + Only checks already instantiated singletons; does not count + singleton object definitions which have not been instantiated yet. + + + The main purpose of this method is to check manually registered singletons + . Can also be used to count the number of + singletons defined by an object definition that have already been created. + + + The number of singleton objects. + + + + + + + Ignore the given dependency type for autowiring. + + +

+ To be invoked during factory configuration. +

+

+ This will typically be used for dependencies that are resolved + in other ways, like + through . +

+
+ + The to be ignored. + +
+ + + Determines whether the specified object name is currently in creation.. + + Name of the object. + + true if the specified object name is currently in creation; otherwise, false. + + + + + Add a new + that will get applied to objects created by this factory. + + +

+ To be invoked during factory configuration. +

+
+ + The + to register. + +
+ + + Given an object name, create an alias. + + +

+ This is typically used to support names that are illegal within + XML ids (which are used for object names). +

+

+ Typically invoked during factory configuration, but can also be + used for runtime registration of aliases. Therefore, a factory + implementation should synchronize alias access. +

+
+ The name of the object. + + + The alias that will behave the same as the object name. + + + If there is no object with the given name. + + + If the alias is already in use. + +
+ + + Register the given custom + for all properties of the given . + + +

+ To be invoked during factory configuration. +

+
+ + The required of the property. + + + The to register. + +
+ + + Set the parent of this object factory. + + +

+ Note that the parent shouldn't be changed: it should only be set outside + a constructor if it isn't available when an object of this class is + created. +

+
+
+ + + Returns the current number of registered + s. + + + The current number of registered + s. + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + Whether to search parent object factories. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Register a new object definition with this registry. + Must support + + and . + + + The name of the object instance to register. + + + The definition of the object instance to register. + + +

+ Must support + and + . +

+
+ + If the object definition is invalid. + +
+ + + Injects dependencies into the supplied instance + using the supplied . + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + An object definition that should be used to configure object. + + + + + + Ensure that all non-lazy-init singletons are instantiated, also + considering s. + + +

+ Typically invoked at the end of factory setup, if desired. +

+

+ As this is a startup method, it should destroy already created singletons if + it fails, to avoid dangling resources. In other words, after invocation + of that method, either all or no singletons at all should be + instantiated. +

+
+ + If one of the singleton objects could not be created. + +
+ + + Register a special dependency type with corresponding autowired value. + + + This is intended for factory/context references that are supposed + to be autowirable but are not defined as objects in the factory: + e.g. a dependency of type ApplicationContext resolved to the + ApplicationContext instance that the object is living in. + + Note there are no such default types registered in a plain IObjectFactory, + not even for the BeanFactory interface itself. + + + Type of the dependency to register. + This will typically be a base interface such as IObjectFactory, with extensions of it resolved + as well if declared as an autowiring dependency (e.g. IListableBeanFactory), + as long as the given value actually implements the extended interface. + + The autowired value. This may also be an + implementation o the interface, + which allows for lazy resolution of the actual target value. + + + + Determines whether the specified object qualifies as an autowire candidate, + to be injected into other beans which declare a dependency of matching type. + This method checks ancestor factories as well. + + Name of the object to check. + The descriptor of the dependency to resolve. + + true if the object should be considered as an autowire candidate; otherwise, false. + + if there is no object with the given name. + + + + May be used to store custom value references in object definition properties. + + + Erich Eichinger + + + + + + the object factory holding the given object definition + + + The name of the object that is having the value of one of its properties resolved. + + + The definition of the named object. + + + The name of the property the value of which is being resolved. + + + The value of the property that is being resolved. + + + + + Subinterface of + that adds + a before-destruction callback. + + + The typical usage will be to invoke custom destruction callbacks on + specific object types, matching corresponding initialization callbacks. + + Juergen Hoeller + Simon White (.NET) + + + + Apply this + to the + given new object instance before its destruction. Can invoke custom + destruction callbacks. + + The new object instance. + The name of the object. + + In case of errors. + + + + + Denotes a special placeholder collection that may contain + s or + other placeholder objects that will need to be resolved. + + +

+ 'A special placeholder collection' means that the elements of this + collection can be placeholders for objects that will be resolved later by + a Spring.NET IoC container, i.e. the elements themselves will be + resolved at runtime by the enclosing IoC container. +

+

+ The core Spring.NET library already provides three implementations of this interface + straight out of the box; they are... +

+ + + + . + + + + + . + + + + + . + + + +

+ If you have a custom collection class (i.e. a class that either implements the + directly or derives from a class that does) + that you would like to expose as a special placeholder collection (i.e. one that can + have s as elements + that will be resolved at runtime by an appropriate Spring.NET IoC container, just + implement this interface. +

+
+ +

+ Lets say one has a Bag class (i.e. a collection that supports bag style semantics). +

+ + using System; + + using Spring.Objects.Factory.Support; + + namespace MyNamespace + { + public sealed class Bag : ICollection + { + // ICollection implementation elided for clarity... + + public void Add(object o) + { + // implementation elided for clarity... + } + } + + public class ManagedBag : Bag, IManagedCollection + { + public ICollection Resolve( + string objectName, RootObjectDefinition definition, + string propertyName, ManagedCollectionElementResolver resolver) + { + Bag newBag = new Bag(); + string elementName = propertyName + "[bag-element]"; + foreach(object element in this) + { + object resolvedElement = resolver(objectName, definition, elementName, element); + newBag.Add(resolvedElement); + } + return newBag; + } + } + } + +
+ Rick Evans +
+ + + Resolves this managed collection at runtime. + + + The name of the top level object that is having the value of one of it's + collection properties resolved. + + + The definition of the named top level object. + + + The name of the property the value of which is being resolved. + + + The callback that will actually do the donkey work of resolving + this managed collection. + + A fully resolved collection. + + + + Resolves a single element value of a managed collection. + + +

+ If the does not need to be resolved or + converted to an appropriate , the + will be returned as-is. +

+
+ + The name of the top level object that is having the value of one of it's + collection properties resolved. + + + The definition of the named top level object. + + + The name of the property the value of which is being resolved. + + + That element of a managed collection that may need to be resolved + to a concrete value. + + A fully resolved element. +
+ + + Describes an object instance, which has property values, constructor + argument values, and further information supplied by concrete implementations. + + +

+ This is just a minimal interface: the main intention is to allow + + (like PropertyPlaceholderConfigurer) to access and modify property values. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Return the property values to be applied to a new instance of the object. + + + + + Return the constructor argument values for this object. + + + + + Return the event handlers for any events exposed by this object. + + + + + Return a description of the resource that this object definition + came from (for the purpose of showing context in case of errors). + + + + + Is this object definition a "template", i.e. not meant to be instantiated + itself but rather just serving as an object definition for configuration + templates used by . + + + if this object definition is a "template". + + + + + Is this object definition "abstract", i.e. not meant to be instantiated + itself but rather just serving as parent for concrete child object + definitions. + + + if this object definition is "abstract". + + + + + Return whether this a Singleton, with a single, shared instance + returned on all calls. + + +

+ If , an object factory will apply the Prototype + design pattern, with each caller requesting an instance getting an + independent instance. How this is defined will depend on the + object factory implementation. Singletons are the commoner type. +

+
+
+ + + Is this object lazily initialized? + +

+ Only applicable to a singleton object. +

+

+ If , it will get instantiated on startup by object factories + that perform eager initialization of singletons. +

+
+
+ + + The name of the parent definition of this object definition, if any. + + + + + The target scope for this object. + + + + + Get the role hint for this object definition + + + + + Returns the of the object definition (if any). + + + A resolved object . + + + If the of the object definition is not a + resolved or . + + + + + Returns the of the + of the object definition. + + Note that this does not have to be the actual type name used at runtime, + in case of a child definition overrding/inheriting the the type name from its + parent. It can be modifed during object factory post-processing, typically + replacing the original class name with a parsed variant of it. + Hence, do not consider this to be the definitive bean type at runtime + but rather only use it for parsing purposes at the individual object + definition level. + + + + + The autowire mode as specified in the object definition. + + +

+ This determines whether any automagical detection and setting of + object references will happen. Default is + , + which means there's no autowire. +

+
+
+ + + The object names that this object depends on. + + +

+ The object factory will guarantee that these objects get initialized + before. +

+

+ Note that dependencies are normally expressed through object properties + or constructor arguments. This property should just be necessary for + other kinds of dependencies like statics (*ugh*) or database + preparation on startup. +

+
+
+ + + The name of the initializer method. + + +

+ The default is , in which case there is no initializer method. +

+
+
+ + + Return the name of the destroy method. + + +

+ The default is , in which case there is no destroy method. +

+
+
+ + + The name of the factory method to use (if any). + + +

+ This method will be invoked with constructor arguments, or with no + arguments if none are specified. The static method will be invoked on + the specified . +

+
+
+ + + The name of the factory object to use (if any). + + + + + Gets a value indicating whether this instance a candidate for getting autowired into some other + object. + + + true if this instance is autowire candidate; otherwise, false. + + + + + Simple factory for shared instances. + + Juergen Hoeller + Simon White (.NET) + + + + Constructs a new instance of the target dictionary. + + The new instance. + + + + Set the source . + + +

+ This value will be used to populate the + returned by this factory. +

+
+
+ + + Set the of the + implementation to use. + + +

+ The default is the . +

+
+
+ + + The of objects created by this factory. + + + Always returns the . + + + + + implementation that + creates instances of the class. + + +

+ Typically used for retrieving shared + instances for common topics (such as the 'DAL', 'BLL', etc). The + + property determines the name of the + Common.Logging logger. +

+
+ Rick Evans + +
+ + + Creates a new instance of the + + class. + + + + + Creates a new instance of the + + class. + + + The name of the instance served up by + this factory. + + + If the supplied is + or contains only whitespace character(s). + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object + managed by this factory. + + + + + + Invoked by an + after it has set all object properties supplied + (and satisfied the + + and + interfaces). + + + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + + + + + The name of the instance served up by + this factory. + + + The name of the instance served up by + this factory. + + + If the supplied to the setter is + or contains only whitespace character(s). + + + + + Return the type of object that this + creates, or + if not known in advance. + + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + + Tag subclass used to hold a dictionary of managed elements. + + Juergen Hoeller + Rick Evans (.NET) + + + + Interface representing an object whose value set can be merged with that of a parent object. + + Rob Harrop + Mark Pollack (.NET) + + + + Merges the current value set with that of the supplied object. + + The supplied object is considered the parent, and values in the + callee's value set must override those of the supplied object. + + The parent object to merge with + The result of the merge operation + If the supplied parent is null + If merging is not enabled for this instance, + (i.e. MergeEnabled equals false. + + + + Gets a value indicating whether this instance is merge enabled for this instance + + + true if this instance is merge enabled; otherwise, false. + + + + + Initializes a new, empty instance of the class using the default initial capacity, load factor, hash code provider, and comparer. + + + + + Initializes a new, empty instance of the class using the specified initial capacity, and the default load factor, hash code provider, and comparer. + + The approximate number of elements that the object can initially contain. is less than zero. + + + + Resolves this managed collection at runtime. + + + The name of the top level object that is having the value of one of it's + collection properties resolved. + + + The definition of the named top level object. + + + The name of the property the value of which is being resolved. + + + The callback that will actually do the donkey work of resolving + this managed collection. + + A fully resolved collection. + + + + Merges the current value set with that of the supplied object. + + The supplied object is considered the parent, and values in the + callee's value set must override those of the supplied object. + + The parent object to merge with + The result of the merge operation + If the supplied parent is null + If merging is not enabled for this instance, + (i.e. MergeEnabled equals false. + + + + Gets or sets the unresolved name for the + of the keys of this managed dictionary. + + The unresolved name for the type of the keys of this managed dictionary. + + + + Gets or sets the unresolved name for the + of the values of this managed dictionary. + + The unresolved name for the type of the values of this managed dictionary. + + + + Gets a value indicating whether this instance is merge enabled for this instance + + + true if this instance is merge enabled; otherwise, false. + + + + + Tag subclass used to hold a list of managed elements. + + Rod Johnson + Rick Evans (.NET) + + + + Initializes a new instance of the ManagedList class that is empty and has the default initial capacity. + + + + + Initializes a new instance of the ManagedList class that is empty and has the specified initial capacity. + + The number of elements that the new list can initially store. is less than zero. + + + + Resolves this managed collection at runtime. + + + The name of the top level object that is having the value of one of it's + collection properties resolved. + + + The definition of the named top level object. + + + The name of the property the value of which is being resolved. + + + The callback that will actually do the donkey work of resolving + this managed collection. + + A fully resolved collection. + + + + Merges the current value set with that of the supplied object. + + The supplied object is considered the parent, and values in the + callee's value set must override those of the supplied object. + + The parent object to merge with + The result of the merge operation + If the supplied parent is null + If merging is not enabled for this instance, + (i.e. MergeEnabled equals false. + + + + Gets or sets the unresolved name for the + of the elements of this managed list. + + The unresolved name for the type of the elements of this managed list. + + + + Gets a value indicating whether this instance is merge enabled for this instance + + + true if this instance is merge enabled; otherwise, false. + + + + + Tag class which represent a Spring-managed instance that + supports merging of parent/child definitions. + + + + + Initializes a new instance of the class that is empty, has the default initial capacity and uses the default case-insensitive hash code provider and the default case-insensitive comparer. + + + + + Initializes a new instance of the class that is empty, has the specified initial capacity and uses the default case-insensitive hash code provider and the default case-insensitive comparer. + + The initial number of entries that the can contain. is less than zero. + + + + Merges the current value set with that of the supplied object. + + The supplied object is considered the parent, and values in the + callee's value set must override those of the supplied object. + + The parent object to merge with + The result of the merge operation + If the supplied parent is null + If merging is not enabled for this instance, + (i.e. MergeEnabled equals false. + + + + Gets a value indicating whether this instance is merge enabled for this instance + + + true if this instance is merge enabled; otherwise, false. + + + + + Tag subclass used to hold a set of managed elements. + + Juergen Hoeller + Rick Evans (.NET) + + + + Creates a new set instance based on either a list or a hash table, + depending on which will be more efficient based on the data-set + size. + + + + + Initializes a new instance of the class with a given capacity + + The size. + + + + Resolves this managed collection at runtime. + + + The name of the top level object that is having the value of one of it's + collection properties resolved. + + + The definition of the named top level object. + + + The name of the property the value of which is being resolved. + + + The callback that will actually do the donkey work of resolving + this managed collection. + + A fully resolved collection. + + + + Merges the current value set with that of the supplied object. + + The supplied object is considered the parent, and values in the + callee's value set must override those of the supplied object. + + The parent object to merge with + The result of the merge operation + If the supplied parent is null + If merging is not enabled for this instance, + (i.e. MergeEnabled equals false. + + + + Gets or sets the unresolved name for the + of the elements of this managed set. + + The unresolved name for the type of the elements of this managed set. + + + + Gets a value indicating whether this instance is merge enabled for this instance + + + true if this instance is merge enabled; otherwise, false. + + + + + An that returns a value + that is the result of a or instance method invocation. + + +

+ Note that this class generally is expected to be used for accessing factory methods, + and as such defaults to operating in singleton mode. The first request to + + by the owning object factory will cause a method invocation, the return + value of which will be cached for all subsequent requests. The + property may be set to + , to cause this factory to invoke the target method each + time it is asked for an object. +

+

+ A target method may be specified by setting the + property to a string representing + the method name, with specifying + the that the method is defined on. + Alternatively, a target instance method may be specified, by setting the + property as the target object, and + the property as the name of the + method to call on that target object. Arguments for the method invocation may be + specified by setting the property. +

+

+ Another (esoteric) use case for this factory object is when one needs to call a method + that doesn't return any value (for example, a class method to + force some sort of initialization to happen)... this use case is not supported by + factory-methods, since a return value is needed to become the object. +

+

+ + This class depends on the + + method being called after all properties have been set, as per the + contract. If you are + using this class outside of a Spring.NET IoC container, you must call one of either + or + yourself to ready the object's internal + state, or you will get a nasty . + +

+
+ +

+ The following example uses an instance of this class to call a + factory method... +

+ + + + + + + + 1st + 2nd + and 3rd arguments + + + + +

+ The following example is similar to the preceding example; the only pertinent difference is the fact that + a number of different objects are passed as arguments, demonstrating that not only simple value types + are valid as elements of the argument list... +

+ + + + + + + + + + + 1st + + + + + + + http://www.springframework.net/ + + + + + +

+ Named parameters are also supported... this next example yields the same results as + the preceding example (that did not use named arguments). +

+ + + + + + + + + + 1st + and 3rd arguments + 2nd + + + + +

+ Similarly, the following example uses an instance of this class to call an instance method... +

+ + + + + + + + + +

+ The above example could also have been written using an anonymous inner object definition... if the + object on which the method is to be invoked is not going to be used outside of the factory object + definition, then this is the preferred idiom because it limits the scope of the object on which the + method is to be invoked to the surrounding factory object. +

+ + + + + + + + + + Colin Sampaleanu + Juergen Hoeller + Rick Evans (.NET) + Simon White (.NET) + + + + + + Specialisation of the class that tries + to convert the given arguments for the actual target method via an + appropriate implementation. + + Juergen Hoeller + Rick Evans + + + + + Helper class allowing one to declaratively specify a method call for later invocation. + + +

+ Typically not used directly but via its subclasses such as + . +

+

+ Usage: specify either the and + or the + and + properties respectively, and + (optionally) any arguments to the method. Then call the + method to prepare the invoker. + Once prepared, the invoker can be invoked any number of times. +

+
+ +

+ The following example uses the class to invoke the + ToString() method on the Foo class using a mixture of both named and unnamed + arguments. +

+ + public class Foo + { + public string ToString(string name, int age, string address) + { + return string.Format("{0}, {1} years old, {2}", name, age, address); + } + + public static void Main() + { + Foo foo = new Foo(); + MethodInvoker invoker = new MethodInvoker(); + invoker.Arguments = new object [] {"Kaneda", "18 Kaosu Gardens, Nakatani Drive, Okinanawa"}; + invoker.AddNamedArgument("age", 29); + invoker.Prepare(); + // at this point, the arguments that will be passed to the method invocation + // will have been resolved into the following ordered array : {"Kaneda", 29, "18 Kaosu Gardens, Nakatani Drive, Okinanawa"} + string details = (string) invoker.Invoke(); + Console.WriteLine (details); + // will print out 'Kaneda, 29 years old, 18 Kaosu Gardens, Nakatani Drive, Okinanawa' + } + } + +
+ Colin Sampaleanu + Juergen Hoeller + Simon White (.NET) +
+ + + The used to search for + the method to be invoked. + + + + + The value returned from the invocation of a method that returns void. + + + + + The method that will be invoked. + + + + + Creates a new instance of the class. + + + + + Prepare the specified method. + + +

+ The method can be invoked any number of times afterwards. +

+
+ + If all required properties are not set, or a matching argument could not be found + for a named argument (typically down to a typo). + + + If the specified method could not be found. + +
+ + + Searches for and returns the method that is to be invoked. + + + The return value of this method call will subsequently be returned from the + . + + The method that is to be invoked. + + If no method could be found. + + + If more than one method was found. + + + + + Adds the named argument to this instances mapping of argument names to argument values. + + + The name of an argument on the method that is to be invoked. + + + The value of the named argument on the method that is to be invoked. + + + + + Returns the prepared object that + will be invoked. + + +

+ A possible use case is to determine the return of the method. +

+
+ + The prepared object that + will be invoked. + +
+ + + Invoke the specified method. + + +

+ The invoker needs to have been prepared beforehand (via a call to the + method). +

+
+ + The object returned by the method invocation, or + if the method returns void. + + + If at least one of the arguments passed to this + was incompatible with the signature of the invoked method. + +
+ + + The target on which to call the target method. + + +

+ Only necessary when the target method is ; + else, a target object needs to be specified. +

+
+
+ + + The target object on which to call the target method. + + +

+ Only necessary when the target method is not ; + else, a target class is sufficient. +

+
+
+ + + The name of the method to be invoked. + + +

+ Refers to either a method + or a non- method, depending on + whether or not a target object has been set. +

+
+ +
+ + + Arguments for the method invocation. + + +

+ Ordering is significant... the order of the arguments in this + property must match the ordering of the various parameters on the target + method. There does however exist a small possibility for confusion when + the arguments in this property are supplied in addition to one or more named + arguments. In this case, each named argument is slotted into the index position + corresponding to the named argument... once once all named arguments have been + resolved, the arguments in this property are slotted into any remaining (empty) + slots in the method parameter list (see the example in the overview of the + class if this is not clear). +

+

+ If this property is not set, or the value passed to the setter invocation + is or a zero-length array, a method with no (un-named) arguments is assumed. +

+
+ +
+ + + The resolved arguments for the method invocation. + + + + This property is not set until the target method has been resolved via a call to the + method). It is a combination of the + named and plain vanilla arguments properties, and it is this object array that + will actually be passed to the invocation of the target method. + +

+ Setting the value of this property to results in basically clearing out any + previously prepared arguments... another call to the + method will then be required to prepare the arguments again (or the prepared arguments + can be set explicitly if so desired). +

+
+ + +
+ + + Named arguments for the method invocation. + + +

+ The keys of this dictionary are the () names of the + method arguments, and the () values are the actual + argument values themselves. +

+

+ If this property is not set, or the value passed to the setter invocation + is a reference, a method with no named arguments is assumed. +

+
+ +
+ + + Creates a new instance of the + class. + + + + + Prepare the specified method. + + +

+ The method can be invoked any number of times afterwards. +

+
+ + If all required properties are not set. + + + If the specified method could not be found. + +
+ + + Register the given custom + for all properties of the given . + + + The of property. + + + The to register. + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + +

+ Returns the return value of the method that is to be invoked. +

+

+ Will return the same value each time if the + + property value is . +

+
+ + An instance (possibly shared or independent) of the object managed by + this factory. + + +
+ + + Prepares this method invoker. + + + If all required properties are not set. + + + If the specified method could not be found. + + + + + + If a singleton should be created, or a new object on each request. + Defaults to . + + + + + Return the return value of the method + that this factory invokes, or if not + known in advance. + + +

+ If the return value of the method that this factory is to invoke is + , then the + will be returned (in accordance with the + contract that + treats a value as a configuration error). +

+
+ +
+ + + Holder for an with + name and aliases. + + +

+ Recognized by + + for inner object definitions. Registered by + , + which also uses it as general holder for a parsed object definition. +

+

+ Can also be used for programmatic registration of inner object + definitions. If you don't care about the functionality offered by the + interface and the like, + registering + or is good enough. +

+
+ Juergen Hoeller + Simon White (.NET) +
+ + + Creates a new instance of the + class. + + + The object definition to be held by this instance. + + + The name of the object definition. + + + + + Creates a new instance of the + class. + + + The object definition to be held by this instance. + + The name of the object. + + Any aliases for the supplied + + + + + The held by this + instance. + + + + + The name of the object definition. + + + + + Any aliases for the object definition. + + +

+ Guaranteed to never return ; if the associated + + does not have any aliases associated with it, then an empty + array will be returned. +

+
+
+ + + Visitor class for traversing objects, in particular + the property values and constructor arguments contained in them resolving + object metadata values. + + + Used by and + to parse all string values contained in a ObjectDefinition, resolving any placeholders found. + + Mark Pollack + + + + Initializes a new instance of the class. + + The handler to be called for resolving variables contained in a string. + + + + Initializes a new instance of the class + for subclassing + + Subclasses should override the ResolveStringValue method + + + + Traverse the given ObjectDefinition object and the MutablePropertyValues + and ConstructorArgumentValues contained in them. + + The object definition to traverse. + + + + Visits the ObjectDefinition property ObjectTypeName, replacing string values using + the specified IVariableSource. + + The object definition. + + + + Visits the property values of the ObjectDefinition, replacing string values + using the specified IVariableSource. + + The object definition. + + + + Visits the indexed constructor argument values, replacing string values using the + specified IVariableSource. + + The indexed argument values. + + + + Visits the named constructor argument values, replacing string values using the + specified IVariableSource. + + The named argument values. + + + + Visits the generic constructor argument values, replacing string values using + the specified IVariableSource. + + The genreic argument values. + + + + Configures the constructor argument ValueHolder. + + The vconstructor alue holder. + + + + Resolves the given value taken from an object definition according to its type + + the value to resolve + the resolved value + + + + Visits the ManagedList property ElementTypeName and + calls for list element. + + + + + Visits the ManagedSet property ElementTypeName and + calls for list element. + + + + + Visits the ManagedSet properties KeyTypeName and ValueTypeName and + calls for dictionary's value element. + + + + + Visits the elements of a NameValueCollection and calls + for value of each element. + + + + + calls the to resolve any variables contained in the raw string. + + the raw string value containing variable placeholders to be resolved + If no has been configured. + the resolved string, having variables being replaced, if any + + + + Returns a value that is an + that + returns an object from an + . + + +

+ The primary motivation of this class is to avoid having a client object + directly calling the + + method to get a prototype object out of an + , which would be a + violation of the inversion of control principle. With the use of this + class, the client object can be fed an + as a property + that directly returns one target prototype object. +

+

+ The object referred to by the value of the + + property does not have to be a prototype object, but there is little + to no point in using this class in conjunction with a singleton object. +

+
+ +

+ The following XML configuration snippet illustrates the use of this + class... +

+ + + + + + + + + + + + + + + + Colin Sampaleanu + Simon White (.NET) + + + + Interface to be implemented by objects that wish to be aware of their owning + . + + +

+ For example, objects can look up collaborating objects via the factory. +

+

+ Note that most objects will choose to receive references to collaborating + objects via respective properties and / or an appropriate constructor. +

+

+ For a list of all object lifecycle methods, see the + API documentation. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Returns an instance of the object factory. + + The object factory. + + + + Invoked by an + after it has set all supplied object properties. + + + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + + + + + Sets the name of the target object. + + + + + The target factory that will be used to perform the lookup + of the object referred to by the + property. + + + The owning + (will never be ). + + + In case of initialization errors. + + + + + + The of object created by this factory. + + + + + Interface defining a factory which can return an object instance + (possibly shared or independent) when invoked. + + + This interface is typically used to encapsulate a generic factory + which returns a new instance (prototype) on each invocation. + It is similar to the , but + implementations of the aforementioned interface are normally meant to be defined + as instances by the user in an , + while implementations of this class are normally meant to be fed as a property to + other objects; as such, the + method + has different exception handling behavior. + + Colin Sampaleanu + Simon White (.NET) + + + + Return an instance (possibly shared or independent) + of the object managed by this factory. + + + An instance of the object (should never be ). + + + + + Creates a new instance of the GenericObjectFactory class. + + + The enclosing + . + + + + + Returns the object created by the enclosed object factory. + + The created object. + + + + An implementation + that exposes an arbitrary target object under a different name. + + +

+ Usually, the target object will reside in a different object + definition file, using this + to link it in + and expose it under a different name. Effectively, this corresponds + to an alias for the target object. +

+ + For XML based object definition files, a <alias> + tag is available that effectively achieves the same. + +
+ Juergen Hoeller + Rick Evans (.NET) + +
+ + + Initialize a new default instance + + + + + Initialize this instance with the predefined and . + + + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + + + The name of the target object. + + +

+ The target object may potentially be defined in a different object + definition file. +

+
+ The name of the target object. +
+ + + Return the type of object that this + creates, or + if not known in advance. + + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + + Callback that supplies the owning factory to an object instance. + + + The owning + (may not be ). The object can immediately + call methods on the factory. + + + In case of initialization errors. + + + + + + + Erich Eichinger + + + + Role hint indicating that a is a major part of the application. Typically corresponds to a user-defined object. + + + + + Role hint indicating that a is a supporting + part of some larger configuration, typically an outer ComponentDefinition + SUPPORT objects are considered important enough to be aware + of when looking more closely at a particular ComponentDefinition, + but not when looking at the overall configuration of an application. + + + + + Role hint indicating that a is providing an + entirely background role and has no relevance to the end-user. This hint is + used when registering objects that are completely part of the internal workings + of a ComponentDefinition. + + + + + Implementation of that + resolves variable name against Java-style property file. + + + Aleksandar Seovic + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + The variable value if able to resolve, null otherwise. + + + + + Initializes properties based on the specified + property file locations. + + + + + Gets or sets the locations of the property files + to read properties from. + + + The locations of the property files + to read properties from. + + + + + Convinience property. Gets or sets a single location + to read properties from. + + + A location to read properties from. + + + + + Sets a value indicating whether to ignore resource locations that do not exist. This will call + the Exists property. + + + true if one should ignore missing resources; otherwise, false. + + + + + Overrides default values in one or more object definitions. + + +

+ Instances of this class override already existing values, and is + thus best suited to replacing defaults. If you need to replace + placeholder values, consider using the + + class instead. +

+

+ In contrast to the + + class, the original object definition can have default + values or no values at all for such object properties. If an overriding + configuration file does not have an entry for a certain object property, + the default object value is left as is. Also note that it is not + immediately obvious to discern which object definitions will be mutated by + one or more + s + simply by looking at the object configuration. +

+

+ Each line in a referenced configuration file is expected to take the + following form... +

+ + + +

+ The name.property key refers to the object name and the + property that is to be overridden; and the value is the overridding + value that will be inserted into the appropriate object definition's + named property. +

+

+ Please note that in the case of multiple + s + that define different values for the same object definition value, the + last overridden value will win (due to the fact that the values + supplied by previous + s + will be overridden). +

+
+ +

+ The following XML context definition defines an object that has a number + of properties, all of which have default values... +

+ + + + + + + + +

+ What follows is a .NET config file snippet for the above example (assuming + the need to override one of the default values)... +

+ + + + + + +
+ Juergen Hoeller + Simon White (.NET) + + + +
+ + + Allows for the configuration of individual object property values from + a .NET .config file. + + +

+ Useful for custom .NET .config files targetted at system administrators + that override object properties configured in the application context. +

+

+ Two concrete implementations are provided in the Spring.NET core library: + + + + + for <add key="placeholderKey" value="..."/> style + overriding (pushing values from a .NET .config file into object + definitions). + + + + + + for replacing "${...}" placeholders (pulling values from a .NET .config + file into object definitions). + + + +

+

+ Please refer to the API documentation for the concrete implementations + listed above for example usage. +

+
+ Juergen Hoeller + Simon White (.NET) + + +
+ + + The default configuration section name to use if none is explictly supplied. + + + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Modify the application context's internal object factory after its + standard initialization. + + + The object factory used by the application context. + + + In case of errors. + + + + + + Loads properties from the configuration sections + specified in into . + + The instance to be filled with properties. + + + + Apply the given properties to the supplied + . + + + The + used by the application context. + + The properties to apply. + + If an error occured. + + + + + Validates the supplied . + + +

+ Basically, if external locations are specified, ensure that either + one or a like number of config sections are also specified. +

+
+ + The to be validated. + +
+ + + Simply initializes the supplied + collection with this instances default + (if any). + + + The collection to be so initialized. + + + + + The policy for resolving conflicting property overrides from + several resources. + + +

+ When merging conflicting property overrides from several resources, + should append an override with the same key be appended to the + current value, or should the property override from the last resource + processed override previous values? +

+

+ The default value is ; i.e. a property + override from the last resource to be processed overrides previous + values. +

+
+ + if the property override from the last resource + processed overrides previous values. + +
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + The order value. + + + + + The default properties to be applied. + + +

+ These are to be considered defaults, to be overridden by values + loaded from other resources. +

+
+
+ + + The location of the .NET .config file that contains the property + overrides that are to be applied. + + + + + The locations of the .NET .config files containing the property + overrides that are to be applied. + + + + + The configuration sections to look for within the .config files. + + + + + + + Should a failure to find a .config file be ignored? + + +

+ is only appropriate if the .config file is + completely optional. The default is . +

+
+ + if a failure to find a .config file is to be + ignored. + +
+ + + Apply the given properties to the supplied + . + + + The + used by the application context. + + The properties to apply. + + If an error occured. + + + + + Process the given key as 'name.property' entry. + + + The object factory containing the object definitions that are to be + processed. + + The key. + The value. + + If an error occurs. + + + If the property was not well formed (i.e. not in the format "name.property"). + + + + + implementation that + evaluates a property path on a given target object. + + +

+ The target object can be specified directly or via an object name (see + example below). +

+

+ Please note that the + is an implementation, and as such has + to comply with the contract of the + interface; more specifically, this means that the end result of the property lookup path + evaluation cannot be ( + implementations are not permitted to return ). If the resut of a + property lookup path evaluates to , an exception will be thrown. +

+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + Juergen Hoeller + Rick Evans (.NET) + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + + + The target object that the property path lookup is to be applied to. + + +

+ This would most likely be an inner object, but can of course be + any object reference. +

+
+ + The target object that the property path lookup is to be applied to. + + +
+ + + The (object) name of the target object that the property path lookup + is to be applied to. + + +

+ Please note that any leading or trailing whitespace will be + trimmed from this name prior to resolution. The implication of this is that + one cannot use the + class in conjunction with object names that start or end with whitespace. +

+
+ + The (object) name of the target object that the property path lookup + is to be applied to. + + +
+ + + The property (lookup) path to be applied to the target object. + + +

+ Please note that any leading or trailing whitespace will be + trimmed from this path prior to resolution. Whitespace is not a valid + identifier for property names (in part or whole) in CLS-based languages, + so this is a not unreasonable action. Please also note that whitespace + that is embedded within the property path will be left as-is (which may + or may not result in an error being thrown, depending on the context of + the whitespace). +

+
+ +

+ Examples of such property lookup paths can be seen below; note that + property lookup paths can be nested to an arbitrary level. +

+ + name.length + accountManager.account['the key'].name + accounts[0].name + +
+ + The property (lookup) path to be applied to the target object. + +
+ + + The 'expected' of the result from evaluating the + property path. + + +

+ This is not necessary for directly specified target objects, or + singleton target objects, where the can + be determined via reflection. Just specify this in case of a + prototype target, provided that you need matching by type (for + example, for autowiring). +

+

+ It is permissable to set the value of this property to + (which in any case is the default value). +

+
+ + The 'expected' of the result from evaluating the + property path. + +
+ + + Return the of object that this + creates, or + if not known in advance. + + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + + Set the name of the object in the object factory that created this object. + + +

+ The object name of this + + will be interpreted as "objectName.property" pattern, if neither the + + + have been supplied (set). +

+

+ This allows for concise object definitions with just an id or name. +

+
+ + The name of the object in the factory. + +
+ + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + In case of initialization errors. + + + + + Resolves placeholder values in one or more object definitions. + + +

+ The default placeholder syntax follows the NAnt style: ${...}. + Instances of this class can be configured in the same way as any other + object in a Spring.NET container, and so custom placeholder prefix + and suffix values can be set via the + and properties. +

+ +

+ The following example XML context definition defines an object that has + a number of placeholders. The placeholders can easily be distinguished + by the presence of the ${} characters. +

+ + + + + + + + +

+ The associated XML configuration file for the above example containing the + values for the placeholders would contain a snippet such as .. +

+ + + + + + + + +

+ The preceding XML snippet listing the various property keys and their + associated values needs to be inserted into the .NET config file of + your application (or Web.config file for your ASP.NET web application, + as the case may be), like so... +

+ + + + + + + + +
+

+ + checks simple property values, lists, dictionaries, sets, constructor + values, object type name, and object names in + runtime object references ( + ). + Furthermore, placeholder values can also cross-reference other + placeholders, in the manner of the following example where the + rootPath property is cross-referenced by the subPath + property. +

+ + + + + + + + +

+ In contrast to the + + class, this configurer only permits the replacement of explicit + placeholders in object definitions. Therefore, the original definition + cannot specify any default values for its object properties, and the + placeholder configuration file is expected to contain an entry for each + defined placeholder. That is, if an object definition contains a + placeholder ${foo}, there should be an associated + <add key="foo" value="..."/> entry in the + referenced placeholder configuration file. Default property values + can be defined via the inherited + + collection to overcome any perceived limitation of this feature. +

+

+ If a configurer cannot resolve a placeholder, and the value of the + + property is currently set to , an + + will be thrown. If you want to resolve properties from multiple configuration + resources, simply specify multiple resources via the + + property. Finally, please note that you can also define multiple + + instances, each with their own custom placeholder syntax. +

+
+ Juergen Hoeller + Simon White (.NET) + + + +
+ + + The default placeholder prefix. + + + + + The default placeholder suffix. + + + + + Initializes the new instance + + + + + Apply the given properties to the supplied + . + + + The + used by the application context. + + The properties to apply. + + If an error occured. + + + + + Parse values recursively to be able to resolve cross-references between + placeholder values. + + + The map of constructor arguments / property values. + + The string to be resolved. + The placeholders that have already been visited + during the current resolution attempt (used to detect circular references + between placeholders). Only non-null if we're parsing a nested placeholder. + + If an error occurs. + + The resolved string. + + + + Resolve the given placeholder using the given name value collection, + performing an environment variables check according to the given mode. + + +

+ The default implementation delegates to + + before/afer the environment variable check. Subclasses can override + this for custom resolution strategies, including customized points + for the environment properties check. +

+
+ The placeholder to resolve + + The merged name value collection of this configurer. + + The environment variable mode. + + The resolved value or if none. + + +
+ + + Resolve the given placeholder using the given name value collection. + + +

+ This (the default) implementation simply looks up the value of the + supplied key. +

+

+ Subclasses can override this for customized placeholder-to-key + mappings or custom resolution strategies, possibly just using the + given name value collection as fallback. +

+
+ The placeholder to resolve. + + The merged name value collection of this configurer. + + The resolved value. +
+ + + The placeholder prefix (the default is ${). + + + + + + The placeholder suffix (the default is }) + + + + + + Indicates whether unresolved placeholders should be ignored. + + + + + Controls how environment variables will be used to + replace property placeholders. + + +

+ See the overview of the + + enumeration for the available options. +

+
+
+ + + implementation that + retrieves a or non-static public property value. + + +

+ Typically used for retrieving public property values. +

+
+ Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + + + + Invoked by an + after it has set all object properties supplied + (and satisfied + and ApplicationContextAware). + + + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + + + + Template method that subclasses must override to construct the object + returned by this factory. + + + If an exception occured during object creation. + + The object returned by this factory. + + + + The of the static property + to be retrieved. + + + + + Arguments for the property invocation. + + +

+ If this property is not set, or the value passed to the setter invocation + is a null or zero-length array, a property with no arguments is assumed. +

+
+
+ + + The name of the property the value of which is to be retrieved. + + +

+ Refers to either a property or a non-static property, + depending on a target object being set. +

+
+
+ + + The object instance on which the property is defined. + + + + + The on which the property is defined. + + + + + Return the type of object that this + creates, or + if not known in advance. + + + + + Implementation of that + resolves variable name against registry key. + + Aleksandar Seovic + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves variable value for the specified variable name. + + + The name of the variable to resolve. + + + This implementation resolves REG_SZ as well as REG_MULTI_SZ values. In case of a REG_MULTI_SZ value, + strings are concatenated to a comma-separated list following + + + The variable value if able to resolve, null otherwise. + + + + + Gets or sets the registry key to obtain variable values from. + + + The registry key to obtain variable values from. + + + + + + implementation that allows for convenient registration of custom + IResource implementations. + + +

+ Because the + class implements the + + interface, instances of this class that have been exposed in the + scope of an + will + automatically be picked up by the application context and made + available to the IoC container whenever resolution of IResources is required. +

+
+ Mark Pollack + + +
+ + + Registers custom IResource implementations. The supplied + is not used since IResourse implementations + are registered with a global + + + The object factory. + + + In case of errors. + + + + + The IResource implementations, i.e. resource handlers, to register. + + +

+ The has the + contains the resource protocol name as the key and type as the value. + The key name can either be a string or an object, in which case + ToString() will be used to obtain the string name. + The value can be the fully qualified name of the IResource + implementation, a string, or + an actual of the IResource class + +

+
+
+ + + A convenience class to create a + given the resource base + name and assembly name. + + +

+ This is currently the preferred way of injecting resources into view + tier components (such as Windows Forms GUIs and ASP.NET ASPX pages). + A GUI component (typically a Windows Form) is injected with + an instance, and can + then proceed to use the various GetXxx() methods on the + to retrieve images, + strings, custom resources, etc. +

+
+ Mark Pollack + + + +
+ + + Creates a . + + + If an exception occured during object creation. + + The object returned by this factory. + + + + + + Invoked by an + after it has set all object properties supplied + (and satisfied the + + and + interfaces). + + + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + + + + + The root name of the resources. + + +

+ For example, the root name for the resource file named + "MyResource.en-US.resources" is "MyResource". +

+ + The namespace is also prefixed before the resource file name. + +
+
+ + + The string representation of the assembly that contains the resource. + + + + + The . + + + + + Immutable placeholder class used for the value of a + object when it's a reference + to another object in this factory to be resolved at runtime. + + Rod Johnson + Rick Evans (.NET) + + + + Creates a new instance of the + + class. + + +

+ This does not mark this object as being a reference to + another object in any parent factory. +

+
+ The name of the target object. +
+ + + Creates a new instance of the + + class. + + +

+ This variant constructor allows a client to specifiy whether or not + this object is a reference to another object in a parent factory. +

+
+ The name of the target object. + + Whether this object is an explicit reference to an object in a + parent factory. + +
+ + + Returns a string representation of this instance. + + A string representation of this instance. + + + + Return the target object name. + + + + + Is this is an explicit reference to an object in the parent + factory? + + + if this is an explicit reference to an + object in the parent factory. + + + + + Simple factory object for shared instances. + + Juergen Hoeller + Simon White (.NET) + + + + Constructs a new instance of the target set. + + The new instance. + + + + Set the source . + + +

+ This value will be used to populate the + returned by this factory. +

+
+
+ + + Set the of the + implementation to use. + + +

+ The default is the . +

+
+
+ + + The of objects created by this factory. + + + Always returns the . + + + + + Configure all ISharedStateAware objects, delegating concrete handling to the list of . + + + + + Creates a new empty instance. + + + + + Creates a new preconfigured instance. + + + priority value affecting order of invocation of this processor. See interface. + + + + Iterates over configured list of s until + the first provider is found that
+ a) true == provider.CanProvideState( instance, name )
+ b) null != provider.GetSharedState( instance, name )
+
+
+ + + A NoOp for this processor + + + The new object instance. + + + The name of the object. + + + the original . + + + + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+ + + Get/Set the (already ordererd!) list of instances. + + + If this list is not set, the containing object factory will automatically + be scanned for instances. + + + + + Implementation of that + resolves variable name against special folders (as defined by + enumeration). + + Aleksandar Seovic + + + + Before requesting a variable resolution, a client should + ask, whether the source can resolve a particular variable name. + + the name of the variable to resolve + true if the variable can be resolved, false otherwise + + + + Resolves specified special folder to its full path. + + + The name of the special folder to resolve. Should be one of the values + defined by the enumeration. + + + The folder path if able to resolve, null otherwise. + + + + + + implementation that allows for convenient registration of custom + type aliases. + + + Type aliases can be used instead of fully qualified type names anywhere + a type name is expected in a Spring.NET configuration file. +

+ Because the + class implements the + + interface, instances of this class that have been exposed in the + scope of an + will + automatically be picked up by the application context and made + available to the IoC container whenever resolution of type aliases is required. +

+
+ Mark Pollack + + +
+ + + Registers any type aliases. The supplied + is not used since type aliases + are registered with a global + + + The object factory. + + + In case of errors. + + + + + The type aliases to register. + + +

+ The has the + contains the alias name as the key and type as the value. + The key name can either be a string or an object, in which case + ToString() will be used to obtain the string name. + the value can be the fully qualified name of the type as a string or + an actual of the class that + being aliased. +

+
+
+ + + Holder for a typed value. + + +

+ Can be added to object definitions to explicitly specify + a target type for a value, + for example for collection + elements. +

+

+ This holder just stores the value and the target + . The actual conversion will be performed by + the surrounding object factory. +

+
+ Juergen Hoeller + Rick Evans (.NET) + Bruno Baia (.NET) +
+ + + Creates a new instance of the + + class. + + + + + Initializes a new instance of the class. + + The value. + + + + Creates a new instance of the + + class. + + + The value that is to be converted. + + + The to convert to. + + + If the supplied is + . + + + + + Creates a new instance of the + + class. + + + The value that is to be converted. + + + The unresolved type to convert to. + + + If the supplied is a + or an empty string. + + + + + Determine the type to convert to, resolving it from a specified type name if necessary. + + The resolved type to convert to. + + + + The value that is to be converted. + + +

+ Obviously if the + + is the , no conversion + will actually be performed. +

+
+
+ + + The to convert to. + + + If the setter is supplied with a value. + + + + + The unresolved type to convert to. + + + If the setter is supplied with a value or an empty string. + + + + + Gets a value indicating whether this instance has target type. + + + true if this instance has target type; otherwise, false. + + + + + Provides methods for type-safe accessing s. + + Erich Eichinger + + + + Initialize a new instance of an + + The underlying to read values from. + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The expected format of the variable's value + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The expected format of the variable's value + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + A that contains the value of the specified variable + or , if returns null. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + A that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns an of 's type that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + An of 's type that contains the value of the specified variable + or , if returns null. + + + + + Returns an of 's type that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns null. + + If false, suppresses exceptions if the result + of cannot be parsed + and returns instead. + + An of 's type that contains the value of the specified variable + or , if cannot be parsed. + + + + + Returns a that contains the value of the specified variable. + + The name of the variable to be read. + The value to be returned if returns or . + + A that contains the value of the specified variable + or , if returns null. + + + + + Resolves placeholder values in one or more object definitions + + + The placeholder syntax follows the NAnt style: ${...}. + Placeholders values are resolved against a list of + s. In case of multiple definitions + for the same property placeholder name, the first one in the + list is used. + Variable substitution is performed on simple property values, + lists, dictionaries, sets, constructor + values, object type name, and object names in + runtime object references ( + ). + Furthermore, placeholder values can also cross-reference other + placeholders, in the manner of the following example where the + rootPath property is cross-referenced by the subPath + property. + + + + + + + + + + If a configurer cannot resolve a placeholder, and the value of the + + property is currently set to , an + + will be thrown. + + Mark Pollack + + + + The default placeholder prefix. + + + + + The default placeholder suffix. + + + + + Create a new instance without any variable sources + + + + + Create a new instance and initialize with the given variable source + + + + + + Create a new instance and initialize with the given list of variable sources + + + + + Modify the application context's internal object factory after its + standard initialization. + + The object factory used by the application context. + +

+ All object definitions will have been loaded, but no objects will have + been instantiated yet. This allows for overriding or adding properties + even to eager-initializing objects. +

+
+ + In case of errors. + +
+ + + Apply the property replacement using the specified s for all + object in the supplied + . + + + The + used by the application context. + + + If an error occured. + + + + + Sets the list of s that will be used to resolve placeholder names. + + A list of s. + + + + Sets that will be used to resolve placeholder names. + + A instance. + + + + The placeholder prefix (the default is ${). + + + + + + The placeholder suffix (the default is }) + + + + + + Indicates whether unresolved placeholders should be ignored. + + + + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + The order value. + + + + + Initializes a new instance of the Location class. + + + + + + + Initializes a new instance of the Location class. + + + + + + Thrown when an + encounters an internal error, and its definitions are invalid. + + +

+ An example of a situation when this exception would be thrown is + in the case of an XML document containing object definitions being + malformed. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + Creates a new instance of the ObjectDefinitionStoreException class. + + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + A message about the exception. + + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + The description of the resource that the object definition came from + + + The name of the object that triggered the exception. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + + The description of the resource that the object definition came from + + The detail message (used as exception message as-is) + The root cause. (may be null + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + The resource location (e.g. an XML object definition file) associated + with the offending object definition. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + The resource location (e.g. an XML object definition file) associated + with the offending object definition. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + The description of the resource that the object definition came from + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionStoreException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The description of the resource associated with the object + + + + + The name of the object that trigger the exception. + + + + + The name of the object that triggered the exception (if any). + + + + + The description of the resource associated with the object (if any). + + + + + Initializes a new instance of the ObjectDefinitionParsingException class. + + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + A message about the exception. + + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + The description of the resource that the object definition came from + + + The name of the object that triggered the exception. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + + The description of the resource that the object definition came from + + The detail message (used as exception message as-is) + The root cause. (may be null + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + The resource location (e.g. an XML object definition file) associated + with the offending object definition. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + The resource location (e.g. an XML object definition file) associated + with the offending object definition. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + The description of the resource that the object definition came from + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionParsingException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The message. + The location. + + + + Initializes a new instance of the Problem class. + + + + + + + + Context that gets passed along an object definition reading process, + encapsulating all relevant configuraiton as well as state. + + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The resource. + + + + Gets the resource. + + The resource. + + + + Abstract superclass + that implements default object creation. + + +

+ Provides object creation, initialization and wiring, supporting + autowiring and constructor resolution. Handles runtime object + references, managed collections, and object destruction. +

+

+ The main template method to be implemented by subclasses is + , + used for autowiring by type. Note that this class does not implement object + definition registry capabilities + ( + does). +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + Abstract superclass for + implementations. + + +

+ This class provides singleton / prototype determination, singleton caching, + object definition aliasing, + handling, and object definition merging for child object definitions. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + Marker object to be temporarily registered in the singleton cache, + while instantiating an object (in order to be able to detect circular references). + + + + + Used as value in hashtable that keeps track of singleton names currently in the + process of being created. Would not be necessary if we created a case insensitive implementation of + ISet. + + + + + The instance for this class. + + + + + Cache of singleton objects created by s: FactoryObject name -> product + + + + + Creates a new instance of the + class. + + +

+ This constructor implicitly creates an + + that treats the names of objects in this factory in a case-sensitive fashion. +

+

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+ + if the names of objects in this factory are to be treated in a + case-sensitive fashion. + +
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+ + if the names of objects in this factory are to be treated in a + case-sensitive fashion. + + + Any parent object factory; may be . + +
+ + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + + + Apply the property values of the object definition with the supplied + to the supplied . + + +

+ The object definition can either define a fully self-contained object, + reusing it's property values, or just property values meant to be used + for existing object instances. +

+
+ + The existing object that the property values for the named object will + be applied to. + + + The name of the object definition associated with the property values that are + to be applied. + + + In case of errors. + +
+ + + Apply the property values of the object definition with the supplied + to the supplied . + + +

+ The object definition can either define a fully self-contained object, + reusing it's property values, or just property values meant to be used + for existing object instances. +

+
+ + The existing object that the property values for the named object will + be applied to. + + + The name of the object definition associated with the property values that are + to be applied. + + + An object definition that should be used to apply property values. + + + In case of errors. + +
+ + + Create an object instance for the given object definition. + + The name of the object. + + The object definition for the object that is to be instantiated. + + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. It is invalid to use a non- arguments value + in any other case. + + + Whether eager caching of singletons is allowed... typically true for + singlton objects, but never true for inner object definitions. + + + Create instance only - suppress injecting dependencies yet. + + + A new instance of the object. + + + In case of errors. + + +

+ The object definition will already have been merged with the parent + definition in case of a child definition. +

+

+ All the other methods in this class invoke this method, although objects + may be cached after being instantiated by this method. All object + instantiation within this class is performed by this method. +

+
+
+ + + Destroy the target object. + + +

+ Must destroy objects that depend on the given object before the object itself, + nor throw an exception. +

+
+ + The name of the object. + + + The target object instance to destroyed. + +
+ + + Does this object factory contain an object definition with the + supplied ? + + +

+ Does not consider any hierarchy this factory may participate in. + Invoked by + + when no cached singleton instance is found. +

+
+ + The name of the object to look for. + + + if this object factory contains an object + definition with the supplied . + +
+ + + Adds the supplied (object) to this factory's + singleton cache. + + +

+ To be called for eager registration of singletons, e.g. to be able to + resolve circular references. +

+ + If a singleton has already been registered under the same name as + the supplied , then the old singleton will + be replaced. + +
+ The name of the object. + The singleton object. + + If the argument is + or consists wholly of whitespace characters; or if the + is . + +
+ + + Return the object name, stripping out the factory dereference prefix if + necessary, and resolving aliases to canonical names. + + + The transformed name of the object. + + + + + Ensures, that the given name is prefixed with + if it incidentially already starts with this prefix. This avoids troubles when dereferencing + the object name during + + + + + Determines whether the specified name is defined as an alias as opposed + to the name of an actual object definition. + + The object name to check. + + true if the specified name is alias; otherwise, false. + + + + + Return a , + even by traversing parent if the parameter is a child definition. + + + The name of the object. + + + Are ancestors to be included in the merge? + + +

+ Will ask the parent object factory if not found in this instance. +

+
+ + A merged + with overridden properties. + +
+ + + Return a , + even by traversing parent if the parameter is a child definition. + + + A merged + with overridden properties. + + + + + Creates the root object definition. + + The template definition to base root definition on. + Root object definition. + + + + Register a new object definition with this registry. + + + The name of the object instance to register. + + + The definition of the object instance to register. + + + If the object definition is invalid. + + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + Whether to search parent object factories. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Gets the type for the given FactoryObject. + + The factory object instance to check. + the FactoryObject's object type + + + + Gets the object type for the given FactoryObject definition, as far as possible. + Only called if there is no singleton instance registered for the target object already. + + + The default implementation creates the FactoryObject via GetObject + to call its ObjectType property. Subclasses are encouraged to optimize + this, typically by just instantiating the FactoryObject but not populating it yet, + trying whether its ObjectType property already returns a type. + If no type found, a full FactoryObject creation as performed by this implementation + should be used as fallback. + + Name of the object. + The merged object definition for the object. + The type for the object if determinable, or null otherwise + + + + Predict the eventual object type (of the processed object instance) for the + specified object. + + + Does not need to handle FactoryObjects specifically, since it is only + supposed to operate on the raw object type. + This implementation is simplistic in that it is not able to + handle factory methods and InstantiationAwareBeanPostProcessors. + It only predicts the object type correctly for a standard object. + To be overridden in subclasses, applying more sophisticated type detection. + + Name of the object. + The merged object definition to determine the type for. May be null + The type of the object, or null if not predictable + + + + Get the object for the given object instance, either the object + instance itself or its created object in case of an + . + + + The name that may include the factory dereference prefix. + + The object instance. + + The singleton instance of the object. + + + + + Get the object for the given object instance, either the object + instance itself or its created object in case of an + . + + The object instance. + + The name that may include the factory dereference prefix (=the requested name). + + + The canonical object name + + the merged object definition + + The singleton instance of the object. + + + + + Obtain an object to expose from the given IFactoryObject. + + The IFactoryObject instance. + Name of the object. + The merged object definition. + The object obtained from the IFactoryObject + If IFactoryObject object creation failed. + + + + Post-process the given object that has been obtained from the FactoryObject. + The resulting object will be exposed for object references. + + The default implementation simply returns the given object + as-is. Subclasses may override this, for example, to apply + post-processors. + The instance obtained from the IFactoryObject. + Name of the object. + The object instance to expose + if any post-processing failed. + + + + Convenience method to pull an + from this factory. + + + The name of the factory object to be retrieved. If this name is not a valid + name, it will be converted + into one. + + + The associated with the + supplied . + + + + + Is the supplied a factory object dereference? + + + + + Determines whether the type of the given object definition matches the + specified target type. + + Allows for lazy load of the actual object type, provided that the + type match can be determined otherwise. + The default implementation simply delegates to the standard + ResolveObjectType method. Subclasses may override this to use + a differnt strategy. + + Name of the object (for error handling purposes). + The merged object definition to determine the type for. + Type to match against (never null). + + true if object definition matches tye specified target type; otherwise, false. + + if we failed to load the type." + + + + Resolves the type of the object for the specified object definition resolving + an object type name to a Type (if necessary) and storing the resolved Type + in the object definition for further use. + + The merged object definition to dertermine the type for. + Name of the object (for error handling purposes). + + + + + Is the object (definition) with the supplied an + ? + + The name of the object to be checked. + + the object (definition) with the supplied + an ? + + + + + Remove the object identified by the supplied + from this factory's singleton cache. + + + The name of the object that is to be removed from the singleton + cache. + + + If the argument is or + consists wholly of whitespace characters. + + + + + Return the names of objects in the singleton cache that match the given + object type (including subclasses). + + + The class or interface to match, or for all object names. + + +

+ Will not consider s + as the type of their created objects is not known before instantiation. +

+

+ Does not consider any hierarchy this factory may participate in. +

+
+ + The names of objects in the singleton cache that match the given + object type (including subclasses), or an empty array if none. + +
+ + + Determines whether the object with the given name matches the specified type. + + More specifically, check whether a GetObject call for the given name + would return an object that is assignable to the specified target type. + Translates aliases back to the corresponding canonical bean name. + Will ask the parent factory if the bean cannot be found in this factory instance. + + The name of the object to query. + Type of the target to match against. + + true if the object type matches; otherwise, false + if it doesn't match or cannot be determined yet. + + Ff there is no object with the given name + + + + + Determines the of the object with the + supplied . + + +

+ More specifically, checks the of object that + would return. + For an , returns the + of object that the + creates. +

+

+ Please note that (prototype) objects created via a factory method or + objects are handled + slightly differently, in that we don't want to needlessly create + instances of such objects just to determine the + of object that they create. +

+
+ The name of the object to query. + + The of the object or + if not determinable. + +
+ + + Determines the of the object defined + by the supplied object . + + +

+ This, the default, implementation returns + to indicate that the type cannot be determined. Subclasses are + encouraged to try to determine the actual return + here, matching their strategy of resolving + factory methods in the + Spring.Objects.Factory.Support.AbstractObjectFactory.CreateObject + implementation. +

+
+ + The name associated with the supplied object . + + + The + that the is to be determined for. + + + The of the object defined by the supplied + object ; or if the + cannot be determined. + +
+ + + Returns the names of the objects in the singleton cache. + + +

+ Does not consider any hierarchy this factory may participate in. +

+
+ The names of the objects in the singleton cache. +
+ + + Returns the number of objects in the singleton cache. + + +

+ Does not consider any hierarchy this factory may participate in. +

+
+ The number of objects in the singleton cache. +
+ + + Destroys the named singleton object. + + +

+ Delegates to + + if a corresponding singleton instance is found. +

+
+ + The name of the singleton object that is to be destroyed. + + +
+ + + Check the supplied merged object definition for any possible + validation errors. + + + The object definition to be checked for validation errors. + + + The name of the object associated with the supplied object definition. + + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + + In the case of object validation errors. + + + + + Parent object factory, for object inheritance support + + + + + Dependency types to ignore on dependency check and autowire, as Set of + Type objects: for example, string. Default is none. + + + + + ObjectPostProcessors to apply in CreateObject + + + + + Indicates whether any IInstantiationAwareBeanPostProcessors have been registered + + + + + Indicates whether any IDestructionAwareBeanPostProcessors have been registered + + + + + Set of registered singletons, containing the bean names in registration order + + + + + Set that holds all inner objects created by this factory that implement the IDisposable + interface, to be destroyed on call to Dispose. + + + + + Determines whether the local object factory contains a bean of the given name, + ignoring object defined in ancestor contexts. + This is an alternative to ContainsObject, ignoring an object + of the given name from an ancestor object factory. + + The name of the object to query. + + true if objects with the specified name is defined in the local factory; otherwise, false. + + + + + Is this object a singleton? + + + + + + Determines whether the specified object name is prototype. That is, will GetObject + always return independent instances? + + The name of the object to query + + true if the specified object name will always deliver independent instances; otherwise, false. + + This method returning false does not clearly indicate a singleton object. + It indicated non-independent instances, which may correspond to a scoped object as + well. use the IsSingleton property to explicitly check for a shared + singleton instance. + Translates aliases back to the corresponding canonical object name. Will ask the + parent factory if the object can not be found in this factory instance. + + + if there is no object with the given name. + + + + Does this object factory or one of its parent factories contain an object with the given name? + + + This method scans the object factory hierarchy starting with the current factory instance upwards. + Use if you want to explicitely check just this object factory instance. + + . + + + + Return the aliases for the given object name, if defined. + + . + + + + Return an unconfigured(!) instance (possibly shared or independent) of the given object name. + + + + This method will only instantiate the requested object. It does NOT inject any dependencies! + + + + + Return an instance (possibly shared or independent) of the given object name. + + . + + + + Return an instance (possibly shared or independent) of the given object name. + + + + + + Return an instance (possibly shared or independent) of the given object name. + + +

+ This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. +

+

+ Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. +

+

+ Will ask the parent factory if the object cannot be found in this factory + instance. +

+
+ The name of the object to return. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. If there is no factory method and the + arguments are not null, then match the argument values by type and + call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the supplied is . + +
+ + + Return an instance (possibly shared or independent) of the given object name, + optionally injecting dependencies. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + whether to inject dependencies or not. + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + + + + Checks, if the passed instance is of the required type. + + the name of the object + the actual instance + the type contract the given instance must adhere. + the object instance passed in via (for more fluent usage) + + if is null or not assignable to . + + + + + Creates a singleton instance for the specified object name and definition. + + + The object name (will be used as the key in the singleton cache key). + + The object definition. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. If there is no factory method and the + arguments are not null, then match the argument values by type and + call the object's constructor. + + The created object instance. + + + + Injects dependencies into the supplied instance + using the named object definition. + + + + + + Injects dependencies into the supplied instance + using the supplied . + + + + + + Destroy all cached singletons in this factory. + + + + + Ignore the given dependency type for autowiring + + . + + + + Determines whether the specified object name is currently in creation.. + + Name of the object. + + true if the specified object name is currently in creation; otherwise, false. + + + + + Add a new + that will get applied to objects created by this factory. + + + The + to register. + + . + + + + Given an object name, create an alias. + + . + + + + Register the given custom + for all properties of the given . + + . + + + + Register the given existing object as singleton in the object factory, + under the given object name. + + . + + + + Does this object factory contains a singleton instance with the + supplied ? + + + + + + Tries to find a cached object for the specified name. + + Teh object name to look for. + The cached object if found, otherwise. + + + + Determines whether the given object name is already in use within this factory, + i.e. whether there is a local object or alias registered under this name or + an inner object created with this name. + + Name of the object to check. + + true if is object name in use; otherwise, false. + + + + + Gets the singleton lock for a given object name. + + Name of the object. + lock object + + + + Returns, whether this factory treats object names case sensitive or not. + + + + + Gets the of + s + that will be applied to objects created by this factory. + + + + + Gets the set of classes that will be ignored for autowiring. + + +

+ The elements of this are + s. +

+
+
+ + + Returns, whether this object factory instance contains objects. + + + + + Returns, whether this object factory instance contains objects. + + + + + Gets the temporary object that is placed + into the singleton cache during object resolution. + + + + + Set that holds all inner objects created by this factory that implement the IDisposable + interface, to be destroyed on call to Dispose. + + + + + The parent object factory, or if there is none. + + + The parent object factory, or if there is none. + + + + + Return an instance (possibly shared or independent) of the given object name. + + . + + + + Returns the current number of registered + s. + + + The current number of registered + s. + + . + + + + Gets the names of singleton objects registered in this registry. + + The list of names as String array (never null). + + + Only checks already instantiated singletons; does not return names + for singleton bean definitions which have not been instantiated yet. + + + The main purpose of this method is to check manually registered singletons + . Can also be used to check which + singletons defined by an object definition have already been created. + + + + + + + + + Gets the number of singleton beans registered in this registry. + + The number of singleton objects. + + + Only checks already instantiated singletons; does not count + singleton object definitions which have not been instantiated yet. + + + The main purpose of this method is to check manually registered singletons + . Can also be used to count the number of + singletons defined by an object definition that have already been created. + + + + + + + + + Makes a distinction between sort order and object identity. + This is important when used with , since most + implementations assume Order == Identity + + + + + Handle the case when both objects have equal sort order priority. By default returns 0, + but may be overriden for handling special cases. + + The first object to compare. + The second object to compare. + + -1 if first object is less then second, 1 if it is greater, or 0 if they are equal. + + + + + The used during the invocation and + searching for of methods. + + + + + The instance for this class. + + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+ Flag specifying whether to make this object factory case sensitive or not. +
+ + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+ Flag specifying whether to make this object factory case sensitive or not. + The parent object factory, or if none. +
+ + + Predict the eventual object type (of the processed object instance) for the + specified object. + + Name of the object. + The merged object definition to determine the type for. May be null + + The type of the object, or null if not predictable + + + + + Determines the of the object defined + by the supplied object . + + + The name associated with the supplied object . + + + The + that the is to be determined for. + + + The of the object defined by the supplied + object ; or if the + cannot be determined. + + + + + Apply the property values of the object definition with the supplied + to the supplied . + + + The existing object that the property values for the named object will + be applied to. + + + The name of the object definition associated with the property values that are + to be applied. + + + + + Apply the property values of the object definition with the supplied + to the supplied . + + + The existing object that the property values for the named object will + be applied to. + + + The name of the object definition associated with the property values that are + to be applied. + + + An object definition that should be used to apply property values. + + + + + Apply any + s. + + +

+ The returned instance may be a wrapper around the original. +

+
+ + The of the object that is to be + instantiated. + + + The name of the object that is to be instantiated. + + + An instance to use in place of the original instance. + + + In case of errors. + +
+ + + Apply the given property values, resolving any runtime references + to other objects in this object factory. + + + The object name passed for better exception information. + + + The definition of the named object. + + + The wrapping the target object. + + + The new property values. + + +

+ Must use deep copy, so that we don't permanently modify this property. +

+
+
+ + + Create the value resolver strategy to use for resolving raw property values + + + + + Return an array of object-type property names that are unsatisfied. + + +

+ These are probably unsatisfied references to other objects in the + factory. Does not include simple properties like primitives or + s. +

+
+ + An array of object-type property names that are unsatisfied. + + + The definition of the named object. + + + The wrapping the target object. + +
+ + + Destroy all cached singletons in this factory. + + +

+ To be called on shutdown of a factory. +

+
+
+ + + Populate the object instance in the given + with the property values from the + object definition. + + + The name of the object. + + + The definition of the named object. + + + The wrapping the target object. + + + + + Wires up any exposed events in the object instance in the given + with any event handler + values from the . + + + The name of the object. + + + The definition of the named object. + + + The wrapping the target object. + + + + + Fills in any missing property values with references to + other objects in this factory if autowire is set to + . + + + The object name to be autowired by . + + + The definition of the named object to update through autowiring. + + + The wrapping the target object (and + from which we can rip out information concerning the object). + + + The property values to register wired objects with. + + + + + Defines "autowire by type" (object properties by type) behavior. + + +

+ This is like PicoContainer default, in which there must be exactly one object + of the property type in the object factory. This makes object factories simple + to configure for small namespaces, but doesn't work as well as standard Spring + behavior for bigger applications. +

+
+ + The object name to be autowired by . + + + The definition of the named object to update through autowiring. + + + The wrapping the target object (and + from which we can rip out information concerning the object). + + + The property values to register wired objects with. + +
+ + + Ignore the given dependency type for autowiring + + + This will typically be used by application contexts to register + dependencies that are resolved in other ways, like IOjbectFactory through + IObjectFactoryAware or IApplicationContext through IApplicationContextAware. + By default, IObjectFactoryAware and IObjectName interfaces are ignored. + For further types to ignore, invoke this method for each type. + + . + + + + Create an object instance for the given object definition. + + The name of the object. + + The object definition for the object that is to be instantiated. + + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. It is invalid to use a non- arguments value + in any other case. + + + Whether eager caching of singletons is allowed... typically true for + singlton objects, but never true for inner object definitions. + + + Suppress injecting dependencies yet. + + + A new instance of the object. + + + In case of errors. + + +

+ The object definition will already have been merged with the parent + definition in case of a child definition. +

+

+ All the other methods in this class invoke this method, although objects + may be cached after being instantiated by this method. All object + instantiation within this class is performed by this method. +

+
+
+ + + Add the created, but yet unpopulated singleton to the singleton cache + to be able to resolve circular references + + the name of the object to add to the cache. + the definition used to create and populated the object. + the raw object instance. + + Derived classes may override this method to select the right cache based on the object definition. + + + + + Remove the specified singleton from the singleton cache that has + been added before by a call to + + the name of the object to remove from the cache. + the definition used to create and populated the object. + + Derived classes may override this method to select the right cache based on the object definition. + + + + + Creates an instance from the passed in + using constructor + + The name of the object to create - used for error messages. + The describing the object to be created. + optional arguments to pass to the constructor + An wrapping the already instantiated object + + + + Instantiates the given object using its default constructor + + Name of the object. + The definition. + IObjectWrapper for the new instance + + + + Determines candidate constructors to use for the given object, checking all registered + + + Raw type of the object. + Name of the object. + the candidate constructors, or null if none specified + In case of errors + + + + + Instantiate an object instance using a named factory method. + + +

+ The method may be static, if the + parameter specifies a class, rather than a + instance, or an + instance variable on a factory object itself configured using Dependency + Injection. +

+

+ Implementation requires iterating over the static or instance methods + with the name specified in the supplied + (the method may be overloaded) and trying to match with the parameters. + We don't have the types attached to constructor args, so trial and error + is the only way to go here. +

+
+ + The name associated with the supplied . + + + The definition describing the instance that is to be instantiated. + + + Any arguments to the factory method that is to be invoked. + + + The result of the factory method invocation (the instance). + +
+ + + "autowire constructor" (with constructor arguments by type) behaviour. + + The name of the object to autowire by type. + The object definition to update through autowiring. + The chosen candidate constructors. + The argument values passed in programmatically via the GetObject method, + or null if none (-> use constructor argument values from object definition) + + An for the new instance. + + + + Also applied if explicit constructor argument values are specified, + matching all remaining arguments with objects from the object factory. + + + This corresponds to constructor injection: in this mode, a Spring.NET + object factory is able to host components that expect constructor-based + dependency resolution. + + + + + + Perform a dependency check that all properties exposed have been set, if desired. + + +

+ Dependency checks can be objects (collaborating objects), simple (primitives + and ), or all (both). +

+
+ + The name of the object. + + + The definition of the named object. + + + The wrapping the target object. + + + The property values to be checked. + + + If all of the checked dependencies were not satisfied. + +
+ + + Extract a filtered set of PropertyInfos from the given IObjectWrapper, excluding + ignored dependency types. + + The object wrapper the object was created with. + The filtered PropertyInfos + + + + Determine whether the given bean property is excluded from dependency checks. + This implementation excludes properties whose type matches an ignored dependency type + or which are defined by an ignored dependency interface. + + + + the of the object property + whether the object property is excluded + + + + Give an object a chance to react now all its properties are set, + and a chance to know about its owning object factory (this object). + + +

+ This means checking whether the object implements + and / or + , and invoking the + necessary callback(s) if it does. +

+

+ Custom init methods are resolved in a case-insensitive manner. +

+
+ + The new object instance we may need to initialise. + + + The name the object has in the factory. Used for logging output. + + + The definition of the target object instance. + +
+ + + Invoke the specified custom destroy method on the given object. + + +

+ This implementation invokes a no-arg method if found, else checking + for a method with a single boolean argument (passing in "true", + assuming a "force" parameter), else logging an error. +

+

+ Can be overridden in subclasses for custom resolution of destroy + methods with arguments. +

+

+ Custom destroy methods are resolved in a case-insensitive manner. +

+
+
+ + + Destroy the target object. + + +

+ Must destroy objects that depend on the given object before the object itself. + Should not throw any exceptions. +

+
+ + The name of the object. + + + The target object instance to destroyed. + +
+ + + Destroys all of the objects registered as dependant on the + object (definition) identified by the supplied . + + + The name of the root object (definition) that is itself being destroyed. + + + + + Resolve a reference to another object in the factory. + + + The name of the object that is having the value of one of its properties resolved. + + + The definition of the named object. + + + The name of the property the value of which is being resolved. + + + The runtime reference containing the value of the property. + + A reference to another object in the factory. + + + + Find object instances that match the required . + + +

+ Called by autowiring. If a subclass cannot obtain information about object + names by , a corresponding exception should be thrown. +

+
+ + The of the objects to look up. + + + An of object names and object + instances that match the required , or + if none are found. + + + In case of errors. + +
+ + + Return the names of the objects that depend on the given object. + Called by DestroyObject, to be able to destroy depending objects first. + + + The name of the object to find depending objects for. + + + The array of names of depending objects, or the empty string array if none. + + + In case of errors. + + + + + Injects dependencies into the supplied instance + using the named object definition. + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + + + + Injects dependencies into the supplied instance + using the supplied . + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + An object definition that should be used to configure object. + + + + + + Configures object instance by injecting dependencies, satisfying Spring lifecycle + interfaces and applying object post-processors. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + An object definition that should be used to configure object. + + + A wrapped object instance that is to be so configured. + + + + + + Applies the PostProcessAfterInitialization callback of all + registered IObjectPostProcessors, giving them a chance to post-process + the object obtained from IFactoryObjects (for example, to auto-proxy them) + + The instance obtained from the IFactoryObject. + Name of the object. + The object instance to expose + if any post-processing failed. + + + + Create a new object instance of the given class with the specified + autowire strategy. + + + The of the object to instantiate. + + + The desired autowiring mode. + + + Whether to perform a dependency check for objects (not applicable to + autowiring a constructor, thus ignored there). + + The new object instance. + + If the wiring fails. + + + + + + Autowire the object properties of the given object instance by name or + . + + + The existing object instance. + + + The desired autowiring mode. + + + Whether to perform a dependency check for the object. + + + If the wiring fails. + + + If the supplied is not one of the + or + + values. + + + + + + Apply s + to the given existing object instance, invoking their + + methods. + + + The existing object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + If any post-processing failed. + + + + + + Apply s + to the given existing object instance, invoking their + + methods. + + + The existing object instance. + + + The name of the object. + + + The object instance to use, either the original or a wrapped one. + + + If any post-processing failed. + + + + + + Resolve the specified dependency against the objects defined in this factory. + + The descriptor for the dependency. + Name of the object which declares the present dependency. + A list that all names of autowired object (used for + resolving the present dependency) are supposed to be added to. + + the resolved object, or null if none found + + if dependency resolution failed + + + + Cache of filtered PropertyInfos: object Type -> PropertyInfo array + + + + + Dependency interfaces to ignore on dependency check and autowire, as Set of + Class objects. By default, only the IObjectFactoryAware and IObjectNameAware + interfaces are ignored. + + + + + The + implementation to be used to instantiate managed objects. + + + + + An + implementation that provides some convenience support for + derived classes. + + +

+ This class is reserved for internal use within the framework; it is + not intended to be used by application developers using Spring.NET. +

+
+ Rick Evans +
+ + + Permits the (re)implementation of an arbitrary method on a Spring.NET + IoC container managed object. + + +

+ Encapsulates the notion of the Method-Injection form of Dependency + Injection. +

+

+ Methods that are dependency injected with implementations of this + interface may be (but need not be) , in which + case the container will create a concrete subclass of the + class prior to instantiation. +

+

+ Do not use this mechanism as a means of AOP. See the reference + manual for examples of appropriate usages of this interface. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + Reimplement the supplied . + + + The instance whose is to be + (re)implemented. + + + The method that is to be (re)implemented. + + The target method's arguments. + + The result of the (re)implementation of the method call. + + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such has no + publicly visible constructors. +

+
+ + The object definition that is the target of the method replacement. + + + The enclosing IoC container with which the above + is associated. + + + If either of the supplied arguments is . + +
+ + + Is ; derived classes must supply an implementation. + + + The instance whose is to be + (re)implemented. + + + The method that is to be (re)implemented. + + The target method's arguments. + The result of the object lookup. + + + + Helper method for subclasses to retrieve the appropriate + for the + supplied . + + + The to use to retrieve + the appropriate + . + + + The appropriate + . + + + + + Helper method for subclasses to lookup an object from an enclosing + IoC container. + + + The name of the object that is to be looked up. + + + The named object. + + + + + Common base class for object definitions, factoring out common + functionality from + and + . + + Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + + + + Describes a configurable object instance, which has property values, + constructor argument values, and further information supplied by concrete + implementations. + + Rick Evans + + + + Return the property values to be applied to a new instance of the object. + + + + + Return the constructor argument values for this object. + + + + + The method overrides (if any) for this object. + + + The method overrides (if any) for this object; may be an + empty collection but is guaranteed not to be + . + + + + + Return the event handlers for any events exposed by this object. + + + + + Get or set the role hint for this object definition + + + + + Return a description of the resource that this object definition + came from (for the purpose of showing context in case of errors). + + + + + Is this object definition "abstract", i.e. not meant to be instantiated + itself but rather just serving as parent for concrete child object + definitions. + + + if this object definition is "abstract". + + + + + Returns the of the object definition (if any). + + + A resolved object . + + + If the of the object definition is not a + resolved or . + + + + + Returns the of the + of the object definition (if any). + + + + + Return whether this a Singleton, with a single, shared instance + returned on all calls. + + +

+ If , an object factory will apply the Prototype + design pattern, with each caller requesting an instance getting an + independent instance. How this is defined will depend on the + object factory implementation. Singletons are the commoner type. +

+
+
+ + + Is this object lazily initialized? + +

+ Only applicable to a singleton object. +

+

+ If , it will get instantiated on startup by object factories + that perform eager initialization of singletons. +

+
+
+ + + The autowire mode as specified in the object definition. + + +

+ This determines whether any automagical detection and setting of + object references will happen. Default is + , + which means there's no autowire. +

+
+
+ + + The dependency check code. + + + + + The object names that this object depends on. + + +

+ The object factory will guarantee that these objects get initialized + before. +

+

+ Note that dependencies are normally expressed through object properties + or constructor arguments. This property should just be necessary for + other kinds of dependencies like statics (*ugh*) or database + preparation on startup. +

+
+
+ + + The name of the initializer method. + + +

+ The default is , in which case there is no initializer method. +

+
+
+ + + Return the name of the destroy method. + + +

+ The default is , in which case there is no destroy method. +

+
+
+ + + The name of the factory method to use (if any). + + +

+ This method will be invoked with constructor arguments, or with no + arguments if none are specified. The static method will be invoked on + the specified . +

+
+
+ + + The name of the factory object to use (if any). + + + + + Gets or sets a value indicating whether this instance a candidate for getting autowired into some other + object. + + + true if this instance is autowire candidate; otherwise, false. + + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Creates a new instance of the + + class. + + + The object definition used to initialise the member fields of this + instance. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+
+ + + Resolves the type of the object, resolving it from a specified + object type name if necessary. + + + A resolved instance. + + + If the type cannot be resolved. + + + + + Validate this object definition. + + + In the case of a validation failure. + + + + + Validates all + + + + + Validate the supplied . + + + The + to be validated. + + + + + Override settings in this object definition from the supplied + object definition. + + + The object definition used to override the member fields of this instance. + + + + + Returns a that represents the current + . + + + A that represents the current + . + + + + + The name of the parent definition of this object definition, if any. + + + + + The property values that are to be applied to the object + upon creation. + + +

+ Setting the value of this property to + will merely result in a new (and empty) + + collection being assigned to the property value. +

+
+ + The property values (if any) for this object; may be an + empty collection but is guaranteed not to be + . + +
+ + + Does this definition have any + ? + + + if this definition has at least one + . + + + + + The constructor argument values for this object. + + +

+ Setting the value of this property to + will merely result in a new (and empty) + + collection being assigned. +

+
+ + The constructor argument values (if any) for this object; may be an + empty collection but is guaranteed not to be + . + +
+ + + The event handler values for this object. + + +

+ Setting the value of this property to + will merely result in a new (and empty) + + collection being assigned. +

+
+ + The event handler values (if any) for this object; may be an + empty collection but is guaranteed not to be + . + +
+ + + The method overrides (if any) for this object. + + +

+ Setting the value of this property to + will merely result in a new (and empty) + + collection being assigned to the property value. +

+
+ + The method overrides (if any) for this object; may be an + empty collection but is guaranteed not to be + . + +
+ + + The name of the target scope for the object. + Defaults to "singleton", ootb alternative is "prototype". Extended object factories + might support further scopes. + + + + + Get or set the role hint for this object definition + + + + + Is this definition a singleton, with + a single, shared instance returned on all calls to an enclosing + container (typically an + or + ). + + +

+ If , an object factory will apply the + prototype design pattern, with each caller requesting an + instance getting an independent instance. How this is defined + will depend on the object factory implementation. singletons + are the commoner type. +

+
+ +
+ + + Gets a value indicating whether this instance is prototype, with an independent instance + returned for each call. + + + true if this instance is prototype; otherwise, false. + + + + + Is this object lazily initialized? + +

+ Only applicable to a singleton object. +

+

+ If , it will get instantiated on startup + by object factories that perform eager initialization of + singletons. +

+
+
+ + + Is this object definition a "template", i.e. not meant to be instantiated + itself but rather just serving as an object definition for configuration + templates used by . + + + if this object definition is a "template". + + + + + Is this object definition "abstract", i.e. not meant to be + instantiated itself but rather just serving as a parent for concrete + child object definitions. + + + if this object definition is "abstract". + + + + + The of the object definition (if any). + + + A resolved object . + + + If the of the object definition is not a + resolved or . + + + + + + Is the of the object definition a resolved + ? + + + + + Returns the of the + of the object definition (if any). + + + + + A description of the resource that this object definition + came from (for the purpose of showing context in case of errors). + + + + + The autowire mode as specified in the object definition. + + +

+ This determines whether any automagical detection and setting of + object references will happen. The default is + , + which means that no autowiring will be performed. +

+
+
+ + + Gets the resolved autowire mode. + + +

+ This resolves + + to one of + + or + . +

+
+
+ + + The dependency checking mode. + + +

+ The default is + . +

+
+
+ + + The object names that this object depends on. + + +

+ The object factory will guarantee that these objects get initialized + before this object definition. +

+ + Dependencies are normally expressed through object properties + or constructor arguments. This property should just be necessary for + other kinds of dependencies such as statics (*ugh*) or database + preparation on startup. + +
+
+ + + Gets or sets a value indicating whether this instance a candidate for getting autowired into some other + object. + + + true if this instance is autowire candidate; otherwise, false. + + + + + The name of the initializer method. + + +

+ The default value is the constant, + in which case there is no initializer method. +

+
+
+ + + Return the name of the destroy method. + + +

+ The default value is the constant, + in which case there is no destroy method. +

+
+
+ + + The name of the factory method to use (if any). + + +

+ This method will be invoked with constructor arguments, or with no + arguments if none are specified. The + method will be invoked on the specified + . +

+
+
+ + + The name of the factory object to use (if any). + + + + + Does this object definition have any constructor argument values? + + + if his object definition has at least one + element in it's + + property. + + + + + Abstract base class for object definition readers. + + +

+ Provides common properties like the object registry to work on. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Simple interface for object definition readers. + + Juergen Hoeller + Rick Evans + + + + Load object definitions from the supplied . + + + The resource for the object definitions that are to be loaded. + + + The number of object definitions found + + + In the case of loading or parsing errors. + + + + + Load object definitions from the supplied . + + + The resources for the object definitions that are to be loaded. + + + The number of object definitions found + + + In the case of loading or parsing errors. + + + + + Loads the object definitions from the specified resource location. + + The resource location, to be loaded with the + IResourceLoader location . + + The number of object definitions found + + + + + Loads the object definitions from the specified resource locations. + + The the resource locations to be loaded with the + IResourceLoader of this object definition reader. + + The number of object definitions found + + + + + Gets the + + instance that this reader works on. + + + + + The against which any class names + will be resolved into instances. + + + + + The to use for anonymous + objects (wihtout explicit object name specified). + + + + + Gets the resource loader to use for resource locations. + + There is also a method + available for loading object definitions from a resource location. This is + a convenience to avoid explicit ResourceLoader handling. + The resource loader. + + + + The instance for this class (and derived classes). + + + + + Creates a new instance of the + + class. + + + The + instance that this reader works on. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Creates a new instance of the + + class. + + + The + instance that this reader works on. + + + The against which any class names + will be resolved into instances. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Load object definitions from the supplied . + + + The resource for the object definitions that are to be loaded. + + + The number of object definitions that were loaded. + + + In the case of loading or parsing errors. + + + + + Load object definitions from the supplied . + + + The resources for the object definitions that are to be loaded. + + + The number of object definitions found + + + In the case of loading or parsing errors. + + + + + Loads the object definitions from the specified resource location. + + The resource location, to be loaded with the + IResourceLoader location . + + The number of object definitions found + + + + + Loads the object definitions from the specified resource locations. + + The the resource locations to be loaded with the + IResourceLoader of this object definition reader. + + The number of object definitions found + + + + + Gets the + + instance that this reader works on. + + + + + The to use for anonymous + objects (wihtout explicit object name specified). + + + + + + The against which any class names + will be resolved into instances. + + + + + Gets or sets the resource loader to use for resource locations. + + The resource loader. + + + + Utility class that contains various methods useful for the implementation of + autowire-capable object factories. + + Juergen Hoeller + Rick Evans (.NET) + + + + Creates a new instance of the AutowireUtils class. + + +

+ This is a utility class, and as such has no publicly + visible constructors. +

+
+
+ + + Gets those s + that are applicable for autowiring the supplied . + + + The + (definition) that is being autowired by constructor. + + + The absolute minimum number of arguments that any returned constructor + must have. If this parameter is equal to zero (0), then all constructors + are valid (regardless of their argument count), including any default + constructor. + + + Those s + that are applicable for autowiring the supplied . + + + + + Determine a weight that represents the class hierarchy difference between types and + arguments. + + +

+ A direct match, i.e. type MyInteger -> arg of class MyInteger, does not increase + the result - all direct matches means weight zero (0). A match between the argument type + and a MyInteger instance argument would increase the weight by + 1, due to the superclass () being one (1) steps up in the + class hierarchy being the last one that still matches the required type. +

+

+ Therefore, with an argument of type , a + constructor taking a argument would be + preferred to a constructor taking an argument + which would be preferred to a constructor taking an + argument which would in turn be preferred + to a constructor taking an argument. +

+

+ All argument weights get accumulated. +

+
+ + The argument s to match. + + The arguments to match. + The accumulated weight for all arguments. +
+ + + Algorithm that judges the match between the declared parameter types of a candidate method + and a specific list of arguments that this method is supposed to be invoked with. + + + Determines a weight that represents the class hierarchy difference between types and + arguments. The following a an example based on the Java class hierarchy for Integer. + A direct match, i.e. type Integer -> arg of class Integer, does not increase + the result - all direct matches means weight 0. A match between type Object and arg of + class Integer would increase the weight by 2, due to the superclass 2 steps up in the + hierarchy (i.e. Object) being the last one that still matches the required type Object. + Type Number and class Integer would increase the weight by 1 accordingly, due to the + superclass 1 step up the hierarchy (i.e. Number) still matching the required type Number. + Therefore, with an arg of type Integer, a constructor (Integer) would be preferred to a + constructor (Number) which would in turn be preferred to a constructor (Object). + All argument weights get accumulated. + + The param types. + The args. + + + + + Determines whether the given object property is excluded from dependency checks. + + The PropertyInfo of the object property. + + true if is excluded from dependency check; otherwise, false. + + + + + Sorts the supplied , preferring + public constructors and "greedy" ones (that have lots of arguments). + + +

+ The result will contain public constructors first, with a decreasing number + of arguments, then non-public constructors, again with a decreasing number + of arguments. +

+
+ + The array to be sorted. + +
+ + + Determines whether the setter property is defined in any of the given interfaces. + + The PropertyInfo of the object property + The ISet of interfaces. + + true if setter property is defined in interface; otherwise, false. + + + + + Creates the autowire candidate resolver. + + A SimpleAutowireCandidateResolver + + + + Returns the list of that are not satisfied by . + + the filtered list. Is never null + + + + Object definition for definitions that inherit settings from their + parent (object definition). + + +

+ Will use the + of the parent object definition if none is specified, but can also + override it. In the latter case, the child's + + must be compatible with the parent, i.e. accept the parent's property values + and constructor argument values (if any). +

+

+ A will + inherit all of the , + , and + from it's parent + object definition, with the option to add new values. If the + , + , + and / or + + properties are specified, they will override the corresponding parent settings. +

+

+ The remaining settings will always be taken from the child definition: + , + , + , + , + and + +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + +
+ + + Creates a new instance of the + + class. + + + The name of the parent object. + + + + + Creates a new instance of the + + class. + + + The name of the parent object. + + + The additional property values (if any) of the child. + + + + + Creates a new instance of the + + class. + + + The name of the parent object. + + + The + to be applied to a new instance of the object. + + + The additional property values (if any) of the child. + + + + + Creates a new instance of the + + class. + + + The name of the parent object. + + + The class of the object to instantiate. + + + The + to be applied to a new instance of the object. + + + The additional property values (if any) of the child. + + + + + Creates a new instance of the + + class. + + + The name of the parent object. + + + The of the object to + instantiate. + + + The + to be applied to a new instance of the object. + + + The additional property values (if any) of the child. + + + + + Validate this object definition. + + +

+ A common cause of validation failures is a missing value for the + + property; by + their very nature require that the + + be set. +

+
+ + In the case of a validation failure. + +
+ + + A that represents the current + . + + + A that represents the current + . + + + + + The name of the parent object definition. + + + This value is required. + + + The name of the parent object definition. + + + + + Helper class for resolving constructors and factory methods. + Performs constructor resolution through argument matching. + + + Operates on a and an . + Used by . + + Juergen Hoeller + Mark Pollack + + + + Initializes a new instance of the class for the given factory + and instantiation strategy. + + The object factory to work with. + The object factory as IAutowireCapableObjectFactory. + The instantiation strategy for creating objects. + the resolver to resolve property value placeholders if any + + + + "autowire constructor" (with constructor arguments by type) behavior. + Also applied if explicit constructor argument values are specified, + matching all remaining arguments with objects from the object factory. + + + This corresponds to constructor injection: In this mode, a Spring + object factory is able to host components that expect constructor-based + dependency resolution. + + Name of the object. + The merged object definition for the object. + The chosen chosen candidate constructors (or null if none). + The explicit argument values passed in programmatically via the getBean method, + or null if none (-> use constructor argument values from object definition) + An IObjectWrapper for the new instance + + + + Gets the constructor instantiation info given the object definition. + + Name of the object. + The RootObjectDefinition + The explicitly chosen ctors. + The explicit chose ctor args. + A ConstructorInstantiationInfo containg the specified constructor in the RootObjectDefinition or + one based on type matching. + + + + Instantiate an object instance using a named factory method. + + +

+ The method may be static, if the + parameter specifies a class, rather than a + instance, or an + instance variable on a factory object itself configured using Dependency + Injection. +

+

+ Implementation requires iterating over the static or instance methods + with the name specified in the supplied + (the method may be overloaded) and trying to match with the parameters. + We don't have the types attached to constructor args, so trial and error + is the only way to go here. +

+
+ + The name associated with the supplied . + + + The definition describing the instance that is to be instantiated. + + + Any arguments to the factory method that is to be invoked. + + + The result of the factory method invocation (the instance). + +
+ + + Create an array of arguments to invoke a constructor or static factory method, + given the resolved constructor arguments values. + + When return value is null the out parameter UnsatisfiedDependencyExceptionData will contain + information for use in throwing a UnsatisfiedDependencyException by the caller. This avoids using + exceptions for flow control as in the original implementation. + + + + Resolves the + of the supplied . + + The name of the object that is being resolved by this factory. + The rod. + The wrapper. + The cargs. + Where the resolved constructor arguments will be placed. + + The minimum number of arguments that any constructor for the supplied + must have. + + +

+ 'Resolve' can be taken to mean that all of the s + constructor arguments is resolved into a concrete object that can be plugged + into one of the s constructors. Runtime object + references to other objects in this (or a parent) factory are resolved, + type conversion is performed, etc. +

+

+ These resolved values are plugged into the supplied + object, because we wouldn't want to touch + the s constructor arguments in case it (or any of + its constructor arguments) is a prototype object definition. +

+

+ This method is also used for handling invocations of static factory methods. +

+
+
+ + + Returns an array of all of those + methods exposed on the + that match the supplied criteria. + + + Methods that have this name (can be in the form of a regular expression). + + + Methods that have exactly this many arguments. + + + Methods that are static / instance. + + + The on which the methods (if any) are to be found. + + + An array of all of those + methods exposed on the + that match the supplied criteria. + + + + + Concrete implementation of the + and + + interfaces. + + +

+ This class is a full-fledged object factory based on object definitions + that is usable straight out of the box. +

+

+ Can be used as an object factory in and of itself, or as a superclass + for custom object factory implementations. Note that readers for + specific object definition formats are typically implemented separately + rather than as object factory subclasses. +

+

+ For an alternative implementation of the + interface, + have a look at the + + class, which manages existing object instances rather than creating new + ones based on object definitions. +

+
+ Juergen Hoeller + Rick Evans (.NET) + +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + Flag specifying whether to make this object factory case sensitive or not. + + + + Creates a new instance of the + class. + + The parent object factory. + + + + Creates a new instance of the + class. + + Flag specifying whether to make this object factory case sensitive or not. + The parent object factory. + + + + Find object instances that match the . + + +

+ Called by autowiring. If a subclass cannot obtain information about object + names by , a corresponding exception should be thrown. +

+
+ + The type of the objects to look up. + + + An of object names and object + instances that match the , or + if none is found. + + + In case of errors. + +
+ + + Return the names of the objects that depend on the given object. + + +

+ Called by the + + so that dependant objects are able to be disposed of first. +

+
+ + The name of the object to find depending objects for. + + + The array of names of depending objects, or the empty string array if none. + + + In case of errors. + +
+ + + Check whether the specified object matches the supplied . + + The name of the object to check. + + The to check for. + + + if the object matches the supplied , + or if the supplied is . + + + + + The instance for this class. + + + + + Whether to allow re-registration of a different definition with the + same name. + + + + + The mapping of object definition objects, keyed by object name. + + + + + List of object definition names, in registration order. + + + + + Resolver to use for checking if an object definition is an autowire candidate + + + + + IDictionary from dependency type to corresponding autowired value + + + + + Check if this registry contains a object definition with the given + name. + + + The name of the object to look for. + + + if this object factory contains an object + definition with the given name. + + + + + + Register a new object definition with this registry. + + + The name of the object instance to register. + + + The definition of the object instance to register. + + + If the object definition is invalid. + + + + + + Ensure that all non-lazy-init singletons are instantiated, also + considering s. + + + If one of the singleton objects could not be created. + + + + + + Register a special dependency type with corresponding autowired value. + + Type of the dependency to register. + This will typically be a base interface such as IObjectFactory, with extensions of it resolved + as well if declared as an autowiring dependency (e.g. IListableBeanFactory), + as long as the given value actually implements the extended interface. + The autowired value. This may also be an + implementation o the interface, + which allows for lazy resolution of the actual target value. + + This is intended for factory/context references that are supposed + to be autowirable but are not defined as objects in the factory: + e.g. a dependency of type ApplicationContext resolved to the + ApplicationContext instance that the object is living in. + + Note there are no such default types registered in a plain IObjectFactory, + not even for the IObjectFactory interface itself. + + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + + The registered , + or null, if specified object definitions does not exist. + + + If is null or empty string. + + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + Whether to search parent object factories. + + The registered , + or null, if specified object definitions does not exist. + + + If is null or empty string. + + + + + + Return the names of all objects defined in this factory. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + + The (class or interface) to match. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + + + + + + Return the object instances that match the given object + (including subclasses). + + + The (class or interface) to match. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + An of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If any of the objects could not be created. + + + + + + Return the object instances that match the given object + (including subclasses). + + + The (class or interface) to match. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + An of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If any of the objects could not be created. + + + + + + Check whether the specified bean would need to be eagerly initialized + in order to determine its type. + + a factory-bean reference that the bean definition defines a factory method for + whether eager initialization is necessary + + + + Check whether the given bean is defined as a . + + the name of the object + the corresponding object definition + + + + Resolve the specified dependency against the objects defined in this factory. + + The descriptor for the dependency. + Name of the object which declares the present dependency. + A list that all names of autowired object (used for + resolving the present dependency) are supposed to be added to. + + the resolved object, or null if none found + + if dependency resolution failed + + + + Raises the no such object definition exception for an unresolvable dependency + + The type. + The dependency description. + The descriptor. + + + + Determines whether the specified object qualifies as an autowire candidate, + to be injected into other beans which declare a dependency of matching type. + This method checks ancestor factories as well. + + Name of the object to check. + The descriptor of the dependency to resolve. + + true if the object should be considered as an autowire candidate; otherwise, false. + + if there is no object with the given name. + + + + Determine whether the specified object definition qualifies as an autowire candidate, + to be injected into other beans which declare a dependency of matching type. + + Name of the object definition to check. + The merged object definiton to check. + The descriptor of the dependency to resolve. + + true if the object should be considered as an autowire candidate; otherwise, false. + + + + + Should object definitions registered under the same name as an + existing object definition be allowed? + + +

+ If , then the new object definition will + replace (override) the existing object definition. If + , an exception will be thrown when + an attempt is made to register an object definition under the same + name as an already existing object definition. +

+

+ The default is . +

+
+ + is the registration of an object definition + under the same name as an existing object definition is allowed. + +
+ + + Get or set custom autowire candidate resolver for this IObjectFactory to use + when deciding whether a bean definition should be considered as a + candidate for autowiring. Never null + + + + + Return the number of objects defined in this registry. + + + The number of objects defined in this registry. + + + + + + Default implementation of the + + interface. + + +

+ Does not support per + loading. +

+
+ Aleksandar Seovic +
+ + + Central interface for factories that can create + + instances. + + +

+ Allows for replaceable object definition factories using the Strategy + pattern. +

+
+ Aleksandar Seovic +
+ + + Factory style method for getting concrete + + instances. + + + The FullName of the of the defined object. + + The name of the parent object definition (if any). + + The against which any class names + will be resolved into instances. It can be null to register the + object class just by name. + + + An + + instance. + + + + + Factory style method for getting concrete + + instances. + + /// If no parent is specified, a RootObjectDefinition is created, otherwise a + ChildObjectDefinition. + The of the defined object. + The name of the parent object definition (if any). + The against which any class names + will be resolved into instances. + + An + + instance. + + + + + Default implementation of the interface, deleagting to + 's GenerateObjectName. + + Note that this implementation is only able to handle + subclasses such as + and + + Juergen Hoeller + Mark Pollack (.NET) + + + + Strategy interface for generating object names for object definitions + + Juergen Hoeller + Mark Pollack (.NET) + + + + Generates an object name for the given object definition. + + The object definition to generate a name for. + The object definitions registry that the given definition is + supposed to be registerd with + the generated object name + + + + Generates an object name for the given object definition. + + The object definition to generate a name for. + The object definitions registry that the given definition is + supposed to be registerd with + the generated object name + + + + An + implementation that delegates to an + that is + obtained as the result of a lookup in an associated IoC container. + + +

+ This class is reserved for internal use within the framework; it is + not intended to be used by application developers using Spring.NET. +

+
+ Rick Evans +
+ + + Creates a new instance of the + + class. + + + The object definition that is the target of the method replacement. + + + The enclosing IoC container with which the above + is associated. + + + If either of the supplied arguments is . + + + + + Reimplements the supplied by delegating to + another + looked up in an enclosing IoC container. + + + The instance whose is to be + (re)implemented. + + + The method that is to be (re)implemented. + + The target method's arguments. + + The result of the delegated call to the looked up + . + + + + + The various modes of dependency checking. + + Rick Evans (.NET) + + + + DO not do any dependency checking. + + + + + Check object references. + + + + + Just check primitive (string, int, etc) values. + + + + + Check everything. + + + + + GenericObjectDefinition is a one-stop shop for standard object definition purposes. + Like any object definition, it allows for specifying a class plus optionally + constructor argument values and property values. Additionally, deriving from a + parent bean definition can be flexibly configured through the "parentName" property. + + In general, use this class for the purpose of + registering user-visible object definitions (which a post-processor might operate on, + potentially even reconfiguring the parent name). + Use / + where parent/child relationships happen to be pre-determined. + + + + Juergen Hoeller + Erich Eichinger + + + + Creates a new to be configured through its + object properties and configuration methods. + + + + + Creates a new as deep copy of the given + object definition. + + the original object definition to copy from + + + + Returns a representation of this + for debugging purposes. + + + + + The name of the parent object definition. + + + This value is required. + + + The name of the parent object definition. + + + + + Strategy interface for determining whether a specific object definition + qualifies as an autowire candidate for a specific dependency. + + Mark Fisher + Juergen hoeller + Mark Pollack (.NET) + + + + Determines whether the given object definition qualifies as an + autowire candidate for the given dependency. + + The object definition including object name and aliases. + The descriptor for the target method parameter or field. + + true if the object definition qualifies as autowire candidate; otherwise, false. + + + + + Responsible for creating instances corresponding to a + . + + Rod Johnson + Rick Evans (.NET) + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + An instance of the object described by the supplied + from the supplied . + + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + The to be used to instantiate + the object. + + + Any arguments to the supplied . May be null. + + + An instance of the object described by the supplied + from the supplied . + + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + The to be used to get the object. + + + Any arguments to the supplied . May be null. + + + An instance of the object described by the supplied + from the supplied . + + + + + Represents an override of a method that looks up an object in the same IoC context. + + +

+ Methods eligible for lookup override must not have arguments. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + Represents the override of a method on a managed object by the IoC container. + + +

+ Note that the override mechanism is not intended as a generic means of + inserting crosscutting code: use AOP for that. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no + public constructors. +

+
+ + The name of the method that is to be overridden. + + + If the supplied is or + contains only whitespace character(s). + +
+ + + Does this + match the supplied ? + + +

+ By 'match' one means does this particular + + instance apply to the supplied ? +

+

+ This allows for argument list checking as well as method name checking. +

+
+ The method to be checked. + + if this override matches the supplied + . + +
+ + + The name of the method that is to be overridden. + + + + + Is the method that is ot be injected + () + to be considered as overloaded? + + +

+ If (the default), then argument type matching + will be performed (because one would not want to override the wrong + method). +

+

+ Setting the value of this property to can be used + to optimize runtime performance (ever so slightly). +

+
+
+ + + Creates a new instance of the + class. + + +

+ Methods eligible for lookup override must not have arguments. +

+
+ + The name of the method that is to be overridden. + + + The name of the object in the current IoC context that the + dependency injected method must return. + + + If either of the supplied arguments is or + contains only whitespace character(s). + +
+ + + Does this + match the supplied ? + + The method to be checked. + + if this override matches the supplied . + + + If the supplied is . + + + + + A that represents the current + . + + + A that represents the current + . + + + + + The name of the object in the current IoC context that the + dependency injected method must return. + + + + + An + implementation that simply returns the result of a lookup in an + associated IoC container. + + +

+ This class is Spring.NET's implementation of Dependency Lookup via + Method Injection. +

+

+ This class is reserved for internal use within the framework; it is + not intended to be used by application developers using Spring.NET. +

+
+ Rick Evans +
+ + + Creates a new instance of the + class. + + + The object definition that is the target of the method replacement. + + + The enclosing IoC container with which the above + is associated. + + + If either of the supplied arguments is . + + + + + Reimplements the supplied by returning the + result of an object lookup in an enclosing IoC container. + + + The instance whose is to be + (re)implemented. + + + The method that is to be (re)implemented. + + The target method's arguments. + + The result of the object lookup. + + + + + An + implementation that supports method injection. + + +

+ Classes that want to take advantage of method injection must meet some + stringent criteria. Every method that is to be method injected + must be defined as either or + . An + will be thrown if these criteria are not met. +

+
+ Rick Evans +
+ + + Simple object instantiation strategy for use in + implementations. + + +

+ Does not support method injection, although it provides hooks for subclasses + to override to add method injection support, for example by overriding methods. +

+
+ Rod Johnson + Rick Evans (.NET) + +
+ + + The shared instance for this class (and derived classes). + + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + An instance of the object described by the supplied + from the supplied . + + + + + Gets the zero arg ConstructorInfo object, if the type offers such functionality. + + The type. + Zero argument ConstructorInfo + + If the type does not have a zero-arg constructor. + + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + The to be used to instantiate + the object. + + + Any arguments to the supplied . May be null. + + + An instance of the object described by the supplied + from the supplied . + + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + The to be used to get the object. + + + Any arguments to the supplied . May be null. + + + An instance of the object described by the supplied + from the supplied . + + + + + Instantiate an instance of the object described by the supplied + from the supplied , + injecting methods as appropriate. + + +

+ The default implementation of this method is to throw a + . +

+

+ Derived classes can override this method if they can instantiate an object + with the Method Injection specified in the supplied + . Instantiation should use a no-arg constructor. +

+
+ + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be a + or zero length string if we're autowiring an object that + doesn't belong to the supplied . + + + The owning + + + An instance of the object described by the supplied + from the supplied . + +
+ + + Instantiate an instance of the object described by the supplied + from the supplied , + injecting methods as appropriate. + + +

+ The default implementation of this method is to throw a + . +

+

+ Derived classes can override this method if they can instantiate an object + with the Method Injection specified in the supplied + . Instantiation should use the supplied + and attendant . +

+
+ + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + The to be used to instantiate + the object. + + + Any arguments to the supplied . May be null. + + + An instance of the object described by the supplied + from the supplied . + +
+ + + The name of the dynamic assembly that holds dynamically created code + + + + + A cache of generated instances, keyed on + the object name for which the was generated. + + + + + Instantiate an instance of the object described by the supplied + from the supplied , + injecting methods as appropriate. + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the + or zero length string if we're autowiring an + object that doesn't belong to the supplied + . + + + The owning + + + An instance of the object described by the supplied + from the supplied . + + + + + + Instantiate an instance of the object described by the supplied + from the supplied , + injecting methods as appropriate. + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the + or zero length string if we're autowiring an + object that doesn't belong to the supplied + . + + + The owning + + + The to be used to instantiate + the object. + + + Any arguments to the supplied . May be null. + + + An instance of the object described by the supplied + from the supplied . + + + + + + Instantiate an instance of the object described by the supplied + from the supplied , + injecting methods as appropriate. + + +

+ This method dynamically generates a subclass that supports method + injection for the supplied . It then + instantiates an new instance of said type using the constructor + identified by the supplied , + passing the supplied to said + constructor. It then manually injects (generic) method replacement + and method lookup instances (of + ) into + the new instance: those methods that are 'method-injected' will + then delegate to the approriate + + instance to effect the actual method injection. +

+
+ + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the + or zero length string if we're autowiring an + object that doesn't belong to the supplied + . + + + The owning + + + The parameter s to use to find the + appropriate constructor to invoke. + + + The aguments that are to be passed to the appropriate constructor + when the object is being instantiated. + + + A new instance of the defined by the + supplied . + +
+ + + A factory that generates subclasses of those + classes that have been configured for the Method-Injection form of + Dependency Injection. + + +

+ This class is designed as for one-shot usage; i.e. it must + be used to generate exactly one method injected subclass and + then discarded (it maintains state in instance fields). +

+
+
+ + + The name of the generated + property (for method replacement). + + +

+ Exists so that clients of this class can use this name to set properties reflectively + on the dynamically generated subclass. +

+
+
+ + + The name of the generated + property (for method lookup). + + +

+ Exists so that clients of this class can use this name to set properties reflectively + on the dynamically generated subclass. +

+
+
+ + + Creates a new instance of the + class. + + + The in which + the generated is to be defined. + + + The object definition that is the target of the method injection. + + + If either of the supplied arguments is . + + + + + Builds a suitable for Method-Injection. + + + A suitable for Method-Injection. + + + + + Defines overrides for those methods that are configured with an appropriate + . + + + The overarching that is defining + the generated . + + + + + Override the supplied with the logic + encapsulated by the + + defined by the supplied . + + + The builder for the subclass that is being generated. + + + The method on the superclass that is to be overridden. + + + The field defining the + + that the overridden method will delegate to to do the 'actual' + method injection logic. + + + + + Generates the MSIL for actually returning a return value if the + supplied is not + . + + + The definition of the return value; if , it + means that no return value is to required (a void + return type). + + + The to emit + the MSIL to. + + + + + Generates the MSIL for a return value if the supplied + returns a value. + + + The method to be checked. + + + The to emit + the MSIL to. + + + The return value, or if the method does not + return a value (has a void return type). + + + + + Pushes (sets up) the arguments for a call to the + + method of an appropriate + . + + + The parameters to the original method (will be bundled + up into a generic object[] and passed as the third + argument to the + + invocation. + + + The to emit + the MSIL to. + + + + + Simply generates the IL for a write only property for the + . + + + The in which the property is defined. + + + The name of the (to be) generated property. + + + The (instance) field that the property is to 'set'. + + + + + A collection (with set semantics) of method overrides, determining which, if any, + methods on a managed object the Spring.NET IoC container will override at runtime. + + Rod Johnson + Rick Evans + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + +

+ Deep copy constructoe. +

+
+ + The instance supplying initial overrides for this new instance. + +
+ + + Copy all given method overrides into this object. + + + The overrides to be copied into this object. + + + + + Adds the supplied to the overrides contained + within this instance. + + + The to be + added. + + + + + Adds the supplied to the overloaded method names + contained within this instance. + + + The overloaded method name to be added. + + + + + Returns true if the supplied is present within + the overloaded method names contained within this instance. + + + The overloaded method name to be checked. + + + True if the supplied is present within + the overloaded method names contained within this instance. + + + + + Return the override for the given method, if any. + + + The method to check for overrides for. + + + the override for the given method, if any. + + + + + Returns an that can iterate + through a collection. + + +

+ The returned is the + exposed by the + + property. +

+
+ + An that can iterate through a + collection. + +
+ + + The collection of method overrides. + + + + + Returns true if this instance contains no overrides. + + + + + Programmatic means of constructing a using the builder pattern. Intended primarily + for use when implementing custom namespace parsers. + + Set methods are used instead of properties, so that chaining of methods can be used to create + 'one-liner'definitions that set multiple properties at one. + Rod Johnson + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class, private + to force use of factory methods. + + + + + Creates a new used to construct a . + + + + + Creates a new used to construct a . + + the of the object that the definition is being created for + + + + Creates a new used to construct a . + + the name of the of the object that the definition is being created for + + + + Create a new ObjectDefinitionBuilder used to construct a root object definition. + + The object definition factory. + The type name of the object. + A new ObjectDefinitionBuilder instance. + + + + Create a new ObjectDefinitionBuilder used to construct a root object definition. + + The object definition factory. + Name of the object type. + Name of the factory method. + A new ObjectDefinitionBuilder instance. + + + + Create a new ObjectDefinitionBuilder used to construct a root object definition. + + The object definition factory. + Type of the object. + A new ObjectDefinitionBuilder instance. + + + + Create a new ObjectDefinitionBuilder used to construct a root object definition. + + The object definition factory. + Type of the object. + Name of the factory method. + A new ObjectDefinitionBuilder instance. + + + + Create a new ObjectDefinitionBuilder used to construct a child object definition.. + + The object definition factory. + Name of the parent object. + + + + + Adds the property value under the given name. + + The name. + The value. + The current ObjectDefinitionBuilder. + + + + Adds a reference to the specified object name under the property specified. + + The name. + Name of the object. + The current ObjectDefinitionBuilder. + + + + Adds an index constructor arg value. The current index is tracked internally and all addtions are + at the present point + + The constructor arg value. + The current ObjectDefinitionBuilder. + + + + Adds a reference to the named object as a constructor argument. + + Name of the object. + + + + + Sets the name of the factory method to use for this definition. + + The factory method. + The current ObjectDefinitionBuilder. + + + + Sets the name of the factory object to use for this definition. + + The factory object. + The factory method. + The current ObjectDefinitionBuilder. + + + + Sets whether or not this definition describes a singleton object. + + if set to true [singleton]. + The current ObjectDefinitionBuilder. + + + + Sets whether objects or not this definition is abstract. + + if set to true [flag]. + The current ObjectDefinitionBuilder. + + + + Sets whether objects for this definition should be lazily initialized or not. + + if set to true [lazy]. + The current ObjectDefinitionBuilder. + + + + Sets the autowire mode for this definition. + + The autowire mode. + The current ObjectDefinitionBuilder. + + + + Sets the dependency check mode for this definition. + + The dependency check. + The current ObjectDefinitionBuilder. + + + + Sets the name of the destroy method for this definition. + + Name of the method. + The current ObjectDefinitionBuilder. + + + + Sets the name of the init method for this definition. + + Name of the method. + The current ObjectDefinitionBuilder. + + + + Sets the resource description for this definition. + + The resource description. + The current ObjectDefinitionBuilder. + + + + Adds the specified object name to the list of objects that this definition depends on. + + Name of the object. + The current ObjectDefinitionBuilder. + + + + Gets the current object definition in its raw (unvalidated) form. + + The raw object definition. + + + + Validate and gets the object definition. + + The object definition. + + + + Utility methods that are useful for + + implementations. + + Juergen Hoeller + Rick Evans (.NET) + + + + + The string used as a separator in the generation of synthetic id's + for those object definitions explicitly that aren't assigned one. + + +

+ If a name or parent object definition + name is not unique, "#1", "#2" etc will be appended, until such + time that the name becomes unique. +

+
+
+ + + Registers the supplied with the + supplied . + + +

+ This is a convenience method that registers the + + of the supplied under the + + property value of said . If the + supplied has any + , + then those aliases will also be registered with the supplied + . +

+
+ + The object definition holder containing the + that + is to be registered. + + + The registry that the supplied + is to be registered with. + + + If either of the supplied arguments is . + + + If the could not be registered + with the . + +
+ + + Generates an object definition name for the supplied + that is guaranteed to be unique + within the scope of the supplied . + + The + that requires a generated name. + The + + that the supplied is to be + registered with (needed so that the uniqueness of any generated + name can be guaranteed). + if set to true if the given object + definition will be registed as an inner object or as a top level objener objects + verses top level objects. + + An object definition name for the supplied + that is guaranteed to be unique + within the scope of the supplied and + never . + + + If either of the or + arguments is . + + + If a unique name cannot be generated. + + + + + Generates the name of the object for a top-level object definition unique within the given object factory. + + The object definition to generate an object name for. + The registry to check for existing names. + The generated object name + if no unique name can be generated for the given + object definition + + + + Factory method for getting concrete + instances. + + + The name of the event handler method. This may be straight text, a regular + expression, , or empty. + + + The name of the event being wired. This too may be straight text, a regular + expression, , or empty. + + + A concrete + instance. + + + + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Thrown when the validation of an object definition failed. + + Juergen Hoeller + Rick Evans (.NET) + + + + Creates a new instance of the + + class. + + + + + Creates a new instance of the + + class. + + The detail message. + + + + Creates a new instance of the + + class. + + + The detail message. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionValidationException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Helper class for use in object factory implementations, + resolving values contained in object definition objects + into the actual values applied to the target object instance. + + + Used by . + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The object factory. + + + + Given a property value, return a value, resolving any references to other + objects in the factory if necessary. + + +

+ The value could be : + + +

+ An , + which leads to the creation of a corresponding new object instance. + Singleton flags and names of such "inner objects" are always ignored: inner objects + are anonymous prototypes. +

+ + +

+ A , which must + be resolved. +

+
+ +

+ An . This is a + special placeholder collection that may contain + s or + collections that will need to be resolved. +

+
+ +

+ An ordinary object or , in which case it's left alone. +

+
+ +

+
+ + The name of the object that is having the value of one of its properties resolved. + + + The definition of the named object. + + + The name of the property the value of which is being resolved. + + + The value of the property that is being resolved. + +
+ + + TODO + + + The name of the object that is having the value of one of its properties resolved. + + + The definition of the named object. + + + The name of the property the value of which is being resolved. + + + The value of the property that is being resolved. + + + + + Resolve the target type of the passed . + + The who's target type is to be resolved + The resolved target type, if any. otherwise. + + + + Resolves an inner object definition. + + + The name of the object that surrounds this inner object definition. + + + The name of the inner object definition... note: this is a synthetic + name assigned by the factory (since it makes no sense for inner object + definitions to have names). + + + The name of the property the value of which is being resolved. + + + The definition of the inner object that is to be resolved. + + + if the owner of the property is a singleton. + + + The resolved object as defined by the inner object definition. + + + + + Checks the given bean name whether it is unique. If not already unique, + a counter is added, increasing the counter until the name is unique. + + Original Name of the inner object. + The Adapted name for the inner object + + + + Resolve a reference to another object in the factory. + + + The name of the object that is having the value of one of its properties resolved. + + + The definition of the named object. + + + The name of the property the value of which is being resolved. + + + The runtime reference containing the value of the property. + + A reference to another object in the factory. + + + + The possible object scope values. + + Aleksandar Seovic + + + + + + + + + Application scope. + + + + + Session scope. + + + + + Request scope. + + + + + + + + + + Default scope (currently + ). + + + + + + Object definition reader for a simple properties format. + + + Provides object definition registration methods for + and + instances. Typically applied to a + . + + Rod Johnson + Juergen Hoeller + Simon White (.NET) + + + + Value of a T/F attribute that represents true. + Anything else represents false. Case seNsItive. + + + + + Separator between object name and property name. + + + + + Prefix for the class property of a root object definition. + + + + + Special string added to distinguish if the object will be + a singleton. + + +

+ Default is true. +

+
+ +

+ owner.(singleton)=true +

+
+
+ + + Special string added to distinguish if the object will be + lazily initialised. + + +

+ Default is false. +

+
+ +

+ owner.(lazy-init)=true +

+
+
+ + + Reserved "property" to indicate the parent of a child object definition. + + + + + Property suffix for references to other objects in the current + : e.g. + owner.dog(ref)=fido. + + +

+ Whether this is a reference to a singleton or a prototype + will depend on the definition of the target object. +

+
+
+ + + Prefix before values referencing other objects. + + + + + Creates a new instance of the + + class. + + + The + instance that this reader works on. + + + + + Load object definitions from the supplied . + + + The resource for the object definitions that are to be loaded. + + + The number of object definitions that were loaded. + + + In the case of loading or parsing errors. + + + + + Load object definitions from the specified properties file. + + + The resource descriptor for the properties file. + + + The match or filter for object definition names, e.g. 'objects.' + + in case of loading or parsing errors + the number of object definitions found + + + + Register object definitions contained in a + , using all property keys (i.e. + not filtering by prefix). + + + The containing object definitions. + + + In case of loading or parsing errors. + + The number of object definitions registered. + + + + Register object definitions contained in a + . + + +

+ Similar syntax as for an . + This method is useful to enable standard .NET internationalization support. +

+
+ + The containing object definitions. + + + The match or filter for object definition names, e.g. 'objects.' + + + In case of loading or parsing errors. + + The number of object definitions registered. +
+ + + Register object definitions contained in an + , using all property keys + (i.e. not filtering by prefix). + + + The containing object definitions. + + + In case of loading or parsing errors. + + The number of object definitions registered. + + + + Registers object definitions contained in an + using all property keys ( i.e. not filtering by prefix ) + + The containing + object definitions. + + + In case of loading or parsing errors. + + The number of object definitions registered. + + + + Register object definitions contained in a + . + + +

+ Ignores ineligible properties. +

+
+ IDictionary name -> property (String or Object). Property values + will be strings if coming from a Properties file etc. Property names + (keys) must be strings. Type keys must be strings. + + + The match or filter within the keys in the map: e.g. 'objects.' + + + In case of loading or parsing errors. + + The number of object definitions found. +
+ + + Register object definitions contained in a + . + + +

+ Ignores ineligible properties. +

+
+ IDictionary name -> property (String or Object). Property values + will be strings if coming from a Properties file etc. Property names + (keys) must be strings. Type keys must be strings. + + + The match or filter within the keys in the map: e.g. 'objects.' + + + The description of the resource that the + came from (for logging purposes). + + + In case of loading or parsing errors. + + The number of object definitions found. +
+ + + Get all property values, given a prefix (which will be stripped) + and add the object they define to the factory with the given name + + The name of the object to define. + + The containing string pairs. + + The prefix of each entry, which will be stripped. + + The description of the resource that the + came from (for logging purposes). + + + In case of loading or parsing errors. + + + + + Name of default parent object + + + + + Gets or sets object definition factory to use. + + + + + A plain-vanilla object definition. + + +

+ This is the most common type of object definition; + instances + do not derive from a parent + , and usually + (but not always - see below) have an + + and (optionally) some + and + . +

+

+ Note that + instances do not have to specify an + : + This can be useful for deriving + instances + from such definitions, each with it's own + , + inheriting common property values and other settings from the parent. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + + class. + + + The of the object to instantiate. + + + + + Creates a new instance of the + + class. + + + The of the object to instantiate. + + + if this object definition defines a singleton object. + + + + + Creates a new instance of the + class + for a singleton, providing property values and constructor arguments. + + + The of the object to instantiate. + + + The + to be applied to a new instance of the object. + + + The to be applied to + a new instance of the object. + + + + + Creates a new instance of the + class + for a singleton using the supplied + . + + + The of the object to instantiate. + + + The autowiring mode. + + + + + Creates a new instance of the + class + for a singleton using the supplied + . + + + The of the object to instantiate. + + + The autowiring mode. + + + Whether to perform a dependency check for objects (not + applicable to autowiring a constructor, thus ignored there) + + + + + Creates a new instance of the + class + with the given singleton status, providing property values. + + + The of the object to instantiate. + + + The to be applied to + a new instance of the object. + + + + + Creates a new instance of the + class + with the given singleton status, providing property values. + + + The of the object to instantiate. + + + The to be applied to + a new instance of the object. + + + if this object definition defines a singleton object. + + + + + Creates a new instance of the + class + for a singleton, providing property values and constructor arguments. + + +

+ Takes an object class name to avoid eager loading of the object class. +

+
+ + The assembly qualified of the object to instantiate. + + + The to be applied to + a new instance of the object. + + + The + to be applied to a new instance of the object. + +
+ + + Creates a new instance of the + class. + + +

+ Deep copy constructor. +

+
+ + The definition that is to be copied. + +
+ + + Validate this object definition. + + + In the case of a validation failure. + + + + + A that represents the current + . + + + A that represents the current + . + + + + + Is always null for a . + + + It is safe to request this property's value. Setting any other value than null will + raise an . + + Raised on any attempt to set a non-null value on this property. + + + + A implementation to use that checks + the object definitions only (no attributes) + + Mark Fisher + Mark Pollack (.NET) + + + + Determines whether the given object definition qualifies as an + autowire candidate for the given dependency. + + The object definition including object name and aliases. + The descriptor for the target method parameter or field. + + true if the object definition qualifies as autowire candidate; otherwise, false. + + + + + Static factory that permits the registration of existing singleton instances. + + +

+ Does not have support for prototype objects, aliases, and post startup object + configuration. +

+

+ Serves as a simple example implementation of the + interface, that manages existing object instances as opposed to creating new ones + based on object definitions. +

+

+ The + method is not supported by this class; this class deals exclusively with + existing singleton instances, thus the methods mentioned previously make little sense in this context. +

+
+ Rod Johnson + Juergen Hoeller + Simon White (.NET) +
+ + + Map from object name to object instance. + + + + + This method is not supported by . + + + + + + Return an instance of the given object name. + + The name of the object to return. + The instance of the object. + + is not currently supported. + + + + + + Return an instance (possibly shared or independent) of the given object name. + + +

+ This method allows an object factory to be used as a replacement for the + Singleton or Prototype design pattern. +

+

+ Note that callers should retain references to returned objects. There is no + guarantee that this method will be implemented to be efficient. For example, + it may be synchronized, or may need to run an RDBMS query. +

+

+ Will ask the parent factory if the object cannot be found in this factory + instance. +

+
+ The name of the object to return. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. If there is no factory method and the + arguments are not null, then match the argument values by type and + call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the supplied is . + +
+ + + Return an instance (possibly shared or independent) of the given object name. + + The name of the object to return. + + The the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + + The arguments to use if creating a prototype using explicit arguments to + a factory method. If there is no factory method and the + supplied array is not , then + match the argument values by type and call the object's constructor. + + The instance of the object. + + If there's no such object definition. + + + If the object could not be created. + + + If the object is not of the required type. + + + If the supplied is . + + + + + + Return an instance of the given object name. + + The name of the object to return. + + the object may match. Can be an interface or + superclass of the actual class. For example, if the value is the + class, this method will succeed whatever the + class of the returned instance. + + The instance of the object. + + + + + Does this object factory contain an object with the given name? + + The name of the object to query. + True if an object with the given name is defined. + + + + Is this object a singleton? + + +

+ That is, will + or + always return the same object? +

+
+ The name of the object to query. + True if the named object is a singleton. + + If there's no such object definition. + +
+ + + Determines whether the specified object name is prototype. That is, will GetObject + always return independent instances? + + This method returning false does not clearly indicate a singleton object. + It indicated non-independent instances, which may correspond to a scoped object as + well. use the IsSingleton property to explicitly check for a shared + singleton instance. + Translates aliases back to the corresponding canonical object name. Will ask the + parent factory if the object can not be found in this factory instance. + + + + The name of the object to query + + true if the specified object name will always deliver independent instances; otherwise, false. + + if there is no object with the given name. + + + + Determine the type of the object with the given name. + + +

+ More specifically, checks the type of object that + would return. + For an , returns the type + of object that the creates. +

+
+ The name of the object to query. + + The of the object or if + not determinable. + +
+ + + Determines whether the object with the given name matches the specified type. + + The name of the object to query. + Type of the target to match against. + + true if the object type matches; otherwise, false + if it doesn't match or cannot be determined yet. + + Ff there is no object with the given name + + + + + Return the aliases for the given object name, if defined. + + The object name to check for aliases. + The aliases, or an empty array if none. + + If there's no such object definition. + + + + + Not supported. + + The name of the object. + + The registered + . + + + Always, as object definitions are not supported by this + implementation. + + + + + Return the registered + for the + given object, allowing access to its property values and constructor + argument values. + + The name of the object. + Whether to search parent object factories. + + The registered + . + + + If there is no object with the given name. + + + In the case of errors. + + + + + Return the names of all objects defined in this factory. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + + + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + +

+ Will not consider s, + as the type of their created objects is not known before instantiation. +

+
+ + The names of all objects defined in this factory, or an empty array if none + are defined. + +
+ + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + + The (class or interface) to match, or + for all object names. + + +

+ Does consider objects created by s, + or rather it considers the type of objects created by + (which means that + s will be instantiated). +

+

+ Does not consider any hierarchy this factory may participate in. +

+
+ + The names of all objects defined in this factory, or an empty array if none + are defined. + +
+ + + Return the names of objects matching the given + (including subclasses), judging from the object definitions. + + +

+ Since this implementation of the + + interface does not support the notion of ptototype objects, the + parameter is ignored. +

+
+ + The (class or interface) to match, or + for all object names. + + + Whether to include prototype objects too or just singletons (also applies to + s). Ignored. + + + Whether to include s too + or just normal objects. + + + The names of all objects defined in this factory, or an empty array if none + are defined. + + +
+ + + Tests whether this object factory contains an object definition for the + specified object name. + + The object name to query. + + True if an object defintion is contained within this object factory. + + + + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + +

+ This version of the + method matches all kinds of object definitions, be they singletons, prototypes, or + s. Typically, the results + of this method call will be the same as a call to + IListableObjectFactory.GetObjectsOfType(type,true,true) . +

+
+ + The (class or interface) to match. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + +
+ + + Return the object instances that match the given object + (including subclasses), judging from either object + definitions or the value of + in the case of + s. + + + The (class or interface) to match. + + + Whether to include prototype objects too or just singletons (also applies to + s). + + + Whether to include s too + or just normal objects. + + + A of the matching objects, + containing the object names as keys and the corresponding object instances + as values. + + + If the objects could not be created. + + + + + Add a new singleton object. + + + The name to be associated with the object name. + + The singleton object. + + + + Injects dependencies into the supplied instance + using the named object definition. + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + This feature is not currently supported. + + + + + + Injects dependencies into the supplied instance + using the supplied . + + + The object instance that is to be so configured. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + An object definition that should be used to configure object. + + + + + + Defines a method to release allocated unmanaged resources. + + + + + Determine whether this object factory treats object names case-sensitive or not. + + + + + Return the number of objects defined in the factory. + + + The number of objects defined in the factory. + + + + + Return an instance of the given object name. + + The name of the object to return. + The instance of the object. + + + + + Abstract implementation providing + a number of convenience methods and a + template method + that subclasses must override to provide the actual parsing logic. + + + Use this implementation when you want + to parse some arbitrarily complex XML into one or more + ObjectDefinitions. If you just want to parse some + XML into a single IObjectDefinition, you may wish to consider + the simpler convenience extensions of this class, namely + and + + + Rob Harrop + Juergen Hoeller + Rick Evans + Mark Pollack (.NET) + + + + Interface used to handle custom, top-level tags. + + Implementations are free to turn the metadata in the custom tag into as + many as required. + + Rob Harrop + Mark Pollack (.NET) + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+ + The element to be parsed. + + + TThe object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + + + The primary object definition. + +
+ + + Constant for the ID attribute + + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + The element to be parsed. + TThe object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + The primary object definition. + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+
+ + + Resolves the ID for the supplied . + + + When using generation, a name is generated automatically. + Otherwise, the ID is extracted from the "id" attribute, potentially with a + fallback to a generated id. + + The element that the object definition has been built from. + The object definition to be registered. + The the object encapsulating the current state of the parsing process; + provides access to a + the resolved id + + if no unique name could be generated for the given object definition + + + + + Registers the supplied with the supplied + . + + Subclasses can override this method to control whether or not the supplied + is actually even registered, or to + register even more objects. + + The default implementation registers the supplied + with the supplied only if the IsNested + parameter is false, because one typically does not want inner objects + to be registered as top level objects. + + + + The object definition to be registered. + The registry that the bean is to be registered with. + + + + Returns the value of the element's attribute or null, if the attribute is not specified. + + + This is a helper for bypassing the behavior of + to return if the attribute does not exist. + + + + + Returns the value of the element's attribute or , + if the attribute is not specified. + + + This is a helper for bypassing the behavior of + to return if the attribute does not exist. + + + + + Central template method to actually parse the supplied XmlElement + into one or more IObjectDefinitions. + + The element that is to be parsed into one or more s + The the object encapsulating the current state of the parsing process; + provides access to a + The primary IObjectDefinition resulting from the parsing of the supplied XmlElement + + + + Gets a value indicating whether an ID should be generated instead of read + from the passed in XmlElement. + + Note that this flag is about always generating an ID; the parser + won't even check for an "id" attribute in this case. + + true if should generate id; otherwise, false. + + + + Gets a value indicating whether an ID should be generated instead if the + passed in XmlElement does not specify an "id" attribute explicitly. + + Disabled by default; subclasses can override this to enable ID generation + as fallback: The parser will first check for an "id" attribute in this case, + only falling back to a generated ID if no value was specified. + + true if should generate id if no value was specified; otherwise, false. + + + + + Convenient base class for when there exists a one-to-one mapping + between attribute names on the element that is to be parsed and + the property names on the Type being configured. + + + + + Mark Pollack + + + + Base Type for those implementations that + need to parse and define just a single IObjectDefinition. + + + Extend this parser Type when you want to create a single object definition + from an arbitrarily complex XML element. You may wish to consider extending + the when you want to create a + single Object definition from a relatively simple custom XML element. + The resulting ObjectDefinition will be automatically registered + with the ObjectDefinitionRegistry. Your job simply is to parse the + custom XML element into a single ObjectDefinition + + Rob Harrop + Juergen Hoeller + Rick Evans + Mark Pollack (.NET) + + + + Central template method to actually parse the supplied XmlElement + into one or more IObjectDefinitions. + + The element that is to be parsed into one or more s + The the object encapsulating the current state of the parsing process; + provides access to a + + The primary IObjectDefinition resulting from the parsing of the supplied XmlElement + + + + + Determine the name for the parent of the currently parsed object, + in case of the current object being defined as a child object. + The default implementation returns null + indicating a root object definition. + + + the name of the parent object for the currently parsed object. + + + + Gets the type of the object corresponding to the supplied XmlElement. + + Note that, for application classes, it is generally preferable to override + GetObjectTypeName instad, in order to avoid a direct + dependence on the object implementation class. The ObjectDefinitionParser + and its IXmlObjectDefinitionParser (namespace parser) can be used within an + IDE add-in then, even if the application classses are not available in the add-ins + AppDomain. + + The element. + The Type of the class that is being defined via parsing the supplied + Element. + + + + Gets the name of the object type name (FullName) corresponding to the supplied XmlElement. + + The element. + The type name of the object that is being defined via parsing the supplied + XmlElement. + + + + Parse the supplied XmlElement and populate the supplied ObjectDefinitionBuilder as required. + + The default implementation delegates to the DoParse version without + ParameterContext argument. + The element. + The parser context. + The builder used to define the IObjectDefinition. + + + + Parse the supplied XmlElement and populate the supplied ObjectDefinitionBuilder as required. + + The default implementation does nothing. + The element. + The builder used to define the IObjectDefinition. + + + + Default implementation of the interface. + Resolves namespace URIs to implementation types based on mappings. + + Erich Eichinger + + + + + + Used by to locate + implementations for a particular namespace URI. + + TODO (EE): clarify naming of INamespaceParser (SPR/NET) vs. INamespaceHandler (SPR/Java), thus internal for now + Erich Eichinger + + + + + + + Lookup a for the given namespace URI. + + the namespace URI + the located namespace handler or null + + + + Resolve the namespace URI and return the corresponding + implementation. + + the namespace URI to get the matching parser for. + the matching parser or null + + + + XML resource reader. + + +

+ Navigates through an XML resource and invokes parsers registered + with the . +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + SPI for parsing an XML document that contains Spring object definitions. + Used by for actually parsing a DOM + document. + + Instantiated per document to parse: Implementations can hold state in + instance variables during the execution of the RegisterObjectDefinitions + method, for example global settings that are defined for all object definitions + in the document. + + Juergen Hoeller + Rob Harrop + Mark Pollack (.NET) + + + + + Read object definitions from the given DOM element, and register + them with the given object registry. + + The DOM element containing object definitions, usually the + root (document) element. + The current context of the reader. Includes + the resource being parsed + + The number of object definitions that were loaded. + + + In case of parsing errors. + + + + + The shared instance for this class (and derived classes). + + + + + Creates a new instance of the DefaultObjectDefinitionDocumentReader class. + + + + + Read object definitions from the given DOM element, and register + them with the given object registry. + + The DOM element containing object definitions, usually the + root (document) element. + The current context of the reader. Includes + the resource being parsed + + The number of object definitions that were loaded. + + + In case of parsing errors. + + + + + Parses object definitions starting at the given + using the passed . + + The root element to start parsing from. + The instance to use. + + in case an error happens during parsing and registering object definitions + + + + + Process an alias element. + + + + + Process the object element + + + + + Loads external XML object definitions from the resource described by the supplied + . + + The XML element describing the resource. + + If the resource could not be imported. + + + + + Parses the given alias element, registering the alias with the registry. + + The alias element. + The registry. + + + + Parse an object definition and register it with the object factory.. + + The element containing the object definition. + The helper. + + + + + + Allow the XML to be extensible by processing any custom element types last, + after we finished processing the objct definitions. This method is a natural + extension point for any other custom post-processing of the XML. + + The default implementation is empty. Subclasses can override this method to + convert custom elements into standard Spring object definitions, for example. + Implementors have access to the parser's object definition reader and the + underlying XML resource, through the corresponding properties. + + + The root. + + + + Allow the XML to be extensible by processing any custom element types first, + before we start to process the object definitions. + + This method is a natural + extension point for any other custom pre-processing of the XML. +

The default implementation is empty. Subclasses can override this method to + convert custom elements into standard Spring object definitions, for example. + Implementors have access to the parser's object definition reader and the + underlying XML resource, through the corresponding properties. +

+
+ The root element of the XML document. +
+ + + Creates an instance for the given and element. + + the to create the + the root to start reading from + a new instance + + + + Gets the reader context. + + The reader context. + + + + Simple class that holds the defaults specified at the <objects> + level in a standard Spring XML object definition document: + default-lazy-init, default-autowire, etc. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Gets or sets the autowire setting for the document that's currently parsed. + + The autowire. + + + + Gets or sets the dependency-check setting for the document that's currently parsed + + The dependency check. + + + + Gets or sets the lazy-init flag for the document that's currently parsed. + + The lazy init. + + + + Gets or sets the merge setting for the document that's currently parsed. + + The merge. + + + + Strategy interface for parsing XML object definitions. Equivalent to Spring/Java's NamespaceHandler interface. + + +

+ Used by + for actually parsing a DOM document or + fragment. +

+
+ Juergen Hoeller + Rick Evans (.NET) + Sandu Turcan (.NET) +
+ + + Invoked by after construction but before any + elements have been parsed. + + + + + Parse the specified element and register any resulting + IObjectDefinitions with the IObjectDefinitionRegistry that is + embedded in the supplied ParserContext. + + + Implementations should return the primary IObjectDefinition + that results from the parse phase if they wish to used nested + inside (for example) a <property> tag. + Implementations may return null if they will not + be used in a nested scenario. + + + The element to be parsed into one or more IObjectDefinitions + The object encapsulating the current state of the parsing + process. + + The primary IObjectDefinition (can be null as explained above) + + + + + Parse the specified XmlNode and decorate the supplied ObjectDefinitionHolder, + returning the decorated definition. + + The XmlNode may either be an XmlAttribute or an XmlElement, depending on + whether a custom attribute or element is being parsed. + Implementations may choose to return a completely new definition, + which will replace the original definition in the resulting IApplicationContext/IObjectFactory. + + The supplied ParserContext can be used to register any additional objects needed to support + the main definition. + + The source element or attribute that is to be parsed. + The current object definition. + The object encapsulating the current state of the parsing + process. + The decorated definition (to be registered in the IApplicationContext/IObjectFactory), + or simply the original object definition if no decoration is required. A null value is strickly + speaking invalid, but will leniently treated like the case where the original object definition + gets returned. + + + + Attribute that should be used to specify the default namespace + and schema location for a custom namespace parser. + + Aleksandar Seovic + + + + Creates a new instance of . + + + + + Gets or sets the default namespace for the configuration parser. + + + The default namespace for the configuration parser. + + + + + Gets or sets the default schema location for the configuration parser. + + + The default schema location for the configuration parser. + + + If the property is set, the will always resolve to an assembly-resource + and the set will be interpreted relative to this assembly. + + + + + Gets or sets a type from the assembly containing the schema + + + If this property is set, the will always resolve to an assembly-resource + and the will be interpreted relative to this assembly. + + + + + Provides a resolution mechanism for configuration parsers. + + +

+ The uses this registry + class to find the parser handling a specific namespace. +

+
+ Aleksandar Seovic +
+ + + Name of the .Net config section that contains definitions + for custom config parsers. + + + + + Creates a new instance of the NamespaceParserRegistry class. + + + + + Reset the list of registered parsers to "factory"-setting + + use for unit tests only + + + + Registers the type for wellknown namespaces + + true if the parser could be registered, false otherwise + + + + Constructs a "assembly://..." qualified schemaLocation url using the given type + to obtain the assembly name. + + + + + Returns a parser for the given namespace. + + + The namespace for which to lookup the parser implementation. + + + A parser for a given , or + if no parser was found. + + + + + Returns a schema collection containing validation schemas for all registered parsers. + + + A schema collection containing validation schemas for all registered parsers. + + + + + Pegisters parser, using default namespace and schema location + as defined by the . + + + The of the parser that will be activated + when an element in its default namespace is encountered. + + + If is . + + + + + Associates a parser with a namespace. + + + + Parsers registered with the same as that + of a parser that has previously been registered will overwrite the existing + parser. + + + + The of the parser that will be activated + when the attendant is + encountered. + + + The namespace with which to associate instance of the parser. + + + The location of the XML schema that should be used for validation + of the XML elements that belong to the specified namespace + (can be any valid Spring.NET resource URI). + + + If the is not a + that implements the + interface. + + + If is . + + + + + Pegisters parser, using default namespace and schema location + as defined by the . + + + The parser instance. + + + If is . + + + + + Associates a parser with a namespace. + + + + Parsers registered with the same as that + of a parser that has previously been registered will overwrite the existing + parser. + + + + The namespace with which to associate instance of the parser. + + + The parser instance. + + + The location of the XML schema that should be used for validation + of the XML elements that belong to the specified namespace + (can be any valid Spring.NET resource URI). + + + If is , or if + is not specified and parser class + does not have default value defined using . + + + + + Register a schema as well-known + + + + + + + Returns default values for the parser namespace and schema location as + defined by the . + + + A type of the parser. + + + A instance containing + default values for the parser namsepace and schema location + + + + + Resolves xml entities by using the infrastructure. + + + + + Adapts the interface to . + Only for smooth transition between 1.x and 2.0 style namespace handling, will be dropped for 2.0 + + + + + Support class for implementing custom namespace parsers. + + Parsing of individual elements is done via a ObjectDefintionParser. + Provides the RegisterObjectDefinitionParser for registering a ObjectDefintionParser + to handle a specific element. + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + + + + Invoked by after construction but before any + elements have been parsed. + + + + + Parses an element under the root node, typically + an object definition or import statement. + + + The element to be parsed. + + + The parser context. + + + The number of object defintions created from this element. + + + + + Parse the specified XmlNode and decorate the supplied ObjectDefinitionHolder, + returning the decorated definition. + + The XmlNode may either be an XmlAttribute or an XmlElement, depending on + whether a custom attribute or element is being parsed. + Implementations may choose to return a completely new definition, + which will replace the original definition in the resulting IApplicationContext/IObjectFactory. + + The supplied ParserContext can be used to register any additional objects needed to support + the main definition. + + The source element or attribute that is to be parsed. + The current object definition. + The object encapsulating the current state of the parsing + process. + The decorated definition (to be registered in the IApplicationContext/IObjectFactory), + or simply the original object definition if no decoration is required. A null value is strickly + speaking invalid, but will leniently treated like the case where the original object definition + gets returned. + + + + Register the specified for the given + + + + + Constants defining the structure and values associated with the + Spring.NET XML object definition format. + + Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + + + + Value of a boolean attribute that represents + . + + +

+ Anything else represents . +

+
+
+ + + Signifies that a default value is to be applied. + + + + + Defines an external XML object definition resource. + + + + + Specifies the relative path to an external XML object definition + resource. + + + + + Defines an alias for an object definition. + + + + + Specifies the alias of an object definition. + + + + + Specifies the default lazy initialization mode. + + + + + Specifies the default dependency checking mode. + + + + + Specifies the default autowire mode. + + + + + Specifies the default collection merge mode. + + + + + Defines a single named object. + + + + + Element containing informative text describing the purpose of the + enclosing element. + + +

+ Always optional. +

+

+ Used primarily for user documentation of XML object definition + documents. +

+
+
+ + + Specifies a . + + +

+ Does not have to be fully assembly qualified, but it is recommended + that the names of one's objects are + specified explicitly. +

+
+
+ + + The name or alias of the parent object definition that a child + object definition inherits from. + + + + + Objects can be identified by an id, to enable reference checking. + + +

+ There are constraints on a valid XML id: if you want to reference + your object in .NET code using a name that's illegal as an XML id, + use the optional "name" attribute + (). + If neither given, the objects name is + used as id. +

+
+
+ + + Can be used to create one or more aliases illegal in an id. + + +

+ Multiple aliases can be separated by any number of spaces, + semicolons, or commas + (). +

+

+ Always optional. +

+
+
+ + + Is this object a "singleton" (one shared instance, which will + be returned by all calls to + with the id), or a + "prototype" (independent instance resulting from each call to + ). + + +

+ Singletons are most commonly used, and are ideal for multi-threaded + service objects. +

+
+ +
+ + + Controls object scope. Only applicable to ASP.NET web applications. + + +

+ Scope can be defined as either application, session or request. It + defines when "singleton" instances are initialized, but has no + effect on prototype definitions. +

+
+
+ + + The names of the objects that this object depends on being + initialized. + + +

+ The object factory will guarantee that these objects + get initialized before this object definition. +

+ + Dependencies are normally expressed through object properties or + constructor arguments. This property should just be necessary for + other kinds of dependencies such as statics (*ugh*) or database + preparation on startup. + +
+
+ + + Optional attribute for the name of the custom initialization method + to invoke after setting object properties. + + +

+ The method must have no arguments. +

+
+
+ + + Optional attribute for the name of the custom destroy method to + invoke on object factory shutdown. + + +

+ Valid destroy methods have either of the following signatures... + + void MethodName() + void MethodName(bool force) + +

+ + Only invoked on singleton objects! + +
+
+ + + A constructor argument : the constructor-arg tag can have an + optional type attribute, to specify the exact type of the + constructor argument + + +

+ Only needed to avoid ambiguities, e.g. in case of 2 single + argument constructors that can both be converted from a + . +

+
+
+ + + The constructor-arg tag can have an optional index attribute, + to specify the exact index in the constructor argument list. + + +

+ Only needed to avoid ambiguities, e.g. in case of 2 arguments of + the same type. +

+
+
+ + + The constructor-arg tag can have an optional named parameter + attribute, to specify a named parameter in the constructor + argument list. + + + + + Is this object "abstract", i.e. not meant to be instantiated itself + but rather just serving as parent for concrete child object + definitions? + + +

+ Default is . Specify + to tell the object factory to not try to instantiate that + particular object in any case. +

+
+
+ + + A property definition : object definitions can have zero or more + properties. + + +

+ Spring.NET supports primitives, references to other objects in the + same or related factories, lists, dictionaries, and name value + collections. +

+
+
+ + + A reference to another managed object or static + . + + + + + ID refs must specify a name of the target object. + + + + + A reference to the name of another managed object in the same + context. + + + + + A reference to the name of another managed object in the same + context. + + +

+ Local references, using the "local" attribute, have to use object + ids; they can be checked by a parser, thus should be preferred for + references within the same object factory XML file. +

+
+
+ + + Alternative to type attribute for factory-method usage. + + +

+ If this is specified, no type attribute should be used. This should + be set to the name of an object in the current or ancestor + factories that contains the relevant factory method. This allows + the factory itself to be configured using Dependency Injection, and + an instance (rather than static) method to be used. +

+
+
+ + + Optional attribute specifying the name of a factory method to use + to create this object. + + +

+ Use constructor-arg elements to specify arguments to the factory + method, if it takes arguments. Autowiring does not apply to + factory methods. +

+

+ If the "type" attribute is present, the factory method will be a + static method on the type specified by the "type" attribute on + this object definition. Often this will be the same type as that + of the constructed object - for example, when the factory method + is used as an alternative to a constructor. However, it may be on + a different type. In that case, the created object will *not* be + of the type specified in the "type" attribute. This is analogous + to behaviour. +

+

+ If the "factory-object" attribute is present, the "type" attribute + is not used, and the factory method will be an instance method on + the object returned from a + + call with the specified object name. The factory object may be + defined as a singleton or a prototype. +

+

+ The factory method can have any number of arguments. Use indexed + constructor-arg elements in conjunction with the factory-method + attribute. +

+

+ Setter Injection can be used in conjunction with a factory method. + Method Injection cannot, as the factory method returns an instance, + which will be used when the container creates the object. +

+
+
+ + + A list can contain multiple inner object, ref, collection, or + value elements. + + +

+ Lists are untyped, pending generics support, although references + will be strongly typed. +

+

+ A list can also map to an array type. The necessary conversion is + automatically performed by the + . +

+
+
+ + + A set can contain multiple inner object, ref, collection, or value + elements. + + +

+ Sets are untyped, pending generics support, although references + will be strongly typed. +

+
+
+ + + A Spring.NET map is a mapping from a string key to object (a .NET + ). + + +

+ Dictionaries may be empty. +

+
+
+ + + A lookup key (for a dictionary or name / value collection). + + + + + A lookup key (for a dictionary or name / value collection). + + + + + Contains a string representation of a value. + + +

+ This is used by name-value, ctor argument, and property elements. +

+
+
+ + + Contains delimiters that should be used to split delimited string values. + + +

+ This is used by name-value element. +

+
+
+ + + A reference to another objects. + + +

+ Used as a convenience shortcut on property and constructor-arg + elements to refer to other objects. +

+
+
+ + + Contains a string representation of an expression. + + +

+ This is used by ctor argument and property elements. +

+
+
+ + + A map entry can be an inner object, ref, collection, or value. + + +

+ The name of the property is given by the "key" attribute. +

+
+
+ + + Contains a string representation of a property value. + + +

+ The property may be a string, or may be converted to the + required using the + + machinery. This makes it possible for application developers to + write custom + implementations that can convert strings to objects. +

+ + This is recommended for simple objects only. Configure more complex + objects by setting properties to references to other objects. + +
+
+ + + Contains a string representation of an expression. + + + + + Denotes value. + + +

+ Necessary because an empty "value" tag will resolve to an empty + , which will not be resolved to + value unless a special + does so. +

+
+
+ + + 'name-values' elements differ from dictionary elements in that + values must be strings. + + +

+ May be empty. +

+
+
+ + + Element content is the string value of the property. + + +

+ The "key" attribute is the name of the property. +

+
+
+ + + The lazy initialization mode for an individual object definition. + + + + + The dependency checking mode for an individual object definition. + + + + + Defines a subscription to one or more events published by one or + more event sources. + + + + + The name of an event handling method. + + +

+ Defaults to On${event}. + Note : this default will probably change before the first 1.0 + release. +

+
+
+ + + The name of an event. + + + + + The autowiring mode for an individual object definition. + + + + + Shortcut alternative to specifying a key element in a + dictionary entry element with <ref object="..."/>. + + + + + Shortcut alternative to specifying a value element in a + dictionary entry element with <ref object="..."/>. + + + + + Specify if the collection values should be merged with the parent. + + + + + The string of characters that delimit object names. + + + + + A lookup method causes the IoC container to override a given method and return + the object with the name given in the attendant object attribute. + + +

+ This is a form of Method Injection. +

+

+ It's particularly useful as an alternative to implementing the + interface, + in order to be able to make + + calls for non-singleton instances at runtime. In this case, Method Injection + is a less invasive alternative. +

+
+
+ + + The name of a lookup method. This method must take no arguments. + + + + + The name of the object in the IoC container that the lookup method + must resolve to. + + +

+ Often this object will be a prototype, in which case the lookup method + will return a distinct instance on every invocation. This is useful + for single-threaded objects. +

+
+
+ + + A replaced method causes the IoC container to override a given method + with an (arbitrary) implementation at runtime. + + +

+ This (again) is a form of Method Injection. +

+
+
+ + + Name of the method whose implementation should be replaced by the + IoC container. + + +

+ If this method is not overloaded, there's no need to use arg-type + subelements. +

+

+ If this method is overloaded, arg-type subelements must be + used for all override definitions for the method. +

+
+
+ + + The object name of an implementation of the + interface. + + +

+ This may be a singleton or prototype. If it's a prototype, a new + instance will be used for each method replacement. Singleton usage + is the norm. +

+
+
+ + + Subelement of replaced-method identifying an argument for a + replaced method in the event of method overloading. + + + + + + Specification of the of an overloaded method + argument as a . + + +

+ For convenience, this may be a substring of the FQN. E.g. all the following would match + : +

+

+ + + System.String + + + string + + + str + + +

+
+ +
+ + + Check everything. + + + + + Just check primitive (string, int, etc) values. + + + + + Check object references. + + + + + Autowire by name. + + + + + Autowire by . + + + + + Autowiring by constructor. + + + + + The autowiring strategy is to be determined by introspection + of the object's . + + + + + Creates a new instance of the + + class. + + +

+ This is a utility class, and as such has no publicly visible + constructors. +

+
+
+ + + Stateful class used to parse XML object definitions. + + Not all parsing code has been refactored into this class. See + BeanDefinitionParserDelegate in Java for how this class should evolve. + Rob Harrop + Juergen Hoeller + Rod Johnson + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + The reader context. + + + + Initializes a new instance of the class. + + The reader context. + The root element of the definition document to parse + + + + Initialize the default lazy-init, dependency check, and autowire settings. + + The root element + + + + Determines whether the Spring object namespace is equal to the the specified namespace URI. + + The namespace URI. + + true if is the default Spring namespace; otherwise, false. + + + + + Decorates the object definition if required. + + The element. + The holder. + + + + + Parse a standard object definition into a + , + including object name and aliases. + + The element containing the object definition. + + The parsed object definition wrapped within an + + instance. + + + + Object elements specify their canonical name via the "id" attribute + and their aliases as a delimited "name" attribute. + + + If no "id" is specified, uses the first name in the "name" attribute + as the canonical name, registering all others as aliases. + + + + + + Parse a standard object definition into a + , + including object name and aliases. + + The element containing the object definition. + The containing object definition if is a nested element. + + The parsed object definition wrapped within an + + instance. + + + + Object elements specify their canonical name via the "id" attribute + and their aliases as a delimited "name" attribute. + + + If no "id" is specified, uses the first name in the "name" attribute + as the canonical name, registering all others as aliases. + + + + + + Create an instance from the given and . + + + This method may be used as a last resort to post-process an object definition before it gets added to the registry. + + + + + Allows deriving classes to post process the name and aliases for the current element. By default + does nothing and returns the unmodified . + + + The list passed in may be modified by an implementation of this method to reflect special needs. + + the object name obtained by the default algorithm from 'id' and 'name' attributes so far. + the object aliases obtained by the default algorithm from 'name' attribute so far. + the currently processed element. + the containing object definition, may be null + the new object name to be used. + + + + Validate that the specified object name and aliases have not been used already. + + + + + Parses an element in a custom namespace. + + + the parsed object definition or null if not supported by the corresponding parser. + + + + Parses an element in a custom namespace. + + + if a nested element, the containing object definition + the parsed object definition or null if not supported by the corresponding parser. + + + + Given a string containing delimited object names, returns + a string array split on the object name delimeter. + + + The string containing delimited object names. + + + A string array split on the object name delimeter. + + + + + + Determines whether the string represents a 'true' boolean value. + + The value. + + true if is 'true' string value; otherwise, false. + + + + + Convenience method to create a builder for a root object definition. + + Name of the object type. + A builder for a root object definition. + + + + Convenience method to create a builder for a root object definition. + + Type of the object. + a builder for a root object definition + + + + Returns the value of the element's attribute or null, if the attribute is not specified. + + + This is a helper for bypassing the behavior of + to return if the attribute does not exist. + + + + + Returns the value of the element's attribute or , + if the attribute is not specified. + + + This is a helper for bypassing the behavior of + to return if the attribute does not exist. + + + + + Report a parser error. + + + + + Gets the defaults definition object, or null if the + default have not yet been initialized. + + The defaults. + + + + Gets the reader context. + + The reader context. + + + + Creates an instance + populated with the object definitions supplied in the configuration + section. + + +

+ Applications will typically want to use an + , and instantiate it + via the use of the + class (which is similar in functionality to this class). This class is + provided for those times when only an + is required. +

+ Creates an instance of the class XmlObjectFactory +
+ +

+ +

+
+ Mark Pollack (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a + instance populated with the object definitions supplied in the + configuration section. + + + The configuration settings in a corresponding parent configuration + section. + + + The configuration context when called from the ASP.NET + configuration system. Otherwise, this parameter is reserved and + is . + + + The for the section. + + + A instance + populated with the object definitions supplied in the configuration + section. + + + + + Default implementation of the + interface. + + +

+ Parses object definitions according to the standard Spring.NET schema. +

+

+ This schema is typically located at + http://www.springframework.net/xsd/spring-objects.xsd. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + The namespace URI for the standard Spring.NET object definition schema. + + + + + The shared instance for this class (and derived classes). + + + + + Invoked by after construction but before any + elements have been parsed. + + This is a NoOp + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + The element to be parsed. + TThe object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + The primary object definition. + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+
+ + + Parse the specified element and register any resulting + IObjectDefinitions with the IObjectDefinitionRegistry that is + embedded in the supplied ParserContext. + + The element to be parsed into one or more IObjectDefinitions + The object encapsulating the current state of the parsing + process. + + The primary IObjectDefinition (can be null as explained above) + + + Implementations should return the primary IObjectDefinition + that results from the parse phase if they wish to used nested + inside (for example) a <property> tag. + Implementations may return null if they will not + be used in a nested scenario. + + + + + + Parse the specified XmlNode and decorate the supplied ObjectDefinitionHolder, + returning the decorated definition. + + The XmlNode may either be an XmlAttribute or an XmlElement, depending on + whether a custom attribute or element is being parsed. + Implementations may choose to return a completely new definition, + which will replace the original definition in the resulting IApplicationContext/IObjectFactory. + + The supplied ParserContext can be used to register any additional objects needed to support + the main definition. + + The source element or attribute that is to be parsed. + The current object definition. + The object encapsulating the current state of the parsing + process. + The decorated definition (to be registered in the IApplicationContext/IObjectFactory), + or simply the original object definition if no decoration is required. A null value is strickly + speaking invalid, but will leniently treated like the case where the original object definition + gets returned. + + + + Loads external XML object definitions from the resource described by the supplied + . + + The XML element describing the resource. + The parser context. + + If the resource could not be imported. + + + + Parses an event listener definition. + + The name associated with the object that the event handler is being defined on. + + The events being populated. + + The element containing the event listener definition. + + + The namespace-aware parser. + + + + + Parse an object definition and register it with the object factory.. + + The element containing the object definition. + The parser context. + + + + + Parse an object definition and register it with the object factory.. + + The element containing the object definition. + The parser context. + + + + + Parse an object definition and register it with the object factory.. + + The element containing the object definition. + The parser context. + + + + + Parse a standard object definition into a + , + including object name and aliases. + + The element containing the object definition. + The parser context. + if set to true if we are processing an inner + object definition. + + The object (definition) wrapped within an + + instance. + + +

+ Object elements specify their canonical name via the "id" attribute + and their aliases as a delimited "name" attribute. +

+

+ If no "id" is specified, uses the first name in the "name" attribute + as the canonical name, registering all others as aliases. +

+
+
+ + + Calculates an id for an object definition. + + +

+ Called when an object definition has not been explicitly defined + with an id. +

+
+ + The element containing the object definition. + + + The list of names defined for the object; may be + or even empty. + + + A calculated object definition id. + +
+ + + Parse a standard object definition. + + The element containing the object definition. + The id of the object definition. + parsing state holder + The object (definition). + + + + Parse method override argument subelements of the given object element. + + + + + Parse element and add parsed element to + + + + + Parse element and add parsed element to + + + + + Parse constructor argument subelements of the given object element. + + + + + Parse event handler subelements of the given object element. + + + + + Parse property value subelements of the given object element. + + + The name of the object (definition) associated with the property element (s) + + + The element containing the top level object definition. + + + The namespace-aware parser. + + + The property (s) associated with the object (definition). + + + + + Parse a constructor-arg element. + + + The name of the object (definition) associated with the ctor arg. + + + The list of constructor args associated with the object (definition). + + + The name of the element containing the ctor arg definition. + + + The namespace-aware parser. + + + + + Parse a property element. + + + The name of the object (definition) associated with the property. + + + The list of properties associated with the object (definition). + + + The name of the element containing the property definition. + + + The namespace-aware parser. + + + + + Get the value of a property element (may be a list). + +

+ Please note that even though this method is named GetPropertyValue, + it is called by both the property and constructor argument element + handlers. +

+
+ The property element. + + The name of the object associated with the property. + + + The namespace-aware parser. + +
+ + + Parse a value, ref or collection subelement of a property element. + + + Subelement of property element; we don't know which yet. + + + The name of the object (definition) associated with the top level property. + + + The namespace-aware parser. + + + + + Gets a list definition. + + + The element describing the list definition. + + + The name of the object (definition) associated with the list definition. + + + The namespace-aware parser. + + The list definition. + + + + Gets a set definition. + + + The element describing the set definition. + + + The name of the object (definition) associated with the set definition. + + + The namespace-aware parser. + + The set definition. + + + + Gets a dictionary definition. + + The element describing the dictionary definition. + The name of the object (definition) associated with the dictionary definition. + The namespace-aware parser. + The dictionary definition. + + + + Selects sub-elements with a given + name. + + +

+ Uses a namespace manager if necessary. +

+
+ + The element to be searched in. + + + The name of the child nodes to look for. + + + The child s of the supplied + with the supplied + . + +
+ + + Selects a single sub-element with a given + name. + + +

+ Uses a namespace manager if necessary. +

+
+ + The element to be searched in. + + + The name of the child node to look for. + + + The first child of the supplied + with the supplied + . + +
+ + + Gets a name value collection mapping definition. + + + The element describing the name value collection mapping definition. + + + The name of the object (definition) associated with the + name value collection mapping definition. + + the context carrying parsing state information + The name value collection definition. + + + + Returns the text of the supplied , + or the empty string value if said is empty. + + +

+ If the supplied is , + then the empty string value will be returned. +

+
+
+ + + Strips the dependency check value out of the supplied string. + + +

+ If the supplied is an invalid dependency + checking mode, the invalid value will be logged and this method will + return the value. + No exception will be raised. +

+
+ + The string containing the dependency check value. + + The dependency check value. + +
+ + + Strips the autowiring mode out of the supplied string. + + +

+ If the supplied is an invalid autowiring mode, + the invalid value will be logged and this method will return the + value. No exception will be raised. +

+
+ + The string containing the autowiring mode definition. + + The autowiring mode. + +
+ + + Given a string containing delimited object names, returns + a string array split on the object name delimeter. + + + The string containing delimited object names. + + + A string array split on the object name delimeter. + + + + + + Context that gets passed along an object definition parsing process, encapsulating + all relevant configuraiton as well as state. + + + + + Initializes a new instance of the class. + + The parser helper. + + + + Initializes a new instance of the class. + + The parser helper. + The containing object definition. + + + + Initializes a new instance of the class. + + The reader context. + The parser helper. + + + + Initializes a new instance of the class. + + The reader context. + The parser helper. + The containing object definition. + + + + Gets the reader context. + + The reader context. + + + + Gets the registry. + + The registry. + + + + Gets the parser helper. + + The parser helper. + + + + Gets the containing object definition. + + The containing object definition. + + + + Gets a value indicating whether this instance is nested. + + true if this instance is nested; otherwise, false. + + + + Gets a value indicating whether this instance is default lazy init. + + + true if this instance is default lazy init; otherwise, false. + + + + + Represents the replacement of a method on a managed object by the IoC + container. + + +

+ Note that this mechanism is not intended as a generic means of + inserting crosscutting code: use AOP for that. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + + The name of the method that is to be overridden. + + + The object name of the + instance in the surrounding IoC container. + + + If either of the supplied arguments is or + contains only whitespace character(s). + + + + + Add a fragment of a instance's + such as 'Exception or System.Excep to identify an argument + for a dependency injected method. + + + A (sub) string of a instance's . + + + If the supplied is or + contains only whitespace character(s). + + + + + + Does this + match the supplied ? + + The method to be checked. + + if this override matches the supplied . + + + If the supplied is . + + + + + A that represents the current + . + + + A that represents the current + . + + + + + The object name of the + instance in the surrounding IoC container. + + + + + Object definition reader for Spring's default XML object definition format. + + +

+ Typically applied to a + instance. +

+

+ This class registers each object definition with the given object factory superclass, + and relies on the latter's implementation of the + interface. +

+

+ It supports singletons, prototypes, and references to either of these kinds of object. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Creates a new instance of the + class. + + + The + instance that this reader works on. + + + + + Creates a new instance of the + class. + + + The + instance that this reader works on. + + + The to be used for parsing. + + + + + Creates a new instance of the + class. + + + The + instance that this reader works on. + + + The to be used for parsing. + + the to use for creating new s + + + + Load object definitions from the supplied XML . + + + The XML resource for the object definitions that are to be loaded. + + + The number of object definitions that were loaded. + + + In the case of loading or parsing errors. + + + + + Actually load object definitions from the specified XML file. + + The input stream to read from. + The resource for the XML data. + + + + + Validation callback for a validating XML reader. + + The source of the event. + Any data pertinent to the event. + + + + Register the object definitions contained in the given DOM document. + + The DOM document. + + The original resource from where the + was read. + + + The number of object definitions that were registered. + + + In case of parsing errors. + + + + + Creates the to use for actually + reading object definitions from an XML document. + + Default implementation instantiates the specified + or if no reader type is specified. + + + + + Creates the to be passed along + during the object definition reading process. + + The underlying that is currently processed. + A new + + + + Create a instance for handling custom namespaces. + + + TODO (EE): make protected virtual, see remarks on + + + + + The to be used for parsing. + + + + + Sets the IObjectDefinitionDocumentReader implementation to use, responsible for + the actual reading of the XML object definition document.stype of the document reader. + + The type of the document reader. + + + + Specify a to use. If none is specified a default + instance will be created by + + + + + Specify a for creating instances of . + + + + + For retrying the parse process + + + + + Convenience extension of + + that reads object definitions from an XML document or element. + + +

+ Delegates to + + underneath; effectively equivalent to using a + for a + . +

+ + objects doesn't need to be the root element of + the XML document: this class will parse all object definition elements in the + XML stream. + +

+ This class registers each object definition with the + + superclass, and relies on the latter's implementation of the + interface. It supports + singletons, prototypes and references to either of these kinds of object. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + +
+ + + Creates a new instance of the class, + with the given resource, which must be parsable using DOM. + + + The XML resource to load object definitions from. + + + In the case of loading or parsing errors. + + + + + Creates a new instance of the class, + with the given resource, which must be parsable using DOM. + + + The XML resource to load object definitions from. + + Flag specifying whether to make this object factory case sensitive or not. + + In the case of loading or parsing errors. + + + + + Creates a new instance of the class, + with the given resource, which must be parsable using DOM, and the + given parent factory. + + + The XML resource to load object definitions from. + + The parent object factory (may be ). + + In the case of loading or parsing errors. + + + + + Creates a new instance of the class, + with the given resource, which must be parsable using DOM, and the + given parent factory. + + + The XML resource to load object definitions from. + + Flag specifying whether to make this object factory case sensitive or not. + The parent object factory (may be ). + + In the case of loading or parsing errors. + + + + + Gets object definition reader to use. + + + + + Extension of specific to use with an XmlObjectDefinitionReader. + Provides access to configured in + + + + + The maximum length of any XML fragment displayed in the error message + reporting. + + +

+ Hopefully this will display enough context so that a user + can pinpoint the cause of the error. +

+
+
+ + + Initializes a new instance of the class. + + The resource. + The reader. + + + + Initializes a new instance of the class. + + The resource. + The reader. + The factory to use for creating new instances. + + + + Generates the name of the object. + + The object definition. + the generated object name + + + + Registers the name of the with generated. + + The object definition. + the generated object name + + + + Reports a parse error by loading a + with helpful contextual + information and throwing said exception. + + +

+ Derived classes can of course override this method in order to implement + validators capable of displaying a full list of errors found in the + definition. +

+
+ + The node that triggered the parse error. + + + The name of the object that triggered the exception. + + + A message about the exception. + + + Always throws an instance of this exception class, that will + contain helpful contextual infomation about the parse error. + + +
+ + + Reports a parse error by loading a + with helpful contextual + information and throwing said exception. + + +

+ Derived classes can of course override this method in order to implement + validators capable of displaying a full list of errors found in the + definition. +

+
+ + The node that triggered the parse error. + + + The name of the object that triggered the exception. + + + A message about the error. + + + The root cause of the parse error (if any - may be ). + + + Always throws an instance of this exception class, that will + contain helpful contextual infomation about the parse error. + +
+ + + This method can be overwritten in order to implement validators + capable of displaying a full list of errors found in the definition. + + + The node that triggered the parse error. + + + A message about the exception. + + + + + Gets the reader. + + The reader. + + + + Gets the resource loader. + + The resource loader. + + + + Gets the registry. + + The registry. + + + + Gets or sets the object definition factory. + + The object definition factory. + + + + Get the instance to lookup parsers for custom namespaces. + + + + + Exception thrown if an + is not fully + initialized, for example if it is involved in a circular reference. + + +

+ This is usually indicated by any of the variants of the + + method returning . +

+

+ A circular reference with an + cannot be solved by eagerly caching singleton instances (as is the + case with normal objects. The reason is that every + needs to be fully + initialized before it can return the created object, while only specific + normal objects need to be initialized - that is, if a collaborating object + actually invokes them on initialization instead of just storing the reference. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Thrown when an + encounters an error when attempting to create an object from an object + definition. + + Juergen Hoeller + Rick Evans (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The description of the resource associated with the object. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the + class. + + + The description of the resource associated with the object. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The name of the object that triggered the exception (if any). + + + + + The description of the resource associated with the object (if any). + + + + + Describes the creation failure trace of this exception. + + + + + Creates a new instance of the + FactoryObjectNotInitializedException class. + + + + + Creates a new instance of the FactoryObjectNotInitializedException class. + + + A message about the exception. + + + + + Creates a new instance of the FactoryObjectNotInitializedException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + FactoryObjectCircularReferenceException class. + + + The name of the object that triggered the exception. + + + A message about the exception. + + + + + Creates a new instance of the FactoryObjectCircularReferenceException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when an + is asked for an object instance name for which it cannot find a definition. + + Rod Johnson + Rick Evans (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + Name of the missing object. + + + A further, detailed message describing the problem. + + + + + Initializes a new instance of the class. + + The required type of the object. + A description of the originating dependency. + A message describing the problem. + + + + Creates a new instance of the + class. + + + The of the missing object. + + + A further, detailed message describing the problem. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + Return the required of object, if it was a + lookup by that failed. + + + + + Return the name of the missing object, if it was a lookup by name that + failed. + + + + + Thrown in case of a reference to an object that is currently in creation. + + +

+ Typically happens when constructor autowiring matches the currently + constructed object. +

+
+ Juergen Hoeller + Rick Evans +
+ + + The default error message text to be used, if none is specified. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the + class. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The description of the resource associated with the object. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + + + Creates a new instance of the + class. + + + The description of the resource associated with the object. + + + A message about the exception. + + + The name of the object that triggered the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectCurrentlyInCreationException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when an + encounters an error when attempting to parse an object + definition. + + Federico Spinazzi (.NET) + + + + Creates a new instance of the ObjectDefinitionException class. + + + + + Creates a new instance of the ObjectDefinitionException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectDefinitionException class. + + + The value of the xml class attribute thet can be resolved + as a type + + + + + Creates a new instance of the ObjectDefinitionException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The message about the exception. + + + + + Convenience methods operating on object factories, returning object instances, + names, or counts. + + +

+ The nesting hierarchy of an object factory is taken into account by the various methods + exposed by this class. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + Used to dereference an + and distinguish it from managed objects created by the factory. + + +

+ For example, if the managed object identified as foo is a + factory, getting &foo will return the factory, not the + instance returned by the factory. +

+
+
+ + + The string used as a separator in the generation of synthetic id's + for those object definitions explicitly that aren't assigned one. + + +

+ If a name or parent object definition + name is not unique, "#1", "#2" etc will be appended, until such + time that the name becomes unique. +

+
+
+ + + Creates a new instance of the + class. + + +

+ This is a utility class, and as such has no publicly visible + constructors. +

+
+
+ + + Count all object definitions in any hierarchy in which this + factory participates. + + +

+ Includes counts of ancestor object factories. +

+

+ Objects that are "overridden" (specified in a descendant factory + with the same name) are counted only once. +

+
+ The object factory. + + The count of objects including those defined in ancestor factories. + +
+ + + Return all object names in the factory, including ancestor factories. + + The object factory. + The array of object names, or an empty array if none. + + + + Get all object names for the given type, including those defined in ancestor + factories. + + +

+ Will return unique names in case of overridden object definitions. +

+

+ Does consider objects created by s + if is set to true, + which means that s will get initialized. +

+
+ + If this isn't also an + , + this method will return the same as it's own + + method. + + + The that objects must match. + + + Whether to include prototype objects too or just singletons + (also applies to instances). + + + Whether to include instances + too or just normal objects. + + + The array of object names, or an empty array if none. + +
+ + + Get all object names for the given type, including those defined in ancestor + factories. + + +

+ Will return unique names in case of overridden object definitions. +

+

+ Does consider objects created by s, + or rather it considers the type of objects created by + (which means that + s will be instantiated). +

+
+ + If this isn't also an + , + this method will return the same as it's own + + method. + + + The that objects must match. + + + The array of object names, or an empty array if none. + +
+ + + Return all objects of the given type or subtypes, also picking up objects + defined in ancestor object factories if the current object factory is an + . + + +

+ The return list will only contain objects of this type. + Useful convenience method when we don't care about object names. +

+
+ The object factory. + The of object to match. + + Whether to include prototype objects too or just singletons + (also applies to instances). + + + Whether to include instances + too or just normal objects. + + + If the objects could not be created. + + + The of object instances, or an + empty if none. + +
+ + + Return a single object of the given type or subtypes, also picking up objects defined + in ancestor object factories if the current object factory is an + . + + +

+ Useful convenience method when we expect a single object and don't care + about the object name. +

+
+ The object factory. + The of object to match. + + Whether to include prototype objects too or just singletons + (also applies to instances). + + + Whether to include instances + too or just normal objects. + + + If the object could not be created. + + + If more than one instance of an object was found. + + + A single object of the given type or subtypes. + +
+ + + Return a single object of the given type or subtypes, not looking in + ancestor factories. + + +

+ Useful convenience method when we expect a single object and don't care + about the object name. +

+
+ The object factory. + The of object to match. + + Whether to include prototype objects too or just singletons + (also applies to instances). + + + Whether to include instances + too or just normal objects. + + + If the object could not be created. + + + If not exactly one instance of an object was found. + + + A single object of the given type or subtypes. + +
+ + + Return a single object of the given type or subtypes, not looking in + ancestor factories. + + +

+ Useful convenience method when we expect a single object and don't care + about the object name. + This version of ObjectOfType automatically includes prototypes and + instances. +

+
+ The object factory. + The of object to match. + + If the object could not be created. + + + If not exactly one instance of an object was found. + + + A single object of the given type or subtypes. + +
+ + + Return the object name, stripping out the factory dereference prefix if necessary. + + The name of the object. + The object name sans any factory dereference prefix. + + + + Given an (object) name, builds a corresponding factory object name such that + the return value can be used as a lookup name for a factory object. + + + The name to be used to build the resulting factory object name. + + + The transformed into its factory object name + equivalent. + + + + + + + Is the supplied a factory dereference? + + +

+ That is, does the supplied begin with + the + ? +

+
+ The name to check. + + if the supplied is a + factory dereference; if not, or the + aupplied is or + consists solely of the + + value. + + +
+ + + Exception that an object implementation is suggested to throw if its own + factory-aware initialization code fails. + thrown by object factory methods + themselves should simply be propagated as-is. + + +

+ Note that non-factory-aware initialization methods like AfterPropertiesSet () + or a custom "init-method" can throw any exception. +

+
+ Juergen Hoeller + Rick Evans (.NET) +
+ + + Creates a new instance of the ObjectInitializationException class. + + + + + Creates a new instance of the ObjectInitializationException class. + + + A message about the exception. + + + + + Creates a new instance of the ObjectInitializationException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectInitializationException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Thrown in response to an attempt to lookup a factory object, and + the object identified by the lookup key is not a factory. + + +

+ An object is a factory if it implements (either directly or indirectly + via inheritance) the + interface. +

+
+ Rod Johnson + Rick Evans (.NET) +
+ + + Thrown when an object doesn't match the required . + + Rod Johnson + Rick Evans (.NET) + + + + Creates a new instance of the ObjectNotOfRequiredTypeException class. + + + + + Creates a new instance of the ObjectNotOfRequiredTypeException class. + + + A message about the exception. + + + + + Creates a new instance of the ObjectNotOfRequiredTypeException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ObjectNotOfRequiredTypeException class. + + + Name of the object requested. + + + The required of the actual object + instance that was retrieved. + + + The instance actually returned, whose class did not match the + expected . + + + + + Creates a new instance of the ObjectNotOfRequiredTypeException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The actual of the actual object + instance that was retrieved. + + + + + The required of the actual object + instance that was retrieved. + + + + + The instance actually returned, whose class did not match the + expected . + + + + + The name of the object requested. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The name of the object that was being retrieved from the factory. + + + The object instance that was retrieved. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when an object depends on other objects or simple properties + that were not specified in the object factory definition, although dependency + checking was enabled. + + Rod Johnson + Juergen Hoeller + Rick Evans (.NET) + + + + Creates a new instance of the UnsatisfiedDependencyException class. + + + + + Creates a new instance of the UnsatisfiedDependencyException class. + + + A message about the exception. + + + + + Creates a new instance of the UnsatisfiedDependencyException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the UnsatisfiedDependencyException class. + + + The description of the resource associated with the object. + + + The name of the object that has the unsatisfied dependency. + + + The constructor argument index at which the dependency is + unsatisfied. + + + The of the constructor argument at + which the dependency is unsatisfied. + + + A message about the exception. + + + + + Creates a new instance of the UnsatisfiedDependencyException class. + + + The description of the resource associated with the object. + + + The name of the object that has the unsatisfied dependency. + + + The name identifying the property on which the dependency is + unsatisfied. + + + A message about the exception. + + + + + Creates a new instance of the UnsatisfiedDependencyException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Base class implementation for classes that describe an event handler. + + Rick Evans + + + + Describes an event handler. + + Rick Evans + + + + Wires up the specified handler to the named event on the + supplied event source. + + + The object (an object instance, a , etc) + exposing the named event. + + + The handler for the event (an object instance, a + , etc). + + + + + The source of the event. + + + + + The name of the method that is going to handle the event. + + + + + The name of the event that is being wired up. + + + + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Creates a new instance of the + class. + + + The object (possibly unresolved) that is exposing the event. + + + The name of the method on the handler that is going to handle the event. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Wires up the specified handler to the named event on the + supplied event source. + + + The object (an object instance, a , etc) + exposing the named event. + + + The handler for the event (an object instance, a + , etc). + + + + + Returns a stringified representation of this object. + + A stringified representation of this object. + + + + The source of the event (may be unresolved, as in the case + of a + value). + + + + + The name of the method that is going to handle the event. + + + + + The name of the event that is being wired up. + + + + + Convenience base class for implementations. + + + + + Abstracts the state sharing strategy used + by + + Erich Eichinger + + + + Indicate, whether the given instance can be served by this factory + + the instance to serve state + the name of the instance + + a boolean value indicating, whether state can + be served for the given instance or not. + + + + + Returns the shared state for the given instance. + + the instance to obtain shared state for. + the name of this instance + a dictionary containing shared state for or null. + + + + Gets a dictionary acc. to the type of . + If no dictionary is found, create it according to + + the instance to obtain shared state for + the name of the instance. + + A dictionary containing the 's state, + or null if no state can be served by this provider. + + + + + Creates a dictionary to hold the shared state identified by . + + a key to create the dictionary for. + a dictionary according to and . + + + + Indicate, whether the given instance will be served by this provider + + the instance to serve state + the name of the instance + + a boolean value indicating, whether state shall + be resolved for the given instance or not. + + + + + Create the key used for obtaining the state dictionary for . + + the instance to create the key for + the name of the instance. + + the key identifying the state dictionary to be used for + or null, if this state manager doesn't serve the given instance. + + + + Implementations may choose to return null from this method to indicate, + that they won't serve state for the given instance. + + + Note:Keys returned by this method are always treated case-sensitive! + + + + + + Create shared state dictionaries case-sensitive or case-insensitive? + + + + + A number indicating the priority of this ( for more). + + + + + Base class for all + implemenations that actually perform event wiring. + + Rick Evans + + + + Creates a new instance of the + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Creates a new instance of the + class. + + + The object (possibly unresolved) that is exposing the event. + + + The name of the method on the handler that is going to handle the event. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Wires up the specified handler to the named event on the + supplied event source. + + + The object (an object instance, a , etc) + exposing the named event. + + + The handler for the event (an object instance, a + , etc). + + + + + Gets the event handler. + + + The instance that is registering for the event notification. + + + Event metadata about the event. + + + The event handler. + + + + + Resolves the method metadata that describes the method that is to be used + as the argument to a delegate constructor. + + + The exposing the method. + + + The of the delegate (e.g. System.EventHandler). + + + The custom binding flags to use when searching for the method. + + The method metadata. + + If the method could not be found. + + + + + Describes an implementation + that autowires events to handler methods. + + Rick Evans + + + + Creates a new instance of the + class. + + + + + Wires up the specified handler to the named event on the supplied event source. + + + The object (an object instance, a , etc) + exposing the named event. + + + The handler for the event (an object instance, a , + etc). + + + + + The name of the method that is going to handle the event. + + + + + Performs the matching up of handler methods to one or more source events. + + +

+ This class merely marshals the matching of handler methods to the events exposed + by an event source, and then delegates to a concrete + implementation (such as + or + ) to do the heavy lifting of + actually wiring a handler method to an event. +

+

+ Note : the order in which handler's are wired up to events is non-deterministic. +

+
+
+ + + Creates a new instance of the + class. + + + The object exposing the event (s) being wired up. + + + The name of the event that is being wired up. + + + The object exposing the method (s) being wired to the event. + + + The name of the method that is going to handle the event. + + + + + Wires up events on the source to methods exposed on the handler. + + + + + Wires up the supplied event to any handler methods that match the event + signature. + + The event being wired up. + + + + Only replaces the first occurrence of the placeholder. + + The event whose name is going to be used. + + The method name customised for the name of the supplied event. + + + + + The object exposing the event (s) being wired up. + + + + + The object exposing the method (s) being wired to an event source. + + + + + The of the object that is handling any events. + + + + + The name of the method that is going to handle the event. + + + + + The name of the event that is being wired up. + + + + + Serves shared state on a by-type basis. + + + + + Creates a new instance matching all types by default. + + + + + Creates a new instance matching only specified list of types. + + the list of types to serve. + + + + Indicate, whether the given instance will be served by this provider + + the instance to serve state + the name of the instance + + a boolean value indicating, whether state shall + be resolved for the given instance or not. + + + + + Returns the for the given . + + the instance to obtain the key for. + the name of the instance (ignored by this provider) + instance.GetType() if it matches the list. Null otherwise. + + This method will only be called if returned true previously. + + + + + Limit object types to be served by this state manager. + + + Only objects assignable to one of the types in this list + will be served state by this manager. + + + + + Describes an event handler for an object instance. + + Rick Evans + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The object (possibly unresolved) that is exposing the event. + + + The name of the method on the handler that is going to handle the event. + + + + + Gets the event handler. + + + The instance that is registering for the event notification. + + + Event metadata about the event. + + + The event handler. + + + + + Definition for sorting object instances by a property. + + Juergen Hoeller + Simon White (.NET) + + + + The name of the property to sort by. + + + + + Whether upper and lower case in string values should be ignored. + + + True if the sorting should be performed in a case-insensitive fashion. + + + + + If the sorting should be ascending or descending. + + + True if the sorting should be in the ascending order. + + + + + Mutable implementation of the + interface that + supports toggling the ascending value on setting the same property again. + + Juergen Hoeller + Jean-Pierre Pawlak + Simon White (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class using + the specified . + + + The to use + as a source for initial property values. + + + + + Creates a new instance of the + class. + + + The name of the property to sort by. + + + Whether upper and lower case in string values should be ignored. + + + Whether or not the sorting should be ascending or descending. + + + + + Creates a new instance of the + class. + + + Whether or not the + + property should be toggled if the same name is set on the + + property. + + + + + Overrides the default method + + + The object to test against this instance for equality. + + + True if the supplied is equal to this instance. + + + + + Overrides the default method. + + The hashcode for this instance. + + + + The name of the property to sort by. + + + + + Whether upper and lower case in string values should be ignored. + + + True if the sorting should be performed in a case-insensitive fashion. + + + + + If the sorting should be ascending or descending. + + + True if the sorting should be in the ascending order. + + + + + Performs a comparison of two objects, using the specified object property via + an . + + Juergen Hoeller + Jean-Pierre Pawlak + Simon White (.NET) + + + + Creates a new instance of the + class. + + + The to use for any + sorting. + + + If the supplied is . + + + + + Compares two objects and returns a value indicating whether one is less + than, equal to or greater than the other. + + The first object to compare. + The second object to compare. + + + + + Get the 's property + value for the given object. + + The object to get the property value for. + The property value. + + + + Sort the given according to the + given sort definition. + + + The to be sorted. + + The parameters to sort by. + + In the case of a missing property name. + + + If the supplied is . + + + + + Gets the to + use for any sorting. + + + The to use for + any sorting. + + + + + Describes an event handler for a static class method. + + Rick Evans + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The object (possibly unresolved) that is exposing the event. + + + The name of the method on the handler that is going to handle the event. + + + + + Gets the event handler. + + + The instance that is registering for the event notification. + + + Event metadata about the event. + + + The event handler. + + + + + The central interface of Spring.NET's low-level object infrastructure. + + +

+ Typically not directly used by application code but rather implicitly + via an . +

+

+ Implementing classes have the ability to get and set property values + (individually or in bulk), get property descriptors and query the + readability and writability of properties. +

+

+ This interface supports nested properties enabling the setting + of properties on subproperties to an unlimited depth. +

+

+ If a property update causes an exception, a + will be thrown. Bulk + updates continue after exceptions are encountered, throwing an exception + wrapping all exceptions encountered during the update. +

+

+ implementations can be used + repeatedly, with their "target" or wrapped object changed. +

+
+ Rod Johnson + Mark Pollack (.NET) +
+ + Get the value of a property. + + The name of the property to get the value of. May be nested. + + The value of the property. + + if the property isn't readable, or if the getting the value throws + an exception. + + + + + Get the for a particular + property. + + + The property to be retrieved. + + + The for the particular + property. + + + + + Get the for a particular property. + + + The property the of which is to be retrieved. + + + The for a particular property.. + + + + + Get all of the instances for + all of the properties of the wrapped object. + + + An array of instances. + + + + + Set a property value. + + +

+ This is the preferred way to update an individual property. +

+
+ The new property value. +
+ + + Set a property value. + + +

+ This method is provided for convenience only. The + + method is more powerful. +

+
+ + The name of the property to set value of. + + The new property value. +
+ + Set a number of property values in bulk. + +

+ This is the preferred way to perform a bulk update. +

+

+ Note that performing a bulk update differs from performing a single update, + in that an implementation of this class will continue to update properties + if a recoverable error (such as a vetoed property change or a type + mismatch, but not an invalid property name or the like) is + encountered, throwing a + containing + all the individual errors. This exception can be examined later to see all + binding errors. Properties that were successfully updated stay changed. +

+

+ Does not allow the setting of unknown fields. Equivalent to + + with an argument of false for the second parameter. +

+
+ + The collection of instances to + set on the wrapped object. + +
+ + + Set a number of property values in bulk with full control over behavior. + + +

+ Note that performing a bulk update differs from performing a single update, + in that an implementation of this class will continue to update properties + if a recoverable error (such as a vetoed property change or a type + mismatch, but not an invalid property name or the like) is + encountered, throwing a + containing + all the individual errors. This exception can be examined later to see all + binding errors. Properties that were successfully updated stay changed. +

+

Does not allow the setting of unknown fields. +

+
+ + The to set on the target object + + + Should we ignore unknown values (not found in the object!?) + +
+ + + The object wrapped by the wrapper (cannot be ). + + +

+ Implementations are required to allow the type of the wrapped + object to change. +

+
+ The object wrapped by this wrapper. +
+ + + Convenience method to return the + of the wrapped object. + + The of the wrapped object. + + + + A collection style container for + instances. + + Rod Johnson + Mark Pollack (.NET) + + + + Return the instance with the + given name. + + The name to search for. + the , or null if a + the with the supplied + did not exist in this collection. + + + + + Is there a instance for this + property name? + + The name to search for. + + True if there is a instance for + the supplied . + + + + + Return the difference (changes, additions, but not removals) of + property values between the supplied argument and the values + contained in the collection. + + +

+ Subclasses should also override Equals. +

+
+ The old property values. + + An containing any changes, or + an empty instance if there were + no changes. + +
+ + + Return an array of the objects + held in this object. + + An array of the objects held + in this object. + + + + + This interface should be implemented by classes that want to + have access to the shared state. + + +

+ Shared state is very useful if you have data that needs to be shared by all instances + of e.g. the same webform (or other IHttpHandlers). +

+

+ For example, Spring.Web.UI.Page class implements this interface, which allows + each page derived from it to cache localizalization resources and parsed data binding + expressions only once and then reuse the cached values, regardless of how many instances + of the page are created. +

+
+
+ + + Gets or sets the that should be used + to store shared state for this instance. + + + + + Default implementation of the + interface. + + +

+ Allows simple manipulation of properties, and provides constructors to + support deep copy and construction from a number of collection types such as + and + . +

+
+ Rod Johnson + Mark Pollack (.NET) + Rick Evans (.NET) +
+ + + The list of objects. + + + + + Creates a new instance of the + class. + + +

+ The returned instance is initially empty... + s can be added with the various + overloaded , + , + , + and + methods. +

+
+ + +
+ + + Creates a new instance of the + class. + + +

+ Deep copy constructor. Guarantees + references are independent, although it can't deep copy objects currently + referenced by individual objects. +

+
+
+ + + Creates a new instance of the + class. + + + The with property values + keyed by property name, which must be a . + + + + + Overloaded version of Add that takes a property name and a property value. + + + The name of the property. + + + The value of the property. + + + + + Add the supplied object, + replacing any existing one for the respective property. + + + The object to add. + + + + + Merges the value of the supplied 'new' with that of + the current if merging is supported and enabled. + + + The new pv. + The current pv. + The possibly merged PropertyValue + + + + Add all property values from the given + . + + + The map of property values, the keys of which must be + s. + + + + + Add all property values from the given + . + + + The list of s to be added. + + + + + Remove the given , if contained. + + + The to remove. + + + + + Removes the named , if contained. + + + The name of the property. + + + + + Modify a object held in this object. Indexed from 0. + + + + + Return the property value given the name. + + + The property name is checked in a case-insensitive fashion. + + + The name of the property. + + + The property value. + + + + + Does the container of properties contain one of this name. + + The name of the property to search for. + + True if the property is contained in this collection, false otherwise. + + + + + Return the difference (changes, additions, but not removals) of + property values between the supplied argument and the values + contained in the collection. + + Another property values collection. + + The collection of property values that are different than the supplied one. + + + + + Returns an that can iterate + through a collection. + + +

+ The returned is the + exposed by the + + property. +

+
+ + An that can iterate through a + collection. + +
+ + + Convert the object to a string representation. + + + A string representation of the object. + + + + + Property to retrieve the array of property values. + + + + + Default implementation of the + interface that should be sufficient for all normal uses. + + +

+ will convert + and array + values to the corresponding target arrays, if necessary. Custom + s that deal with + s or arrays can be written against a + comma delimited as + arrays are converted in such a format if the array itself is not assignable. +

+
+ Rod Johnson + Juergen Hoeller + Jean-Pierre Pawlak + Mark Pollack (.NET) + Aleksandar Seovic(.NET) +
+ + The wrapped object. + + + + The ILog instance for this class. We'll create a lot of these objects, + so we don't want a new instance every time. + + + + + Creates a new instance of the class. + + +

+ The wrapped target instance will need to be set afterwards. +

+
+ +
+ + + Creates a new instance of the class. + + + The object wrapped by this . + + + If the supplied is . + + + + + Creates a new instance of the class, + instantiating a new instance of the specified and using + it as the . + + +

+ Please note that the passed as the + argument must have a no-argument constructor. + If it does not, an exception will be thrown when this class attempts + to instantiate the supplied using it's + (non-existent) constructor. +

+
+ + The to instantiate and wrap. + + + If the is , or if the + invocation of the s default (no-arg) constructor + fails (due to invalid arguments, insufficient permissions, etc). + +
+ + Gets the value of a property. + + The name of the property to get the value of. + + The value of the property. + + If there is no such property, if the property isn't readable, or + if getting the property value throws an exception. + + + + Gets the value of a property. + + The property expression that should be used to retrieve the property value. + + The value of the property. + + If there is no such property, if the property isn't readable, or + if getting the property value throws an exception. + + + + + Sets a property value. + + +

+ This method is provided for convenience only. The + + method is more powerful. +

+
+ + The name of the property to set value of. + + The new value. +
+ + + Sets a property value. + + + The property expression that should be used to set the property value. + + The new value. + + + + Sets a property value. + + +

+ This is the preferred way to update an individual property. +

+
+ + The object containing new property value. + +
+ + Set a number of property values in bulk. + +

+ Does not allow unknown fields. Equivalent to + + with and for + arguments. +

+
+ + The to set on the target + object. + + + If an error is encountered while setting a property. + + + On a mismatch while setting a property, insufficient permissions, etc. + + +
+ + + Perform a bulk update with full control over behavior. + + +

+ This method may throw a reflection-based exception, if there is a critical + failure such as no matching field... less serious exceptions will be accumulated + and thrown as a single . +

+
+ + The s to set on the target object. + + + Should we ignore unknown values (not found in the object!?). + + + If an error is encountered while setting a property (only thrown if the + parameter is set to ). + + + On a mismatch while setting a property, insufficient permissions, etc. + + +
+ + + Returns PropertyInfo for the specified property + + The name of the property to search for. + The for the specified property. + If cannot be determined. + + + + Get the for a particular property. + + + The property the of which is to be retrieved. + + + The for a particular property.. + + + + + Returns MemberInfo for the specified property or field + + The name of the property or field to search for. + The or for the specified property or field. + If does not resolve to a property or field. + + + + Get the properties of the wrapped object. + + + An array of s. + + + + + This method is expensive! Only call for diagnostics and debugging reasons, + not in production. + + + A string describing the state of this object. + + + + + Attempts to parse property expression first and falls back to full expression + if that fails. Performance optimization. + + Property expression to parse. + Parsed proeprty expression. + + + + The object wrapped by this . + + + If the object cannot be changed; or an attempt is made to set the + value of this property to . + + + + + Convenience method to return the of the wrapped object. + + +

+ Do not use this (convenience) method prior to setting the + property. +

+
+ + The of the wrapped object. + + + If the property + is . + +
+ + + Return the collection of property descriptors. + + + + + Combined exception, composed of individual binding + s. + + +

+ An object of this class is created at the beginning of the binding + process, and errors added to it as necessary. +

+

+ The binding process continues when it encounters application-level + s, applying those changes + that can be applied and storing rejected changes in an instance of this class. +

+
+ Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) +
+ + + Creates a new instance of the PropertyAccessExceptionsException class. + + + + + Creates a new instance of the PropertyAccessExceptionsException class. + + + A message about the exception. + + + + + Creates a new instance of the PropertyAccessExceptionsException class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Create new empty PropertyAccessExceptionsException. + We'll add errors to it as we attempt to bind properties. + + + + + Creates a new instance of the PropertyAccessExceptionsException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Populates a with + the data needed to serialize the target object. + + + The to populate + with data. + + + The destination (see ) + for this serialization. + + + + + The IObjectWrapper wrapping the target object at the root of the exception. + + + + The list of PropertyAccessException objects. + + + + Return the + for the supplied , or + if there isn't one. + + + + + Describe the number of exceptions contained in this container class. + + A description of the instance contents. + + + + Return the that generated + this exception. + + + + + Return the object we're binding to. + + + + + If this returns zero (0), no errors were encountered during binding. + + + + + Return an array of the s + stored in this object. + + +

+ Will return the empty array (not ) if there were no errors. +

+
+
+ + + Describe the group of exceptions. + + + + + Holds information and value for an individual property. + + +

+ Using an object here, rather than just storing all properties in a + map keyed by property name, allows for more flexibility, and the + ability to handle indexed properties in a special way if necessary. +

+

+ Note that the value doesn't need to be the final required + : an + implementation must + handle any necessary conversion, as this object doesn't know anything + about the objects it will be applied to. +

+
+ Rod Johnson + Mark Pollack (.NET) +
+ + + Creates a new instance of the + class. + + The name of the property. + + The value of the property (possibly before type conversion). + + + If the supplied is or + contains only whitespace character(s). + + + + + Creates a new instance of the + class. + + The name of the property. + + The value of the property (possibly before type conversion). + + Pre-parsed property name. + + If the supplied or + is , or if the name contains only whitespace characters. + + + + + Print a string representation of the property. + + A string representation of the property. + + + + Determines whether the supplied + is equal to the current . + + The other instance. + + if they are equal in content. + + + + + Serves as a hash function for a particular type, suitable for use + in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + The name of the property. + The name of the property. + + + + Parsed property expression. + + + + + Return the value of the property. + + +

+ Note that type conversion will not have occurred here. + It is the responsibility of the + implementation to + perform type conversion. +

+
+ The (possibly unresolved) value of the property. +
+ + + A simple pool implementation + + +

+ Based on the implementation found in Concurrent Programming in Java, + 2nd ed., by Doug Lea. +

+
+ Doug Lea + Federico Spinazzi + Mark Pollack +
+ + + A simple pooling interface for managing and monitoring a pool + of objects. + + +

+ Based on the Jakarta Commons Pool API. +

+
+ Federico Spinazzi + +
+ + + Obtain an instance from the pool. + + +

+ By contract, clients must return the borrowed + instance using + or a related method as defined in an implementation or + sub-interface. +

+
+ An instance from the pool. + + In case the pool is unusable. + + +
+ + + Return an instance to the pool. + + +

+ By contract, the object must have been obtained using + + or a related method as defined in an implementation or sub-interface. +

+
+ The instance to be returned to the pool. + +
+ + + Create an object using the factory set by + the property + or other implementation dependent mechanism + and place it into the pool. + + +

+ This is an optional operation. AddObject is useful for "pre-loading" a + pool with idle objects. +

+
+ + If the implementation does not support the operation. + +
+ + + Close the pool and free any resources associated with it. + + + + + Clear objects sitting idle in the pool, releasing any + associated resources. + + +

+ This is an optional operation. +

+
+ + If the implementation does not support the operation. + +
+ + + Gets the number of instances currently borrowed from the pool. + + +

+ This is an optional operation. +

+
+ + If the implementation does not support the operation. + +
+ + + Gets the number of instances currently idle in the pool. + + +

+ This is an optional operation. +

+

+ This may be considered an approximation of the number of objects + that can be borrowed without creating any new instances. +

+
+ + If the implementation does not support the operation. + +
+ + + Set the factory used to create new instances. + + +

+ This is an optional operation. +

+
+ + If the implementation does not support the operation. + +
+ + + Set of permits + + + + + Creates a new instance of the + class. + + + The factory used to instantiate and manage the lifecycle of pooled objects. + + The initial size of the pool. + + If the supplied is . + + + If the supplied is less than or equal to zero. + + + + + Obtain an instance from the pool. + + + In case the pool is unusable. + + + + + + + Return an instance to the pool. + + The instance to be returned to the pool. + + + + + + Create an object using the factory set by + the property + or other implementation dependent mechanism + and place it into the pool. + + +

+ This implementation always throws a + . +

+
+ + If the implementation does not support the operation. + +
+ + + Synchronized borrow logic. + + + + + + Synchronized release logic. + + + The object to release to the pool. + + + if the object was not a busy one. + + + + + Instantiates the supplied number of instances and adds + them to the pool. + + + The initial number of objects to build. + + + If the supplied number of is + less than or equal to zero. + + + + + Close the pool and free any resources associated with it. + + + + + Clear objects sitting idle in the pool, releasing any + associated resources. + + +

+ This implementation always throws a + . +

+
+ + If the implementation does not support the operation. + +
+ + + Change the state of the pool to unusable. + + + + + Gets the number of instances currently borrowed from the pool. + + + If the implementation does not support the operation. + + + + + + Gets the number of instances currently idle in the pool. + + + If the implementation does not support the operation. + + + + + + Set the factory used to create new instances. + + +

+ This implementation always throws a + . +

+
+ + If the implementation does not support the operation. + +
+ + + Defines lifecycle methods for objects that are to be used in an + implementation. + + +

+ The following methods summarize the contract between an + and an + an . +

+ + + + is called whenever a new instance is needed. + + + + is invoked on every instance before it is returned from + the pool. + + + + is invoked on every instance when it is returned to the pool. + + + + is invoked on every instance when it is being dropped from the + pool (see + + + +

+ Based on the Jakarta Commons Pool API. +

+
+ Federico Spinazzi + +
+ + + Creates an instance that can be returned by the pool. + + + An instance that can be returned by the pool. + + + + + Destroys an instance no longer needed by the pool. + + +

+ Invoked on every instance when it is being "dropped" + from the pool (whether due to the return value from a call to the + + method, or for reasons specific to the pool implementation.) +

+
+ The instance to be destroyed. +
+ + + Ensures that the instance is safe to be returned by the pool. + Returns false if this object should be destroyed. + + +

+ Invoked in an implementation-specific fashion to determine if an + instance is still valid to be returned by the pool. + It will only be invoked on an "activated" instance. +

+
+ The instance to validate. + + if this object is not valid and + should be dropped from the pool, otherwise . + +
+ + + Reinitialize an instance to be returned by the pool. + + +

+ Invoked on every instance before it is returned from the pool. +

+
+ The instance to be activated. +
+ + + Uninitialize an instance to be returned to the pool. + + +

+ Invoked on every instance when it is returned to the pool. +

+
+ The instance returned to the pool. +
+ + + Base class for all pooling exceptions. + + Federico Spinazzi + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Base class for method builders that contains common functionalities. + + Bruno Baia + + + + Defines interface that proxy method builders have to implement. + + Aleksandar Seovic + Bruno Baia + + + + Dynamically builds proxy method. + + The method to proxy. + + The interface definition of the method, if applicable. + + + The for the proxy method. + + + + + The type builder to use. + + + + + The implementation to use. + + + + + Indicates whether interfaces should be implemented explicitly. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + if the interface is to be + implemented explicitly; otherwise . + + + + + Dynamically builds proxy method. + + The method to proxy. + + The interface definition of the method, if applicable. + + + The for the proxy method. + + + + + Generates the IL instructions that pushes + the proxy instance on stack. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Defines proxy method for the target object. + + The method to proxy. + + The interface definition of the method, if applicable. + + + if the supplied is to be + implemented explicitly; otherwise . + + + The for the proxy method. + + + + + Defines generic method parameters based on proxied method metadata. + + + The to use. + + The method to proxy. + + + + Generates the proxy method. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Calls target method directly. + + The IL generator to use. + The method to invoke. + + + + Emits code to ensure that target on stack understands the method and throw a sensible exception otherwise. + + The IL generator to use. + The method to test for + the name of the target to be used in error messages + + + + Calls base method directly. + + The IL generator to use. + The method to proxy. + + + + Replaces a raw reference with a reference to a proxy. + + +

+ If the target object returns reference to itself -- 'this' -- + we need to treat it as a special case and return a reference + to a proxy object instead. +

+
+ The IL generator to use. + The location of the return value. +
+ + + Generates code that throws . + + IL generator to use. + the type of the exception to throw + Error message to use. + + + + Base class for proxy builders that can be used + to create a proxy for any class. + + +

+ This class provides a set of template + methods that derived classes can override to provide custom behaviour + appropriate to the type of proxy that is being generated (one of + inheritance or composition-based proxying). +

+
+ Aleksandar Seovic + Bruno Baia +
+ + + Describes the operations for a generic proxy type builder that can be + used to create a proxy type for any class. + + Aleksandar Seovic + + + + Creates the proxy type. + + The generated proxy class. + + + + The name of the proxy . + + The name of the proxy . + + + + The of the target object. + + + + + The of the class that the proxy must + inherit from. + + + + + Gets or sets the list of interfaces proxy should implement. + + + + + Should we proxy target attributes? + + + by default. + Target type attributes, method attributes, method's return type attributes + and method's parameter attributes are copied to the proxy. + + + + + The list of custom s that the proxy + class must be decorated with. + + +

+ Note that the list is composed of instances of the actual + s that are to be applied, not the + s of the s. +

+
+ +

+ The following code snippets show examples of how to decorate the + the proxied class with one or more s. +

+ + // get a concrete implementation of an IProxyTypeBuilder... + IProxyTypeBuilder builder = ... ; + builder.TargetType = typeof( ... ); + + IDictionary typeAtts = new Hashtable(); + builder.TypeAttributes = typeAtts; + + // applies a single Attribute to the proxied class... + typeAtts = new Attribute[] { new MyCustomAttribute() }); + + // applies a number of Attributes to the proxied class... + typeAtts = new Attribute[] + { + new MyCustomAttribute(), + new AnotherAttribute(), + }); + +
+
+ + + The custom s that the proxy + members must be decorated with. + + +

+ This dictionary must use simple s for keys + (denoting the member names that the attributes are to be applied to), + with the corresponding values being + s. +

+

+ The key may be wildcarded using the '*' character... if so, + then those proxy members that match against the key will be + decorated with the attendant list of + s. This naturally implies that using + the '*' character as a key will result in the attendant list + of s being applied to every member of + the proxied class. +

+
+ +

+ The following code snippets show examples of how to decorate the + members of a proxied class with one or more + s. +

+ + // get a concrete implementation of an IProxyTypeBuilder... + IProxyTypeBuilder builder = ... ; + builder.TargetType = typeof( ... ); + + IDictionary memAtts = new Hashtable(); + builder.MemberAttributes = memAtts; + + // applies a single Attribute to all members of the proxied class... + memAtts ["*"] = new Attribute[] { new MyCustomAttribute() }); + + // applies a number of Attributes to all members of the proxied class... + memAtts ["*"] = new Attribute[] + { + new MyCustomAttribute(), + new AnotherAttribute(), + }); + + // applies a single Attribute to those members of the proxied class + // that have identifiers starting with 'Do' ... + memAtts ["Do*"] = new Attribute[] { new MyCustomAttribute() }); + + // applies a number of Attributes to those members of the proxied class + // that have identifiers starting with 'Do' ... + memAtts ["Do*"] = new Attribute[] + { + new MyCustomAttribute(), + new AnotherAttribute(), + }); + +
+
+ + + Describes the operations that generates IL instructions + used to build the proxy type. + + Bruno Baia + + + + Generates the IL instructions that pushes + the proxy instance on stack. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + The shared instance for this class (and derived classes). + + + + + Creates the proxy type. + + The generated proxy class. + + + + Generates the IL instructions that pushes + the proxy instance on stack. + + The IL generator to use. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Creates an appropriate type builder. + + The name to use for the proxy type name. + The type to extends if provided. + The type builder to use. + + + + Applies attributes to the proxy class. + + The type builder to use. + The proxied class. + + + + + + Applies attributes to the proxied method. + + The method builder to use. + The proxied method. + + + + + + Applies attributes to the proxied method's return type. + + The method builder to use. + The proxied method. + + + + + Applies attributes to proxied method's parameters. + + The method builder to use. + The proxied method. + + + + + Calculates and returns the list of attributes that apply to the + specified type. + + The type to find attributes for. + + A list of custom attributes that should be applied to type. + + + + + + + Calculates and returns the list of attributes that apply to the + specified method. + + The method to find attributes for. + + A list of custom attributes that should be applied to method. + + + + + + + Calculates and returns the list of attributes that apply to the + specified method's return type. + + The method to find attributes for. + + A list of custom attributes that should be applied to method's return type. + + + + + + Calculates and returns the list of attributes that apply to the + specified method's parameters. + + The method to find attributes for. + The method's parameter to find attributes for. + + A list of custom attributes that should be applied to the specified method's parameter. + + + + + + Check that the specified object is matching the passed attribute type. + + +

+ The specified object can be of different type : +

+ + + + + + System.Reflection.CustomAttributeData (Only with .NET 2.0) + + + + + +
+ The object instance to check. + The attribute type to test against. + + if the object instance matches the attribute type; + otherwise . + +
+ + + Defines the types of the parameters for the specified constructor. + + The constructor to use. + The types for constructor's parameters. + + + + Implements constructors for the proxy class. + + + The builder to use. + + + + + Generates the proxy constructor. + + The constructor builder to use. + The IL generator to use. + The constructor to use. + + + + Implements an interface. + + + Generates proxy methods that belongs to the interface + using the specified . + + The type builder to use. + + The implementation to use + + The interface to implement. + + The of the target object. + + + + + Implements an interface. + + + Generates proxy methods that belongs to the interface + using the specified . + + The type builder to use. + + The implementation to use + + The interface to implement. + + The of the target object. + + + if target virtual methods should not be proxied; + otherwise . + + + + + Gets the mapping of the interface to proxy + into the actual methods on the target type + that does not need to implement that interface. + + +

+ If the target type does not implement the interface, + we return the interfaces methods as the target methods for many reasons : +

    +
  • + The target object can change for an object that implements the interface. + (See 'Spring.Aop.Framework.DynamicProxy.IAdvisedProxyMethodBuilder' + implementation in the Spring AOP framework for an example) +
  • +
  • + Allow Transparent proxies to be proxied. + (See Spring Remoting framework for an example) +
  • +
  • + Allow null target to be proxied. + (See Spring AOP framework which avoid calls to the target object + by intercepting all methods. Think "dynamic mock") + (See 'Spring.Web.Services.WebServiceProxyFactory' implementation for another example) +
  • +
+

+
+ + The of the target object. + + The interface to implement. + + An interface mapping for the interface to proxy. + +
+ + + Inherit from a type. + + + Generates proxy methods for base virtual methods + using the specified . + + + The builder to use for code generation. + + + The implementation to use to override base virtual methods. + + The to inherit from. + + + + Inherit from a type. + + + Generates proxy methods for base virtual methods + using the specified . + + + The builder to use for code generation. + + + The implementation to use to override base virtual methods. + + The to inherit from. + + if only members declared at the level + of the supplied 's hierarchy should be proxied; + otherwise . + + + + + Implements the specified . + + The type builder to use. + The type the property is defined on. + The property to proxy. + The implemented methods map. + + + + Implements the specified event. + + The type builder to use. + The type the event is defined on. + The event to proxy. + The implemented methods map. + + + + Returns an array of s that represent + the proxiable interfaces. + + + An interface is proxiable if it's not marked with the + . + + + The array of interfaces from which + we want to get the proxiable interfaces. + + + An array containing the interface s. + + + + + Checks if specified interface is of a special type + that should never be proxied (i.e. ISerializable). + + Interface type to check. + + true if it is, false otherwise. + + + + + The name of the proxy . + + The name of the proxy . + + + + The of the target object. + + + + + The of the class that the proxy must + inherit from. + + +

+ The default value of this property is the + . +

+
+
+ + + Gets or sets the list of interfaces proxy should implement. + + + The default value of this property is all the interfaces + implemented or inherited by the target type. + + + + + Should we proxy target attributes? + + + + + + The list of custom s that the proxy + class must be decorated with. + + + + + + The custom s that the proxy + members must be decorated with. + + + + + + Implementation of IProxyMethodBuilder that delegates method calls to the base class. + + Bruno Baia + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + if the interface is to be + implemented explicitly; otherwise . + + + + + Generates the proxy method. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Builds a proxy type using composition. + + + + In order for this builder to work, the target must implement + one or more interfaces. + + + Aleksandar Seovic + Bruno Baia + + + + Target instance calls should be delegated to. + + + + + Creates a new instance of the + class. + + + + + Creates a proxy that delegates calls to an instance of the + target object. + + +

+ Only interfaces can be proxied using composition, so the target + must implement one or more interfaces. +

+
+ The generated proxy class. + + If the + does not implement any interfaces. + +
+ + + Create an to create interface implementations + + + + + Allows subclasses to generate additional code + + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Deaclares a field that holds the target object instance. + + + The builder to use for code generation. + + + + + Generates the proxy constructor. + + +

+ This implementation creates instance of the target object for delegation + using constructor arguments. +

+
+ The constructor builder to use. + The IL generator to use. + The constructor to delegate the creation to. +
+ + + Gets or sets a value indicating whether interfaces should be implemented explicitly. + + + if they should be; otherwise, . + + + + + Allows easy access to existing and creation of new dynamic proxies. + + Aleksandar Seovic + Bruno Baia + + + + The name of the assembly that defines proxy types created. + + + + + The attributes of the proxy type to generate. + + + + + Creates an appropriate type builder. + + The proxy type name. + The type to extends if provided. + The type builder to use. + + + + Saves dynamically generated assembly to disk. + Can only be called in DEBUG_DYNAMIC mode, per ConditionalAttribute rules. + + + + + Builds a proxy type using inheritance. + + + + In order for this builder to work, target methods have to be either + , or belong to an interface. + + + Aleksandar Seovic + Bruno Baia + + + + Creates a new instance of the + class. + + + + + Creates a proxy that inherits the proxied object's class. + + +

+ Only (non-final) methods can be proxied, + unless they are members of one of the interfaces that target class + implements. In that case, methods will be proxied using explicit + interface implementation, which means that client code will have + to cast the proxy to a specific interface in order to invoke the + methods. +

+
+ The generated proxy class. +
+ + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Generates the proxy constructor. + + +

+ This implementation delegates the call to a base class constructor. +

+
+ The constructor builder to use. + The IL generator to use. + + The base class constructor to delegate the call to. + +
+ + + Gets or sets a value indicating whether inherited members should be proxied. + + + if they should be; otherwise, . + + + + + This attribute can be used to mark interfaces that should not be proxied + + Bruno Baia + + + + Creates a new instance of the + class. + + + + + Implementation of IProxyMethodBuilder that delegates method calls to target object. + + Bruno Baia + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + if the interface is to be + implemented explicitly; otherwise . + + + + + Generates the proxy method. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Base class for dynamic members. + + Aleksandar Seovic + + + + Method attributes constant. + + + + + Sets up target instance for invocation. + + IL generator to use. + Type of target instance. + + + + Sets up invocation argument. + + IL generator to use. + Argument type. + Argument position. + + + + Generates method invocation code. + + IL generator to use. + Flag specifying whether method is static. + Flag specifying whether method is on the value type. + Method to invoke. + + + + Generates code to process return value if necessary. + + IL generator to use. + Type of the return value. + + + + Generates code that throws . + + IL generator to use. + Error message to use. + + + + Defines constructors that dynamic constructor class has to implement. + + + + + Invokes dynamic constructor. + + + Constructor arguments. + + + A constructor value. + + + + + Safe wrapper for the dynamic constructor. + + + will attempt to use dynamic + constructor if possible, but it will fall back to standard + reflection if necessary. + + + + + Obtains cached constructor info or creates a new entry, if none is found. + + + + + Creates a new instance of the safe constructor wrapper. + + Constructor to wrap. + + + + Invokes dynamic constructor. + + + Constructor arguments. + + + A constructor value. + + + + + Factory class for dynamic constructors. + + Aleksandar Seovic + + + + Creates dynamic constructor instance for the specified . + + Constructor info to create dynamic constructor for. + Dynamic constructor for the specified . + + + + Defines methods that dynamic field class has to implement. + + + + + Gets the value of the dynamic field for the specified target object. + + + Target object to get field value from. + + + A field value. + + + + + Gets the value of the dynamic field for the specified target object. + + + Target object to set field value on. + + + A new field value. + + + + + Safe wrapper for the dynamic field. + + + will attempt to use dynamic + field if possible, but it will fall back to standard + reflection if necessary. + + + + + Obtains cached fieldInfo or creates a new entry, if none is found. + + + + + Creates a new instance of the safe field wrapper. + + Field to wrap. + + + + Gets the value of the dynamic field for the specified target object. + + + Target object to get field value from. + + + A field value. + + + + + Gets the value of the dynamic field for the specified target object. + + + Target object to set field value on. + + + A new field value. + + + + + Holds cached Getter/Setter delegates for a Field + + + + + Factory class for dynamic fields. + + Aleksandar Seovic + + + + Creates dynamic field instance for the specified . + + Field info to create dynamic field for. + Dynamic field for the specified . + + + + Defines methods that dynamic indexer class has to implement. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to get the indexer value from. + + + Indexer argument. + + + A indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to get the indexer value from. + + + Indexer argument. + + + A indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to get the indexer value from. + + + Indexer arguments. + + + A indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to set the indexer value on. + + + Indexer argument. + + + A new indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to set the indexer value on. + + + Indexer argument. + + + A new indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to set the indexer value on. + + + Indexer arguments. + + + A new indexer value. + + + + + Safe wrapper for the dynamic indexer. + + + will attempt to use dynamic + indexer if possible, but it will fall back to standard + reflection if necessary. + + + + + Creates a new instance of the safe indexer wrapper. + + Indexer to wrap. + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to get indexer value from. + + + Indexer arguments. + + + A indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to get the indexer value from. + + + Indexer argument. + + + A indexer value. + + + + + Gets the value of the dynamic indexer for the specified target object. + + + Target object to get indexer value from. + + + Indexer arguments. + + + A indexer value. + + + + + Sets the value of the dynamic indexer for the specified target object. + + + Target object to set indexer value on. + + + Indexer arguments. + + + A new indexer value. + + + + + Sets the value of the dynamic indexer for the specified target object. + + + Target object to set indexer value on. + + + Indexer arguments. + + + A new indexer value. + + + + + Sets the value of the dynamic indexer for the specified target object. + + + Target object to set indexer value on. + + + Indexer arguments. + + + A new indexer value. + + + + + Internal PropertyInfo accessor. + + + + + Factory class for dynamic indexers. + + Aleksandar Seovic + + + + Prevent instantiation + + + + + Creates dynamic indexer instance for the specified . + + Indexer info to create dynamic indexer for. + Dynamic indexer for the specified . + + + + Defines methods that dynamic method class has to implement. + + + + + Invokes dynamic method on the specified target object. + + + Target object to invoke method on. + + + Method arguments. + + + A method return value. + + + + + Safe wrapper for the dynamic method. + + + will attempt to use dynamic + method if possible, but it will fall back to standard + reflection if necessary. + + + + + Creates a new instance of the safe method wrapper. + + Method to wrap. + + + + Invokes dynamic method. + + + Target object to invoke method on. + + + Method arguments. + + + A method return value. + + + + + Gets the class, that declares this method + + + + + Factory class for dynamic methods. + + Aleksandar Seovic + + + + Creates dynamic method instance for the specified . + + Method info to create dynamic method for. + Dynamic method for the specified . + + + + Defines methods that dynamic property class has to implement. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to get property value from. + + + A property value. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to set property value on. + + + A new property value. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to get property value from. + + Optional index values for indexed properties. This value should be null reference for non-indexed properties. + + A property value. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to set property value on. + + + A new property value. + + Optional index values for indexed properties. This value should be null reference for non-indexed properties. + + + + Safe wrapper for the dynamic property. + + + will attempt to use dynamic + property if possible, but it will fall back to standard + reflection if necessary. + + + + + Obtains cached property info or creates a new entry, if none is found. + + + + + Creates a new instance of the safe property wrapper. + + Property to wrap. + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to get property value from. + + + A property value. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to get property value from. + + Optional index values for indexed properties. This value should be null reference for non-indexed properties. + + A property value. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to set property value on. + + + A new property value. + + + + + Gets the value of the dynamic property for the specified target object. + + + Target object to set property value on. + + + A new property value. + + Optional index values for indexed properties. This value should be null reference for non-indexed properties. + + + + Internal PropertyInfo accessor. + + + + + Holds cached Getter/Setter delegates for a Property + + + + + Factory class for dynamic properties. + + Aleksandar Seovic + + + + Creates safe dynamic property instance for the specified . + + +

This factory method will create a dynamic property with a "safe" wrapper.

+

Safe wrapper will attempt to use generated dynamic property if possible, + but it will fall back to standard reflection if necessary.

+
+ Property info to create dynamic property for. + Safe dynamic property for the specified . + +
+ + + Creates dynamic property instance for the specified . + + Property info to create dynamic property for. + Dynamic property for the specified . + + + + Represents a Get method + + the target instance when calling an instance method + the value return by the Get method + + + + Represents a Set method + + the target instance when calling an instance method + the value to be set + + + + Represents an Indexer Get method + + the target instance when calling an instance method + + the value return by the Get method + + + + Represents a Set method + + the target instance when calling an instance method + the value to be set + + + + + Represents a method + + the target instance when calling an instance method + arguments to be passed to the method + the value return by the method. null when calling a void method + + + + Represents a constructor + + arguments to be passed to the method + the new object instance + + + + Represents a callback method used to create an from a instance. + + + + + Represents a callback method used to create an from a instance. + + + + + Represents a callback method used to create an from a instance. + + + + + Represents a callback method used to create an from a instance. + + + + + Represents a callback method used to create an from a instance. + + + + + Allows easy access to existing and creation of new dynamic relection members. + + Aleksandar Seovic + + + + The name of the assembly that defines reflection types created. + + + + + The attributes of the reflection type to generate. + + + + + Cache for dynamic property types. + + + + + Cache for dynamic field types. + + + + + Cache for dynamic indexer types. + + + + + Cache for dynamic method types. + + + + + Cache for dynamic constructor types. + + + + + Creates an appropriate type builder. + + + The base name to use for the reflection type name. + + The type builder to use. + + + + Returns dynamic property if one exists. + + Property to look up. + callback function that will be called to create the dynamic property + An for the given property info. + + + + Returns dynamic field if one exists. + + Field to look up. + callback function that will be called to create the dynamic field + An for the given field info. + + + + Returns dynamic indexer if one exists. + + Indexer to look up. + callback function that will be called to create the dynamic indexer + An for the given indexer. + + + + Returns dynamic method if one exists. + + Method to look up. + callback function that will be called to create the dynamic method + An for the given method. + + + + Returns dynamic constructor if one exists. + + Constructor to look up. + callback function that will be called to create the dynamic constructor + An for the given constructor. + + + + Saves dynamically generated assembly to disk. + Can only be called in DEBUG mode, per ConditionalAttribute rules. + + + + + Create a new Get method delegate for the specified field using + + the field to create the delegate for + a delegate that can be used to read the field + + + + Create a new Set method delegate for the specified field using + + the field to create the delegate for + a delegate that can be used to read the field. + + If the field's returns true, the returned method + will throw an when called. + + + + + Create a new Get method delegate for the specified property using + + the property to create the delegate for + a delegate that can be used to read the property. + + If the property's returns false, the returned method + will throw an when called. + + + + + Create a new Set method delegate for the specified property using + + the property to create the delegate for + a delegate that can be used to write the property. + + If the property's returns false, the returned method + will throw an when called. + + + + + Create a new method delegate for the specified method using + + the method to create the delegate for + a delegate that can be used to invoke the method. + + + + Creates a new delegate for the specified constructor. + + the constructor to create the delegate for + delegate that can be used to invoke the constructor. + + + + Creates a instance with the highest possible code access security. + + + If allowed by security policy, associates the method with the s declaring type. + Otherwise associates the dynamic method with . + + + + + Delegates a Method(object target, params object[] args) call to the actual underlying method. + + + + + Generates code to process return value if necessary. + + IL generator to use. + Type of the return value. + + + + Converts to an instance of if necessary to + e.g. avoid e.g. double/int cast exceptions. + + + + This method mimics the behavior of the compiler that + automatically performs casts like int to double in "Math.Sqrt(4)".
+ See about implicit, widening type conversions on MSDN - Type Conversion Tables +
+ + Note: is expected to be a value type! + +
+
+ + + Generates code that throws . + + IL generator to use. + Error message to use. + + + + Indicates that an annotated class is a "component". + Such classes are considered as candidates for future features such + as auto-detection when using attribute-based configuration and assembly scanning. + + Other class-level annotations may be considered as identifying + a component as well, typically a special kind of component: + e.g. the Repository attribute. + + Mark Fisher + Mark Pollack (.NET) + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The name of the component. + + + + Gets or sets the name of the component + + The name of the component. + + + + Indicates that an annotated class is a "Repository" (or "DAO"). + + + A class with this attribute is eligible for Spring DataAccessException translation. A class + with the Repository attribute is also clarified as to its role in the overall application + architecture for the purpose of tools, aspects, etc. + + This attribute also serves as a specialization of the ComponentAttribute, allowing implementation + classes to be autodetected in future releases through assembly scanning. + + + Rod Johnson + Jueren Hoeller + Mark Pollack (.NET) + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The name of the repository. + + + + Indicates that an annotated class is a "Service" (e.g. a business service facade). + + + + This attribute also serves as a specialization of the ComponentAttribute, allowing implementation + classes to be autodetected in future releases through assembly scanning. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The name. + + + + Implements by using . + + Erich Eichinger + + + + Specifies the contract a strategy must be implement to store and + retrieve data that is specific to the executing thread. + + + All implementations of this interface must treat keys case-sensitive. + + Erich Eichinger + + + + Retrieves an object with the specified . + + The name of the item. + + The object in the current thread's context associated with the + specified or null if no object has been stored previously + + + + + Stores a given object and associates it with the specified . + + The name with which to associate the new item. + The object to store in the current thread's context. + + + + Empties a data slot with the specified name. + + + If the object with the specified is not found, the method does nothing. + + The name of the object to remove. + + + + Retrieves an object with the specified name. + + The name of the item. + The object in the call context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the call context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + + Acquire/Release protocol, base of many concurrency utilities. + + + +

objects isolate waiting and notification for particular logical + states, resource availability, events, and the like that are shared + across multiple threads.

+ +

Use of s sometimes (but by no means always) adds + flexibility and efficiency compared to the use of plain + .Net monitor methods and locking, and are sometimes (but by no means + always) simpler to program with.

+ +

Used for implementation of a

+
+ + Doug Lea + Federico Spinazzi (.Net) +
+ + Wait (possibly forever) until successful passage. + Fail only upon interuption. Interruptions always result in + `clean' failures. On failure, you can be sure that it has not + been acquired, and that no + corresponding release should be performed. Conversely, + a normal return guarantees that the acquire was successful. + + + + + Potentially enable others to pass. +

+ Because release does not raise exceptions, + it can be used in `finally' clauses without requiring extra + embedded try/catch blocks. But keep in mind that + as with any java method, implementations may + still throw unchecked exceptions such as Error or NullPointerException + when faced with uncontinuable errors. However, these should normally + only be caught by higher-level error handlers. +

+
+
+ + + Wait at most msecs to pass; report whether passed. +

+ The method has best-effort semantics: + The msecs bound cannot + be guaranteed to be a precise upper bound on wait time in Java. + Implementations generally can only attempt to return as soon as possible + after the specified bound. Also, timers in Java do not stop during garbage + collection, so timeouts can occur just because a GC intervened. + So, msecs arguments should be used in + a coarse-grained manner. Further, + implementations cannot always guarantee that this method + will return at all without blocking indefinitely when used in + unintended ways. For example, deadlocks may be encountered + when called in an unintended context. +

+
+ the number of milleseconds to wait + An argument less than or equal to zero means not to wait at all. + However, this may still require + access to a synchronization lock, which can impose unbounded + delay if there is a lot of contention among threads. + + true if acquired +
+ + A latch is a boolean condition that is set at most once, ever. + Once a single release is issued, all acquires will pass. +

+ Sample usage. Here are a set of classes that use + a latch as a start signal for a group of worker threads that + are created and started beforehand, and then later enabled. +

+ + class Worker implements IRunnable { + private readonly Latch startSignal; + Worker(Latch l) + { + startSignal = l; + } + + public void Run() { + startSignal.acquire(); + DoWork(); + } + + void DoWork() { ... } + } + + class Driver { // ... + void Main() { + Latch go = new Latch(); + for (int i = 0; i < N; ++i) // make threads + new Thread(new ThreadStart(new Worker(go)).Start(); + DoSomethingElse(); // don't let run yet + go.Release(); // let all threads proceed + } + } + +
+ Doug Lea + Federico Spinazzi (.Net) +
+ + + can acquire ? + + + + + Method mainly used by clients who are trying to get the latch + + + + Wait at most msecs millisconds for a permit + + + + Enable all current and future acquires to pass + + + + + An abstraction to safely store "ThreadStatic" data. + + + By default, is used to store thread-specific data. + You may switch the storage strategy by calling .

+ NOTE: Access to the underlying storage is not synchronized for performance reasons. + You should call only once at application startup! + + Erich Eichinger + + +

+ Holds the current strategy. + + + Access to this variable is not synchronized on purpose for performance reasons. + Setting a different strategy should happen only once + at application startup. + +
+ + + Set the new strategy. + + + + + Retrieves an object with the specified name. + + The name of the item. + The object in the context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the current thread's context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + +

Base class for counting semaphores based on Semaphore implementation + from Doug Lea.

+
+ + +

Conceptually, a semaphore + maintains a set of permits. Each acquire() blocks if + necessary until a permit is available, and then takes it.

+ +

Each release adds a permit. However, no actual permit objects are used; + the Semaphore just keeps a count of the number available + and acts accordingly.

+ +

A semaphore initialized to 1 can serve as a mutual exclusion lock.

+ + Used for implementation of a +
+ Doug Lea + Federico Spinazzi (.Net) +
+ + + current number of available permits + + + + +

Create a Semaphore with the given initial number of permits.

+

Using a seed of 1 makes the semaphore act as a mutual + exclusion lock.

+ +

Negative seeds are also allowed, + in which case no acquires will proceed until the number of + releases has pushed the number of permits past 0.

+
+
+ + + Release a permit + + + + + Acquire a permit + + + + + Wait at most msecs millisconds for a permit + + number of ms to wait + true if aquired + + + Release N permits. release(n) is + equivalent in effect to: +
+            for (int i = 0; i < n; ++i) release();
+            
+ But may be more efficient in some semaphore implementations. +
+ if n is negative. + + +
+ + Return the current number of available permits. + Returns an accurate, but possibly unstable value, + that may change immediately after returning. + + + + + Utility class to use an with the + C# using () {} idiom + + + + + Creates a new trying to the given + + + the to be held + + + + Creates a new trying to the given + + + the to be held + millisecond to try to acquire the lock + + + + Releases the held + + + + + initializes and acquire access to the + + + + + + Implements by using a hashtable. + + Erich Eichinger + + + + Retrieves an object with the specified name. + + The name of the item. + The object in the call context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the call context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + Thrown by synchronization classes that report + timeouts via exceptions. The exception is treated + as a form (subclass) of InterruptedException. This both + simplifies handling, and conceptually reflects the fact that + timed-out operations are artificially interrupted by timers. + + + + + The approximate time that the operation lasted before + this timeout exception was thrown. + + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + + + Creates a new instance of the + class with the + specified message. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Override of GetObjectData to allow for private serialization + + serialization info + streaming context + + + Constructs a TimeoutException with given duration value. + + + + + Constructs a TimeoutException with the + specified duration value and detail message. + + + + + Gets the approximate time that the operation lasted before + this timeout exception was thrown. + + + + A TimeoutSync is an adaptor class that transforms all + calls to acquire to instead invoke attempt with a predetermined + timeout value. + + + + + + the adapted sync + + + + + timeout value + + + + Create a TimeoutSync using the given Sync object, and + using the given timeout value for all calls to acquire. + + + + + Try to acquire the sync before the timeout + + In case a time out occurred + + + + + + + + + + + + + + Support to account for differences between java nad .NET: +
    +
+
+
+ + + .NET threads have not a method to check if they have been interrupted. + Moreover, differently from java threads, when entering locked + blocks, Monitor, Sleep, SpinWait and so on, a + will be raised by the runtime. +

Spring.Threading classes usually call this method before entering a lock block, to mirror java code +

Usually this is non issue because the same exception will be raised entering the monitor + associated with the lock () +

+
+ if the thread has been interrupted +
+ + + Normalize the given so that + is is comparable with . + + Date. + + + + + + + + + the difference between millisecodns of the first and second date + + + + Returns the number of nanoseconds for the current value of + + Current number of nanoseconds + + + + Returns the number of nano seconds represented by the + + to use + Number of nano seconds for + + + + Returns a representing the number of nanoseconds passed in via . + + Number of nanoseconds. + representing the number of nanoseconds passed in. + + + + Placeholder for java.lang.System.currentTimeMillis + + The current machine time in milliseconds + + + + Has been interrupted this thread + + + + + Miscellaneous generic collection utility methods. + + + Mainly for internal use within the framework. + + Mark Pollack (.NET) + + + + Determine whether a given collection only contains + a single unique object + + + + + + + Determines whether the contains the specified . + + The collection to check. + The object to locate in the collection. + if the element is in the collection, otherwise. + + + + Determines whether the collection contains all the elements in the specified collection. + + The collection to check. + Collection whose elements would be checked for containment. + true if the target collection contains all the elements of the specified collection. + + + + Removes all the elements from the target collection that are contained in the source collection. + + Collection where the elements will be removed. + Elements to remove from the target collection. + + + + Various utility methods relating to the manipulation of arrays. + + Aleksandar Seovic + + + + Checks if the given array or collection has elements and none of the elements is null. + + the collection to be checked. + true if the collection has a length and contains only non-null elements. + + + + Use this sort method instead of to overcome + bugs in Mono. + + + + + Checks if the given array or collection is null or has no elements. + + + + + + + Tests equality of two single-dimensional arrays by checking each element + for equality. + + The first array to be checked. + The second array to be checked. + True if arrays are the same, false otherwise. + + + + Returns hash code for an array that is generated based on the elements. + + + Hash code returned by this method is guaranteed to be the same for + arrays with equal elements. + + + Array to calculate hash code for. + + + A hash code for the specified array. + + + + + Returns string representation of an array. + + + Array to return as a string. + + + String representation of the specified . + + + + + Concatenates 2 arrays of compatible element types + + + If either of the arguments is null, the other array is returned as the result. + The array element types may differ as long as they are assignable. The result array will be of the "smaller" element type. + + + + + Assertion utility methods that simplify things such as argument checks. + + +

+ Not intended to be used directly by applications. +

+
+ Aleksandar Seovic + Erich Eichinger +
+ + + Checks, whether may be invoked on . + Supports testing transparent proxies. + + the target instance or null + the name of the target to be used in error messages + the method to test for + + if is null + + + if it is not possible to invoke on + + + + + checks, whether supports the methods of . + Supports testing transparent proxies. + + the target instance or null + the name of the target to be used in error messages + the type to test for + + if is null + + + if it is not possible to invoke methods of + type on + + + + + Checks the value of the supplied and throws an + if it is . + + The object to check. + The argument name. + + If the supplied is . + + + + + Checks the value of the supplied and throws an + if it is . + + The object to check. + The argument name. + + An arbitrary message that will be passed to any thrown + . + + + If the supplied is . + + + + + Checks the value of the supplied string and throws an + if it is or + contains only whitespace character(s). + + The string to check. + The argument name. + + If the supplied is or + contains only whitespace character(s). + + + + + Checks the value of the supplied string and throws an + if it is or + contains only whitespace character(s). + + The string to check. + The argument name. + + An arbitrary message that will be passed to any thrown + . + + + If the supplied is or + contains only whitespace character(s). + + + + + Checks the value of the supplied and throws + an if it is or contains no elements. + + The array or collection to check. + The argument name. + + If the supplied is or + contains no elements. + + + + + Checks the value of the supplied and throws + an if it is or contains no elements. + + The array or collection to check. + The argument name. + An arbitrary message that will be passed to any thrown . + + If the supplied is or + contains no elements. + + + + + Checks the value of the supplied and throws + an if it is , contains no elements or only null elements. + + The array or collection to check. + The argument name. + + If the supplied is , + contains no elements or only null elements. + + + + + Checks whether the specified can be cast + into the . + + + The argument to check. + + + The name of the argument to check. + + + The required type for the argument. + + + An arbitrary message that will be passed to any thrown + . + + + + + Assert a boolean expression, throwing ArgumentException + if the test result is false. + + a boolean expression. + The exception message to use if the assertion fails. + + if expression is false + + + + + Assert a boolean expression, throwing ArgumentException + if the test result is false. + + a boolean expression. + + if expression is false + + + + + Assert a bool expression, throwing InvalidOperationException + if the expression is false. + + a boolean expression. + The exception message to use if the assertion fails + if expression is false + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + General utility methods for working with annotations + + + + + Find a single Attribute of the type 'attributeType' from the supplied class, + traversing it interfaces and super classes if no attribute can be found on the + class iteslf. + + + This method explicitly handles class-level attributes which are not declared as + inherited as well as attributes on interfaces. + + The class to look for attributes on . + Type of the attribibute to look for. + the attribute of the given type found, or null + + + + Miscellaneous collection utility methods. + + + Mainly for internal use within the framework. + + Mark Pollack (.NET) + + + + Checks if the given array or collection has elements and none of the elements is null. + + the collection to be checked. + true if the collection has a length and contains only non-null elements. + + + + Checks if the given array or collection is null or has no elements. + + + + + + + Determine whether a given collection only contains + a single unique object + + + + + + + Determines whether the contains the specified . + + The collection to check. + The object to locate in the collection. + if the element is in the collection, otherwise. + + + + Adds the specified to the specified . + + The collection to add the element to. + The object to add to the collection. + + + + Adds the specified to the specified . + + The enumerable to add the element to. + The object to add to the collection. + + + + Determines whether the collection contains all the elements in the specified collection. + + The collection to check. + Collection whose elements would be checked for containment. + true if the target collection contains all the elements of the specified collection. + + + + Removes all the elements from the target collection that are contained in the source collection. + + Collection where the elements will be removed. + Elements to remove from the target collection. + + + + Converts an instance to an instance. + + The instance to be converted. + An instance in which its elements are the elements of the instance. + if the is null. + + + + Copies the elements of the to a + new array of the specified element type. + + The instance to be converted. + The element of the destination array to create and copy elements to + An array of the specified element type containing copies of the elements of the . + + + + Returns the first element contained in both, and . + + The implementation assumes that <<< + the source enumerable. may be null + the list of candidates to match against elements. may be null + the first element found in both enumerables or null + + + + Finds a value of the given type in the given collection. + + The collection to search. + The type to look for. + a value of the given type found, or null if none. + If more than one value of the given type is found + + + + Finds a value of the given type in the given collection. + + The collection to search. + The type to look for. + a collection of matching values of the given type found, empty if none found, or null if the input collection was null. + + + + Find a value of one of the given types in the given Collection, + searching the Collection for a value of the first type, then + searching for a value of the second type, etc. + + The collection to search. + The types to look for, in prioritized order. + a value of the given types found, or null if none + If more than one value of the given type is found + + + + Determines whether the specified collection is null or empty. + + The collection to check. + + true if the specified collection is empty or null; otherwise, false. + + + + + Determines whether the specified collection is null or empty. + + The collection to check. + + true if the specified collection is empty or null; otherwise, false. + + + + + Determines whether the specified dictionary is null empty. + + The dictionary to check. + + true if the specified dictionary is empty or null; otherwise, false. + + + + + A simple stable sorting routine - far from being efficient, only for small collections. + + + + + + + + A simple stable sorting routine - far from being efficient, only for small collections. + + + Sorting is not(!) done in-place. Instead a sorted copy of the original input is returned. + + input collection of items to sort + the for comparing 2 items in . + a new collection of stable sorted items. + + + + A simple stable sorting routine - far from being efficient, only for small collections. + + + Sorting is not(!) done in-place. Instead a sorted copy of the original input is returned. + + input collection of items to sort + the for comparing 2 items in . + a new collection of stable sorted items. + + + + A simple stable sorting routine - far from being efficient, only for small collections. + + + Sorting is not(!) done in-place. Instead a sorted copy of the original input is returned. + + input collection of items to sort + the for comparing 2 items in . + a new collection of stable sorted items. + + + + A callback method used for comparing to items. + + + + the first object to compare + the second object to compare + Value Condition Less than zero x is less than y. Zero x equals y. Greater than zero x is greater than y. + + + + + + Utility class containing helper methods for object comparison. + + Aleksandar Seovic + + + Compares two objects. + First object. + Second object. + + 0, if objects are equal; + less than zero, if the first object is smaller than the second one; + greater than zero, if the first object is greater than the second one. + + + + Utility class for .NET configuration files management. + + Aleksandar Seovic + + + + Avoid BeforeFieldInit pitfall + + + + + Parses the configuration section. + + +

+ Primary purpose of this method is to allow us to parse and + load configuration sections using the same API regardless + of the .NET framework version. +

+

+ If Microsoft paid a bit more attention to preserving backwards + compatibility we would not even need it, but... :( +

+
+ Name of the configuration section. + Object created by a corresponding . +
+ + + Refresh the configuration section. + + +

+ Primary purpose of this method is to allow us to parse and + load configuration sections using the same API regardless + of the .NET framework version. +

+

+ If Microsoft paid a bit more attention to preserving backwards + compatibility we would not even need it, but... :( +

+
+ Name of the configuration section. +
+ + + Creates the configuration exception. + + The message to display to the client when the exception is thrown. + The inner exception. + Name of the configuration file. + The line where exception occured. + Configuration exception. + + + + Creates the configuration exception. + + The message to display to the client when the exception is thrown. + Name of the configuration file. + The line where exception occured. + Configuration exception. + + + + Creates the configuration exception. + + The message to display to the client when the exception is thrown. + The inner exception. + XML node where exception occured. + Configuration exception. + + + + Creates the configuration exception. + + The message to display to the client when the exception is thrown. + XML node where exception occured. + Configuration exception. + + + + Creates the configuration exception. + + The message to display to the client when the exception is thrown. + The inner exception. + Configuration exception. + + + + Creates the configuration exception. + + The message to display to the client when the exception is thrown. + Configuration exception. + + + + Creates the configuration exception. + + Configuration exception. + + + + Determines whether the specified exception is configuration exception. + + The exception to check. + + true if the specified exception is configuration exception; otherwise, false. + + + + + Returns the line number of the specified node. + + Node to get the line number for. + The line number of the specified node. + + + + Returns the name of the file specified node is defined in. + + Node to get the file name for. + The name of the file specified node is defined in. + + + + Sets the current to be used by . + + + íf implements , this method invokes + on the new configSystem to chain them.
+ Note, that this method requires reflection on internals of +
+ the configuration system to set + bypasses the check if the current system has already been initialized + the previous config system, if any +
+ + + Resets the global configuration system instance. Use for unit testing only! + + + + + An holding information about its original text source location. + + Erich Eichinger + + + + Holds text position information for e.g. error reporting purposes. + + + + + + + Gets a string specifying the file/resource name related to the configuration details. + + + + + Gets an integer specifying the line number related to the configuration details. + + + + + Gets an integer specifying the line position related to the configuration details. + + + + + Creates a new instance of , storing a copy of the passed + . + + + + + Creates a duplicate of this node. + + true to recursively clone the subtree under the specified node; false to clone only the node itself + + + + The name of the resource this element was read from + + + + + The line number within the resource this element was read from + + + + + The line position within the resource this element was read from. + + + + + An implementation, who's elements retain information + about their location in the original XML text document the were read from. + + + When loading a document, the used must implement . + Typical XmlReader implementations like support this interface. + + Erich Eichinger + + + + Overridden to create a retaining the current + text position information. + + + + + Overridden to create a retaining the current + text position information. + + + + + Load the document from the given . + Child nodes will store as their property. + + the name of the resource + The XML source + + + + Load the document from the given . + + The XML source + + + + Load the document from the given . + Child nodes will store as their property. + + the name of the resource + The XML source + + + + Load the document from the given . + Child nodes will store as their property. + + the name of the resource + The XML source + + + + Load the document from the given . + Child nodes will store as their property. + + the name of the resource + The XML source + + + + Load the document from the given . + Child nodes will store as their property. + + the name of the resource + The XML source + + + + Load the document from the given . + Child nodes will store null as their property. + + The XML source + + + + Creates an object based on the information in the . The reader must be positioned on a node or attribute. + Child nodes will store as their property. + + + The new XmlNode or null if no more nodes exist. + + the name of the resource + The XML source + The reader is positioned on a node type that does not translate to a valid DOM node (for example, EndElement or EndEntity). + + + + Creates an object based on the information in the . The reader must be positioned on a node or attribute. + Child nodes will store null as their property. + + + The new XmlNode or null if no more nodes exist. + + The XML source + The reader is positioned on a node type that does not translate to a valid DOM node (for example, EndElement or EndEntity). + + + + Get info about the current text position during loading a document. + Outside loading a document, the properties of + will always be null. + + + + + Holds the current text position during loading a document + + + + + An holding information about its original text source location. + + Erich Eichinger + + + + Creates a new instance of , storing a copy of the passed + . + + + + + Creates a duplicate of this node. + + true to recursively clone the subtree under the specified node; false to clone only the node itself + + + + The name of the resource this element was read from + + + + + The line number within the resource this element was read from + + + + + The line position within the resource this element was read from. + + + + + Collects information on the constructor to use to create the instance and the argument instances to pass into the + constructor. + + + + + Initializes a new instance of the class. + + The constructor info. + The arg instances. + + + + Gets the constructor info. + + The constructor info. + + + + Gets the arg instances. + + The arg instances. + + + + Discovers the attributes of a + and provides access to the + s metadata. + + Rick Evans + + + + The method name associated with a delegate invocation. + + + + + Creates a new instance of the + class. + + + The event used to extract the delegate + from. + + + if the supplied is + . + + + + + Creates a new instance of the + class. + + + The delegate . + + + If the supplied is not a subclass of the + class, or is . + + + + + Checks to see if the method encapsulated by the supplied method + metadata is compatible with the method signature associated with + this delegate type. + + The method to be checked. + + if the method signature is compatible with + the signature of this delegate; if not, or + if the supplied parameter is + . + + + + + Gets the s of the parameters of the + method signature associated with this delegate type. + + +

+ This method will never return ; the returned + array may be empty, but it most certainly + will not be . +

+
+ + A array of the parameter + s; or the + array if the method signature has no parameters. + +
+ + + Gets the return of the + method signature associated with this delegate type. + + The return . + + + + Gets the metadata about the method signature associated + with this delegate type. + + + The metadata about the method signature associated + with this delegate type. + + + + + Determines whether the supplied + is a type. + + + The to be checked. + + + if the supplied + is a ; + if not or the supplied + is . + + + + + Checks if the signature of the supplied + is compatible with the signature expected by the supplied + . + + The event to be checked against. + + The method signature to check for compatibility. + + + if the signature of the supplied + is compatible with the signature + expected by the supplied ; + if not or either of the supplied + parameters is . + + + + + + The of the delegate. + + + + + Use this class for obtaining instances for dynamic code generation. + + +

+ The purpose of this class is to provide a simple abstraction for creating and managing dynamic assemblies. +

+ + Using this factory you can't define several modules within a single dynamic assembly - only a simple one2one relation between assembly/module is used. + +
+ +

The following excerpt from demonstrates usage:

+ + public class DynamicProxyManager + { + public const string PROXY_ASSEMBLY_NAME = "Spring.Proxy"; + + public static TypeBuilder CreateTypeBuilder(string name, Type baseType) + { + // Generates type name + string typeName = String.Format("{0}.{1}_{2}", PROXY_ASSEMBLY_NAME, name, Guid.NewGuid().ToString("N")); + ModuleBuilder module = DynamicCodeManager.GetModuleBuilder(PROXY_ASSEMBLY_NAME); + return module.DefineType(typeName, PROXY_TYPE_ATTRIBUTES); + } + } + +
+ Erich Eichinger + + + +
+ + + prevent instantiation + + + + + Returns the for the dynamic module within the specified assembly. + + + If the assembly does not exist yet, it will be created.
+ This factory caches any dynamic assembly it creates - calling GetModule() twice with + the same name will *not* create 2 distinct modules! +
+ The assembly-name of the module to be returned + the that can be used to define new types within the specified assembly +
+ + + Persists the specified dynamic assembly to the file-system + + the name of the dynamic assembly to persist + + Can only be called in DEBUG_DYNAMIC mode, per ConditionalAttribute rules. + + + + + Removes all registered s. + + + + + A utility class for raising events in a generic and consistent fashion. + + Rick Evans + + + + Create a new EventRaiser instance + + + + + Raises the event encapsulated by the supplied + , passing the supplied + to the event. + + The event to be raised. + The arguments to the event. + a map of sink/exception entries that occurred during event raising + + + + Invokes the supplied , passing the supplied + to the sink. + + The sink to be invoked. + The arguments to the sink. + the map of sink/exception entries to add any exception to + + + + Raises events defensively. + + +

+ Raising events defensively means that as the raised event is passed to each handler, + any thrown by a handler will be caught and silently + ignored. +

+
+ Rick Evans +
+ + + Defensively invokes the supplied , passing the + supplied to the sink. + + The sink to be invoked. + The arguments to the sink. + the map of sink/exception entries to add any exception to + + + + Implement this interface to create your own, delegating + and set them using + + + + + + + + + + + A strategy for handling errors. This is especially useful for handling + errors that occur during asynchronous execution as in such cases it may not be + possible to throw the error to the original caller. + + Mark Fisher + Mark Pollack (.NET) + + + + Handles the error. + + The exception. + + + + Utility methods for IO handling + + + + + Copies one stream into another. + (Don't forget to call on the destination stream!) + + + Does not close the input stream! + + + + + Reads a stream into a byte array. + + + Does not close the input stream! + + + + + Various utility methods relating to numbers. + + +

+ Mainly for internal use within the framework. +

+
+ Aleksandar Seovic +
+ + + Determines whether the supplied is an integer. + + The object to check. + + if the supplied is an integer. + + + + + Determines whether the supplied is a decimal number. + + The object to check. + + if the supplied is a decimal number. + + + + + Determines whether the supplied is of numeric type. + + The object to check. + + true if the specified object is of numeric type; otherwise, false. + + + + + Determines whether the supplied can be converted to an integer. + + The object to check. + + if the supplied can be converted to an integer. + + + + + Determines whether the supplied can be converted to an integer. + + The object to check. + + if the supplied can be converted to an integer. + + + + + Determines whether the supplied can be converted to a number. + + The object to check. + + true if the specified object is decimal number; otherwise, false. + + + + + Is the supplied equal to zero (0)? + + The number to check. + + id the supplied is equal to zero (0). + + + + + Negates the supplied . + + The number to negate. + The supplied negated. + + If the supplied is not a supported numeric type. + + + + + Returns the bitwise not (~) of the supplied . + + The number. + The value of ~. + + If the supplied is not a supported numeric type. + + + + + Bitwise ANDs (&) the specified integral values. + + The first number. + The second number. + + If one of the supplied arguments is not a supported integral types. + + + + + Bitwise ORs (|) the specified integral values. + + The first number. + The second number. + + If one of the supplied arguments is not a supported integral types. + + + + + Bitwise XORs (^) the specified integral values. + + The first number. + The second number. + + If one of the supplied arguments is not a supported integral types. + + + + + Adds the specified numbers. + + The first number. + The second number. + + + + Subtracts the specified numbers. + + The first number. + The second number. + + + + Multiplies the specified numbers. + + The first number. + The second number. + + + + Divides the specified numbers. + + The first number. + The second number. + + + + Calculates remainder for the specified numbers. + + The first number (dividend). + The second number (divisor). + + + + Raises first number to the power of the second one. + + The first number. + The second number. + + + + Coerces the types so they can be compared. + + The right. + The left. + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Helper methods with regard to objects, types, properties, etc. + + +

+ Not intended to be used directly by applications. +

+
+ Rod Johnson + Juergen Hoeller + Rick Evans (.NET) +
+ + + The instance for this class. + + + + + An empty object array. + + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Instantiates the type using the assembly specified to load the type. + + This is a convenience in the case of needing to instantiate a type but not + wanting to specify in the string the version, culture and public key token. + The assembly. + Name of the type. + + + If the or is + + + If cannot load the type from the assembly or the call to InstantiateType(Type) fails. + + + + + Convenience method to instantiate a using + its no-arg constructor. + + +

+ As this method doesn't try to instantiate s + by name, it should avoid loading issues. +

+
+ + The to instantiate* + + A new instance of the . + + If the is + + + If the is an abstract class, an interface, + an open generic type or does not have a public no-argument constructor. + +
+ + + Gets the zero arg ConstructorInfo object, if the type offers such functionality. + + The type. + Zero argument ConstructorInfo + + If the type is an interface, abstract, open generic type, or does not have a zero-arg constructor. + + + + + Determines whether the specified type is instantiable, i.e. not an interface, abstract class or contains + open generic type parameters. + + The type. + + + + Convenience method to instantiate a using + the given constructor. + + +

+ As this method doesn't try to instantiate s + by name, it should avoid loading issues. +

+
+ + The constructor to use for the instantiation. + + + The arguments to be passed to the constructor. + + A new instance. + + If the is + + + If the 's declaring type is an abstract class, + an interface, an open generic type or does not have a public no-argument constructor. + +
+ + + Checks whether the supplied is not a transparent proxy and is + assignable to the supplied . + + +

+ Neccessary when dealing with server-activated remote objects, because the + object is of the type TransparentProxy and regular is testing for assignable + types does not work. +

+

+ Transparent proxy instances always return when tested + with the 'is' operator (C#). This method only checks if the object + is assignable to the type if it is not a transparent proxy. +

+
+ The target to be checked. + The value that should be assigned to the type. + + if the supplied is not a + transparent proxy and is assignable to the supplied . + +
+ + + Determine if the given is assignable from the + given value, assuming setting by reflection and taking care of transparent proxies. + + +

+ Considers primitive wrapper classes as assignable to the + corresponding primitive types. +

+

+ For example used in an object factory's constructor resolution. +

+
+ The target . + The value that should be assigned to the type. + True if the type is assignable from the value. +
+ + + Check if the given represents a + "simple" property, + i.e. a primitive, a , a + , or a corresponding array. + + +

+ Used to determine properties to check for a "simple" dependency-check. +

+
+ + The to check. + +
+ + + Check if the given class represents a primitive array, + i.e. boolean, byte, char, short, int, long, float, or double. + + + + + Determines whether the specified array is null or empty. + + The array to check. + + true if the specified array is null empty; otherwise, false. + + + + + Determine if the given objects are equal, returning + if both are respectively + if only one is . + + The first object to compare. + The second object to compare. + + if the given objects are equal. + + + + + Returns the first element in the supplied . + + + The to use to enumerate + elements. + + + The first element in the supplied . + + + If the supplied did not have any elements. + + + + + Returns the first element in the supplied . + + + The to use to enumerate + elements. + + + The first element in the supplied . + + + If the supplied did not have any elements. + + + If the supplied is . + + + + + Returns the element at the specified index using the supplied + . + + + The to use to enumerate + elements until the supplied is reached. + + + The index of the element in the enumeration to return. + + + The element at the specified index using the supplied + . + + + If the supplied was less than zero, or the + supplied did not contain enough elements + to be able to reach the supplied . + + + + + Returns the element at the specified index using the supplied + . + + + The to use to enumerate + elements until the supplied is reached. + + + The index of the element in the enumeration to return. + + + The element at the specified index using the supplied + . + + + If the supplied was less than zero, or the + supplied did not contain enough elements + to be able to reach the supplied . + + + If the supplied is . + + + + + Gets the qualified name of the given method, consisting of + fully qualified interface/class name + "." method name. + + The method. + qualified name of the method. + + + + Return a String representation of an object's overall identity. + + The object (may be null). + The object's identity as String representation, + or an empty String if the object was null + + + + + Gets a hex String form of an object's identity hash code. + + The obj. + The object's identity code in hex notation + + + + Support matching of file system paths in a manner similar to that of the + NAnt FileSet. + + +

+ Any (back)slashes are converted to forward slashes. +

+
+ + + // true + PathMatcher.Match("c:/*.bat", @"c:\autoexec.bat"); + PathMatcher.Match("c:\fo*\*.bat", @"c:/foobar/autoexec.bat"); + PathMatcher.Match("c:\fo?\*.bat", @"c:/foo/autoexec.bat"); + // false + PathMatcher.Match("c:\fo?\*.bat", @"c:/fo/autoexec.bat"); + + + Federico Spinazzi +
+ + + Determines if a given path matches a NAnt-like pattern. + + + A forward or back-slashed fileset-like pattern. + + A forward or back-slashed full path. + should the match consider the case + + if the path is matched by the pattern; + otherwise . + + + + + Determines if a given path matches a NAnt-like pattern. + + + A forward or back-slashed fileset-like pattern. + + A forward or back-slashed full path. + + if the path is matched by the pattern; + otherwise . + + + + + Replaces back(slashes) with forward slashes. + + + The path or the pattern to modify. + + A forward-slashed string. + + + + Helper method to convert a NAnt-like pattern into the + appropriate pattern for a regular expression. + + The NAnt-like pattern. + A regex-compatible pattern. + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + Utility methods for simple pattern matching, in particular for + Spring's typical "xxx*", "*xxx" and "*xxx*" pattern styles. + + Juergen Hoeller + Mark Pollack + + + Match a String against the given pattern, supporting the following simple + pattern styles: "xxx*", "*xxx" and "*xxx*" matches, as well as direct equality. + + the pattern to match against + + the String to match + + whether the String matches the given pattern + + + + Match a String against the given patterns, supporting the following simple + pattern styles: "xxx*", "*xxx" and "*xxx*" matches, as well as direct equality. + + the patterns to match against + + the String to match + + whether the String matches any of the given patterns + + + + + An implementation of the Java Properties class. + + + For the complete syntax see java.util.Properties JavaDoc. + This class supports an extended syntax. There may also be sole keys on a line, in that case values are treated as null. + + + key1 = value + key2: + key3 + + will result in the name/value pairs: + + key1:="value" + key2:=string.Empty + key3:=<null> + + note, that to specify a null value, the key must not be followed by any character except newline. + + + Simon White + + + + Creates an empty property list with no default values. + + + + + Creates a property list with the specified initial properties. + + The initial properties. + + + + Reads a property list (key and element pairs) from the input stream. + + The stream to load from. + + + + Reads a property list (key and element pairs) from a text reader. + + The text reader to load from. + + + + Reads a property list (key and element pairs) from the input stream. + + the dictionary to put it in + The stream to load from. + + + + Reads a property list (key and element pairs) from a text reader. + + the dictionary to put it in + The text reader to load from. + + + + Strips whitespace from the front of the specified string. + + The string. + The string with all leading whitespace removed. + + + + Splits the specified string into a key / value pair. + + The line to split. + An array containing the key / value pair. + + + + Searches for the property with the specified key in this property list. + + The key. + The property, or null if the key was not found. + + + + Searches for the property with the specified key in this property list. + + The key. + + The default value to be returned if the key is not found. + + The property, or the default value. + + + + Writes this property list out to the specified stream. + + The stream to write to. + + + + Sets the specified property key / value pair. + + The key. + The value. + + + + Writes the properties in this instance out to the supplied stream. + + The stream to write to. + Arbitrary header information. + + + + Removes the key / value pair identified by the supplied key. + + + The key identifying the key / value pair to be removed. + + + + + Adds the specified key / object pair to this collection. + + The key. + The value. + + + + Adds the specified key / object pair to this collection. + + + + + Various reflection related methods that are missing from the standard library. + + Rod Johnson + Juergen Hoeller + Aleksandar Seovic (.NET) + Stan Dvoychenko (.NET) + Bruno Baia (.NET) + + + + Convenience value that will + match all private and public, static and instance members on a class + in a case inSenSItivE fashion. + + + + + Avoid BeforeFieldInit problem + + + + + Checks, if the specified type is a nullable + + + + + Returns signature for the specified , method name and argument + s. + + The the method is in. + The method name. + + The argument s. + + The method signature. + + + + Returns method for the specified , method + name and argument + s. + + + Searches with BindingFlags + When dealing with interface methods, you probable want to 'normalize' method references by calling + . + + + + The target to find the method on. + + The method to find. + + The argument s. May be + if the method has no arguments. + + The target method. + + + + + Resolves a given to the representing the actual implementation. + + + see article How To Get an Explicit Interface Implementation Method. + + a + the type to lookup + the representing the actual implementation method of the specified + + + + Returns an array of parameter s for the specified method + or constructor. + + The method (or constructor). + An array containing the parameter s. + + If is . + + + + + Returns an array of parameter s for the + specified parameter info array. + + The parameter info array. + An array containing parameter s. + + If is or any of the + elements is . + + + + + Returns an array of s that represent + the names of the generic type parameter. + + The method. + An array containing the parameter names. + + If is . + + + + + Returns an array of s that represent + the names of the generic type parameter. + + The parameter info array. + An array containing parameter names. + + If is or any of the + elements is . + + + + + From a given list of methods, selects the method having an exact match on the given ' types. + + the list of methods to choose from + the arguments to the method + the method matching exactly the passed ' types + + If more than 1 matching methods are found in the list. + + + + + From a given list of methods, selects the method having an exact match on the given ' types. + + the type of method (used for exception reporting only) + the list of methods to choose from + the arguments to the method + the method matching exactly the passed ' types + + If more than 1 matching methods are found in the list. + + + + + From a given list of constructors, selects the constructor having an exact match on the given ' types. + + the list of constructors to choose from + the arguments to the method + the constructor matching exactly the passed ' types + + If more than 1 matching methods are found in the list. + + + + + Packages arguments into argument list containing parameter array as a last argument. + + Argument vaklues to package. + Total number of oarameters. + Type of the param array element. + Packaged arguments. + + + + Convenience method to convert an interface + to a array that contains + all the interfaces inherited and the specified interface. + + The interface to convert. + An array of interface s. + + If the specified is not an interface. + + + If is . + + + + + Is the supplied the default indexer for the + supplied ? + + + The name of the property on the supplied to be checked. + + + The to be checked. + + + if the supplied is the + default indexer for the supplied . + + + If the supplied is . + + + + + Is the supplied declared on one of these interfaces? + + The method to check. + The array of interfaces we want to check. + + if the method is declared on one of these interfaces. + + + If any of the s specified is not an interface. + + + If or any of the specified interfaces is + . + + + + + Returns the default value for the specified + + +

+ Follows the standard .NET conventions for default values where + relevant; for example, all numeric types default to the value + 0. +

+
+ + The to return default value for. + + + The default value for the specified . + + + If the supplied is an enumerated type that + has no values. + +
+ + + Returns an array consisting of the default values for the supplied + . + + + The array of s to return default values for. + + + An array consisting of the default values for the supplied + . + + + If any of the elements in the supplied + array is an enumerated type that has no values. + + + + + + Checks that the parameter s of the + supplied match the parameter + s of the supplied + . + + The method to be checked. + + The array of parameter s to check against. + + + if the parameter s + match. + + + + + Returns an array containing the s of the + objects in the supplied array. + + + The objects array for which the corresponding s + are needed. + + + An array containing the s of the objects + in the supplied array; this array will be empty (but not + if the supplied + is null or has no elements. + + +

+ [C#]
+ Given an array containing the following objects, + [83, "Foo", new object ()], the + array returned from this method call would consist of the following + elements... + [Int32, String, Object]. +

+
+
+ + + Given the return its representation as + it would appear in the source code files. + + + Largely intended to handle generic types where .ToString() will typically return: + "System.Collections.Generic.List`1[System.Collections.Generic.Dictionary`2[System.String,System.Int32]]" + and this method will instead return: + "System.Collections.Generic.List<System.Collections.Generic.Dictionary<string,int>>" + + The type. + Friendly string representing the Type + + + + Does the given and/or it's superclasses + have at least one or more methods with the given name (with any + argument types)? + + +

+ Includes non-public methods in the methods searched. +

+
+ + The to be checked. + + + The name of the method to be searched for. Case inSenSItivE. + + + if the given or / and it's + superclasses have at least one or more methods (with any argument types); + if not, or either of the parameters is . + +
+ + + Within , counts the number of overloads for the method with the given (case-insensitive!) + + The type to be searched + the name of the method for which overloads shall be counted + The number of overloads for method within type + + + + Creates a . + + +

+ Note that if a non- + is supplied, any read write properties exposed by the + will be used to overwrite values that may have been passed in via the + . That is, the will be used + to initialize the custom attribute, and then any read-write properties on the + will be plugged in. +

+
+ + The desired . + + + Any constructor arguments for the attribute (may be + in the case of no arguments). + + + Source attribute to copy properties from (may be ). + + A custom attribute builder. + + If the parameter is . + + + If the parameter is not a + that derives from the class. + + +
+ + + Creates a . + + + The desired . + + + Source attribute to copy properties from (may be ). + + A custom attribute builder. + + + + Creates a . + + + The source attribute to copy properties from. + + A custom attribute builder. + + If the supplied is + . + + + + + Creates a . + + + The desired . + + A custom attribute builder. + + + + Creates a . + + + The desired . + + + Any constructor arguments for the attribute (may be + in the case of no arguments). + + A custom attribute builder. + + + + Creates a . + + + The to create + the custom attribute builder from. + + A custom attribute builder. + + + + Calculates and returns the list of attributes that apply to the + specified type or method. + + The type or method to find attributes for. + + A list of custom attributes (CustomAttributeData or Attribute instances) + that should be applied to type or method. + + + + + Tries to find matching methods in the specified + for each method in the supplied list. + + + The to look for matching methods in. + + The methods to match. + + A flag that specifies whether to throw an exception if a matching + method is not found. + + A list of the matched methods. + + If either of the or + parameters are . + + + + + Returns the of the supplied + . + + +

+ If the is a + instance, the return value of this method call with be the + parameter cast to a + . If the is + anything other than a , the return value + will be the result of invoking the 's + method. +

+
+ + A or instance. + + + The argument if it is a + or the result of invoking + on the argument if it + is an . + + + If the is . + +
+ + + Unwraps the supplied + and returns the inner exception preserving the stack trace. + + + The to unwrap. + + The unwrapped exception. + + + + Is the supplied can be accessed outside the assembly ? + + The type to check. + + if the type can be accessed outside the assembly; + Otherwise . + + + + + Determines whether the specified type is nullable. + + The type. + + true if the specified type is ullable]; otherwise, false. + + + + + Is the supplied can be accessed + from the supplied friendly assembly ? + + The type to check. + The friendly assembly name. + + if the type can be accessed + from the supplied friendly assembly; Otherwise . + + + + + Gets all of the interfaces implemented by + the specified . + + + The object to get the interfaces of. + + + All of the interfaces implemented by the + . + + + + + Returns the explicit that is the root cause of an exception. + + + If the InnerException property of the current exception is a null reference + or a , returns the current exception. + + The last exception thrown. + + The first explicit exception thrown in a chain of exceptions. + + + + + Copies all fields from one object to another. + + + The types of both objects must be related. This means, that either of the following is true: + + fromObject.GetType() == toObject.GetType() + fromObject.GetType() is derived from toObject.GetType() + toObject.GetType() is derived from fromObject.GetType() + + + The source object + The object, who's fields will be populated with values from the source object + If the object's types are not related + + + + Convenience method that uses reflection to return the value of a non-public field of a given object. + + Useful in certain instances during testing to avoid the need to add protected properties, etc. to a class just to facilitate testing. + The instance of the object from which to retrieve the field value. + Name of the field on the object from which to retrieve the value. + + + + + Convenience method that uses reflection to set the value of a non-public field of a given object. + + Useful in certain instances during testing to avoid the need to add protected properties, etc. to a class just to facilitate testing. + The instance of the object from which to set the field value. + Name of the field on the object to which to set the value. + The field value to set. + + + + Creates a . + + Bruno Baia + + + + Creates a new instance of the + class. + + The custom attribute type. + + + + Creates a new instance of the + class. + + The custom attribute type. + The custom attribute constructor arguments. + + + + Adds the specified values to the constructor argument list + used to create the custom attribute. + + An array of argument values. + + + + Adds a property value to the custom attribute. + + The property name. + The property value. + + + + Creates the . + + The created . + + + + Utility class to be used from within this assembly for executing security critical code + NEVER EVER MAKE THIS PUBLIC! + + Erich Eichinger + + + + Miscellaneous utility methods. + + +

+ Mainly for internal use within the framework. +

+
+ Rod Johnson + Juergen Hoeller + Keith Donald + Aleksandar Seovic (.NET) + Mark Pollack (.NET) + Rick Evans (.NET) + Erich Eichinger (.NET) +
+ + + The string that signals the start of an Ant-style expression. + + + + + The string that signals the end of an Ant-style expression. + + + + + An empty array of instances. + + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Tokenize the given into a + array. + + +

+ If is , returns an empty + array. +

+

+ If is or the empty + , returns a array with one + element: itself. +

+
+ The to tokenize. + + The delimiter characters, assembled as a . + + + Trim the tokens via . + + + Omit empty tokens from the result array. + An array of the tokens. +
+ + + Tokenize the given into a + array. + + +

+ If is , returns an empty + array. +

+

+ If is or the empty + , returns a array with one + element: itself. +

+
+ The to tokenize. + + The delimiter characters, assembled as a . + + + Trim the tokens via . + + + Omit empty tokens from the result array. + + + Pairs of quote characters. within a pair of quotes are ignored + + An array of the tokens. +
+ + + Convert a CSV list into an array of s. + + + Values may also be quoted using doublequotes. + + A CSV list. + + An array of s, or the empty array + if is . + + + + + Take a which is a delimited list + and convert it to a array. + + +

+ If the supplied is a + or zero-length string, then a single element + array composed of the supplied + will be + eturned. If the supplied + is , then an empty, + zero-length array will be returned. +

+
+ + The to be parsed. + + + The delimeter (this will not be returned). Note that only the first + character of the supplied is used. + + + An array of the tokens in the list. + +
+ + + Convenience method to return an + as a delimited + (e.g. CSV) . + + + The to parse. + + + The delimiter to use (probably a ','). + + The delimited string representation. + + + + Convenience method to return an + as a CSV + . + + + The to display. + + The delimited string representation. + + + + Convenience method to return an array as a CSV + . + + + The array to parse. Elements may be of any type ( + will be called on each + element). + + + + + Convenience method to return a + array as a delimited (e.g. CSV) . + + + The array to parse. Elements may be of any type ( + will be called on each + element). + + + The delimiter to use (probably a ','). + + + + Checks if a string has length. + + The string to check, may be . + + + if the string has length and is not + . + + + + StringUtils.HasLength(null) = false + StringUtils.HasLength("") = false + StringUtils.HasLength(" ") = true + StringUtils.HasLength("Hello") = true + + + + + + Checks if a has text. + + +

+ More specifically, returns if the string is + not , it's is > + zero (0), and it has at least one non-whitespace character. +

+
+ + The string to check, may be . + + + if the is not + , + > zero (0), and does not consist + solely of whitespace. + + + + StringUtils.HasText(null) = false + StringUtils.HasText("") = false + StringUtils.HasText(" ") = false + StringUtils.HasText("12345") = true + StringUtils.HasText(" 12345 ") = true + + +
+ + + Checks if a is + or an empty string. + + +

+ More specifically, returns if the string is + , it's is equal + to zero (0), or it is composed entirely of whitespace + characters. +

+
+ + The string to check, may (obviously) be . + + + if the is + , has a length equal to zero (0), or + is composed entirely of whitespace characters. + + + + StringUtils.IsNullOrEmpty(null) = true + StringUtils.IsNullOrEmpty("") = true + StringUtils.IsNullOrEmpty(" ") = true + StringUtils.IsNullOrEmpty("12345") = false + StringUtils.IsNullOrEmpty(" 12345 ") = false + + +
+ + + Returns , if it contains non-whitespaces. null otherwise. + + + + + Strips first and last character off the string. + + The string to strip. + The stripped string. + + + + Returns a list of Ant-style expressions from the specified text. + + The text to inspect. + + A list of expressions that exist in the specified text. + + + If any of the expressions in the supplied + is empty (${}). + + + + + Replaces Ant-style expression placeholder with expression value. + + +

+ +

+
+ The string to set the value in. + The name of the expression to set. + The expression value. + + A new string with the expression value set; the + value if the supplied + is , has a length + equal to zero (0), or is composed entirely of whitespace + characters. + +
+ + + Surrounds (prepends and appends) the string value of the supplied + to the supplied . + + +

+ The return value of this method call is always guaranteed to be non + . If every value passed as a parameter to this method is + , the string will be returned. +

+
+ + The prefix and suffix that respectively will be prepended and + appended to the target . If this value + is not a value, it's attendant + value will be used. + + + The target that is to be surrounded. If this value is not a + value, it's attendant + value will be used. + + The surrounded string. +
+ + + Surrounds (prepends and appends) the string values of the supplied + and to the supplied + . + + +

+ The return value of this method call is always guaranteed to be non + . If every value passed as a parameter to this method is + , the string will be returned. +

+
+ + The value that will be prepended to the . If this value + is not a value, it's attendant + value will be used. + + + The target that is to be surrounded. If this value is not a + value, it's attendant + value will be used. + + + The value that will be appended to the . If this value + is not a value, it's attendant + value will be used. + + The surrounded string. +
+ + + Converts escaped characters (for example "\t") within a string + to their real character. + + The string to convert. + The converted string. + + + + Utility class containing miscellaneous system-level functionality. + + Aleksandar Seovic + + + + Registers assembly resolver that iterates over the + assemblies loaded into the current + in order to find an assembly that cannot be resolved. + + + This method has to be called if you need to serialize dynamically + generated types in transient assemblies, such as Spring AOP proxies, + because standard .NET serialization engine always tries to load + assembly from the disk. + + + + + Returns true if running on Mono + + Tests for the presence of the type Mono.Runtime + + + + Returns true if running on CLR 4.0 under InProc SxS mode + + + + + Gets the thread id for the current thread. Use thread name is available, + otherwise use CurrentThread.GetHashCode() for .NET 1.0/1.1 and + CurrentThread.ManagedThreadId otherwise. + + The thread id. + + + + Holds text position information for e.g. error reporting purposes. + + + + + + + Creates a new TextPositionInfo instance. + + + + + Creates a new TextPositionInfo instance, copying values from another instance. + + + + + The filename related to this text position + + + + + The line number related to this text position + + + + + The line position related to this text position + + + + + UniqueKey allows for generating keys unique to a type or particular instance and a partial name, + that can e.g. be used as keys in . + + + // shows usage type-scoped keys + UniqueKey classAKey = UniqueKey.GetTypeScoped(typeof(ClassA), "myKey"); + UniqueKey classBKey = UniqueKey.GetTypeScoped(typeof(ClassB), "myKey"); + + HttpContext.Current.Items.Add( classAKey, "some value unqiue for class A having key 'myKey'"); + object value = HttpContext.Current.Items[ UniqueKey.GetTypeScoped(typeof(ClassA), "myKey") ]; + Assert.AreEqual( "some value unique for class A having key 'myKey'", value); + + HttpContext.Current.Items.Add( classBKey, "some value unqiue for class B having key 'myKey'"); + object value = HttpContext.Current.Items[ UniqueKey.GetTypeScoped(typeof(ClassB), "myKey") ]; + Assert.AreEqual( "some value unique for class B having key 'myKey'", value); + + + + + Initialize a new instance of from its string representation. + See and See for details. + + The string representation of the new instance. + + + + Compares this instance to another. + + + + + Compares this instance to another. + + + + + Returns the hash code for this key. + + + + + + Returns a string representation of this key. + + + + + Creates a new key instance unique to the given instance. + + The instance the key shall be unique to + The partial key to be made unique + + + If is of type + + + + Creates a new key instance unique to the given type. + + The type the key shall be unique to + The partial key to be made unique + + + + Returns a key unique for the given instance. + + The instance the key shall be unique to + The partial key to be made unique + A key formatted as typename[instance-id].partialkey + + + + Returns a key unique for the given type. + + The type the key shall be unique to + The partial key to be made unique + A key formatted as typename.partialkey + + + + XML utility methods. + + Aleksandar Seovic + + + + Gets an appropriate implementation + for the supplied . + + The XML that is going to be read. + XML schemas that should be used for validation. + Validation event handler. + + A validating implementation. + + + + + Gets an appropriate implementation + for the supplied . + + The XML that is going to be read. + to be used for resolving external references + XML schemas that should be used for validation. + Validation event handler. + + A validating implementation. + + + + + Gets an appropriate implementation + for the supplied . + + The XML that is going to be read. + + A non-validating implementation. + + + + + Implementation of that adds error message + to the validation errors container. + + Aleksandar Seovic + + + + Abstract base class that should be extended by all + validation actions. + + +

+ This class implements template Execute method + and defines OnValid and OnInvalid methods that + can be overriden + by specific validation actions. +

+
+ Aleksandar Seovic +
+ + + An action that should be executed after validator is evaluated. + + +

+ This interface allows us to define the actions that should be executed + after validation in a generic fashion. +

+

+ For example, addition of error messages to validation errors collection + is performed by one specific implementation of this interface, . +

+
+ Aleksandar Seovic +
+ + + Executes the action. + + Whether associated validator is valid or not. + Validation context. + Additional context parameters. + Validation errors container. + + + + Initializes a new instance of the class. + + + + + Executes the action. + + Whether associated validator is valid or not. + Validation context. + Additional context parameters. + Validation errors container. + + + + Called when associated validator is valid. + + Validation context. + Additional context parameters. + Validation errors container. + + + + Called when associated validator is not valid. + + Validation context. + Additional context parameters. + Validation errors container. + + + + Evaluates 'when' expression. + + Root context to use for expression evaluation. + Additional context parameters. + True if the condition is true, False otherwise. + + + + Gets or sets the expression that determines if this validator should be evaluated. + + The expression that determines if this validator should be evaluated. + + + + Initializes a new instance of the class. + + Error message resource identifier. + Names of the error providers this message should be added to. + + + + Called when associated validator is invalid. + + Validation context. + Additional context parameters. + Validation errors container. + + + + Resolves the error message. + + Validation context to resolve message parameters against. + Additional context parameters. + Resolved error message + + + + Resolves the message parameters. + + List of parameters to resolve. + Validation context to resolve parameters against. + Additional context parameters. + Resolved message parameters. + + + + Sets the expressions that should be resolved to error message parameters. + + The expressions that should be resolved to error message parameters. + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Expression that defines the exception to throw when the validator is not valid. + + + + Initializes a new instance of the class with an expression + that defines the exception to throw. + + + + + Called when associated validator is invalid. + + Validation context. + Additional context parameters. + Validation errors container. + + + + Gets or sets the exception to throw + + The throws. + + + + Implementation of that allows you + to define Spring.NET expressions that should be evaluated after + validation. + + Aleksandar Seovic + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Expression to execute when validator is valid. + Expression to execute when validator is not valid. + + + + Initializes a new instance of the class. + + Expression to execute when validator is valid. + Expression to execute when validator is not valid. + + + + Called when associated validator is valid. + + Validation context. + Additional context parameters. + Validation errors container. + + + + Called when associated validator is invalid. + + Validation context. + Additional context parameters. + Validation errors container. + + + + Gets or sets the expression to execute when validator is valid. + + The expression to execute when validator is valid. + + + + Gets or sets the expression to execute when validator is not valid. + + The expression to execute when validator is not valid. + + + + Implementation of the custom configuration parser for validator definitions. + + Aleksandar Seovic + + + + Initializes a new instance of the class. + + + + + Parse the specified element and register any resulting + IObjectDefinitions with the IObjectDefinitionRegistry that is + embedded in the supplied ParserContext. + + The element to be parsed into one or more IObjectDefinitions + The object encapsulating the current state of the parsing + process. + + The primary IObjectDefinition (can be null as explained above) + + + Implementations should return the primary IObjectDefinition + that results from the parse phase if they wish to used nested + inside (for example) a <property> tag. + Implementations may return null if they will not + be used in a nested scenario. + + + + + + Parses the validator definition. + + Validator's identifier. + The element to parse. + The parser helper. + Validator object definition. + + + + Parses the attribute of the given from the XmlElement and, if available, adds a property of the given with + the parsed value. + + + + + Parses and potentially registers a validator. + + + Only validators that have id attribute specified are registered + as separate object definitions within application context. + + Validator XML element. + The parser helper. + Validator object definition. + + + + Gets the name of the object type for the specified element. + + The element. + The name of the object type. + + + + Creates an error message action based on the specified message element. + + The message element. + The parser helper. + The error message action definition. + + + + Creates a generic action based on the specified element. + + The action definition element. + The parser helper. + Generic validation action definition. + + + + Creates object definition for the validator reference. + + The action definition element. + The parser helper. + Generic validation action definition. + + + + Evaluates validator test using condition evaluator. + + Aleksandar Seovic + + + + Base class that defines common properties for all single validators. + + +

+ Custom single validators should always extend this class instead of + simply implementing interface, in + order to inherit common validator functionality. +

+
+ Aleksandar Seovic + Erich Eichinger +
+ + + Base class that defines common properties for all validators. + + +

+ Custom validators should always extend this class instead of + simply implementing interface, in + order to inherit common validator functionality. +

+
+ Aleksandar Seovic + Erich Eichinger +
+ + + An object that can validate application-specific objects. + + +

+ The primary motivation for this interface is to enable validation to be + decoupled from the (user) interface and placed in business objects. +

+

+ Application developers writing their own custom + implementations will + typically not implement this interface directly. In most cases, custom + validators woud be better served deriving from the + class, with the + custom validation ligic being implemented in an override of the + + + template method. +

+
+ Aleksandar Seovic + +
+ + + Validates the specified object. + + The object to validate. + + The instance to add any error + messages to in the case of validation failure. + + + if validation was successful. + + + + + Validates the specified object. + + The object to validate. + Additional context parameters. + + The instance to add any error + messages to in the case of validation failure. + + + if validation was successful. + + + + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the class. + + The expression that determines if this validator should be evaluated. + + + + Validates the specified object. + + The object to validate. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Validates the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Evaluates when expression. + + Root context to use for expression evaluation. + Additional context parameters. + True if the condition is true, False otherwise. + + + + Processes the error messages. + + Whether validator is valid or not. + Validation context. + Additional context parameters. + Validation errors container. + + + + Gets or sets the expression that determines if this validator should be evaluated. + + The expression that determines if this validator should be evaluated. + + + + Gets or sets the validation actions. + + The actions that should be executed after validation. + + + + Creates a new instance of the validator without any + and criteria + + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Validates the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Validates test object. + + Object to validate. + True if specified object is valid, False otherwise. + + + + Evaluates test expression. + + Root context to use for expression evaluation. + Additional context parameters. + Result of the test expression evaluation, or validation context if test is null. + + + + Gets or sets the test expression. + + The test expression. + + + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Evaluates the test using condition evaluator. + + +

+ Test can be any logical expression that is supported by the Spring.NET logical + expression evaluation engine, and can use any variables that can be resolved + by the variable resolver used by the validation engine. +

+
+ The object to validate. + + if the supplied is valid. + +
+ + + Perform credit card validations. + + + By default, all supported card types are allowed. You can specify + which credit card type validator should be used by setting + the value of property to a concrete + instance. + + + + + Creates a new instance of the UrlValidator class. + + + + + Creates a new instance of the UrlValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + Credit Card type validator to use. + + + + Creates a new instance of the UrlValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + Credit Card type validator to use. + + + + Validates the supplied . + + + In the case of the class, + the test should be a string variable that will be evaluated and the object + obtained as a result of this evaluation will be checked if it is + a valid credit card number. + + The object to validate. + + if the supplied is valid + credit card number. + + + + + Checks if the is a valid credit card number. + + + The card number to validate. + + + true if the card number is valid. + + + + + Validates card number with the specified validator. + + + Credit card number to validate. + + + true if credit card number is a valid number of credit card type specified. + + + + + Checks for a valid credit card number. + + + Credit Card Number. + + + true if the card number passes the LuhnCheck. + + + + + Credit card type validator to use. + + + Can be concrete implementations of + interface. The following are available implementations: + , , , + . + + + + + CreditCardType interface defines how validation is performed + for one type/brand of credit card. + + + + + Returns true if the card number matches this type of + credit card. + + + The card number, never null. + + + true if the number matches. + + + + + Visa credit card type validation support. + + + + + Indicates, wheter the given credit card number matches a visa number. + + + + + American Express credit card type validation support. + + + + + Indicates, wheter the given credit card number matches an amex number. + + + + + Discover credit card type validation support. + + + + + Indicates, wheter the given credit card number matches a discover number. + + + + + Mastercard credit card type validation support. + + + + + Indicates, wheter the given credit card number matches a mastercard number. + + + + + Perform email validations. + + +

+ This implementation is not guaranteed to catch all possible errors in an + email address. For example, an address like nobody@noplace.nowhere will + pass validator, even though there is no TLD "nowhere". + + Goran Milosavljevic + + +

+ Creates a new instance of the EmailValidator class. + +
+ + + Creates a new instance of the EmailValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the EmailValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Validates the supplied . + + + In the case of the class, + the test should be a string variable that will be evaluated and the object + obtained as a result of this evaluation will be checked if it is + a valid e-mail address. + + The object to validate. + + if the supplied is valid + e-mail address. + + + + + Regular expression used for validation of object passed to this . + + + + + Validates that the object is valid ISBN-10 or ISBN-13 value. + + Goran Milosavljevic + + + + Creates a new instance of the ISBNValidator class. + + + + + Creates a new instance of the ISBNValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the ISBNValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Validates the supplied . + + + In the case of the class, + the test should be a string variable that will be evaluated and the object + obtained as a result of this evaluation will be tested using the ISBN-10 or + ISBN-13 validation rules. + + The object to validate. + + if the supplied is valid ISBN. + + + + + Validates against ISBN-10 or ISBN-13 validation + rules. + + + ISBN string to validate. + + + true if is a valid ISBN-10 or ISBN-13 code. + + + + + ISBN-10 consists of 4 groups of numbers separated by either + dashes (-) or spaces. + + + The first group is 1-5 characters, second 1-7, third 1-6, + and fourth is 1 digit or an X. + + + + + ISBN-13 consists of 5 groups of numbers separated by either + dashes (-) or spaces. + + + The first group is 978 or 979, the second group is + 1-5 characters, third 1-7, fourth 1-6, and fifth is 1 digit. + + + + + Validates that object matches specified regular expression. + + +

+ The test expression must evaluate to a ; + otherwise, an exception is thrown. +

+
+ Aleksandar Seovic +
+ + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + The regular expression to match against. + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + The regular expression to match against. + + + + Validates an object. + + Object to validate. + + if the supplied + object is valid. + + + If the supplied is not a + + + + + + The regular expression text to match against. + + The regular expression text. + + + + Gets or sets a value indicating whether to do a partial match instead of a full match. + Default is false. + + + + + The for the regular expression evaluation. + + The regular expression evaluation options. + + + + + Validates that required value is not empty. + + +

+ This validator uses following rules to determine if target value is valid: + + + + + + + + + + + + + + + + + + + + + + + + + +
Target Valid Value
A .Not or an empty string.
A .Not and not .
One of the number types.Not zero.
A .Not or whitespace.
Any reference type other than .Not .
+

+

+ You cannot use this validator to validate any value types other than the ones + specified in the table above. +

+
+ Aleksandar Seovic +
+ + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Validates the supplied . + + + In the case of the class, + the test should be a variable expression that will be evaluated and the object + obtained as a result of this evaluation will be tested using the rules described + in the class overview of the + class. + + The object to validate. + + if the supplied is valid. + + + + + Validates that the value is valid URL. + + Goran Milosavljevic + + + + Creates a new instance of the UrlValidator class. + + + + + Creates a new instance of the UrlValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Creates a new instance of the UrlValidator class. + + The expression to validate. + The expression that determines if this validator should be evaluated. + + + + Validates the supplied . + + + In the case of the class, + the test should be a string variable that will be evaluated and the object + obtained as a result of this evaluation will be tested using the URL validation rules. + + The object to validate. + + if the supplied is valid. + + + + + Regular expression used for validation of object passed to this . + + + + + implementation that supports grouping of validators. + + +

+ This validator will be valid when one or more of the validators in the Validators + collection are valid. +

+

+ ValidationErrors property will return a union of all validation error messages + for the contained validators, but only if this validator is not valid (meaning, when none + of the contained validators are valid). +

+

Note, that defaults to true for this validator type!

+
+ Aleksandar Seovic + Erich Eichinger +
+ + + Base class for composite validators + + + + + Initializes a new instance + + + + + Initializes a new instance + + The expression that determines if this validator should be evaluated. + + + + Initializes a new instance + + The expression that determines if this validator should be evaluated. + + + + Validates the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Actual implementation how to validate the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Gets or sets the child validators. + + The validators. + + + + When set true, shortcircuits evaluation. + + + Setting this property true causes the evaluation process to prematurely abort + if the end result is known. Any remaining child validators will not be considered then. + Setting this value false causes implementations to evaluate all child validators, regardless + of the potentially already known result. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The expression that determines if this validator should be evaluated. + + + + Initializes a new instance of the class. + + The expression that determines if this validator should be evaluated. + + + + Validates the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + implementation that supports validating collections. + + +

+ This validator will be valid only when all of the validators in the Validators + collection are valid for all of the objects in the specified collection. +

+

+ You can specify if you want to validate all of the collection elements regardless of the errors by + setting the property to false. +

+

Note, that defaults to true for this validator type!

+

+ If you set the IncludeElementErrors property to true, + ValidationErrors collection will contain a union of all validation error messages + for the contained validators; + Otherwise it will contain only error messages that were set for this Validator. +

+
+ Damjan Tomic + Aleksandar Seovic +
+ + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The bool that determines if all elements of the collection should be evaluated. + regardless of the Errors + + The bool that determines whether Validate method should collect + all error messages returned by the item validators + + + + Initializes a new instance of the class. + + The expression that determines if this validator should be evaluated. + The bool that determines if this all elements of the collection should be evaluated. + regardless of the Errors + + The bool that determines whether Validate method should collect + all error messages returned by the item validators + + + + Initializes a new instance of the class. + + The expression that determines if this validator should be evaluated. + The bool that determines if this all elements of the collection should be evaluated. + regardless of the Errors + + The bool that determines whether Validate method should collect + all error messages returned by the item validators + + + + Validates the specified collection of objects. + If the IncludeElementErrors property was set to true, + collection will contain a union of all validation error messages + for the contained validators; + Otherwise it will contain only error messages that were set for this Validator. + + The collection to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Actual implementation how to validate the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Gets or sets the value that indicates whether to validate all elements of the collection + regardless of the errors. + + This is just an alias for property + + + + Gets or sets the value that indicates whether to capture all the errors of the specific + elements of the collection + + + + + Gets or sets the expression that should be used to narrow validation context. + + The expression that should be used to narrow validation context. + + + + implementation that supports grouping of validators. + + +

+ This validator will be valid when one and only one of the validators in the Validators collection are valid +

+

+ ValidationErrors property will return a union of all validation error messages + for the contained validators, but only if this validator is not valid (meaning, when none + of the contained validators are valid). +

+

+ By default, this validator group uses == true semantics. +

+
+ Aleksandar Seovic + Erich Eichinger +
+ + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The expression that determines if this validator should be evaluated. + + + + Initializes a new instance of the class. + + The expression that determines if this validator should be evaluated. + + + + Actual implementation how to validate the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + An interface that validation errors containers have to implement. + + Aleksandar Seovic + + + + Adds the supplied to this + instance's collection of errors. + + + The provider that should be used for message grouping; can't be + . + + The error message to add. + + If the supplied or is . + + + + + Merges another instance of into this one. + + +

+ If the supplied is , + then no errors will be added to this instance, and this method will + (silently) return. +

+
+ + The validation errors to merge; can be . + +
+ + + Gets the list of errors for the supplied error . + + +

+ If there are no errors for the supplied , + an empty will be returned. +

+
+ Error key that was used to group messages. + + A list of all s for the supplied lookup . + +
+ + + Gets the list of resolved error messages for the supplied lookup . + + +

+ If there are no errors for the supplied lookup , + an empty will be returned. +

+
+ Error key that was used to group messages. + to resolve messages against. + + A list of resolved error messages for the supplied lookup . + +
+ + + Does this instance contain any validation errors? + + +

+ If this returns , this means that it (obviously) + contains no validation errors. +

+
+ if this instance is empty. +
+ + + Gets the list of all error providers. + + + + + Allows developers to specify which validator should be used + to validate method argument. + + Damjan Tomic + Aleksandar Seovic + + + + Creates an attribute instance. + + + The name of the validator to use (must be defined within + Spring application context). + + + + + Gets the name of the validator to use. + + The name of the validator to use. + + + + A container for validation errors. + + +

+ This class groups validation errors by validator names and allows + access to both the complete errors collection and to the errors for a + certain validator. +

+
+ Aleksandar Seovic + Goran Milosavljevic +
+ + + Default constructor. + + + + + This property is reserved, apply the + + to the class instead. + + + An that describes the + XML representation of the object that is produced by + the + method and consumed by the + + method. + + + + + Generates an object from its XML representation. + + + The stream + from which the object is deserialized. + + + + + Converts an object into its XML representation. + + + The stream + to which the object is serialized. + + + + + Adds the supplied to this + instance's collection of errors. + + + The provider that should be used for message grouping; can't be + . + + The error message to add. + + If the supplied or is . + + + + + Merges another instance of into this one. + + +

+ If the supplied is , + then no errors will be added to this instance, and this method will + (silently) return. +

+
+ + The validation errors to merge; can be . + +
+ + + Gets the list of errors for the supplied lookup . + + +

+ If there are no errors for the supplied lookup , + an empty will be returned. +

+
+ Error key that was used to group messages. + + A list of all s for the supplied lookup . + +
+ + + Gets the list of resolved error messages for the supplied lookup . + + +

+ If there are no errors for the supplied lookup , + an empty will be returned. +

+
+ Error key that was used to group messages. + to resolve messages against. + + A list of resolved error messages for the supplied lookup . + +
+ + + Does this instance contain any validation errors? + + +

+ If this returns , this means that it (obviously) + contains no validation errors. +

+
+ if this instance is empty. +
+ + + Gets the list of all providers. + + + + + Thrown by the validation advice if the method parameters validation fails. + + Aleksandar Seovic + + + + Creates a new instance of the ValidationException class. + + + + + Creates a new instance of the ValidationException class with + specified validation errors. + + + Validation errors. + + + + + Creates a new instance of the ValidationException class with the + specified message. + + + A message about the exception. + + + + + Creates a new instance of the ValidationException class with the + specified message and validation errors. + + + A message about the exception. + + + Validation errors. + + + + + Creates a new instance of the ValidationException class with the + specified message and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the ValidationException class with the + specified message, root cause and validation errors. + + + A message about the exception. + + + The root exception that is being wrapped. + + + Validation errors. + + + + + Creates a new instance of the ValidationException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Implements object serialization. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets validation errors. + + Validation errors. + + + + implementation that supports grouping of validators. + + +

+ This validator will be valid only when all of the validators in the Validators + collection are valid. +

+

+ ValidationErrors property will return a union of all validation error messages + for the contained validators. +

+
+ Aleksandar Seovic + Erich Eichinger +
+ + + Initializes a new instance + + + + + Initializes a new instance + + The expression that determines if this validator should be evaluated. + + + + Initializes a new instance + + The expression that determines if this validator should be evaluated. + + + + Actual implementation how to validate the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Represents a reference to an externally defined validator object + + +

+ This class allows validation groups to reference validators that + are defined outside of the group itself. +

+

+ It also allows users to narrow the context for the referenced validator + by specifying value for the Context property. +

+
+ Aleksandar Seovic +
+ + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + + The expression that determines if this validator should be evaluated. + + + + + Creates a new instance of the class. + + + The expression that determines if this validator should be evaluated. + + + + + Validates the specified object. + + The object to validate. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Validates the specified object. + + The object to validate. + Additional context parameters. + instance to add error messages to. + True if validation was successful, False otherwise. + + + + Gets or sets the name of the referenced validator. + + The name of the referenced validator. + + + + Gets or sets the expression that should be used to narrow validation context. + + The expression that should be used to narrow validation context. + + + + Gets or sets the expression that determines if this validator should be evaluated. + + The expression that determines if this validator should be evaluated. + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.dll b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.dll new file mode 100644 index 0000000000000000000000000000000000000000..26b751ed1c3b03bdbb989916aaf1ba9152e2965a GIT binary patch literal 76288 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�H&6tW%d#Zt!fxLSSg=tRG^`N_3?P5L1d zpB2ryLO$1ON9b@F%&eG?t*hPs(l%6`l{J_0jk$syd}{ihSxGr)JA9?~JSA;|JOEQ! z7fpr6_FTTroaxr8i>3-2=GLC4#1GR{DlX)k8;e}xAmcUj{=w*1ocBn$iF*{q@6N4V z{)x)eddkr~gFR<)U9BaPE48&|Ob-ax{ha7_=REuI+T|Y5U0;o}7au!{`FyFp$xhh9 zc6}g{^?wNu0Qq{=#@S_;-THZb{pirL5w;A~Q`JIyOQ~7jx@bb!t`nm9&b7Cwwq1wG zi%S>x)$4Vzq>NJ6;5u@-QlZhd)UXXlMRT|}UBZ@AOxbkT_8DqJqPu+F%*2T6e+83d zjq&2}q>rp5zSPUfFV~zSsBZg^QeuLhK5sBr>u!u1JF;!fZJlN!9WIMvVvqXIsP>qx z_W0*)7*S|y>tHOiXLq%HM{|W8D{K1>wIeWp!;rQ@XTGz|UcIViM=6;@sUKZi+n1#6 z@Xw_%rJYM0ZB5A~yc%ug(Bzy;&v`TBFO#b0zL-$#EEKa%c19U)8w(Ttdd@d@{QV?# z?icTrThVB-rL(EfR%pqZ(IspPyP#Nqre(2y{PmKurTXO;Y-uUBH)e9V@yxrXC$?z0 ztgSuo(l+AS5aASuQU3FCU9qIe%$x zk~dqJ5Y~HGB=^rr*w?O$uBtsAZ=iRPg^m zB=2=rJ6-OHfZWq?ng>_zr9hg$4sd@AaDNJLTTvLk{K>PJK09Z?`SM;L;93Iu4i3n5 z1muni$Sn+TT>(zkzkT^z8sOyK6`$ON0q$b~ZgqgW2CmMwO1CZD2j{EXhvD|}$o&Y8 z|8a2BlzWuUvj<&n!9;ofrn=lm;P@X0S8f#qO|&ZaaX4;4s>)pt=hOFOfO|E-O{c(o zX)c62*kjA5;dD*N&EJ!7dR@-t{uAybPnz>-NcA4>Vz`|>+_iAKd$_N{aZ7Lm-`+ZrpCbz{qc9Hw;u(#pTqG#4zAoUA=F>H+<(C7wN#gzi6hqw&GxcLoW9ty z2u^*L%Uuko^|v8+(8Pz~b~0wN?cV3?H`6Ykg`1mj2^F{5?YS>W%Vonfd9N{?=H2D$ z0&@EWdY;t#_B3m*VIeNs#h95l-vK!;|JGTS>P=W-2jT;_{|%eBL)PjtZdW@EdYyqiwsCAeHa+}xO{ zSOpxg0!!f;fnT%%Qe!d3m$F+PUlj%;3Pqd8TT+cO}yADr5$dLEYykAwGSp;k1lhTW)}(n&RMccfp@=Ie>(-__6*2P56I09$Yld^a{_Y3fZUM*x#I(Jrv$j(0JkKd??VB(6#==G0l8HH zxhn&5*9EvWaCM%x^jJXdNjUABZhv?_Aon7i&J|p_m*KRZyWE=rxk*fteR5L+-2QOt z2VH%0;B?${xsE`ZCj_{DIQ6$~nqzQ!Oh2Vs#GhRX=dBqG6;I|(jps0!{A zaK7@q5l+W`H_b1>>72&p?hkNJz_oa6c^&Qm$tb~1bDur@d7lmEtD|`zhSf9=Vw;DEjI>2j|QC5pZ>$G?xU@9E0=a{R?ou zyx#-o%lnT5a{mH%qQ}lToW%L^cU*uw6Rz8n<~QMHdAQ%f(G26@*6p@+8EnD;dFkj^JV4c!D-)gxr^ZTm52oO>GECl-BwpVXLh-l;Iz#26OmZ%b+``s zL2$W4rv4{Z^bPnLG+ylx2-+ma!XSB=u$}#xy#_Row?jYDLI;d5=8C?DLI$hnu{9RhUyY2 zQ!abKX}ff}=9JttNA7Sqjqh>;DLJY+31a6(DSa;Y>69GRl?0Ky6Yc}{h|8@@$x#eR z5V@D&w0*hUn{ZmEd`*JL?K-2JKbJcYPUZNT1d%(D16qGBcLfKu9`yWJghg%*oVI6| zdoU%pzX;eMa?ikZ*xxQUg@jb!0V>3&$n6iO<>GRMl$@5ih{yR$$+_GRoc0I3hM{s7 z!D+v9x$EKHEfEPWw+2qneO>O0aD7IsLT+mc!zZ^xfZG+Wx-D%Jrv>B=fIGos%f;R_ znO_Ie{A57xntG})8W*IxVFgS%|5xgaPRZ2N+f zm%#aKSq|s3<fZT5ba&HE>_cr^>Y%1J)JoPsX z&R4gYfLvQZ?r=C?-JS@ywa1ojI31_m_PGqM&LekiAk8&!I*)hL{Cl|fdeVFjZnlS; zzzL8~ZX3A6J#q`-e0e_|&X@O5xH?aoR|nF(8P1pYC*gc~_%56;?{5XEthjq_{Scux7BaU5S-7JivrvyQXJEVB*>iT zhLk>+yA$sHHa0^=5=8D{I8KA&;BqgdO zIGRopMDAR;^Xw6q`!$@-auP&t9h~+fm-|yn4zrRF=kK7hoXd5>X+4lc5=3qxoc0x$>q*J+ zH3=d&#DRtOh|7J013G`1lSr9!yl=q`*kdl&#DU#B+|dDU08V|Ro90MB?vrr(+?*@- z)q~4z!sWgX*Y2@%=R?Zp%&uGx?pq$Yx8Syrf+e_e6Xurtt;_8Mcf1G@Ty9`)`8tEk z-3zDw!R20nyNmQBxZIV6DAIQ6a!!?F zsgfj!n(N{8+J(#A4>#Awrr47pa<9Tov`1X-4LJ3mF1LNDe7@;&GvS6kY2FB@*I!(@ z^>7zfk=r8LBHA`C%LzQ!Yo1i>B9Td3n8`y9J8>uARL-h*r6=wl?List71ePCW$$PoeB^ZMX+Oq^1DGSs zq+Vw8d!Ff^JIW z>-=7illmdQcizf;KF#q9Id%jWTfR&qXrqh;?^KXy(G-)h<3@D99f++R*u9?ojDo%c zyUrLMS<*Ec?;|~Xuz##;Y-HKs*ib4F zW%_oHj;{0`uDWONW>V$Zrgh`AH8%N+F4?woql&JI2D?eXX0N1jBN*u!9PNo;DQ`Ew z*|<_`%2bq^e?#kyD!mFl)f(O=&rDKq$JW}VeB)Gmb60aK?2Xe~rT)^J)GwAN+&9>z zev_*!mvFp6ns-n7jZ<7%zUi&5H!kfe{W`Q^z~)tEcSYFrN=$jBw|m$)9Thc_Gz4c; z=#5iTrE)5qZh2R!jnn1NQhHzSO{_!RU{ZXWKQ|lh7B2aD^EYq)My6Zwlq>#YXI?Uq zHDM1XrTTrdPs^^UZ=CSJ7WreulUw?2Q>B}mUwHO2d!BLHgIpYKIBN0W+4Ba^ z9EutSd(P<}jT)F(H4OCkEb1TWUCIuX=D?YYm-de~1Sex=hGr*f^^4?%AA6vIpL;G3_>B&9i4J|#QH>_@u!l-k}fFtn6` zZj-5Dj^z$>XPF&5yOLaP24^!KwVS*it0+zK*we=@siQ-iwP0-x+F@&%Y`eBO>(NYa ztWpLq*>UY1(>J=|PHUofDib=n;LP>5Xvw?Z`p%wwN_YE40GXeGM_gAt|`Wg6ePjL zRI@;`8}Vd8wHI<1KJO$QS;%;n-@EepGvr0rO48k#PYE1~3Mi9>5_x&JTmXNaPhF7b z=byu-DS>X1k?Q;!bs}pXYx?*@SV9|+cSWDf_f3sIP__G$uDlO$Jook3|tOYfscbLz$bv%^-1t4a3#13d>VWPTn*&iW3q?dXTfzq%Hsy`IUv{JZvr=i zTfiD{E4U4O9?1TBQV(|k>Be6KUjknSe*yjy+y(9i_kgbesh6*UzXB8yD=cQsaXOzf zzu&ElQEM|Sqqc(VTvwxDKw4PWr!OQmm}^R`ETavSyzJvX(CE;&UVW zDC>2y_9p9EvI;d96hJ#Df)eNeo!~HVIG6{H07rtOz|r6sa4eV)jsvpZxd1E#Cx8>d zNkIDI2f-=eRL})Z1E+&CKsV?Cy`T>)0{!4ja26Nj`#U<8bU zF|Z7r3(f<}!3uCbxBy%TE&>;WOTbF-Vek>~QSdQvDYy(=4pxDWgDb!%z-sVG@F{R5 zxC(q4d$fCd>4EVJO{oHegOUv{1f;g_!0Oqcpm%&{1p5Q ztOq{_{|sILFM^lAzkq)QzW~1k{|5dY{0jUUybOK=UID)azXQJqe*k|3uY&&ouYvyr zuY>;rZ-766H^EyVn!tY`>-_HmTY{~?MDT7f3A_hv4c-g30kY1!9e5v@47LY5fGJ={ z@P4op*cnU(yMSH6ZeVw?2iOzr1?s>wus7HT>@<7%g4+IB+IpAP$2sjkX1qIL!il78KKqoj191iAzBf$~iC~!15 z1{@3KgX6&QU;$VNP5>u@lfcQ~gWwc!D(C{Ifz!bmpd0jnUeE^?fqrl%I13Db#b60I z8!QFqfI%<>hQWux2p9!pU>P_UoClVJ72teu0k{xc1TF@bfR*6S;r~tvJV<>#1Re&D NfJecf!~dTW_;2}^4E_KB literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.xml b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.xml new file mode 100644 index 00000000..7ee37713 --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate20.xml @@ -0,0 +1,6095 @@ + + + + Spring.Data.NHibernate20 + + + + + Convenient FactoryObject for defining Hibernate FilterDefinitions. + Exposes a corresponding Hibernate FilterDefinition object. + + + +

+ Typically defined as an inner object within a LocalSessionFactoryObject + definition, as the list element for the "filterDefinitions" object property. + For example: +

+ +
+            <objectn id="sessionFactory" type="Spring.Data.NHibernate.LocalSessionFactoryObject, Spring.Data.NHibernate">
+              ...
+              <property name="FilterDefinitions">
+               <list>
+                  <object type="Spring.Data.NHibernate.FilterDefinitionFactoryObject, Spring.Data.NHibernate">
+                    <property name="FilterName" value="myFilter"/>
+                    <property name="ParameterTypes">
+                      <props>
+                        <prop key="MyParam">string</prop>
+                        <prop key="MyOtherParam">long</prop>
+                      </props>
+                    </property>
+                  </object>
+                </list>
+              </property>
+              ...
+            </object>
+            
+

+ Alternatively, specify an object id (or name) attribute for the inner object, + instead of the "FilterName" property. +

+
+ Juergen Hoeller + Marko Lahma (.NET) + + + $Id: FilterDefiniitionFactoryObject.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ +
+ + + Initializes the filter definitions. + + + + + Returns the singleton filter definition. + + + + + + Set the name of the filter. + + + + + Set the parameter types for the filter, + with parameter names as keys and type names as values. + + + + + + Specify a default filter condition for the filter, if any. + + + + + If no explicit filter name has been specified, the object name of + the FilterDefinitionFactoryObject will be used. + + + + + + Returns the type of the object this factory produces. + + + + + Returns whether this factory produces singletons, always true. + + + + + Hibernate-specific subclass of ObjectRetrievalFailureException. + + + Converts Hibernate's UnresolvableObjectException, ObjectNotFoundException, + ObjectDeletedException, and WrongClassException. + + Mark Pollack (.NET) + $Id: HibernateObjectRetrievalFailureException.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateObjectRetrievalFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Hibernate-specific subclass of ObjectOptimisticLockingFailureException. + + + Converts Hibernate's StaleObjectStateException. + + Mark Pollack (.NET) + $Id: HibernateOptimisticLockingFailureException.cs,v 1.2 2008/04/23 11:41:41 lahma Exp $ + + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The StaleStateException. + + + + Creates a new instance of the HibernateOptimisticLockingFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + An IFactoryObject that creates a local Hibernate SessionFactory instance. + Behaves like a SessionFactory instance when used as bean reference, + e.g. for HibernateTemplate's "SessionFactory" property. + + + The typical usage will be to register this as singleton factory + in an application context and give objects references to application services + that need it. + + Hibernate configuration settings can be set using the IDictionary property 'HibernateProperties'. + + + This class implements the interface, + as autodetected by Spring's + for AOP-based translation of PersistenceExceptionTranslationPostProcessor. + Hence, the presence of e.g. LocalSessionFactoryBean automatically enables + a PersistenceExceptionTranslationPostProcessor to translate Hibernate exceptions. + + + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Return the singleon session factory. + + The singleon session factory. + + + + Initialize the SessionFactory for the given or the + default location. + + + + + Close the SessionFactory on application context shutdown. + + + + + Subclasses can override this method to perform custom initialization + of the Configuration instance used for ISessionFactory creation. + + + The properties of this LocalSessionFactoryObject will be applied to + the Configuration object that gets returned here. +

The default implementation creates a new Configuration instance. + A custom implementation could prepare the instance in a specific way, + or use a custom Configuration subclass. +

+
+ The configuration instance. +
+ + + To be implemented by subclasses that want to to perform custom + post-processing of the Configuration object after this FactoryObject + performed its default initialization. + + The current configuration object. + + + + Executes schema update if requested. + + + + + Execute schema drop script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryBean itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfb = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema creation script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema update script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaUpdate class, for automatically executing schema update scripts + on application startup. Can also be invoked manually. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute the given schema script on the given ADO.NET Connection. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override the ExecuteSchemaStatement + method to treat failures differently. + + The connection to use. + The SQL statement to execute. + + + + Execute the given schema SQL on the given ADO.NET command. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override this method to treat failures differently. + + + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + Implementation of the PersistenceExceptionTranslator interface, + as autodetected by Spring's PersistenceExceptionTranslationPostProcessor. + Converts the exception if it is a HibernateException; + else returns null to indicate an unknown exception. + translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + The exception thrown. + + the corresponding DataAccessException (or null if the + exception could not be translated. + + + + + + Convert the given HibernateException to an appropriate exception from the + Spring's DAO Exception hierarchy. + Will automatically apply a specified IAdoExceptionTranslator to a + Hibernate ADOException, else rely on Hibernate's default translation. + + The Hibernate exception that occured. + A corresponding DataAccessException + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Setting the Application Context determines were resources are loaded from + + + + + Gets or sets the to use for loading mapping assemblies etc. + + + + + Sets the assemblies to load that contain mapping files. + + The mapping assemblies. + + + + Sets the hibernate configuration files to load, i.e. hibernate.cfg.xml. + + + + + Sets the locations of Spring IResources that contain mapping + files. + + The location of mapping resources. + + + + Return the Configuration object used to build the SessionFactory. + Allows access to configuration metadata stored there (rarely needed). + + The hibernate configuration. + + + + Set NHibernate configuration properties, like "hibernate.dialect". + + The hibernate properties. + +

Can be used to override values in a NHibernate XML config file, + or to specify all necessary properties locally. +

+

Note: Do not specify a transaction provider here when using + Spring-driven transactions. It is also advisable to omit connection + provider settings and use a Spring-set IDbProvider instead. +

+
+
+ + + Get or set the DataSource to be used by the SessionFactory. + + The db provider. + + If set, this will override corresponding settings in Hibernate properties. + Note: If this is set, the Hibernate settings should not define + a connection string + (hibernate.connection.connection_string) to avoid meaningless double configuration. + + + + + + Gets or sets a value indicating whether to expose a transaction aware session factory. + + + true if want to expose transaction aware session factory; otherwise, false. + + + + + Set a NHibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + Will get applied to any new Session created by this factory. +

Such an interceptor can either be set at the SessionFactory level, i.e. on + LocalSessionFactoryObject, or at the Session level, i.e. on HibernateTemplate, + HibernateInterceptor, and HibernateTransactionManager. It's preferable to set + it on LocalSessionFactoryObject or HibernateTransactionManager to avoid repeated + configuration and guarantee consistent behavior in transactions.

+
+ + +
+ + + Set a Hibernate NamingStrategy for the SessionFactory, determining the + physical column and table names given the info in the mapping document. + + + + + Specify the Hibernate type definitions to register with the SessionFactory, + as Spring IObjectDefinition instances. This is an alternative to specifying + <typedef> elements in Hibernate mapping files. +

Unfortunately, Hibernate itself does not define a complete object that + represents a type definition, hence the need for Spring's TypeDefinitionBean.

+ @see TypeDefinitionBean + @see org.hibernate.cfg.Mappings#addTypeDef(String, String, java.util.Properties) +
+
+ + + Specify the NHibernate FilterDefinitions to register with the SessionFactory. + This is an alternative to specifying <filter-def> elements in + Hibernate mapping files. + + + Typically, the passed-in FilterDefinition objects will have been defined + as Spring FilterDefinitionFactoryBeans, probably as inner beans within the + LocalSessionFactoryObject definition. + + + + + + Specify the cache strategies for entities (persistent classes or named entities). + This configuration setting corresponds to the <class-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="entityCacheStrategies">
+              <props>
+                <prop key="MyCompany.Customer">read-write</prop>
+                <prop key="MyCompany.Product">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the cache strategies for persistent collections (with specific roles). + This configuration setting corresponds to the <collection-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="CollectionCacheStrategies">
+              <props>
+                <prop key="MyCompany.Order.Items">read-write</prop>
+                <prop key="MyCompany.Product.Categories">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the NHibernate event listeners to register, with listener types + as keys and listener objects as values. +

+ Instead of a single listener object, you can also pass in a list + or set of listeners objects as value. +

+
+ listener objects as values + + See the NHibernate documentation for further details on listener types + and associated listener interfaces. + +
+ + + Set whether to execute a schema update after SessionFactory initialization. +

+ For details on how to make schema update scripts work, see the NHibernate + documentation, as this class leverages the same schema update script support + in as NHibernate's own SchemaUpdate tool. +

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Return the type or subclass. + + The type created by this factory + + + + Returns true + + true + + + + Holds the references and configuration settings for a instance. + References are resolved by looking up the given object names in the root obtained by . + + + + + Holds the references and configuration settings for a instance. + + + + + Default value for property. + + + + + Default value for property. + + + + + Initialize a new instance of with default values. + + + Calling this constructor from your derived class leaves and + uninitialized. See and for more. + + + + + Initialize a new instance of with the given sessionFactory + and default values for all other settings. + + + The instance to be used for obtaining instances. + + + Calling this constructor marks all properties initialized. + + + + + Initialize a new instance of with the given values and references. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by the instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by the instance. + + + Calling this constructor marks all properties initialized. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Gets the configured instance to be used. + + + If the entity interceptor is not set by the constructor, this property calls + to obtain an instance. This allows derived classes to + override the behaviour of how to obtain the concrete instance. + + + + + Gets the configured instance to be used. + + + If this property is requested for the first time, is called. + This allows derived classes to override the behaviour of how to obtain the concrete instance. + + If the instance cannot be resolved. + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets or Sets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + The default session factory name to use when retrieving the Hibernate session factory from + the root context. + + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The configuration section to read setting variables from. + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The variable source to obtain settings from. + + + + Resolve the entityInterceptor by looking up + in the root application context. + + The resolved instance or + + + + Resolve the by looking up + in the root application context. + + The resolved instance or + + + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+
+ + + Check if the hibernate template property has been set. + + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Provide support for the open session in view pattern for lazily loaded hibernate objects + used in ASP.NET pages. + + jjx: http://forum.springframework.net/member.php?u=29 + Mark Pollack (.NET) + Erich Eichinger + Harald Radi + + + + Implementation of SessionScope that associates a single session within the using scope. + + + It is recommended to be used in the following type of scenario: + + using (new SessionScope()) + { + ... do multiple operation, possibly in multiple transactions. + } + + At the end of "using", the session is automatically closed. All transactions within the scope use the same session, + if you are using Spring's HibernateTemplate or using Spring's implementation of NHibernate 1.2's + ICurrentSessionContext interface. + + + It is assumed that the session factory object name is called "SessionFactory". In case that you named the object + in different way you can specify your can specify it in the application settings using the key + Spring.Data.NHibernate.Support.SessionScope.SessionFactoryObjectName. Values for EntityInterceptorObjectName + and SingleSessionMode can be specified similarly. + + + Note: + The session is managed on a per thread basis on the thread that opens the scope instance. This means that you must + never pass a reference to a instance over to another thread! + + + Robert M. (.NET) + Harald Radi (.NET) + + + + The logging instance. + + + + + Initializes a new instance of the class in single session mode, + associating a session with the thread. The session is opened lazily on demand. + + + + + Initializes a new instance of the class. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + The type, who's full name is used for prefixing appSetting keys + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by this instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by this instance. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + An instance holding the scope configuration + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Sets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets/Sets a flag, whether this scope manages it's own session for the current logical thread or not. + + false if session is managed by this module. false otherwise + + + + Call Close(), + + + + + Opens a new session or participates in an existing session and + registers with spring's . + + + + + Close the current view's session and unregisters + from spring's . + + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + Get or set the configured SessionFactory + + + + + Get or set the configured EntityInterceptor + + + + + Gets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets a flag, whether this scope manages it's own session for the current logical thread or not. + + + + + This sessionHolder creates a default session only if it is needed. + + + Although a NHibernateSession deferes creation of db-connections until they are really + needed, instantiation a session is imho still more expensive than this LazySessionHolder. (EE) + + + + + Session holder, wrapping a NHibernate ISession and a NHibernate Transaction. + HibernateTransactionManager binds instances of this class + to the thread, for a given ISessionFactory. + + + Note: This is an SPI class, not intended to be used by applications. + + Mark Pollack (.NET) + + + + May be used by derived classes to create an empty SessionHolder. + + + When using this ctor in your derived class, you MUST override ! + + + + + Initializes a new instance of the class. + + The session. + + + + Initializes a new instance of the class. + + The key to store the session under. + The hibernate session. + + + + May be overridden in a derived class to e.g. lazily create a session + + + + + Gets the session given key identifier + + The key. + A hibernate session + + + + Gets the session given the key and removes the session from + the dictionary storage. + + The key. + A hibernate session + + + + Adds the session to the dictionary storage using the default key. + + The hibernate session. + + + + Adds the session to the dictionary storage using the supplied key. + + The key. + The hibernate session. + + + + Removes the session from the dictionary storage for the given key. + + The key. + The session that was previously contained in the + dictionary storage. + + + + Determines whether the holder the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Clear the transaction state of this resource holder. + + + + + Gets the session using the default key + + The hibernate session. + + + + Gets the first session based on iteration over + the IDictionary storage. + + Any hibernate session. + + + + Gets a value indicating whether dictionary of + hibernate sessions is empty. + + + true if this session holder is empty; otherwise, false. + + + + + Gets a value indicating whether this SessionHolder + does not hold non default session. + + + true if does not hold non default session; otherwise, false. + + + + + Gets or sets the hibernate transaction. + + The transaction. + + + + Gets or sets the ADO.NET Connection used to create the session. + + The ADO.NET connection. + + + + Gets or sets the previous flush mode. + + The previous flush mode. + + + + Gets a value indicating whether the PreviousFlushMode property + was set. + + + true if assigned PreviousFlushMode property; otherwise, false. + + + + + Gets the validated session. + + The validated session. + + + + Initialize a new instance. + + + + + Create a new session on demand + + + + + Ensure session is closed (if any) and remove circular references to avoid memory leaks! + + + + + Initializes a new instance of the class. Creates a SessionScope, + but does not yet associate a session with a thread, that is left to the lifecycle of the request. + + + + + Register context handler and look up SessionFactoryObjectName under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SessionFactoryObjectName if not using the default value + (i.e. sessionFactory) and look up the SingleSession setting under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SingleSession if not using the default value of true. + + The standard HTTP application context + + + + A do nothing dispose method. + + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for ADO.NET exceptions that Hibernate rethrew and could not be + mapped into the DAO exception heirarchy. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API - ADO.NET + + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Hibernate-specific subclass of InvalidDataAccessResourceUsageException, + thrown on invalid HQL query syntax. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateQueryException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets the query string that was invalid. + + The query string that was invalid. + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for Hibernate system errors that do not match any concrete + Spring.Dao exceptions. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute supporting Hibernate access code + implementing the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Mark Pollack (.NET) +
+ + + Base class for HibernateTemplate defining common + properties like SessionFactory and flushing behavior. + + +

Not intended to be used directly. See HibernateTemplate. +

+
+ Mark Pollack (.NET) +
+ + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Apply the flush mode that's been specified for this accessor + to the given Session. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + the previous flush mode to restore after the operation, + or null if none + + + + + Flush the given Hibernate Session if necessary. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + + + Note that a direct SQLException can just occur when callback code + performs direct ADO.NET access via ISession.Connection(). + + + The ADO.NET exception. + The corresponding DataAccessException instance + + + + Prepare the given IQuery object, applying cache settings and/or + a transaction timeout. + + The query object to prepare. + + + + Apply the given name parameter to the given Query object. + + The query object. + Name of the parameter + The value of the parameter + The NHibernate type of the parameter (or null if none specified) + + + + Prepare the given Criteria object, applying cache settings and/or + a transaction timeout. + + + Note that for NHibernate 1.2 this only works if the + implementation is of the type CriteriaImpl, which should generally + be the case. The SetFetchSize method is not available on the + ICriteria interface + + This is a no-op for NHibernate 1.0.x since + the SetFetchSize method is not on the ICriteria interface and + the implementation class is has internal access. + + To remove the method completely for Spring's NHibernate 1.0 + support while reusing code for NHibernate 1.2 would not be + possible. So now this ineffectual operation is left in tact for + NHibernate 1.0.2 support. + + The criteria object to prepare + + + + Ensure SessionFactory is not null + + If SessionFactory property is null. + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance. + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets a Session for use by this template. + + The session. + + - Returns a new Session in case of "alwaysUseNewSession" (using the same ADO.NET connection as a transaction Session, if applicable) + - a pre-bound Session in case of "AllowCreate" is set to false (not the default) + - or a pre-bound Session or new Session if no transactional or other pre-bound Session exists. + + + + + Helper class to determine if the FlushMode enumeration + was changed from its default value + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The flush mode. + + + + Gets or sets a value indicating whether the FlushMode + property was set.. + + true if FlushMode was set; otherwise, false. + + + + Gets or sets the FlushMode. + + The FlushMode. + + + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Mark Pollack (.NET) +
+ + + Interface that specifies a set of Hibernate operations that + are common across versions of Hibernate. + + + Base interface for generic and non generic IHibernateOperations interfaces + Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ Mark Pollack (.NET) + +
+ + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + Tthe persistent instance to delete. + The lock mode to obtain. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + a persistent type. + An identifier of the persistent instance. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + A persistent class. + An identifier of the persistent instance. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The default for creating a new non-transactional + session when no transactional Session can be found for the current thread + is set to true. + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional when no transactional Session can be found + for the current thread. + + + + Delegate function that clears the session. + + The hibernate session. + null + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + The type. + An identifier of the persistent instance. + The persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The type. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + If length for argument values and types are not equal. + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + + + + Execute the action specified by the given action object within a Session. + + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Create a close-suppressing proxy for the given Hibernate Session. + The proxy also prepares returned Query and Criteria objects. + + The session. + The session proxy. + + + + Check whether write operations are allowed on the given Session. + + + Default implementation throws an InvalidDataAccessApiUsageException + in case of FlushMode.Never. Can be overridden in subclasses. + + The current Hibernate session. + If write operation is attempted in read-only mode + + + + + Compares if the flush mode enumerations, Spring's + TemplateFlushMode and NHibernates FlushMode have equal + settings. + + The template flush mode. + The NHibernate flush mode. + + Returns true if both are Never, Auto, or Commit, false + otherwise. + + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. + If object factory is not set and need to retrieve entity interceptor by name. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets whether to check that the Hibernate Session is not in read-only mode + in case of write operations (save/update/delete). + + + true if check that the Hibernate Session is not in read-only mode + in case of write operations; otherwise, false. + + + Default is "true", for fail-fast behavior when attempting write operations + within a read-only transaction. Turn this off to allow save/update/delete + on a Session with flush mode NEVER. + + + + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Set the object factory instance. + + The object factory instance + + + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Callback interface for NHibernate code. + + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object, or null if none. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Enumeration for the various Hibernate flush modes. + + Mark Pollack (.NET) + + + Never flush is a good strategy for read-only units of work. + + + Hibernate will not track and look for changes in this case, + avoiding any overhead of modification detection. +

In case of an existing ISession, TemplateFlushMode.Never will turn + the hibenrate flush mode + to FlushMode.Never for the scope of the current operation, resetting the previous + flush mode afterwards. +

+
+
+ + Automatic flushing is the default mode for a Hibernate Session. + + + A session will get flushed on transaction commit, and on certain find + operations that might involve already modified instances, but not + after each unit of work like with eager flushing. +

In case of an existing Session, TemplateFlushMode.Auto + will participate in the existing flush mode, not modifying + it for the current operation. + This in particular means that this setting will not modify an existing + hibernate flush mode FlushMode.Never, in contrast to TemplateFlushMode.Eager. +

+
+
+ + + Eager flushing leads to immediate synchronization with the database, + even if in a transaction. + + + This causes inconsistencies to show up and throw + a respective exception immediately, and ADO access code that participates + in the same transaction will see the changes as the database is already + aware of them then. But the drawbacks are: +
    +
  • additional communication roundtrips with the database, instead of a + single batch at transaction commit;
  • +
  • the fact that an actual database rollback is needed if the Hibernate + transaction rolls back (due to already submitted SQL statements).
  • +
+

In case of an existing Session, TemplateFlushMode.Eager + will turn the NHibernate flush mode + to FlushMode.Auto for the scope of the current operation and issue a flush at the + end, resetting the previous flush mode afterwards. +

+
+
+ + + Flushing at commit only is intended for units of work where no + intermediate flushing is desired, not even for find operations + that might involve already modified instances. + + +

In case of an existing Session, TemplateFlushMode.Commit + will turn the NHibernate flush mode + to FlushMode.Commit for the scope of the current operation, resetting the previous + flush mode afterwards. The only exception is an existing flush mode + FlushMode.Never, which will not be modified through this setting. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning an IList of result objects created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+ The new HibernateTemplate instance +
+ + + Check if the hibernate template property has been set. + + If HibernateTemplate property is null. + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning the result object created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Generic version of the Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute() supporting Hibernate access code which + implements the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as a direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Return the persistent instance of the given entity type + with the given identifier, or if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lenths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Allows creation of a new non-transactional session when no + transactional Session can be found for the current thread + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional session when no transactional Session can be found + for the current thread. + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets the classic hibernate template for access to non-generic methods. + + The classic hibernate template. + + + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Callback interface (Generic version) for NHibernate code. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + + Sree Nivask (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object. + The active Hibernate session +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Callback interface (Generic version) for NHibernate code that + returns a List of objects. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ Collection result object. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Helper class featuring methods for Hibernate Session handling, + allowing for reuse of Hibernate Session instances within transactions. + Also provides support for exception translation. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + The ordering value for synchronizaiton this session resources. + Set to be lower than ADO.NET synchronization. + + + + + Initializes a new instance of the class. + + + + + Get a new Hibernate Session from the given SessionFactory. + Will return a new Session even if there already is a pre-bound + Session for the given SessionFactory. + + + Within a transaction, this method will create a new Session + that shares the transaction's ADO.NET Connection. More specifically, + it will use the same ADO.NET Connection as the pre-bound Hibernate Session. + + The session factory to create the session with. + The Hibernate entity interceptor, or null if none. + The new session. + If could not open Hibernate session + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using HibernateTransactionManager. Will always create a new + Session otherwise. + + + Supports setting a Session-level Hibernate entity interceptor that allows + to inspect and change property values before writing to and reading from the + database. Such an interceptor can also be set at the SessionFactory level + (i.e. on LocalSessionFactoryObject), on HibernateTransactionManager, or on + HibernateInterceptor/HibernateTemplate. + + The session factory to create the + session with. + Hibernate entity interceptor, or null if none. + AdoExceptionTranslator to use for flushing the + Session on transaction synchronization (can be null; only used when actually + registering a transaction synchronization). + The Hibernate Session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using . Will create a new Session + otherwise, if allowCreate is true. + + The session factory to create the session with. + if set to true create a non-transactional Session when no + transactional Session can be found for the current thread. + The hibernate session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. + + Is aware of and will return any existing corresponding + Session bound to the current thread, for example whenusing + . Will create a new + Session otherwise, if "allowCreate" is true. +

Throws the orginal HibernateException, in contrast to + . +

+ The session factory. + if set to true [allow create]. + The Hibernate Session + + if the Session couldn't be created + + + If no thread-bound Session found and allowCreate is false. + +
+ + + Open a new Session from the factory. + + The session factory to create the session with. + Hibernate entity interceptor, or null if none. + the newly opened session + + + + Perform the actual closing of the Hibernate Session + catching and logging any cleanup exceptions thrown. + + The hibernate session to close + + + + Return whether the given Hibernate Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The hibernate session to check + The session factory that the session + was created with, can be null. + + true if the session transactional; otherwise, false. + + + + + Converts a Hibernate ADOException to a Spring DataAccessExcption, extracting the underlying error code from + ADO.NET. Will extract the ADOException Message and SqlString properties and pass them to the translate method + of the provided IAdoExceptionTranslator. + + The IAdoExceptionTranslator, may be a user provided implementation as configured on + HibernateTemplate. + + The ADOException throw + The translated DataAccessException or UncategorizedAdoException in case of an error in translation + itself. + + + + Convert the given HibernateException to an appropriate exception from the + Spring.Dao hierarchy. Note that it is advisable to + handle AdoException specifically by using a AdoExceptionTranslator for the + underlying ADO.NET exception. + + The Hibernate exception that occured. + DataAccessException instance + + + + Close the given Session, created via the given factory, + if it is not managed externally (i.e. not bound to the thread). + + The hibernate session to close + The hibernate SessionFactory that + the session was created with. + + + + Close the given Session or register it for deferred close. + + The session. + The session factory. + + + + Initialize deferred close for the current thread and the given SessionFactory. + Sessions will not be actually closed on close calls then, but rather at a + processDeferredClose call at a finishing point (like request completion). + + The session factory. + + + + Return if deferred close is active for the current thread + and the given SessionFactory. + The session factory. + + true if [is deferred close active] [the specified session factory]; otherwise, false. + + If SessionFactory argument is null. + + + + Process Sessions that have been registered for deferred close + for the given SessionFactory. + + The session factory. + If there is no session factory associated with the thread. + + + + Applies the current transaction timeout, if any, to the given + criteria object + + The Hibernate Criteria object. + Hibernate SessionFactory that the Criteria was created for + (can be null). + If criteria argument is null. + + + + Applies the current transaction timeout, if any, to the given + Hibenrate query object. + + The Hibernate Query object. + Hibernate SessionFactory that the Query was created for + (can be null). + If query argument is null. + + + + Gets the Spring IDbProvider given the ISessionFactory. + + The matching is performed by comparing the assembly qualified + name string of the hibernate Driver.ConnectionType to those in + the DbProviderFactory definitions. No connections are created + in performing this comparison. + The session factory. + The corresponding IDbProvider, null if no mapping was found. + If DbProviderFactory's ApplicaitonContext is not + an instance of IConfigurableApplicaitonContext. + + + + Create a IAdoExceptionTranslator from the given SessionFactory. + + If a corresponding IDbProvider is found, a ErrorcodeExceptionTranslator + for the IDbProvider is created. Otherwise, a FallbackException is created. + The session factory to create the translator for + An IAdoExceptionTranslator + + + + Implementation of NHibernates 1.2's ICurrentSessionContext interface + that delegates to Spring's SessionFactoryUtils for providing a + Spirng-managed current Session. + + Used by Spring's LocalSessionFactoryBean if told to expose + a transaction-aware SessionFactory. +

This ICurrentSessionContext implementation can also be specified in + custom ISessionFactory setup through the + "hibernate.current_session_context_class" property, with the fully + qualified name of this class as value.

+ Juergen Hoeller + Mark Pollack (.NET) + +
+ + + Initializes a new instance of the class + + The NHibernate session factory. + + + + Retrieve the Spring-managed Session for the current thread. + + Current session associated with the thread + On errors retrieving thread bound session. + + + + NHibnerations actions taken during the transaction lifecycle. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Suspend this synchronization. + + +

+ Unbind Hibernate resources (SessionHolder) from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Rebind Hibernate resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + + + If the transaction is defined as a read-only transaction. + + +

+ Can flush transactional sessions to the database. +

+

+ Note that exceptions will get propagated to the commit caller and + cause a rollback of the transaction. +

+
+
+ + + Invoked before transaction commit (before + ) + Can e.g. flush transactional O/R Mapping sessions to the database + + + + This callback does not mean that the transaction will actually be + commited. A rollback decision can still occur after this method + has been called. This callback is rather meant to perform work + that's only relevant if a commit still has a chance + to happen, such as flushing SQL statements to the database. + + + Note that exceptions will get propagated to the commit caller and cause a + rollback of the transaction. + + (note: do not throw TransactionException subclasses here!) + + + + + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.dll b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.dll new file mode 100644 index 0000000000000000000000000000000000000000..a8bebbbc4380ffe5f521d678193df5db0f26f4ee GIT binary patch literal 92160 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.pdb b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.pdb new file mode 100644 index 0000000000000000000000000000000000000000..995ad94cb29c14a630d354d489cb3a9e1a92022f GIT binary patch literal 286208 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 + The Spring for .NET-backed ByteCodeprovider for NHibernate + + Fabio Maulo + + + + Creates a new bytecode Provider instance using the specified object factory + + + + + + Retrieve the delegate for this provider + capable of generating reflection optimization components. + + The class to be reflected upon.All property getters to be accessed via reflection.All property setters to be accessed via reflection. + The reflection optimization delegate. + + + + The specific factory for this provider capable of + generating run-time proxies for lazy-loading purposes. + + + + + NHibernate's object instaciator. + + + For entities and its implementations. + + + + + Instanciator of NHibernate's collections default types. + + + + + + + Fabio Maulo + + + + + + + + + + + + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + + + Fabio Maulo + + + + + + + + + Creates an instance of the specified type. + + The type of object to create. + A reference to the created object. + + + + Creates an instance of the specified type. + + The type of object to create.true if a public or nonpublic default constructor can match; false if only a public default constructor can match. + A reference to the created object + + + + Creates an instance of the specified type using the constructor that best matches the specified parameters. + + The type of object to create.An array of constructor arguments. + A reference to the created object. + + + + A Spring for .NET backed implementation for creating + NHibernate proxies. + + + Erich Eichinger + + + + Creates a new proxy. + + The id value for the proxy to be generated. + The session to which the generated proxy will be associated. + The generated proxy. + Indicates problems generating requested proxy. + + + + Creates a Spring for .NET backed instance. + + Erich Eichinger + + + + Build a proxy factory specifically for handling runtime lazy loading. + + The lazy-load proxy factory. + + + + + + + + + + + + + + + + + + Fabio Maulo + + + + + + + + + + + + Perform instantiation of an instance of the underlying class. + + The new instance. + + + + + + + + + + Delegates to an implementation of ISessionFactory that can select among multiple instances based on + thread local storage. + + + + + An IFactoryObject that creates a local Hibernate SessionFactory instance. + Behaves like a SessionFactory instance when used as bean reference, + e.g. for HibernateTemplate's "SessionFactory" property. + + + The typical usage will be to register this as singleton factory + in an application context and give objects references to application services + that need it. + + Hibernate configuration settings can be set using the IDictionary property 'HibernateProperties'. + + + This class implements the interface, + as autodetected by Spring's + for AOP-based translation of PersistenceExceptionTranslationPostProcessor. + Hence, the presence of e.g. LocalSessionFactoryBean automatically enables + a PersistenceExceptionTranslationPostProcessor to translate Hibernate exceptions. + + + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Return the singleon session factory. + + The singleon session factory. + + + + Initialize the SessionFactory for the given or the + default location. + + + + + Close the SessionFactory on application context shutdown. + + + + + Subclasses can override this method to perform custom initialization + of the Configuration instance used for ISessionFactory creation. + + + The properties of this LocalSessionFactoryObject will be applied to + the Configuration object that gets returned here. +

The default implementation creates a new Configuration instance. + A custom implementation could prepare the instance in a specific way, + or use a custom Configuration subclass. +

+
+ The configuration instance. +
+ + + To be implemented by subclasses that want to to register further mappings + on the Configuration object after this FactoryObject registered its specified + mappings. + + + Invoked before the BuildMappings call, + so that it can still extend and modify the mapping information. + + the current Configuration object + + + + To be implemented by subclasses that want to to perform custom + post-processing of the Configuration object after this FactoryObject + performed its default initialization. + + The current configuration object. + + + + Executes schema update if requested. + + + + + Execute schema drop script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryBean itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfb = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema creation script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema update script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaUpdate class, for automatically executing schema update scripts + on application startup. Can also be invoked manually. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute the given schema script on the given ADO.NET Connection. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override the ExecuteSchemaStatement + method to treat failures differently. + + The connection to use. + The SQL statement to execute. + + + + Execute the given schema SQL on the given ADO.NET command. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override this method to treat failures differently. + + + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + Implementation of the PersistenceExceptionTranslator interface, + as autodetected by Spring's PersistenceExceptionTranslationPostProcessor. + Converts the exception if it is a HibernateException; + else returns null to indicate an unknown exception. + translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + The exception thrown. + + the corresponding DataAccessException (or null if the + exception could not be translated. + + + + + + Convert the given HibernateException to an appropriate exception from the + Spring's DAO Exception hierarchy. + Will automatically apply a specified IAdoExceptionTranslator to a + Hibernate ADOException, else rely on Hibernate's default translation. + + The Hibernate exception that occured. + A corresponding DataAccessException + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Setting the Application Context determines were resources are loaded from + + + + + Gets or sets the to use for loading mapping assemblies etc. + + + + + Sets the assemblies to load that contain mapping files. + + The mapping assemblies. + + + + Sets the hibernate configuration files to load, i.e. hibernate.cfg.xml. + + + + + Sets the locations of Spring IResources that contain mapping + files. + + The location of mapping resources. + + + + Return the Configuration object used to build the SessionFactory. + Allows access to configuration metadata stored there (rarely needed). + + The hibernate configuration. + + + + Set NHibernate configuration properties, like "hibernate.dialect". + + The hibernate properties. + +

Can be used to override values in a NHibernate XML config file, + or to specify all necessary properties locally. +

+

Note: Do not specify a transaction provider here when using + Spring-driven transactions. It is also advisable to omit connection + provider settings and use a Spring-set IDbProvider instead. +

+
+
+ + + Get or set the DataSource to be used by the SessionFactory. + + The db provider. + + If set, this will override corresponding settings in Hibernate properties. + Note: If this is set, the Hibernate settings should not define + a connection string + (hibernate.connection.connection_string) to avoid meaningless double configuration. + + + + + + Gets or sets a value indicating whether to expose a transaction aware session factory. + + + true if want to expose transaction aware session factory; otherwise, false. + + + + + Set a NHibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + Will get applied to any new Session created by this factory. +

Such an interceptor can either be set at the SessionFactory level, i.e. on + LocalSessionFactoryObject, or at the Session level, i.e. on HibernateTemplate, + HibernateInterceptor, and HibernateTransactionManager. It's preferable to set + it on LocalSessionFactoryObject or HibernateTransactionManager to avoid repeated + configuration and guarantee consistent behavior in transactions.

+
+ + +
+ + + Set a Hibernate NamingStrategy for the SessionFactory, determining the + physical column and table names given the info in the mapping document. + + + + + Specify the Hibernate type definitions to register with the SessionFactory, + as Spring IObjectDefinition instances. This is an alternative to specifying + <typedef> elements in Hibernate mapping files. +

Unfortunately, Hibernate itself does not define a complete object that + represents a type definition, hence the need for Spring's TypeDefinitionBean.

+ @see TypeDefinitionBean + @see org.hibernate.cfg.Mappings#addTypeDef(String, String, java.util.Properties) +
+
+ + + Specify the NHibernate FilterDefinitions to register with the SessionFactory. + This is an alternative to specifying <filter-def> elements in + Hibernate mapping files. + + + Typically, the passed-in FilterDefinition objects will have been defined + as Spring FilterDefinitionFactoryBeans, probably as inner beans within the + LocalSessionFactoryObject definition. + + + + + + Specify the cache strategies for entities (persistent classes or named entities). + This configuration setting corresponds to the <class-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="entityCacheStrategies">
+              <props>
+                <prop key="MyCompany.Customer">read-write</prop>
+                <prop key="MyCompany.Product">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the cache strategies for persistent collections (with specific roles). + This configuration setting corresponds to the <collection-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="CollectionCacheStrategies">
+              <props>
+                <prop key="MyCompany.Order.Items">read-write</prop>
+                <prop key="MyCompany.Product.Categories">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the NHibernate event listeners to register, with listener types + as keys and listener objects as values. +

+ Instead of a single listener object, you can also pass in a list + or set of listeners objects as value. +

+
+ listener objects as values + + See the NHibernate documentation for further details on listener types + and associated listener interfaces. + +
+ + + Set whether to execute a schema update after SessionFactory initialization. +

+ For details on how to make schema update scripts work, see the NHibernate + documentation, as this class leverages the same schema update script support + in as NHibernate's own SchemaUpdate tool. +

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Sets custom byte code provider implementation to be used. This corresponds to setting + the property before NHibernate session factory + configuration. + + + + + Return the type or subclass. + + The type created by this factory + + + + Returns true + + true + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + PostProcessConfiguration + + + + + + DelegatingSessionFactory class + + + + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Does the tx scope commit. + + The status. + + + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Does the tx scope rollback. + + The status. + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Does the tx scope set rollback only. + + The status. + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + SimpleDelegatingSessionFactory class + + + + + Connection string config element name + + + + + public Constructor + + + + + + TargetSessionFactory + + + + + Holds the references and configuration settings for a instance. + References are resolved by looking up the given object names in the root obtained by . + + + + + Holds the references and configuration settings for a instance. + + + + + Default value for property. + + + + + Default value for property. + + + + + Initialize a new instance of with default values. + + + Calling this constructor from your derived class leaves and + uninitialized. See and for more. + + + + + Initialize a new instance of with the given sessionFactory + and default values for all other settings. + + + The instance to be used for obtaining instances. + + + Calling this constructor marks all properties initialized. + + + + + Initialize a new instance of with the given values and references. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by the instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by the instance. + + + Calling this constructor marks all properties initialized. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Gets the configured instance to be used. + + + If the entity interceptor is not set by the constructor, this property calls + to obtain an instance. This allows derived classes to + override the behaviour of how to obtain the concrete instance. + + + + + Gets the configured instance to be used. + + + If this property is requested for the first time, is called. + This allows derived classes to override the behaviour of how to obtain the concrete instance. + + If the instance cannot be resolved. + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets or Sets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + The default session factory name to use when retrieving the Hibernate session factory from + the root context. + + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The configuration section to read setting variables from. + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The variable source to obtain settings from. + + + + Resolve the entityInterceptor by looking up + in the root application context. + + The resolved instance or + + + + Resolve the by looking up + in the root application context. + + The resolved instance or + + + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+
+ + + Check if the hibernate template property has been set. + + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Provide support for the open session in view pattern for lazily loaded hibernate objects + used in ASP.NET pages. + + jjx: http://forum.springframework.net/member.php?u=29 + Mark Pollack (.NET) + Erich Eichinger + Harald Radi + + + + Implementation of SessionScope that associates a single session within the using scope. + + + It is recommended to be used in the following type of scenario: + + using (new SessionScope()) + { + ... do multiple operation, possibly in multiple transactions. + } + + At the end of "using", the session is automatically closed. All transactions within the scope use the same session, + if you are using Spring's HibernateTemplate or using Spring's implementation of NHibernate 1.2's + ICurrentSessionContext interface. + + + It is assumed that the session factory object name is called "SessionFactory". In case that you named the object + in different way you can specify your can specify it in the application settings using the key + Spring.Data.NHibernate.Support.SessionScope.SessionFactoryObjectName. Values for EntityInterceptorObjectName + and SingleSessionMode can be specified similarly. + + + Note: + The session is managed on a per thread basis on the thread that opens the scope instance. This means that you must + never pass a reference to a instance over to another thread! + + + Robert M. (.NET) + Harald Radi (.NET) + + + + The logging instance. + + + + + Initializes a new instance of the class in single session mode, + associating a session with the thread. The session is opened lazily on demand. + + + + + Initializes a new instance of the class. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + The type, who's full name is used for prefixing appSetting keys + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by this instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by this instance. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + An instance holding the scope configuration + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Sets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets/Sets a flag, whether this scope manages it's own session for the current logical thread or not. + + false if session is managed by this module. false otherwise + + + + Call Close(), + + + + + Opens a new session or participates in an existing session and + registers with spring's . + + + + + Close the current view's session and unregisters + from spring's . + + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + Get or set the configured SessionFactory + + + + + Get or set the configured EntityInterceptor + + + + + Gets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets a flag, whether this scope manages it's own session for the current logical thread or not. + + + + + This sessionHolder creates a default session only if it is needed. + + + Although a NHibernateSession deferes creation of db-connections until they are really + needed, instantiation a session is imho still more expensive than this LazySessionHolder. (EE) + + + + + Session holder, wrapping a NHibernate ISession and a NHibernate Transaction. + HibernateTransactionManager binds instances of this class + to the thread, for a given ISessionFactory. + + + Note: This is an SPI class, not intended to be used by applications. + + Mark Pollack (.NET) + + + + May be used by derived classes to create an empty SessionHolder. + + + When using this ctor in your derived class, you MUST override ! + + + + + Initializes a new instance of the class. + + The session. + + + + Initializes a new instance of the class. + + The key to store the session under. + The hibernate session. + + + + May be overridden in a derived class to e.g. lazily create a session + + + + + Gets the session given key identifier + + The key. + A hibernate session + + + + Gets the session given the key and removes the session from + the dictionary storage. + + The key. + A hibernate session + + + + Adds the session to the dictionary storage using the default key. + + The hibernate session. + + + + Adds the session to the dictionary storage using the supplied key. + + The key. + The hibernate session. + + + + Removes the session from the dictionary storage for the given key. + + The key. + The session that was previously contained in the + dictionary storage. + + + + Determines whether the holder the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Clear the transaction state of this resource holder. + + + + + Gets the session using the default key + + The hibernate session. + + + + Gets the first session based on iteration over + the IDictionary storage. + + Any hibernate session. + + + + Gets a value indicating whether dictionary of + hibernate sessions is empty. + + + true if this session holder is empty; otherwise, false. + + + + + Gets a value indicating whether this SessionHolder + does not hold non default session. + + + true if does not hold non default session; otherwise, false. + + + + + Gets or sets the hibernate transaction. + + The transaction. + + + + Gets or sets the ADO.NET Connection used to create the session. + + The ADO.NET connection. + + + + Gets or sets the previous flush mode. + + The previous flush mode. + + + + Gets a value indicating whether the PreviousFlushMode property + was set. + + + true if assigned PreviousFlushMode property; otherwise, false. + + + + + Gets the validated session. + + The validated session. + + + + Initialize a new instance. + + + + + Create a new session on demand + + + + + Ensure session is closed (if any) and remove circular references to avoid memory leaks! + + + + + Initializes a new instance of the class. Creates a SessionScope, + but does not yet associate a session with a thread, that is left to the lifecycle of the request. + + + + + Register context handler and look up SessionFactoryObjectName under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SessionFactoryObjectName if not using the default value + (i.e. sessionFactory) and look up the SingleSession setting under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SingleSession if not using the default value of true. + + The standard HTTP application context + + + + A do nothing dispose method. + + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for ADO.NET exceptions that Hibernate rethrew and could not be + mapped into the DAO exception heirarchy. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API - ADO.NET + + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Hibernate-specific subclass of InvalidDataAccessResourceUsageException, + thrown on invalid HQL query syntax. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateQueryException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets the query string that was invalid. + + The query string that was invalid. + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for Hibernate system errors that do not match any concrete + Spring.Dao exceptions. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute supporting Hibernate access code + implementing the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Mark Pollack (.NET) +
+ + + Base class for HibernateTemplate defining common + properties like SessionFactory and flushing behavior. + + +

Not intended to be used directly. See HibernateTemplate. +

+
+ Mark Pollack (.NET) +
+ + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Apply the flush mode that's been specified for this accessor + to the given Session. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + the previous flush mode to restore after the operation, + or null if none + + + + + Flush the given Hibernate Session if necessary. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + + + Note that a direct SQLException can just occur when callback code + performs direct ADO.NET access via ISession.Connection(). + + + The ADO.NET exception. + The corresponding DataAccessException instance + + + + Prepare the given IQuery object, applying cache settings and/or + a transaction timeout. + + The query object to prepare. + + + + Apply the given name parameter to the given Query object. + + The query object. + Name of the parameter + The value of the parameter + The NHibernate type of the parameter (or null if none specified) + + + + Prepare the given Criteria object, applying cache settings and/or + a transaction timeout. + + + Note that for NHibernate 1.2 this only works if the + implementation is of the type CriteriaImpl, which should generally + be the case. The SetFetchSize method is not available on the + ICriteria interface + + This is a no-op for NHibernate 1.0.x since + the SetFetchSize method is not on the ICriteria interface and + the implementation class is has internal access. + + To remove the method completely for Spring's NHibernate 1.0 + support while reusing code for NHibernate 1.2 would not be + possible. So now this ineffectual operation is left in tact for + NHibernate 1.0.2 support. + + The criteria object to prepare + + + + Ensure SessionFactory is not null + + If SessionFactory property is null. + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance. + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets a Session for use by this template. + + The session. + + - Returns a new Session in case of "alwaysUseNewSession" (using the same ADO.NET connection as a transaction Session, if applicable) + - a pre-bound Session in case of "AllowCreate" is set to false (not the default) + - or a pre-bound Session or new Session if no transactional or other pre-bound Session exists. + + + + + Helper class to determine if the FlushMode enumeration + was changed from its default value + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The flush mode. + + + + Gets or sets a value indicating whether the FlushMode + property was set.. + + true if FlushMode was set; otherwise, false. + + + + Gets or sets the FlushMode. + + The FlushMode. + + + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Mark Pollack (.NET) +
+ + + Interface that specifies a set of Hibernate operations that + are common across versions of Hibernate. + + + Base interface for generic and non generic IHibernateOperations interfaces + Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ Mark Pollack (.NET) + +
+ + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + Tthe persistent instance to delete. + The lock mode to obtain. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + a persistent type. + An identifier of the persistent instance. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + A persistent class. + An identifier of the persistent instance. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The default for creating a new non-transactional + session when no transactional Session can be found for the current thread + is set to true. + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional when no transactional Session can be found + for the current thread. + + + + Delegate function that clears the session. + + The hibernate session. + null + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + The type. + An identifier of the persistent instance. + The persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The type. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + If length for argument values and types are not equal. + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + + + + Execute the action specified by the given action object within a Session. + + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Create a close-suppressing proxy for the given Hibernate Session. + The proxy also prepares returned Query and Criteria objects. + + The session. + The session proxy. + + + + Check whether write operations are allowed on the given Session. + + + Default implementation throws an InvalidDataAccessApiUsageException + in case of FlushMode.Never. Can be overridden in subclasses. + + The current Hibernate session. + If write operation is attempted in read-only mode + + + + + Compares if the flush mode enumerations, Spring's + TemplateFlushMode and NHibernates FlushMode have equal + settings. + + The template flush mode. + The NHibernate flush mode. + + Returns true if both are Never, Auto, or Commit, false + otherwise. + + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. + If object factory is not set and need to retrieve entity interceptor by name. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets whether to check that the Hibernate Session is not in read-only mode + in case of write operations (save/update/delete). + + + true if check that the Hibernate Session is not in read-only mode + in case of write operations; otherwise, false. + + + Default is "true", for fail-fast behavior when attempting write operations + within a read-only transaction. Turn this off to allow save/update/delete + on a Session with flush mode NEVER. + + + + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Set the object factory instance. + + The object factory instance + + + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Callback interface for NHibernate code. + + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object, or null if none. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Enumeration for the various Hibernate flush modes. + + Mark Pollack (.NET) + + + Never flush is a good strategy for read-only units of work. + + + Hibernate will not track and look for changes in this case, + avoiding any overhead of modification detection. +

In case of an existing ISession, TemplateFlushMode.Never will turn + the hibenrate flush mode + to FlushMode.Never for the scope of the current operation, resetting the previous + flush mode afterwards. +

+
+
+ + Automatic flushing is the default mode for a Hibernate Session. + + + A session will get flushed on transaction commit, and on certain find + operations that might involve already modified instances, but not + after each unit of work like with eager flushing. +

In case of an existing Session, TemplateFlushMode.Auto + will participate in the existing flush mode, not modifying + it for the current operation. + This in particular means that this setting will not modify an existing + hibernate flush mode FlushMode.Never, in contrast to TemplateFlushMode.Eager. +

+
+
+ + + Eager flushing leads to immediate synchronization with the database, + even if in a transaction. + + + This causes inconsistencies to show up and throw + a respective exception immediately, and ADO access code that participates + in the same transaction will see the changes as the database is already + aware of them then. But the drawbacks are: +
    +
  • additional communication roundtrips with the database, instead of a + single batch at transaction commit;
  • +
  • the fact that an actual database rollback is needed if the Hibernate + transaction rolls back (due to already submitted SQL statements).
  • +
+

In case of an existing Session, TemplateFlushMode.Eager + will turn the NHibernate flush mode + to FlushMode.Auto for the scope of the current operation and issue a flush at the + end, resetting the previous flush mode afterwards. +

+
+
+ + + Flushing at commit only is intended for units of work where no + intermediate flushing is desired, not even for find operations + that might involve already modified instances. + + +

In case of an existing Session, TemplateFlushMode.Commit + will turn the NHibernate flush mode + to FlushMode.Commit for the scope of the current operation, resetting the previous + flush mode afterwards. The only exception is an existing flush mode + FlushMode.Never, which will not be modified through this setting. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning an IList of result objects created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+ The new HibernateTemplate instance +
+ + + Check if the hibernate template property has been set. + + If HibernateTemplate property is null. + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning the result object created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Generic version of the Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute() supporting Hibernate access code which + implements the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as a direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Return the persistent instance of the given entity type + with the given identifier, or if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lenths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Allows creation of a new non-transactional session when no + transactional Session can be found for the current thread + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional session when no transactional Session can be found + for the current thread. + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets the classic hibernate template for access to non-generic methods. + + The classic hibernate template. + + + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Callback interface (Generic version) for NHibernate code. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + + Sree Nivask (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object. + The active Hibernate session +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Callback interface (Generic version) for NHibernate code that + returns a List of objects. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ Collection result object. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Helper class featuring methods for Hibernate Session handling, + allowing for reuse of Hibernate Session instances within transactions. + Also provides support for exception translation. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + The ordering value for synchronizaiton this session resources. + Set to be lower than ADO.NET synchronization. + + + + + Initializes a new instance of the class. + + + + + Get a new Hibernate Session from the given SessionFactory. + Will return a new Session even if there already is a pre-bound + Session for the given SessionFactory. + + + Within a transaction, this method will create a new Session + that shares the transaction's ADO.NET Connection. More specifically, + it will use the same ADO.NET Connection as the pre-bound Hibernate Session. + + The session factory to create the session with. + The Hibernate entity interceptor, or null if none. + The new session. + If could not open Hibernate session + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using HibernateTransactionManager. Will always create a new + Session otherwise. + + + Supports setting a Session-level Hibernate entity interceptor that allows + to inspect and change property values before writing to and reading from the + database. Such an interceptor can also be set at the SessionFactory level + (i.e. on LocalSessionFactoryObject), on HibernateTransactionManager, or on + HibernateInterceptor/HibernateTemplate. + + The session factory to create the + session with. + Hibernate entity interceptor, or null if none. + AdoExceptionTranslator to use for flushing the + Session on transaction synchronization (can be null; only used when actually + registering a transaction synchronization). + The Hibernate Session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using . Will create a new Session + otherwise, if allowCreate is true. + + The session factory to create the session with. + if set to true create a non-transactional Session when no + transactional Session can be found for the current thread. + The hibernate session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. + + Is aware of and will return any existing corresponding + Session bound to the current thread, for example whenusing + . Will create a new + Session otherwise, if "allowCreate" is true. +

Throws the orginal HibernateException, in contrast to + . +

+ The session factory. + if set to true [allow create]. + The Hibernate Session + + if the Session couldn't be created + + + If no thread-bound Session found and allowCreate is false. + +
+ + + Open a new Session from the factory. + + The session factory to create the session with. + Hibernate entity interceptor, or null if none. + the newly opened session + + + + Perform the actual closing of the Hibernate Session + catching and logging any cleanup exceptions thrown. + + The hibernate session to close + + + + Return whether the given Hibernate Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The hibernate session to check + The session factory that the session + was created with, can be null. + + true if the session transactional; otherwise, false. + + + + + Converts a Hibernate ADOException to a Spring DataAccessExcption, extracting the underlying error code from + ADO.NET. Will extract the ADOException Message and SqlString properties and pass them to the translate method + of the provided IAdoExceptionTranslator. + + The IAdoExceptionTranslator, may be a user provided implementation as configured on + HibernateTemplate. + + The ADOException throw + The translated DataAccessException or UncategorizedAdoException in case of an error in translation + itself. + + + + Convert the given HibernateException to an appropriate exception from the + Spring.Dao hierarchy. Note that it is advisable to + handle AdoException specifically by using a AdoExceptionTranslator for the + underlying ADO.NET exception. + + The Hibernate exception that occured. + DataAccessException instance + + + + Close the given Session, created via the given factory, + if it is not managed externally (i.e. not bound to the thread). + + The hibernate session to close + The hibernate SessionFactory that + the session was created with. + + + + Close the given Session or register it for deferred close. + + The session. + The session factory. + + + + Initialize deferred close for the current thread and the given SessionFactory. + Sessions will not be actually closed on close calls then, but rather at a + processDeferredClose call at a finishing point (like request completion). + + The session factory. + + + + Return if deferred close is active for the current thread + and the given SessionFactory. + The session factory. + + true if [is deferred close active] [the specified session factory]; otherwise, false. + + If SessionFactory argument is null. + + + + Process Sessions that have been registered for deferred close + for the given SessionFactory. + + The session factory. + If there is no session factory associated with the thread. + + + + Applies the current transaction timeout, if any, to the given + criteria object + + The Hibernate Criteria object. + Hibernate SessionFactory that the Criteria was created for + (can be null). + If criteria argument is null. + + + + Applies the current transaction timeout, if any, to the given + Hibenrate query object. + + The Hibernate Query object. + Hibernate SessionFactory that the Query was created for + (can be null). + If query argument is null. + + + + Gets the Spring IDbProvider given the ISessionFactory. + + The matching is performed by comparing the assembly qualified + name string of the hibernate Driver.ConnectionType to those in + the DbProviderFactory definitions. No connections are created + in performing this comparison. + The session factory. + The corresponding IDbProvider, null if no mapping was found. + If DbProviderFactory's ApplicaitonContext is not + an instance of IConfigurableApplicaitonContext. + + + + Create a IAdoExceptionTranslator from the given SessionFactory. + + If a corresponding IDbProvider is found, a ErrorcodeExceptionTranslator + for the IDbProvider is created. Otherwise, a FallbackException is created. + The session factory to create the translator for + An IAdoExceptionTranslator + + + + Implementation of NHibernates 1.2's ICurrentSessionContext interface + that delegates to Spring's SessionFactoryUtils for providing a + Spirng-managed current Session. + + Used by Spring's LocalSessionFactoryBean if told to expose + a transaction-aware SessionFactory. +

This ICurrentSessionContext implementation can also be specified in + custom ISessionFactory setup through the + "hibernate.current_session_context_class" property, with the fully + qualified name of this class as value.

+ Juergen Hoeller + Mark Pollack (.NET) + +
+ + + Initializes a new instance of the class + + The NHibernate session factory. + + + + Retrieve the Spring-managed Session for the current thread. + + Current session associated with the thread + On errors retrieving thread bound session. + + + + NHibnerations actions taken during the transaction lifecycle. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Suspend this synchronization. + + +

+ Unbind Hibernate resources (SessionHolder) from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Rebind Hibernate resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + + + If the transaction is defined as a read-only transaction. + + +

+ Can flush transactional sessions to the database. +

+

+ Note that exceptions will get propagated to the commit caller and + cause a rollback of the transaction. +

+
+
+ + + Invoked before transaction commit (before + ) + Can e.g. flush transactional O/R Mapping sessions to the database + + + + This callback does not mean that the transaction will actually be + commited. A rollback decision can still occur after this method + has been called. This callback is rather meant to perform work + that's only relevant if a commit still has a chance + to happen, such as flushing SQL statements to the database. + + + Note that exceptions will get propagated to the commit caller and cause a + rollback of the transaction. + + (note: do not throw TransactionException subclasses here!) + + + + + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+ + + Convenient FactoryObject for defining Hibernate FilterDefinitions. + Exposes a corresponding Hibernate FilterDefinition object. + + + +

+ Typically defined as an inner object within a LocalSessionFactoryObject + definition, as the list element for the "filterDefinitions" object property. + For example: +

+ +
+            <objectn id="sessionFactory" type="Spring.Data.NHibernate.LocalSessionFactoryObject, Spring.Data.NHibernate">
+              ...
+              <property name="FilterDefinitions">
+               <list>
+                  <object type="Spring.Data.NHibernate.FilterDefinitionFactoryObject, Spring.Data.NHibernate">
+                    <property name="FilterName" value="myFilter"/>
+                    <property name="ParameterTypes">
+                      <props>
+                        <prop key="MyParam">string</prop>
+                        <prop key="MyOtherParam">long</prop>
+                      </props>
+                    </property>
+                  </object>
+                </list>
+              </property>
+              ...
+            </object>
+            
+

+ Alternatively, specify an object id (or name) attribute for the inner object, + instead of the "FilterName" property. +

+
+ Juergen Hoeller + Marko Lahma (.NET) + + + $Id: FilterDefiniitionFactoryObject.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ +
+ + + Initializes the filter definitions. + + + + + Returns the singleton filter definition. + + + + + + Set the name of the filter. + + + + + Set the parameter types for the filter, + with parameter names as keys and type names as values. + + + + + + Specify a default filter condition for the filter, if any. + + + + + If no explicit filter name has been specified, the object name of + the FilterDefinitionFactoryObject will be used. + + + + + + Returns the type of the object this factory produces. + + + + + Returns whether this factory produces singletons, always true. + + + + + Hibernate-specific subclass of ObjectRetrievalFailureException. + + + Converts Hibernate's UnresolvableObjectException, ObjectNotFoundException, + ObjectDeletedException, and WrongClassException. + + Mark Pollack (.NET) + $Id: HibernateObjectRetrievalFailureException.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateObjectRetrievalFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Hibernate-specific subclass of ObjectOptimisticLockingFailureException. + + + Converts Hibernate's StaleObjectStateException. + + Mark Pollack (.NET) + $Id: HibernateOptimisticLockingFailureException.cs,v 1.2 2008/04/23 11:41:41 lahma Exp $ + + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The StaleStateException. + + + + Creates a new instance of the HibernateOptimisticLockingFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.dll b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.dll new file mode 100644 index 0000000000000000000000000000000000000000..c9e4dfab6239cce5ffe5be0fbcece4246862aebb GIT binary patch literal 92160 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.pdb b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate30.pdb new file mode 100644 index 0000000000000000000000000000000000000000..d6ce2d8c0b24d17b6f7a1693087aed96e5a4d701 GIT binary patch literal 286208 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 z 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 + + + Spring.Data.NHibernate30 + + + + + Holds the references and configuration settings for a instance. + References are resolved by looking up the given object names in the root obtained by . + + + + + Holds the references and configuration settings for a instance. + + + + + Default value for property. + + + + + Default value for property. + + + + + Initialize a new instance of with default values. + + + Calling this constructor from your derived class leaves and + uninitialized. See and for more. + + + + + Initialize a new instance of with the given sessionFactory + and default values for all other settings. + + + The instance to be used for obtaining instances. + + + Calling this constructor marks all properties initialized. + + + + + Initialize a new instance of with the given values and references. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by the instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by the instance. + + + Calling this constructor marks all properties initialized. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Gets the configured instance to be used. + + + If the entity interceptor is not set by the constructor, this property calls + to obtain an instance. This allows derived classes to + override the behaviour of how to obtain the concrete instance. + + + + + Gets the configured instance to be used. + + + If this property is requested for the first time, is called. + This allows derived classes to override the behaviour of how to obtain the concrete instance. + + If the instance cannot be resolved. + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets or Sets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + The default session factory name to use when retrieving the Hibernate session factory from + the root context. + + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The configuration section to read setting variables from. + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The variable source to obtain settings from. + + + + Resolve the entityInterceptor by looking up + in the root application context. + + The resolved instance or + + + + Resolve the by looking up + in the root application context. + + The resolved instance or + + + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+
+ + + Check if the hibernate template property has been set. + + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Provide support for the open session in view pattern for lazily loaded hibernate objects + used in ASP.NET pages. + + jjx: http://forum.springframework.net/member.php?u=29 + Mark Pollack (.NET) + Erich Eichinger + Harald Radi + + + + Implementation of SessionScope that associates a single session within the using scope. + + + It is recommended to be used in the following type of scenario: + + using (new SessionScope()) + { + ... do multiple operation, possibly in multiple transactions. + } + + At the end of "using", the session is automatically closed. All transactions within the scope use the same session, + if you are using Spring's HibernateTemplate or using Spring's implementation of NHibernate 1.2's + ICurrentSessionContext interface. + + + It is assumed that the session factory object name is called "SessionFactory". In case that you named the object + in different way you can specify your can specify it in the application settings using the key + Spring.Data.NHibernate.Support.SessionScope.SessionFactoryObjectName. Values for EntityInterceptorObjectName + and SingleSessionMode can be specified similarly. + + + Note: + The session is managed on a per thread basis on the thread that opens the scope instance. This means that you must + never pass a reference to a instance over to another thread! + + + Robert M. (.NET) + Harald Radi (.NET) + + + + The logging instance. + + + + + Initializes a new instance of the class in single session mode, + associating a session with the thread. The session is opened lazily on demand. + + + + + Initializes a new instance of the class. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + The type, who's full name is used for prefixing appSetting keys + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by this instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by this instance. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + An instance holding the scope configuration + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Sets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets/Sets a flag, whether this scope manages it's own session for the current logical thread or not. + + false if session is managed by this module. false otherwise + + + + Call Close(), + + + + + Opens a new session or participates in an existing session and + registers with spring's . + + + + + Close the current view's session and unregisters + from spring's . + + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + Get or set the configured SessionFactory + + + + + Get or set the configured EntityInterceptor + + + + + Gets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets a flag, whether this scope manages it's own session for the current logical thread or not. + + + + + This sessionHolder creates a default session only if it is needed. + + + Although a NHibernateSession deferes creation of db-connections until they are really + needed, instantiation a session is imho still more expensive than this LazySessionHolder. (EE) + + + + + Session holder, wrapping a NHibernate ISession and a NHibernate Transaction. + HibernateTransactionManager binds instances of this class + to the thread, for a given ISessionFactory. + + + Note: This is an SPI class, not intended to be used by applications. + + Mark Pollack (.NET) + + + + May be used by derived classes to create an empty SessionHolder. + + + When using this ctor in your derived class, you MUST override ! + + + + + Initializes a new instance of the class. + + The session. + + + + Initializes a new instance of the class. + + The key to store the session under. + The hibernate session. + + + + May be overridden in a derived class to e.g. lazily create a session + + + + + Gets the session given key identifier + + The key. + A hibernate session + + + + Gets the session given the key and removes the session from + the dictionary storage. + + The key. + A hibernate session + + + + Adds the session to the dictionary storage using the default key. + + The hibernate session. + + + + Adds the session to the dictionary storage using the supplied key. + + The key. + The hibernate session. + + + + Removes the session from the dictionary storage for the given key. + + The key. + The session that was previously contained in the + dictionary storage. + + + + Determines whether the holder the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Clear the transaction state of this resource holder. + + + + + Gets the session using the default key + + The hibernate session. + + + + Gets the first session based on iteration over + the IDictionary storage. + + Any hibernate session. + + + + Gets a value indicating whether dictionary of + hibernate sessions is empty. + + + true if this session holder is empty; otherwise, false. + + + + + Gets a value indicating whether this SessionHolder + does not hold non default session. + + + true if does not hold non default session; otherwise, false. + + + + + Gets or sets the hibernate transaction. + + The transaction. + + + + Gets or sets the ADO.NET Connection used to create the session. + + The ADO.NET connection. + + + + Gets or sets the previous flush mode. + + The previous flush mode. + + + + Gets a value indicating whether the PreviousFlushMode property + was set. + + + true if assigned PreviousFlushMode property; otherwise, false. + + + + + Gets the validated session. + + The validated session. + + + + Initialize a new instance. + + + + + Create a new session on demand + + + + + Ensure session is closed (if any) and remove circular references to avoid memory leaks! + + + + + Initializes a new instance of the class. Creates a SessionScope, + but does not yet associate a session with a thread, that is left to the lifecycle of the request. + + + + + Register context handler and look up SessionFactoryObjectName under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SessionFactoryObjectName if not using the default value + (i.e. sessionFactory) and look up the SingleSession setting under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SingleSession if not using the default value of true. + + The standard HTTP application context + + + + A do nothing dispose method. + + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for ADO.NET exceptions that Hibernate rethrew and could not be + mapped into the DAO exception heirarchy. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API - ADO.NET + + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Hibernate-specific subclass of InvalidDataAccessResourceUsageException, + thrown on invalid HQL query syntax. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateQueryException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets the query string that was invalid. + + The query string that was invalid. + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for Hibernate system errors that do not match any concrete + Spring.Dao exceptions. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute supporting Hibernate access code + implementing the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Mark Pollack (.NET) +
+ + + Base class for HibernateTemplate defining common + properties like SessionFactory and flushing behavior. + + +

Not intended to be used directly. See HibernateTemplate. +

+
+ Mark Pollack (.NET) +
+ + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Apply the flush mode that's been specified for this accessor + to the given Session. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + the previous flush mode to restore after the operation, + or null if none + + + + + Flush the given Hibernate Session if necessary. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + + + Note that a direct SQLException can just occur when callback code + performs direct ADO.NET access via ISession.Connection(). + + + The ADO.NET exception. + The corresponding DataAccessException instance + + + + Prepare the given IQuery object, applying cache settings and/or + a transaction timeout. + + The query object to prepare. + + + + Apply the given name parameter to the given Query object. + + The query object. + Name of the parameter + The value of the parameter + The NHibernate type of the parameter (or null if none specified) + + + + Prepare the given Criteria object, applying cache settings and/or + a transaction timeout. + + + Note that for NHibernate 1.2 this only works if the + implementation is of the type CriteriaImpl, which should generally + be the case. The SetFetchSize method is not available on the + ICriteria interface + + This is a no-op for NHibernate 1.0.x since + the SetFetchSize method is not on the ICriteria interface and + the implementation class is has internal access. + + To remove the method completely for Spring's NHibernate 1.0 + support while reusing code for NHibernate 1.2 would not be + possible. So now this ineffectual operation is left in tact for + NHibernate 1.0.2 support. + + The criteria object to prepare + + + + Ensure SessionFactory is not null + + If SessionFactory property is null. + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance. + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets a Session for use by this template. + + The session. + + - Returns a new Session in case of "alwaysUseNewSession" (using the same ADO.NET connection as a transaction Session, if applicable) + - a pre-bound Session in case of "AllowCreate" is set to false (not the default) + - or a pre-bound Session or new Session if no transactional or other pre-bound Session exists. + + + + + Helper class to determine if the FlushMode enumeration + was changed from its default value + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The flush mode. + + + + Gets or sets a value indicating whether the FlushMode + property was set.. + + true if FlushMode was set; otherwise, false. + + + + Gets or sets the FlushMode. + + The FlushMode. + + + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Mark Pollack (.NET) +
+ + + Interface that specifies a set of Hibernate operations that + are common across versions of Hibernate. + + + Base interface for generic and non generic IHibernateOperations interfaces + Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ Mark Pollack (.NET) + +
+ + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + Tthe persistent instance to delete. + The lock mode to obtain. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + a persistent type. + An identifier of the persistent instance. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + A persistent class. + An identifier of the persistent instance. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The default for creating a new non-transactional + session when no transactional Session can be found for the current thread + is set to true. + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional when no transactional Session can be found + for the current thread. + + + + Delegate function that clears the session. + + The hibernate session. + null + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + The type. + An identifier of the persistent instance. + The persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The type. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + If length for argument values and types are not equal. + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + + + + Execute the action specified by the given action object within a Session. + + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Create a close-suppressing proxy for the given Hibernate Session. + The proxy also prepares returned Query and Criteria objects. + + The session. + The session proxy. + + + + Check whether write operations are allowed on the given Session. + + + Default implementation throws an InvalidDataAccessApiUsageException + in case of FlushMode.Never. Can be overridden in subclasses. + + The current Hibernate session. + If write operation is attempted in read-only mode + + + + + Compares if the flush mode enumerations, Spring's + TemplateFlushMode and NHibernates FlushMode have equal + settings. + + The template flush mode. + The NHibernate flush mode. + + Returns true if both are Never, Auto, or Commit, false + otherwise. + + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. + If object factory is not set and need to retrieve entity interceptor by name. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets whether to check that the Hibernate Session is not in read-only mode + in case of write operations (save/update/delete). + + + true if check that the Hibernate Session is not in read-only mode + in case of write operations; otherwise, false. + + + Default is "true", for fail-fast behavior when attempting write operations + within a read-only transaction. Turn this off to allow save/update/delete + on a Session with flush mode NEVER. + + + + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Set the object factory instance. + + The object factory instance + + + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Callback interface for NHibernate code. + + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object, or null if none. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Enumeration for the various Hibernate flush modes. + + Mark Pollack (.NET) + + + Never flush is a good strategy for read-only units of work. + + + Hibernate will not track and look for changes in this case, + avoiding any overhead of modification detection. +

In case of an existing ISession, TemplateFlushMode.Never will turn + the hibenrate flush mode + to FlushMode.Never for the scope of the current operation, resetting the previous + flush mode afterwards. +

+
+
+ + Automatic flushing is the default mode for a Hibernate Session. + + + A session will get flushed on transaction commit, and on certain find + operations that might involve already modified instances, but not + after each unit of work like with eager flushing. +

In case of an existing Session, TemplateFlushMode.Auto + will participate in the existing flush mode, not modifying + it for the current operation. + This in particular means that this setting will not modify an existing + hibernate flush mode FlushMode.Never, in contrast to TemplateFlushMode.Eager. +

+
+
+ + + Eager flushing leads to immediate synchronization with the database, + even if in a transaction. + + + This causes inconsistencies to show up and throw + a respective exception immediately, and ADO access code that participates + in the same transaction will see the changes as the database is already + aware of them then. But the drawbacks are: +
    +
  • additional communication roundtrips with the database, instead of a + single batch at transaction commit;
  • +
  • the fact that an actual database rollback is needed if the Hibernate + transaction rolls back (due to already submitted SQL statements).
  • +
+

In case of an existing Session, TemplateFlushMode.Eager + will turn the NHibernate flush mode + to FlushMode.Auto for the scope of the current operation and issue a flush at the + end, resetting the previous flush mode afterwards. +

+
+
+ + + Flushing at commit only is intended for units of work where no + intermediate flushing is desired, not even for find operations + that might involve already modified instances. + + +

In case of an existing Session, TemplateFlushMode.Commit + will turn the NHibernate flush mode + to FlushMode.Commit for the scope of the current operation, resetting the previous + flush mode afterwards. The only exception is an existing flush mode + FlushMode.Never, which will not be modified through this setting. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning an IList of result objects created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+ The new HibernateTemplate instance +
+ + + Check if the hibernate template property has been set. + + If HibernateTemplate property is null. + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning the result object created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Generic version of the Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute() supporting Hibernate access code which + implements the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as a direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Return the persistent instance of the given entity type + with the given identifier, or if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lenths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Allows creation of a new non-transactional session when no + transactional Session can be found for the current thread + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional session when no transactional Session can be found + for the current thread. + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets the classic hibernate template for access to non-generic methods. + + The classic hibernate template. + + + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Callback interface (Generic version) for NHibernate code. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + + Sree Nivask (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object. + The active Hibernate session +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Callback interface (Generic version) for NHibernate code that + returns a List of objects. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ Collection result object. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Helper class featuring methods for Hibernate Session handling, + allowing for reuse of Hibernate Session instances within transactions. + Also provides support for exception translation. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + The ordering value for synchronizaiton this session resources. + Set to be lower than ADO.NET synchronization. + + + + + Initializes a new instance of the class. + + + + + Get a new Hibernate Session from the given SessionFactory. + Will return a new Session even if there already is a pre-bound + Session for the given SessionFactory. + + + Within a transaction, this method will create a new Session + that shares the transaction's ADO.NET Connection. More specifically, + it will use the same ADO.NET Connection as the pre-bound Hibernate Session. + + The session factory to create the session with. + The Hibernate entity interceptor, or null if none. + The new session. + If could not open Hibernate session + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using HibernateTransactionManager. Will always create a new + Session otherwise. + + + Supports setting a Session-level Hibernate entity interceptor that allows + to inspect and change property values before writing to and reading from the + database. Such an interceptor can also be set at the SessionFactory level + (i.e. on LocalSessionFactoryObject), on HibernateTransactionManager, or on + HibernateInterceptor/HibernateTemplate. + + The session factory to create the + session with. + Hibernate entity interceptor, or null if none. + AdoExceptionTranslator to use for flushing the + Session on transaction synchronization (can be null; only used when actually + registering a transaction synchronization). + The Hibernate Session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using . Will create a new Session + otherwise, if allowCreate is true. + + The session factory to create the session with. + if set to true create a non-transactional Session when no + transactional Session can be found for the current thread. + The hibernate session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. + + Is aware of and will return any existing corresponding + Session bound to the current thread, for example whenusing + . Will create a new + Session otherwise, if "allowCreate" is true. +

Throws the orginal HibernateException, in contrast to + . +

+ The session factory. + if set to true [allow create]. + The Hibernate Session + + if the Session couldn't be created + + + If no thread-bound Session found and allowCreate is false. + +
+ + + Open a new Session from the factory. + + The session factory to create the session with. + Hibernate entity interceptor, or null if none. + the newly opened session + + + + Perform the actual closing of the Hibernate Session + catching and logging any cleanup exceptions thrown. + + The hibernate session to close + + + + Return whether the given Hibernate Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The hibernate session to check + The session factory that the session + was created with, can be null. + + true if the session transactional; otherwise, false. + + + + + Converts a Hibernate ADOException to a Spring DataAccessExcption, extracting the underlying error code from + ADO.NET. Will extract the ADOException Message and SqlString properties and pass them to the translate method + of the provided IAdoExceptionTranslator. + + The IAdoExceptionTranslator, may be a user provided implementation as configured on + HibernateTemplate. + + The ADOException throw + The translated DataAccessException or UncategorizedAdoException in case of an error in translation + itself. + + + + Convert the given HibernateException to an appropriate exception from the + Spring.Dao hierarchy. Note that it is advisable to + handle AdoException specifically by using a AdoExceptionTranslator for the + underlying ADO.NET exception. + + The Hibernate exception that occured. + DataAccessException instance + + + + Close the given Session, created via the given factory, + if it is not managed externally (i.e. not bound to the thread). + + The hibernate session to close + The hibernate SessionFactory that + the session was created with. + + + + Close the given Session or register it for deferred close. + + The session. + The session factory. + + + + Initialize deferred close for the current thread and the given SessionFactory. + Sessions will not be actually closed on close calls then, but rather at a + processDeferredClose call at a finishing point (like request completion). + + The session factory. + + + + Return if deferred close is active for the current thread + and the given SessionFactory. + The session factory. + + true if [is deferred close active] [the specified session factory]; otherwise, false. + + If SessionFactory argument is null. + + + + Process Sessions that have been registered for deferred close + for the given SessionFactory. + + The session factory. + If there is no session factory associated with the thread. + + + + Applies the current transaction timeout, if any, to the given + criteria object + + The Hibernate Criteria object. + Hibernate SessionFactory that the Criteria was created for + (can be null). + If criteria argument is null. + + + + Applies the current transaction timeout, if any, to the given + Hibenrate query object. + + The Hibernate Query object. + Hibernate SessionFactory that the Query was created for + (can be null). + If query argument is null. + + + + Gets the Spring IDbProvider given the ISessionFactory. + + The matching is performed by comparing the assembly qualified + name string of the hibernate Driver.ConnectionType to those in + the DbProviderFactory definitions. No connections are created + in performing this comparison. + The session factory. + The corresponding IDbProvider, null if no mapping was found. + If DbProviderFactory's ApplicaitonContext is not + an instance of IConfigurableApplicaitonContext. + + + + Create a IAdoExceptionTranslator from the given SessionFactory. + + If a corresponding IDbProvider is found, a ErrorcodeExceptionTranslator + for the IDbProvider is created. Otherwise, a FallbackException is created. + The session factory to create the translator for + An IAdoExceptionTranslator + + + + Implementation of NHibernates 1.2's ICurrentSessionContext interface + that delegates to Spring's SessionFactoryUtils for providing a + Spirng-managed current Session. + + Used by Spring's LocalSessionFactoryBean if told to expose + a transaction-aware SessionFactory. +

This ICurrentSessionContext implementation can also be specified in + custom ISessionFactory setup through the + "hibernate.current_session_context_class" property, with the fully + qualified name of this class as value.

+ Juergen Hoeller + Mark Pollack (.NET) + +
+ + + Initializes a new instance of the class + + The NHibernate session factory. + + + + Retrieve the Spring-managed Session for the current thread. + + Current session associated with the thread + On errors retrieving thread bound session. + + + + NHibnerations actions taken during the transaction lifecycle. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Suspend this synchronization. + + +

+ Unbind Hibernate resources (SessionHolder) from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Rebind Hibernate resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + + + If the transaction is defined as a read-only transaction. + + +

+ Can flush transactional sessions to the database. +

+

+ Note that exceptions will get propagated to the commit caller and + cause a rollback of the transaction. +

+
+
+ + + Invoked before transaction commit (before + ) + Can e.g. flush transactional O/R Mapping sessions to the database + + + + This callback does not mean that the transaction will actually be + commited. A rollback decision can still occur after this method + has been called. This callback is rather meant to perform work + that's only relevant if a commit still has a chance + to happen, such as flushing SQL statements to the database. + + + Note that exceptions will get propagated to the commit caller and cause a + rollback of the transaction. + + (note: do not throw TransactionException subclasses here!) + + + + + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+ + + Convenient FactoryObject for defining Hibernate FilterDefinitions. + Exposes a corresponding Hibernate FilterDefinition object. + + + +

+ Typically defined as an inner object within a LocalSessionFactoryObject + definition, as the list element for the "filterDefinitions" object property. + For example: +

+ +
+            <objectn id="sessionFactory" type="Spring.Data.NHibernate.LocalSessionFactoryObject, Spring.Data.NHibernate">
+              ...
+              <property name="FilterDefinitions">
+               <list>
+                  <object type="Spring.Data.NHibernate.FilterDefinitionFactoryObject, Spring.Data.NHibernate">
+                    <property name="FilterName" value="myFilter"/>
+                    <property name="ParameterTypes">
+                      <props>
+                        <prop key="MyParam">string</prop>
+                        <prop key="MyOtherParam">long</prop>
+                      </props>
+                    </property>
+                  </object>
+                </list>
+              </property>
+              ...
+            </object>
+            
+

+ Alternatively, specify an object id (or name) attribute for the inner object, + instead of the "FilterName" property. +

+
+ Juergen Hoeller + Marko Lahma (.NET) + + + $Id: FilterDefiniitionFactoryObject.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ +
+ + + Initializes the filter definitions. + + + + + Returns the singleton filter definition. + + + + + + Set the name of the filter. + + + + + Set the parameter types for the filter, + with parameter names as keys and type names as values. + + + + + + Specify a default filter condition for the filter, if any. + + + + + If no explicit filter name has been specified, the object name of + the FilterDefinitionFactoryObject will be used. + + + + + + Returns the type of the object this factory produces. + + + + + Returns whether this factory produces singletons, always true. + + + + + Hibernate-specific subclass of ObjectRetrievalFailureException. + + + Converts Hibernate's UnresolvableObjectException, ObjectNotFoundException, + ObjectDeletedException, and WrongClassException. + + Mark Pollack (.NET) + $Id: HibernateObjectRetrievalFailureException.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateObjectRetrievalFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Hibernate-specific subclass of ObjectOptimisticLockingFailureException. + + + Converts Hibernate's StaleObjectStateException. + + Mark Pollack (.NET) + $Id: HibernateOptimisticLockingFailureException.cs,v 1.2 2008/04/23 11:41:41 lahma Exp $ + + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The StaleStateException. + + + + Creates a new instance of the HibernateOptimisticLockingFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + An IFactoryObject that creates a local Hibernate SessionFactory instance. + Behaves like a SessionFactory instance when used as bean reference, + e.g. for HibernateTemplate's "SessionFactory" property. + + + The typical usage will be to register this as singleton factory + in an application context and give objects references to application services + that need it. + + Hibernate configuration settings can be set using the IDictionary property 'HibernateProperties'. + + + This class implements the interface, + as autodetected by Spring's + for AOP-based translation of PersistenceExceptionTranslationPostProcessor. + Hence, the presence of e.g. LocalSessionFactoryBean automatically enables + a PersistenceExceptionTranslationPostProcessor to translate Hibernate exceptions. + + + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Return the singleon session factory. + + The singleon session factory. + + + + Initialize the SessionFactory for the given or the + default location. + + + + + Close the SessionFactory on application context shutdown. + + + + + Subclasses can override this method to perform custom initialization + of the Configuration instance used for ISessionFactory creation. + + + The properties of this LocalSessionFactoryObject will be applied to + the Configuration object that gets returned here. +

The default implementation creates a new Configuration instance. + A custom implementation could prepare the instance in a specific way, + or use a custom Configuration subclass. +

+
+ The configuration instance. +
+ + + To be implemented by subclasses that want to to register further mappings + on the Configuration object after this FactoryObject registered its specified + mappings. + + + Invoked before the BuildMappings call, + so that it can still extend and modify the mapping information. + + the current Configuration object + + + + To be implemented by subclasses that want to to perform custom + post-processing of the Configuration object after this FactoryObject + performed its default initialization. + + The current configuration object. + + + + Executes schema update if requested. + + + + + Execute schema drop script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryBean itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfb = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema creation script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema update script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaUpdate class, for automatically executing schema update scripts + on application startup. Can also be invoked manually. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute the given schema script on the given ADO.NET Connection. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override the ExecuteSchemaStatement + method to treat failures differently. + + The connection to use. + The SQL statement to execute. + + + + Execute the given schema SQL on the given ADO.NET command. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override this method to treat failures differently. + + + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + Implementation of the PersistenceExceptionTranslator interface, + as autodetected by Spring's PersistenceExceptionTranslationPostProcessor. + Converts the exception if it is a HibernateException; + else returns null to indicate an unknown exception. + translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + The exception thrown. + + the corresponding DataAccessException (or null if the + exception could not be translated. + + + + + + Convert the given HibernateException to an appropriate exception from the + Spring's DAO Exception hierarchy. + Will automatically apply a specified IAdoExceptionTranslator to a + Hibernate ADOException, else rely on Hibernate's default translation. + + The Hibernate exception that occured. + A corresponding DataAccessException + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Setting the Application Context determines were resources are loaded from + + + + + Gets or sets the to use for loading mapping assemblies etc. + + + + + Sets the assemblies to load that contain mapping files. + + The mapping assemblies. + + + + Sets the hibernate configuration files to load, i.e. hibernate.cfg.xml. + + + + + Sets the locations of Spring IResources that contain mapping + files. + + The location of mapping resources. + + + + Return the Configuration object used to build the SessionFactory. + Allows access to configuration metadata stored there (rarely needed). + + The hibernate configuration. + + + + Set NHibernate configuration properties, like "hibernate.dialect". + + The hibernate properties. + +

Can be used to override values in a NHibernate XML config file, + or to specify all necessary properties locally. +

+

Note: Do not specify a transaction provider here when using + Spring-driven transactions. It is also advisable to omit connection + provider settings and use a Spring-set IDbProvider instead. +

+
+
+ + + Get or set the DataSource to be used by the SessionFactory. + + The db provider. + + If set, this will override corresponding settings in Hibernate properties. + Note: If this is set, the Hibernate settings should not define + a connection string + (hibernate.connection.connection_string) to avoid meaningless double configuration. + + + + + + Gets or sets a value indicating whether to expose a transaction aware session factory. + + + true if want to expose transaction aware session factory; otherwise, false. + + + + + Set a NHibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + Will get applied to any new Session created by this factory. +

Such an interceptor can either be set at the SessionFactory level, i.e. on + LocalSessionFactoryObject, or at the Session level, i.e. on HibernateTemplate, + HibernateInterceptor, and HibernateTransactionManager. It's preferable to set + it on LocalSessionFactoryObject or HibernateTransactionManager to avoid repeated + configuration and guarantee consistent behavior in transactions.

+
+ + +
+ + + Set a Hibernate NamingStrategy for the SessionFactory, determining the + physical column and table names given the info in the mapping document. + + + + + Specify the Hibernate type definitions to register with the SessionFactory, + as Spring IObjectDefinition instances. This is an alternative to specifying + <typedef> elements in Hibernate mapping files. +

Unfortunately, Hibernate itself does not define a complete object that + represents a type definition, hence the need for Spring's TypeDefinitionBean.

+ @see TypeDefinitionBean + @see org.hibernate.cfg.Mappings#addTypeDef(String, String, java.util.Properties) +
+
+ + + Specify the NHibernate FilterDefinitions to register with the SessionFactory. + This is an alternative to specifying <filter-def> elements in + Hibernate mapping files. + + + Typically, the passed-in FilterDefinition objects will have been defined + as Spring FilterDefinitionFactoryBeans, probably as inner beans within the + LocalSessionFactoryObject definition. + + + + + + Specify the cache strategies for entities (persistent classes or named entities). + This configuration setting corresponds to the <class-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="entityCacheStrategies">
+              <props>
+                <prop key="MyCompany.Customer">read-write</prop>
+                <prop key="MyCompany.Product">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the cache strategies for persistent collections (with specific roles). + This configuration setting corresponds to the <collection-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="CollectionCacheStrategies">
+              <props>
+                <prop key="MyCompany.Order.Items">read-write</prop>
+                <prop key="MyCompany.Product.Categories">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the NHibernate event listeners to register, with listener types + as keys and listener objects as values. +

+ Instead of a single listener object, you can also pass in a list + or set of listeners objects as value. +

+
+ listener objects as values + + See the NHibernate documentation for further details on listener types + and associated listener interfaces. + +
+ + + Set whether to execute a schema update after SessionFactory initialization. +

+ For details on how to make schema update scripts work, see the NHibernate + documentation, as this class leverages the same schema update script support + in as NHibernate's own SchemaUpdate tool. +

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Sets custom byte code provider implementation to be used. This corresponds to setting + the property before NHibernate session factory + configuration. + + + + + Return the type or subclass. + + The type created by this factory + + + + Returns true + + true + + + + The Spring for .NET-backed ByteCodeprovider for NHibernate + + Fabio Maulo + + + + Creates a new bytecode Provider instance using the specified object factory + + + + + + Retrieve the delegate for this provider + capable of generating reflection optimization components. + + The class to be reflected upon.All property getters to be accessed via reflection.All property setters to be accessed via reflection. + The reflection optimization delegate. + + + + The specific factory for this provider capable of + generating run-time proxies for lazy-loading purposes. + + + + + NHibernate's object instaciator. + + + For entities and its implementations. + + + + + Instanciator of NHibernate's collections default types. + + + + + + + Fabio Maulo + + + + + + + + + + + + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + + + Fabio Maulo + + + + + + + + + Creates an instance of the specified type. + + The type of object to create. + A reference to the created object. + + + + Creates an instance of the specified type. + + The type of object to create.true if a public or nonpublic default constructor can match; false if only a public default constructor can match. + A reference to the created object + + + + Creates an instance of the specified type using the constructor that best matches the specified parameters. + + The type of object to create.An array of constructor arguments. + A reference to the created object. + + + + A Spring for .NET backed implementation for creating + NHibernate proxies. + + + Erich Eichinger + + + + Creates a new proxy. + + The id value for the proxy to be generated. + The session to which the generated proxy will be associated. + The generated proxy. + Indicates problems generating requested proxy. + + + + Creates a Spring for .NET backed instance. + + Erich Eichinger + + + + Build a proxy factory specifically for handling runtime lazy loading. + + The lazy-load proxy factory. + + + + + + + + + + + + + + + + + + Fabio Maulo + + + + + + + + + + + + Perform instantiation of an instance of the underlying class. + + The new instance. + + + + + + + + + + Delegates to an implementation of ISessionFactory that can select among multiple instances based on + thread local storage. + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + PostProcessConfiguration + + + + + + DelegatingSessionFactory class + + + + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Does the tx scope commit. + + The status. + + + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Does the tx scope rollback. + + The status. + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Does the tx scope set rollback only. + + The status. + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + SimpleDelegatingSessionFactory class + + + + + Connection string config element name + + + + + public Constructor + + + + + + TargetSessionFactory + + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.dll b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.dll new file mode 100644 index 0000000000000000000000000000000000000000..13703fe0812c521842665ca2c8d68e23d2b24a31 GIT binary patch literal 92160 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�&jGDbNSvSFgc0`!MyH9Z z^0xxLrO~VTZ(;VlQ=>2Qci`RSYeq`5Lh+M_mS6@Rt#vICFp5N_hoVMY^zcxTQ6`3Y zsH0IK_V-Y|Q6(N%C`2VzBVN>q%BV)Xtr6w6M(osx%DqN>rP0_J#k0GzE}^N6${4K_ zb7MqfN#^1x>h9c)Oy7sEiUKlu%kPDj;;4Mwx;|K-)Ds zgVD_Hiu2}zy^VyJqtOEe(|{Ig^lZU_Mt5on?FxDn`Pg~Zsxc?Q;RX~7X+s+ttGHD9h%Xf4 zw$ew08;EnK(XVK=(MR-Pv{_Ku_7%MttrTO5E;9OxK^h$h)L)Ebr0VrRF~LJu7z4#L z53M%_iCG@H#n?;CV?^bCr-73!_%peede|7Q(Pm>~(UZnV5B<65S!0xkz9@R#7%P@| zGMlh>c!GznFvf|M9(vDc5^Fqki!olTQz#TE{>YdpZfB%)nJDh_IGe=Y;xP|hVeBoQ z@z5>CWU3(GI~ge{Q^n^Vt;zdWqBiIDDPH75qp>GHjdO&R+}!;@+s{KsgO)|7 zf<}9P^tUGEv8P@|nTL1VWagc|a;!AvJX8a@LV2`#qeuWR65-*UmJlY!U_Gi&mpdI4T z?f@-|UW-@ALp|Ex<27=&$j2%n#yD>Mv&CG6_)Ar@#XmGEE9oT<6E$??8tdfLCm$h( zGumV%O9sigVzP%u$s@&F%{i%LlAI?#)##X#X>z_;)RUyF62B`sR30sQ_9C=WTvyVB z9e|~bHXHXaI*ZY&kW;z{vJezZa^@zKtdX&+jRuLP(+ig$@T&O^_aHi;8Gw54>t%%azkLdK)L zUb;e__X&+8D-zfbv`6a+U=!3qUD(D6<}0iUhkp#Nd0CXdRgA$LvP62d}xRK zy$^jNH+bj-q<*G+T5$}zE-%72>!CzO?#k9z2mvX|wP9=aE3qlca;t23YWp+@r= z4{a%}GoSaNM)O4vy-+sDe8oe5M5$~M&v`YuNo*CN-bAL+ViM3C4;2}&iboi24pATZ zn%JZf^^vcMmo%b2@^$gLM$|{XF1Bez{oos7r$*Edz9Bx>i2A`dv3o$NZw^sE_@+2O zBkHr>60U`toNn#Y2teU&L&UsJ?t6j`C2W`Kh3P=ZEGR)Z6@BoU0Mlo-f3D zji~SWQrzaD74j?bh(^@Ed?Q}ci29dr#rqywFTWFi*NFO;AH??_S|R@_qWx6r)W7^B z@Dk6uP;LDg`#%a%Z}W>7suA@z!kDZP^}>d6ghtd48pd%NQ9me+RT@zbZ5nGlv_e|O zwH`WC+QtSCt(HOKJr7+XBSx&h(uI1rT%$%K>fQ2;o{UzB0cG>d4#seg_MnUzQ#GQ# zuE4m+<6LYO8gyZWEKfaOv617Umu1}O>7h4dsWHn#J7k41-$S3sPR6AgQO{RpT<;-a zb}`=fP>$Kn_|!usX3`kTyXHF$>iHUtsUCV+_AuxlCnnA2m%Sl-8P|AdhwN+I=Alny zf8$+^sOKAGeC#1%4l$|+D=8iL?Cn>C`IZ-Vgzqs>NT#Zq&U zF=Q{2vf1ceu>&iU3mKgzCRenYlMSL!&%P8bU?1ajrcr;EkyDL}80|EOwy$xMN4wCR zW^D4&rW@aTv>VMCMim`BK;9|dLBAB!%ML zXwETuGEy?<8h3lNr_Cdc?LOL3#*AUvct;y2F;ejy;}?(iw7JAc@zh+=T8wKMQF^bL z#~DxfXeS!q`)JFI(h-z`iq~rF%ZTD_H0M%UWJJ0c)}_WEA8nm+kVm`Fyxch6N4v_n-J|_rUTr+(qpdgI_h=88 z*BW2@XxAGvM+^K>dOw&q7{@SDy4+-(>7(6jT;-$PYCPc4n#66!Gai}*^pQfLrjB{m z?Z)3Un$fWc=xdE=OufT6VhpFwW9l8oB8_Mq`@PYk5sfQj!VRyMrTc$ZI$?{)4tY|#vKZUtj;s7jmEti#XBz&8;wUbXFa2LG#cEw3A7&>Z4OOjTFqpZ zi8?{Fq=)81<_Lv2g{O`28eQIbiS@KWvE27?7twq88tWNN+icK#__H4RqUcKN1!Jn0 zLX&vWn5kuU$^V1(qA^FKLHYLrE!2og`Xyt9MpV)-8Ru(6YdS9**D|7Yw@0j(jawDs zb+=cH#~G=0w^xiWH6qJzF~k(g#c6`p-L|&L(W{=;8;f4BUh@#;=yeZ$QS?XaEk@MO zKU4Ou^|lXvXuad1Ev4^T@A=S&*83iMq3l!Z0}t(6_H7$v2DbZX`GF68s4DPhA8HKz z#X~d7Mg%_bp(%mSd}wyy3mE_}PaV19T)! z(M~|>rVmXC&|axan;oFLGcIxhxgNTt%nZalbT3e$hX$0L8YuRmH39r916s;}va156 zK6G0EAFb51v1JbiDtzdL06vH4(Y6IT`_SisN}0!Xg8IlNQ7x-IGzn-g4;2|Tat0&y z7E&vZ(1_kbYUQyS(OXDYxm+W93+XD))re;Pb@DQeXy#uhZ__@Zt^LO zs5ec>S2UtGl!Sa=BkE1N%fD$vEhj0z(}-G5Qri1a<~N6^AFP)}8qwQJN>*z`Z!am? zLnC_YX^=xSqPLy~IZ-2en`o2=Xhd%ljq*s1=&h%ROlw4MJw4z82v|f&rmuf_BA>-u@9$FzM$a^%Rw~$HlDUIm8V{b{{QK3B0 zd&gwCO(W`wrpS*y^r5wn{7xh4iT0IpUlngl>4(-dS)dX1MElEXji@KuU#2`{2ByoY z9?B0KAW!m8Rp20bhKCvhv*cYGQBO2mKH;G$fy3qZ9-1APCqvVeE;GuUz(P4oBkGA3 z%LN`X1INg7J(M3LvEIa*mI7qx{IDb+vDj z`7>4iDBkUI6(bez4tcwecBkxdAaN3{t9_T8#Ym-hzkJoB^|K$4pZjPJ%kBrc@%q`1 z$nlI+yvOBAkJe;AA=mh5Ps*!2+6?}nN4DoEM;_wxW4iTdy~9E zqp^jKy;;8Iq2=~-GG`XWy9B#>%k39rDWeOpgL9_+lANm1RrzPyTjh#Fi1T;iF35ac zZeVnYc&u`*{if`AsFLzR<<<6Ea=b>#l3VO|WY5`(_G<{EUnr2r$YwwUbhbhj|s#oj}<#>%6LHkJNAFgPltKP8xB=`5wc6+D1LZgGL zKCwTR+mBG33#-1e|0)aS5>op|pUB~isQirJCvqyIoyLZ$jpA?eT#ptC{!PB6XyG@j z3gqAA2aGn09aT-@@A4as{>mu-NJ?R|_`GTfXg6#06KJ2yA2sSxT^#&eo;Hs-SA}k_ zzQXuIuF+^?bt?F!OwCucH$eMJ_G7d&`~}e0a-2duqy9$D(@4}*Sl`HFG-sryPw*SL zOrx@zMdBMt|B|SxtxZ5{+Mu-_y2AKIuJ_Q`;6LOe9@;zjt$fo%`vt#~UwY`E;P*0j zft$iD#t*WDk=i5rQC54jCh@cE?x8D;pJi_k9TxmWPWI4(pfG27=oZ5;=P^<;O>>Dy zYZ3wT1V%fJ{Qb06B$J{H55OuMy2{;^vteT~POzVBB1z(T#PV0$s*v zr$M!@#9XgXm}*^#`J_fv>q^W`DjwI?5_8rP%KJ{K%>t5SaCwiA)z|6Y^l|;hWI>TA}dV)XvaQ z^F&4}y`knx4}A&RMT|C!SL-XRk>+cRHi=cK%f(3Z4UMQSjWV}sM0Izx`4b~0bBq}{ zo^rG^e0RzUk1-20dOo#Cj4>-U`YM$R8u4Ky$(0TBKual_L8nZ{n1eK;GYezPaT@I` zEkwNO9=cqNGmp@yqM;((WTriIg)zZgp;3Lq6~;vKJP%cbCz)4jGyt^8=4~Eo5>w0v z7_AcX@u7q%=F=LT-_QW`s^+}8VGz)E4~+`%WB!ju4>n8)Pc?tk=#_?zVqY_S0_Aq6 zv7=#Xcwe(bqq`~(2v0M+dT68A&+P4?IpO`xksewUo^I}=QLwQkJj0yjp$yPbjCL3u z8>_HSua~Y`;JHWirLz6&zN+E8yGtK8UqINsed`%;Izdg_# zeIn&(6|WW^Xzr~Mz26>WPS=Qf+JntQG@@SkU~_>+v|2dJd`}~K6P{)MNh5j_o@IW< zNUatgVt%7(v|4zG`Lm|cTk@f1Xc_6ERtsmFH)=$yg|p2kG@{kQIc82PajwK!f(_xr z%^{2~5VLwb6rO9Y(P(v#jo~BBnah<-T34KB-mDR=E6!IRBSw0(uDH;A;AG-FP2AX{ zn{|{qWQB@HtBgmROBtOe?gMR+`G}^`n&VoCAN)*PXbpcTkwv-DJ=sTIhj=97%n3gl9At3n~G=hpCX=Gz+8_k0uRLzjlt z$>YsWG@{kX60|ybyxHM2N@10t)yd<{L5$SuCaaze-2G#74rczv&s{HM>3TV#iSeEmD zIPN#>;^-{WQYjY0FSXyF7v(3aA(Xo-zdyW$^)F-oYL=PU#h>I5a;50Ki+>1*D+wdn zKc0D1y5vf+4?;{qR71>USIJa1^h@?j+cn+U9M{jYYu^8x5T)&roQmJC^z^$YG7q^@ zoDSFIx@3v-Is77a{hD0KA*WQ31;~}+eD<&PT*(qlErG%%PT-T|+n7hi`o#0Mm6MhH zYvB^7>)q6UjYowW;!fs#mt8uUWbpYUIzvu=rJKrK*1xOfE~h^iPeX#=Vs!GnZHQ|_ zCHWyxO}2w8EgNEK%a8tIxBs*LY+LqgWpG_pdGTxb>$&sSValCb-~272 zz2B{?zg>G(jcwlw{PJBn|8BeUw*_hu68CyYbAP)azZ*_v?bcOQ3jeo_v~M;4s*U*T z+bwL{JGd88;i{CCe*;q~#I1q;aI(DWJ=_%iR8_LSCiA!BDk`;li+iVl?u-2LDc8TA zx}xrh1l4c&C9Bl^;Sc)kvunSh;{IB=YH_N4`BPCXRD~!W)pmX@BwH5lEF~La>e0t9 z|JO>5!rMylmsD0}TONNb)i>^WADAql6v>t1VYZ|{WHX1ny^Fh@L$b31DL(bZeXSEo z`w%YO-y#3EOx^Q2l3#z7qg`j7doE3tFS+jAW7iO>SO2%~k|H~r|NG;+nlmJ^8Q)c_A=j-H?dt&gRj#)b{{P*Kbl1ANYe;*|{WW>lT)5Q#Y#ykr;jbs{L);OE z`gyk&sTQq9L-M;?sgVCa%ue^DX8LD4zs9fndH<;7?|Bq;*O2V!(6(=G8`5naMR{yU?bN`sDMk1BEKir>dT)RT)N7$tnEk&`n*>%R^aFVHBNt8|8M(ya(c^5d4b=enG~a7eUImZ~_%R#S*-O=J_dWhwjMFl33cIgukxpX%gZdd%ev@f(ZZ1pHbNbETLn zR^w*m#rWmo7Gy8{`r+3dzpmnY@e%gqzQ^s^jQn0q#2(!D;$-ZFbvNcWoEGkGoZqk} ze3nT&8W+G_A})h_g|VL9TiCsm-3QrylHKRn-3k}Cf7ri+-M_*e9r+$^TpAY13=4Lx z4*foj#H_l0Uq;FheuYuZZg+NjS($#{M+U)fLd^b5hgwO=0Gd;1kdM_SMItBX#s zzUx;X#o5)GUeOrK9BCBy?;kzT>fL{M^e}5m|31Nm*3tdPM#G{7{$5sV|0&TEt%v*X z4|ik#1L3~Ve|B^wr?}Agw*Mk=mX#VXH@eUmI3Od>vW5*<7(L6HG@v=UuW`_Tj5yYy zTvT&f#~KR;R9F{S=M6YDdaQBLfScq6)|CU!hX2|D1@c(q_5qhhFSA}5aAkD8_5OfG zV!gE!{Kpz}R&HN|Zjm2re2G-Tu*2hs_5FawM$8Hf+zfxt!1a(&JaDm5&9|3tfrbwo zXW{P2*63NrNVs<*qzR?!x>p$FzlGg9aT}Pz$wjFd^9FvzA-BMv9{5)DIfL%=67^1K za{9m)u`l0SdfWKjz)zw(j4KCz1NYW}KSm$4-W_P>EHpkIn334Ig@1?f&;O^rZ-JAm zsPe9RGp~@Do=i`GL?+TGN}^;Wga~<%(3wZlOEQyWCSU{{J2Q8ZhMw+8cTbYxA=5LW zqT-rWR#`#Ky0An~iVhN|Zi#L9UVXdVAw0xxeVt-V(VD@0zT=;6sfwk-pVwaeuJvqm9f*8rWW|T59W; z|Dds@wq^M>_}0!Zae}(Z;E*>9H{k~3H4^^4gl}=@$+xjLIlP6q$!S~u2h62$*-?S> z4+s}5uW8!kERy^c%Uh8C{Ja-SxDer&=Q91}xjMZMJtUSdZaQjO@w=Uy9NvW7Q$=IpxTi(;O zQ}N{H4D|@=ES9-1bpGY^2e2M_ig|`QX~igL^lg*^j}uIsc92>+wYv=-Wffu<_!18Xj^n1!CBKjhbtoP z99{9fhOJU(q08^{7oFCX;2bBp@|#UNYp-1S&-hjK+6#WslydSb(|9rO-j#oD8n6A} z%BO@^Ya=P=o|V^NtOF}YAu)NYey7a(OoS8e*%F?I@IcKxLvuBW$cIDBkS57U4T<-iVyFb#GUE%gehJ@1x%;@4~qiUg4W&kaj-+Kk&}yKS};S znS9>uBpn~G`G~yzg%td4LgAKs~3XWTDu10q-aHu9j9J}9LR!sb0Z<3XwO zpw#)Ilzvg(2lGYA|Dxo7P4d4c`CpS(Uz5_WN$Gc_^gB}e9r(P@#rFaEHkzkpl&2-< zSpzgcJVPgHqRBcxB@)&eVmZ(cTN+3wiq zDdkdvJyv_osu71$ZmoI}rE68ny=K)u_a{i-)|hfBuO6$VOmkdHxii#ltJ0wRM^;7M zqt1h?a#&vvuA0%9aGzTBSo8C>&z$+nSx>6&)!%Dwsk?mj51SuzuU!4J=D0Jl`YFe$ zJGA;Y%?s7p<9*1cZ=mWq7Nz(_I-qID4nN5v`c>nb|kG1M#Pv8%sG~kov$IO7C?Zk+uwP zb@ocly;74oU%=Z>h+&5JI^zO!i+dw_+vmPN{`J}W+z-c}KzK0zquGsu=Q#pfvF=Cl zKO_JD#v5Dib=%jR+_JZhcy5%^d)@dNz*E=1=Cqc5?!cM_2=i-Rh4A_{=e5j%9$AI- zJJxg}ymif{mc#Cy%U{#7ukIUb29WckH6Fs>Ab+3x=QV4gcbYohGwY!A5U)92`Gut0#d;^n)8s?})azTf4S8;||}R@}%@1cdqPufAlEo z+!>u&Khbq48h78(bz03)tftRJTk7xWI@g(3e@o~D&XqlXK!v@=fYPBslH_`waLY6KZA63?L)2e+}qYZ-b#&dt5ckDVC|1v zcLM(ZXf4h-vi3Kq^Tb-L!Ft{u8b|(qr-<-HbN1E$==?PZsXO+|d}-0$);I@t(WP_Z z&JF9Ha_+6aW!>xM%v5)+i@FEv53L)R^+*ln(i~Vj@1C7E*&ZaF*Z)>`{ z>ElhGYdX^OWYhm?YK&wfe;?V_Jknfj-rM{S&HI}VHh-@9;pWq4Z?>#AI{RSD z(&$Ce*G9*p*G4C!H%Gr6{cW_p_1e}qwZ5nIE3Hqq{-L#Y&a63S&RH^N*_?HAdgctx z!I!JChpffF2J9swc;nNluXZV7GURbKHiUWks>A*V>fUfb|zhT%V;;=QIb%v z!<$L-z)k@>gxz@O<~Vi;R|8MiU`KF0_8D)%8&KYk+V8+^k*;Q5gSoW%EeMC3nNw)~ zJB06bo+;%!Ezeby>iW9v9W88iw}iUpyINWQ{jJQuL&67I@lJI0rPe(Nzun6IpOyT& zIjs4jllhIV&!5WrUzPC35}sP?xfa6TpUOIV+*9Y`w_4T9=Cb~|bD7^UcPDZ-Ncft$ zV@PXAJ}h+(%;ku|{)0X19&~TI2R-`0Y3yH*t4GwM>#;uB@Mhew(PO=7en(9?oH~E+ zd_tmIeQbULbv`qned^xcudYDOWiMt_OvX`2x1md@``$6)4Rtzz^`LH!L_G;X4y|L$k_~cpZzTIuW!F~rc!^`&YbtP-;VSh?QcQ) zFQeC=+rNt*j!iZ8?_%Z7K*-gLA5nm>$-#%=O#E}PqGuv~GS;*UZw13su(t8`M1(HZ zcr(J6VU@dB>#YdSLR}YY{#1ku;mdI0i#QG8tKr9RAqP%J$hU6t7i?aN5O3;5Z!09c z5Uufxvj`n{9~L6LO2Uia%W$!4T!e4{ZwPkrn~{rAX9q$T9)~4JUy0C#T;*E;(+FL7 zAkIfRBjG4UbMfw-Wysly(Oi{-p9AmSldyo%TzD(u$k~O^g&gWYdJjSu@~8{xs}Z`8 zNo$e57NM)&0NLfhr;$MVddM#q??1*{mDSrMya|%bh1_EJ5Z(>z;QJE{ABJRe@s8I% zr2h@l%~g*`_yxXo8J-!2{|;}8s~(l`OVB3{-ottsa*n{;;;646bk$dZ37k?&_zjgr z&est-cuUG4!f)Xnvo79svK{GfBg8E>;K{+8N*I0@cyiSf5`G_e!VM7#H#%A5_ab!E zW@jhTn-Dsx&&ea*?~Eb61)-}hadsoT)EP(4YY@6>t8)#~uXV0Nc$srOa;|iW2(NOc z5N4bk5bku|j4O7BAGs*gDDLi%nAKjz$w zoR1>Jof_voNZ%vjzc{xb=i?II=e!U32b|lG^9cz*>3je=pMqWPsDlV`TIhTT=}#kc z)&0)xNFS2$GtNIF=YLE1S!X};4NbRR&t$$bd~kMM zPCr86+5H02TO_>HeH1ybLFlNh?w1h0);)soGWV+pFL%F=@Cv*a2Oe4XF@yu|;|O2x zK7laleh+Q8A;eoJ-6xSAlyKO63hC|c50QVJ`(vc9m2lGi3DQ&U&k(-ReGcJU@unA7 zz0Ey}@LhP9i>uy?ceuFfgYIt;?t{0^RsZPz9^r@ZRujs3 ze(au#@TcxPgg?W3PF(!D#(ZbJnq4~s)^A6Xq)8|jT)8X1UekGv!DnaJlOUy6J)@^s|c$gd-A^GVIo<`*@; zr1=%i=Qb~I&d+}9?4Qs6?d+NfdaP$)orDnD;9UKF1Hq>aeRcKS8m7- zjitR+s&AA(Ak^NOEF{}|)}^+2xlFR)Em_`P*3UATg zH#Rz&%@tHfHZz>s-scS#*fOkx(kPwDtZfynXop>wO%HjwX&_YVlUI+MR;FU_sAmUE zWG+d0yY(DZX}tJQwrkIzH%iF-+)gj;ZO5GboK0h1Zak!B-*~>@jf51$2M00HY)*Bj z$MQQctY<(b;dFSE_PG@4ka=L59~HtfT}RMs~cRK&5dsG=PB0rff2i}an#^;DfCU;h5GYiJl=lH;WFF zJjR@~aezAIQx1riJz^e(NT9wHbhzh_QqjXmelVL$r?x3=R+za4QRJtyC6N)ZnG&6; z{Af1M`P-TSC`v7?kkc}*WN?Ws(|)P94JJmRFlub2l5v++TQY+X{M)lRP-2Mop|)~- zrr9u-2A?GJ1uMN&A_L}11uEOIx8xy{{g!5wj%=<3xuJBsC0L@w2Ee^xu!N3HmH6%? zn#Z^03puQzjj)!6v$>G~2CODXSSUiu3?zXPl{iLMCG@~rwwQ!f8ECFSv}IkHu@P(` zO|y7*RN(_*no4E{z4nqgP>E{!00j8LBG`((B;rFb$UNm+?15yvl^ltVv0To}6eSe?o+jm@NNEY*-VoP-qd?X7ldLj^<*Xxlj0FLNvAC0S)X z=2@vMhjpMJ%g150s!Ym>^e(S@WK&Qvcy+ys3gvKA4QI$OV9C-Q@96K{ymg>=&EIr& z^bhpJH*~3d85uNJarsrFJy6Cihg~v;5v^S1vcUFSB`!%qdqQ&Y*enxW;#RIe({D zsjN0bktbo2nO<$I_vh{Fv)i|WX;cCUmBt72)ZUJb@y-2-j>N`zf7igpUAQ^g*SoQ+ zN0MZ$M4ny;nPeglD;EkeH43?ezWTg^lp!uJ&}!RLQYwa`>de}hnHD(Hd1c3zZwQXI z9YEEzF>mr}T{6F;AVxu6Pqq_VcL>U4ZroNUPF13Fn=csEU`a+ol=-_URS2Yqt#?Bu zv3$2@u)WWDyHeS)yuX0EGI>~*!4*$5#WU7dV^GyKGFljybZ6Gf_hbvSPI|H#vq&rk z*ft0a*)RCa^1vim9C&1DHH55GohwjIJ1drAcaY*%c*p{`)@M>AtBT`8rJ9?)k?gJ# z?*T&b-`IXSz?nG}Kv5#E(Q{1H1kn(fbM?&P)6S|2&=pt^QJ zyvK9f^W+%rPX^X_SUQ`%onv0UP|EDeU~{dr;+?(zGWAo2b2pDce~ftTC2O9ninU{G zdp;#H!&!wNI`@(zSXaazw?(iuvsb}C7SCf#1OW{-q9kp1j!FPC)c}u4$rjQFgOrsl z{Y&a9m>$ffU=5{`B2QTnmRokW7GjhTWzV{NcXB+xCGYikyDfEfz3P0{@7e?V-Rpt8 z@VSHa!}3|*ieZ1bv37WFwRV!8E46h%ZIqkWGC^HxjR1nsksRFN5lJa8FICDiSVJ%< zxtqZmASTDH%4E%MuQ0fy58Df=;y1*o}Gxtt&N3Lgs`$sW*y^h<*szWx_NG31tl5dkGh9u0N|ABsvU_ z*?vmTTy6G2_cDxjFb1))E&%y`9{4@LkMVRhkA?A36<-86pq$)gl&vD5Pp$xMra`h0 z6n=n9lL9s=MF+Kcw57rY%vU3RVW6HAajyxtxb<;s8&+If$~Ztv{&C1EXg;Z`=wejb zO)2T#T*w1`k4jvP3XXfLQN>SC@PKRU0fL!;y^4LJKS+FF5(NF;!3<6AW4f}cs+aq% zOfiJEb!*ezCsQYEK_@Dou}lZAx|G}nlfoW4cp(BO8NxUt{^~23lL&u}Bm-QRm3@vC z5Q9PCu#=}KK{+s7TJFhdRxl-bHd_EA$o3$(^ATG??8M4Bk()vb$X8`uux43?Xx_M3 zN1BmLT8nri!KH-?839<%?#3oL4o}+7F?iKV=21xHyz0y*G9|;+*zYQf6NVftPJLpd z1ZPGQ?INM`ssLj?ud7q!Le?ZlC`oyLw+(jR=~=G&#n+G*L$au$_$8HVmMHf_zgTtscw7>xxl>@eejlt*hxGL4%rn1 ztsa<3d+4gnY%j|VJiwYvX}>72FXjMZ7E3E;}W5D#A%l{gB;k6AS4C?iv{ zKuiX}HVkbtNS^8(-*Pe4u$>4_uX6V6r3@Wa9h8;&ma6FTOWzC`M#8Jo1BSZdwLQE6`d^TChx4*fCwf4!dD4o&A=4c)Q>s z*H*0YxAbl8=~%b9w9_%^{%%Z{}Y6L;$!qsC8%h`+23a)s&$HouMiHsI253+kha8cot9R&o2Co=wnt=j?=%jQT>~c#cCw?}%D0G#QYB6UZa0hf}$1+2e z`P%jiWM7JtuVj(n!4EJSm`WVVl)8Gyo_k*l90d(GG@EdCRl*w#B*KF`YHi(V=Pz#Jc1cl=q~tZ zc4`4eDS!d|$9xqh*|WuV9yD@6m%xz?p_plAG|p_WWc^l_Kmcb7G=F*04VD|+;f*A% zEp5H@Ih<|us?xa&51t{bNp@;_^O&FnDR<&4ptv$i6M@ntAXc_j9xRf-L;52-Pm^t_ zW}smQAz4_x6+~x6%_csbnP+O+KJr?xlyMNDDe0d84cL6Te7%J`4!f}96ROCODp-qI zT%$qmVV++3mAQKNSjiNu?{ApGO2usyU>h{(3$hMpU{5lD8Eu)e+p0`xl=4-&F`F-- z2{n|VL0$#&$}5W`FJEk8?9)%tiB&-jyp4Wh0nRwAD>5~=S7e&Y0lHluJV&E&QPIOX zGLpppu)LUZiJA@ejP(;)^H(U%n_ne~mKert@+qG3VlHJ)?ou7m#uaPHa-w1IYEG`? z;wlafp>RBH|PSW<^i%;ebC*_KV8VxzfgN&@cm=I7(0V$CH@Z2oIOp+LnVU4+x z(5iGD!otLSt!_)Fk^v`25PH@OpI3OU_2iaj0w0RL?E=58XD?jJNnR$IhQBQD<>2ou z;4UM$9jDmsgL3MZuxI()B4smJAB3u876$FXz)5M@!7Hr(fS z1MM{Q8C^eX`J~hII3fodJSJw3R!K=(#p z|7Kh_Q3Hcz#_zz8)tFWr8$ag&9Fi%n_kn`GLZjUoT5oZoiStLv*`$cvyuQ}M^^dZ$ zYYg5Vg`G`?`z0?w3f&?NQhB(*Gu)O3j^|T(ob`8l+s3wcWvK0k)K%WNJ-@{68ux>9 z_+}#d;oUWrgI~HMIhOZSipP=K8bB!(ox+Vs?Hz<}<2mG@RP;i;lj7htEGBLOnMHwm z4mKmydnzfXA4)T**J#H_n@N1Aji<+mWbza z$?F)&dc+az;5^+)E}O<-E4XHm=M?62(uYtFw8v1#XV-uapksX>jT7GA zEBM11m%w;Okm0L~v5JPq21DD8j3zSy`27w?$8)^URoxln%Mf3UsgHc^@ z35k)-R2RUpk{s{DjgIP~{!}3y(p9IImpx8dcScBdrjpw;*pyN0$^zTY_2qZ1^We|m zfgT(a`X;Kq2tfS8fs%ts!YhstkCGuCRhVeWJ(9}%-I<20hN5k$G z|Kc(JP+lt2g~KwsvY677VFi6+-L~|7eFjZCYnoxY3%rpVzA-?#_9#sO8o%o#*xz zGGxB?zSmdv)`Bh{sU5Xb@PQkGLq zYeSUgx4|erSeHPL00%)2UjdGs_|yR>s7}Fz=2>8Z^vA5kXg6tU&b68|IA1(%z+Iyr zGKKV^?Ls)hc?F3c1i5=ePDC1#UmVE^j%&+gFxa{f)0z)*DmgS%e$R&)fjd6I{e!>u zIQ|BsKbcNI^XJN`;iF0jLB|IvD=s9NrhPEd+F!!$+z*!S(b6a%mmDS z3OKntoy3JHK5+jo7nk(%QS6Qm8XqfmwOgsvJ67l&-ki(?@6V%)@_Y92(Nx71d$2iH zN#>UK`Kj2Alb=Ca$QNi{yEbN1NNm92JBrK@hl$T60Ke5naCfSR1?co{H+q<+3>8 z9P+(amaO1QvOo_mi9s9tmkRUt6rB+84#Q{`c8JZy(4~dO3SiOd(?b8u#v9_d*aE$) z1a5I`hY0ZpuyNlD+JJt$xH@TDa2*L3pDY0iNK4rQ*uF}Z1|h^*aPq)}mM4UTo`d16wYT9Og)Y$>XMwc*(U?nO zut}dpmxWTSQZ_Q$h)G@ZZ@@poL;BbfcD=t4EH8Cee*cNheJ&6Zn)OHzij{c_yK)m96z28+@!NM!KEr5rY4x_}q>d=&fDj5_z-6)^R9 zXKiRm#EPV?-36n|Z%Fjft}zG7d}O*myB>$p{z5?qwhDYIRxV(&`tU%AP@U}`B3Z{M z8*3AvR%-PDRDkt6bASL6+{7HhBy}W~k`al<@xRudw30jXuqeeoVoPh}Z=$Zic1XV8 zOsAI*4aG0Dpr)t=n2pPGN`r`FMISDspFEs&W}hVHtuR38VCop9BJQmMGOZ*E+|iI{ zb71Qa8>pZ`^ouA8%KB8@X4_mMy|A#}s)FgYat%5bLhn(?kxpQp$p+0_unC^Z2hQjN zrjvhg4=W57GLcK;h-9(|U+0bG#EV#>oxci8+u8wt4=bIZJG%)ElGKVIb1K8(P;8W% zS^eN_yJop$xJdnPjZzoGq(D_jeH;x3*%RM~#IjV_fJqF5+hplvOmk=H(JWF;tGwDU zCj4ec4=_wfmTp9xh~&k>W*P+N8n5y`0vOwe;Kw}B!Gr4MPj+eeN5~3ahZ`N^rU~E z;CP7)pp!4@#C#2_6(E+_*CGjdk}jMDyA(Suf>Uw6CBs`=j4_)C=Ru%ge+uV^>d%&d zv^7NF+6UE@*_Fb52|0IMS$)>IYTLlTIcBr%<>ZU(V6Y+InzvbOT6WC2Qu7pbfPZw# z?)ZIl0E%vOeW?eJfjJ&s8FrA$b}+!TPk>$8D~n~{Rtey-AG_oB9ot6E9U8)K_!<~W zc11Y=dO$P0`5F$yg`CjlWhF{lcGTv?7Ftl-y(CK_&kcpOU*u$@;`G1@f4ib7^o)rD z4lcRc*qN1uS|DQq;FQLmfK`3FQ1%R^6EHDQ>@LMW1Z?jd&pjStSeG%7%o|TPpRTj4{H{-RL6Nh zGH;HS1UY*7ioq_=x``|t%v)zc{y=7#1E@07jjynYo3FRBf8*T`W`*A;g&g;CxY)w) zj%kmSfSw&S?tXT5ygHgI0y;|k9zjbR;EyKp78)KPu*bmj8gEAuU$Wx&a>#*YI}jQ` zeefMhnYD(D0>pjy3@#f%A>c(9=K88n>yl3M)umq;fE3%$!7K*ht|dZ&6ZC!s z+9Wca*|BW_i_tfby&+h3=Id#kXE!WA(H`2#BXhT=v-nB4fY^kaN{)}SO}PNRo;L=S znvbi|cr#)i?+VP~{fXUpuizlw&YHzL6Y&GgT_bqTz-gW=<;Cz$wdq^LP&f$`Y z>4+9O-uz?DObr~XKT;_NdXO&LFm4XBBs+kc@EO58)8;vb8l)Vlv=cC=BsBzlZ$yn8 z+N6M)6k6!^swsi`y?FM}r&`)CW3UHYpu?!lw|yot3j0k01LMfmrD)}a^{pw&wi(p* z@N!Q=W+}}dR;irJvDsQBEtIxrE*NqR>31UiSy;;H&{vwLy7c(-&`UFAc%Pgwj1O0j zUQ>gBCX0Czq7kHoSKKNem$C`FdS4>wj z9aa5aDI*pMjM>u2TC|W43BQxZ;zpMM}tw)XdBpIV-k4HLI)tyaq#&l&1BX{*p5-G1`@*-X%jTs= z4@!PtHgW!xVV2LVJh8k)O|=`NmiOo^wj7~bo&Zc;U4VN#dc(JrgcpVpYk6+R3gdzD zan)I2bu`R4T#(gG^{pljbO5;|Gbd)r&(6pW-4YK%%u@YajVGbuQtIjo>Wg(WBGj0TU9BPBeCZO!gAIJ8mHuZ!o zgm%EB$K$)?HJcHQ6lAvKY>X7vR?X`JgjAjkgELkg9cZ7yd#8z!6T?j9=uU4nIsQ}7 zPQ0sf2s=Tah)JxtBqmR7yG@8dGF4BIvY8X~TWYe{scM2Hs!&Ru>RULFUrX7-mlEZs zp_SlOx_;s&jbF=qWPM`V@(cMwFHCY(xv3Px6iMB3P&g57Zm}JCi+xwtp~2)^u9mW@ ziAdvu<5X03y}+>@5K-W0P7T(eNlAs86exW`N;_EdQA|)zVHfPfayyL|zXx^AW*Ju- za+MGhbp=31gG#TjVWhL*`7pIWtWtPyLp%sksR>~Dm^fPx>~NheM;h-DpK*m!$!_$g zt#Gc$9q3=1P>axyU&6KG6WW&v)m&a_@;TS{pdZrLs%|UPMrEw>ajN^PG`onsVf07N z2*X0v_$O=CO8&4$Ip{ndM(41aL23on-tp)?9nYxU|J5T;!)dLRvjY~2iA#Y-YG(@i zYHeYeRoe!djGD=^(0!UENlvXbX?ZU~FV?297G?}T08qV0X$LvF@cQR2wHdGV*EWo0 z_81lynU5r{WIc|jEzGb!TIjH>rgVGAG}4mFwIDAOrlL2>*dV=weGk=u`s zsqJxF57VdYv)b6-duzm34@;AtN}_!78zj$~E8HO9{yFOSsw5AxaqG` z{IkZKW}CS5aAIR=$xhO1+eI@0iAU*AEutkD<4#B~Vuys+jsudGCJIiQprDLeL5>B{o9qZ&~9@zcB~OxxkxX==0;nG+-_Rhhm9IOZ{me> z*U*p(VcbY9rjlXytToodXIcrZrA7EC>N1W%z99b`+eHxGgQa2RxPboBFx#{pD>rPu z#He)~>6JXKb-N)9E0(`Gk8sR{!>eZX+zhpGE zh2#9y>2*4VwS~;W1x%&(mgB=iAM_T?b(p3*qmx$TdN`)kl2Lv`~G2ZCe@UMK-u;JFzXAZ{G*^WC>^% ztxv2BqQ+PQwxR~MwzXQ=i5wc0G`YxbVR}j=_cg?d=APr@u@Z7Cv#VQ%^I5s&q9$$# zTbuN#YlTns&&ldF8a@TzQY0R zIBU>UvsL9zL`^)-)f%ox%Lx%H+e>Q(3+}b4#Yq~jmg$)#%-Z%hV{EB6H@=mx*B0e; z1{iLNbbK2fmIZ_3!;<7g*f<+!?rZH;kWMSY#XEQoXN7{X>7 zsPCxLwEhpPsglzz>o9y*t}3eo^oE?!a0Td9WDlRz`FfR>x2+V>cpJBw;J$cfo4YU1D)OxDUMu9%>AIc(MU zV{n3*M@^!W_TlvQeYK1M3oU}4IJII>^dF@)7aDu9GKymin6W5XxCHr3j-nJ(OG()* z^2Z@LH7?0#Jd-ScE^9Thm*O($4)D7n+XXwaPQM@%#VRI2B|}iPQ;;%6y9lWehky>2 zTk#zfcRbqS62WQw_4b6E=wll#o~^4LP;*_)o)ww=Gf<9ucvB%M(pj01i zIeUC*387Ce$Rl=Si>$No8@%V>S9j^g*Y=G*chLm6MlD8}bMYDwhsUBml26>sr`+>T z4Y^5sp*C(s4(VzjHMi@8Jh{gx*>+VN#u zYZ>Jh`IZ}YI~p&Ak#9BD$fKOMZv==0Tulz+DTVLX9>x=QK_}Gy z`u@@`$+xP>+4OX*L8t{w@Z6#LV4gcZp1M|YIxQ+qEr0cqSN*dawKRct+U8<=ylPI` zkZ*G0bLo?L^8~mbIpkjLT(CV`Y>~5qLXi0yXWYee{9&}_y5R~{7j6K=EHAg;C=J4- ze)&pOT^g3k^CWUFThpZR$D@;k&su75UqZ=(%PaBedLa(j3-?5t*L7QZr?>+mHK--j zL@_9rtHsbZ5oY1T_@HW|hUO8$+>DS0s=dufz^Ml+^LtQlw^G-H_pTX&3QrryB=HcC zPXt?svlf-s?aXskvidmeM#8~OC1Y(Gk-S_Qv?#g7F5r|^t>uy>Ny||@9Yp?&wTsps zf~XCDc|Ue8b{25IcJu+ppl&W;#@dk7!q=*m%C-T=`|fav`hXoWErq~z$0|J73daDi z6%kWpM=rW{&{V5T3%yzxCc3Qacn5GztuBIR8P#pLACOCk^R)_6)3fB6Td38kz3)4H zKPs!s%0))`QnZVnT*f0>@|S;&MUSj)58r`L3|b?PqRYam2Kt1<^p&qp^hjZ0mmp_O z%IeK0=S~{=%9Pk;ZaK7lfw5GpR`2@8pH}DUH2t&yJ&`V2#1F|G0(Ekjr`ERMdhv}L z+afqZ4CVw)2K;^R7jGPS?&fdx-0_P|UvOW(=igPsC$GNzl6mKS|HcOI>B5ot4_;T_ zaL?+2>s!8l((?L~qZ40qS{37`5jTAJ=3my2-}J}(+&Z_Wu4Uqun!4!3%?xgv5mQcG z%yIDC6suu`OczyZV+tt=Z$>4z29;bqqKNfbV}aCQc=L<}%EdEs-MWbGZ(n`PMSuGu zGj$xDxP3-lw6g~NcGhx4glM|IK87T^Kr1}C4UF!NPTZ?|*? zaqc?^`2lp+P>Zf3XfnfzU?f+Mc(WUc)dptb))9aP*R5+~!-EVCF*wZnZ5UJlIjjdf zEDwkD10$5TVe)R90C8BtLl}GxyFgRSWR9-=km>Ic;wr)iK=r7Jk7zV}y=CGtLftkO zZ8&ygY({kA2_&KuPqyj2CvJ1#ZK|eny z6M3#7=0-0-_XasWf*-Y*KBDU%oh9@?8Ua+l(OJ(6N$-~_{{)aUNa{Hb(q`uRM?5q{ zK!FBncM=ox+vcMSnI$pT#%Vdxq61vDMHfi8j#Mw!M%SSTF_Fcn4ecdHdjgKE`EA6I zB-krP;zOhj(CP#-O{@8+9MRcKvO4<3boQ}diK7#LdRGHFPI!?S=@F0V&1T~f0+6LjT(;70&97wcR_=W@}_WykYm)VWB=2=k=L zyc!Cm8i#?)UCq z5_8;!IvKlFodjMnNiD>`Y#6Fp1R1uuQ z|7M;4d?|GlDK;w3GzoS?%~gDv=Iocr3Y&{ejDU3txma9y5)e~d_5<1$zel{^!%3upucX6wPi@9W3K=(RYEG1WPnU4|Z5d;%Orgk!QlZI(zHihjNIwa4Uh=VoLIf6Ww6o>^8dzYkv&ro8@UXLD)M=L8zgG9xEEEW_u|c{ z2Y#Tsix$PwDBjXSSy~(kfYT78Sh&s6__PK`n^*-<5G*7Y6mJit_lqdJ9lc-(6j8fI zi~Du7SR)gBd7B7IBn}}h7-m|)xm$Vw7a!8y-WwP~()$}0Shz@leZ=blQUAq*(P9($ zxutl>CJrOP3J0a{gMbF$92EK-eBFPoHOsMDiqB7cP@M@OKB3gRA;;?|(eb>wFTPmS zfQqcneL@$g)FPvEq3n3DTPR_4^Sc%js zP{E@m5)lEkuVr!}^ClO`&ui=cKJYQt`8L(<_h%svj@HlyBgS=?4r??l^b z5lrj{Ku+6iX2Tq+pFw#C-osc9!^ur2)z=`@*(i3~m;p=T7T`N=J8 zI&oxH{R|iv`ai9kiMuhK30i8=iK7&Ah=gS)jy4dO$t%Q;Jc>CdA@#VLPyr9_e6gwU zfMrK>i1{2VI`O>j=XoF&Pq5QPWbZ?=DOTGSX_*{}PVQ_2!ef|bbdvH1jT##3Yvywa zM<>T&<#6nA)Mz738tO3|%^q2S=ywJtN7QjZjC`c6ewHAB1}XY@ROI@-C_sXk1+euq ztg@=*Qb;t^!*ZM46m1eT9BuHY(ICj4ys569lcLp&NR#HM*n5+ZClh}pa8V>>5kHTV z5bt?F6`3hSgGRXrjj`O#EvT|IWmJ&~Z_j z=Wm&qX3L8Ml!L`mPC7j-ZIT6nYLLG3kyTOGWlRzc%sjO#BBOV@lE+hSa^%-XRK$H-Lg}#0dLIkk1PH$=k>b zFf2fu{epHTpx3m8Gx=z9eJzXk3$6D@=h`|)C?V#~gtDRtnm7U`V}vCvtD=GRic6!D z&k5C*&PF%#NX{Xj3uT{YI8`el*bQp}JmYfz9i2LvoL<~2N^eTrprpY)UfZQP*+#cM^bq{VkEEC%g z%{=qu=#;jq1dhcbH+~aAwlTKYqE)pzjrFxHQ%f=4)Z%DUvtR;ss2eAKBXgMCt2dkb zC^oP&2CgK94q&i=%{jwOh8Rc`w}3x5c7%MxxDnHwitApb`cxO51+D}{A#iWX^vYfg zGDqNvpk4+Xz?}nT!kz`g_!T)ekvp|PBX^5|V`^)yg4KpHb{v5Qq5u^61_397CRufI zZ_CsbOiZOvPD2gPT7V(}O#&e^maku=2jw(?CV(BC>VlxyYNm+120sZRB{3#OpU>Lt zCtAb^$>@{^IZO--+eiwe)cswNiVFnGleY~AB#6ojA<*7qIjyv|3zAX zuxe@YL9$O3=Ue~44cLLULEkiSMcja*o1#;Dp?wHCtTiZKL{t*c;>Kze)E5~Ru~mnG zJGmG2VMo()1jN^oBQf#YxLAwlM2joY2b9g;2sc8Ld$AD2u7v?MxmT>osoS;Z2G2$# zBOg=0T`C}PcXaYLt2c@piO^zyNnuRwKdZh8=3A75^vg<`P9s3EOx;aRg)P`pJd6h* zPp2`TmMQ83JQA@jQwPX-4GrSiX_-1GHKC98i3oWOH3dh5jGRL7_XJGQK9Uy*7})1JxII&Aw@ zD=a#%{hapQsmzjdSHyDq=eCtP+fiqkmrV6^^~XxTYad(OzNG!!*l;!%Yi9x4D%Iks zMqSyw2}Uh(6kY&i-hv!E_ndRiU4&p+EVRphyc-G*`xq~E;pN{uyx4lYK{%85&W@Q^ zAIHw+FfVu18MXtj5c6Lq6kF21IF>gr$5a~}wa$M{O$;x|jo}@)cx`Y#R@jjLb2 z=B8;MOJzz>;7t@;VcTc%AmmI}whDxtrk)K7#3ugb9dqEHDvgHsH z*CBhrfj!>Y_o{E#KUR3%GwW|W<;*)ib6W4O*kEw^FEK3wQ7*?j;4)WT zzKy@)a5ccuzE9=9K{laFU)CCHrM`^4}Fcx0Z6c}SMW={;9i_dwW!ZL(Q zF!tqYKH8D`!LxFIhQawA?}peC;I~~4WA*BKqk0wk=J$Ac)P-My1b#+=KVo1z&YK~N zLh@pOk^FKl?qciIvJm>{Z*6v?Fa0H*-RPTNPL1J+l80S9#^m4YRa+ShnyYzG$RlC4 zAm=H$;>bfceV>Ql04EiB4(}-*<&|TUFt!UX4+;Ky&78vSO|5_OMf5K#OdH?_b literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.pdb b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.pdb new file mode 100644 index 0000000000000000000000000000000000000000..2b5e34c844f5a0170f609196d19153744525dc0b GIT binary patch literal 286208 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.xml b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.xml new file mode 100644 index 00000000..53b56aea --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate31.xml @@ -0,0 +1,6711 @@ + + + + Spring.Data.NHibernate31 + + + + + Holds the references and configuration settings for a instance. + References are resolved by looking up the given object names in the root obtained by . + + + + + Holds the references and configuration settings for a instance. + + + + + Default value for property. + + + + + Default value for property. + + + + + Initialize a new instance of with default values. + + + Calling this constructor from your derived class leaves and + uninitialized. See and for more. + + + + + Initialize a new instance of with the given sessionFactory + and default values for all other settings. + + + The instance to be used for obtaining instances. + + + Calling this constructor marks all properties initialized. + + + + + Initialize a new instance of with the given values and references. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by the instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by the instance. + + + Calling this constructor marks all properties initialized. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Gets the configured instance to be used. + + + If the entity interceptor is not set by the constructor, this property calls + to obtain an instance. This allows derived classes to + override the behaviour of how to obtain the concrete instance. + + + + + Gets the configured instance to be used. + + + If this property is requested for the first time, is called. + This allows derived classes to override the behaviour of how to obtain the concrete instance. + + If the instance cannot be resolved. + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets or Sets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + The default session factory name to use when retrieving the Hibernate session factory from + the root context. + + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The configuration section to read setting variables from. + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The variable source to obtain settings from. + + + + Resolve the entityInterceptor by looking up + in the root application context. + + The resolved instance or + + + + Resolve the by looking up + in the root application context. + + The resolved instance or + + + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+
+ + + Check if the hibernate template property has been set. + + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Provide support for the open session in view pattern for lazily loaded hibernate objects + used in ASP.NET pages. + + jjx: http://forum.springframework.net/member.php?u=29 + Mark Pollack (.NET) + Erich Eichinger + Harald Radi + + + + Implementation of SessionScope that associates a single session within the using scope. + + + It is recommended to be used in the following type of scenario: + + using (new SessionScope()) + { + ... do multiple operation, possibly in multiple transactions. + } + + At the end of "using", the session is automatically closed. All transactions within the scope use the same session, + if you are using Spring's HibernateTemplate or using Spring's implementation of NHibernate 1.2's + ICurrentSessionContext interface. + + + It is assumed that the session factory object name is called "SessionFactory". In case that you named the object + in different way you can specify your can specify it in the application settings using the key + Spring.Data.NHibernate.Support.SessionScope.SessionFactoryObjectName. Values for EntityInterceptorObjectName + and SingleSessionMode can be specified similarly. + + + Note: + The session is managed on a per thread basis on the thread that opens the scope instance. This means that you must + never pass a reference to a instance over to another thread! + + + Robert M. (.NET) + Harald Radi (.NET) + + + + The logging instance. + + + + + Initializes a new instance of the class in single session mode, + associating a session with the thread. The session is opened lazily on demand. + + + + + Initializes a new instance of the class. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + The type, who's full name is used for prefixing appSetting keys + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by this instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by this instance. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + An instance holding the scope configuration + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Sets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets/Sets a flag, whether this scope manages it's own session for the current logical thread or not. + + false if session is managed by this module. false otherwise + + + + Call Close(), + + + + + Opens a new session or participates in an existing session and + registers with spring's . + + + + + Close the current view's session and unregisters + from spring's . + + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + Get or set the configured SessionFactory + + + + + Get or set the configured EntityInterceptor + + + + + Gets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets a flag, whether this scope manages it's own session for the current logical thread or not. + + + + + This sessionHolder creates a default session only if it is needed. + + + Although a NHibernateSession deferes creation of db-connections until they are really + needed, instantiation a session is imho still more expensive than this LazySessionHolder. (EE) + + + + + Session holder, wrapping a NHibernate ISession and a NHibernate Transaction. + HibernateTransactionManager binds instances of this class + to the thread, for a given ISessionFactory. + + + Note: This is an SPI class, not intended to be used by applications. + + Mark Pollack (.NET) + + + + May be used by derived classes to create an empty SessionHolder. + + + When using this ctor in your derived class, you MUST override ! + + + + + Initializes a new instance of the class. + + The session. + + + + Initializes a new instance of the class. + + The key to store the session under. + The hibernate session. + + + + May be overridden in a derived class to e.g. lazily create a session + + + + + Gets the session given key identifier + + The key. + A hibernate session + + + + Gets the session given the key and removes the session from + the dictionary storage. + + The key. + A hibernate session + + + + Adds the session to the dictionary storage using the default key. + + The hibernate session. + + + + Adds the session to the dictionary storage using the supplied key. + + The key. + The hibernate session. + + + + Removes the session from the dictionary storage for the given key. + + The key. + The session that was previously contained in the + dictionary storage. + + + + Determines whether the holder the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Clear the transaction state of this resource holder. + + + + + Gets the session using the default key + + The hibernate session. + + + + Gets the first session based on iteration over + the IDictionary storage. + + Any hibernate session. + + + + Gets a value indicating whether dictionary of + hibernate sessions is empty. + + + true if this session holder is empty; otherwise, false. + + + + + Gets a value indicating whether this SessionHolder + does not hold non default session. + + + true if does not hold non default session; otherwise, false. + + + + + Gets or sets the hibernate transaction. + + The transaction. + + + + Gets or sets the ADO.NET Connection used to create the session. + + The ADO.NET connection. + + + + Gets or sets the previous flush mode. + + The previous flush mode. + + + + Gets a value indicating whether the PreviousFlushMode property + was set. + + + true if assigned PreviousFlushMode property; otherwise, false. + + + + + Gets the validated session. + + The validated session. + + + + Initialize a new instance. + + + + + Create a new session on demand + + + + + Ensure session is closed (if any) and remove circular references to avoid memory leaks! + + + + + Initializes a new instance of the class. Creates a SessionScope, + but does not yet associate a session with a thread, that is left to the lifecycle of the request. + + + + + Register context handler and look up SessionFactoryObjectName under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SessionFactoryObjectName if not using the default value + (i.e. sessionFactory) and look up the SingleSession setting under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SingleSession if not using the default value of true. + + The standard HTTP application context + + + + A do nothing dispose method. + + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for ADO.NET exceptions that Hibernate rethrew and could not be + mapped into the DAO exception heirarchy. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API - ADO.NET + + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Hibernate-specific subclass of InvalidDataAccessResourceUsageException, + thrown on invalid HQL query syntax. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateQueryException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets the query string that was invalid. + + The query string that was invalid. + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for Hibernate system errors that do not match any concrete + Spring.Dao exceptions. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute supporting Hibernate access code + implementing the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Mark Pollack (.NET) +
+ + + Base class for HibernateTemplate defining common + properties like SessionFactory and flushing behavior. + + +

Not intended to be used directly. See HibernateTemplate. +

+
+ Mark Pollack (.NET) +
+ + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Apply the flush mode that's been specified for this accessor + to the given Session. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + the previous flush mode to restore after the operation, + or null if none + + + + + Flush the given Hibernate Session if necessary. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + + + Note that a direct SQLException can just occur when callback code + performs direct ADO.NET access via ISession.Connection(). + + + The ADO.NET exception. + The corresponding DataAccessException instance + + + + Prepare the given IQuery object, applying cache settings and/or + a transaction timeout. + + The query object to prepare. + + + + Apply the given name parameter to the given Query object. + + The query object. + Name of the parameter + The value of the parameter + The NHibernate type of the parameter (or null if none specified) + + + + Prepare the given Criteria object, applying cache settings and/or + a transaction timeout. + + + Note that for NHibernate 1.2 this only works if the + implementation is of the type CriteriaImpl, which should generally + be the case. The SetFetchSize method is not available on the + ICriteria interface + + This is a no-op for NHibernate 1.0.x since + the SetFetchSize method is not on the ICriteria interface and + the implementation class is has internal access. + + To remove the method completely for Spring's NHibernate 1.0 + support while reusing code for NHibernate 1.2 would not be + possible. So now this ineffectual operation is left in tact for + NHibernate 1.0.2 support. + + The criteria object to prepare + + + + Ensure SessionFactory is not null + + If SessionFactory property is null. + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance. + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets a Session for use by this template. + + The session. + + - Returns a new Session in case of "alwaysUseNewSession" (using the same ADO.NET connection as a transaction Session, if applicable) + - a pre-bound Session in case of "AllowCreate" is set to false (not the default) + - or a pre-bound Session or new Session if no transactional or other pre-bound Session exists. + + + + + Helper class to determine if the FlushMode enumeration + was changed from its default value + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The flush mode. + + + + Gets or sets a value indicating whether the FlushMode + property was set.. + + true if FlushMode was set; otherwise, false. + + + + Gets or sets the FlushMode. + + The FlushMode. + + + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Mark Pollack (.NET) +
+ + + Interface that specifies a set of Hibernate operations that + are common across versions of Hibernate. + + + Base interface for generic and non generic IHibernateOperations interfaces + Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ Mark Pollack (.NET) + +
+ + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + Tthe persistent instance to delete. + The lock mode to obtain. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + a persistent type. + An identifier of the persistent instance. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + A persistent class. + An identifier of the persistent instance. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The default for creating a new non-transactional + session when no transactional Session can be found for the current thread + is set to true. + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional when no transactional Session can be found + for the current thread. + + + + Delegate function that clears the session. + + The hibernate session. + null + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + The type. + An identifier of the persistent instance. + The persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The type. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + If length for argument values and types are not equal. + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + + + + Execute the action specified by the given action object within a Session. + + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Create a close-suppressing proxy for the given Hibernate Session. + The proxy also prepares returned Query and Criteria objects. + + The session. + The session proxy. + + + + Check whether write operations are allowed on the given Session. + + + Default implementation throws an InvalidDataAccessApiUsageException + in case of FlushMode.Never. Can be overridden in subclasses. + + The current Hibernate session. + If write operation is attempted in read-only mode + + + + + Compares if the flush mode enumerations, Spring's + TemplateFlushMode and NHibernates FlushMode have equal + settings. + + The template flush mode. + The NHibernate flush mode. + + Returns true if both are Never, Auto, or Commit, false + otherwise. + + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. + If object factory is not set and need to retrieve entity interceptor by name. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets whether to check that the Hibernate Session is not in read-only mode + in case of write operations (save/update/delete). + + + true if check that the Hibernate Session is not in read-only mode + in case of write operations; otherwise, false. + + + Default is "true", for fail-fast behavior when attempting write operations + within a read-only transaction. Turn this off to allow save/update/delete + on a Session with flush mode NEVER. + + + + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Set the object factory instance. + + The object factory instance + + + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Callback interface for NHibernate code. + + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object, or null if none. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Enumeration for the various Hibernate flush modes. + + Mark Pollack (.NET) + + + Never flush is a good strategy for read-only units of work. + + + Hibernate will not track and look for changes in this case, + avoiding any overhead of modification detection. +

In case of an existing ISession, TemplateFlushMode.Never will turn + the hibenrate flush mode + to FlushMode.Never for the scope of the current operation, resetting the previous + flush mode afterwards. +

+
+
+ + Automatic flushing is the default mode for a Hibernate Session. + + + A session will get flushed on transaction commit, and on certain find + operations that might involve already modified instances, but not + after each unit of work like with eager flushing. +

In case of an existing Session, TemplateFlushMode.Auto + will participate in the existing flush mode, not modifying + it for the current operation. + This in particular means that this setting will not modify an existing + hibernate flush mode FlushMode.Never, in contrast to TemplateFlushMode.Eager. +

+
+
+ + + Eager flushing leads to immediate synchronization with the database, + even if in a transaction. + + + This causes inconsistencies to show up and throw + a respective exception immediately, and ADO access code that participates + in the same transaction will see the changes as the database is already + aware of them then. But the drawbacks are: +
    +
  • additional communication roundtrips with the database, instead of a + single batch at transaction commit;
  • +
  • the fact that an actual database rollback is needed if the Hibernate + transaction rolls back (due to already submitted SQL statements).
  • +
+

In case of an existing Session, TemplateFlushMode.Eager + will turn the NHibernate flush mode + to FlushMode.Auto for the scope of the current operation and issue a flush at the + end, resetting the previous flush mode afterwards. +

+
+
+ + + Flushing at commit only is intended for units of work where no + intermediate flushing is desired, not even for find operations + that might involve already modified instances. + + +

In case of an existing Session, TemplateFlushMode.Commit + will turn the NHibernate flush mode + to FlushMode.Commit for the scope of the current operation, resetting the previous + flush mode afterwards. The only exception is an existing flush mode + FlushMode.Never, which will not be modified through this setting. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning an IList of result objects created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+ The new HibernateTemplate instance +
+ + + Check if the hibernate template property has been set. + + If HibernateTemplate property is null. + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning the result object created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Generic version of the Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute() supporting Hibernate access code which + implements the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as a direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Return the persistent instance of the given entity type + with the given identifier, or if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lenths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Allows creation of a new non-transactional session when no + transactional Session can be found for the current thread + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional session when no transactional Session can be found + for the current thread. + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets the classic hibernate template for access to non-generic methods. + + The classic hibernate template. + + + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Callback interface (Generic version) for NHibernate code. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + + Sree Nivask (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object. + The active Hibernate session +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Callback interface (Generic version) for NHibernate code that + returns a List of objects. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ Collection result object. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Helper class featuring methods for Hibernate Session handling, + allowing for reuse of Hibernate Session instances within transactions. + Also provides support for exception translation. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + The ordering value for synchronizaiton this session resources. + Set to be lower than ADO.NET synchronization. + + + + + Initializes a new instance of the class. + + + + + Get a new Hibernate Session from the given SessionFactory. + Will return a new Session even if there already is a pre-bound + Session for the given SessionFactory. + + + Within a transaction, this method will create a new Session + that shares the transaction's ADO.NET Connection. More specifically, + it will use the same ADO.NET Connection as the pre-bound Hibernate Session. + + The session factory to create the session with. + The Hibernate entity interceptor, or null if none. + The new session. + If could not open Hibernate session + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using HibernateTransactionManager. Will always create a new + Session otherwise. + + + Supports setting a Session-level Hibernate entity interceptor that allows + to inspect and change property values before writing to and reading from the + database. Such an interceptor can also be set at the SessionFactory level + (i.e. on LocalSessionFactoryObject), on HibernateTransactionManager, or on + HibernateInterceptor/HibernateTemplate. + + The session factory to create the + session with. + Hibernate entity interceptor, or null if none. + AdoExceptionTranslator to use for flushing the + Session on transaction synchronization (can be null; only used when actually + registering a transaction synchronization). + The Hibernate Session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using . Will create a new Session + otherwise, if allowCreate is true. + + The session factory to create the session with. + if set to true create a non-transactional Session when no + transactional Session can be found for the current thread. + The hibernate session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. + + Is aware of and will return any existing corresponding + Session bound to the current thread, for example whenusing + . Will create a new + Session otherwise, if "allowCreate" is true. +

Throws the orginal HibernateException, in contrast to + . +

+ The session factory. + if set to true [allow create]. + The Hibernate Session + + if the Session couldn't be created + + + If no thread-bound Session found and allowCreate is false. + +
+ + + Open a new Session from the factory. + + The session factory to create the session with. + Hibernate entity interceptor, or null if none. + the newly opened session + + + + Perform the actual closing of the Hibernate Session + catching and logging any cleanup exceptions thrown. + + The hibernate session to close + + + + Return whether the given Hibernate Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The hibernate session to check + The session factory that the session + was created with, can be null. + + true if the session transactional; otherwise, false. + + + + + Converts a Hibernate ADOException to a Spring DataAccessExcption, extracting the underlying error code from + ADO.NET. Will extract the ADOException Message and SqlString properties and pass them to the translate method + of the provided IAdoExceptionTranslator. + + The IAdoExceptionTranslator, may be a user provided implementation as configured on + HibernateTemplate. + + The ADOException throw + The translated DataAccessException or UncategorizedAdoException in case of an error in translation + itself. + + + + Convert the given HibernateException to an appropriate exception from the + Spring.Dao hierarchy. Note that it is advisable to + handle AdoException specifically by using a AdoExceptionTranslator for the + underlying ADO.NET exception. + + The Hibernate exception that occured. + DataAccessException instance + + + + Close the given Session, created via the given factory, + if it is not managed externally (i.e. not bound to the thread). + + The hibernate session to close + The hibernate SessionFactory that + the session was created with. + + + + Close the given Session or register it for deferred close. + + The session. + The session factory. + + + + Initialize deferred close for the current thread and the given SessionFactory. + Sessions will not be actually closed on close calls then, but rather at a + processDeferredClose call at a finishing point (like request completion). + + The session factory. + + + + Return if deferred close is active for the current thread + and the given SessionFactory. + The session factory. + + true if [is deferred close active] [the specified session factory]; otherwise, false. + + If SessionFactory argument is null. + + + + Process Sessions that have been registered for deferred close + for the given SessionFactory. + + The session factory. + If there is no session factory associated with the thread. + + + + Applies the current transaction timeout, if any, to the given + criteria object + + The Hibernate Criteria object. + Hibernate SessionFactory that the Criteria was created for + (can be null). + If criteria argument is null. + + + + Applies the current transaction timeout, if any, to the given + Hibenrate query object. + + The Hibernate Query object. + Hibernate SessionFactory that the Query was created for + (can be null). + If query argument is null. + + + + Gets the Spring IDbProvider given the ISessionFactory. + + The matching is performed by comparing the assembly qualified + name string of the hibernate Driver.ConnectionType to those in + the DbProviderFactory definitions. No connections are created + in performing this comparison. + The session factory. + The corresponding IDbProvider, null if no mapping was found. + If DbProviderFactory's ApplicaitonContext is not + an instance of IConfigurableApplicaitonContext. + + + + Create a IAdoExceptionTranslator from the given SessionFactory. + + If a corresponding IDbProvider is found, a ErrorcodeExceptionTranslator + for the IDbProvider is created. Otherwise, a FallbackException is created. + The session factory to create the translator for + An IAdoExceptionTranslator + + + + Implementation of NHibernates 1.2's ICurrentSessionContext interface + that delegates to Spring's SessionFactoryUtils for providing a + Spirng-managed current Session. + + Used by Spring's LocalSessionFactoryBean if told to expose + a transaction-aware SessionFactory. +

This ICurrentSessionContext implementation can also be specified in + custom ISessionFactory setup through the + "hibernate.current_session_context_class" property, with the fully + qualified name of this class as value.

+ Juergen Hoeller + Mark Pollack (.NET) + +
+ + + Initializes a new instance of the class + + The NHibernate session factory. + + + + Retrieve the Spring-managed Session for the current thread. + + Current session associated with the thread + On errors retrieving thread bound session. + + + + NHibnerations actions taken during the transaction lifecycle. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Suspend this synchronization. + + +

+ Unbind Hibernate resources (SessionHolder) from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Rebind Hibernate resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + + + If the transaction is defined as a read-only transaction. + + +

+ Can flush transactional sessions to the database. +

+

+ Note that exceptions will get propagated to the commit caller and + cause a rollback of the transaction. +

+
+
+ + + Invoked before transaction commit (before + ) + Can e.g. flush transactional O/R Mapping sessions to the database + + + + This callback does not mean that the transaction will actually be + commited. A rollback decision can still occur after this method + has been called. This callback is rather meant to perform work + that's only relevant if a commit still has a chance + to happen, such as flushing SQL statements to the database. + + + Note that exceptions will get propagated to the commit caller and cause a + rollback of the transaction. + + (note: do not throw TransactionException subclasses here!) + + + + + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+ + + Convenient FactoryObject for defining Hibernate FilterDefinitions. + Exposes a corresponding Hibernate FilterDefinition object. + + + +

+ Typically defined as an inner object within a LocalSessionFactoryObject + definition, as the list element for the "filterDefinitions" object property. + For example: +

+ +
+            <objectn id="sessionFactory" type="Spring.Data.NHibernate.LocalSessionFactoryObject, Spring.Data.NHibernate">
+              ...
+              <property name="FilterDefinitions">
+               <list>
+                  <object type="Spring.Data.NHibernate.FilterDefinitionFactoryObject, Spring.Data.NHibernate">
+                    <property name="FilterName" value="myFilter"/>
+                    <property name="ParameterTypes">
+                      <props>
+                        <prop key="MyParam">string</prop>
+                        <prop key="MyOtherParam">long</prop>
+                      </props>
+                    </property>
+                  </object>
+                </list>
+              </property>
+              ...
+            </object>
+            
+

+ Alternatively, specify an object id (or name) attribute for the inner object, + instead of the "FilterName" property. +

+
+ Juergen Hoeller + Marko Lahma (.NET) + + + $Id: FilterDefiniitionFactoryObject.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ +
+ + + Initializes the filter definitions. + + + + + Returns the singleton filter definition. + + + + + + Set the name of the filter. + + + + + Set the parameter types for the filter, + with parameter names as keys and type names as values. + + + + + + Specify a default filter condition for the filter, if any. + + + + + If no explicit filter name has been specified, the object name of + the FilterDefinitionFactoryObject will be used. + + + + + + Returns the type of the object this factory produces. + + + + + Returns whether this factory produces singletons, always true. + + + + + Hibernate-specific subclass of ObjectRetrievalFailureException. + + + Converts Hibernate's UnresolvableObjectException, ObjectNotFoundException, + ObjectDeletedException, and WrongClassException. + + Mark Pollack (.NET) + $Id: HibernateObjectRetrievalFailureException.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateObjectRetrievalFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Hibernate-specific subclass of ObjectOptimisticLockingFailureException. + + + Converts Hibernate's StaleObjectStateException. + + Mark Pollack (.NET) + $Id: HibernateOptimisticLockingFailureException.cs,v 1.2 2008/04/23 11:41:41 lahma Exp $ + + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The StaleStateException. + + + + Creates a new instance of the HibernateOptimisticLockingFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + An IFactoryObject that creates a local Hibernate SessionFactory instance. + Behaves like a SessionFactory instance when used as bean reference, + e.g. for HibernateTemplate's "SessionFactory" property. + + + The typical usage will be to register this as singleton factory + in an application context and give objects references to application services + that need it. + + Hibernate configuration settings can be set using the IDictionary property 'HibernateProperties'. + + + This class implements the interface, + as autodetected by Spring's + for AOP-based translation of PersistenceExceptionTranslationPostProcessor. + Hence, the presence of e.g. LocalSessionFactoryBean automatically enables + a PersistenceExceptionTranslationPostProcessor to translate Hibernate exceptions. + + + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Return the singleon session factory. + + The singleon session factory. + + + + Initialize the SessionFactory for the given or the + default location. + + + + + Close the SessionFactory on application context shutdown. + + + + + Subclasses can override this method to perform custom initialization + of the Configuration instance used for ISessionFactory creation. + + + The properties of this LocalSessionFactoryObject will be applied to + the Configuration object that gets returned here. +

The default implementation creates a new Configuration instance. + A custom implementation could prepare the instance in a specific way, + or use a custom Configuration subclass. +

+
+ The configuration instance. +
+ + + To be implemented by subclasses that want to to register further mappings + on the Configuration object after this FactoryObject registered its specified + mappings. + + + Invoked before the BuildMappings call, + so that it can still extend and modify the mapping information. + + the current Configuration object + + + + To be implemented by subclasses that want to to perform custom + post-processing of the Configuration object after this FactoryObject + performed its default initialization. + + The current configuration object. + + + + Executes schema update if requested. + + + + + Execute schema drop script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryBean itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfb = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema creation script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema update script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaUpdate class, for automatically executing schema update scripts + on application startup. Can also be invoked manually. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute the given schema script on the given ADO.NET Connection. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override the ExecuteSchemaStatement + method to treat failures differently. + + The connection to use. + The SQL statement to execute. + + + + Execute the given schema SQL on the given ADO.NET command. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override this method to treat failures differently. + + + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + Implementation of the PersistenceExceptionTranslator interface, + as autodetected by Spring's PersistenceExceptionTranslationPostProcessor. + Converts the exception if it is a HibernateException; + else returns null to indicate an unknown exception. + translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + The exception thrown. + + the corresponding DataAccessException (or null if the + exception could not be translated. + + + + + + Convert the given HibernateException to an appropriate exception from the + Spring's DAO Exception hierarchy. + Will automatically apply a specified IAdoExceptionTranslator to a + Hibernate ADOException, else rely on Hibernate's default translation. + + The Hibernate exception that occured. + A corresponding DataAccessException + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Setting the Application Context determines were resources are loaded from + + + + + Gets or sets the to use for loading mapping assemblies etc. + + + + + Sets the assemblies to load that contain mapping files. + + The mapping assemblies. + + + + Sets the hibernate configuration files to load, i.e. hibernate.cfg.xml. + + + + + Sets the locations of Spring IResources that contain mapping + files. + + The location of mapping resources. + + + + Return the Configuration object used to build the SessionFactory. + Allows access to configuration metadata stored there (rarely needed). + + The hibernate configuration. + + + + Set NHibernate configuration properties, like "hibernate.dialect". + + The hibernate properties. + +

Can be used to override values in a NHibernate XML config file, + or to specify all necessary properties locally. +

+

Note: Do not specify a transaction provider here when using + Spring-driven transactions. It is also advisable to omit connection + provider settings and use a Spring-set IDbProvider instead. +

+
+
+ + + Get or set the DataSource to be used by the SessionFactory. + + The db provider. + + If set, this will override corresponding settings in Hibernate properties. + Note: If this is set, the Hibernate settings should not define + a connection string + (hibernate.connection.connection_string) to avoid meaningless double configuration. + + + + + + Gets or sets a value indicating whether to expose a transaction aware session factory. + + + true if want to expose transaction aware session factory; otherwise, false. + + + + + Set a NHibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + Will get applied to any new Session created by this factory. +

Such an interceptor can either be set at the SessionFactory level, i.e. on + LocalSessionFactoryObject, or at the Session level, i.e. on HibernateTemplate, + HibernateInterceptor, and HibernateTransactionManager. It's preferable to set + it on LocalSessionFactoryObject or HibernateTransactionManager to avoid repeated + configuration and guarantee consistent behavior in transactions.

+
+ + +
+ + + Set a Hibernate NamingStrategy for the SessionFactory, determining the + physical column and table names given the info in the mapping document. + + + + + Specify the Hibernate type definitions to register with the SessionFactory, + as Spring IObjectDefinition instances. This is an alternative to specifying + <typedef> elements in Hibernate mapping files. +

Unfortunately, Hibernate itself does not define a complete object that + represents a type definition, hence the need for Spring's TypeDefinitionBean.

+ @see TypeDefinitionBean + @see org.hibernate.cfg.Mappings#addTypeDef(String, String, java.util.Properties) +
+
+ + + Specify the NHibernate FilterDefinitions to register with the SessionFactory. + This is an alternative to specifying <filter-def> elements in + Hibernate mapping files. + + + Typically, the passed-in FilterDefinition objects will have been defined + as Spring FilterDefinitionFactoryBeans, probably as inner beans within the + LocalSessionFactoryObject definition. + + + + + + Specify the cache strategies for entities (persistent classes or named entities). + This configuration setting corresponds to the <class-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="entityCacheStrategies">
+              <props>
+                <prop key="MyCompany.Customer">read-write</prop>
+                <prop key="MyCompany.Product">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the cache strategies for persistent collections (with specific roles). + This configuration setting corresponds to the <collection-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="CollectionCacheStrategies">
+              <props>
+                <prop key="MyCompany.Order.Items">read-write</prop>
+                <prop key="MyCompany.Product.Categories">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the NHibernate event listeners to register, with listener types + as keys and listener objects as values. +

+ Instead of a single listener object, you can also pass in a list + or set of listeners objects as value. +

+
+ listener objects as values + + See the NHibernate documentation for further details on listener types + and associated listener interfaces. + +
+ + + Set whether to execute a schema update after SessionFactory initialization. +

+ For details on how to make schema update scripts work, see the NHibernate + documentation, as this class leverages the same schema update script support + in as NHibernate's own SchemaUpdate tool. +

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Sets custom byte code provider implementation to be used. This corresponds to setting + the property before NHibernate session factory + configuration. + + + + + Return the type or subclass. + + The type created by this factory + + + + Returns true + + true + + + + The Spring for .NET-backed ByteCodeprovider for NHibernate + + Fabio Maulo + + + + Creates a new bytecode Provider instance using the specified object factory + + + + + + Retrieve the delegate for this provider + capable of generating reflection optimization components. + + The class to be reflected upon.All property getters to be accessed via reflection.All property setters to be accessed via reflection. + The reflection optimization delegate. + + + + The specific factory for this provider capable of + generating run-time proxies for lazy-loading purposes. + + + + + NHibernate's object instaciator. + + + For entities and its implementations. + + + + + Instanciator of NHibernate's collections default types. + + + + + + + Fabio Maulo + + + + + + + + + + + + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + + + Fabio Maulo + + + + + + + + + Creates an instance of the specified type. + + The type of object to create. + A reference to the created object. + + + + Creates an instance of the specified type. + + The type of object to create.true if a public or nonpublic default constructor can match; false if only a public default constructor can match. + A reference to the created object + + + + Creates an instance of the specified type using the constructor that best matches the specified parameters. + + The type of object to create.An array of constructor arguments. + A reference to the created object. + + + + A Spring for .NET backed implementation for creating + NHibernate proxies. + + + Erich Eichinger + + + + Creates a new proxy. + + The id value for the proxy to be generated. + The session to which the generated proxy will be associated. + The generated proxy. + Indicates problems generating requested proxy. + + + + Creates a Spring for .NET backed instance. + + Erich Eichinger + + + + Build a proxy factory specifically for handling runtime lazy loading. + + The lazy-load proxy factory. + + + + + + + + + + + + + + + + + + Fabio Maulo + + + + + + + + + + + + Perform instantiation of an instance of the underlying class. + + The new instance. + + + + + + + + + + Delegates to an implementation of ISessionFactory that can select among multiple instances based on + thread local storage. + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + PostProcessConfiguration + + + + + + DelegatingSessionFactory class + + + + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Does the tx scope commit. + + The status. + + + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Does the tx scope rollback. + + The status. + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Does the tx scope set rollback only. + + The status. + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + SimpleDelegatingSessionFactory class + + + + + Connection string config element name + + + + + public Constructor + + + + + + TargetSessionFactory + + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.dll b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.dll new file mode 100644 index 0000000000000000000000000000000000000000..e8e235c7cc01cb61f5973c314fa579b6d09c8403 GIT binary patch literal 92160 zcmeFacYsty);C9z?94l?IX^#AuSHKAC&V6xDIS!Ar@E$@>C%T`TyKgLuM9Y9^~#z ze#o5`(1HHPRffm|{__cj=<8KPw>TQUV7MZOMy2Y2z^20yh3mPUyTrR zo70)}p$KH%prfz>=Hlu58wrCnrw?1?fRS_+(3xx?=I_8an#lgYtH`eSBi*D3h*wv^ zK7SV?%%M4FS`AE;gTLxa=5^nH+db#pH2RALqpJgddARJJ!z;EAdH;&$W9knad_xt~ zKXtDw_L%cwNO{_wP( zo12c=E)#JfBC@0nwc3*LHdJg22t`W>*0bbtWZ7y9vKMBu+EB-=gqmqYT#_gw`KFRzrsP{newmUVP_hfO;QeKml5Gk~Cjy~KnI&bCLYTd!7^y8O zv!rNKAE_luCkkGbNS3nF6i-(p_4sP&U?j?+L#6`GGRf3rSDB>@CF`IWdl10cq5$?p zN|LA~5Rs{*cmvC*Hd*l%l-uM$X{J%?OA-a7;ZSK>nJRE4IuR`HZHYfXPw>a&a?}i~ z4H>ay0s*#}E-(-eZ6gvf(<5Df)Jz}e`t!{6`K~|T%5(v1u_a@c&9a=Xz)E1u3YI8{ z%o9gQCSW?-LCzxyWXncaSSFAk`>X~iJ zF_X_pLoXOqnhuJ~Zey-VQYK1(oCRXXLJW)nqpdy>jNhEcksfdXhqSeW=1T0EST_sZxiy zNEPri*k?~B`FNpT#6nd+*`o5 zWJ@WI!V|U5wdHhetVYwb&qJ;No#B4S{n8*LMQmpe(mco7HQ=eormm+}k|WP{$tX5T zy9Q~aCLwL&mQ=6NiV-IQfa-2L{gDXZDkyvLCq;}6M5{bd^NC)YmXCTV*7?Fn{v=w?A(Jc`>Wrq?&5%6v> zscb4m-~J*3k%G!_E}m#ev3S%kJHN=-LAJ9Sq{RC)Xue@U&hBtv+TnOK*v<$%mQuQT zTMA0@wnTy{JFLSUqPF*2ZsS0e*^5K!y}um=I96fhhEGLx%=dzHpOjc6ztJdpe$rMqk&2y zc8B8j%4FhXmF7T|GgDP#{&dEo!-NpKDIxWz+Lv{0P+Otu~Ov}Usu*s4HYAsD%sSW|5UD?Uy8KB4t>JT=g zfvXXohvOAwDm2sfbJ5Lci9V(_%r?<~^(Dbs^7Hsa9W8ux5afxJ+HkT<`KE09S&20 z$__Ki_^mfT99LF2>k??YJ{(D(7Q(PFAFR<}Nn!z>sghv&Ed3v!x_Y z8|-V)LR76ITf`1FJA!y!n{`(7u$1^Qj3PZlL}~39|3BIAfTHY zz#ar(AW~7-gMb=0!1J(lTGJubD47PAg*^ypbOYFf0OUnU^*nghvXUpsEIpfIQuh)G z)c7_EQiNok=`2DnOHko35Pk@|XE6BKWr<(lHV~Qm$C6|c171nuBLpT#(|SOrpFvy_ zuBQDZM;nl%5p!mcha0f=Ae zR%VnJ(4eG!LDCd$jE^>&Vvp+>(BcbV`4hbWOx+P;sI|rDLs1z-0rfwo>K7w++*)s!t;Sr>hz8?< z^+Cn{ij}Ggq{^+c7Y5E=*j$+2hMJxJ8&z+N!KmI`Sk+!q*HW(vqe8b@FR+1@1~Ywt zS$&$WFw*4G6(zBBbNRT8(5~P)DP|R2P}0-p!kb5=g%faXb&@F+NY)!Ndy0&9j=q z(ss&_g+{~9H^WXPyjXw)eI@8It2pxBgHX9RpcCnVM2hX0ovMi0v4BIfFlPyzR9FI@ zj5y0;feeN%ds%T%#)7=YwyZehj~HR5wc!VXaqCV6YNJS}*E~-8zqq={m3Ke_kkFV66`&q7+k0VL#%V zcng?C@_Di0IdK&v=}DtmG2T+S1fn-=%B4KVj(5@TQ+0{q`ix6 znAw#L*}GF49-Xrxn#|5@SVU?e&41s9B@|QJkp0k|Y>1Z;{_D`abg-nA>eAkr&%lo9 z9gW%8L2Y!R=(L-58rrKvsOl@`LYn~U2CWUyq$al<#$#VoXPLpYH_}GqpBfHjrU=c3 zrYeX+!KSm+^V1AntzC6^>2}}a-F2%wr1KiJ)NbzEM5T#_75!|hs-G-N#?h&&O)Iml7j#KZGG&%L&M{ErEFLiMdQWpdjQhPQ z6INRvdIZ|~68|eQOQEJyj#Ooq!cs+$!8{Dej2whaO+k{yf( z1~yuM9EWs@sf}le=B7goyto)`EC}+tVg&Pg%0!SC8=F4a5)0BBijfz>0w=xxMBXi- zu~L;+xv1<*T^f2rFUvzH(V@_eJkAM-;Wx-o1VXdj=n-feMh_SSqbn4p_6=i-66lHe z#N)IfKI#!gvz=2>BV?8$rS^z^NO^;6omI%HR*{&X;uBiMT;&=A0#rm5A{9}>tm1e) zcd#Y#I4hMcDVnPrMRILP5y_VHbZtp=Qc#8YZK){jY)L^owPgzkP;>%40&RE|VnrwM zGtf2}&yKbvR##t&?dnT$Tw8Lu%#t`#kx29;aoU#TZEs6r^4T)i^!ES(Dq;vD6{q4s zHk3Rzma6(lG*>5LS303W5;x6LXlZ?R&j$+mA$9ZTpj`=}4P#mY{PQIO)a6 z?UfHuth0%gZC8Uf7guFMfzIiOfIfowY>I8$^os0H?LZ~sAQC~TG0qa?-rJwr9K|}9 zSZ|V9dZtPcg~J)r6f)A7r^B4zbx`+UCEySeFkfZ~s_qsMD3B(ee%l_Z_~+3h&~_Le z^!iAlUNojSS5WFB@J5>^mL^_ zXAQ*rs*>c_brU^$g?Ql#8XptZd#ETQ`p?5Tt zohak6b}4ABJuq6Put-M0UDjX%x(p+=o6KU&>$o_=yhKN#5!v49@<<7%OT0M`G-`DN z*rVogX#JubI$<8yJT@_8O0k6QS^_IqZabHdE^Fa5Mbm4Mbmmg{ zmz6|q=LkwLUp<*4wI6mX5SSOjQa>BnxeUyWc?yJ_%YpL!*{jmo>r^C`ggfReoau-B zmT~q}DrL?Ukf2i}V?=|_l?W-eEaxgbvF`00Nm>PAmHr4&!A(6?a8qrN_YjH$u|QKP z_6C?oiNl*ZCOdY}a@HZ9v!0~l_>k?)gS_IPX0mBF*_Kw~YNCf?q0(k;0KB3pSHhjO35LJ~F)O#op|;4lOk!a^i($vYswh<+ zvDQKLSZT%#TS|)~LEh6!uOn%Z%ne9vSrYYdRA)H&gVDqVDEH^^D}^6MGN^rzfuHKC zt_yaFTdTOKpd57F#LBp;CPY;X zIGSYjCDXJMZ#y_crwG&!TVfUDA}cY|xsi0D3LP<>o8V7%*M>BUX)&EDr)n?WvXN>p ziZT?%=-iBGTZTr{a}a~K1@eNJi0E~=$VZk@8{lshValY0zhwng2b$MeVkDkj ze>*?-cgRnt(sq56vly8`pJR%BAgh{WwZgq#pzZWTKGMAqr@G#`9sazK?c9N9 z>o_n)x76!CBfT3~!fKxcTUyjhrawUtZ)vGBDzsZv*DOk?ENJZ>0{BlR_JIniD!n;Z ztT*RWu!DoI*hf_Rb~(~agldx7y<29bKZ@g&0B^u1?nLs~wZkYBQCoLptLKnf4dqW& zP2C-JsPf#;>V~A6fv>)zW92RkGvVAY;P#XGWvGzpad2}ZKv1=z1g-2fj^A0V#XE_m zQyhs(k&5Z=joy#-VI)-nCm?TXEJM#NYLPFM7KVb{R+O3rsBMvAZ{&X*X}Tv)GZ+$6 z2dkFdgfW8q6k0XKBJWVG@LfpCYr=iXsd?N@mc0i~`T*d>y#()rgTr9csK9g$cmqTZ z=c6&lAuUYxj;B!=<1;~eGEOUu9cm7DsC|{F6MgaIDw&{0SLWPLNhB_Tiy00-RT$2F zGKcd3NKNtfEF6fXnKC4ncn}P}8QL>W6%CFOHXw&lzhCP zjd>il%y0(VR$O#46z693$13jl}0XsPvx(swh?0unHJ z>yFN4G6{2b+CJB$BM7-9%*cJDMSjxab|g%nbFnZ{_Qk?X*@rN@%Q0g9=p&&n`_NK9 zV{1FoF@Dmq?MSGUIq|5OK7ptlITC7!k92~cM1_?zM;jqjDJ}umEbp~r+2W7=Z9CHU zgwPJz>X!3EJK~RohP%Xo^N$YrC&F%$9}vh%`k0_sW}mbte%g-s_jc&J_N=3d1wgHNL`7Qc?j(oy9|VxVtSN^a}>15%p(jfBCECi z0C|6FZJ!y?r|#m~KC`Q}efHk;FZM?s%_*c8rBJ(MUS%tv2kidy3IiFOtPr@MQi@UL?BMBzWz-4pFBu6RH+P%)B?-odlmuh?jpEcDcl z7CQakw9wC$|JnBPzh|3DF>sn_?uYp`tsV?q?%D?aGhEwLii_`1wxP=QG*z}dx3Uq^ zRWn!FxTfZof}a5o4IK0|oo5N<7RWHgj$nrOJcX{8S$d|5u@K4O44r&ROb0my1ai?| zQqec-==9|19G)fUbkfl&$SG8cyDPVUqIlHzNKudSiPKzvGu$e5&Ie^i>$b$@uG_{) zz3ogH_B~^L-GY;#PVD+P2XHDt>?`y|=WpCGog> z9Td&gjUu_Wq=;lodb+kGIw`2a{I*n-cDAITo!SzeC@K19dIZ`&q6ZY+&d)&GU-0Z` zOJa5PrP!{%6vwqChs!L9BNd56PZFnXN#6FhBqpCNbL;LOg8&u(N{>L>CwQo}oF>%E zQmW@NOEgy}VplrhWrDcfeH|{MoLEfsNGv9CBo?zbxBd9!649+U#P7)^_I7e}odhO+ z+)2>WbpA#tM_ffoHA~aMlrxgIWspD6!OR?C-ON-3?|GLqz#-Pl*pnYk9|5(4nZE-rQ}<$!q}Xpi zk)MJ}wDwd5+?{kVt+GS~Mz!dc{0K+0RkUF4d}&_ZPU4l6n7bM;DT%ofiKw+XU)li< z-i5TOjn*521`C{zg=b0n7UYrda+XNi^{t43L^@)2$UdHH)v6&>GncTP;*i zS$;JNF#QRYaUZZ^!8V>rLC?hZgw!gsS_;Neb#(%7JdvhyZ#_7~E5VIe6d48ikSl|j zKJtyNe3kV6DuL4~-2{rQnAH?f3)aO}V+hwy>2it9qEo@JT8)ljWuh#nNX$~2;AU%c z2sc%E{WH*1i5shQZmkK+zH~n!U0H>tlxFC-EQ~(Fy_6E)fy%iwaYIn8w+D6I z!JG_Y`J;zzc49@0|$=TF-vq3-ZF8T0*}UTuN`1j~hKXIl9UD zQW8^1#TV;J>2Vr+Lxi811Iai#ol#&-lM~GRf>5+b7y;7-`Wrr6oJlsJHAtLn1m>SnfTk+n&jP%TmQjF7e z7(FxNRTv^MA3ZZIDh#cK!|0hgP$hgfg>_8io}C54pgvARsk77Q_xm`@GRQp?&&;Fr zX38dmni5xU)KXrvM4gs=#v0~}Ex#5mm#@{fPJtNopM%ZR0F=53F{zZUrm&yd9?=&; zOveIw>4S)Y129eipdl%_^*|`KnaL=DMrs4;#}S!tdn;K#xUzOgxha;hAt=HGo9>&U zBgx=+V#Eo-p|Q~vyQt2NYMH0 zD*%{i!)f3?Z8x8c1tjCdoQzcczYv4tj&xy!*53!BtwGV4Y@Nu}X9x{0wi5$KE4nUJ zk0ChVC=zfYt&br913)x=Cnd%`Y|tqt$`hdEhlgPLEW!@XGDdidqSy*;-Utd$^~>T; zDG1n0w46A3aQ3&jFkT!Rd;wy`3S+Ug#laArBaYz6FOJ&rexZYtezYgZr;0H!*P`60 z?zTP!xy6xK#KF<;$kL~QoX*4=jYU6#rNWT96!!ilbTMk zV4^EUFNhTsciK`Pi+m52s@c8? z+I0kJ98hBhjE{L21;!KQ=&oq$U~|_;hs&}3241&s?bJ!+uK{fLJ&euc+G){tJw)M< z1KJqQJk&u17S?YdV71*yk3ic^^uQeaW;~OX%SlsoP+5vWM;nMsZO+h<5e|ih95+jX zc(g`4#`~0K=T_2`r`b0!h zBa7Nv3g$+-W$BlQ$fL!wyb$k3ElaAgxQ7V!5`+7}9yH2_7Kl(v+XfclKbfU0(&fio zo^a!nvV=Vp%8N4+jUasFu^^vwefX8%jR2+TZVAc0s`vNqK;H*dkLYGoYqAS5TpREAW zp-90{B7qQkI2SN7S>3T3#Q6YDc z2Nu4ao)ClC4vV3|zKwti;@AY)gV_&9;wLGCK9d9ZNdcJkDAosD52hn3-dk{d3$>r+V6y4n2t2!!(hcK!} zH23af3(=R_v2z5PA=)NoEVa9x{u&*PLe6j)#2Epn!A>{TW8|6ScCkF*DU#w{fngE- z>@3JiRoUqo#65PW++-#k8j@M^I3r2A%#z7CkUY*P6-eeAg3(xHMk4^dB^3rY=i;iy z##j|kX1GD;1&i<@4KQ(whTm(@&KQJ(75!MG>G>_Cu_`sq=^X2fX-;P~%?T#Pf-Bz+ zJLB*yw&KNs!DpdQky%n97Fb(svkJvQ90wW?7N>>yx->S$y5y9=X`oxy4Bs+Kbt=^mFAg`B z!kC0&;kC|WiV#Kw%rI0aR(jsI)90cA;3ZNz&R@R zr=Ox|G&``JDPUpd&C}YKD_K~{8uBuXrm703m71l~pvt2r@Z)`H^i*l=-<>KP>%x3A z8_G>`{i!o~D##70ICQeAN>rmXs(qyqjYW#0zS4+xERE`1X;iDysEO5}G-~wR7gI5u z)1cZ(T}Y}?J&SAO#dVGGSZ%CsZE>C*%X4rPA<_`5gU#z=b+KC5`vaM!J|;C8SN+i- zFfYr;t9h2Xtzw*HAzE>_cyWDWU94NIer<69rfsnT2Pfwu&UAA2W|8#}Ss$y9b%V&) zWtRFc(t@7F-Q&d#(4u>+VQq0IJJ!j;=@w|wfGBWd-B}A9Bti1FGXpf4rM_p#$y}|; z>)>>Y`Up#LkH$S?J=CiKjfllKT0U^Hcf2fYcZc(>+A(`!8doOsYiFZ=>d94nTU#D1>z=iWSG#I|ilva*l+G+pexWW%=TPdQqw1N!F}8?mgd3ncH#KRu z(YPq_hK3J!*=;nY;JOmLCEUl;oXfyGR*HMY;J@(^LimRnLys{^L4yBTIn*+>KVZ#1 z*wX$r){KvoA1joB`iTKd%IU0GQQ)yx0?hM>8mCeXzD`1SM4fuL`tc}7r?Mi+%FF_K z(ASQJ%j{#&6yN!BmOxkaZjL#*=tuKHUT?*jp6MWQN5&m~R0Ra-d}##NKSR#Zluh*> zNpbrlt}@SF?UT=-Dbqga&-Ss1!IyVwxeAw@d5*lR>EgK2zexAdUrYD6ou#`wbRO^< z`L&n62a5+YM{>Gs4ZNT(0>TS<*v&o7^YI?tF8_^*cIMalk2^;p(`1I@JF0_uxkd8} zl7kh6W*iZS_eq#^4lokIwV?uO(=C=X;_;0jy1??;mY|(D3JiQcv5@Lgp}-l-AjI%I ze_uQYxn-h`N0+Mdxd{4M{MMvaLM_LE9Mf3>w_!_nRmmNkF~wK?RE(Fs7#+X6P%8@i zi0-I2yq<~oQZblqnnrBA;!FequQ*jfwWdH*BHSa(L;rp+^&xG@k)1rq-u9XnU5umr&?)@KOsTPP)&(mNEqmIUG-lMVO)_)0?4|dZkI9i`1*@=>S_~ z#q&g*gl!9aAFv=$U>5`v$0MBj8>&kS@Wh*>-owEWK-0l7G|DdA1U|M3)t9&7(HsaC zTU&ip%DTA1Ij)dw=2l^`{!kYzEvS-NWt5H{2*qnk)=M=C;Y}EeVK{IhG#ZweJzSiWALLkC_ z7OxJU4O&G4VV{tofqfXI>zsx#>6{K1SMASWa3;IIgKK40p>QIZ^WoA;=~)PKR>Q$& z$Jz9diE}7ujS9+OSPAm|*1XWtc`yU4*Cl`Xi^y8~DHL9q7tobAb1vevv)!SGiY`>x zGdE9dUzI67?3g$YG3bQ^-ZWA|hkhC!R@?YDnUIgyGfa zC1rP$>$BFt zRDgXM=`e}d`by_&Je`XvwhJ!tgSCFZgO$scrG$qn0jA|#N{sj_5Xm#0%LwI&m$xHc z(GFeNp7pAB#C3$+6xaJffRcA9cn9<)eswz$*R(^|`ej_#j&yxHbh%&tW$p9&O}pg2 z^>g0PPRNb^)OOU^tqSw8zV`~1Hs5KInVS%e4pdlty~#&0+cq=X`&4-7i141Gx=!}+ zn0+YPPZ_t{KY{4oZzAB{Z(;&Xkm-KY>mZ1kwCEg4Xd%#yoH_nXL0tQUKrmlr_h zWC~?X&5_Q7ewcX1G9M#3Oo#mUn^=S1C}O(b#Na}J|L}g(R>+r$$KcZaCVKAVepBXV z6ugtSQ z!7*@799N?_an4tH=+~}B<%gUPAu6Sx>T1*+nRo($yittHQDhReS*rnd5vc9pM4a!~ zzk4@`u1CcJ9qvbk@KKR|n1GczTOmxPsWz0ApI4pp!|H;RZ8=v_X>jUo!KY(?ptYd37Bx4QYan+l>8b9ZQBQ*z=1qv`U0_jn(5M&K`5iQ- zU_Sd_+(CO6!f^*}O9(Un*WrIx?+4}XqR~CBsi&!b5rOteraMfhvi zKSJbFJEC`z6!=k6?QCarm(+xNYM#N=4v?966B*;Za*Ef|K3+TBSz+|u@f0ci2b2Z& z$56LPm;A17`WAnyvSa!k%1+&7^HfQ9yvw#7I>F{|lWP24iYi0x8hPS6;NDD|2UWO_ zO56{#IS-IYaTe!5ujs#c)LUA{4b+3-}jzTxwA+A z9l2LPr#o_#Z@MGL>i$=EK_caP@8bcfCM0L=F9T%vmiX+!6CwQ2-OMaHl@owK?bPx{l} ztK3R4G7qBJwQVDB;$diN;*829)X(%Oa54{3e};^2Av&EvwtnmV4|{PPSRN+f?{j2w zn|h`H0I@q|sU(ZsWZQgYmx)Mgo$teyN1rtv|K>9qAe<#vo zc^%cZoef~pp|tuH4K78qHQFtFRfhOq$w>bJqSQZsftiTG%V1Ke5Og*oZeyKKfe`k| zSb>cl6i_-_;BTef%l!1#9W4;fDd9W`PG=LGoK?cbfh~D_h{;yp>y8Czj2hJ$^#adf z_!W@7@uRsO{f*vx(rAN*E&Nf~G5wo+H}~t^ug?$)35Z4XI2`vomJ6{6&!^GkyY0O+ zz3`|786x$^iuw1=2%E9DNNwfs5Q=UsGbUn=Acg_IiV0)4(Tkizfawo<82eVQkA@2X ze#BBECYzM{clhm#-!}X{2h;H;{;ebUkwN-i8BNuwp3pZN#M$`0h@XvL9exy_=Bpw6 z_QJ0SKNPIal`YN>uMS7V1L5n#ws?~LpM_tB0{IaciHQ10MZ^~4BE+*V{6%7YMKS{;l~>gU2o)_v+}=&}vJk)sSfve%Pr}98&l+G`YF3B2pwnzK>OkE=5mA3qf4rRJ)K)x$6i2{~;L`=4S4G4- zoymszU0x2?i9Nb}kMQHWl084|y18py>{GoAaxSPjxh5hCYF~y9(`q+&trV+jPp+}W zy|vFk=M(BEt&7>cjoqi%eTUs|*)8uD?p7(Tf(r|G`w*{?zjXT={=@2L))$FW>Tk=d z6Z3m~kGBT9=kH*j(LGu7o@D>KdS219Qar@2oiy@oF()}C39XXEb4&8%no6;)aS1rP zq{!U|t}U)jk)D4^y^*REvzo>>Rf;UT-!?rRZQxu)#PiJ$Hs5Rfg4U80<9hY!l@!b1 z+TyvsWbMKI$er46O41gK*#pV|LAgFa4Yi(C4i z)!!D+!z~i#fUmpRqIv+yZ(?@@+#)e!09oc}P>aMl?0=a39}jqWfGx~{#NT5er7{L? zS21^BIM%G|*mVOh7-)<4z!MRXK~z$!2DJ`C84aQm-@tCS!6acC+)DAx;QI$RXllg} zN`2^%>LF-HLr8ur+-6p3&vjzZZr{iHvKtYbcB7j1J={vsc^K813B&pfv&Fu{rX(Zc)M1}jHRxLR_ONB( z{CpU-&E)RX-mlvIQt14^?iA})c0Y$35!P^OP4&aczdQUz;@IKyh8Kww;o9P~;gr*t zhQFB?5kC(9ysAj#jiA;&d_-zQrPvE@U#@i#v8oGE*N!0je+akA>^GA7t%)N)>;&pa z%GY|hw)o4)&0THr%}BCpWE9o^x>2*rio{W)X4Y4VEu)?rRVlt4MfJRVba-@;xM4Ka z@H^nz;-%3~j&5KVt#Zt9V=BdCiQ~rD;*VoU+6!Yy+i%8%Q8y~ap4Goj+&T8Dv6bS@ zv5$@I%l-zg`Ejvy9JR`e$1TY(67P?Da-1!G8b_s8JD&Q$KaQtzp&kQyAHM{CY6}tZ z(fGm9q-bpE(+fFj3Bx~VH>&MVw@{gGM@U4-3FKD81$6?oh`rg}P~4|ik#HuERnMEy zI%uG{cfw56Yt`42OaB$(%-=AK4lX(XD1?6*BVViptqmxQF|C+6&t=YhoYALvSK$0{ z4FC1Tzl&2SHb8DU{+qB2WJJ)bYWnaF^yaBb(1QLR75KUss%cL zQ4lw9(My9>YXb;iE$S^5|Jw-1@^^B&AK8z+Y+FSHvbQq(VVgRF+jP?_Q7+uNe z05OEoBa99dyD@r|(HyZmqt6)~EJiR2Ta@~tVicoBM)SoOMiUt=6yq2zW^|-zVRSa5 z#R4adV9(naIbt%3wop6;)Fh4;Q}8b=7K#ro+CMx_EM)XEPyqif!4dTsdh!st?w$F#yA$-F`oFdD#UohW2kIVT=kxw}``l#xmz_KmnjhG5{$vFvUAs zJSDPBTM#-f6cA5~6^JLq#X!f4=f$Z^yMbvhh_e{o3v?>xjBBKc^fp4u8R8}Jd#1g| zoG*zB7<~zJE@*2R1;V%BhSp|rIp?n@P(W-JS21lgP!rH2GFM;T6k8do`tpwWD{~$O z&OMCx#AkA#_#%G*&IJ?}3`T3OE7%=wpMn8!Cl`!{dm#Ilv3ojr28vTVT`X$FjqE-F z*TCueyKoDtOYA3v*TxK^RwQG@GZbzg@o=m!Lbk^SppF$44TYO58Uc4;5v4e?XaIOr zTyhOjhJVM=5M4@6g4M!E6YhMisgoUSV1A*vzu2*{+i0srXdpLnCHywOvYS7y->*tAuXET!-RP`pCY27Anjuo1 z$yFu$YL_YC`Jl@HQ7gz_E6(hCh-KTibscTaTybC5ad01DcLTf6z@^%I6JmYcmCE{^ zD${OnAHS{6s3K0~?yO{q`s*c2)SZ=VE_`Pto1?lVn@hzl+2PQ6boF#wwWEPze)VXx zk2s~8+F)J5Pqu0=u1(0EwQRjw@n{X%^I3Ms)l#iKsJ3&^5Dxnt zsK$gD9tWCCx&W8zn)X!&gr=~+}576LVd&$$xGlT zs@Idi@9MlOHD`PC&0&Mh7WGSZg>`q0p5DbMa1ef<|{2%m;c}qo)fN0d3ak?Sdsh zZ)x;dK`V}6ZPUo;lm+^P(MBWQX)b1)pKH{s(|n*G7@b>wcJhi)NCfL#%`OG4)I;kr zFRk~`P58HtwlLZ#NM^pUx>3B1f@J24BqJp=UkqeKxorV$xI&?Bh4%rC*Jw!L!$5m# zM7b>x^EKMDa57MlxD@^pB`F*8F;kbwM4)u5!D`w8gbFfLnTIq81A9YMwQsdLybm_ zcvPVfl~|p4ULz`_I`Ni9l-oM7T_Y;@I`Oqe<6;!g?#{Y|rZK8uv{KBAEdgyejTQlQ z69+QdWVFRvFybDr;)zokjcs5l;!H+&FQM3@1Q9^_gO6x^Mgig^YTeJvht460Wn$=Tr-cYoM zkq~n=y02(D&_a!#F51uNDUR0YjiNa~%QV_v)Qa_qlQjCNC<}C+Mn%PoaFcYcM!kzS z0NtRF7*{;s!1^sMIO0o{(|}Tf{#8pt^NP1&u5^lr#v1rcA()BgfU~z)s!?0&^FL@!301eI-n(TCAWF}CDTXp7^Q`Or!6B01Zmt-)@84qXA-fgbHv&~oV2c$GZJ zqx~&jC+CPltP*03W&SEJ?SOMupDw7R@iEEelEy0AP8bhAR-8jlipdMGQ7qQvmGDM0PrQ2^+H z@~rfu6>^D>cDhXa&}w`oK>bm?3*|8$dbYep9Pgpc@o$jGX#r5(G4^;u3 z>7k~ITjcLNG^pZEd6o~|FIRhLT*agEY!B^K@svErhhCIxeCTy~o)2x47x>U85}V8X zw<$2Q;ybz4hlEMHz4S-4Jae4_jLOVwJhT9*-{3SAY}APQ$XCS+ z8c`qlns`kk>LXthTQs76@O80WBkBiV7hh;Z{ooteJ)qP#g{U8VL+q;&^;vIyzb`gvL_PHT;w6o!Z`~^1(1`lhtzxS};g2f! zGq;J4HTrwy9H1{XC-to#h#xhgzV$;<#Vg6Dh+x&@#)qPw(RPFSi9hp)tf}WK2JO#c zjHXe2`AAIlP_y|LF-Ie+FQ14bJk)G{Cg|V!p}7Y2Hh&XmX+*W>OR-KP>U+KtH+yJ> z{8~Ju5%n+MiWfAZ{^dLIo`=@S@5SFVqWp}$bX3F0F^rRFaH#HiDzA?w*HL$ zABCv5`9{ZoW!&iPq1R=(G227iWR~Gxcp-<#M;~kBt=Nn>t z>>*(eGirw_DaWDT9clFTP?>|P z4J(ri8J!}gRJEB?45Coaz7#EBPvcakQGb?|(~R>OZ8wOvmvOyEJI|bMZ1mA)7(aNl z>&%%(4IMo|-YMSx#u7#(^FH$c<8&YGK;tuymX!w?|M1b~7?Isc3dOt5oNM%Eq-4%B z?(}F+nui%%eY7KtnZtAOjxW9k(7dp*JkX+h~jNEmm70^v=fb^Jlb}1h4DKd?PTLIAMF(5Js<5fqljMf-O5+J1ZJqI+N4w8lZ+zpUU1Q7| zBk)J*{b*im9K}fKa=mf7k9LD`g^zZVai2$P5jPu8d1x}whYE#SIu}^C7@ul1vvUd1 zHyY8HdaH5hSWcbC)LV^38qqlR2cuOZ8dv^k(7)UTJwr6+{LwgFqr*Da$=i&dG@>!? zHp3dHIBAT#&B$l8J$zc{D(iNmRMRf)yhPk?bk#H(Deo{6j5dn9zk*^#WF=*Bm#lou_=eGTeq(stxO@+ytrA~% z*~@y|xK*K$)peG&!MIzac-KW@gYmHDY-IGdMnk){fc6ukO`%CltDC|yQ74F&^w0vx z9H|he@T4(8qf5Ikv7R(2mir#=B6<&BV?Cv5n+$pnf7(M|mRxQP3J{pJtJCod&qjxxJe;icYDcrl#yC@ zd&&4pBeMKvLrkSyoFZu5?d5hkdd1UvL&1WOa5fN$%y*-rz+mD-twUj zthYV1x%?gLT_5_ude1}8ReWZ>@1eaazH5ifz*ZlvFz|s7)dW8Bq2|C}JT$XnWZ)AY zni}}rhvo#n^dTqkjfWN>_3wSi4E*3jg#p?}rN2#q1r;@cpM9t~Ku6LP?Kq@v`q0z> z?UlN;IRUym<02=J@1YAT%s|XTcLNoBXi&w;fl?n@6TrVRprs6|xFS&QLpKNT(MnAl zS8;!!%7>l{;B$x`ZA+l54}B4+mIYiVsE=$BwX)VjlYw^gP>E3|XEIW6A@%Z5jp!|; zULLIxy@hm_%Qd36knZv*RQOkw)|uGC^MJp%rqXyh|f`3z;mR(1_kU_K@@)70Ls>cTAC6G@_np zs{GhPA6R?J?=_;HXfG-EQt>vIe_&0QMH*30w2!RShzV;-6sI7I&7p*ey1GBjQ3GPA-7ER?e~qMm56JlsQO;3#>P zhYABrbo`<^O0zJ<)OUCl5^xWaWUpReHx&%n6(*$9l*KoFvz2L_N_e zd51>S6P+$MXhc2Hnet^1tqJ^2ZuQU=fz|R058WI%Tb9gF>5Z%SBCtmGp6R0d1Lw)% z9(peDdpX5JTLKq&{nFB^=d26mY^G7alxJTgkJOw*yI3CY(N@Sy?K1hI zk9LJGg*Dcd@;i_7ZtE%;;ssxt9j>v~$-#^$^)h?Coa>`qCqMLP-R#G-7b6WN1R0KZr>qiGg9f@D_`+w1MK_c7e3m9vgiJ8yaDz@asne2?@_tZ zqqW$N$u&OO%oedxmNU9gTvL6hy-{AK(YRvA-Xvf3 z&~p13nKzr_U5H)1<@R&3oYA@1!8zT2K~B@?io(-p1%c@ksT> z_8YSEK}yPV)mPeY$_W}J%Wkyamc8dF+AD>3+waQZa~1lk@Dckxxeue?iw~+FvEP?> zX_{U0w7pH{9jrLZYhJQHkP|d&2JJ&xc!;8nsd?T0v)so+TkY-gGK~(X`NaNMZaq|S zF0A?5{;MpSM@a1-eIiFNqVh9>pU7#9wi~zAY!IKyvpiZT_^EtT(ZX-k6v@BI_Ze*x z+iF_G-{iL%{gqMSVU)rq@kPxN&~DJ^pP+pqf6}N|ZE5fedCGj^Tot;Z_A=v3xkjT6 zwW;7&GPOX_UI*=KIe^jj@RvZ}$ngsCjQU$SUn5ahWqm7;(wvdHe!*|$GL0(g7Kv{q z{Y#>%wzdGRX@@TM&}GKAa-E091^+G|^3Wc^@8laE+B^8Y{K`Z72Y--{V z_~rV`g8_4;;tYLUe@)Of&rqD9U+QlHx<;d-?zaKms!{ju_XdOJJsRx>6fz&xXiuQ9 z`Lss!x<4F@n42{^ruzn2+5pkZq;W{%NlPoN@m4~-T# zq=Lof42@PaED7|dk~s^G}{y3uVfmdO~&qw=z|(~_cf;X_#s$f9;eaKJ!GiL{7j?M zdqhHA%!UkcZa3EU7%jV+!x?Qf?(OlWs5TGKh<4Iy%o{lMmAL%+xKV4?aC$4n6reiu zVvSA(>SiwFc&fLlH&0|ly$#L~n5QYks}A+%IT}%YsW&fXv`KuNm}7J|Z_w!b#C}GD z`LW`JlmkNzX2nva^~Rp_LOsl$3WeY4*&0fkeKh*IXBKFPMqQFCfkrV>nkCJH7?Eb{ zL0hUg@g_Xm?qhz>Xq)j^vdZdfidIT*oAG%PGgVV66s~LR7wl(7G}^Cmk?3dUGa{J> zhWeSE8ErRSX}mYo-`vMTkAw!8XL@K;Xpnh6qfO$g#+O1v%t^;kddgo0 zGujmT2h!WkoY9W+Kt|h*#?)J(-OPC!?VfrcXn{t1q!t^)%(Oz`d8zH8-Ob|}sq}U? zS9<6x(9UPHNxafnWsNdlWwcSON?j^OnXhX^b!oJ@MI)-aW6XatQZmPyfnzC0+rxLJ ztngT~NTX*{i^N#7TBEO1`JfRWMv{ElG#|8-q8W6`WUM(vBRaD%)*P?V_VQxHo8h5L z#dz~jjjEce!YyXnLzfv7%@rCoHeF^+GSBuc=R zm})+$(K$^`K(A=d8=8gyZS~OT@Sf)XXmo$m#PBrpCyice+938a!^cr>w;S7au(Yd)cysvqz zMw6SHfKFjV<4TLz*F1}nDzSad>pV0Wv?mnec00>_RwHV+v&>gDqW9bV%rVDPj#lw% z;eO^G8qxdh{^ksgsHZ)^JWwO*g%2W()GJjXti*T`IttuS~%CtYa`B;I7@I__z-g#qjSaV zUJr!lnQJs!-D^YmFmu*&C6m?_=bJZZMC*zR)W?XC9<3`bH19i+I8PDR_3B|AVGdiN z;?XMOk>*lHr-*w%TVy_@X|(3J*epaROYxot?I?4uMzjLyn41}GH} zvW_-KDkNwHGGmsXOfg2KJR|*MQojlg;bPA=gO3>=$vE~p)YIX8hbAh69%{mqz!eUOK1(12FLcBV8yt!H< zTAe)Jyx8OXDtNp(?No}lDMWq2GLvq-)D^g{#EEfQ$y^545~p+ct-Xn=+&kG%t`raZ z{LlD!6sMB8dnLtvlc`-w$o~%eDXwhi--;0Yn_o<&xGq)sJ8BisoVBqW=l^irZ`sAs zS)`>>EQMcczdtX^PgFxFcSnAIcp2+o!Thx>GqHm|$sy!Q(RT;`Fb-D|MzMba^Qd&m zm10kXn1ZN=n8mJ=sch(%?3cDf;zne!cX>12|@=ac9RIr)`tDt9^mj+(oi{#-l>34V*w$@BIht__vs2S7F1 z4z9FZh@~w<5?nb-D#QDPH0fRbG_;eT2AWk@G`O z=FElAod}oHPjySj-@mCI$zR|8&-!z1*{_wsbyelXui>xf&R>TqcW!<2w}_5@x32zn z?Nv3lV=M5>cjf%M?atp8s6|NJ>mkkk?SlMnIF+?qS5+ze-!{^*)%>eA;;(NvvTbkW zUPy(jQda)km`WjT4fKbTE-)Em4`wbQM*TPkcQ|-&2ifW-MMDeJ$^J^iwvT$c9xe!y2K7RSXR%#U9 zUV^`*ax&ZV_+zQQao796WD%uEt`rZlCH*0rIOMGz+^rmvn-xg$nJ@0ET}avoaOwUI z`M+c8uFsMD`l}r6IP=_fX{vn5b>|*ChETowzkQb!xzYUJAK%riY3Cz_J4WmZ&;QQ& zu38PbZmsB82hgu_y`}K~?`EVs*3}(DI%@8($vfu4rT%C0KxGYoJ?R+YjyTlMyR}HQ zXf+y=-_=Tm{QqHgx+^u)Kil~=e$~(WMIx>$6PfMsnq@9{#@hQ6-qzCF12VWN_~E{0&pU)Cn&1w;dk`sI4#^C zCz*=px58Z;Qck5_51|oC>a`0sa`~x#Kgsv6q8NhSYF#1Xlvm< zFG=gcc~>K;e{}Qv{VM~xvDIB~`R%m=KmV_B`qTP<+uxh>tK30svE4WXAGd+^lwVQ( zn&-;JUxMyx)fkr0r6<{Q0?U~S*Az23{2&fl$RX6eEO9*i0kImcE!M#e>Qy6ECvQgx zQekPTpC?y}`#4=2D_4swiuK~Xv_$Bb`iC+@GM*LFv9!3iP za!3lHDRA~fy8ZDLk^XoNMC}@c-(dWP;(Kzt;WrGw-SHca-w6Ch;x`Jv(QrrO3$vre zM0_823VbtgUvoeF4#clJLifXuo(u8I$8RzIUDj6IzZ`|%IQ%B!*M^uY#Wb-RHzO~= zFCVuc``|YKzn=JY7e9y(u_yNfZqH`r4`LGb;C>J%VlS+xv7qUca8Ki$rZwR+Oxn>n z7w!^q3Eaz!b?n~A?(OW}&+g;wKEv+IaB=&G{oC06E8H=WAK=ENVUf(RVAtw2;Il}~ zY8dcUqypiW8MW;8WVer%9q>bB2>eELh;`L~5Zs#v6u`ZEKuL6z^~`{V=tS%L0gX|d zU9IaAjj_y8M(MzT(fzEx14l#;wx$m37hGr^IdEJwEL!33W3>&O8a>{6aNs_0Hw@el z?sEg@L|1Z(3ytpvE)r*0sX_Ci3yr~pvhoaT_@IT+GpxyjGSR(^{Rd^m(FWzBmeV@g zIDAl*b*^>xpp&CV8|M$YUY=`RKIlyN*AFU^M;o^cx+r>y_0pirqwB2q1}zfntnJ`G z+Mu&?dl__#{AlAVq!NZ59!0Dl1}!#XR$%ZZ`11y@gM`w-i;Y^oy?i4ye9$-pcTZl9 zo?(oFdpkl}P^zwbnL+*=*}WaNfhn9^l$tSr@P{07BmC*XZ$_Un=sqt|Z-*wQ4sI2D z@x7(DjNcFbB)ZMGeDJq$ZyNkl^nUA|!Dik<cw;BH!T=@UA_cdU06;;}G zZ{{y#rYF-AB$0_U{*fpdNkYW@kkFZ*q?cqS$xOfqICf_4Bn>^?lkT1*6F{bCL`B6l ztE{qu8d+Q-qM}62Bl$D}E3EKo{6|GaP*Gtuu71kr-}kW_QmT*48#^o=Qa9QJVw7L-ChhNp%c&w&p`NfTK=QYc>AiQSz`9V_y)w#j!gcBy+-^fc{KJh?er zJ%l=oW$p`|Pn>lh)+0|b&sL|c90iRYjJ~dEp8K+uX*JL7UO9|$4y{Z#0rJYRrnA)> zS3b{O?A{!?26f)MG72vJ#L71|Z3eW1&e`rA(KBn#c7KYtMdu-$H63ucBI3^Rl|N|M zCUq9Ne4oGQw5|f@ILTGtYT8wM<*I+dud3I+>Q_xEC%-C<5A*I{^_Qmc+7GOHLU^?{ zl5#%2>T2|LXw@hrCU4d6l3BkP;e>mxgy$nXRI>`<8FifqUsAV0(*2UY9O1IMAqmq6 z8|w;+H~X$Z_>P)4AZK0O+Z4a@@-D^u=(otXaBhKD_{JHe-H*Tzyz}|blK;;ppLaV+ z$M4pBM85t)3jQu~ucYslFTUIh@6;_b?v<|rkt==|xnD}}m(u%T^B$dXztp*3>O3r^ z56kyp9+v!vCI9P^|8>d#y0rSblzv@GzbB>NlhW_O=e-2)1M+J$Pf9OOO3u@m-RipE zV0Q1QiM#*0YHf3}=9pmk_{#OoH`M-k)tNQqgpJJ%w>9qOzXJXA0j#GDJ&2O6* z)_r-+ADZuW|Fp)Py}0hoi|(smUbp5V+>)q!-9-(^8M`Pl``OydVsmFF>NuXwb$4F0 zc198-gk&Rc;1ecU(I_p#t zYvkbUqtce)EzT}?Rs8VmUG65dV$SDg-{20!pKxv{<$Ou%18*q3+j&UZGQ7pvFE#f| zP3C+FUq2y+8Q$%T%a~i-8vyNq`@Z-$W*=}r9DfYq;rLHxHwvET$k>W?KZ*YZ`TsZG z*mAeqzV`H%{dL51qmfW*9)h!3=zPWY)IX_wJA^a`!54e9>yAFD%spH+V4hw{M&GR}k$bV%=K|+jB zK{95N^nkk);c?`2A^o$?-sre<`I?>4&2=?hndmXMwd)q= znERrxsGD+@c0pshU0uWKabOZ~aHHw%(H3`G*EVO|;n!0h7x;1K%C7fCkE6~V(V6uV zT}PsE_w8M0)*Q!b`a-m&{^MOsoO$&(M;=D{=g6N|f8U(1MYq*3Y^i@<_n9><^`t&I z^Qq{<`metHR}%g)I@2K!%yd{f(|LJ!ZR<>@L&D3tXCa;KZfR|)eSP;_gg17_kn_H7 zNbma3c8@CZ=Sz{pk;l8 z;*4YKev3Mft-~6u=iQ-kbfHSc{OlW6ycrf(CO{?rHZ{sU#wn_uuuIH!mCsh z@~0&Kt*RaAcdD%j->Yszc$@mj=|Al0fc>X>8O9{6*|Aa;YuaXIXYHMJ?X16_b=$0u z&bnvT!?V6W>$Jx4#y2*;tMS8)hZ?`y_^rmL8c%DQ+q9zTqNdKKtxa!jx~u7vO*w^$8JdHatFecy z#eWUhOGNO+r!!#N&qeB`*y$|5&f@}nALk-POf1H3;C$>%y6~0JZhWI8p=5<=Pgi3{a2@s;Z^jo;-iF$5$8C|WW?qB2wE4{lhntyGX#NL;?{S_g zbYY`>ydm| z>KvNO9)s|MkTnDiO+(PV51dK(x?kO+?p^ow>4rDqhK=s)jq^Kd%Ezhm_s{1@bgPfe zPoU1{<`brd_C9q5axQxTbJ7y(obeazM*e%82N3GEdM?57|L5_u@GR0-&tlEl#NNUe z5|ih@aCtrODe2cp=)G_aazkH~ zI9aiPtu&tuEO;48GYjwoeCqWJE1*;K$NW#xct1nA^jlCTWohS|Vu3cx*Jz}Mv9kKs)G=VC?AMEZ2BX&2rKhR?&=#@7=Ox>)1Q2w#F# z?qaRCB0L9mU99;t5H5r-!-X&6OoXq5AH#(lI13@ay2)R#c@aWTU zI`BR$M0&M^7r~d|V%N9`;Q+o6?BX{g7o*Njgf2V|OOd`3p$oanuK=bIy6`|;fOJN} zQS|2G+dIpVvkSesDhEFYzP%@50lm5KR>YCB8=(t1)PeL~gf8S!7t;F>x{yihkiG_? zt6mS;<-n(rK>9k!FBjiG##fcqTP3^^lFWtNV)y{Q4eQ|j35E|svbp%iYai182I=Oi zha~(Gzq$<148#8oZ;GoPk?_mVCl0>DdKq$#!Q0}fuOf8S*MJF}QcCzul|;@r5IXou z${@mT;~TRszICz#>F*%KEjHlE!Iw%Hejj*p)ngL=5O~535eYXrS>*R3bkr7S7t)&% zI;zjfBi-+eA-xr$t1fZ&AiUHWN6xDex@wzqHPWwfu0?p6a~*Q7bczVCa;6Ywoa+(p za^8e6=iGpBuk%*a9GCEF=SJl0lkghn?~(qnvmd2*B6QV9oOdF9mxLd4ZbHsS5#mmb z^KPU+F5xGfo00QL3GZ>bH7FUa{{5`Nw}i2S1nUG)X$PK5V4cOmC~gsxiTehlfQ?%fE_#}|AYwah()@RjbT zQM%kcjBthfS%e$hBgns4!XEc?$k~X{QN8X_gqz&^5N>uKK>il@iwOJNhmg~c5O{XK zg!EPkFLfV5&Z`kRYMc9Igs*XrA-v4}8p6xnZy>w^-^GDP)_oM=fcss9uX7(mm~?-D zw%ZZntCQ~INDoRl>^_0?4)@2%zt;UJ($`2h>HZAqDfbr$-{3xj@Gbb#i>u!19!L02 ze9OgE@4+`*T=fC>cL)!_Tj#0|x_>};8@|c{yy5#RuKK)$UvT-k==&tRA750#ig0U@ z^REc87TkJ-54tmv^AJM*&h#v#zl5)*U`4pi2!G_ZApda*pKx1|eiGk5an(=VGZ6mV zormxj_|A!oU)PxLY*4dnXTX|>;>*q()STLSgwLy;i8Z&ob{4|DwN3D>zF3{pct+%` z$T^W$L@tP|iL8tCMlOvEM0P~p9{F74i;*u!z7=^g@^s`k5x4oY=4kWtn_t-cvgRet zE1L7O-!l7`vwt_cW`Z8;8JOoU-w$P^{_eD&pHFYP|IblxfE4y?F@2hPujB>mwJP_t z>U!6OLcAd!x*)9@+%IKmv(m6j)@nV_~j;EWa3wtc(I9>ns}LsFEH_P6R$M!g(hBO;<$-BOx$JSbtX=j z_+k@pH1Q`*e8|L~Ht}H-f7ZlDO#C?$A2soPCVs%gUo`PUCjOF%A2IQlO?=G6Uo-JH zO#CeqKWgIdn)opj|G>nLoA?P6|JcMoHSy0({0kF5W8z<$__&Gx1MxjGqLH8D?=$#& z8h`iW??L=MjK6QqSWKK`D<->>oaUgrmqTk&@r{%*(LLHvCZf5OnKHfD#$(%x#- zH_9InYVS-IlI=a~Q`@~Z1;}elyKA*~F`UbP3UY}Pe$WIN0w`lJh8y(H& z3aTTU8BXo!^9BoS83v%#OJ_1`TLmlHZr5kiLtbv05vmQzedDH;sn|Q}*$xw#OH$q* zJx5jQFFus*+B@ita%6sPrAgW)IOpkfJ+ph#CPB(xPR_WU74UQGOsLaH!c)q}JI8K!SMcvW?yE#7d>%kQi%=u7UN77u>erK!TsLBx?TAY`ML+Yy4{(p>v<$xJ>eB4=YVliUHZ5mu&Wq58)15EVn- z&=xPB9m`?un&oO&U1=GsG6uIqf8F9~gi`xDFXQD>gC{92$;#3g1CXm1Ji0q2UPQg= zxeALV%t`7?fI^NF1P& zAwuYM%Y*{zcBHd;kID^8lJa7sSJ;^yN@NNi*ln}`Rbg~jH@G&N8{b+;rSpbuObNxj zx3^H9**BgU+?mT}Qu{=W0QYHt?DU3HnH2Sk0cRM!giZat#lx=!db^Y9?qn)Gmh(b1 zSud31NGe}Q4N{9>;8j(TpG=nz-t^YFeN!&GI|ZG6X)ZYmO{dn57ra4eLz_R{y0G;` zsV6v-WIDAE05s&hnUw;Zz2o+w4=at;lH1elz%K|s*vb%&X>F3|84|czbeQA`=A?}S z)G42GK)mb~^C(0D^`)T0J-?R<2qXEyY%ZPJuC!TU<{CtipU##7^1GFjp#2+4j9P51H(@G`)0WbET0RO1E2rB}!}n+#3c<=-5<=?@6M0e0#o- z!y4KIYiT%}8wp^*YJ!9vMM#+$NuWd}P5`Qe9$3p3ldviS&Gis%SyyIk1Y1bcES?=z z_=7M_B{PFwdr2IqM74YX0(@Z+Y(*%E_z(;-Px%&mAlYsuN1|gam-8}(3V{+BZG||A z4<$#@sY>+bu!_AQCyJ0qad$PH!z>a|`c69{c*+I8&NbT5J z*yAx&i3(ZMm*`oyp{uW}uP@QtGtk-99pAd4-`}mM?hRY})^F_X>?)Pz_0G+9SpMiw zd`N-6V8aHPwJIlAoystc&7^EB)sQ!wgcR}Zt#)cd1w;;L+c*f9xfS!0tTKpsRw~P3 z9Vp21epsz4lX4=x+pF%`6jXFxU9X}-`8cY&Gh`UBWa*A~^!IMrHqg8F@47nr2YTWg zyHvi644SLB{HoC&DC3sHE*Zm!R<3ecV0*3-mn5M*p*al0?zDSFYXS=mO7=r3mv{@$ zt(d#zK!Ib*R7cK(N~vz&vC|v83YyIft~0w1E6K1(nC2-#D9H-0@!ej|-|1Be#ZXk8SsOFc4$c6t1Z??+!_l?_sG2tB zO!rN_1}b1)~})$w-JYe>bHHf%LHTZm1-d?~V+% z_c?EODm#|<7jRc556d#R;)$ks#`Y2r-omJJ4vwN_8wK7N1EDR`GSa+#{>e>zQ9?$K_ zlVi9)8CdIK>1^?Kjd}S(DYGks&9%;oclP?r)K3}C-7*IKG2*qCta-93){e35`IN{E zXBB?v+)IvNT@icS7QxocUIqVHJdZ6A1T@r$lC<49DjArmhVht`Y$5$&kg}4ce@R^h z(}TGbtf5p={*xZNsi~Y=Di+okEO1zSDnxLU3+1_dp(dBK6kKw zSU&4pG3+ll)(+3D)=mPsQdF2;dMpl7l-vA}QtNrAk=_YX}AW-Kba4x>BPgWKP(VdZXBg=!bw^CQOr%Q2Ow_mvGVM`m?%0qQmf*g;RRw zYO@a-$}rl&7{tc90Oa?1;P(JO#?#e27REaNJvsDt>~32V7eZ5X=PZRqPY}LE;0GAn5lFW@vJs(3MqHz1(kQiXpVE zTbu4anL5W7bfWSZ%XILnOUYd@DeR$x7b0+yA&fKPufBpgiSXA*GQf3N+2>dRF&GpM zyLgHclmo-1<(`~o1yhn|vjs4MY!8AvAF&n0POO|0xhb@Od{qX5HOn$Y^Tx$G(u`!% zTErU(E-h3@55RJE4>rkhc+z%_!K+p>k3uTvRcAJlDH*QDepgwXFyvry>Ju9!I5V1P zHwm3r1sL;rU7aEqvL-n~S(4Y4WiudE_2R{rDs6y^)JP54odAtK7>YcPqV0!iiLXu# z`N`y10V@wayF##B@1062Gazz_;XqB|H}EK>y739*0{2$*!CM|8ka*ZQWLFThdSE8) zrK>WtqbxV@0BbU({i49Wm;;E7_a7-L7;L4C%^7IdS4bAdNHL-dMh~h&9LV7t+It22 z)SF3<6PJOeT$2?!H154*W^6Q02@a6(3W}8zz?B(8JbYnP;wTh9X3?0Vj7-S_F&P-P zVQ7;<@>J*emW!!|?L=^Tm9r<5GIUe{C@b|XRRbPYr18xJhE-Kd7<^zr^>|RmiqltJ z@F?aW>xDqo+n~}>jL2$uD$)Rv3^T$PvSN4e)?Z}w{&)GA=`Oy&kf1WPfwmpv@e}4$f5=#`M8wLqM?>KTrfM? z1XQX>%K(*<>9RV#Ia*@yuJNG2?^6u=iky7eGsPkFCPW3zp|T<+Mopm4epvC4X5{|> zUtdIgT0aM;g#7Ke!*U1QW8*m7fJ2F+K#N2A9ToNz?B{Pca(jM`_CXgk* z)`M@@Gt5$Yuo4xZ>>|8$UEBGFq%W$nK5F(UO}>8i2Wn zrx>jX3Vl2V008Ie8Qq*fh8I8r$RnZjz1q?k9$*2oKnJ95l z7kmUqL8d}RK~V%cujp)=jsl(Nq<{^A+?vUWpN%dGU8SU2%ozyW0o~cL%ur>%w*3Ox zm*OOBhb&RQDoAGGl6t;78Cyt{ROAJ?uw!@!O-Fdg#X_on=dm2Edt@5e;1u5?DdTY**R@3$UDcuFF|pB|vWU1xtWOFyji~f{$jW7GRVD z7{GtbS8WDV3SWA`@4TD#6awQj6ac~$< zo)Vi?uvjH~RkKz&TTRbW73@^TN&`dwhDK~F%+sC(uJa0kCov6uHDpPUhIFgW&6c0& zVPR0u`a|R-Ed*bDGIuyBS3J~c$Uz=tWc9^_fKm!bi3A4E%_7VsiSZcLm@5gbO4lLm zn3%8CZRu1p;N%F7o;Abg6`pH7xuu!FhoW!0z;El>3zu?|mr17KFUxy5_&W=@%Ls1A zDR%pyocbl~Sw6Q&*$mbPM^!QlgZ5zHq_phd6;^*iAH>oQHK}PUn=>I(t^8@)M#PS8 zA)~8!JYh3fL0I{?9>zwchiRJxdYQIP35s@EBr;%KoT0;j2rk~e<3xvWh3(rq*eO;3 zr0g-sK5Fe)DvfgKEQD+yLsI z_5xPHFM$Y#inlj{z=tDQk@3}ywTy(z#}sL|k&$r$J1nmP4{`;J*IZym=#>~=Sk_3_ z&sR6F1*I{Vjce)Ix>Wp8LMPZvaY~Jze1Kqpa*2gSS^< zXOrQ6$;*#Iw@8Cj9xm_ zT~j&ur8|;ic~7Ny9I34Vlv2?t+=$fPLFhJ~Lk>zsFT^`34qn4z;wF$;6sYH5GeW(m zl5+Z?G{dUG@QA|y)(NkM=u0Sh2deHdt2|aSJeNDIcdCD{KEc;VWT1%gvL)>s3n?6< z8h2GHaN$hGi5**VNZ3h}lGsuCT{v49!JJ`L(W$m?A7wB`F8&9Jp%-u^NM?p@roPuz z5IM%Gi6NE`r@S2G7qJHptI8X+CO~3HNT^vuWwMz~W7vETDq0M33@vVncrKS5j~8&g zbvqpD#{aE*9KjCG(?D|BG!9$AHG@2-FsGCL2z5t$4Rw5W4fp^$HuTXr;r+dW-<@#@ zjCTYXzPcEzXlQIOwB5*PG7}iT4{&rm#|vH6z#w0Su=CDcRbA8p7Q`Kl>Viv1jBKX5 z0FIU9cpq+bR2TK93h59~onBt{IA!3BknBt)cVw_Bqt=xLwu9@-2d(qq&)|U`925E` zs=Ww6{KA2fgGs_Gju4NMAs$tjXvw{j%KP9c#O#*pdARxbIHQOOh`wKfaBO=j3q?vv^gJ#u>I{Y&D!-NnlhrMs!-S-XF6nhg*p zOBu9rEbFmDg&BxKK6OKNm>j)8ao!ul;yF z-F9H03HY%CLO-ad%kS3P2>``*E3MgCt;LCNDQjzHd+?F!(mx1fhjb~+siw6dO7q)j z6d$ZhphpG=K@VR6j-2?^0Vk+V!Gz{nV1o3=ti)(HX==`Onlm_GJZ;2XqaHGaz|eLf z9O1lzL=S@8Jt8L}4aqN#d@=*jw2aS&vyV|YP=^ZQd4sS_jg7@bEqWqqHd^A;Y#U5;qRZ@9ph1bUO zxWQ)L)x;GwbCEm`@@RA0n4^MFB?tm{QELwAETYSIA8TXR-cwOsxm*?}oI}3%%90g) zNfzkAB{67Y|59Pzo}zOEyu&b>g&kru(RFE|u>x4M`n1qLv+;)b7Fz(iO5hg94u}xH zL+&s9;R*Mj2mlAY#hO70uz{$b4RC{}WkLbS6{WIq2oytjV41^@@7bd=LApLROW@My zAP$D~J~hxPwC=_fULk;HOlC5$N+B)_UZ9E3OB}pNJ0%ws%61=G8u@kY_93{f@k;~i zF3^+0*CQj7;FNQ=(3{} ztCWq5HeyoO{5$ZE@Q^;XgkA411j|d^mG3{Xxz7bcVsoSzybN1W12R>gs#fL`no*Vk z?3B1j7Kt!V->$S#^ZLSPf7U#fy?YZpKvkPc2DP?ReG*AmDG2S#0<&Dlg${mwqJ>Vm z9oTn_Uy?GM?U&;=uC`i$HCU8>K_Y_}mvY#I=>lHh^HJH*DWKX;giDjv<0h1UAx5?7UnC8yXqgkYyR(Z8?O!&?A9$=V| zEZvAW5y^{%%`^zkHD2X?#9%B8!H;>Mg9p{ipX}1`kB}8!hZ`N^rUi6Kol#gS|lM)(uK2Nmtv>I;Z&S&N%z(kW6UPPc@QYrpThZ}`m?1$+8QEo?Styd z>`vjngq%CBsy^#ny?tQdJhR#Ma`GZO7;MP5=4}?6mK}4h(mX{S;2)h59N$OBKmkVA zmwNCRnB&n^VF#&f2LoLD1PIbzSuA^7C4k3%?2g-aZXa1PG=$&qHDf5*73Bla9h&aV zYd8=WazdMzl_+W1QJWK6XhCiFk}QclHx$->k&}^%(*rB~?TV(*GbRc+xa4XhFe?kS zK*j>VDUCe=t9rXo_6(&HFfmZ6i#9J6v1+UXS{c;D^hG2E?Ip~sp3(0YZkUt$9X_9Z;qA(IePhu z!7k6bi7Xt*p2TB4&v*qS$s1QKfv5Ig69mJ=E+iC4Bu3nzC{eRv#1+W!-&VEt(y4zad}`N ze9HhA6L2x)?#452HlcgG2`l+Kk)uDTRJ< z4_s;w0)jdtsYdZ1Tj4YB=np)D8fx*0;Pk5P`0ylr-)PYTSR9|apbKpYp#XFxB+dD- zmr>*qjiK$%>@&UMu6f1i)!CiM8%7Ufm}dbbNh5_L34CgjxInLq^9ZLST4;asPc$<% za3Xl5QV#SWUACj&9A-&&05{=p1oKRr=NM{`a-`BOj5#H#A>exxYUI!+1=JS- z&gH~xt&(<>7BUwMxrX#R6?k?m<#gyP%~M@^@_Fc`nKHajP8h}?SC3v(gBVQ~^W=y| zkP=>rCooR(X9~DWBix5SjyxvirvPDjKYAE1wIWx?FmAuEY3FpsbS2YK)rU$Mu}H?4 zE%mHL3;B@acaj}u40b+$bDCUO*#j|{#;8utKaeIndNIzla4R{!n*TY+lS4Ww9_p_G z#UZR0UMw+bPkBKhY=tq`EuSb+(n>XxM|}BFDfdnR0@j0;+yoVqxyj5K`FWq}k^82!h^QR26 zd}if|5XW9sU{xOV^=-ck}?7)Gq+x$P^A2g>_Z=Y-YKW5(fv ztZu4rHF2l|$R(LMF-v{|BRh0UJP0vM^|KF8T2GS<34F15Oolm*uXx7rUl+tCMKBef zo-TjsiQ=AOpCX$=h22_puGuULvBaElBf#TO8$>n-N?3kB7M|MN6S5H6F(%y~za_8P zjA*1FvnA)Er?9qaULQtC<;gHOW7W}t_8EM4nix4X%vAR7^j4GOKQ-EkcUE>`C+HI~ zi4~W`IqUdbAoLqTDpJ61+;+Pu!^S zYk7~XPfS~WAz$c)Nv`z;mVKC$JQR!Zp4O^3)IS$$)F^F`_-o0j&=OCA)%!zHm7XA{`3W+;IYgcQ@sO@Tw zL)$gXb(a5i3kl2cf-9s~y@v{00O8|Mlle_Do$?hF$1gJWLO&C^{QyjDkK1~fK4qWP z#{S-0Bfh#@n)Fl><&)nidDdLv1_AfaQO8#$d611;XHJK!J}1(JsM6-2HRd$i#0A2s z^`#{{Nv~}e%>*PKr9ZWZmSBuKA-#wl5?(tFNLrGMDk}{lQ#B@Jg#MP4TgnmqM@>W` z(?Zg{&>SONO3{;TB2H~KqyWccHw@uKCT2C$Rree=M_M~t_i6cL<>VencIpy_?6sQS z?1v?l{6p5Kvx3sUT{#QwHdkZE8o`x|^fGL2v~|esrloyYui^71UO0C>8d4#Q8>z)q zGR&T}#(MZnD@SW-5#Ecsj6IMq$Ui4`5rjjqG_33wqrWuFHf_hs4Vy19Y8^*`cTxhB}IRp!RVWZ{h)tl+RrZ=^f{rt`8bryxS z9hn`Muk@T*J_gmqU18IruSr*;K&BAlLJlW*P#c9I`b6S02Epquy1zOI7Yk|GN-{sfTW!?KWKVJZ)xm zf!*BObr6QJ5dJ=gTobfgeZ&V%3)T0xwv}OCWP_WwQ`@5X_I+?qmVjo_`ozj0YK*mD zD{5eCTdReg$e~e5lZ)&Yrl&-5UrnrN?m0OgD@Sf+c6G~eJ}b9e)Wr2+Ym**zt?;S- zIa$3%!>8a|isdA)94f_b1|~-eMhb1(fH!8AWhnUU<6$FuE{aTDc(QSX?fOeTzlry5 z!Gw2UnA-708d{ef_iFYjoOfv#;VpU~jC)83;E2-?hM_V8k z{&N`T%frT@7iVxmiQhS}p6MA-TW-W$X^q=G&xOdd z_IBlb*(=u|o#@)4<`V@Q{icllJ&tw)R`#oF*w*Oh71Y-W%z`-Qjv;Kef%=X*Q|te* znkqTnvJS&{<*KqeKyS!78m<7nitOQ&xz`V zcB&c;{+BDLE2lqTi&I(2=F(YH|I5JOtu zCzV>Rab4-ECRE>XOifXR?K5~BOgQ6Z$Kh(JhUk}`0<4Kc);I1SL->kFZ>i}dPQWmw ztAg7adc>{Zq)5`H4lVVd(~rWEw+rY>s66N(Jl!&=>9rsJRQge;4*^MZKJXrbzEA;_ zomiTrolKa@eZxN9P=79yN(h z+K1EI_tlanxZOF~l?|;$_2#K^iroA87E3!UP>v>vv4rimR{+`NtI+B({9qO4U=Jcy z-gh`!telFJ(mKbVtzFGJ|HM|43OPrb-WzgaSfZO=RO#QTrlVR;maFs`@;9uja|b|c z&P?M&ofB54U1$;X#Hp2oqW>tZxzGs3$|&|RVEUqD;S%ICIf_zDEhA;K$RCH~)VL&{ z@l3M(xvbU1eu~SWJHQ7+whIEXPQM@%#VRI2CBva=ryymDb`eq`4gno3x8ge}?s&At zC4$rV>+A_R(Z@DgJX=?zRwKbNoP+6y8$=x;q=|(%K&|stj(>Qhs68y@zF~?&TJfBk zre}~^gBUs`xaMb4XouvGmfSlKDMSHR6sM#$sLu5f67&&kjXjPQ1*Q6E%h}^gO9*{( zK_0O^TV$Ps-{3tDzq(5|zP4}lxr-*i)oL-yoQv0jI6M~hk$mcAKINW&YRFC6bG30R zAdGYh|5EYTSy*9Df0CW0rU1phzjF$cUX|ODir%iGF6Iv1_gkK7Zzq>+m3?i+oHX?3 zIZW0=h7$h z<_T~=a>%{fxnLn%Y>~5qLXi0yXWYfJ|6#P|y5R~{7jDFeSzd0xQ5u9v{qmKny7X8o z&y&c#Y)zBK?~hIrK5MDLeF-HCF0aI=gF+k-3im{s*L7QZr?>+mHK--jL@_9rtHscE z5oY1t_(Ro34b3ACa|=QmsP;A^2TnauncstYdz8959J*!*Dm-l*lf*+nJ`rpk&RSGj zw=>UG$?D^<8#xYcDj93jh~(wcphd|ob^)iXY8{s>Nm`EL=|<$wSi5NLA&A=e*Tb=M zv9o~twWAMX4C>|rW~>cKEqtw7scai?yzdDgQ6I2Frlk;=?pTEfTj3bswIX7Q?8rse z4w`C}X-BUXhKVlgI^GFfQ>%;MSx$8u?g!)&;(V=w)buQQ<`!yoYVZ3_4@YHnS-Hq4 zUy63olgoHSOaAh&vFM()?cqD{i9u`RQFPgHs)0V?Fn#5#6A&pZ>=NY6Nm;%5=y& zGF?=ujVYugya|=u8dP%eh$7Z!jRjJJ;Y~9ZC>PJjb?YJ;-huj<3wQ@2Gj$xDxP3-l zw6g|qJ8Rh^LNq;CA43u#&QJs8<>e(#{o3BZe1H29%gWa!BN(4L#Hy3qq@VR@^C~yFhY47 zChxY%AdX6S1f9>Af=LpJ5~ol6r=nw3)g72@eesP@qBDoyNrc zw)p@dvn1x)I4vhybbzb2=mH7Xlj_CV=z0_(CbAf{p}oXt&w(Rrej70)2|`6re2BDR zv^s%I(`r5{M|3umtPZ%C&H=)eI6CnsP8&UgUFsUR815xrf5zY$1~&-WZqNuog!T)_ zL2c3Xnm0kHgPLvtrO^^Xqz&9fG&#`)7&jR30D+o@69HjyzqQ$w3!qYCO*bBN*}&n{-x- zOd8VQ=qzBB%j*$Lm((oI1YOx7_z?q}i*>G|bGhi|67W3fbuJRp!#rs+uZ9At#$n(x zn1P@%=A0fa&WE%SruH8mBXYhXSpAB|>Q{vGzJfI`{PY#@g0wR6V|C{_&I?rA%<~)< z5vG3Hd5#j`FHo~kW|EOcRIur`=JT8xr3YZXDNs1SttC*ZIRoXT`jNKT=Q%aDwJ>rJ z9Ldufs9?#3{xMEq^+81Juk_%SioPB!;)9E!*cqVd=aCilhiY;vDm__Mi8*dVo%G$R zP6Mx)q!!{|F$~o#f)G#UnUWI3h_p%5&janIDU)D=^M&iq2btQU#j|HA@Cw-dCdinG zf|xRCu+B_d~cm>E|vNHXw%#xdQEdY8O*C>M@PXrm!7@{6Wic{9P*;yivlUjJ`-f6E{jI z>7qcn9umQs6RQ`s3|6{c{=XqwBxDL=BbOmjMLy4OgG7xM_oJ#nFW!WD;0LO^Xi+SU z;>|6TrNxoJa2jG13%5ENpVr`L6RQ9Uf`#OQ;_ZR-K@o+w0}8r85w&Zycu+@+H8R1M zw~C-d;t0}$VWwp`cL@Y=@evL7?m!okKG?9pj*A31K)fCj^+$niQ#bUbhAi!W9+AS3=e^s(&c zA2@Ju#drVx+9fBVk$ZEyMdhu*gAL+$IjZ~Epd zU%hyB@3Ig6`j)S~t^O7H7ry?Z5B%y=f5^Ts^36MYXTN6on$h=tH2o*1`4_+Vc+F!k zYTA70sgFLm{8Llsp8fQ``#$w=-@W6}&%9~Y^Y7kt&7D8*|K3Nw`o*4q-m>_%Bejqg zZIL?VMj*%P5rKNfD!LuSjzqu!t{b6=6TL7Jy>MndEQClTIyt`vVkJ_mKn0JMNJIqC zftJaI%$r;!kB6d@%h5xmErQx@s13WV4M~U3F#Fhf+l+e0WpP_gy%TM#MKEy?19IAC zGaKem{S3-G@E-bd7*1|Jt-c1K&PK7@#tc|utXHRIpf7e7AxsnsBO;F^)p~x z=>KWmOx%U(Owdw`P8_G0LnJIaalCm$m5uE5>k(=2^H|*&KH{s4_J0IhnUa4 zq7%<*IL`vHc!HfSBKrW6O|jaxNXz6%baGc45FW!cqmz_BXw=YHUo)ReI665FD~ElL zqedHP(om1?X!gho1l$>z98t#((etsk`dNYi8l-^nh{*N3QGf(7i^0~4uok{M0S|$%j)1xhux1(AE)~l>#NQUC+G=)z)o3pwHQ-Y|F z@CXP8TMOl=JrC29E?=UU=(o6_dOH;(8N!f_-PaW%EZ4h@$XIiM;#ZHdH%MEX|}u| zKsi_}<)qWy(k59Ds0QgfA6XT3O)kb+tTFJv4da93e$d3uXtjP-uNHI@i`YMhP)@CX^LL(8Mt?86zxVSrrYeS6mjId`76YY&O8i zBRPkBE|h(i;Z&`JU^lD@@Qlm-cXaA>a(Z!_D7`6dmv1B6Oi3j!=HkrAqWUOor0A~b zloOqriN@G$Kof3@PR&C_oxt-<{69Y;W15U(1dux%2e$`zbKQg6j>^OiLNm`iJvybW zDjCOOksH5_Aln#QY|*M(oyPjwmZ@dvZ)$P0saY_AI@FC5zm+*m?$?{m0~8zB83R|6 z0st5+U~|rJvmpi&#jW5E_8lSLFmA*&r{Wr_RG;d?vy3YNQ3%|dGQF}FgUk_lBB+-! z4&crKGhxqyZv2Yuo5-EosFAzXjALqBt%B8tG6If315p5qe1m|KPLr%UxxZ!V3MQsf zD5s%@XDvXHfF^;E8Ozr%(w%Y|Kof=?o$7+1*k-1PyaqoBA|=r$dY{kQgcB{Ihh%ih zgB&J?g>57SQtJP87THPi>th%`IuiMI1c~_(a%rasvZ-rX5_6?SbZWebVv3cJHl}I{ zqz0-|6t%^aXq<^hgja4NmlYQXmM3o&-UhcFAwL$crx?>#AVu+1k^dKI1;VPO$p^_k zRh)1A1J`2*+6H~o#1(Npif)Wf?T7Z^&|$4X`68l{fEG7aqoBUXu!yZX4BW~6s1G}u zmLo=dEjbbszmfkx`O)%f0?4(~-(sUXDie>69aw=@Wmf}%70C_r%`Ls+? zAK;OQZJ9bm&TD88&rZwKVW|mybU;MNtEnm28)OXi3W?e>^#Gow;Ba*6q39GAv}mDX zztBi)6bKWonvO{(2aNt&DH|2a9&N3k3Dkqc3lKsS+|<_4P|IzXoo=1VYY zsiW`#AoCUE*plnRyeta7W4*M7{b>ZXRJH6Njd_g#q_s)%(PansYu$z}U z>TCGLb{vj};?>}TCq^{_5m4l!{pvIiX40w{P&lasMtl4`r8DKnhij6aeh_~kN8zMfv?VIz4iEe^@O8-U&AN;@Aoz5BXJ21 z1_luF<-b0az@4uiJSPx#Bh7zDYJT}=?uKUI@0ag)OYs^h#r_GgrnbpI)QLX_Q29Dv zw;Xffmp5>{z#DV?_hM<~AN2%pR!Rl+@tRiyu!AxA2Oias&X+ppVcz<`^Kk$N9H@_= zH%AUN>|11f-%QCE^oi}T9DwjhB!-l|@oVq4=zRaqX8B2SEcEtLOfAK+)Dpm}eDjV+ zPdr~G6nzZE`%iMq0%KaGno48kxhb!tl7B4*Z;mJ9B z;hj=_Scht5Fl^t?Z5B$sO2PCf^>qpQ!e^QSeJsZ8H3r(%`JlpbgiF!)B*izuPT@GXQ>Ux8E1z__%ULJMfmmqj8?f|CI(q<{FQ>+EM9IT09%J&~>r`9W7&KS&ppZwxY(dUba>bE{Zu&kC z-vB2Sc@FO>9_5u|lw)icULF$s^_n@6e>hW1b3XB4xst{wzG+v9$59-}Ip&%Y53hMN z=u@Z?wtb^D3^zU(__t-qaT=TFn>no#Ueb33Y=7nR$Cr~(H;kVylD2W+jhGw3iq}W; er`leK@jodTg{6S;e*VJ$NrV3XWBprU;Qs*=S88Yg literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.pdb b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.pdb new file mode 100644 index 0000000000000000000000000000000000000000..b11f1039430be99d7033b66a035182e08e6ae5be GIT binary patch literal 286208 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.xml b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.xml new file mode 100644 index 00000000..e51ea37b --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate32.xml @@ -0,0 +1,6711 @@ + + + + Spring.Data.NHibernate32 + + + + + Holds the references and configuration settings for a instance. + References are resolved by looking up the given object names in the root obtained by . + + + + + Holds the references and configuration settings for a instance. + + + + + Default value for property. + + + + + Default value for property. + + + + + Initialize a new instance of with default values. + + + Calling this constructor from your derived class leaves and + uninitialized. See and for more. + + + + + Initialize a new instance of with the given sessionFactory + and default values for all other settings. + + + The instance to be used for obtaining instances. + + + Calling this constructor marks all properties initialized. + + + + + Initialize a new instance of with the given values and references. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by the instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by the instance. + + + Calling this constructor marks all properties initialized. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Override this method to resolve an instance according to your chosen strategy. + + + + + Gets the configured instance to be used. + + + If the entity interceptor is not set by the constructor, this property calls + to obtain an instance. This allows derived classes to + override the behaviour of how to obtain the concrete instance. + + + + + Gets the configured instance to be used. + + + If this property is requested for the first time, is called. + This allows derived classes to override the behaviour of how to obtain the concrete instance. + + If the instance cannot be resolved. + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets or Sets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + The default session factory name to use when retrieving the Hibernate session factory from + the root context. + + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The configuration section to read setting variables from. + + + + Initializes a new instance. + + The type, who's name will be used to prefix setting variables with + The variable source to obtain settings from. + + + + Resolve the entityInterceptor by looking up + in the root application context. + + The resolved instance or + + + + Resolve the by looking up + in the root application context. + + The resolved instance or + + + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+
+ + + Check if the hibernate template property has been set. + + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Provide support for the open session in view pattern for lazily loaded hibernate objects + used in ASP.NET pages. + + jjx: http://forum.springframework.net/member.php?u=29 + Mark Pollack (.NET) + Erich Eichinger + Harald Radi + + + + Implementation of SessionScope that associates a single session within the using scope. + + + It is recommended to be used in the following type of scenario: + + using (new SessionScope()) + { + ... do multiple operation, possibly in multiple transactions. + } + + At the end of "using", the session is automatically closed. All transactions within the scope use the same session, + if you are using Spring's HibernateTemplate or using Spring's implementation of NHibernate 1.2's + ICurrentSessionContext interface. + + + It is assumed that the session factory object name is called "SessionFactory". In case that you named the object + in different way you can specify your can specify it in the application settings using the key + Spring.Data.NHibernate.Support.SessionScope.SessionFactoryObjectName. Values for EntityInterceptorObjectName + and SingleSessionMode can be specified similarly. + + + Note: + The session is managed on a per thread basis on the thread that opens the scope instance. This means that you must + never pass a reference to a instance over to another thread! + + + Robert M. (.NET) + Harald Radi (.NET) + + + + The logging instance. + + + + + Initializes a new instance of the class in single session mode, + associating a session with the thread. The session is opened lazily on demand. + + + + + Initializes a new instance of the class. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The name of the configuration section to read configuration settings from. + See for more info. + + The type, who's full name is used for prefixing appSetting keys + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + + The instance to be used for obtaining instances. + + + Specify the to be set on each session provided by this instance. + + + Set whether to use a single session for each request. See property for details. + + + Specify the flushmode to be applied on each session provided by this instance. + + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Initializes a new instance of the class. + + An instance holding the scope configuration + + If set to true associate a session with the thread. If false, another + collaborating class will associate the session with the thread, potentially by calling + the Open method on this class. + + + + + Sets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets/Sets a flag, whether this scope manages it's own session for the current logical thread or not. + + false if session is managed by this module. false otherwise + + + + Call Close(), + + + + + Opens a new session or participates in an existing session and + registers with spring's . + + + + + Close the current view's session and unregisters + from spring's . + + + + + Set whether to use a single session for each request. Default is "true". + If set to false, each data access operation or transaction will use + its own session (like without Open Session in View). Each of those + sessions will be registered for deferred close, though, actually + processed at request completion. + + + + + Gets the flushmode to be applied on each newly created session. + + + This property defaults to to ensure that modifying objects outside the boundaries + of a transaction will not be persisted. It is recommended to not change this value but wrap any modifying operation + within a transaction. + + + + + Get or set the configured SessionFactory + + + + + Get or set the configured EntityInterceptor + + + + + Gets a flag, whether this scope is in "open" state on the current logical thread. + + + + + Gets a flag, whether this scope manages it's own session for the current logical thread or not. + + + + + This sessionHolder creates a default session only if it is needed. + + + Although a NHibernateSession deferes creation of db-connections until they are really + needed, instantiation a session is imho still more expensive than this LazySessionHolder. (EE) + + + + + Session holder, wrapping a NHibernate ISession and a NHibernate Transaction. + HibernateTransactionManager binds instances of this class + to the thread, for a given ISessionFactory. + + + Note: This is an SPI class, not intended to be used by applications. + + Mark Pollack (.NET) + + + + May be used by derived classes to create an empty SessionHolder. + + + When using this ctor in your derived class, you MUST override ! + + + + + Initializes a new instance of the class. + + The session. + + + + Initializes a new instance of the class. + + The key to store the session under. + The hibernate session. + + + + May be overridden in a derived class to e.g. lazily create a session + + + + + Gets the session given key identifier + + The key. + A hibernate session + + + + Gets the session given the key and removes the session from + the dictionary storage. + + The key. + A hibernate session + + + + Adds the session to the dictionary storage using the default key. + + The hibernate session. + + + + Adds the session to the dictionary storage using the supplied key. + + The key. + The hibernate session. + + + + Removes the session from the dictionary storage for the given key. + + The key. + The session that was previously contained in the + dictionary storage. + + + + Determines whether the holder the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Clear the transaction state of this resource holder. + + + + + Gets the session using the default key + + The hibernate session. + + + + Gets the first session based on iteration over + the IDictionary storage. + + Any hibernate session. + + + + Gets a value indicating whether dictionary of + hibernate sessions is empty. + + + true if this session holder is empty; otherwise, false. + + + + + Gets a value indicating whether this SessionHolder + does not hold non default session. + + + true if does not hold non default session; otherwise, false. + + + + + Gets or sets the hibernate transaction. + + The transaction. + + + + Gets or sets the ADO.NET Connection used to create the session. + + The ADO.NET connection. + + + + Gets or sets the previous flush mode. + + The previous flush mode. + + + + Gets a value indicating whether the PreviousFlushMode property + was set. + + + true if assigned PreviousFlushMode property; otherwise, false. + + + + + Gets the validated session. + + The validated session. + + + + Initialize a new instance. + + + + + Create a new session on demand + + + + + Ensure session is closed (if any) and remove circular references to avoid memory leaks! + + + + + Initializes a new instance of the class. Creates a SessionScope, + but does not yet associate a session with a thread, that is left to the lifecycle of the request. + + + + + Register context handler and look up SessionFactoryObjectName under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SessionFactoryObjectName if not using the default value + (i.e. sessionFactory) and look up the SingleSession setting under the application configuration key, + Spring.Data.NHibernate.Support.OpenSessionInViewModule.SingleSession if not using the default value of true. + + The standard HTTP application context + + + + A do nothing dispose method. + + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for ADO.NET exceptions that Hibernate rethrew and could not be + mapped into the DAO exception heirarchy. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API - ADO.NET + + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Hibernate-specific subclass of InvalidDataAccessResourceUsageException, + thrown on invalid HQL query syntax. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateQueryException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Gets the query string that was invalid. + + The query string that was invalid. + + + + Hibernate-specific subclass of UncategorizedDataAccessException, + for Hibernate system errors that do not match any concrete + Spring.Dao exceptions. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Creates a new instance of the HibernateSystemException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute supporting Hibernate access code + implementing the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Mark Pollack (.NET) +
+ + + Base class for HibernateTemplate defining common + properties like SessionFactory and flushing behavior. + + +

Not intended to be used directly. See HibernateTemplate. +

+
+ Mark Pollack (.NET) +
+ + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Apply the flush mode that's been specified for this accessor + to the given Session. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + the previous flush mode to restore after the operation, + or null if none + + + + + Flush the given Hibernate Session if necessary. + + The current Hibernate Session. + if set to true + if executing within an existing transaction. + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + + + Note that a direct SQLException can just occur when callback code + performs direct ADO.NET access via ISession.Connection(). + + + The ADO.NET exception. + The corresponding DataAccessException instance + + + + Prepare the given IQuery object, applying cache settings and/or + a transaction timeout. + + The query object to prepare. + + + + Apply the given name parameter to the given Query object. + + The query object. + Name of the parameter + The value of the parameter + The NHibernate type of the parameter (or null if none specified) + + + + Prepare the given Criteria object, applying cache settings and/or + a transaction timeout. + + + Note that for NHibernate 1.2 this only works if the + implementation is of the type CriteriaImpl, which should generally + be the case. The SetFetchSize method is not available on the + ICriteria interface + + This is a no-op for NHibernate 1.0.x since + the SetFetchSize method is not on the ICriteria interface and + the implementation class is has internal access. + + To remove the method completely for Spring's NHibernate 1.0 + support while reusing code for NHibernate 1.2 would not be + possible. So now this ineffectual operation is left in tact for + NHibernate 1.0.2 support. + + The criteria object to prepare + + + + Ensure SessionFactory is not null + + If SessionFactory property is null. + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance. + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets a Session for use by this template. + + The session. + + - Returns a new Session in case of "alwaysUseNewSession" (using the same ADO.NET connection as a transaction Session, if applicable) + - a pre-bound Session in case of "AllowCreate" is set to false (not the default) + - or a pre-bound Session or new Session if no transactional or other pre-bound Session exists. + + + + + Helper class to determine if the FlushMode enumeration + was changed from its default value + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The flush mode. + + + + Gets or sets a value indicating whether the FlushMode + property was set.. + + true if FlushMode was set; otherwise, false. + + + + Gets or sets the FlushMode. + + The FlushMode. + + + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Mark Pollack (.NET) +
+ + + Interface that specifies a set of Hibernate operations that + are common across versions of Hibernate. + + + Base interface for generic and non generic IHibernateOperations interfaces + Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ Mark Pollack (.NET) + +
+ + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + Tthe persistent instance to delete. + The lock mode to obtain. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + a List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + a persistent type. + An identifier of the persistent instance. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + A persistent class. + An identifier of the persistent instance. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The default for creating a new non-transactional + session when no transactional Session can be found for the current thread + is set to true. + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional when no transactional Session can be found + for the current thread. + + + + Delegate function that clears the session. + + The hibernate session. + null + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + + The type. + An identifier of the persistent instance. + The persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The type. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + Type of the entity. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + Type of the entity. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + Type of the entity. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update all given persistent instances, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instances to save or update + (to be associated with the Hibernate Session)he entities. + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + If length for argument values and types are not equal. + + + + Delete all given persistent instances. + + The persistent instances to delete. + + This can be combined with any of the find methods to delete by query + in two lines of code, similar to Session's delete by query methods. + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + + + + Execute the action specified by the given action object within a Session. + + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning a result object, i.e. a domain + object or a collection of domain objects. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the specified action assuming that the result object is a List. + + + This is a convenience method for executing Hibernate find calls or + queries within an action. + + The calback object that specifies the Hibernate action. + A IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + + + + Execute a query for persistent instances. + + a query expressed in Hibernate's query language + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + a query expressed in Hibernate's query language + the value of the parameter + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + a query expressed in Hibernate's query language + the values of the parameters + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A List containing 0 or more persistent instances + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The name of a Hibernate query in a mapping file + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + A query expressed in Hibernate's query language + The values of the parameters + A List containing 0 or more persistent instances + In case of Hibernate errors + + + + Create a close-suppressing proxy for the given Hibernate Session. + The proxy also prepares returned Query and Criteria objects. + + The session. + The session proxy. + + + + Check whether write operations are allowed on the given Session. + + + Default implementation throws an InvalidDataAccessApiUsageException + in case of FlushMode.Never. Can be overridden in subclasses. + + The current Hibernate session. + If write operation is attempted in read-only mode + + + + + Compares if the flush mode enumerations, Spring's + TemplateFlushMode and NHibernates FlushMode have equal + settings. + + The template flush mode. + The NHibernate flush mode. + + Returns true if both are Never, Auto, or Commit, false + otherwise. + + + + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. + If object factory is not set and need to retrieve entity interceptor by name. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets whether to check that the Hibernate Session is not in read-only mode + in case of write operations (save/update/delete). + + + true if check that the Hibernate Session is not in read-only mode + in case of write operations; otherwise, false. + + + Default is "true", for fail-fast behavior when attempting write operations + within a read-only transaction. Turn this off to allow save/update/delete + on a Session with flush mode NEVER. + + + + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Set the object factory instance. + + The object factory instance + + + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Callback interface for NHibernate code. + + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object, or null if none. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Enumeration for the various Hibernate flush modes. + + Mark Pollack (.NET) + + + Never flush is a good strategy for read-only units of work. + + + Hibernate will not track and look for changes in this case, + avoiding any overhead of modification detection. +

In case of an existing ISession, TemplateFlushMode.Never will turn + the hibenrate flush mode + to FlushMode.Never for the scope of the current operation, resetting the previous + flush mode afterwards. +

+
+
+ + Automatic flushing is the default mode for a Hibernate Session. + + + A session will get flushed on transaction commit, and on certain find + operations that might involve already modified instances, but not + after each unit of work like with eager flushing. +

In case of an existing Session, TemplateFlushMode.Auto + will participate in the existing flush mode, not modifying + it for the current operation. + This in particular means that this setting will not modify an existing + hibernate flush mode FlushMode.Never, in contrast to TemplateFlushMode.Eager. +

+
+
+ + + Eager flushing leads to immediate synchronization with the database, + even if in a transaction. + + + This causes inconsistencies to show up and throw + a respective exception immediately, and ADO access code that participates + in the same transaction will see the changes as the database is already + aware of them then. But the drawbacks are: +
    +
  • additional communication roundtrips with the database, instead of a + single batch at transaction commit;
  • +
  • the fact that an actual database rollback is needed if the Hibernate + transaction rolls back (due to already submitted SQL statements).
  • +
+

In case of an existing Session, TemplateFlushMode.Eager + will turn the NHibernate flush mode + to FlushMode.Auto for the scope of the current operation and issue a flush at the + end, resetting the previous flush mode afterwards. +

+
+
+ + + Flushing at commit only is intended for units of work where no + intermediate flushing is desired, not even for find operations + that might involve already modified instances. + + +

In case of an existing Session, TemplateFlushMode.Commit + will turn the NHibernate flush mode + to FlushMode.Commit for the scope of the current operation, resetting the previous + flush mode afterwards. The only exception is an existing flush mode + FlushMode.Never, which will not be modified through this setting. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning an IList of result objects created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Convenient super class for Hibernate data access objects. + + + Requires a SessionFactory to be set, providing a HibernateTemplate + based on it to subclasses. Can alternatively be initialized directly with + a HibernateTemplate, to reuse the latter's settings such as the SessionFactory, + exception translator, flush mode, etc + + This base call is mainly intended for HibernateTemplate usage. + + This class will create its own HibernateTemplate if only a SessionFactory + is passed in. The "allowCreate" flag on that HibernateTemplate will be "true" + by default. A custom HibernateTemplate instance can be used through overriding + CreateHibernateTemplate. + + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Create a HibernateTemplate for the given ISessionFactory. + + + Only invoked if populating the DAO with a ISessionFactory reference! +

Can be overridden in subclasses to provide a HibernateTemplate instance + with different configuration, or a custom HibernateTemplate subclass. +

+
+ The new HibernateTemplate instance +
+ + + Check if the hibernate template property has been set. + + If HibernateTemplate property is null. + + + + Get a Hibernate Session, either from the current transaction or + a new one. The latter is only allowed if "allowCreate" is true. + + Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Either rely on a thread-bound + Session (via HibernateInterceptor), or use it in combination with + ReleaseSession. + + In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. + + + if a non-transactional Session should be created when no + transactional Session can be found for the current thread + + Hibernate session. + + If the Session couldn't be created + + + if no thread-bound Session found and allowCreate false + + + + + + Convert the given HibernateException to an appropriate exception from the + org.springframework.dao hierarchy. Will automatically detect + wrapped ADO.NET Exceptions and convert them accordingly. + + HibernateException that occured. + + The corresponding DataAccessException instance + + + The default implementation delegates to SessionFactoryUtils + and convertAdoAccessException. Can be overridden in subclasses. + + + + + Close the given Hibernate Session, created via this DAO's SessionFactory, + if it isn't bound to the thread. + + + Typically used in plain Hibernate code, in combination with the + Session property and ConvertHibernateAccessException. + + The session to close. + + + + Gets or sets the hibernate template. + + Set the HibernateTemplate for this DAO explicitly, + as an alternative to specifying a SessionFactory. + + The hibernate template. + + + + Gets or sets the session factory to be used by this DAO. + Will automatically create a HibernateTemplate for the given SessionFactory. + + The session factory. + + + + Get a Hibernate Session, either from the current transaction or a new one. + The latter is only allowed if the "allowCreate" setting of this object's + HibernateTemplate is true. + + +

Note that this is not meant to be invoked from HibernateTemplate code + but rather just in plain Hibernate code. Use it in combination with + ReleaseSession. +

+

In general, it is recommended to use HibernateTemplate, either with + the provided convenience operations or with a custom HibernateCallback + that provides you with a Session to work on. HibernateTemplate will care + for all resource management and for proper exception conversion. +

+
+ The Hibernate session. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning the result object created within the callback. + Note that there's special support for single step actions: + see HibernateTemplate.find etc. +

+
+ The type of result object + Sree Nivask (.NET) +
+ + + Generic version of the Helper class that simplifies NHibernate data access code + + +

Typically used to implement data access or business logic services that + use NHibernate within their implementation but are Hibernate-agnostic in their + interface. The latter or code calling the latter only have to deal with + domain objects.

+ +

The central method is Execute() supporting Hibernate access code which + implements the HibernateCallback interface. It provides NHibernate Session + handling such that neither the IHibernateCallback implementation nor the calling + code needs to explicitly care about retrieving/closing NHibernate Sessions, + or handling Session lifecycle exceptions. For typical single step actions, + there are various convenience methods (Find, Load, SaveOrUpdate, Delete). +

+ +

Can be used within a service implementation via direct instantiation + with a ISessionFactory reference, or get prepared in an application context + and given to services as an object reference. Note: The ISessionFactory should + always be configured as an object in the application context, in the first case + given to the service directly, in the second case to the prepared template. +

+ +

This class can be considered as a direct alternative to working with the raw + Hibernate Session API (through SessionFactoryUtils.Session). +

+ +

LocalSessionFactoryObject is the preferred way of obtaining a reference + to a specific NHibernate ISessionFactory. +

+
+ Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Interface that specifies a basic set of Hibernate operations. + + + Implemented by HibernateTemplate. Not often used, but a useful option + to enhance testability, as it can easily be mocked or stubbed. +

Provides HibernateTemplate's data access methods that mirror + various Session methods. See the NHibernate ISession documentation + for details on those methods. +

+
+ + Sree Nivask (.NET) + Mark Pollack (.NET) +
+ + + Return the persistent instance of the given entity type + with the given identifier, or if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lenths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Allows creation of a new non-transactional session when no + transactional Session can be found for the current thread + The session factory to create sessions. + + + + Initializes a new instance of the class. + + The session factory to create sessions. + if set to true allow creation + of a new non-transactional session when no transactional Session can be found + for the current thread. + + + + Remove all objects from the Session cache, and cancel all pending saves, + updates and deletes. + + + + + Delete the given persistent instance. + + The persistent instance to delete. + In case of Hibernate errors + + + + Delete the given persistent instance. + + Tthe persistent instance to delete. + The lock mode to obtain. + + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The value of the parameter. + The Hibernate type of the parameter (or null). + The number of entity instances deleted. + In case of Hibernate errors + + + + Delete all objects returned by the query. + + a query expressed in Hibernate's query language. + The values of the parameters. + Hibernate types of the parameters (or null) + The number of entity instances deleted. + In case of Hibernate errors + + + + Flush all pending saves, updates and deletes to the database. + + + Only invoke this for selective eager flushing, for example when ADO.NET code + needs to see certain changes within the same transaction. Else, it's preferable + to rely on auto-flushing at transaction completion. + + In case of Hibernate errors + + + + Load the persistent instance with the given identifier + into the given object, throwing an exception if not found. + + Entity the object (of the target class) to load into. + An identifier of the persistent instance. + If object not found. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + + The persistent instance to re-read. + In case of Hibernate errors + + + + Re-read the state of the given persistent instance. + Obtains the specified lock mode for the instance. + + The persistent instance to re-read. + The lock mode to obtain. + In case of Hibernate errors + + + + Determines whether the given object is in the Session cache. + + the persistence instance to check. + + true if session cache contains the specified entity; otherwise, false. + + In case of Hibernate errors + + + + Remove the given object from the Session cache. + + The persistent instance to evict. + In case of Hibernate errors + + + + Obtain the specified lock level upon the given object, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The he persistent instance to lock. + The lock mode to obtain. + If not found + In case of Hibernate errors + + + + Persist the given transient instance. + + The transient instance to persist. + The generated identifier. + In case of Hibernate errors + + + + Persist the given transient instance with the given identifier. + + The transient instance to persist. + The identifier to assign. + In case of Hibernate errors + + + + Update the given persistent instance. + + The persistent instance to update. + In case of Hibernate errors + + + + Update the given persistent instance. + Obtains the specified lock mode if the instance exists, implicitly + checking whether the corresponding database entry still exists + (throwing an OptimisticLockingFailureException if not found). + + The persistent instance to update. + The lock mode to obtain. + In case of Hibernate errors + + + + Save or update the given persistent instance, + according to its id (matching the configured "unsaved-value"?). + + Tthe persistent instance to save or update + (to be associated with the Hibernate Session). + In case of Hibernate errors + + + + Save or update the contents of given persistent object, + according to its id (matching the configured "unsaved-value"?). + Will copy the contained fields to an already loaded instance + with the same id, if appropriate. + + The persistent object to save or update. + (not necessarily to be associated with the Hibernate Session) + + The actually associated persistent object. + (either an already loaded instance with the same id, or the given object) + In case of Hibernate errors + + + + Copy the state of the given object onto the persistent object with the same identifier. + If there is no persistent instance currently associated with the session, it will be loaded. + Return the persistent instance. If the given instance is unsaved, + save a copy of and return it as a newly persistent instance. + The given instance does not become associated with the session. + This operation cascades to associated instances if the association is mapped with cascade="merge". + The semantics of this method are defined by JSR-220. + + The persistent object to merge. + (not necessarily to be associated with the Hibernate Session) + + An updated persistent instance + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The id of the object to get. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity type + with the given identifier, or null if not found. + Obtains the specified lock mode if the instance exists. + + The object type to get. + The lock mode to obtain. + The lock mode. + the persistent instance, or null if not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + + The object type to load. + An identifier of the persistent instance. + The persistent instance + If not found + In case of Hibernate errors + + + + Return the persistent instance of the given entity class + with the given identifier, throwing an exception if not found. + Obtains the specified lock mode if the instance exists. + + The object type to load. + An identifier of the persistent instance. + The lock mode. + The persistent instance + If not found + In case of Hibernate errors + + + + Return all persistent instances of the given entity class. + Note: Use queries or criteria for retrieving a specific subset. + + The object type to load. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances. + + The object type to find. + a query expressed in Hibernate's query language + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a "?" parameter in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the value of the parameter + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding one value + to a "?" parameter of the given type in the query string. + + The object type to find. + a query expressed in Hibernate's query language + The value of the parameter. + Hibernate type of the parameter (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to "?" parameters in the query string. + + The object type to find. + a query expressed in Hibernate's query language + the values of the parameters + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a number of + values to "?" parameters of the given types in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + Hibernate types of the parameters (or null) + + a generic List containing 0 or more persistent instances + + In case of Hibernate errors + If values and types are not null and their lengths are not equal + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + a generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding + one value to a named parameter in the query string. + + The object type to find. + The name of a Hibernate query in a mapping file + The name of the parameter + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding a + number of values to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The names of the parameters + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a "?" parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The value of the parameter + Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding a + number of values to "?" parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If values and types are not null and their lengths differ. + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + one value to a named parameter in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + Name of the parameter + The value of the parameter + The Hibernate type of the parameter (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a named query for persistent instances, binding + number of values to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The names of the parameters + The values of the parameters. + Hibernate types of the parameters (or null) + A generic List containing 0 or more persistent instances + In case of Hibernate errors + If paramNames length is not equal to values length or + if paramNames length is not equal to types length (when types is not null) + + + + Execute a named query for persistent instances, binding the properties + of the given object to named parameters in the query string. + A named query is defined in a Hibernate mapping file. + + The object type to find. + The name of a Hibernate query in a mapping file + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute a query for persistent instances, binding the properties + of the given object to named parameters in the query string. + + The object type to find. + A query expressed in Hibernate's query language + The values of the parameters + A generic List containing 0 or more persistent instances + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type retrieved. + The delegate callback object that specifies the Hibernate action. + a result object returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type retrieved. + The HibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + The callback object that specifies the Hibernate action. + + a result object returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ In case of Hibernate errors +
+ + + Execute the action specified by the given action object within a Session. + + The object type retrieved. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + a result object returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session assuming that an IList is returned. + + The object type to find. + callback object that specifies the Hibernate action. + if set to true expose the native hibernate session to + callback code. + + an IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+ The object type to find. + The delegate callback object that specifies the Hibernate action. + A generic IList returned by the action, or null + + In case of Hibernate errors +
+ + + Execute the action specified by the delegate within a Session. + + The object type to find. + The FindHibernateDelegate that specifies the action + to perform. + if set to true expose the native hibernate session to + callback code. + A generic IList returned by the action, or null + + In case of Hibernate errors + + + + Execute the action specified by the given action object within a Session. + + The object type to find. + The callback object that specifies the Hibernate action. + + A generic IList returned by the action, or null + + + Application exceptions thrown by the action object get propagated to the + caller (can only be unchecked). Hibernate exceptions are transformed into + appropriate DAO ones. Allows for returning the result object. +

Note: Callback code is not supposed to handle transactions itself! + Use an appropriate transaction manager like HibernateTransactionManager. + Generally, callback code must not touch any Session lifecycle methods, + like close, disconnect, or reconnect, to let the template do its work. +

+
+
+ + + Gets or sets if a new Session should be created when no transactional Session + can be found for the current thread. + + + true if allowed to create non-transaction session; + otherwise, false. + + +

HibernateTemplate is aware of a corresponding Session bound to the + current thread, for example when using HibernateTransactionManager. + If allowCreate is true, a new non-transactional Session will be created + if none found, which needs to be closed at the end of the operation. + If false, an InvalidOperationException will get thrown in this case. +

+
+
+ + + Gets or sets a value indicating whether to always + use a new Hibernate Session for this template. + + true if always use new session; otherwise, false. + +

+ Default is "false"; if activated, all operations on this template will + work on a new NHibernate ISession even in case of a pre-bound ISession + (for example, within a transaction). +

+

Within a transaction, a new NHibernate ISession used by this template + will participate in the transaction through using the same ADO.NET + Connection. In such a scenario, multiple Sessions will participate + in the same database transaction. +

+

Turn this on for operations that are supposed to always execute + independently, without side effects caused by a shared NHibernate ISession. +

+
+
+ + + Set whether to expose the native Hibernate Session to IHibernateCallback + code. Default is "false": a Session proxy will be returned, + suppressing close calls and automatically applying + query cache settings and transaction timeouts. + + true if expose native session; otherwise, false. + + + + Gets or sets the template flush mode. + + + Default is Auto. Will get applied to any new ISession + created by the template. + + The template flush mode. + + + + Gets or sets the entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + + + Will get applied to any new ISession created by this object. +

Such an interceptor can either be set at the ISessionFactory level, + i.e. on LocalSessionFactoryObject, or at the ISession level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. +

+
+ The interceptor. +
+ + + Set the object name of a Hibernate entity interceptor that allows to inspect + and change property values before writing to and reading from the database. + + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+ The name of the entity interceptor in the object factory/application context. +
+ + + Gets or sets the session factory that should be used to create + NHibernate ISessions. + + The session factory. + + + + Set the object factory instance. + + The object factory instance + + + + Gets or sets a value indicating whether to + cache all queries executed by this template. + + + If this is true, all IQuery and ICriteria objects created by + this template will be marked as cacheable (including all + queries through find methods). +

To specify the query region to be used for queries cached + by this template, set the QueryCacheRegion property. +

+
+ true if cache queries; otherwise, false. +
+ + + Gets or sets the name of the cache region for queries executed by this template. + + + If this is specified, it will be applied to all IQuery and ICriteria objects + created by this template (including all queries through find methods). +

The cache region will not take effect unless queries created by this + template are configured to be cached via the CacheQueries property. +

+
+ The query cache region. +
+ + + Gets or sets the fetch size for this HibernateTemplate. + + The size of the fetch. + This is important for processing + large result sets: Setting this higher than the default value will increase + processing speed at the cost of memory consumption; setting this lower can + avoid transferring row data that will never be read by the application. +

Default is 0, indicating to use the driver's default.

+
+
+ + + Gets or sets the maximum number of rows for this HibernateTemplate. + + The max results. + + This is important + for processing subsets of large result sets, avoiding to read and hold + the entire result set in the database or in the ADO.NET driver if we're + never interested in the entire result in the first place (for example, + when performing searches that might return a large number of matches). +

Default is 0, indicating to use the driver's default.

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Gets the classic hibernate template for access to non-generic methods. + + The classic hibernate template. + + + + Gets or sets the proxy factory. + + This may be useful to set if you create many instances of + HibernateTemplate and/or HibernateDaoSupport. This allows the same + ProxyFactory implementation to be used thereby limiting the + number of dynamic proxy types created in the temporary assembly, which + are never garbage collected due to .NET runtime semantics. + + The proxy factory. + + + + Callback interface (Generic version) for NHibernate code. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + + Sree Nivask (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ A result object. + The active Hibernate session +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Callback interface (Generic version) for NHibernate code that + returns a List of objects. + + The type of result object + To be used with HibernateTemplate execute + method. The typical implementation will call + Session.load/find/save/update to perform + some operations on persistent objects. + + Sree Nivask (.NET) + Mark Pollack (.NET) + + + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+ Collection result object. +
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Gets called by HibernateTemplate with an active + Hibernate Session. Does not need to care about activating or closing + the Session, or handling transactions. + + +

+ Allows for returning a result object created within the callback, i.e. + a domain object or a collection of domain objects. Note that there's + special support for single step actions: see HibernateTemplate.find etc. +

+
+
+ + + Helper class featuring methods for Hibernate Session handling, + allowing for reuse of Hibernate Session instances within transactions. + Also provides support for exception translation. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + The ordering value for synchronizaiton this session resources. + Set to be lower than ADO.NET synchronization. + + + + + Initializes a new instance of the class. + + + + + Get a new Hibernate Session from the given SessionFactory. + Will return a new Session even if there already is a pre-bound + Session for the given SessionFactory. + + + Within a transaction, this method will create a new Session + that shares the transaction's ADO.NET Connection. More specifically, + it will use the same ADO.NET Connection as the pre-bound Hibernate Session. + + The session factory to create the session with. + The Hibernate entity interceptor, or null if none. + The new session. + If could not open Hibernate session + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using HibernateTransactionManager. Will always create a new + Session otherwise. + + + Supports setting a Session-level Hibernate entity interceptor that allows + to inspect and change property values before writing to and reading from the + database. Such an interceptor can also be set at the SessionFactory level + (i.e. on LocalSessionFactoryObject), on HibernateTransactionManager, or on + HibernateInterceptor/HibernateTemplate. + + The session factory to create the + session with. + Hibernate entity interceptor, or null if none. + AdoExceptionTranslator to use for flushing the + Session on transaction synchronization (can be null; only used when actually + registering a transaction synchronization). + The Hibernate Session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. Is aware of and will + return any existing corresponding Session bound to the current thread, for + example when using . Will create a new Session + otherwise, if allowCreate is true. + + The session factory to create the session with. + if set to true create a non-transactional Session when no + transactional Session can be found for the current thread. + The hibernate session + + If the session couldn't be created. + + + If no thread-bound Session found and allowCreate is false. + + + + + Get a Hibernate Session for the given SessionFactory. + + Is aware of and will return any existing corresponding + Session bound to the current thread, for example whenusing + . Will create a new + Session otherwise, if "allowCreate" is true. +

Throws the orginal HibernateException, in contrast to + . +

+ The session factory. + if set to true [allow create]. + The Hibernate Session + + if the Session couldn't be created + + + If no thread-bound Session found and allowCreate is false. + +
+ + + Open a new Session from the factory. + + The session factory to create the session with. + Hibernate entity interceptor, or null if none. + the newly opened session + + + + Perform the actual closing of the Hibernate Session + catching and logging any cleanup exceptions thrown. + + The hibernate session to close + + + + Return whether the given Hibernate Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The hibernate session to check + The session factory that the session + was created with, can be null. + + true if the session transactional; otherwise, false. + + + + + Converts a Hibernate ADOException to a Spring DataAccessExcption, extracting the underlying error code from + ADO.NET. Will extract the ADOException Message and SqlString properties and pass them to the translate method + of the provided IAdoExceptionTranslator. + + The IAdoExceptionTranslator, may be a user provided implementation as configured on + HibernateTemplate. + + The ADOException throw + The translated DataAccessException or UncategorizedAdoException in case of an error in translation + itself. + + + + Convert the given HibernateException to an appropriate exception from the + Spring.Dao hierarchy. Note that it is advisable to + handle AdoException specifically by using a AdoExceptionTranslator for the + underlying ADO.NET exception. + + The Hibernate exception that occured. + DataAccessException instance + + + + Close the given Session, created via the given factory, + if it is not managed externally (i.e. not bound to the thread). + + The hibernate session to close + The hibernate SessionFactory that + the session was created with. + + + + Close the given Session or register it for deferred close. + + The session. + The session factory. + + + + Initialize deferred close for the current thread and the given SessionFactory. + Sessions will not be actually closed on close calls then, but rather at a + processDeferredClose call at a finishing point (like request completion). + + The session factory. + + + + Return if deferred close is active for the current thread + and the given SessionFactory. + The session factory. + + true if [is deferred close active] [the specified session factory]; otherwise, false. + + If SessionFactory argument is null. + + + + Process Sessions that have been registered for deferred close + for the given SessionFactory. + + The session factory. + If there is no session factory associated with the thread. + + + + Applies the current transaction timeout, if any, to the given + criteria object + + The Hibernate Criteria object. + Hibernate SessionFactory that the Criteria was created for + (can be null). + If criteria argument is null. + + + + Applies the current transaction timeout, if any, to the given + Hibenrate query object. + + The Hibernate Query object. + Hibernate SessionFactory that the Query was created for + (can be null). + If query argument is null. + + + + Gets the Spring IDbProvider given the ISessionFactory. + + The matching is performed by comparing the assembly qualified + name string of the hibernate Driver.ConnectionType to those in + the DbProviderFactory definitions. No connections are created + in performing this comparison. + The session factory. + The corresponding IDbProvider, null if no mapping was found. + If DbProviderFactory's ApplicaitonContext is not + an instance of IConfigurableApplicaitonContext. + + + + Create a IAdoExceptionTranslator from the given SessionFactory. + + If a corresponding IDbProvider is found, a ErrorcodeExceptionTranslator + for the IDbProvider is created. Otherwise, a FallbackException is created. + The session factory to create the translator for + An IAdoExceptionTranslator + + + + Implementation of NHibernates 1.2's ICurrentSessionContext interface + that delegates to Spring's SessionFactoryUtils for providing a + Spirng-managed current Session. + + Used by Spring's LocalSessionFactoryBean if told to expose + a transaction-aware SessionFactory. +

This ICurrentSessionContext implementation can also be specified in + custom ISessionFactory setup through the + "hibernate.current_session_context_class" property, with the fully + qualified name of this class as value.

+ Juergen Hoeller + Mark Pollack (.NET) + +
+ + + Initializes a new instance of the class + + The NHibernate session factory. + + + + Retrieve the Spring-managed Session for the current thread. + + Current session associated with the thread + On errors retrieving thread bound session. + + + + NHibnerations actions taken during the transaction lifecycle. + + Mark Pollack (.NET) + + + + The instance for this class. + + + + + Initializes a new instance of the class. + + + + + Suspend this synchronization. + + +

+ Unbind Hibernate resources (SessionHolder) from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Rebind Hibernate resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + + + If the transaction is defined as a read-only transaction. + + +

+ Can flush transactional sessions to the database. +

+

+ Note that exceptions will get propagated to the commit caller and + cause a rollback of the transaction. +

+
+
+ + + Invoked before transaction commit (before + ) + Can e.g. flush transactional O/R Mapping sessions to the database + + + + This callback does not mean that the transaction will actually be + commited. A rollback decision can still occur after this method + has been called. This callback is rather meant to perform work + that's only relevant if a commit still has a chance + to happen, such as flushing SQL statements to the database. + + + Note that exceptions will get propagated to the commit caller and cause a + rollback of the transaction. + + (note: do not throw TransactionException subclasses here!) + + + + + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Return the order value of this object, where a higher value means greater in + terms of sorting. + + +

+ Normally starting with 0 or 1, with indicating + greatest. Same order values will result in arbitrary positions for the affected + objects. +

+

+ Higher value can be interpreted as lower priority, consequently the first object + has highest priority. +

+
+ The order value. +
+ + + Convenient FactoryObject for defining Hibernate FilterDefinitions. + Exposes a corresponding Hibernate FilterDefinition object. + + + +

+ Typically defined as an inner object within a LocalSessionFactoryObject + definition, as the list element for the "filterDefinitions" object property. + For example: +

+ +
+            <objectn id="sessionFactory" type="Spring.Data.NHibernate.LocalSessionFactoryObject, Spring.Data.NHibernate">
+              ...
+              <property name="FilterDefinitions">
+               <list>
+                  <object type="Spring.Data.NHibernate.FilterDefinitionFactoryObject, Spring.Data.NHibernate">
+                    <property name="FilterName" value="myFilter"/>
+                    <property name="ParameterTypes">
+                      <props>
+                        <prop key="MyParam">string</prop>
+                        <prop key="MyOtherParam">long</prop>
+                      </props>
+                    </property>
+                  </object>
+                </list>
+              </property>
+              ...
+            </object>
+            
+

+ Alternatively, specify an object id (or name) attribute for the inner object, + instead of the "FilterName" property. +

+
+ Juergen Hoeller + Marko Lahma (.NET) + + + $Id: FilterDefiniitionFactoryObject.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ +
+ + + Initializes the filter definitions. + + + + + Returns the singleton filter definition. + + + + + + Set the name of the filter. + + + + + Set the parameter types for the filter, + with parameter names as keys and type names as values. + + + + + + Specify a default filter condition for the filter, if any. + + + + + If no explicit filter name has been specified, the object name of + the FilterDefinitionFactoryObject will be used. + + + + + + Returns the type of the object this factory produces. + + + + + Returns whether this factory produces singletons, always true. + + + + + Hibernate-specific subclass of ObjectRetrievalFailureException. + + + Converts Hibernate's UnresolvableObjectException, ObjectNotFoundException, + ObjectDeletedException, and WrongClassException. + + Mark Pollack (.NET) + $Id: HibernateObjectRetrievalFailureException.cs,v 1.1 2008/04/07 20:12:53 lahma Exp $ + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The ex. + + + + Creates a new instance of the HibernateObjectRetrievalFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Hibernate-specific subclass of ObjectOptimisticLockingFailureException. + + + Converts Hibernate's StaleObjectStateException. + + Mark Pollack (.NET) + $Id: HibernateOptimisticLockingFailureException.cs,v 1.2 2008/04/23 11:41:41 lahma Exp $ + + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class. + + The ex. + + + + Initializes a new instance of the class. + + The StaleStateException. + + + + Creates a new instance of the HibernateOptimisticLockingFailureException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + An IFactoryObject that creates a local Hibernate SessionFactory instance. + Behaves like a SessionFactory instance when used as bean reference, + e.g. for HibernateTemplate's "SessionFactory" property. + + + The typical usage will be to register this as singleton factory + in an application context and give objects references to application services + that need it. + + Hibernate configuration settings can be set using the IDictionary property 'HibernateProperties'. + + + This class implements the interface, + as autodetected by Spring's + for AOP-based translation of PersistenceExceptionTranslationPostProcessor. + Hence, the presence of e.g. LocalSessionFactoryBean automatically enables + a PersistenceExceptionTranslationPostProcessor to translate Hibernate exceptions. + + + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Return the singleon session factory. + + The singleon session factory. + + + + Initialize the SessionFactory for the given or the + default location. + + + + + Close the SessionFactory on application context shutdown. + + + + + Subclasses can override this method to perform custom initialization + of the Configuration instance used for ISessionFactory creation. + + + The properties of this LocalSessionFactoryObject will be applied to + the Configuration object that gets returned here. +

The default implementation creates a new Configuration instance. + A custom implementation could prepare the instance in a specific way, + or use a custom Configuration subclass. +

+
+ The configuration instance. +
+ + + To be implemented by subclasses that want to to register further mappings + on the Configuration object after this FactoryObject registered its specified + mappings. + + + Invoked before the BuildMappings call, + so that it can still extend and modify the mapping information. + + the current Configuration object + + + + To be implemented by subclasses that want to to perform custom + post-processing of the Configuration object after this FactoryObject + performed its default initialization. + + The current configuration object. + + + + Executes schema update if requested. + + + + + Execute schema drop script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryBean itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfb = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema creation script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaExport class, to be invoked on application setup. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute schema update script, determined by the Configuration object + used for creating the SessionFactory. A replacement for NHibernate's + SchemaUpdate class, for automatically executing schema update scripts + on application startup. Can also be invoked manually. + + + Fetch the LocalSessionFactoryObject itself rather than the exposed + SessionFactory to be able to invoke this method, e.g. via + LocalSessionFactoryObject lsfo = (LocalSessionFactoryObject) ctx.GetObject("mySessionFactory");. +

+ Uses the SessionFactory that this bean generates for accessing a ADO.NET + connection to perform the script. +

+
+
+ + + Execute the given schema script on the given ADO.NET Connection. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override the ExecuteSchemaStatement + method to treat failures differently. + + The connection to use. + The SQL statement to execute. + + + + Execute the given schema SQL on the given ADO.NET command. + + + Note that the default implementation will log unsuccessful statements + and continue to execute. Override this method to treat failures differently. + + + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + Implementation of the PersistenceExceptionTranslator interface, + as autodetected by Spring's PersistenceExceptionTranslationPostProcessor. + Converts the exception if it is a HibernateException; + else returns null to indicate an unknown exception. + translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + The exception thrown. + + the corresponding DataAccessException (or null if the + exception could not be translated. + + + + + + Convert the given HibernateException to an appropriate exception from the + Spring's DAO Exception hierarchy. + Will automatically apply a specified IAdoExceptionTranslator to a + Hibernate ADOException, else rely on Hibernate's default translation. + + The Hibernate exception that occured. + A corresponding DataAccessException + + + + Converts the ADO.NET access exception to an appropriate exception from the + org.springframework.dao hierarchy. Can be overridden in subclasses. + + ADOException that occured, wrapping underlying ADO.NET exception. + + the corresponding DataAccessException instance + + + + + Setting the Application Context determines were resources are loaded from + + + + + Gets or sets the to use for loading mapping assemblies etc. + + + + + Sets the assemblies to load that contain mapping files. + + The mapping assemblies. + + + + Sets the hibernate configuration files to load, i.e. hibernate.cfg.xml. + + + + + Sets the locations of Spring IResources that contain mapping + files. + + The location of mapping resources. + + + + Return the Configuration object used to build the SessionFactory. + Allows access to configuration metadata stored there (rarely needed). + + The hibernate configuration. + + + + Set NHibernate configuration properties, like "hibernate.dialect". + + The hibernate properties. + +

Can be used to override values in a NHibernate XML config file, + or to specify all necessary properties locally. +

+

Note: Do not specify a transaction provider here when using + Spring-driven transactions. It is also advisable to omit connection + provider settings and use a Spring-set IDbProvider instead. +

+
+
+ + + Get or set the DataSource to be used by the SessionFactory. + + The db provider. + + If set, this will override corresponding settings in Hibernate properties. + Note: If this is set, the Hibernate settings should not define + a connection string + (hibernate.connection.connection_string) to avoid meaningless double configuration. + + + + + + Gets or sets a value indicating whether to expose a transaction aware session factory. + + + true if want to expose transaction aware session factory; otherwise, false. + + + + + Set a NHibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + Will get applied to any new Session created by this factory. +

Such an interceptor can either be set at the SessionFactory level, i.e. on + LocalSessionFactoryObject, or at the Session level, i.e. on HibernateTemplate, + HibernateInterceptor, and HibernateTransactionManager. It's preferable to set + it on LocalSessionFactoryObject or HibernateTransactionManager to avoid repeated + configuration and guarantee consistent behavior in transactions.

+
+ + +
+ + + Set a Hibernate NamingStrategy for the SessionFactory, determining the + physical column and table names given the info in the mapping document. + + + + + Specify the Hibernate type definitions to register with the SessionFactory, + as Spring IObjectDefinition instances. This is an alternative to specifying + <typedef> elements in Hibernate mapping files. +

Unfortunately, Hibernate itself does not define a complete object that + represents a type definition, hence the need for Spring's TypeDefinitionBean.

+ @see TypeDefinitionBean + @see org.hibernate.cfg.Mappings#addTypeDef(String, String, java.util.Properties) +
+
+ + + Specify the NHibernate FilterDefinitions to register with the SessionFactory. + This is an alternative to specifying <filter-def> elements in + Hibernate mapping files. + + + Typically, the passed-in FilterDefinition objects will have been defined + as Spring FilterDefinitionFactoryBeans, probably as inner beans within the + LocalSessionFactoryObject definition. + + + + + + Specify the cache strategies for entities (persistent classes or named entities). + This configuration setting corresponds to the <class-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="entityCacheStrategies">
+              <props>
+                <prop key="MyCompany.Customer">read-write</prop>
+                <prop key="MyCompany.Product">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the cache strategies for persistent collections (with specific roles). + This configuration setting corresponds to the <collection-cache> entry + in the "hibernate.cfg.xml" configuration format. +

For example: +

+            <property name="CollectionCacheStrategies">
+              <props>
+                <prop key="MyCompany.Order.Items">read-write</prop>
+                <prop key="MyCompany.Product.Categories">read-only,myRegion</prop>
+              </props>
+            </property>
+

+
+
+ + + Specify the NHibernate event listeners to register, with listener types + as keys and listener objects as values. +

+ Instead of a single listener object, you can also pass in a list + or set of listeners objects as value. +

+
+ listener objects as values + + See the NHibernate documentation for further details on listener types + and associated listener interfaces. + +
+ + + Set whether to execute a schema update after SessionFactory initialization. +

+ For details on how to make schema update scripts work, see the NHibernate + documentation, as this class leverages the same schema update script support + in as NHibernate's own SchemaUpdate tool. +

+
+
+ + + Set the ADO.NET exception translator for this instance. + Applied to System.Data.Common.DbException (or provider specific exception type + in .NET 1.1) thrown by callback code, be it direct + DbException or wrapped Hibernate ADOExceptions. +

The default exception translator is either a ErrorCodeExceptionTranslator + if a DbProvider is available, or a FalbackExceptionTranslator otherwise +

+
+ The ADO exception translator. +
+ + + Sets custom byte code provider implementation to be used. This corresponds to setting + the property before NHibernate session factory + configuration. + + + + + Return the type or subclass. + + The type created by this factory + + + + Returns true + + true + + + + The Spring for .NET-backed ByteCodeprovider for NHibernate + + Fabio Maulo + + + + Creates a new bytecode Provider instance using the specified object factory + + + + + + Retrieve the delegate for this provider + capable of generating reflection optimization components. + + The class to be reflected upon.All property getters to be accessed via reflection.All property setters to be accessed via reflection. + The reflection optimization delegate. + + + + The specific factory for this provider capable of + generating run-time proxies for lazy-loading purposes. + + + + + NHibernate's object instaciator. + + + For entities and its implementations. + + + + + Instanciator of NHibernate's collections default types. + + + + + + + Fabio Maulo + + + + + + + + + + + + + + + Implement this method to perform extra treatments before and after + the call to the supplied . + + +

+ Polite implementations would certainly like to invoke + . +

+
+ + The method invocation that is being intercepted. + + + The result of the call to the + method of + the supplied ; this return value may + well have been intercepted by the interceptor. + + + If any of the interceptors in the chain or the target object itself + throws an exception. + +
+ + + + + Fabio Maulo + + + + + + + + + Creates an instance of the specified type. + + The type of object to create. + A reference to the created object. + + + + Creates an instance of the specified type. + + The type of object to create.true if a public or nonpublic default constructor can match; false if only a public default constructor can match. + A reference to the created object + + + + Creates an instance of the specified type using the constructor that best matches the specified parameters. + + The type of object to create.An array of constructor arguments. + A reference to the created object. + + + + A Spring for .NET backed implementation for creating + NHibernate proxies. + + + Erich Eichinger + + + + Creates a new proxy. + + The id value for the proxy to be generated. + The session to which the generated proxy will be associated. + The generated proxy. + Indicates problems generating requested proxy. + + + + Creates a Spring for .NET backed instance. + + Erich Eichinger + + + + Build a proxy factory specifically for handling runtime lazy loading. + + The lazy-load proxy factory. + + + + + + + + + + + + + + + + + + Fabio Maulo + + + + + + + + + + + + Perform instantiation of an instance of the underlying class. + + The new instance. + + + + + + + + + + Delegates to an implementation of ISessionFactory that can select among multiple instances based on + thread local storage. + + + + + Subclasses can override this method to perform custom initialization + of the SessionFactory instance, creating it via the given Configuration + object that got prepared by this LocalSessionFactoryObject. + + +

The default implementation invokes Configuration's BuildSessionFactory. + A custom implementation could prepare the instance in a specific way, + or use a custom ISessionFactory subclass. +

+
+ The ISessionFactory instance. +
+ + + PostProcessConfiguration + + + + + + DelegatingSessionFactory class + + + + + PlatformTransactionManager implementation for a single Hibernate SessionFactory. + Binds a Hibernate Session from the specified factory to the thread, potentially + allowing for one thread Session per factory + + + SessionFactoryUtils and HibernateTemplate are aware of thread-bound Sessions and participate in such + transactions automatically. Using either of those is required for Hibernate + access code that needs to support this transaction handling mechanism. + + Supports custom isolation levels at the start of the transaction + , and timeouts that get applied as appropriate + Hibernate query timeouts. To support the latter, application code must either use + HibernateTemplate (which by default applies the timeouts) or call + SessionFactoryUtils.applyTransactionTimeout for each created + Hibernate Query object. + + Note that you can specify a Spring IDbProvider instance which if shared with + a corresponding instance of AdoTemplate will allow for mixing ADO.NET/NHibernate + operations within a single transaction. + + Mark Pollack (.NET) + + + + Just needed for entityInterceptorBeanName. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The session factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Does the tx scope commit. + + The status. + + + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Does the tx scope rollback. + + The status. + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Does the tx scope set rollback only. + + The status. + + + + Gets the ADO.NET IDbTransaction object from the NHibernate ITransaction object. + + The hibernate transaction. + The ADO.NET transaction. Null if could not get the transaction. Warning + messages will be logged in that case. + + + + Convert the given HibernateException to an appropriate exception from + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The HibernateException that occured. + The corresponding DataAccessException instance + + + + Convert the given ADOException to an appropriate exception from the + the Spring.Dao hierarchy. Can be overridden in subclasses. + + The ADOException that occured, wrapping the underlying + ADO.NET thrown exception. + The translator to convert hibernate ADOExceptions. + + The corresponding DataAccessException instance + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + This implemenation unbinds the SessionFactory and + DbProvider from thread local storage and closes the + ISession. + +

+ Called after + and + + execution on any outcome. +

+

+ Should not throw any exceptions but just issue warnings on errors. +

+
+
+ + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets a Hibernate entity interceptor that allows to inspect and change + property values before writing to and reading from the database. + When getting, return the current Hibernate entity interceptor, or null if none. + + The entity interceptor. + + Resolves an entity interceptor object name via the object factory, + if necessary. + Will get applied to any new Session created by this transaction manager. + Such an interceptor can either be set at the SessionFactory level, + i.e. on LocalSessionFactoryObject, or at the Session level, i.e. on + HibernateTemplate, HibernateInterceptor, and HibernateTransactionManager. + It's preferable to set it on LocalSessionFactoryObject or HibernateTransactionManager + to avoid repeated configuration and guarantee consistent behavior in transactions. + + If object factory is null and need to get entity interceptor via object name. + + + + Sets the object name of a Hibernate entity interceptor that + allows to inspect and change property values before writing to and reading from the database. + + The name of the entity interceptor object. + + Will get applied to any new Session created by this transaction manager. +

Requires the object factory to be known, to be able to resolve the object + name to an interceptor instance on session creation. Typically used for + prototype interceptors, i.e. a new interceptor instance per session. +

+

Can also be used for shared interceptor instances, but it is recommended + to set the interceptor reference directly in such a scenario. +

+
+
+ + + Gets or sets the ADO.NET exception translator for this transaction manager. + + + Applied to ADO.NET Exceptions (wrapped by Hibernate's ADOException) + + The ADO exception translator. + + + + Gets the default IAdoException translator, lazily creating it if nece + + The default IAdoException translator. + + + + Gets or sets the SessionFactory that this instance should manage transactions for. + + The session factory. + + + + Gets the resource factory that this transaction manager operates on, + For the HibenratePlatformTransactionManager this the SessionFactory + + The SessionFactory. + + + + Set whether to autodetect a ADO.NET connection used by the Hibernate SessionFactory, + if set via LocalSessionFactoryObject's DbProvider. Default is "true". + + + true if [autodetect data source]; otherwise, false. + + +

Can be turned off to deliberately ignore an available IDbProvider, + to not expose Hibernate transactions as ADO.NET transactions for that IDbProvider. +

+
+
+ + + The object factory just needs to be known for resolving entity interceptor + It does not need to be set for any other mode of operation. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + SimpleDelegatingSessionFactory class + + + + + Connection string config element name + + + + + public Constructor + + + + + + TargetSessionFactory + + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Data.dll b/Resources/Libraries/Spring.NET/Spring.Data.dll new file mode 100644 index 0000000000000000000000000000000000000000..6606df3085aca5f98e244848a8d630eea3d4d6e4 GIT binary patch literal 384000 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

#N7ql0Rp}oSPi@icqi}!z`KBJfg6FFfarvE z4+8H7J_7t85bFu=-uI7ywcuX>ehBzG;D>=$3H3mGKifxu_<6S75wPv8cc1$V;77sR z``SJRoCjh}TLpvulFk;nQV z>Y@YuY~WWQHy`*_;KjgBU>*?tr*1J2>+HHEK&(0IY%Pki)h!2Ne#gH3670Jo78!1|EM za;+aZV?ou0?*sh=vM1q}t4@|{@#wM#JlS)?vRp?;m;IF|J1Z>9HE?uU^d;nhcaki> zT)#$_eSJ*2Tzf{Boq%JOlknRBS2nI2qsvb9Wcdwl%LCVY(Ph!Mk#44!uAK#NofiFF z8)rk->{L4N1mJ9-y)QBeqc#a6(dCV6tmyhK@bvLpc$PP=i=xZsda{u+b4?Rn_DWAS z()L_$M3=>HWl`qH^Ej>#qRZaq$)aprxQypoc+Ef?fi>0XqHEU|<1g186Jg3DC2kS3#5UgX`I#JkSczJ)lQH zdqA&(CZCRQP#$O*Xd~!RkhvI;TdQGy@|=wi=hAVA@gL`Dj>Y}q$hLX$8ryW4+>y+y zb|_-!B5tqqiWFI!I5!Id!%nBo>-b*QvC`}IIybTSILnNwQ;R##K(I z?-}W{`v%Tou8cbo1Jesa-A1kmc~?q~O5Y`zPt9Q|7IqoXcc#;4^*To3c-qm%j@e%J zk?6lA+<-1`?OP2z9(X4(5nnbia_>Pfd&)MCKK|}OoFvT0ZmhDMBJV`9I&|~yW>2;( zZ1-5lk-HmKHKxy8BV?_PJ^{3E@A&h>x{7{(p~chjuCP6L^-M20Sj|9S560F@pf^A> zQ*h@Gv<$Qnv>mhy^epIqg0u1Oo}WLX44vc4*dJo>Z7wV@z1)s@{1Gy@4D)>YuBvXFz)99){bMJ3%EN~3sk*+yYinX%Y-_W1$kRrzAm(M z&5_wJs}Bq#%)q=4@R0QQ?@Yc1nRut?y6W|7L#tOHt4B1RogUXVs3gz%&!&c<=Zrd) z$KEZ2p9>wy7t$X zmch%gsc(R$W3xLKvM{pW1V^QsWP z&BSl};$qM!UTuxB|JxvMvM${J%rEk^YVMK(y;xqIjvdkw?-T&P1eueLfev@JH#N!}@MY*Y-RUUU7+PMvA#~mH@>S*Q zj?6Z@^0;;R<|w)zgRTps>f)jF3h$Z3`1G1Rv@y)S6tSI_4YR4{&V?;7n>`m8A2==i z`y7kMwv4{#%fk7T_0tQycqyaev3;W7C%G8$tk1m5i#KyrJl1){=KAxw5b~z)QXt=< zxjeiUW&K5u2Yc(qEA-;oZ?diouP=Xr!ke27ntmqsbD%uXQqU?;9cVk~anLiM*Ff*Y z#X!jQ;mL}U>Wc_3tMaJh-`0z%76@li-}L-Hf6dzbRjVq>S1%9E!`~+7zw>2Yemej@ zye9PfFDhRX_UG?PqTVs_){z&!-F;GI)XHr0si8S5pnoi{vckZndjIktv~Qg8UXbkI zk=P5w8?|nHPCBfgIET4EE)R?sWc#!H6?Osth}Jw~^|*bY)Oo5z=dBjs7LregI5SSa|7r|z6C_bzFFnb3xDSldvSmFXyTnLV<+o3k^a zRPQhL8C!FiGrMAaX933RiNI{2Z3D4xfqk;`;@d$tgx5lrUMlFV(zErQrT1Q?m#6gd zz4Y!zTBW1Xn+aLScrTZ)^pb)o}F=7SxlB~ZrbVmve!X&I!;2JEZZ$&hyAiQ zdFe*ZHd*h{(=GF4r-$vB(``0;YAWg#bTQ~E&moF9hc?o0ubcZAU7R#wPT0s z%Jv|<4O(PxA+tO4^HIO|BA&%@a%bS3Io1Z-M&ErO^{yrB%45RA?*X!O@ytG8=QVdg z?$I68e=5=i>x(z~9b|hDrw(zj?hky^7st9lL>Jy~c?9nudkvBAL7KJ)`jszDJJa^3 zc`V*RX8qFI)jhj@+$s@nkM}SCNrKF|ZEBCv@9HXFrJK4|e|wPUI>fiQPW~*_UsJeU z@V=w+_58+?z71e9R$qRZTdP*TzhcA6@I7FYLGq(yES*Jb+!qG;emAQle>%${v|e}b zEe$K4KOCX{>-pY0;;f(eWpJeuFC=3kmPXu|aOCw;pBk@^29S|FD4P!1Zq=RjB^wL= zv^UtLc{pnWt3!)-58~MwexKr5-<~`sUdUY^R$R`l@BH1@W83|8D-_(Xts&%2M!Wx3 zc?kTSc7Fo-eG2g{u9LSsTax#O+kNzJQ7qi*VobO#XyI7Pgx}d536G3XYbUD)e;E6~`he?)qr&VZc@?W~V`p9Owd3ok6TEZSo;d}k ze4b+l}L@Yt|^lZSXug5nXkU2$hY zpY>&b+;ySbs&S~zxEdFx-_en*>Bjb9fbUMfR4ntQqcaHz6Hj%hO6n4qb^Rmr+;UNId-htipTuV)?onyto8!*tED0BJSge z`#s1`dYEl!ajgpcamV&YH%9z2czD0O;?|1guG3oj&m#R@NPjERo2m4z%oE3?kNX9@ z*1jI!r9e1_$teBn@iy<}D=%GFfv4OR<&?30@7G^BW{kT2?r=PP(4F@$HA4gEzq^ov z_vi)N)$hmg{WI79{(y8BgFdpu(u%yF&guaBeb3oG0Yl&TI%` zo52?XmjMyxz02+v;BxS{11-JvK$E`@cpG^CJL#rkC7p!Qy!AWj-itGp48*i^WWJN` zRs790M=)HD6XExg3Bf_1_YUg~Kr2f%@HF6E*!$Rgb2oU@qxZc0GGHzED}WycE(6vB zD}bATNW;4ujxg_T_$PoLga4<2_X1&ly|O(FYykfV5cOR5U0@?H0k;EqkJ_HYZ^hr2 z1!8cYI>viPTn#W^ewP9-MG4;vdN*QY^NOc;v8Y*hPhtrMBj?;;c6w8ToTW|iR#pMj#r3EY+gZ;=e>n$X>F`^Jrv^6j+FUdXd>*J8;e}XN-3a+P zphaFd{caBTCs(iY5z2Wh`n%Noke>vT0mk5osEaofew=$EdwXO*{4Am0i^q5ST#NwD z1^5oT2}#cFAO9#FRtMIG##`IH4x9`83osja71_PVF3dF1P>Z}c?1D^s~dZ_mRuGQ8(4a7CPI+Qzb1`y@&@-qlD zIq0y*3*PS}&I0DxQ(L%`z59t*p`Xu2{hPHgJGlgOHK-Ky0nlY2Yo83z6135ko?J4< zM51R43h^umPm$s5-I}hht&M17BlmtLz|Y#i-1(@N=|Ib0oPB8k?lq9vw#Anj7eLRz z?=z6$M?rf)FMwVHoqjg%34?9|Z2&z4dK~l&=q1p!nRs>#$^)5;0lE2Lk9ojNB6$D) z0&9iScAL$GdyDfw7w+Hx|4%vp|99m7tTFjNk~!1LZ*#4yqiE;Gpv|D|pk1J+ zKret^1^pwtw;TTtVe0OQ|NG@n0~=jrBbkL%nZbaWg;9qwH))0_g}@1Wy}W2nPDD@pU|_&szyeGGKCzU#g# zYv#ip>$T@NRa{T+kxW^`Nz&&7g-syFgEaUIP7Za#rVV zZ?i`k_uGH$XyaankXNd=*#Eik|8BeQmh!fja1MKfxZjV-|B;M+E5G0FN8A5l{}G4Z zEsd(9qtOv<{fBWFhr^(w*5THFY_o_B8@rFQ{U7&n_9ef$;r$rvGWz=OT^Li=cMK=u zETjn5!|7xFL|?~UrghxqUcAxkKbARqyb{H;^If;zbmJJ`$@W|-{(S>ua@sjK_W)f2 zS_)bTsslX;`bT#D@&BAE;zD1AEX5p}v~zU7bL+mXkTY2q?jQgD?>xKT{P^!~9LwK< znw=kePs7cE3e&*i#80N)QC zE61hdeD8PRt{m=J;YR83+yCpKquuH7*8l6uSFh&>&wQVmz#Q_b?sumzN6}jf zy^s0zj`^U(c=Wlo;!^7{aQ<@M0DWKg>+|h%jz-rW>GID>H$vC9oG!a3bc}S_9lNpR zx(T|z=X6>7jq{rouFYH>ZkH~9xyqoc$LX?i9i=YUKPF?|8(XdqKv$pB<&{g{Q@`xU zzjflu=JaipK7ZM6hQ8;WKCf)YPT$K>%C`*qUUd4bd{?h=Z)@;MIG#S~%7-!SIe+=e zq3_pDpOx6{i{{CoH)p!~SZ05~*_!D%AfA?b&&*)w>r%kmo^UoW4{IIlEpexo&(4Z~@iH&%IqyW5t@mUj?+oIc5ncAOhZS|F8%2Jm?ir3@*XV0L=$2 z0^J0<7qkQP6zB!e>!4{FI7B~Z*9oLhq~0WAe>0Br^B0X+|z zdam{2qjNEc?(U>Lt>o~$JnU|Rja>W{t^cnJZOC80G_-L;yKeD=9=HMWzXGoE<-wM4et9nsiZdDVYe8p%-{Xs8_3Dok?VGf= zhcFt?-E_;-*gcPHM|=08IsbgS679I+t7=D^Z{Np{t=>hJd=JGS1*2io4$?vqRd7Jx^7aGJ|C#^pfkzZO0dSO`87Xlo73%{YY) z)Ir7zH`8Zp4|}|R4e(a^-vL|#-sbvif%gGzeSx{gi`N2N3jPtGtuwIf^8C?NynA_1 z0+FV72g~wdec}f22Z1*Me-AYOA>hs6C!vg%Z?hMMxclRMa~7|=3#@^eOMY z8cc5;%#8Q$*j+$`*L@9mH}G-bJ-}}O?VS4wU>*Md7H|{L?xDqDCL_%Q&Ie_I>|WWq zph_<<$d~$W(Cf=!QATf#XMcKk1q%d2sn|Bq+BvLs_B{Oxa3fk?}nN8Eh%q6NZPA9L=L(7V&=wfSmM=$7i+ zEU)j}R$AW8zPf#{-8nVq*Ru^WkNfrb4kk@@Jo?-j$&*p^H9_CE{rdDawa|*A(}j0Q zdd|PUy&t;1=XBZr_894UP`do}_yBbM$mz278t2)MYcn?=+nj37uj@hR>htTu`$4a( zS-pJax;3jS?&jA8$J1_3=RHw$Hbdw0ew})+UucE>_^^5%zLR=XedXmSIzI)S|2|4* z`JJJ)_70V!>nlrb(8Kxr%BP|0Kb$V>E7u*JE;r_$lCA`*^#0urUB7d>tgqlbt3Gu{ zRgdm>zkYo!(DxUo?*Veu{1LM)}#s=EXbBR9v4?+KBqxEA%jy9y@(dqioWDS15 z&Q|Drzh9?29UaH_m|eR%eH*3EKR*5m`c^u9*aweMH?B5yb^40*`EA_ipl_|yXJh25 zHF&GrXszR^Q>Sy83YY3@#~sjlmtW`QtJd5yM(KETx_Y(WO_}qL%{J)#w9|R%x==Y@ zUl*}F;~OikjP5%ietn;ZzK5MYSDpCg^wH{cWwhU&jVkN(>okA$3VUC7MC*8Ty61#Dq%+;8vmH8r>U2ixb#chA6!PQI z>&iOa4#?sBdLMz_KZW(OZpSJek51c@*?O33U)&uv#c$&K%ANFJ;>2e(wUG`&RWVwEdE^GT$xBs?sa{Uv%oZBF4=!&)mh%$CIi55ELw5d0>FwZTQ+*oZv4@#pQkp1#O87C46o!w0H<*=M};7lh0F zex>W?WWVgcda@UV`w!>M==J&vWUXEYy}X=>-P)wE4$gnk+wKj>+xviB8{DP*q#`YI z{`|z?cVow6RGO^S-=`&OW7eE)XRNNw;ZyV8`{3=jWHC4ycVp4wao&iuoj=|giig*3 zBHo3g;?ed;kB4J^Palr+5ijz4JZpd2aJO~f3oy!d60b3?}_~*#KSO*CSP$(%EvAwzwZTNy)aie@^AD{>L&I*L2MKj3UgK7eae5U^53F-AHo5-<+oi} zQ$xNpnOFn^X5k0on6DB{BF1kir+*C$pz+yP5zAHYjVF@N&6M0d#7Zo9Oul|Iu|WMi zN9|agP5;AcmnuAdF!{{s#N0*1p4W&ivx&vZe@P?xL_CAGcwx-WkL*#S%AK)_=v@WRMQ(Txe?WC zXF26+uOg=7qJzoxYuq-<-WAKNgKyEZJlRw29A zD7)5kG2=DKKIY1 z#zy)#qwrS#gRB%Ui|4!BafX03Obo!6% zAP&gRmj9A`lFC`A_U?Fv{`;m8iykAk%HCHAdp{}vvxr-^5=&LjgDPL!ar7U2op|7% ziH!@1`_&I}{*!$7H;M5N5)b^2So&vTwdR$UBJySGR|T(;@AwR{qLa8&c5xrt%-XF_ zc5%P@d&gS&pR9PYi$UzOOnzA7rsGwHAE+Y^|AbimTVnfiV!7<)fb8nfx9MN>9C4@G ztyAF%C(ys`UgF@8(I&%lFyQTtW71KE3DW0r}YGu z@31i0jce6MZUy7js9sWJ7fK50KOp-*BD)#;IQ{!SC0s*{RXX`fr}ifLr>T9D-%Gw* zb~SB2`6{(%j_hjRhv=U@LQGJ98(u=b_yS^3`?xIJRkZet6&{dX+$pRVmIyP1hi5Tf ztFTH~AWRkxYJb!yEEi@A{XHj2;Fjtr;9MHVhEo>B)3$ukesZ1w9 zSSdT2FH901!gr>uUQ+OVPs4p$_p}Hrh55oH;USHi-ELhWY?M7O*1j!i8q+Ovi&|l^FkLvJ{#`1}6!vOsIes!kjnMpN0K@A>Soz5Dx!|{yoA<;Xc{7 z7GaJsLD;Wx)Fo^XmI-5JU-!!HHw!C-xxz%@fb3njuu+&P-0~advs9QVtT;sfTw$Vc z;AQ%E3v)Fe?35j@7nTS!gog(huTR)6tPvIo(}cq>QNBmmD(wF${kwz>!ZKl&Fjja# z>(!mY++B>HC>;1I`EFsOuw0lej29l%yxu9?B5Zw(>Fj=#*d*+Jg#17|u|e4PdGhVT z8ex&}u-31A!ggVeut=CD9M-yGujbQcH?InFh3zfWTO%wIrU{3)GrUKbDeTfb(I6}n z);Ci=T{!X}`Bq`a{p4$f#lm#qNE5?*g>AxWVWF_#laxyq4t|3CUSYGaLYON|6b3&| z`Th41bA{y%SED$CO2dfyKcn7g!B{5f+C>*$r{@ubxVYx6{7%x0{E9L8jCBh8h z;Sj_7gz>_{74%OL?$)}iwVeJ{!UAFE&Gg?Q%=`fPP#LlJMq=0di4DR5tuKp&X~Ml% zQLb5-ChWSB{w2Z;;o&Rj-zRJr)(BICLxq&vCu|W`3KN7Kiz!#XNcx1kFC`z!BjyMb zg#GWOf0wX9SSHL8#tIL-hw?q|CbkNzgayK6;o!R{*B~qtwrD+9DcpY^L|bmJ73m@h398GLe`sOcLfy zqyNqmh@Hn12NQ^Uh0VeWVXm-!D&=Z~MZz@U@No>Uovd^xDP3W+utJzCw3mC^x*{}z z7%MygPxId?tQVFDGlYjBgFo>EmS}$)b$*!G^B6Jl5n{ty;?4?U_5;LDjjN#y^7UUN z9)bc(FMka&>xaa>|4!VkcFmbXKDd)uD1CieXH~1ci_c|vvex%m=a6sPOsvrO>-!t| z8dooKxc=(ay0u2@)#??LE7!Vqr~HdwrhkXRGjAlHkx%TZAr2-J8?=u}IFEXYq_=h> z!&|e6IiDt0tDc+hCf}lcOwA?a<6DV`8i-Y@m!9vE@A^5hO#7Z3h1aXz_RVE@=7q$d z?0W4P!H)Xx=|~i2PtGvH0V}_D6|*@#60!7OK3R+F$I|{8AwMd{E;iCx-GJ z-zQf58?iQy*nkSLe$rY(%zT(wrFdzntk>)|`gisa+kQzbyo*?>bB&bS$QP@>R#%X( zpFupVd?l%W7pNX9uVMI>%ZbgOBpy7A*u9mQ{v~2scwa+4B}F(wZ2M`3(0qF zBGxY@R%H+~q<{FET0r1tYsT>9GrGJ&|(4q6lx4uSwmwcPjt<|{77sd*c+9`KH_M@|k{QldC`6m!}{|m8ESSHLA9#;GJ3R{H< zUuV37UnA}m)(Q_Sqko66O?IeI^FX=UtxEkVA7%5(doIgarh16Ig8mg35IZ$5^r{~P z_t3xg=fvtEVu7$ci|HMHmj0Qt|GBdNgA3>%FZ)p=`=9h1`q%1QXF%tgwV$AW(#MH? znh)}2Z~9K7fB*N1nX>PPYshEIZuF^trlc`{6>SVJ`jO)I6XWk9Hmx9*4-m^rh%Lzq z*Z4m8W%B8-5Zg3Phh(o0bx2<4N(EEM7mW~$pCP8aL~K?+DbRC*ibeD4YDX&sIIRUrIjqW#Sg;D>;w+p-y6-+F_^8ql<5*fBq6;I*vkEtF4_{{8PFe_#W#Q}aQS z`frKsb+_zgt;*Lohw`;LckN6hUnRRU_#X1H>W7V*m#Ss2GjzV%xt($YwZ#3B8#;&l zU^?;8JYw)pV#^na-Jc_-BoT}6BOXxve5Knid)lvd>VAWAjk4c;x#UM=2m5azpRIQ8 z*+PEkBgFoh#J@|8S+{`K>T<$ojYlsz7*BOkAO6SXVJ4`|${oKL>zQ$!Sx z_D<{ZUiH^RXOCp(8fEA9#Zf-}CSsrZed7nncgyZ)Jw<-x`^3G%+Mkg>u#4E$L`+X5 z4mrE1ahG?PDkJo{m%(oN8KZCCwwsy=pV{5NR)R-VrI$v+~d{gT+D zey~^lYcP}k`%{R!2PL|n`D^gpb1W4h+A=0)^B7(*ObO>B_;8&JOX_R_z+h*)tcF-LZ|KlO&G1tCH^@$uO1>?g{!L0JOW1sf{`Iqo#ln`akU#VX;(+cqwaT8w zR@1*m_N-U-tU%#uGZ@~lb#1-uTXjDDvt)OAHC_&A+$SB!@YeSd`!tW&Cz9`0x%Op~ zFTjQ2AjWQH3HhpAV)jYIzU9PR*~NWY2luJn60c@>iR@*K>}8X})30NAspQJEK0Pp9 z@nnD6WDgru-}_yEK1{g->IX$1C0}$rF?lj^_$*@Vxx{@Mp99;-50nvy-XNB0T=##N ze2(KIg2^!C>SJJ;lcD+`1eMIwazS=QMcA;n?yWOOI(AYr#j_(mGgc-s^dlfI0{r=#e#Q%s`-cM|l{jOJd z_W=DH28rp(#Nb+D>6eK$s_)+4lJ8W1s%|7-+d<4x|K2x+e2?0z@OR{Q%5E3B{khsb zqUwX=k=~~|oO(kEFNF0P!4+a8( z0gc1%&(r_#iNx4h;$;Wwb$_5|0{zo8?y^;mSYh$|7~Us4lYJif-WkMprC=Ue8oBB+hw;i)ZS@z3{RF_Z@-rO-b!LiEV1CH#HuaCEwY=9 zSCB70Ol+7#%zl)ZHk-H?m1gzUcNei}E-}-c+h`n=tNbl0cecvitNJOEJuY0&_~|Q& zj_tCeIkKZc^}kZtl@#^ER@sF#XTBcCq&yI=OVPxf~}>*>sUDVHhxJMb*| zdhJ8^$^LfTNdJ;$#Ku>NgRc;))UJ(xl$Ard;nM#CG+k-j~Ube3;lOyIA-U@=dabrE|#FJW3o465C}5cg`oD@i$_* z?BU2J^7}P^Bq)CIO3BOKm7Y(&^;5({6Nm{~A129uw0)KS`Rd2T3&U`O>?0E#(F(i0MBe?o~OvWH;lrFYea)P-{EoiZu@n|CD_2a$@LsV$03MoI8o_ z8lN@&@)wT0NWNQ`vzz?LlkykV2y100+QcX9r(9_a@qqG?E&CBteYR-)cglX%e4p}J z!b9I9zw=pQnJ_`PTlEv4sd#@TW?oC|Sx4M`9&z8-hy#C=|6<~nEUvFQl;0{h4+#(S zQm#=LuW{4Xc2<+mT0z{a`WjkAK3;Zi;0p3hdBm>0#ClgIBSn-e{|>SGUx*{I#2neT{r8hEQGJD$ zkgwk(|L2KmJBj@d5?f}notrh!_p2RCPGk7cbjfS|z2y$_iRy>_2gnbEh&@WD=sNPn zPZ85!Af~;CSa?0La~Ad2yiR`bN5rCO#C**QvB~6JwK&?j^bw@Pkx{J*MQDPckZBnPdTx#l-QC; z?3W$reU5yS##O7*-K~80Y5Z4f{Fi9ni&uS=y~_CM3B(MwUzyf7r6;iboti)5wLUxK z?7(Y`SNRgLR^z3so&0X~)6#9^TQ?EQHNUs1oeyZ-94=#cwy^a^@-?y}DGSMGzKa+; zlbEP+QG0^qClZJBysb(0X;}6t;;w4C8Rs;^Fs z@0>#Vr!6Ap%om?Y+^2erSG)IWoVP7yc+wAuyAKi@Wf!~E50ll8lb>dI){DeL%4d8d z`DTsV*lhCq4hdzqx@8a3G=95O{>%?kZczQO|NY`+$9m5vKhR9vDeO?Y?|1fIcCJ8n zE+>xiRkCwKk{_w0|K2^swC9QL8zw2L--1i&-@K7nEjv#NmsGmFjn$vU9o0 zSF!9}`vJ-oe2SQOD=}VrM$|uZFQ$LB^10-X?EInMFul$%6I(AMW}i#U(DS{) zmE?Q6C8vIM$l0s^q<@me`^fF&8=oWYiy>ypPVW1PnEz;LiM{wmAm+I z%IC;U{maAyZXbOE`TP$MLti77X#D4ICm*l%PPNiY(({yoYZ>0C^pdoH&r-S# zlV~SK?x)=TSmI%g&w>*2CHsgq8lU?#K0``p%exhSkQgg_RHbn=^6&IdyOUUvNvu@< z1_JWmOzhRU!cN(h(!1$DtbJy~)#Uqk6O%OFLK<&vX)M>^&l%pdlUV--G5r(7_Ech$ z%H7;SzO;bYuW?kZan!n({uLTW@yK`(c|UkOu|wmfM|P-PXif9wlG#YN!b4b`tKALX*?BZJf+>m@P4&V zx8|{GwevysgSK4C6@P{}qVX5f`0CR5O86GTtA0w%)O_BedfKgVRsJNyQx+5BrxJ@E zAP#+nSp8YzKFuq^`^Yy+Znx^QQ*yy9hSx~%z$xU1HO_MOk&hMj$-cD;D}?1ApOR36N8h9txCU2>31mo0;S)te$+CB@?9FQ zyER^Ss~^@oyYBj>FyR}F*Qfr}EG!iUCo;Tg0x@F^F-h&+toq5;xIe7^kbDE>_Vy8D z=Mu9t-doh~%2v?7S>rwBujH%#Ozi#@F<$@+`!tne(#LAhpPZj5qFa88EBzu&p@jf(6|AH?QlZ9EAksp4y;;Ek` zt|H$jJC&(^kUc>Ee%Ys5$tOQW|HkWyTV$VFv@hsZJ+~^KU1v#N>6GYsO}@teZrQJv zFHkQ3o5Ya%`_63g)kqW$DH=dMk@7b)kUdb0qu1e>_9m+>p1>@I$ zo7np^VzTP3L-w;ahyHDD9(j%YUiGWy5%QH=i4_ZoiTT7Njfal+kk9@T@$ess`-Jr` zk}nh{3J+*r%$FUE7xpRNEy5hx-Jr1N5~kO&lh`whSRi{>uKh*JkLVu~W(g1XD4wt} zK)&k(#OALPW0n8bkCJcFKDxGxeA~;!VvVCAwR5KS(WSB{`${O+^8;dr%Dq?hmRL&v zO!en||4P1Im@6DPK>sB5tG;iLZxj{^6L--6z|)eyk(hpnm@!D)`AK5KZ1$`C)5&+K zpVhc?xqIn%auIy^U z`xri=`Fijw@&y{_N!OB3{yuR?^~CQI;XOai^zVF$SgCv$FD0L_nwTR#Z6Eod>_D&V zfV~SIrZh09em{~&zDHQ`4Ea*^pM%Gd@1IQ!4HN6HlpNBs^wO6RJJfH6HO|XqKWf#^ zSqksZru<%w^Aw$T9DbPoy^DwkFB0A?f8E=u`ZD>l%ZQ1x!%d6H=g5wf#7gcQ;*j*E zSCH@4xNMPKDNuT~2@LO%UFq7d_$p_Q>NQsT^N`xVP3<55Ys#l@Bi0^IEL8ckCXmlp zJ9O2PuMswD+*hj|dNq!7|46yeM~OWe$LZ?N^{Ss_>C4ZcT#Lr_$V~E0+lgCBh=+eb zJopP@pXQNLjpKpO(Lb%9Sn&w4_z*E?9&w+>-)@z={W6TqkH;=c<2{tKU>>e5c<* z`GcD8hn^>&K8aW)y(zQEhvo`3&*W~Ed@-^90^*?hMbkf#@411vTm7I>SR=czTk*?f z7k0`n#D0bG4yry&l#kri^gnzZap(nNgXWt|_1kjUrv|lCrpD7wJ-@9{c#d%7mrSQy zSR>34j;LRB3rD^qd0~w(M>wK+x?5Ny%v3ukJ*@be2bymsU+wI~6XatHh@Ea6{(*eD z>Y;Ns`TXC=U-jQCxeV>|dn*`z=v%~)?7^1H$On%n4qr@6Q+~I|E*zLh|H{jWJvxWz z`~vxE%|qG3VLi8vpUC-Y=y#MGI+GauPh$5u#L9WZc7>PA&J1YY>%58K{jyj6<>dFL z6Z2Khbd8GxC(wU)Dlz9~V*1yK)v_~bA0wY4J5wyX+AKZsO1CG-a)i`w`>Gl5fb35~ z7x^yPr`k#6(^UT0H1dgY@*gISsQm^szSFcH%h7yV@&n2>{epN{=hj_C10ZWRhg{U${qAi+D_d6Sz?RUEB)V*|GyCHon4zsK1Js+{aRNx zs(fk`<4F{ z^0A*H?$i9;lSsaDHL?3C;!fGI?p*Rc?$f{w#i-vWzP=Co>j=M^l3aE{s!gu z-Ab&1%h)v6cYOmf2>~FCn^gsA< z;=uXD4%vawCh}EP#OB+H$+r;OWp`>8k}p(yHN8&0Lg`j1-Qf?=zfAUL=O4-M|0uCU zdb58|K411^SoWk?_M}brr?{GOLFF%9`70Wxe~;`+iN?Vejf1XtF+BH6#9pmWn$+&Y zCG>Cp0kJ^soT>d|aVh8Sl1G=F5P{)Xxq-d0O2k^M;fF8OxZkKM84W3`TNoJxKqo7jIh zG5IuN*K}e+F)>?qq(OG%&|~y(ksTTS3;7|HFQJ)ytn5d#aIfacPW8(J>Zc{wQoc`i zC0%xc7vck} zb*a2iSwrg>jE?K@@J;jUAALUd46#6gu-c40#joqOioQ*JS}l@Oj=z4@h?r?yXpJW zlY%-iko#wuuv_2ZQy`EW9@mm=+f^3B|Z<+O)brU0r_C!ex7{Cg>IeHi9;T zo&jO|9#{fGQ+VHzd>HsTXu$-0LlE>7$iB__0_Zi6y?lNKXffy^kbP_ZV$e;X4Iuj- z{Bt0*b6^^1HfRCpD$s+V9iSIL_O0{RKzPxAUSYl>+W(R3@cf8C>$X?6zOgGGEhw0Hw&+Z^&8-K<&mXSYf z;TZcv5w@|7ZN3zhP$?=QDUzC`s1$$jeIH*!rKp5Tk%S~viX zA(tSJAv?C9uaHSd19BR21@Z{8267kj0P+m7^+V7J zX+SPQu0XCs?nAa9$L)hmK#oIBLC!+%K{kIFbNDG>Ap0PTkmHb3kPDD&klPS^&N0~x z8Hdb6u0rlY9zb^N!kj^7AtxXgA=e=rKaKH)?1P+wT!5@WZbR-t3ZH>K$SUL{8`S0N7|k0H+>TVKXpLCTOx z$Xk$E$O*`4$Q{U2$i~m39Y_&Ug)Bm@K^{V$K&A@N2^s8xE=U7%8gdbG1#%s-r58FN z6Oe*c?#L}3UojwAd8R- zkb96Pke%bu1KA51hfF~ZK`ueALLNi5?uU(#LC6WnMaXr?eaPaM&`-!36Gh`cN9<5Hz9W* zTfPGQkO{~^$Z^Oi$XUn*$Ti3s$RWr)WEJuZvildI8!`!*g)|^1 zAlKf44#*Qo@=F*GNCC1JG7g!7tU?-JN8cfjAX|PJc0hJPijaMf3CKanBIG#a0^~B} z8ss752_!iL-H^SILy&pMD&!>O7UTisF=TfIwn8Q$ry=Jc*CBTxk04v7(LQ7mashG~ zat*Quc>+mh&=1Hq$WF*!$SUL{gcKmF zkV}vUkWEKnBV-3;H)IgffSiC_fn0~&gxrTbf;@#xEI>cxEaU>@8f3l>y^xcTGmu-5 zyO6Dm&>AXgzbAdext zm!TU{hD<`Y6W8pnTM=GPC{-#Zb9xs9zdQ! zHob$sKqet4Ag3YcAQvImAzR)>pCJ1n2O(9+BIFw62}CZqH$(P9Rv|Yaw;-F2VeBD; zkVla1-+~Uv1Y{9%3UU_m5K{OR*b6xXnTM=GPD0K=&O2IMs4BIG*cK4klEq7RVckh73$kb97wCt)k(B;*X_2IMZ}0pu}c({Ev{Aa6lV zL+(KCL!Lr5{x-%3vK_Jr`Ty$Q2a`{JK>D^3vXZ9{j5_?e}ZpnX107dk&hmat}fPQ8nxP$)Ok<@oPgcfbz48XL{_KT~AI|liWs2RCVJ}3mEK@8x zXydf;J*|3Krr7BWI~&2WOtCW=cGG)X^|DN{)eJiy!Lp3lEf}+QfA(#_cJ=>I{{Q|F zkoT6Dzuu1c3d_{54rg&)L=b*Bd8O8Pefk>+(Gb}d*Q_I_RLJy8+%|G?#y-z)jMqRMHIk9}`a-RVXtuGQJh9DqXVG`?+P24f z<@F@Vr!-e3F9=Wb+v_Wh#g#_1UE-AAEB#=un|hIB5)!ZLAIk%Npa;3}WtSUgLvB29 zY++`0slI^JSpDi;V|Hq(vapOKJ6FfnEX}bpzO&4g#Tn!q({m$~FC$lWr-%4pPjO}@ z8@GMPhqT8&`u+OCJoYp;-mF(%HRD|gJZV49W4-d=7q*`4!2Ghka;;LGpIbnkwZ%H+ zIG;G3a>gsmQ*%da^%d*_Gal>7tHLL2Zl9(+Ax+gM=H998UpP>ksV`K;8LeI7ln>wd zjLy|1_!MpR{8#7Z=jWD9iRmC#b-+JfQXPjdfwPH>lN!E%feKvv#3&c*v~lG*Opcox zZ|xGJT&&yH_mhD;Gh3T^+c{P?c*ZAA`S4TACC>tX1mC*P_7f~qY)QtCF>nYmFq^zl z`{qh*8H;^7t}ItP)_KF37#nVQNi?)~L>7hnrX>NL@0Sy*U z#3>(hX8k_ik$<4RvNQv9)^FlfkIRKmot~B2WPNU-F(cW~+Gjm^gP2$A`z$6&$9)M& z5Ivu%E#hLq_njE!Vt$Q#FXPsi8_i^Eml)+D|5*;5L>^(gL)CZYmg`GH)yg7Tf1`F} zZn?39l_s;DSk-|%Xlwh;phJ9^o0X|!a#ttgv0iyaDQ8|PBF~)9d^sH>mMh*}x10}n zX=nfPfw_ev^R-6PTFiRoA^+LfZTUd6PZFbCPL@O7OGRVRS9zQH`a$X`uZ@QmKW{@Ub()1 zL3xhDI_2cX@z*1E{krD=X*V`^pf8VQSS)RCLwNajSMAsfM%B^Ph$@v=TOa2;w6{P~+Ub+$0mhZs`!e^zZMnoK7xQVkU>x(wcH`F?tXCf9)c0*E(zhjz z>pmB&xSg8hu`COE`}La>ZjlY@Z?f9pc}pEw9Ws zF!NYbut&ktiDuJrCQkW?UEk+VM*93ojjKM)iN)y?KwHr_MG zOC#EiA?uZg9B+M;`)k%-%H#B^;zjY^fbUeoqjuRQph*?ueKjnr*~4`7$NfM-@VUc@LDzGvKhFG!nmt=gVTjB??3 z=1W%tSMQ^Y%2JcH$2#R;-LUp{V88XrWdCxQ(;4yc(N)=%ic^@a#3&c*hwUrRw&xCy zO!QzRv-XKq9oQ@QSgA!~rN&q(PP@3e2Yq=g%YxqGH2P&ZSniqBl2Z`9xQcCcLW zxwY_@BX<0<+9B`0F`FMiVIIpe>fPh=l;p)cmSu{C-@uFeoj z={&GrdGHzIZAXm#a`4kQkM+vKcp6V)mhEA+U8=t`7cxlJ9_y9o_ULl2hV8|9tXCe! z*nF*uxMX{_pKQI4M2vFbCpMpV0vEi+xp_Y(ELVJPKl$0ne12AQ@SvM}@rgW^WkGMx zAndR{Tnt!=&vNZ>1&f0l0*e=7lna}TyA9*^S+2j~dO4$J*RI4U*RA_97oT0{`i2Jpdy%`07h7Lg zuRJ(_jp=2_Q?F`S3yD##TVo`zS(~Y?xiy9uawP}Y8YB5E%5Ag85U+aN8nYGGt)K0% z#;{&_ZjCvS^4hNx#3&W zq`fG&WsM^3Yeabtm%6dx9Unz9h?lwZn47qi^Q_l55_ROyXXYZjFa)xRHpv zT62xL%KY57D!FGU#H$|UCetI=vrT%!Eu0oLsXfH29^@-qlXqZ1-jmDsEK@9UlwoD; zK9j?;EMR*|$S>vt*8*1VM@d$i#?5l{x4JUZ$mI#*l#d)^`~v3VGmP(6{&JR2i6egi zdB*sc0za%b9r?s5ANj@jJ1|ddf4EY`t%O(bAn<4<+=D>tS^LB(A9=?3X9Hi_@60Do z`N%akzjD8t?eAZB2aZuqFR6yYZc}cCh#}^0#H$|U9n*6v=n*@*(?h)KK`!dm`;nV4 z(b;^^2ACA?{f<@U=2w<#W>RKT;HWO-Cew8)l-t~Nr;8lbg}AkG-h_3Gc1_lnj?OJF zV*_5UEzH%bG$$ROfK$H9RVPBZ*wUF#obp{fKTX>gKbQNdUp(_$H2gc_v|gH;=VZ=c^;1IOQY1SPa|`{A`{M)Rsd2uenD`Heoh4 z8q-z9dg1r|o~Xqu#jT+!7p5=;1UbOjm6!0=1UtOv!F4nLPR{TDT^~ysYG~QcSf0si(jq_Nq zJouIQ@U6g;_TIoTiKXiD(BZ@37@)J280A*8>&1OoYnQ{GW&bix0X3ZuV4ZT%al7|) zIdERX10pW)XeJ#K)+qYx#AI5Hpb-_1pi8{aR6sEj#j2B)8Q6F%45Cq5M$QPmB4HD0hTKs{%-hf zSkpo~SYG?kzV(^qig&r>M8L}&?r+o(QHE!^;;|nw{X4N%>AW@JS+01*hvDUSz`-6q zrbzX(T=6bOdg@(6__2l&=cA(vIs3%N6fpXM?%tvk* zUi3SASgv@)hv9c^QT_0#o{(F3j-BO-$HZD*MygGIF0vl~obF%x&{vx`*{l3qo4p0= zg8sff^w;bEyNLe3qyExiXUiJ&=dmmcdP|4lT&8!|hE^=g6zkTh(-ADo0(PK)n6y61 zc_H!mb3f%wR+g9F#cG}T0qd0Ga^D1OVmk+Fi#Xlue{;Y( zn}0Nb?ckFV`dz2H;l7`vLP@$%N38DZ*5hvXB0fH<=>f`sg>(T zD{~7R_i??A-xIWu&0b=Z>+Yq<`CjFw^Tsm8B1f2i??#UJKK2K4 zy13TbRLUn#`EE~q5IN)fNx8N>gOlBe8?%k&ibtNXemx6#$>F(fEoWR}l#85Uw#xgh z=wmr9e*TD`s-$fbr+nlP+f&_1`L^}RGO^sP;4gVHJBU|3$S0;}5;6V#uy%H*hj`V4 zF|vE!w}KuSi&j0loThyuR&^l1n2s{86WiI6*Fh|G$hlk7aXsh|JNP?Nx5ntmW@AFE z>OlOOjzQ!t+OfV4VpWIBM^}T6_;}_hWdmIb|iy)F;k3Ru~D$_1;P>dWSa^~ysY zvNpt?OA&i6*>xG_(XeX~EXz19hcRDN-r9$BwE`ozJA}1KdAK~}IRXq{YA5TJhrD6DjTq!kJl2yZ z`xE2Idew=?dgZ~dEQVxGzmXi!-C<@Q%ZaaHt_*)E;IT%B-C>4jx#BTjwil2&|3<=t z4f(wm>y(4JGR|t?ghLEQNym+K%Bg1kf6&~{B7XDIawhj1>ZkIJ92>VO%u`Q2fnPMxM zUa|N0BliA2?JY^ZHXH6luq+FDOTEa^<{yKw;rGM-IX%-GmTz0IQvYDN;@v&cE%2w`m**!rJj)gDt|3hG)6rr!%}0aoIRS)AglBHkK?Wz6bfj_TyVIUkkzSUOndaeP5~LG_%bcG0H`p8~0S; z$~l(yTw;`qxHs;zwB7y7`xjixZvKf;uG>q<*zSwO;6BD+pX4};E7?o!3;mN6AOBsP z@g(2b*xwDj_V@Wxj>~&u*Wrj=hiO-F+U2Jmn5R6JWud>tX~dNEL7r0|#x>RwE^^Yd zuZR?zAJ!|clJTCb!(+Yjrn9-(hWI+13{|u9UwVery(@^SqI*H&l#kf3YpLxox_+6B zO&T(LiB%nl5u1l|K}Y+2DC?DnHOqLLaD9Fl_Z#;w_&0lG?Xg~YSifxk#P@$A`|WUe zz-#`=y1?n5fv;Fzz5xIH4czO3PdA;*V7cO}nO|;(kNgJSm-E`T9&c1%KAvG>VWT<4tXC!(D7P&d#*)`*+DFI$nSrx&-XTo zj@Gq>uFO3dk9;Tq>V2`+W3Oy zQ{)DlXVLKm%vtRB!mJDW`}#1?UjIiU`aeqjg;H*hm&dN5%@pg#M)q@gEX#ro1%I6= z`?)-pWs0pd+xu3;-nTT554io5^!csGZGp?`V3EK{u8?_P^wS*BPw7Te#`s+VPog>RU>Cn8vuDHc9qe)J$VUOYVF)bM?Ym@lUW~ncCpXL`MZT_P9o!bM6-FYm_g5Kf) z?6a|c3-kSp$!oQD@%y^`+R8fRq8;ZhXVW1Q^lHXbNB#u73_Jay;mxCn;DSQZ-@_V_Ea$zrsojs zEaZKmgC62l55~#XntQ39*TPGJoM$Z$&Cl20b?*%#R&`*^OvgdQ82hxo4q{aY#?W-! z2|DDSZ1y}zR+hPjp1^lwLage*`eHgJv2N3j^>q-dI*tc3$s^6r9MK8aw{2Eeji60+H;9f?sUeL z-^Uf!c^*uRa;w?iLw+AuKn&SkI2$XLD<1nD+pC;XyxoN}Jj;o%VQ*u5$H%50Pvmr$ z)$|;a^~!^<+uR<)zN(Pm49)>u6)(ywdT=YV#bvYDBVP5u-@l;GpzjAg_AJZp>*>8V zd1YMeA-eNl@>MTlz}AxaO&m9Q8n>{rm{XkDMV#{C|28fU0w4EWTo5fq88uDlK4>T%`mF28m;*<|xH~uL+*Gc&uau9LKhmRZoS>TW3qItd+8#?m` z;*<|RH~*QydA0)HF~}$1nY}DmJbb%X=TE*1!}~a;zTFHw%NkkV zSgv@)v-!=9kA`+E&$M`+wMU%t5y!^g@-gz6cUtJ_7!jv@#H-m`_;KM|*2?T77`YBPIh@bs$!4UT%eQ^_}L&5UIVyDA&d5?w^$Q^W4^F1jH%d#p$)5 za(wgKjGnenobugzbo!@-kKgLm->&89Hdn+b7cpydb$f?!+hxXV?1@u8;?(c6e z`yKAl`fF&*u(CJIV_6pT_Sc}->?&aY^gCf67Cp9;jtOzfM=mhF+&}-FupjKqCr4oQQ$BKsU3(s&wyC2c$X98 z_mrG->~H7fSLX8jSUDlo{H_|}l#kf8KAppUNa8&IelV5?{6LS(3z+)kWF&{+%ZuS% z?p2rTw<4}jVr^)wEcvGn>D4+^rMZDv)#38(WyIx4`Tbed#gx-vzDJz$F`hOD1^CiQ z$xR~_{D=uZb#!gAPC4jfnhOGF2G4S*pvuBdTDc{A!X>`1WuP>vp6D8);#HtSDG@FMz z@VU=PUWxo(hjq$9?(+U|Avdlv2N&ocr5V_0*gK)Tc@9_>^p<8|i(O9+Vh%2F?eFTH zxx}j;*k^jK20gM4b@%RF;#Cjwh3yRsnBNQQoEs-bxs@#DE(ESVOTrk~Jg{8xh$G9L zXW$DL?3tLuvt03rAG7TQ2K+*@lUX5T`7W5Y7 zU8XkI+c55Vy)08K=GyvuJYXenG_T_y_u$%_+>oSAtJv zH&KnlI^|&QEG}>(p--KEUqGDl;X5{#=Tg31z&5`NpY_Uv-&nhwFfQm9e!|qWl!aGhq6?{y z6Q_Li-~2=R|HX*keNoqyKD1?dN!FDwwz+T2x}d+WFQ@-hME@!3@Atn=TZ8^QmSwd2 zF!u9ii#(e;mEI$GU4D|0_LX&kgFQ<&r)L7Eb??P;#bdv2J|KBS?8)z)SRU{LJ(xp3 zmM=v5`U3k}=qYBpCEvaf&a;;*{&^|OgYJU-4$*SUUfBM^I(d&6<+`|j7PzhbU^)9y zKz#as{8gkMf5m>3YA(OX{N%AL3wld6*kO8QUh-I$DHgfKu<|@Hk7b!+bM{sv_Eu?c zaoXK~5kIZAdB&LHu?I0bHUj_8BD((>bq^G31H>GR3-alYZy1 zEK{r-H?j945qm$PK3IZ(dwcU(u{XuKeVf>p$FeNgQ1IV)65H}vmMIo-U^YCCU|FVE zH@>nq8>VR`CwBRUJh*IN}TfHmu9d0uIKZKuBWbPWIWa@uaen&%JDFh>34waC5gr-PWjVWzD2T4+x2|!L&PXIw+_4%iNTjN z2IU~9tz)vEcuD<~Z*s`yf^|WEp^CN7Vn+55FC|1&*uueIM4dclDv(OJmGuv3F9G8#fT--}Z^S+m5igoL$oOKQQ2~YdLa>c{<&7QS@ z=jkfEhk4~Fb}MEN>y+dCUhZ9lHkxTEkM+uf-&XMq3_p(hBQMGGx|zAAKCoQz zhzaZWm4JtDWt7x@){*1S_ix`MZOCEA?0hcE6zgK+M8HBn;i+zxE8eY_52?H9ok}cI zEaJlYI)UHPar^^3)y;CnyEOyuluWF%woNeC^vU;X(|JaGPpq@Hr98}q@nr2{dp-ka zKFs=HXWt;^#CVc7*j}8+dh+BQv&NIPYhs-M7JdmoFeZ6DLMO@7~GYtLE)%QE`3d~3q6yWlH%y)09#i!Iqp=CLeOEat}aioN?I z_U_mCkh5Jju5xX#Kg37VulCa)2U;E_j(#-Y=H-6i%O0>ZpE%{ac{zxFv3++_SszGS z+r%gr^I~&)D{!Ul_FQ6=>-J{*5I1Z$e(!SSeZ3AUK; z5u;qUK5Rn%lXjcfj>mfCxixz;I+ANMZHsk*(=YdMEXS_~PG+P%tuq^0uRP4Njm^Wr zJ7Vv`&J;L1iBYawAI>3P9_4#0TySL%Zmn(Nln)=Uys`y*pKkcXDIfk|`-8Q>Z@quR z@_-+ZbD=)xeLCWwpQeBI^kd!)`w;!lV_6pT_Q?BmYz!yhU!M*!%omFLD`Xo3Vw8)y zHtvnU4f!ee4S>wQh#^ZezoG<+*r&;&|zms`E?MD-Y|9jcFA=ZFZ)-+%*X?%Eek^ z&tvYkw($6mh!St%>OQu80BJ3Fzz7Y z;nQLN+n!5|aC9VAx60~8CTvZ`RR4; z+Y+N(7n_)(Sa5B$@x zYY{BVg5JU&_@rTF&z9HAGR3-U?$Z%0%M_d2cYZfw?{{f$NuE3N5sN9<{RH%k7zi{>Tvt?Gsp+uP4HE%*?M(J@- zVyTKa=lHef5~Ez?H(T@X1}^Vgq-@t`){`gKTGr+`CbKVnW{c;r_7eriB}Tb!Pj;Q$ z8l27jwjs+otXCd#j;)Kkku&y+d2p6rX+PUfuny%I6Xb$dkFAG5voTw;`q zd}m{KDR5u0Z>y$0#d5_Xw^=@rb1}O#$6D|9FDy4I3p4P%Y_5n?zPm>tbI*RpzqQPI zfeL-GoPDlBEGJ&xX=`(T zJH`8}(ahIauRP=;zKCZno}O~ zm#w*S4|%xFJy_NSyZVZ`>&-7k?D~@0HBiasvVif*V_8PM1Jjwmo({2N z$C()A!Vj$f8!^sb;(b=P+s=5bR~~%AV&qETbv~C!jB=eX972ppoB8)1vt02me-C0p z1#iD_v-xK^@$wxe^R)+xw_lhUp5=;naW?S+^-I?F?*L}G;@uwY^ozvXlMO%4tWys1 zvW;^U*Jz;+ZGL;pdgUP}TRz!|>#8qt?dtj+z~rbd=j)e(u5w+!c5cI;`UvZl2Vb}K zw}ET2FSTCh^7k|dW*cAPln=kR{4tK-$wv6$JgF%$9mJ{*?BjfH`-w>G{DiJe{v94` zn2Th zUN6fOi#RhI&PK2-Q>@FkaxUd3c->*ER%2uypHOf)gcx!q-pse>5pU$$-3NI)ROT0~ zS03Wd{7UZ0MBB{WZzfLpE)FLVw?84zm$jz>zgY-b=2xVsNR{sI4~TWa5;Mx#+duSqFal z-OgIJ3)LTe$Q>qpbpmFlwmc3T>XPr;m=8$5emoL4KW=g3_J3;;EX#u4f;^Wty%HmN zy)09#+v`h=DnGERPG(;#DsQwitgUjYT)wT4(|)Ja*0uHCG*Ee zf$P36+q@l4eTX>aW1KB!s>n~YyZL*zELS|n+VHmmzBR^J9`FMN=(iY?G2AHc{t7z~ zp8m8rW?kSEVN7i1(#AOBj&A#on-m4`kXuMv2XKeE*XT}xx1 z^~!U5#`|e|aUScHhn#P@ZUXxW_RsEx;Cp2Cm4t&f@-C8YcS02kU#k#dx?0qd_?`s+x{vB*G zR(UMTg5ILs1Gn*$n0YPut@#5tLpHapCr|Rctqpr&`)j!Ni@nc~b;?0LvY3@V{B)!b zKdocF$N7$oZyw7sj?Er7momP2EXx#I$!w7E&0|@nSmat;lf>S4!q~Wc=6{fndK)KV zgO2_Z=FN1-_`Q?AN7F_Jv8n^HVKFQDHnpS8_o|3duG`yO3tY)B=tCPWG0Js&8@VoO zZWsIJ+%*6(%EdUF%@+dKx7*4kM!6VwTSvAc&os9yIj8k|Rm3SD`yAt+4t(EsoKKwc ztC{T^F_~%m_D(x}OGP^00i#^(6Rh8>p4!+xmZ7KO`661n|C7bKxet)k#j9?ZP_GvT$@JT+(%ZF>o4S6ifg5E;W?TsX#<*_VNY;Il2VHn_gQ<&vI=y*;$I z$A5cL){s1wWx<9X`F*d?dp#j{>fOOwHTOcQY#%ClFKrL;V16|Yn{zts;%XU`)Gvt( zHuU=60AEk}Oj;JZELS|@zSj0_eXs1{TeHMSQ8Ap7QwPC z=q>ai{~K1~BCnTaimhf?iHkgzWr{`LZLY=Mmz(xVt$Sx;0=H+{<+!bA=jD)}ZJ*W3 zB}TcJb8Gix;L1I#V@f_yYsg0p5d}8J#3s7tw{NM!uV1!v z>F$858qgGf#HtRrr@t3;AlF)#bNAU;uROPBk#+gyb~qg?D+Y(I+|0GZv{F^IIk ztXEzo8{@^m;~Io3s`NLceyoU5ZZ+d>$NKqldhHVD5~E!Bl-YYaaNB>Qfc46AvGXkO zn%5+j5j%stW^1JQs7t%#)3m`1yQ(PwsfESDwos(xl6sPtP6WS@seQD#~4cy%RFZa71Vw4MCFzy8U#&%t!IW95Eg+JK3AZLQk zhVL^@)$J?CHV3RDNA5w}`YQJp&dU29@vOK;(nNixGM_&uN}TfDzVT7u=k|?}`#r=d zA8V)W5#-Dn`}-xlyf(bR)*e*YG0AkiiB%oQtKL_?9+}s#tFI1VZVW5erFksNg5KhQ zi^~fE+deK?uRP3y`R5jl$=5r4bA)|^Kwkqqnb@%NMVw8({ur}p4 ziR3oDnkOAQ)+-O=Z$7gXL1Dc7`^{OW9Jh|0NIC88Bu2Sz@A4$&w!TlDb;@!3^+U*W zU$^%%<-S$II^|&Pvhk4Xl$2xN0dcX*dgZz6?7c4vFMRt$PWWUmEOK08l#4uQzO@C{ zA<9k1on?x3`Lz+jvP`j+EJp7J?E2qCAx`5(66=-cV()U`wf~k1>y_u$M7UQn7s&;4nhUBJ7qd;SIp%aP z7h8W=&o-)VEC!Jm<~poftXG~Ji;IDm%azWrSg$-c7F&@|*q&Px9FO(Nb9v}w;7NN; z=blsFWIcKE4hhRcPg0(1FL!N1jB=5Oj5~`w)M9InON?@ni!6Tb1#b9mZ)zjU6r0QW zKNOkgAL2Y0dfoN-8pbM*Wm(W$=yfqH*9dtm%M|NkSgsNBSe7ZalJ!mea$CgSZECMS z|0TBNu`HurIsav2Cbs3VEK@A}$gpBt9?LSt=HjS7VsAg~?e)I_x&pm<8-yh;L{(OV=%EKI5Tt5gr*?+}(tXCf9)7HXC_#fMwsC?^~Jmb&y zdaP3p=G8dz+@n9_f>sXelrx>>^IdQTwi7=*X}OU&<&z!k`S2Or^KHZ0 zsN;%n;mUoE+R|5-D)Qm5ruV=Qr+oO4@#Qx+?6X`Hw&xS4eE62-h!Zagzw?Bw@$yX&5VSUdY|@8EJK%N36tWcsgQ9gE>vu6X1j!*9a*sTiK+ipT!P ze6xV>0;KrJzJ&G4bJy_q*5R>Ud2SyxvAJ`5tXH0ky{GH&Sg$-6dl&J&=T7}&z4Bb_ zZGFGv<@R{2Q;v(h6CF6LQx0O!;`LDn4(pVIcr(sHd|M&yQ_eQlDF-oT9NcJa%VC{z z5LXr#^MT{{o+Ig304*mFqg)qL_q*T{L+&(U%G#a!fY{o(U1F5$*87`XaEVc_yY}1r z!FKJI@w=ZRI0BO8Ut(1U;?MTB*PcTMv8n?xX*!A@>fR1wRR`kJbX<839mJ{*#H!81 z?yY${?20TK2V#`#u3OG`!6inyh*@iQ^M}`Oml)+DZjF1q3obFrMf}>BJ!-?vW8_*Ne8jiA>ZpX9c#~_gILvpykI)^eXM&sh*cfP554-#;`(|z+$39mBu8~2 zPnfQK_^yf1aV_H#(M68xLcTCvYd?T4a#R=chUpr|w@;qeE^<_tTkGW;DXJ^_J$u$G z&#m=~+dK1EuROQbZ^gG)IobnO(#=qAk zpE%_s*3Ivyc1rtl%`_#iw&a5*H*c(0o{Q_`lbw02SDuUO%j@u1uRIsm2S3%hJ=QA^ zac$$X@n<5u^mmfkvwq@~U&;8_y5tk5d>7yIySi(iIOV(e-tp<~_{1sS?fLIC^T+1q z=hK|TI^`gy?KFRh-2fN{cL*<>&TINdd4a5ZqH$za$LMVY2~=t%=RM0 zDc{BGmCv=b8RZkFd>5~$U+#`iobp|~j(@&8K5@!NyxMy+He&o-yuP_u#U+W$y!L`A z+j|hNdJw;+=izheAzt+$o=wj!%+2%IL%iy7@qGq!)S}1bA=WF;t=m=1O(!1fm4~>t zyf=tB>BM8b@(|DFvyW09&N^tew6SKLauCDDIfMCQTdf?{DaXZa5p&g!!#d@-xV_tf z!#d@-xIK=!Y}XF!$noDG+ktt@aiTFqobp`^-|mu6obp`^pTPWg(>`&^cQIV}N8Ry> zQ@)Gg`(5&hQ$Bnk^@pEz?T74|<*hTJPC1xQ;~d)Cp2IrjU_OmA`E%_#tWyr=!#LMF za9F1t%z<%seW86jtW%C#SI_1-sR!{j4Hi?xDc`NDlV8lW*@jP?^4+?+YhQPK;*{_9 z%@?}l6Q_K{s_jd*4RzN(amq*BTHZb5`E6GL=T`wA^z_MDMAOq4c6M~3hj`V4m^M8J zN1jg)@u~;0ZN7B3RZqHKVV!ai&&Ih_ZfQH^uueIMVdHEZYtLbwa$MZr?!aN4a$MZ* zeWiUntW%ELBVQs1XCdFI`BPgK6RcMrV%P3_Z5x-iI-eCIM!AS#L>T>+rTO+xUd*4|T9f14r0~DXYw^^%ihx?34dtm$clVRF1!99hFtkQi*eVw;1Z);#H4Wt zUthmnVw8(GH16dtxWp(I@o4vtc1-5mZA#8r=iPXdqq-2Mrt88Fpo<*Uh4?jHJAVEL zuq$v>7vkDO*cYeW!jvedMV=8~LZ_E=Gw{ zKJv^*bpFP_Cj8cOyetp+0m*3}bm#v6CUTDBZ+MQQbQm#f*fq4D$FeNwEgeQo8dlDj zgW&Wtn0TUxwWX8(xjr`zr12n{j=+483_Q%YxoMIsa^W<;-Os%QD3x z9~-t2!Lm%T$iKF>-3?edV--JZ!g}Q)*BY<E5c9BHTXnopeaU7nP0PO#0+eBzYv^5kmZhjGnENz)k>;*{_5 z-n23|)BKa}bRR;T@{t#9O~04%_1#sizx5zSxz&t2 z@je?n`_V)zml)+D-&uaR9=NUNV_2?uzt zRh%P<;aRSD#GdKDhw~#bJj)f2_%nPFXES1WmMb1{XZW|a#PKXwJmSsb^yCK|K5|}% z^~yuc8SlwDJk~4EU5`{h*ttE{D-ZEz?cG_2$9m-<&Wu<7Q0MkouRO$;<)N#dmpc=~ zI^`gyjI(2_Yb(cLopKOI#yQ=A!#d?4evI?91BZ3WLEIRp`r-Dru}(RN9gFeXfz$ci z3^C;TGq&ZANPC^R#3&arW$j+;f=i5Y5nsmL{n7Q?B}Tc3HG8Iip)EIi3TyixVpRv? z&vb0x)~@|l9mJ{*#H8ss_Z&KiRUL>=)3Nnq-P=K|>Oid8Se|Lo(RyBo808{fjSI)i z&3`MG808{njl0+dml)+DZjF1t3obFrMf}>BP2zk(v(M7zZ001-@_U=ast&}n>A3kE zI*3&rh;P%e59bxSwS!pIfp|9^*PcTMv8n^{Z#oJ%$KdT~IaA{H^Tbkz+}}4Hm!Cri zv8n_4z;x`wxrlDAPlt0h^EGl* z7xIMZ+OcCDdm_5XQC-Lvrt9Jlpo<*Ug}h<9c76Q$?IK5YA&;1@%RhiFa#WYw3lv^T z?TVfsV!iSz*&gD~Iy}}Z5BbFQ9;=_|+#c(dha6(O?K?a3Sg$vr9g4 z%17KAe;>|zbkja@%15jl|5}%P;*{_94F#MVd3BxNT@a&O#JIJ6A#m5fZ$+H)U94}z zS&~;f{3e$5%0sN%_1dYxYrWsa@_--cfscRC-S7I#$o-?g)calXjyuDyVSUbHSr+t` zYVcjd%Dt^TmSu{CpBh%~ZRN2nQ!ISaup42+<%qqPY41S6^-XNcV_C*=D7e0fZFwxq z6zlpXw&k%bQ>^Qo*!!)Bz2Bm}{d=4ZcOqDp1-<=yoDK4u$-G{cDc0F=K7wVLV%_-4 zd;RlzS*BRTxA~g9i|Sk9o=@|)2w1Lo#Is#9ZhEiaUx~ismUYTO4Ey>1y~z0ep898@ zn#J68jNk8tdxZXXn2pBL-1Lh7Z3JbLY`;#d>cE<1 zV{$p@u&*v=c$O3I-w8L1G5ozY?^a@+a^Tn2#+|^y_hHbpg(F!TELS}I%GQ7J!GArx z|HkzSWwsw=J$aSs=CS|V$k_j_j=j8_!sclW`tn$oQSaeOhLyO=V_BwHXM@C59?LSt zBKMgM(vLrl*!!nyuYAka#&9-Z<$mSRV#*N!b`c$O<3v0-B_ zvG}LSVr6N$`Qs-x=B!s9V#N31P^1rs*oUHjhu=Nel*h6x=q>JXW4;ge(9|XDj@&h1c{e_H5jURUOsl{=X6F{~OwW`4)%e6Pc?w+Pv3^ zb=2RJ)4x5Ue>?RT@FCXChdZDb~en;k~VTS*F-ZX7AYumSu{C@7Vnkd9V8RuqLEm42iybJsoe%r}>?{ zTb*2crAh0%*Ha$m)b?8PPW5P;x%Vy-r#2(+n;%WSApH2c#5(1;JdY-me;WCo3Cjb% zF9C@&pU85>Bks+fhcBvbxuOl9 zV#?ZJopN0KPvIF^-X4}I7V&Sn?OFuOGQ}d^4ZD3)t6r8V*2TmL!@l19-es06-o?a& zHh7jR-o?Z?p6i7^?q3Kk*toNtcsZ9~<9?+Lp5=;nd$w&qtopgVOy`y5ig*5hq79zq zig*71FyN8H@^c!>74P;xr}13!6Y@=>9G>NhhwocnFW|W(#s{yJKeCXze|WN-`42J5 zb$g-vj=O*PwUzmK`8iLN;RN>Z zN91!`OK!g#`93YNs>9tkxE*xxb*d{%wV{LkfG0H`(nO`O7*a@r?`S;GTJm3d-ICJBUqLx*5$Rw0jux-l4Zx` zPSz<071l=?yGms2Dmr%Z-9E$Kk6>9wz4DDd!s7tcP)5o9UkkIhx}sg$$Qkaz39De)+-Nr#(46r(@s3rD-Zr> zyyKXhPCV8t&-tRv>F-A7^mjR@CAsHgv9<|g|GSazS+G3lE)_5aHm{<)H=?_jx_b-G zjw$HQV_6pT_7)Hm*4JwR8}>`n>4$mHmiYkdm52B+-cHPAZ-+BctXCdl#dv1|uUyA! z;Syxl9_y7?$<_ebOZDQr0i&x(uDJ8y$!04t%AL-}TFy=N;#$o<)Ma>XO2ZQpbX`-z~x zK0iN=m%@t<>jUe^k$tm`^9}3~go9PqKCkxr!u+w6$9m-?#3)OTg zfFF?S78@Ulr@shoVaqjBKU$NQXu7#$ec+XJXWw3OS=$@m|%eFW?>-Y$&I!H{?2Jl2Qyit>(F%eUtOPx4&z{bH6Y z-tEZ~^q=iC<5^C;e>ba)Bm2|&+q%Rl-^Ja%w7t%J;*^iLvpJZ=9HiqZ-+RGWTaI9z za$LO0JI@ZT6RX51*Ike9#snQqMrLa>Z%cXz4O)AwQx0Ol;`?0S*zY~ko%}MUI<=J; z<+}A|6LRdqrtikc@8L2Y>y?N2uza=}c-E%el*z83rD3y~IOQW|%-`0KtI?2hFb3hP{uz<*_Uadi#4}i_Nd>#TPs5n^>j~zO!C= zSQpLzwU3=3**m^!@+JFJK~g&I5)oR$7pY7K5@#&dTDugBXZ1Q_MN!2J(epT zIl|`me!%0~s`h0$XCv#BgWO9`nEyzoY$wZwSSxiURU1j#NUU@D*JPtg) z)=XU?FaZGAmu+FiJ70* zb-V{-X!>UZHm;v_L4VPID_!)DM)Z$Te_zq%G0~C7vW#{Yk;g2yB-e~K?M3+E1B(sT zlP7Dw^+EP;qix2Bb;`+&(T5^^_z?S05W6g|tii54mSsV2!GE7r_C0wl%M|Nukmo&l zEXx#&d}TJsnEyz`-XBqW<+~+@72EPymQk;)2Zj~f@>rHBHfL`hEB2ZVeK~voNyOfN zLVHWS&POi7-aM9N!G@CW+eTnN5YhVqn>V-Dmpm&%RIl6XOP}*t zmZ{!KrdRBJF=FqFYHts0upBSfEHC1|GU_CxNi z@YWC3DaZM*jM-qsmOf%@9X;fG8pniSS+fQ#pZ7wN`6V(K(4oO z-GsGwFwyVG*h|lc7OGRL*|-v;ZMw0NzN|+2vdX^n54e8ciC|e4^!Cel56oW&F|K*N zEK{tD+w&1D%M|P4b}#yx*UK`+VlQNSiVFeTdM(Ft#k;jk&iAagxjto`a@;*=8NbQM z_)V%`_PG0PGVggT%Yxpb+%xySFuBfJleU2vHGh`%WU|9rlX6_XkUk7V`Y>Sroa;j# zD}6|@xjqc68+oGb^iUU}%J z`S#7gYu%@@Jm3d<5H~ia((iZI8B<~cw_nZ$7i74y7>1WhU-^S@vOWznz$SHpdU^ zXivf2tGN_7vM-W>sNkjSxT!E)o2|Sv*YvGO;*{^!${p~LZ->2!yGNJ%Os0)1v8n_4 z!mcIG$8g7wbvq8 zmIb|qJ#Mcp*Nl0+EK{u8YfC=KV_BwH__+7kV-b6g(cb<+x30+kDUW4Y(Az% z&5*~kOtJ6@!=8^|S*BR{f?;KR|8aQ#RW^4lBev?sLCQZK>D$M3E~bIC{oLb#m0T{j zU(;KKX>MYDXrmzC5&cK%YlmR_$3slLiPPBfnM(1|$)(!ixz+vIX{PA;L~>Opa)a6O zDAkEGQMIGf^T(R~p7qK@elXr!h)vpp{7_w)X^@uof%VG6yjpIS=YHg6-;C79bt#t^ z<+}aDUc{Pl!^cc>&-qxdJj}V-dO78#&xr!l@(=5k=k}%YOrPz!9bv9bVw79Sa@U!Z ztGhsbX>7i)#3>)Spk%*i!aCH{SLNrwN|;~QHU^&RL$0t~dOFpYjzQ);@JAa9;*?*_ z#&F|{W>0!+x@inquRN?%U(kLuQl9y&JZsCEUe9mISH0L1*qXZ$Yc9vf>$O;De$GlP zb<7|qnqQnqbqvofRC)XeLy?XJ>y?N6XuL;(C(nT5Jk~1@ac{nV5NkYbPUoOJo%1JR zl#AH6{>pduqFmjl9CLOPt2z+t_S{U)faY{$#~34eh*v!>_HU+o(uW4ie%x5EJjA|@ zTM_3$J|6asaUScHhqyPpF9e?KMN(esgrlpAOSnJSbe@EG)q^}><1ab7D0{ms^^Di& zo3Fu%3EbXZw;x&!T(KcM7qvTREqvmX@A97H^kT@}?Y}EajB;JxliVHb&bDwkeUteq z>y_v7-tE8>o12Li>#SE^Zryu3vX;HgwXAp;K5cuJ+py#9@Jzdc@5t8E*kO6lT|5jw zHoUCMZzpydD(eHw6%U^^{DpwG(@+_n<%)N{Dd$z*PKIlT@mX7B-j=gQtXH1%%|_t0 z98pU9!+Pbpy@&YAbY!fib*w6w58F@3Z<_L0mQioT&A~qOJC9|VVk_A-%f*0g`c7zS zH|vyx^~KhME$HvG{Wgm4A z`0P;iow*sTB-xy^PC4)?g8uoMq%QD5HkA@X{ zH%IK@9BuWr*(XLoSzh+_jH&) z?waJzh2=ulaXjSNwZ+K|%=ziuy@blV?Yc7GBu@G0i}9~vK)c}+r+oC!_|LF^>V{98 z@{yk`e=cILavJ9g^7l?yu6X1q+h^Pj`0jo?Oswia?y@$YV1FQU(sDmDln4Ak{MSXS02kU+AQzoGOYMl9?LSty6a<1X|f|??+%TTJuXj* zZFwxqg5JWOYG#AjmdCP8v2Gm1wmg<)ip4ls-V%HNn)hPT7Ydr+vrhY1$!wA5h<}~y zBg+&!ona+*@>rHB){V#62$p4vb>s0gf@PUv-FV3LX5I#tDb|gL#OhzSd4|V2a^!tY z<{vUnAIyyh%L2AgbmOrW!Lm%TZaidu^LkmP*lK2j%x@mcGR3;_5ZnGJV(%YmO!d3< z;cf)WvY@xr?{f2A*pS!DGR3;wd?A8mnPQQrEbqv^?2qW9a$1WwZQZR$n3(2jVpRun zm+kM5r#f;s8XcDywQetDF?n{*IMTT$M5~|a~C%btXCfV#(0}wNZZl}A%!ELXf+pKl>X{y6x3I8~eCS+02axa|ju z@Y6p|X6g&?;Q5J*53;iuAx`=5bBhreGdFyB&U2&bIKt6$j0F~ z#^HORU*+2L%8|5RET`^4=RXfpyn9~Y{FU|O$$f2$jVX*D+tI5%99Fk6XPt83JI1*Y zI5OX@9M&nvU6<^}xU-$s7-XGt;0rca=TZ*t85}saFf+SUUzqz=%lS;=l<)SQn=w~x zQ?Hk6Rr@i^GKMDYCvnP0uC{)j$oQ3aYKwBlIpwfUImp?@c@#J@HV0ZbtWyqr*kbq~ zoSSyy-bO}C+hV=);LFCl8F=mQhp=9G&WDT089FXzWBRLDn|orE3m>+7NtaUY{$=NB zsnw>)^boIlkjE{Kb|Gib2HZlcz3WtE^FoYrXR>~uPq~&Uo7Vx>E3caIHe+x8J;^Q2 zv~-+VuRO$}*?K(iBsWjgXDaheZ0jd6%0*n74?j-1uguq{b7bd(#F6iR7h1)A%kSxX z@6$ncJk~1@F={s72|P0u&+%=h9hVs8B38|>kLQZa!GC`&81_Hj2>*xw`TM`; zzeJb(%l@0C#SL=4M*a?=5ou@kFMkYC!oLG}s=9FG<#MI|a{4Qe<(JdrE+1ubI(GCDLcSniYC0O8Ntjoa}T$w}lS`P+fqEp}`h`jP*8c1+fnWu2Botgxn7 z?kf+BjFdwgoo)H|lbd1y{%%6Tn0zs6%Yl`}#rjg?@YZUi@`#^M6R5qTlj2hz6z2gYo`bnjQ>|b>3Q>OvNvyO1GV5YVxr+~_%J%!$) zocEBw&UXAy$z$m#{vJc*pEu)imibT`TS@=O;Lzyc;Hc2oX(!px($1ep`x^pw4qs`C zHQ3ufFfvpqYtPne^S^89+rxOg;OWoI%F+^?_1IWtZXR#O$oe=q+S@zSR~+l2k3ZGY z$4#Tr_?(pIQ%B{e<}+A--$p8HX?D+G&(Ki+0GnNBY)dWeUW$+HNM&K6-WZw*NAacQ zted@s(cZ#{yc0nFI{VDO)iSP!;&H?tLwzbWF_0zF6R@%gk=%u;ZJC*sCZkC5fiUWH_hQh3_H@-jF(&qR`)R)S*DKn2y znZWt%rP#ENlnaBU(NT7ET_3*RGOy$NqV4WqKp*F-S&Ku9b8pHo2(uyX8R_fmEA`^K zOa3~??01t3x{tY_>&>;>(J|h?FjGe=oN34t*7?Q(#BFASYrC(1c&KlbA+%20x07pV zQ~nNNfsr+4_FqKX9zD9)IL3BkZ6fs-ihaGhY3SVFf460vAI5WW%Q#yYh z{$E01o&&b$FiOH*Tn|oTvIleZ%xiEuQyd0@7Az?-b zd1$PsTqqXpl4qT9E^OF=ciqU}4y=SBXZ}@WoEw#wCSRs> z#jfF^?JOq<#!_Ed-tNx7&VBl)i9BnOzf)*P+FI?tEj?A442}&BjP{qi+4p}x^hw&g zh<2sDO|iXNQ{R^A@65?LvvTji!03>?|6Kk$_v^n;&^%Jsc233C zrffW4#inmgzh%0Z_ zaoG**XkX9RXrbJl|NO_varGbBbIQ0rY};Q6iEwXh8h3@|0P^x;Wk!zC!<3|dV4%?3 zJKD{?oc}X9q-|c*Hm}6?d!esOwU>vgb-vOAw`zKO_uxj&m|Z+{p38q8d_`v6#&kBe zr*-Z48)4-=BVz-4_1U?d|1c?koW3>wVUFRh)-iM!^Do=|u%YSY#u6UXPvT+_$1RUK zj6Fpe!xh@t=$>Kf?`+5amdtDJxrd3AxxCVv?_3+tVF#egi?xNSdw!+|cSncIgXNyC z^2UcZY|=HYfcY2ucD2p>oc9g`Q{FR%%gEtw*3$nXIiq{so#x}Q`#tc3bYiM}_)JMerpgM5j8MBkQ_^z{_5{%e+5Z|py{VN%Ebvd#M!BKzNU+UK=qYC#b{oEqvW z4~Kqr9_LSNkh3!KcS_qIkKGIFs(ts_Dcy0U77Y&-hl=T~g>~lSe^2BLn*7Z}WP0wl z<|?@cz&@G&Xmc-l_yBH~<5`6~jHzOC#8c0*p{^`cQ+vkx2K)C6_S@#O^BDd3hC5;m z{>+~7wtIKj;5~Z==*{cJ z)1_py+VKcB1Uq8avTb|^uYNHX$y+IdrSYrIN9h1S4q4G$1NUsLh8wt>0`=u=KpeX z`~9KWA%5du+VB zwBh9@Tx9dy)8F4eJfL@#*7J$~I@zfA2rlY9g4MS7T(CcwT0Jm>mvy*S?c#2@IE0_< z4|j7P`FqJVnGpOvfXF|${Y{5GN!vDG#>V7my&<37XvOHI#K352Xb6w-rM30O;$OC0 zV~@w4BVfMla1FMR?lOA>->?`i$@}uxZ)@X*N4tr;g#%JD1`q#b{2qyG%hE!E6{}S2 z>Gq!J|D4ACQ}x57%{_`pTQ4_-{-K_vSQ;H09y7DukmPgUwl+Cu-L_kn1Q^pl zgxg^~!}buNb1wR1OCH|TW=(j0TWn>3O+EcRgN5N?JE+pxrk~g#xk3JH4|u7~^=r%~ z_+OeaV_Pj)GcwY*XLPK2uoB^6m3=wxqDHJUW0=Q(dhkPm?KK zOKz(l&$h{@v9TJ)jXoK#U}NV?8kkia>K*PM-J>gO=W+Ybl10t)+jNb)w0_>OSe8rC zE^R9H_K%f%`ngqIXZ^dIJkYU{>pyX^gKhR>v9apbrrrb>T)lXm-f(c?b!@ts$oEv_ z?~2afrZ(5dW|Q2Ql~e9=7$Llbi3cY!KLdRwWc9(Wo^yS0!xe3JpU%%f+ z+v!CX+8!>f+z~o z1VKP*5)vz^fb@dtJ^sKPK*b%{TL$uY54;(vj@aim9>qz-+7gK z|6RS?Pt|=hOMZ<_lkY8T=H_N+q^0V+-)ggYhc}Y^Dc4NfoMYMZ--=Ct=<>1$@C<-c^qb0pGtc?=Uc{9o~-(2<7X9aX5#Uj0fVygGqZBzJM!*6|8TJP zv|QU?Wtm^r-G1Mo*$rolQVl|RbT97o!9s22|Ba`f?N`o}$12OdN-gQ}vQsk$(2*Ma-gm0O|P_mVo+gV=xb1`NpHt}*o`*tm0-|JB}EqK)^grHyaVw)^L0X3?i| z>SU{B%DJ>@<@%Ly=ejNQX zFEc-P03&}L?7mc^e=gbDeP_(&Yqz^)zw|P4(lYxeHelWPUs0o9{#r|Yiu`-o85y}5 znOXX*Ut4+K?^WyT*}v-ZezRJ}r5gP(H@TZ%zUmu2E%rj!qvB5@ z-6fL1Z8JK&3hO_%hKTT7iVz)6Cm+ReCEPeR@NYH?H(K->1!*~ zzq}!OtWnp1{5)FrZ%iI*yi$lQ;lUXL2iEQUeWz#k>~pofVKwJ&Tgz+cH}QaBmVPyO z>VVvVS!s2A{$*gwr+SR|)a2XJc5CKa*!R-2vIl1m%&61cb+flg6*BI7r2brM8JlX_ zomf3KQe5t(r*lD~e}0yV1n2IfZ+Sg+pHc5tRQ5L1(uNcDYaXh}N*~O0)HhbEy?ebf zJs(|!G2fo$+-35Y8=V#L=fI&|DpRGI{c~~#q@|jsTuWY`^~`m=A=>uFTJoxGhufCg z0y5^gQ-ZAs^|H`f^Swuk`lgX`W-eT9x#nW>9o+a5+^^^-gUh$vKar7{mX)5HnH7(+ zmVCeCu?y?FO8!-UX4KM$%~xr*X1afFIuDYi>lHw4?dwYa`7vdDsxI?6wUoJK-NRyj zV0!+bv^*7;a_)A$(mS_R{J2$=yUOzt%Qah5-s&s1`uwBL$@-n-x%qin0|%(*td(=y zywF?C{SeBjwVtxMs^&QDpYM&$;FiL8R~nGcS0wZF&E;-e=X>WW12}UnaZW9^m|&ZW z9W_^W+&h^*FgtaCo~gNQZ}Qsdb)A~8sbs9Jr9Dk3R_`Cvo44_M^1Qs%-2Bx1tU9)% zo+(rH+|bx?{ygFTb>y}cf$0@b8PtaKevg-8;-j?`v!Y+X3TGAu@!%?XejSgDB?Sp=GA)%qj?O7>Dj5~ zR<&B%YttHe++f*<&8;dcDOUISj)*QySj!!#wqyoosa9B9-}uN|A;$f+mi@Kixiih> zr}C&8?9Ba?IXRjAGqN*s;^u0}+XLRI`ux2@*IzSB|F_xmZ!lK(L&Q^|*2;c&_1_Rt z;pOM&rL##EACBDh`+e{nXSGgChUGd#9n+$g$X@o~^t}E9^~Kv-%YT_C+w*eEc%dH* z3C0Nd8LsR>S=B&ih7--7Rh;r+p{dS$1YxT3-MBI*q}*q!j7- zs+p6wt2s7>&gay!e>-IGICXA$@q%b+d||}tzqqtmZ9?grBl8Aka~)1!=&7~LS9?SB zI5|Vltv1$NJ8vZ|6RYEI@3SO=N8WQ;gqe$6?zY!2Wwq`v6Y;46Z*3jZAa4vE$issJ z2kVEYYt8%b-n-iFFl{%Z=9sqCya#sUgLYoVfb>C`xpleT`jpp)>z&FK=<;4&bM73r z8G3j)*m^WmpU`nZ+t43Wkj*XARLOIQGpj12;g^PpRC%d642?Y1qw=ks zyNsUnHtTv@uIsH?&Ff_0^qA>W&FOif$9id*se_ojnJv{?((t@@p*~-v>T#-F&GS<@ z4dHsKnU0`9yulfngHv-e>T*xit|?`zGH}b0`g3Z{wNX9N5O22TH4y3fteIH3C_Boz z>!wf2I^9;*=yK^<_db=loj#Q6plH+?Rdsf6K>wUf_Im4dO`%zedbhc9=3Kg@=5@@F zwJqAN|LVuAlA|LFU5z)7E13D&X=Y;TE}y|EQ}rJ33_TaVqvkW=*7W$F;$YDcIv^+> zJ=mmWGx~9xp`T}WT6(9n(&w90-H&?Kyk9J2YKyW_HQ|>}=m41(?(Q4N!m}=Oo_oBW zl!tQWd6q@1>OAh57ssgY#{_Bca#J(7!ywgc&biB?Q%W=4mllx*^=Db#>m~65wk=bT z&AoeB-26jqwe_2JDV_CrV&?Qq-1Cs|coIMH>v^xeK1`41*3XQ=X<7Q}fxBED^Y1%R z>0g9YxvZ=E`RM;GU42c;W2HeQ#v65T*5d68G^e`m@AgXBq}xgOg1=oGlvpy;v!|GnQVe>qSQCO)@W?m{!XAVvc zZsDzET>c}NSFa-hDhtMvFYQn!x} z>puR5(iW7(mXnC=oLpWdHP}od++)t=-nP0tX6Ur^Y*@R9r$v`aYFb+6p#0#pP)oVA zNV!Lsi@CnAw&tEkDF3zAO*k#;raW$2P+#-XiR+)1o0^uFY9^uXa@sj%j&8p%==QtZ zJr53#Z=p1Ye)b0PY*h|RC?dqU?O*Jv?`0_Wy&l&#*4#4**|C)krBKZah15&07sgK+ zUOJCUr)8+mj)PO$>H9LxGoq{9YgYSuU_xc2vZ})CpU)tc5!||3OF1-8xkIPZ ztl8$c=TXLfsBFwutD5A-s`N`my!^~T+#hFlS!=70TfM3JK3?^lu4)>;y2rDvq(fYb zGIy+UA1_yO2i9#5;TcaoL#v#b%T>Gk?^e=bZu#=m89$5bkA8gacCft0dk==W>mgMB ziQS`|bjsW;z_9AJnO5Vy2d!$}FB-DbH@+nse^p}W_k{ht)byOpTzz9rt@d|Ix!jyP z^jNvE=5@!Aoxa1OReWiUx2Ldas=x7(ustw6HzzZ1P#y2T$f%L`b<)|9 zlF(18zlGk^laY~{nVL6HpRsBy`|WDjU*g`E2pJY{t?A!CJCz3l2H+o_DBWbBTM-9BN)~`Pq$=hm z@}JRvQ2(sps;E2v+t*GJ1Z zx8sN1Elk}nVDe|;R)?xM_U4}hbvVhU!}icjpT_+EQsLBoU3&|=0G4H8>bWsfW-`t% zU?!bRSp&z<-naateB~tj4$vcxYOvkNR9g${4Kw!il*m6)*%=5k`C?rjMoMDPO^=TI5)#8Ea75QOlJ!_2WHC5 z`07xVzhyAJ`Iv4&aA;!I+(iOy`_o-XW~|WD|-)z>`A7c)id@ad(pw(2-!2? zjlGXU_9Xi%6sKfAIoM{HDM!8atjziO+lGd2(k@vGn6V?-t`4>r%-GY*vcO)qkUh!z zgyNJe&A|>1*)#QM@|PE~C)ub_oRUp;u<0;!ynd}okiWShdy-Xz;*{(-2RjXB%G301 zlRtG|x2ZqLE)2yf*%c0UL&)CFe$L|msQz$k$ev{PhT@d$Q3rb_WUrO5_fp87WN(Dx zlM`ic_*K4%RDV&zwV) zSyg`nLiQxf48=c-pU`qB7Y&VrK zoMh`A>MAW`3Y-t9reWLJmclvqbJcB&p83)z$G znNXaPt#h!qV5U6H+*X-X_C5^RlWb!sPRV|7u-`)V_Ed(nQ}$9wh^arxn!`*xldLt& z%uOX54Kw8-*(}&#ZC|o09O3ST+0ybT%+#NZ^Env*_nl$KdL-O zQ_yCPiw^c0 z%(Qu#&UYQ*K5?+G9P9@N`xRzOi^rnK)?S*z%sH`(mvE{Lc7~ZaCF=>J`T9<>0Wh;} zkSq&k(jwU~N1Wpv;ifvmMI7PgIKs_$gsXOhJIN7li6h*3j&REz;jVUsTjdCMrz6~I zN4Uow;nq6Bt#^dm05j*fuDVSrF9mJG0^6+7Bx?&Z>u<^Sc7#iFgv)`M_9^2$6h=4m zon(_?WMiwW&|z;r>?%vRRxI|-d|cY=0n4z2n-0sgu;nnbhLLgJ>R?Ye*qbo3PLXkb z;|SM;LBf`n-5sotgJn6`WCxoIn`$YuCt(9E>}S~B7Pg8LxS5;Ea`_Zy#@)Sjc;%@! z{|C&Ji)5|o3@7R1CA$D-+NWe!!EABf1G`Aa*-iV(Q)wB_hJ~qH$)>~197VD+SPvbS zWEVT)yw$;;gzayM^A86b%;tjW(=sgwJ6Imfod0CFQ7~It7Q;+E$Z!|H%zRw3+hJ6N z@49PWd8!^BhnYM`wiag6DcL%hsXxg+cf|P(%(NF7t_fhAPTxM-SDs4e1ej^-l2yUX z7%ADwu)!(0h4#rrqprj@HGzh49u+mWVjC;;XZeS`xAD6GLDmRW-?ftyh}C> z)*>FPMz~q9CKfga*3`mcFf)codrLy$dg}1XQ)PAzjMI+qB)h^9?m8IVY^&k!hnY4n z<9yP=UUsl|9PA4R`w3>+nM{jn5H_|W%$A2e9IU$|&Vdegh=YxU(FM0!)-zxyYPPTT zm8a_V1DIL!O7;iLv?a;5r6D!baY@z^W((KG5w5)>Tvtc9UXE}B9N{t@;f6TE4ReGW z;|Mp!5$;GwxLJ;H^Bm!-9N~_0ggey{?o3Cx3moAtb%eVH#&GUC*_Q5ynR8q(eT?!{ z+kFuU+uhl!MF6K4IW4pnU_)xi#Q zuv{3Y58uf+r@>6SmaGhxZ3%Z5>?jNCz=o*l4>HcaFw=kf=Uk3e2Q)KOJ6qDi3eLO#Mmr5zNdrB-`YO^LGbp z!se_k&bBaHIy=B@>Ffr>r0--pvtcbQY&5L7g-wB(`I(F}8e*njsAyDqR=}8^`cAUb zVI~ifod+{{muxxA%tIu*1!nRm*=m>>3nY6GW=qQxFk4!lb=Z5|!9IeSHAO#NKFU*N z*0ggXEt2gFGii}*HwW9x5odQtxIT_>sg7_5IKt&P!W|0h>cySRUkS|ApJb&l{_i`< zmIC;{?4*rAF5`!9bvsrom`Cc>Ip*fa;5>0reUR_0(wJJ<;@lfMBvy~&vxWOSng1r(0M)oxqls!(pbq$aF?vZ7p#w2!$J{k5Qf~s^ej%9wa*rwxd2?vhy8r zUgC)JYDc(Lj&OItT3FKZkb^z#VC!L~%w+yPhwZHG4br~yRGIw@GxZ?ZW|*0SN!FSH zz?7$ConU4zC0TEn>3?P{F=aRi!FH{N(Zs!y%=Uo%L3RPmN@sJk-TPMzrn7zu&b!h0t@>c*4e_^ zQ&6^WM?2W7u-2A1KZBWe&7Xl&?RpbG*xJ(0Y4&g(VN-NWGR`WPEiH>-tt{a#c7(eT z##W~9q`k)-;a+vv`@|9MXNSEV)9v}|1l!e;PWAd|Gfv1n42N~Fgo`@D9SgJBJI4|3 zdWXHo9pT=D4Yj1R<6wLL8v^4L=sTJBQb)LRVK#ejI>PHF_rZ3v*n7bd?n6hoUmUFE{`T>#8?4NdmJ4BLSy<--cqYNZ z#=$sU`A(MgDKMtdTV=PwvMua;n2F2y>QHrF>2{#!F@*X~vcq6m7IrDjX763tL6&fP z02rElC+&@aF&u1_{R?I*m(?&^J9{3st0m449PB5Ut(`SL*xn|(z-;!?V753%I9SAC zZy{_?Oa3l^+1lqehuGWaIWSv)zYAvWjga;C28=Bc-%0j6%+_}I8Deisb6{+j_)f;T z6xPGS?uD^M;X4`bJ(#UscLdnl^$ZwGh^@wX4$RmwzB(`kJqdf;50yB^uq!ZT>wmAn zx>&;f1nX*HZQ1PE!@~N)+FDo+>`)6k8)nP|V};TGiD>-}n&t>50`V9&s8_5Q7c zwav57-PB7kI#}{B%E5{q>@-+MOPtp_*yAu;{x&+;&iVFm=?-=TjMJ6xWZS*i!PYxi z3nqiMIP+jvS?qlZvz-Il53{%3{xF)M?@WJE|DpO{g@fG(>#7dI$#5HnC+;UQ=PY%c zI=l@Xh106Eu)x zI2CSRn8~|j{b439$x1_U4hdq6*TWg1I3+s|HbWmT*$=S2HOtbz@>Du^9iK?2WbI+5 zok%tjX2w=dTY*z?mWAS!>}c3zeY9jR!py##=`-q373VvlI3@cSX4XvNtO<)(lJSPGi(RV7`g+e z?A_~NkHJivkl{Xdg!|gTesRRP$0W}y)v1&A7Q?z}HZ;gVyxwnynK`CpZ@^5MN%kJB znI+E89O1rpgxll@_q!w9HZ*uuAIiyeZVNO0NV3kbcJW{}!eziryO!aKU`3X2Yhg_+ z>^Yb%ozKILu!QS5h5LdnY$NO#3!6FB^X{~;Hivm0rybwP{LO$3v9J{|TmG(rwbtR7 zA_Pw5`5stP{flG|!Ax6{>`6zs=N#c)f!WgXX(&#nD}ht#{142Gk&^unX6jF}-(aSl zNw(YJi8;Gu`@%Zu6i7AmX_Nb_8xSwr(vd#jSNaG zUPl{Xd+6UJ`vJD6g|%Q1H02`0b%L34k*qgtM@yU;j&Qk-aN``|j&OuK$`NjXBit!4 zQ%5p?XE@k-Fk6{j4|~y4F6Bq^j&=*no}RdFDAV#I>~2fA>t}f0dJ9_+NnBHuakign zXKP@lZ_02l!P;8veFEFr!hUqHltO!3+6iV$O9z-OEdyY-vw)4>w4tuXU;{4pf{^zjQdUj$>Da)(_%+>~bJHn;GI$FwQf+NnE zj&O@$wlcfK!R~_XWl77+FxzpjQLrofu&<7K!b zVaHq8JE1s7>tmFs>@_V;*pqA!%-EA`e^^Y%CE1OkILGK?l&9>y?qDfLCG5#?&0xl! zWJkj~Xgh4r1y0$!05(MbBH62*6ISAXCndwX6Y99t@ZQ-^;CTiGQ3lVr=v65-g62%HLcvxBX1u-9RxO~^Rk zb+Aty>?;TR0k(rqIa>~aQ+fE^!M2<4d7bsqGF*3xdcX*}e^|G*2VcJ}caHqj`w1hj~!LEYsZ3*`TthHurUj(!z$qOu5K7C&Em7mh2{&Y1eEg1y1GtPFP$0 zi)2s3Oq-YNC73BQ$=-ySek<8WuAWQDnHbuvV6E-C?^}SUSw)o$aK+sk|Qq zGkK6K-@(Sf%z2EhrogE<=fcb$gk-0|Oj_8g2%HLcR>+=Y7dhCKusw84EXf0>;=CVb z#t_L~ftk9M>}^=4j!CjMM<@3AB-`J?A`Z61!ESf3H(;i$Wm>*>upO#BkJGsCWVi*e z&K9=J!R~|E(z4FMzH-F5!$Nyndckb=a$#nyV=E?bs!dFWnKm!k^pHKtPK52IW0LG5 zm}%FNT@LGF3HJ!hjCC^HvoJH(N%jV8vL((w$0X9ic2eL}-Uq=O3q*JoXVJ4lDT@N$ku4K2v%(yGrYp|WYxRdM? zm>G8^`w3>oUCFjRHj(#8JZk@6RSzv-CV!H(ftmbC)&aJsj!Uw12OA4B^)OSUWlG4N zWHTJB7-r4^Y#9YkYp;Ki z>}!~*2gx?UGA-fuJ1%h!kl`je*s%_F4a}68jPqd!djrD5vTaVZ+uIjr+Mo=V1GB|B-oYX; z(ze$*ecm#*tYQ~Ys7gb%*;__ zxC>!pE#W?eb+WK+PD%6!Gv=v7Rk`c}Gwn>W-5qQ%2ix1h_Jx^oN!si02$v3Psq2NXaD^I26W|(R7lC6Pt)W=KqKFpMh zWS=?M*D%vpWVlVRDvQ11QvprlP=+i1SAc^3c6Fr6-&|O~c(5AmQrM0bwi0H_QQB*} z*dDGc%vPR*VW!O31`eD`=fN;jN0N;U#W_C+70+M9!4^2!nXslhE*a7D)EK!`^2w)0SkoZ(yeXN%lVn+irASmt3O%$z$Un-4SnR z2@W;`W@{5AFk6|O0qbr_%k3~*J-h(xVhQ(+gY9&Ny4NJMFB*crEQ+3Nw2N zT;2$rO6T1U_5v(jA1%W*IXjVebFNc|syLg&n(1(o?cxa6&JnJ&BU}$hxPFds>5gy* zJHq8T!i{o-o9GBv;0Raf2samI+L`vHumT=kUCicW-oD*SfE#Zn`rr&Z&A#f@WWiZorC98%t z*GEfs66_!gd(;u`8JI0CFTqS%OM4qb;keuoIF*O*U?vZe{TF8PAeky?8*2_T>13-u zaLQgQn6W2WyHK2xb%B{Olk7-GxY;mUT1sK2%w(KPVCMXAOpt?k+r1?er(}0K*n;8bz^ z3^RF<><^g9gJj!Z)90!ZRdRy#W3VTO0wyy%G@>jJiac_lW z%VGQJqb2({OfO-Bcd@HORh-Yj+FHWB3u~d-BJC?rh5G__qyBA?_LZmDxfgrh*Xj@4 zBLCm`KkBFBE=k<`D%njAwgEO&$0fscx->EWJV_s;JY{bPtd;(at)IXtHWp_3En5JA zQ*0*8#3k7$Fw^^Npvfh^`>QAz%FjEhb6~a2}I8W8S@>Cv9ftmJs znqX%**m(}N9QK!vOU8Ne6^VH(+ZcgUX}JT|S^py0I+#hPWN*SupO)+cN4U=&;l6c* z`x$1&d1>xB-rEnXnF)vYrHMX<-qEy*V(3P~XXN*$ms) z!n$9TD6_@-80D!p(FbPAOtMs%8M7oyhjr3%Nj3>)#xu!|g6*ZlEz!R6R9Y6pcGbU0 zc3CLS)AcdR^V>CSNBx^*kHAb>OZKdTz3yNiIoLO_rk1p9a)k3%*wfh(X2wXC$bnON z@34#G+H%C(6#mt-HpOuLqBBWw>#oGI5Q+O7<@8_d)L%lyEpsCvRoJCiIG z)?6Pg*+DQ%h$h1wi4FV!fu0^@|5B3hncZJvZr9CT}$>htf|G`N3c#7=B-N9gN(Bo zY_uiZWZ0e-Ru+nrEr-CVGOKp5MX)ydXtn?Xr@~zj3MbiRFq3!5u5pCB31;^ESt18c z*;@^3seh5|DcH`Mu`~;u3im3^^fAdkgEiAfOZE-Stj#5h-spKRS;7svDUk;mE(>Pz zAlWFG83#?jP$pC!ieaWaB`brOJV;jU2zR0*++tV@oj)1p`LNCwb{EW?r)9WjU_C71 zzJ-}FONMK4bK)Itl3fh5mCKc|LoN0;!tSuJ<+mi(+S1-NFq1!)>w!~sbU)0D6Ougz zGj$}{3ow%h$zFx+t*uD*3v3q)YkI3a&Yc{rEi7HfY37CMKUMxlz)ati>@b+=f0E6C z9b}2~dYH+(40nrz-R)ox!c1AqIG=EYd)5(dy(8QPN4O6i;l6N$`_2*W7e}~1VWuBl zq|01+s{Y#FmRO5QHVoE59fVsJ_xyj=Per#U>PWJ=uyy))$qt}{&9|^yV5Z*LRtTK3 zcQ?$mCCQ#}u=TKAbxbncXRyu|w%whHv@F-hC{LxOCG2edn`DHX%lQ!1WvI_VLR$yBwGnH{YbLg9pN5! zuxB0Y4Trt=9qe-l`_{pJfep6geZRXCZ9?Wf6=v43lBL7;Qw58Ytni-1Tv4)xu+(@k zkFA)%si~Jr4GegFOK=bt~h1&Jk|CgKcoI4;<`sm@O^e!c6;=>HOWnn%$eY zPe+Cu3^U`4WcjdNbm>br#lhylYnhrOp^wz_@K5$CtCX_j;je<-m&V%sZlsx3ufW}YnB5}4_KlAQxH z{Z_JzVWzK0b~CKMPJv|aI9Q8^6Ype};YPwtI#&d_i}#}mFq2NnroqhKg=9qzHZNrF zYGJQ3WKXi=LUBrVnu9G3*}F#Ay9lG|TVr8OSjFt9B4(!c7f${4tg_KW{l)cQ{hRV{^={>t z6hdsnvm4v-%tTY#ZgZZ$YQfxLNBY~&^qpN;*S6uD*_OV!JMU@TgMQJTJD~-xTr<5w-UA!;W_h!{IXnS%lsA`WQ08%OevEHO%=gN@3a^r<1{Qcn zv-i7@_p~1C9miXRPT&rUMcg@XvUiGis&^XS<6G=4;R||aa5d#Db_kYw=XmFG$xkuD|r+A3h!#~8t+=~I=<3%gSV1x{u{lUyqmpSDA#}f z*El7xq7UyY-;RAK7E<5r;d$3EdG6NJ^JXzQ{j5FDD>4bl=l51U*kj+1HNXzM1A8ye z`+&jsoesQ*k>4}>aqVFr=E#IOQgw_rJR{$dclZ)^e&-gekFnnS!#Q%=uO<}0vuILEwB znHEsC<4Ip<()=s=JbsQv7FN_F_E^F2(!yAI zd9<)nM_GJKR2j`GER0rE)sn3+dW6ZOeJD8g{$4X?nQSb4M{t0*=xIpJ;{4K`R9Z;z*|Bn3 zSP>B>BWd&I(HL@P292vCyQ)~Vg!&{hT!NOW%Brj^FP>Rd8J*y_y1b&|dUrg!hF`K1 zt0xr3%Az6Tqavk|+4al97Nf;z`dgwc)5=tbuJ1VEC)bpAd2B&(Jqy`SVZ4=B6pV_L zl`#s^7RFUY%NN$C(zb|?h{lvf%OedMuySI4Hb*hM7UxDwqO*yvbT)0QLAj0<1Z}6H zU~II!qPU_mT3Q$lI)UE+=wFO(V`CMSNvp2B^72@DPOK=};4!zhK9LhET@Wp2h^u!! znsdeIs*)1jHdOtNk4Ea*+Csf5JSa|BNa4>5ioV|I)lFqmMYKGpJX#bjtt^g|R5Y}y zn2}*Zw0uEvVKg^3FH&4OmZmW)Rz5G3qXvu`|bts>#qDWc2n|-Vxrz9FFtt!ip z6qi($CvWaW#F5fcikQ-1R&z}F6w{#64i`>%Oc)>2Q`4%FXfW8-yKkAXAU8TI;?HzL zouNSmPWLiRWddjKXpukE7E$!|No%+;7yxG#&n}o)omHedZrlp#FD@pn!L+@>OCr-iBC4k96=jjaC<~c-juD|m22~UKts%AUr`WWhWUnerU#nTU{<^3E zLwzXsTU2jNOF^yHuRdczf#*hIIzRP^Y0Curqx0~JSbR+|GP)pIlDt7Vxr1>y;gd?E z)n)8qu=LdPfd-~JR**NZta4#|bWe=L4UE-HvKbH?R%yCBo29YY<*HBpZ_&?^kg!<6 z=vb*=H^nSX5=CcD^bIdU(|I|Oms01fUF&^<+@c(lw(O>wO&ZN;9^~3D8G2WJw?ty` zC1oR&ZMZ*$PfVfTvno_4YrtURm$xY!H7!W&uEysi4UJnbjuWfl25)iFQESdxv&xE- zF=0)N;k9hegzBR{eLPgmTbz_azXxZdBuxEcdaW~tP5gOmITaUO)%z8syw8XKo;?l~(s`{_jYFQH2rwxWuyJc?7PJKn_2$7%q*z?=G%m>3~ z1NWU{{)N6ITyIiiqb zebYAeNk*5CUk-~GYQwu=y!_ZS3f6!Pn?jjWI`Qf$*~IFxk>YxeN1@F!vj9xOrr8#A zk3>S_7jf&`l>C0a-PKB=sTYnKzEY`<|1tw>U@3Jpz6)kFW)poE9w319SR z_$ z14F-=yEfFOXRJ!!X;Ghs9*Q$uw-c&Z4wP1~{%V|SDxBb0O4j>wiaII9&za++TtJVq zwULZrK3o{#S`Pgl`nf*E?GIFmg^XF;H~3Pj9`u9xNN#!Yf@o>Hh!T66_1_Hi(`^Rq zq;HUiP6{-Pdbf&DHEl6kQ55g4+awbo$lPpzV=duG^Qe+#DHWPdiDcOf{5@7mu12?D+FV8eQL;NNX_~EIZ5b%z)*a!OQyNR?Mz#< zrzR&VLG`g1@0R6kF{w#NZnU&GUOUNJdd6>M7#gjl0VNg;4QiL6B2arn@hkViBCLVu z-eAr!Dq0ySqM6pOP(wW@k!x{xPQ7Ce&L>5&35Ai8NIjQ`|1Wp8HQ+M#7S-k7*y7&? zk+i#7R11!`vaG`SRmJ5|wNaY11{Ru!7SJT-#EQ5A7s^tyJAH||Z?Pm~U_vF!ss?38 z70?#9@Fq?*4T?9ENTz}QRZq2|WSP{UXjO7m3jgjEM^KaX>6crUMdFTx(CD=L^vtnMqQg!o&*N+D{`pxn0RGq0N zz40Gr6_-RS`Z*u^h(8IU9|-BI&J_hkwB1OsfnC78P3CstsM%wwRF~`Gw+2KK_Xhci z_&aQtaf@S@hTCUJfxXji!Z>nO5_)nlzna4$vWT7yAUBy+V@lD+%*`qFX=G1_Y zv`8DPcwFVe%&s_bn^Y3AQ|O<^Bk}XC>NG*~PFm!wJmYu2`W+_z^iWc*#Bbi66~CgG zXtqhUk+^cH?Ibhy#z}J`)^h!bRwE@{wMc(0y}+!clU+FFX3w%Qa-g?JO4JrfqRf(+ z1s>a~Tu3Ew6LsSlC^ioe#*I{{$Gd{zJDE8N3|0A8V=Bzmn8vc^&qWiFN6Lz;)UDCU z&5|%;dP~wRm2$7Onlq>?WQjZ_GcQ}WU^0|UOELc`$yjhti#m01PfH{8&$y+=90C50 zTyRp?J2O0^#Li6P)PGrGTek5kq>96D*|5o5q?WaQf$yB)I*j<{?pNa zLpfDeSE%Q)EE5s^)M{hZ zH}SF_PI^5wVsaZJtrfv_^p6Upe^VGE)AF$&C*#+;f$#|3p+;lH=CfrCIO;)1OuAjE~?vd|O6 z4LH4o3~ZTz;GU__5h4kVl=qr5oWSniZ!uoW$+<5qRFYeibz-YIbVQJ6wRlpEzLE0o zUpR~S&+%=|dZV^-E_QMIE;FXT-LfiBKj(kH0##(xgc@UgU2mK&;W0)z9KkpUFr0QKsyHhn3 zFKYn*j#b`98-MzwM7@}@QSuZw#CyxsvtW&3q11mNc_?$dEn9bPUgmC|v`Jz&CjP`* z_8P;$-xqyF@WzqGF0@ddD*X5MH*&$L23OQbEiROoq~72iinpLDcmbKr#~99r2luDpICTmyTyNg@W*#2ZvKn!9{H{nPrx^KDNX+n7n30$hVigGx-44q4qrF62W< zGx3}8fhF~E$DN7fWc(`pQ}Fjr<0DD=Ko?0|$1-ACt;QyYQdhk&iXu4<w9M^A;1&Q2g6yzf`rik#ZY?f9&3T;1s_L=`F>7mV9xDcQ@rW3V$v2Iu`#A%H>%6 z9#rZg{8HLM1^#zrekpz`=_ae*!E_di!drz;(Rn*jSO?%=M!1vkH&6%}_#;X83HTpT zE@aL7nEX;SUMB)i#&1q$%J5&H9!a|QaA!VNhQA&DH2mM-<@le|4kqCDr+p5`zrGK3 zj9*E;q~h;K{Hjgl?iT+z@kb=`c>a4Rg>V{vDTPc^@H+9&k@)8|iGP@UC51eX{~k+u zPQ*WuL}ubI#qNCkYL1_dzmj;f@w2JaIrv>D*Msq2BVN_E7VgBy-|&a^rmy2ajK2WC z{UGWD|No~ho9a--K99On)pfwW{D6C(JZ`27P37-@^iLVM+Q6xFO-2>(UAokTO*swG zC5A8@O=Jkopj&LqP}2vsq>H!Yw?%Z-H5_{#zjb3QDBM4uyZ-beoFkWF=S@IGju%FH1Vm} zxsLxGYuhP0J$El%F`Rcb^ ze!GX`FURjj`cyiUuG3-4IJT8aCpOga1=!e@zdLjMD#CT6EL!s4>(uXXrPZ*BD3>@? znJpsTB}k=7@u@K7zo5(fEW)Z|Gjtqth_65Y-Hc;4@!Ql^gr^)#{O!(&|J^4)@tdl{ zjVfN9?hgF@DdGEIU!`vdelhbM%h%ysB)i*Mp8}};va~;6~yzdPV=rD(~j_)DXZi7doyW!7eCw*x*iCfb1BLT{sY(7Wh8^gj9keTdZb;A8X& z`V@VJK1W|5)&9OjU!nh?uhBQ?Tl5|J9{qrRL_eWT=x6i``Y-ww{SWMa@uiv;%5^)EKrS+6nE9TA^J~Yt#nqirS*x(C(-m+5_#0 z+M^C=FVqorLaLp2L0!?_s2l2z_CY<6>J$5-UZ^)xW7~eHFY1T-qXB3j8iZ0&8cIhi z$lleeZJ}$?b?AC@16qkzp&QXn=w@^ax)t4qZbx^ZJJDU}Zgda27u|>MN2}2T=t1-l zdKf)|9z~C#HRy5l1bPxZh5n76M$e$N=vnj}dLF%iUPLdUm(e=39=(EIMX#aP(HrPZ zv;n<^-bU}BchP(3ee?nP5HTeAQ+kFEf2vLQ_m^x8C4BQcKD}os^rw%Udi-hXuJ{aV z{t}K;jXy`?ROByN+T(M|^Orvz@zwOVGwOo6qP7A@zv6RshYoJJP2P+K@UMgP!`HYIVcz9p?owH4MW4x zp=bmeiAJH(Xbc*Q#-Z_O0#Z}qNoX>fg4Fr{FmyPYh6>OT=twjj%|H<}6BVK&6h*Vp zY%~WIqodGVRD$NAQWQgFXg(@O6{r$bp#|t@RE-v*W6-haICMNZ0iB2zp_9F5k}COQk9jh3Qw(7EV5bUwNOU5GA1%h1JWIl2U0iY`N!qbtyr=qmIP z`WStJK1H9Q&(RlXBl;43h5m!SM&F=s(Rb*3^aJ`4{e(85pV2Sqzvx%=KlB^=9c@N` zpg+-H$V=h>s0rEzsdM#qXnWKYHABtO4oH2kx+U5X?SytlYU^Vc)Ec!xyP~#eH?%ua z=h!{ao~S+Qfc8QiQ76OT=twjj%|H<}6BVK&6h*VpY^1*BU5t)Gb5RMJ zhe}Zlm7)1aZ3R@IN>qgwprcVWT8NH8$D-rV@#q9}B3gt_LMNkB(5dJ&^e?m+EkUQF zGtimnEOa(niq1jjqVv%C=mK;hx(F>p7o+9q5_BoL3|)?{Kv$xx&h;bUV5O-HGl(ccXjIz34u4KU$3*Ko6pa(8K5v^eB1^twE2Y zC(x7VDfDmjGWsReu4r%64RuHRpdP3vQs0j6g?b~kX4nt)Mg35JGyn}m zgHS3;L+MCutE%-{CfXkzfDS|lp@Y#OXb8$e*(e9)qCAw3hN59;I64%KKqJv8G#ZUT zW6?M?9!)?K(Ihk(O+i!9Vd!u)4Hcjx(2;05nt>u{CMrZlD2isG*=P)+&FB_%E4mHcj_yErqPx)D=pJ-0x)0rtR-*^dgXkgjFnR<%iXKC2(BtR{ z^dx!;{Tn@vop~+|pnu-oXhofnz03CsjMAOj>6hSjlAu2*qGz-l}b5Jol3e80& zXdWs>F;s@;qjFS%Dp3_$fR0AhXdyZV9gB`b$D`w z&Om3Pv(VXSDLMz8i_SymqYKc5=pwWXU5u8aOVFk0GITk*0$qu&LMzbK=o)k_x(;2B zZa^#1Ds&^d3EhltLARpY(Cz3BbSJtC-Hq-+_oDmI{b)6M06mBvLJy-y(4*)vv<5wn zo*v@>djc0sLC8?-BGi*`f1 zqjqQyv?pqhI-tE!N7M;*MqN->v^VO8x}$wi57ZOwi+Z8ns1Mo?^+o+qe>4CMM1xQ& zN<-;rFv>ugXn%A7IuIR%4n~KdAt(!Fqa2ir@=!h+iiV-#=uk8QjYOl+Xfy_mMdQ$T zGyzRSlh9-|1x-bVp~KNMRDg~^N22Ly28y7Ws1OyQD4K<4qdBM;9fjti5;PB$q8KVe z^HDjfK$WNpEkH-3YP1j?gN{YVq2tjB=tQ&#orF$Cr=U~OY3N^QF + + + Spring.Data + + + +

+ Spring AOP exception translation aspect for use at Repository or DAO layer level. + Translates native persistence exceptions into Spring's DataAccessException hierarchy, + based on a given PersistenceExceptionTranslator. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The persistence exception translator to use. + Type of the repository attribute to check for. + + + + Initializes a new instance of the class. + + The object factory to obtain all IPersistenceExceptionTranslators from. + Type of the repository attribute to check for. + + + + Return the advice part of this aspect. + + + +

+ An advice may be an interceptor, a throws advice, before advice, + introduction etc. +

+
+ + The advice that should apply if the pointcut matches. + +
+ + + The that drives this advisor. + + + + + + Object post-processor that automatically applies persistence exception + translation to any bean that carries the + attribute, adding a corresponding + to the exposed proxy (either an existing AOP proxy or a newly generated + proxy that implements all of the target's interfaces). + + + Translates native resource exceptions to Spring's + hierarchy. Autodetects object that implement the + interface, which are subsequently asked to translate candidate exceptions. + + All of Spring's applicable resource factories implement the + IPersistenceExceptionTranslator interface out of the box. + As a consequence, all that is usually needed to enable automatic exception + translation is marking all affected objects (such as DAOs) with the + Repository annotation, along with defining this post-processor + in the application context. + + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + + + + + Just return the passed in object instance + + The new object instance. + The name of the object. + + The passed in object instance + + + In case of errors. + + + + + Add PersistenceExceptionTranslationAdvice to candidate object if it is a match. + Create AOP proxy if necessary or add advice to existing advice chain. + + The new object instance. + The name of the object. + + The object instance to use, wrapped with either the original or a wrapped one. + + + In case of errors. + + + + + Sets the type of the repository attribute. The default required attribute type is the + attirbute. This setter property exists so that developers + can provide their own (non-Spring-specific) attribute type to indicate that a class has a + repository role. + + The desitred type of the repository attribute. + + + + Callback that supplies the owning factory to an object instance. + + + + + Miscellaneous utility methods for DAO implementations. + Useful with any data access technology. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Implementation of PersistenceExceptionTranslator that supports chaining, + allowing the addition of PersistenceExceptionTranslator instances in order. + Returns non-null on the first (if any) match. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Interface implemented by Spring integrations with data access technologies + that throw exceptions. + + + This allows consistent usage of combined exception translation functionality, + without forcing a single translator to understand every single possible type + of exception. + + Rod Johnson + Mark Pollack (.NET) + + + + Translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + + + Do not translate exceptions that are not understand by this translator: + for example, if coming from another persistence framework, or resulting + from user code and unrelated to persistence. + + + Of particular importance is the correct translation to + for example on constraint violation. Implementations may use Spring ADO.NET Framework's + sophisticated exception translation to provide further information in the event of SQLException as a root cause. + + + The exception thrown. + the corresponding DataAccessException (or null if the + exception could not be translated, as in this case it may result from + user code rather than an actual persistence problem) + + + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Adds the translator to the translator list. + + The translator. + + + + Translate the given exception thrown by a persistence framework to a + corresponding exception from Spring's generic DataAccessException hierarchy, + if possible. + + The exception thrown. + + the corresponding DataAccessException (or null if the + exception could not be translated, as in this case it may result from + user code rather than an actual persistence problem) + + + + Do not translate exceptions that are not understand by this translator: + for example, if coming from another persistence framework, or resulting + from user code and unrelated to persistence. + + + Of particular importance is the correct translation to + for example on constraint violation. Implementations may use Spring ADO.NET Framework's + sophisticated exception translation to provide further information in the event of SQLException as a root cause. + + + + + + + + Gets all registered IPersistenceExceptionTranslator as an array. + + The IPersistenceExceptionTranslators. + + + + Generic base class for DAOs, defining template methods for DAO initialization. + + + Extended by Spring's specific DAO support classes, such as: + AdoDaoSupport, HibernateDaoSupport, etc. + + Mark Pollack (.NET) + + + + The shared instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Abstract subclasses must override this to check their configuration. + + +

Implementors should be marked as sealed, to make it clear that + concrete subclasses are not supposed to override this template method themselves. +

+
+
+ + + Concrete subclasses can override this for custom initialization behavior. + + + Gets called after population of this instance's object properties. + Exception thrown if InitDao fails will be rethrown as + a ObjectInitializationException. + + + + + Miscellaneous utility methods for DAO implementations. + Useful with any data access technology. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Return a translated exception if this is appropriate, or null if the exception could + not be translated. + + The raw exception we may wish to translate. + The PersistenceExceptionTranslator to use to perform the translation. + A translated exception if translation is possible, or or null if the exception could + not be translated. + + + + AOP MethodInterceptor that provides persistence exception translation + based on a given PersistenceExceptionTranslator. + + + Delegates to the given to translate + an Exception thrown into Spring's DataAccessException hierarchy + (if appropriate). + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + Needs to be configured with a PersistenceExceptionTranslator afterwards. + + + + + Initializes a new instance of the class for the + given IPersistenceExceptionTranslator + + The persistence exception translator to use. + + + + Initializes a new instance of the class, autodetecting + IPersistenceExceptionTranslators in the given object factory. + + The object factory to obtain all IPersistenceExceptionTranslators from. + + + + Ensures that the property PersistenceExceptionTranslator has been set. + Invoked by an + after it has injected all of an object's dependencies. + + + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + + + + + Detects the petsistence exception translators in the given object factory. + + The object factory for obtaining all IPersistenceExceptionTranslators. + A chained IPersistenceExceptionTranslator, combining all PersistenceExceptionTranslators found in the factory + + + + + + Return a translated exception if this is appropriate, otherwise rethrow the original exception. + + + + + + + Sets the persistence exception translator. The default is to autodetect all IPersistenceExceptionTranslators + in the containing object factory, using them in a chain. + + The persistence exception translator. + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Exception thrown on failure to aquire a lock during an update i.e a select for + update statement. + + +

+ This exception will be thrown either by O/R mapping tools or by custom DAO + implementations. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Exception thrown on a pessimistic locking violation. + + + Serves as a superclass for more specific exceptions, like + CannotAcquireLockException and DeadlockLoserDataAccessException + + + This exception will be thrown either by O/R mapping tools or by custom DAO + implementations. + + + Rod Johnson + Mark Pollack (.NET) + + + + Exception thrown on concurrency failure. This exception should be + sublassed to indicate the type of failure - optimistic locking, + failure to acquire lock, etc. + + +

+ This exception will be thrown either by O/R mapping tools or by custom DAO + implementations. +

+
+ Thomas Risberg + Griffin Caprio (.NET) +
+ + + Root of the hierarchy of data access exception that are considered transient - + where a previously failed operation might be able to succeed when the operation + is retried without any intervention by application-level functionality. + + Thomas Risberg + Mark Pollack (.NET) + + + + Root of the hierarchy of data access exceptions + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown on failure to complete a transaction in serialized mode due to + update conflicts. + + +

+ This exception will be thrown either by O/R mapping tools or by custom DAO + implementations. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when we couldn't cleanup after a data access operation, + but the actual operation went OK. + + +

+ For example, this exception or a subclass might be thrown if an ADO.NET + connection couldn't be closed after it had been used successfully. +

+

+ Note that data access code might perform resource cleanup in a + finally block and therefore log cleanup failure rather than rethrow it, + to keep the original data access exception, if any. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Root of the hierarchy of data access exception that are considered non-transient - + where a retry of the same operation would fail unless the cause of the Exception is + corrected. + + Thomas Risberg + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Data access exception thrown when a resource fails completely: + for example, if we can't connect to a database using ADO.NET. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when an attempt to insert or update data + results in violation of an integrity constraint. + + +

+ Note that this is not purely a relational concept; unique primary keys are + required by most database types. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown if certain expected data could not be retrieved, e.g. + when looking up specific data via a known identifier. + + +

+ This exception will be thrown either by O/R mapping tools or by custom DAO + implementations. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Generic exception thrown when the current process was + a deadlock loser, and its transaction rolled back. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Data access exception thrown when a result was not of the expected size, + for example when expecting a single row but getting 0 or more than 1 rows. + + Mark Pollack (.NET) + Juergen Hoeller + + + + Data access exception thrown when a result was not of the expected size, + for example when expecting a single row but getting 0 or more than 1 rows. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Exception thrown on incorrect usage of the API, such as failing to "compile" a query + object that needed compilation before execution. + + +

+ This represents a problem in our data access framework, not the underlying data access + infrastructure. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + The expected result size. + The actual result size (or -1 if unknown). + + + + Creates a new instance of the + class. + > + + A message about the exception. + + The expected result size. + The actual result size (or -1 if unknown). + + + + Initializes a new instance of the class. + + A message about the exception + The expected result size. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Override of + to allow for private serialization. + + + The + that holds the serialized object data about the exception. + + + The + that contains contextual information about the source or destination. + + + + Return the expected result size. + + + Return the actual result size (or -1 if unknown). + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The message. + The inner exception. + + + + Creates a new instance of the + class. + + The expected size. + + + + Creates a new instance of the + class. + + A message about the exception. + The expected size. + + + + Initializes a new instance of the class. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is . + The class name is or is zero (0). + + + + Data access exception thrown when something unintended appears to have + happened with an update, but the transaction hasn't already been rolled back. + + +

+ Thrown, for example, when we wanted to update 1 row in an RDBMS but actually + updated 3. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Root for exceptions thrown when we use a data access resource incorrectly. + + +

+ Thrown for example on specifying bad SQL when using a RDBMS. + Resource-specific subclasses will probably be supplied by data access packages. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + Return whether or not data was updated. + + True if data was updated (as opposed to being incorrectly + updated). If this property returns false, there's nothing to roll back. + + + + + Data access exception thrown when a resource fails completely and the failure is permanent. + + Thomas Risberg + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown on an optimistic locking violation for a mapped object. + Provides information about the persistent class and the identifier. + + Mark Pollack (.NET) + + + + Exception thrown on an optimistic locking violation. + + +

+ This exception will be thrown either by O/R mapping tools or by custom DAO + implementations. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A message about the exception.. + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + When overridden in a derived class, sets the + with information about the exception. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is a null reference ( in Visual Basic). + + + + Exception thrown if a mapped object could not be retrieved via its identifier. + Provides information about the persistent class and the identifier. + + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Initializes a new instance of the class. + + A message about the exception. + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception from the underlying data access API + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + When overridden in a derived class, sets the + with information about the exception. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is a null reference ( in Visual Basic). + + + + Exception thrown when the underlyingresource denied a permission to + access a specific element, such as a specific database table. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + RDta access exception thrown when a resource fails temporarily and the operation can be + retried. + + Thomas Risberg + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown on mismatch between CLS type and database type: + for example on an attempt to set an object of the wrong type + in an RDBMS column. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Normal superclass when we can't distinguish anything more specific + than "something went wrong with the underlying resource": for example, + a SQLException from Sql Server that we can't pinpoint more precisely. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception (from the underlying data access API, such as ADO.NET). + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Provides database metdata information. + + Mark Pollack (.NET) + + + + Provides minimal database metadata information to support the + functionality in Spring.NET ADO.NET Framework. + + + Mark Pollack (.NET) + + + + Gets a descriptive name of the product. + + Example: Microsoft SQL Server, provider V2.0.0.0 in framework .NET V2.0 + The name of the product. + + + + Gets the type of the connection. The fully qualified type name is given since some providers, + notably for SqlServerCe, do not use the same namespace for all data access types. + + Example: System.Data.SqlClient.SqlCommand, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the connection. + + + + Gets the type of the command. + + Example: System.Data.SqlClient.SqlCommand, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the command. + + + + Gets the type of the parameter. + + Example: System.Data.SqlClient.SqlParameter, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the parameter. + + + + Gets the type of the data adapter. + + Example: System.Data.SqlClient.SqlDataAdapter, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the data adapter. + + + + Gets the type of the command builder. + + Example: System.Data.SqlClient.SqlCommandBuilder, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the command builder. + + + + Gets the type of the exception. + + Example: System.Data.SqlClient.SqlException, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the exception. + + + + Gets the error code exception expression. + + Example Errors[0].Number.ToString() for Sql Server + The error code exception expression. + + + + Gets the command builder derive parameters method. + + If the value 'not supported' is specified then this method will throw an ArgumentException + Example: DeriveParameters + The command builder derive parameters method. + + + + Provide the prefix used to indentify named parameters in SQL text. + + @ for Sql Server + + + + Does the driver require the use of the parameter prefix when + specifying the name of the parameter in the Command's + Parameter collection. + + If true, then commamd.Parameters["@parameterName"] is + used, otherwise, command.Parameters["parameterName"]. + + + + + Gets a value indicating whether the Provider requires + the use of a named prefix in the SQL string. + + + The OLE DB/ODBC .NET Provider does not support named parameters for + passing parameters to an SQL Statement or a stored procedure called + by an IDbCommand when CommandType is set to Text. + + + true if use parameter prefix in SQL; otherwise, false. + + + + + For providers that allow you to choose between binding parameters + to a command by name (true) or by position (false). + + + + + Gets the type of the parameter db. + + Example: System.Data.SqlDbType, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the parameter db. + + + + Gets the parameter db type property. + + Example: SqlDbType for SqlServer + The parameter db type property. + + + + Gets the parameter is nullable property. + + Example: IsNullable for Sql Server + The parameter is nullable property. + + + + Gets or sets the error codes. + + The collection of error codes to map error code integer values to Spring's DAO exception hierarchy + The error codes. + + + + Initializes a new instance of the class. + + Name of the product. + Name of the assembly. + Type of the connection. + Type of the command. + Type of the parameter. + Type of the data adapter. + Type of the command builder. + The command builder derive parameters method. + Type of the parameter db. + The parameter db type property. + The parameter is nullable property. + The parameter name prefix. + Type of the exception. + if set to true [use parameter name prefix in parameter collection]. + if set to true [use parameter prefix in SQL]. + if set to true [bind by name]. + The error code exception expression. + + + + Gets a value indicating whether to use param name prefix in parameter collection. + + + true if should use param name prefix in parameter collection; otherwise, false. + + + + + Gets the name of the assembly. + + Example: System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The name of the assembly. + + + + Gets a descriptive name of the product. + + Example: Microsoft SQL Server, provider V2.0.0.0 in framework .NET V2.0 + The name of the product. + + + + Gets the type of the connection. The fully qualified type name is given since some providers, + notably for SqlServerCe, do not use the same namespace for all data access types. + + Example: System.Data.SqlClient.SqlCommand, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the connection. + + + + Gets the type of the command. + + Example: System.Data.SqlClient.SqlCommand, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the command. + + + + Gets the type of the parameter. + + Example: System.Data.SqlClient.SqlParameter, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the parameter. + + + + Gets the type of the data adapter. + + Example: System.Data.SqlClient.SqlDataAdapter, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the data adapter. + + + + Gets the type of the command builder. + + Example: System.Data.SqlClient.SqlCommandBuilder, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the command builder. + + + + Gets the command builder derive parameters method. + + If the value 'not supported' is specified then this method will throw an ArgumentException + Example: DeriveParameters + The command builder derive parameters method. + + + + Provide the prefix used to indentify named parameters in SQL text. + + @ for Sql Server + + + + Gets the type of the exception. + + Example: System.Data.SqlClient.SqlException, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the exception. + + + + Does the driver require the use of the parameter prefix when + specifying the name of the parameter in the Command's + Parameter collection. + + + If true, then commamd.Parameters["@parameterName"] is + used, otherwise, command.Parameters["parameterName"]. + + + + + Gets a value indicating whether the Provider requires + the use of a named prefix in the SQL string. + + + true if use parameter prefix in SQL; otherwise, false. + + + The OLE DB/ODBC .NET Provider does not support named parameters for + passing parameters to an SQL Statement or a stored procedure called + by an IDbCommand when CommandType is set to Text. + + + + + For providers that allow you to choose between binding parameters + to a command by name (true) or by position (false). + + + + + + Gets the type of the parameter db. + + Example: System.Data.SqlDbType, System.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + The type of the parameter db. + + + + Gets the parameter db type property. + + Example: SqlDbType for SqlServer + The parameter db type property. + + + + Gets the parameter is nullable property. + + Example: IsNullable for Sql Server + The parameter is nullable property. + + + + Gets or sets the error codes. + + The collection of error codes to map error code integer values to Spring's DAO exception hierarchy + The error codes. + + + + Gets the error code exception expression. + + Example Errors[0].Number.ToString() for Sql Server + The error code exception expression. + + + + A parameter class used by + + Mark Pollack (.NET) + + + + A parameter interface used by + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + Sets the SourceVersion to be Default and the ParameterDirection to be Input. + + + + + A more portable means to create a collection of ADO.NET + parameters. + + Mark Pollack (.NET) + + + + Determines whether this collection contains the specified parameter name. + + Name of the parameter. + + true if contains the specified parameter name; otherwise, false. + + + + + Add an instance of . + + + + + + Add a parameter specifying the all the individual properties of a + IDbDataParameter. + + + + + + + + + + + + The newly created parameter + + + + + + + + + + + + + + + The newly created parameter + + + + Adds a value to the parameter collection + + This method can not be used with stored procedures for + providers that require named parameters. However, it is of + great convenience for other cases. + The value of the parameter. + Index of added parameter. + + + + Adds a range of vlaues to the parameter collection. + + This method can not be used with stored procedures for + providers that require named parameters. However, it is of + great convenience for other cases. + + + + + Gets the underlying standard ADO.NET for the specified parameter name. + + + + + Gets the underlying standard ADO.NET for the specified index. + + + + + Returns the underlying standard ADO.NET parameters collection. + + + + + Initializes a new instance of the class. + + + + + Assists in creating a collection of parameters by keeping track of all + IDbParameters its creates. After creating a number of parameters ask for the collection + with the GetParameters methods. + + This builder is stateful, you must create a new one for each collection + of parameters you would like to create. + Mark Pollack (.NET) + + + + A builder to create a collection of ADO.NET parameters. + + The chaining of IDbParameter methods does the + building of the parameter details while the builder class + itself keeps track of the collection. + + Mark Pollack (.NET) + + + + Creates a IDbParameter object and adds it to an internal collection for + later retrieval via the GetParameters method. + + + + + + Gets all the parameters created and configured via the Create method. + + An instance of IDbParameters + + + + The shared log instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Implemenation of of DbProvider that uses metadata to create provider specific ADO.NET objects. + + + + + Factory interface to create provider specific ADO.NET objects. + + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + A new Command Builder + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new adapter objects for use with offline DataSets. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Creates the name of the parameter in the format appropriate to use inside IDbCommand.CommandText. + + In most cases this adds the parameter prefix to the name passed into this method. + The unformatted name of the parameter. + The parameter name formatted foran IDbCommand.CommandText. + + + + Creates the name ofthe parameter in the format appropriate for an IDataParameter, i.e. to be + part of a IDataParameterCollection. + + The unformatted name of the parameter. + The parameter name formatted for an IDataParameter + + + + Extracts the provider specific error code as a string. + + The data access exception. + The provider specific error code + + + + Determines whether the provided exception is in fact related + to database access. This can be provider dependent in .NET 1.1 since + there isn't a common base class for ADO.NET exceptions. + + The exception thrown when performing data access + operations. + + true if is a valid data access exception for the specified + exception; otherwise, false. + + + + + Return metadata information about the database provider + + + + + Connection string used to create connections. + + + + + Initializes a new instance of the class. + + The db metadata. + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + A new Command Builder + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new adapter objects for use with offline DataSets. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Creates the name of the parameter in the format appropriate to use inside IDbCommand.CommandText. + + The unformatted name of the parameter. + + The parameter name formatted foran IDbCommand.CommandText. + + In most cases this adds the parameter prefix to the name passed into this method. + + + + Creates the name ofthe parameter in the format appropriate for an IDataParameter, i.e. to be + part of a IDataParameterCollection. + + The unformatted name of the parameter. + + The parameter name formatted for an IDataParameter + + + + + Extracts the provider specific error code as a string. + + The data access exception. + The provider specific error code + + + + Determines whether the provided exception is in fact related + to database access. This can be provider dependent in .NET 1.1 since + there isn't a common base class for ADO.NET exceptions. + + The exception thrown when performing data access + operations. + + true if is a valid data access exception for the specified + exception; otherwise, false. + + + + + Determines whether is data access exception in .NET 1.1 for the specified exception. + + The candidate exception. + + true if is data access exception in .NET 1.1 for the specified exception; otherwise, false. + + + + + Return metadata information about the database provider + + + + + + Connection string used to create connections. + + + + + + + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Modify the application context's internal object factory after its + standard initialization. + + The object factory used by the application context. + +

+ All object definitions will have been loaded, but no objects will have + been instantiated yet. This allows for overriding or adding properties + even to eager-initializing objects. +

+
+ + In case of errors. + +
+ + + Gets or sets the provider resource which contains additional IDbProvider definitions. + + The provider resource. + + + + Create DbProviders based on configuration information in assembly resource + dbproviders.xml + + + + + TODO: Provide over-ride resource location. + TODO: Add error codes to provider. + + Mark Pollack (.NET) + + + + The shared log instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Gets the DbProvider given an identifying name. + + + Familiar names for the .NET 2.0 provider model are supported, i.e. + System.Data.SqlClient. Refer to the documentation for a complete + listing of supported DbProviders and their names. You may + also use the method GetDbProviderClasses or obtain the + underlying IApplicationContext to progammatically obtain information + about supported providers. + + Name of the provider invariant. + + + + + Gets the application context that contains the definitions of the + various providers. + + This method should rarely, if ever, be used in + application code. It is used by the framework itself + to map other data access products abstractions for a 'DbProvider/DataSource' + onto Spring's model. + The application context. + + + + A implementation that + creates instances of the class. + + Typically used as a convenience for retrieving shared + in a Spring XML configuration file as compared to + using explict factory method support. + + + + + Creates a new instance of the class. + + + + + Return an instance of and IDbProvider as configured by this factory + managed by this factory. + + + The same (singleton) instance of the IDbProvider managed by + this factory. + + + + If this method is being called in the context of an enclosing IoC container and + returns , the IoC container will consider this factory + object as not being fully initialized and throw a corresponding (and most + probably fatal) exception. + + + + + + Create the actual provider instance as specified by this factory's configuration properties. + + the fully configured provider + + + + Validates that the provider name is specified. + + + Invoked by an + after it has injected all of an object's dependencies. + + + In the event of not setting the ProviderName. + + + + + Validates the properties. + + + + + Gets or sets the name of the database provider. + + The name of the database provider. + + + + Gets or sets the connection string. + + The connection string. + + + + Return the type of + + + + + Returns true, as the the object managed by this factory is a singleton. + + + + + + IDbProvider implementation that delegates all calls to a given target + IDbProvider + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The target db provider. + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new instance of the providers CommandBuilder class. + + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + A new Command Builder + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new adapter objects for use with offline DataSets. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Creates the name of the parameter in the format appropriate to use inside IDbCommand.CommandText. + + In most cases this adds the parameter prefix to the name passed into this method. + The unformatted name of the parameter. + The parameter name formatted foran IDbCommand.CommandText. + + + + Creates the name ofthe parameter in the format appropriate for an IDataParameter, i.e. to be + part of a IDataParameterCollection. + + The unformatted name of the parameter. + The parameter name formatted for an IDataParameter + + + + Extracts the provider specific error code as a string. + + The data access exception. + The provider specific error code + + + + Determines whether the provided exception is in fact related + to database access. This can be provider dependent in .NET 1.1 since + there isn't a common base class for ADO.NET exceptions. + + The exception thrown when performing data access + operations. + + true if is a valid data access exception for the specified + exception; otherwise, false. + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Gets or sets the target IDbProvider that this IDbProvider should delegate to + + The target db provider. + + + + Return metadata information about the database provider + + + + + Connection string used to create connections. + + + + + Holds ADO.NET error codes for a particular provider. + + + Used by ErrorCodeExceptionTranslator. The embedded resource + "dbProviders.xml" in Spring.Data.Common contains default + ErrorCodes instances for various providers. + + Mark Pollack (.NET) + + + + The shared log instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + A wrapper implementation for IDbProvider such that multiple DbProvider instances can be + selected at runtime, say based on web request criteria. + + + The name of which DbProvider to use, as provided to the IDictionary property TargetDbProviders + is "dbProviderName". Once the target dbprovider name is known, set the name via a call to + LogicalThreadContext.SetData(MultiDelegatingDbProvider.CURRENT_DBPROVIDER_SLOTNAME, "database1ProviderName"). The value + "database1ProviderName" must match a key in the provided TargetDbProviders dictionary. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The target db providers. + + + + Ensures that the there are values in the TargetDbProviders dictionary and that the + key is of the type string and value is of the type IDbProvider. + + If the above conditions are not met. + + + + Returns a new command object for executing SQL statments/Stored Procedures + against the database. + + An new + + + + Returns a new connection object to communicate with the database. + + A new + + + + Returns a new parameter object for binding values to parameter + placeholders in SQL statements or Stored Procedure variables. + + A new + + + + Returns a new adapter objects for use with offline DataSets. + + A new + + + + Returns a new instance of the providers CommandBuilder class. + + A new Command Builder + In .NET 1.1 there was no common base class or interface + for command builders, hence the return signature is object to + be portable (but more loosely typed) across .NET 1.1/2.0 + + + + Creates the name of the parameter in the format appropriate to use inside IDbCommand.CommandText. + + The unformatted name of the parameter. + + The parameter name formatted foran IDbCommand.CommandText. + + In most cases this adds the parameter prefix to the name passed into this method. + + + + Creates the name ofthe parameter in the format appropriate for an IDataParameter, i.e. to be + part of a IDataParameterCollection. + + The unformatted name of the parameter. + + The parameter name formatted for an IDataParameter + + + + + Extracts the provider specific error code as a string. + + The data access exception. + The provider specific error code + + + + Determines whether the provided exception is in fact related + to database access. This can be provider dependent in .NET 1.1 since + there isn't a common base class for ADO.NET exceptions. + + The exception thrown when performing data access + operations. + + true if is a valid data access exception for the specified + exception; otherwise, false. + + + + + Determines whether is data access exception in .NET 1.1 for the specified exception. + + The candidate exception. + + true if is data access exception in .NET 1.1 for the specified exception; otherwise, false. + + + + + Gets the target provider based on the thread local name "dbProviderName" + + The corresonding IDbProvider. + + + + Sets the default IDbProvider. This will be returned if no DbProvider is found in thread local storage. + + The default db provider. + + + + Sets the target db providers. + + The target db providers. + + + + Return metadata information about the database provider + + + + + + Connection string used to create connections. + + + + + + Convenience method to sets the name of the DbProvider that will be used for the + the current thread's procesing. + + The name of the DbProvider to use for the current threads processing. + + + + An adapter for a target IDbProvider, applying the specified user credentials + to the connection string for every GetConnection call. + + + + + Sets the user credentials for current thread. The given username and password + strings will be added to the connection string for all subsequent GetConnection + requests. This will override any statically specified user credentials, that is, + set by the properties Username nad Password. + + The username part of the connection string. + The password part of the connection string. + + + + Removes the user credentials from current thread. Use statically specified + credentials afterwards. + + + + + Returns a new connection object to communicate with the database. + Determine if there are currently thread-bound credentials, using them if + available, falling back to the statically specified username and password + (i.e. values of the properties 'Username' and 'Password') otherwise. + The username and password will be concatenated on the connection string + using string in the Separator property + + A new + + + + Sets the username string that will be appended to the connection string. + + The username. + + + + Sets the password string that will be appended to the connection string. + + The password. + + + + Sets the separator used to separate elements of the connection string. Default is ';'. + + + The separator used to separate elements in the connection string. + + + + Implementation of the custom configuration parser for database definitions. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Parse the specified element and register any resulting + IObjectDefinitions with the IObjectDefinitionRegistry that is + embedded in the supplied ParserContext. + + The element to be parsed into one or more IObjectDefinitions + The object encapsulating the current state of the parsing + process. + + The primary IObjectDefinition (can be null as explained above) + + + Implementations should return the primary IObjectDefinition + that results from the parse phase if they wish to used nested + inside (for example) a <property> tag. + Implementations may return null if they will not + be used in a nested scenario. + + + + + + Parses database provider definitions. + + Validator XML element. + The name of the object definition. + The parser context. + A database provider object definition. + + + + Gets the name of the object type for the specified element. + + The element. + The name of the object type. + + + + Base class for AdoTemplate and other ADO.NET DAO helper classes defining + common properties like DbProvider. + + Mark Pollack (.NET) + Juergen Hoeller + + + + Prepare the command setting the transaction timeout. + + + + + + Dispose the command, if any + + + + + Dispose the command, if any + + + + + Extract the command text from the given , if any. + + + + + Obtain a connection/transaction pair + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Creates the data reader wrapper for use in AdoTemplate callback methods. + + The reader to wrap. + The data reader used in AdoTemplate callbacks + + + + Creates the a db parameters collection, adding to the collection a parameter created from + the method parameters. + + The name of the parameter + The type of the parameter. + The size of the parameter, for use in defining lengths of string values. Use + 0 if not applicable. + The parameter value. + A collection of db parameters with a single parameter in the collection based + on the method parameters + + + + Creates a new instance of + + a new instance of + + + + Derives the parameters of a stored procedure, not including the return parameter. + + Name of the procedure. + The stored procedure parameters. + + + + Derives the parameters of a stored procedure including the return parameter + + Name of the procedure. + if set to true to include return parameter. + The stored procedure parameters + + + + An instance of a DbProvider implementation. + + + + + Gets or sets a value indicating whether to lazily initialize the + IAdoExceptionTranslator for this accessor, on first encounter of a + exception from the data provider. Default is "true"; can be switched to + "false" for initialization on startup. + + true if to lazy initialize the IAdoExceptionTranslator; + otherwise, false. + + + + Gets or sets the exception translator. If no custom translator is provided, a default + is used. + + The exception translator. + + + + Gets or set the System.Type to use to create an instance of IDataReaderWrapper + for the purpose of having defaults values to use in case of DBNull values read + from IDataReader. + + The type of the data reader wrapper. + + + + Gets or sets the command timeout for IDbCommands that this AdoTemplate executes. + + Default is 0, indicating to use the database provider's default. + Any timeout specified here will be overridden by the remaining + transaction timeout when executing within a transaction that has a + timeout specified at the transaction level. + + The command timeout. + + + + Convenient super class for ADO.NET data access objects. + + + Requires a IDBProvider to be set, providing a + AdoTemplate based on it to subclasses. + This base class is mainly intended for AdoTemplate usage. + + + + + Create a AdoTemplate for a given DbProvider + Only invoked if populating the DAO with a DbProvider reference. + + + Can be overriden in subclasses to provide AdoTemplate instances + with a different configuration, or a cusotm AdoTemplate subclass. + + The DbProvider to create a AdoTemplate for + + + + Convenience method to create a parameters builder. + + Virtual for sublcasses to override with custom + implementation. + A new DbParameterBuilder + + + + The DbProvider instance used by this DAO + + + + + Set the AdoTemplate for this DAO explicity, as + an alternative to specifying a IDbProvider + + + + + ADO.NET based implementation of the + interface. + + Mark Pollack (.NET) + + + + Abstract base class that allows for easy implementation of concrete platform transaction managers. + + +

Provides the following workflow handling: +

    +
  • Determines if there is an existing transaction
  • +
  • Applies the appropriate propagation behavior
  • +
  • Suspends and resumes transactions if necessary
  • +
  • Checks the rollback-only flag on commit
  • +
  • Applies the appropriate modification on rollback (actual rollback or setting rollback-only)
  • +
  • Triggers registered synchronization callbacks (if transaction synchronization is active)
  • +
+

+

+ Transaction synchronization is a generic mechanism for registering + callbacks that get invoked at transaction completion time. The same mechanism + can also be used for custom synchronization efforts. +

+

+ The state of this class is serializable. It's up to subclasses if + they wish to make their state to be serializable. + They should implement if they need + to restore any transient state. +

+
+ Juergen Hoeller + Mark Pollack (.NET) + Griffin Caprio (.NET) +
+ + + This is the central interface in Spring.NET's transaction support. + + +

+ Applications can use this directly, but it is not primarily meant as an API. + Typically, applications will work with either + or the AOP transaction + interceptor. +

+

+ For implementers, + is a good starting point. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Return a currently active transaction or create a new one. + + +

+ Note that parameters like isolation level or timeout will only be applied + to new transactions, and thus be ignored when participating in active ones. + Furthermore, they aren't supported by every transaction manager: + a proper implementation should throw an exception when custom values + that it doesn't support are specified. +

+
+ + instance (can be null for + defaults), describing propagation behavior, isolation level, timeout etc. + + + In case of lookup, creation, or system errors. + + + A representing the new or current transaction. + +
+ + + Commit the given transaction, with regard to its status. + + +

+ If the transaction has been marked rollback-only programmatically, + perform a rollback. +

+

+ If the transaction wasn't a new one, omit the commit to take part + in the surrounding transaction properly. +

+
+ + The instance returned by the + () method. + + + In case of commit or system errors + +
+ + + Roll back the given transaction, with regard to its status. + + +

+ If the transaction wasn't a new one, just set it rollback-only + to take part in the surrounding transaction properly. +

+
+ + The instance returned by the + () method. + + + In case of system errors. + +
+ + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing transaction + (that is, a transaction which has already started). + + + The result will be evaluated according to the specified propagation + behavior for the new transaction. An existing transaction might get + suspended (in case of PROPAGATION_REQUIRES_NEW), or the new transaction + might participate in the existing one (in case of PROPAGATION_REQUIRED). + Default implementation returns false, assuming that detection of or + participating in existing transactions is generally not supported. + Subclasses are of course encouraged to provide such support. + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + + Transaction synchronization will already have been suspended. + + Default implementation throws a TransactionSuspensionNotSupportedException, + assuming that transaction suspension is generally not supported. + + + + Transaction object returned by + . + + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + Transaction synchronization will be resumed afterwards. + + Default implementation throws a TransactionSuspensionNotSupportedException, + assuming that transaction suspension is generally not supported. + + + + Transaction object returned by + . + + + The object that holds suspended resources as returned by + . + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + Default implementation throws an IllegalTransactionStateException, + assuming that participating in existing transactions is generally not + supported. Subclasses are of course encouraged to provide such support. + + The status representation of the transaction. + + In the case of system errors. + + + + + Return whether to use a savepoint for a nested transaction. Default is true, + which causes delegation to + for holding a savepoint. + + + +

+ Subclasses can override this to return false, causing a further + invocation of + + despite an already existing transaction. +

+
+
+ + + Register the given list of transaction synchronizations with the existing transaction. + + + Invoked when the control of the Spring transaction manager and thus all Spring + transaction synchronizations end, without the transaction being completed yet. This + is for example the case when participating in an existing System.Transactions or + EnterpriseServices transaction invoked via their APIs. + + The default implementation simply invokes the AfterCompletion methods + immediately, passing in TransactionSynchronizationStatus.Unknown. + This is the best we can do if there's no chance to determine the actual + outcome of the outer transaction. + + + The transaction transaction object returned by DoGetTransaction. + The lList of TransactionSynchronization objects. + In case of errors + + + + + + + Cleanup resources after transaction completion. + + + Transaction object returned by + . + + + + Called after + and + + execution on any outcome. + + + Should not throw any exceptions but just issue warnings on errors. + + + Default implementation does nothing. + + + + + + Return a currently active transaction or create a new one. + + +

+ This implementation handles propagation behavior. +

+

+ Delegates to + , + , + and + . +

+

+ Note that parameters like isolation level or timeout will only be applied + to new transactions, and thus be ignored when participating in active ones. + Furthermore, they aren't supported by every transaction manager: + a proper implementation should throw an exception when custom values + that it doesn't support are specified. +

+
+ + instance (can be null for + defaults), describing propagation behavior, isolation level, timeout etc. + + + In case of lookup, creation, or system errors. + + + representing the new or current transaction. + +
+ + + This implementation of commit handles participating in existing transactions + and programmatic rollback requests. + + + + + ITransactionStatus object returned by the + () method. + + + In case of commit or system errors. + + + + + Roll back the given transaction, with regard to its status. + + +

+ This implementation handles participating in existing transactions. +

+

+ Delegates to + , + and + . +

+

+ If the transaction wasn't a new one, just set it rollback-only + to take part in the surrounding transaction properly. +

+
+ + ITransactionStatusObject returned by the + () method. + + + In case of system errors. + +
+ + + Determines the timeout to use for the given definition. Will fall back to this manager's default + timeout if the transaction definition doesn't specify a non-default value. + + The transaction definition. + the actual timeout to use. + + + + Suspend the given transaction. Suspends transaction synchronization first, + then delegates to the doSuspend template method. + + the current transaction object + an object that holds suspended resources + + + + Resume the given transaction. Delegates to the doResume template method + first, then resuming transaction synchronization. + + the current transaction object + the object that holds suspended resources, as returned by suspend + + + + Invoke doRollback, handling rollback exceptions properly. + + object representing the transaction + the thrown application exception or error + + in case of a rollback error + + + + + Trigger beforeCommit callback. + + object representing the transaction + + + + Trigger beforeCompletion callback. + + object representing the transaction + + + + Trigger afterCompletion callback, handling exceptions properly. + + object representing the transaction + + Completion status according to + + + + + Clean up after completion, clearing synchronization if necessary, + and invoking doCleanupAfterCompletion. + + object representing the transaction + + + + Sets and gets when this transaction manager should activate the thread-bound + transaction synchronization support. Default is "always". + + +

+ Note that transaction synchronization isn't supported for + multiple concurrent transactions by different transaction managers. + Only one transaction manager is allowed to activate it at any time. +

+ +
+
+ + + Sets and gets whether nested transactions are allowed. Default is false. + + +

+ Typically initialized with an appropriate default by the + concrete transaction manager subclass. +

+
+
+ + + Sets and gets a flag that determines whether or not the + + method must be invoked if a call to the + + method fails. Default is false. + + + Typically not necessary and thus to be avoided as it can override the + commit exception with a subsequent rollback exception. + + + + + Gets or sets a value indicating whether to fail early in case of the transaction being + globally marked as rollback-only. + + + Default is "false", only causing an UnexpectedRollbackException at the + outermost transaction boundary. Switch this flag on to cause an + UnexpectedRollbackException as early as the global rollback-only marker + has been first detected, even from within an inner transaction boundary. + + + true if fail early on global rollback; otherwise, false. + + + + + Gets or sets the default timeout that this transaction manager should apply if there + is no timeout specified at the transaction level, in seconds. + + Returns DefaultTransactionDefinition.TIMEOUT_DEFAULT to indicate the + underlying transaction infrastructure's default timeout. + The default timeout. + + + + Extension of the + interface, indicating a native resource transaction manager, operating on a single + target resource. Such transaction managers differ from DTC based transaction managers in + that they do not use transaction enlistment for an open number of resources but + rather focus on leveraging the native power and simplicity of a single target resource. + + + This interface is mainly used for abstract introspection of a transaction manager, + giving clients a hint on what kind of transaction manager they have been given + and on what concrete resource the transaction manager is operating on. + + Juergen Hoeller + Mark Pollack + + + + Gets the resource factory that this transaction manager operates on, + e.g. a IDbProvider or a Hibernate ISessionFactory. + + The resource factory. + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing, + i.e. already begun, transaction. + + + Transaction object returned by + . + + True if there is an existing transaction. + + In the case of system errors. + + + + + Begin a new transaction with the given transaction definition. + + + Transaction object returned by + . + + + instance, describing + propagation behavior, isolation level, timeout etc. + + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + Transaction object returned by + . + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + If suspending is not supported by the transaction manager implementation. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + Transaction object returned by + . + The object that holds suspended resources as returned by + . + + Transaction synchronization will be resumed afterwards. + + + If suspending is not supported by the transaction manager implementation. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+ + In the case of system errors. + +
+ + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Invoked by an + after it has injected all of an object's dependencies. + + + If DbProvider is null. + + + + + Gets the resource factory that this transaction manager operates on, + For the AdoPlatformTransactionManager this is the DbProvider + + The DbProvider. + + + + DbProvider transaction (state) object, representing a ConnectionHolder. + Used as a transaction object by AdoPlatformTransactionManager + + Derives from AdoTransactionObjectSupport to inherit the capability + to manage Savepoints. + + + + + + Convenient base class for ADO.NET transaction aware objects. + + + Can contain a ConnectionHolder object. + + Mark Pollack (.NET) + + + + Interface that specifies means to programmatically manage + transaction savepoints in a generic fashion. + + +

+ Note that savepoints can only work within an active transaction. + Just use this programmatic savepoint handling for advanced needs; + else, a subtransaction with a value + of is preferable. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Create a new savepoint. + + + The name of the savepoint to create. + + + You can roll back to a specific savepoint + via , + and explicitly release a savepoint that you don't need anymore via + . +

+ Note that most transaction managers will automatically release + savepoints at transaction completion. +

+
+ + If the savepoint could not be created, + either because the backend does not support it or because the + transaction is not in an appropriate state. + + + A savepoint object, to be passed into + + or . + +
+ + + Roll back to the given savepoint. + + + The savepoint will be automatically released afterwards. + + The savepoint to roll back to. + + If the rollback failed. + + + + + Explicitly release the given savepoint. + + +

+ Note that most transaction managers will automatically release + savepoints at transaction completion. +

+

+ Implementations should fail as silently as possible if + proper resource cleanup will still happen at transaction completion. +

+
+ The savepoint to release. + + If the release failed. + +
+ + + Interface to be implemented by transaction objects that are able to + return an internal rollback-only marker, typically from a another + transaction that has participated and marked it as rollback-only. + + +

+ Autodetected by , + to always return a current rollbackOnly flag even if not resulting from the current + . +

+
+ Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Return whether the transaction is internally marked as rollback-only. + + True of the transaction is marked as rollback-only. + + + + The shared log instance for this class (and derived classes). + + + + + Create a new savepoint. + + + The name of the savepoint to create. + + + You can roll back to a specific savepoint + via , + and explicitly release a savepoint that you don't need anymore via + . +

+ Note that most transaction managers will automatically release + savepoints at transaction completion. +

+
+ + If the savepoint could not be created, + either because the backend does not support it or because the + transaction is not in an appropriate state. + + + A savepoint object, to be passed into + + or . + +
+ + + Roll back to the given savepoint. + + + The savepoint will be automatically released afterwards. + + The savepoint to roll back to. + + If the rollback failed. + + + + + Explicitly release the given savepoint. + + +

+ Note that most transaction managers will automatically release + savepoints at transaction completion. +

+

+ Implementations should fail as silently as possible if + proper resource cleanup will still happen at transaction completion. +

+
+ The savepoint to release. + + If the release failed. + +
+ + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Sets the rollback only. + + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + This is the central class in the Spring.Data namespace. + It simplifies the use of ADO.NET and helps to avoid commons errors. + + Mark Pollack (.NET) + + + + Interface that defines ADO.NET related database operations. + + Mark Pollack (.NET) + + + + Execute the query with the specified command text returning a scalar result + + No parameters are used. As with + IDbCommand.ExecuteScalar, it returns the first column of the first row in the resultset + returned by the query. Extra columns or row are ignored. + The command type + The command text to execute. + The first column of the first row in the result set. + + + + Execute the query with the specified command text and parameter returning a scalar result + + The command type + The command text to execute. + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameters returning a scalar result + + The command type + The command text to execute. + The parameter collection to map. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameters set via the + command setter, returning a scalar result + + The command type + The command text to execute. + The command setter. + The first column of the first row in the result set + + + + Execute the query with a command created via IDbCommandCreator and + parameters + + Output parameters can be retrieved via the returned + dictionary. + + More commonly used as a lower level support method within the framework, + for example StoredProcedure/AdoScalar. + + + The callback to create a IDbCommand. + A dictionary containing output parameters, if any + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The number of rows affected. + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The number of rows affected. + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The parameter collection to map. + The number of rows affected. + + + + Executes a non query with parameters set via the + command setter, returning the number of rows affected. + + The command type. + The command text to execute. + The command setter. + The number of rows affected. + + + + Executes a non query with a command created via IDbCommandCreator and + parameters. + + Output parameters can be retrieved via the returned + dictionary. + + More commonly used as a lower level support method within the framework, + for example StoredProcedure/AdoScalar. + + + The callback to create a IDbCommand. + The number of rows affected. + + + + Execute a query given IDbCommand's type and text, reading a + single result set on a per-row basis with a . + + The type of command. + The text of the query. + callback that will extract results + one row at a time. + + + + + Execute a query given IDbCommand's type and text and provided parameter + information, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + + + + Execute a query given IDbCommand's type and text and provided IDbParameters, + reading a single result set on a per-row basis with a . + + Type of the command. + The text of the query. + callback that will extract results + one row at a time. + The parameter collection to map. + + + + Execute a query given IDbCommand's type and text by + passing the created IDbCommand to a ICommandSetter implementation + that knows how to bind values to the IDbCommand, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + The command setter. + + + + Execute a ADO.NET operation on a command object using a delegate callback. + + This allows for implementing arbitrary data access operations + on a single command within Spring's managed ADO.NET environment. + The delegate called with a command object. + A result object returned by the action or null + + + + Execute a ADO.NET operation on a command object using an interface based callback. + + the callback to execute + object returned from callback + + + + Executes ADO.NET operations on a command object, created by the provided IDbCommandCreator, + using the interface based callback IDbCommandCallback. + + The command creator. + The callback to execute based on IDbCommand + A result object returned by the action or null + + + + Execute ADO.NET operations on a IDbDataAdapter object using an interface based callback. + + This allows for implementing abritrary data access operations + on a single DataAdapter within Spring's managed ADO.NET environment. + + The data adapter callback. + A result object returned by the callback or null + + + + Execute a query given IDbCommand's type and text, processing a + single result set with an instance of IResultSetExtractor + + The type of command + The text of the query. + Object that will extract all rows of a result set + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given the CommandType and text with parameters set + via the command setter, processing a + single result set with an instance of IResultSetExtractor + + The command type. + The command text to execute. + The result set extractor. + The command setter. + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given the CommandType and text specifying a single parameter and process a single result set with an + instance of IResultSetExtractor. + + Convention is to use 0 For the size if it does not make sense for the given data type + + The command type. + The command text to execute. + The result set extractor. + The name of the parameters + The enumeration of the parameter type + The size of the parmeter - e.g. string length. Use 0 if not relevant for specific data type + The value of the parameters + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given the CommandType and text specifying a collection of parameters and process a single result set with an + instance of IResultSetExtractor. + + The command type. + The command text to execute. + The result set extractor. + The query parameters + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given static SQL/Stored Procedure name + and process a single result set with an instance of ResultSetExtractorDelegate + + The type of command. + The command text. + Delegate that will process all rows of a result set + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given the CommandType and text with parameters set + via the command setter, processing a + single result set with an instance of IResultSetExtractor + + The command type. + The command text to execute. + Delegate that will process all rows of a result set + The command setter. + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given the CommandType and text specifying a single parameter and process a single result set with an + instance of IResultSetExtractor. + + Convention is to use 0 For the size if it does not make sense for the given data type + + The command type. + The command text to execute. + Delegate that will process all rows of a result set + The name of the parameters + The enumeration of the parameter type + The size of the parmeter - e.g. string length. Use 0 if not relevant for specific data type + The value of the parameters + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given the CommandType and text specifying a collection of parameters and process a single result set with an + instance of IResultSetExtractor. + + The command type. + The command text to execute. + Delegate that will process all rows of a result set + The query parameters + An arbitrary result object, as returned by the IResultSetExtractor + + If there is any problem executing the query. + + + + + Execute a query given static SQL, mapping each row to a .NET object + via a RowMapper + + The type of command + SQL query to execute + delegate/lambda that will map one object per row + The result list containing mapped objects + + + + Execute a query given static SQL, mapping each row to a .NET object + via a RowMapper + + The type of command + SQL query to execute + object that will map one object per row + the result list containing mapped objects + + + + Execute a query with the specified command text, mapping a single result + row to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters set via the + command setter, mapping a single result row to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The command setter. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The parameter collection to use in the query. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameter, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text, mapping a single result + row to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters set via the + command setter, mapping a single result row to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The command setter. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The parameter collection to use in the query. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameter, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + + + + + Fill a based on a select command that requires no parameters. + + The to populate + The type of command + SQL query to execute + The number of rows successfully added to or refreshed in the + + + + Fill a based on a select command that requires no parameters. + + The to populate + The type of command + SQL query to execute + The number of rows successfully added to or refreshed in the + + + + Fill a based on a select command that requires no parameters + that returns one or more result sets that are added as + s to the + + The to populate + The type of command + SQL query to execute + The mapping of table names for each + created + + + + + Note that output parameters are marked input/output after derivation.... + (TODO - double check....) + + + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The database provider. + + + + Initializes a new instance of the class. + + The database provider. + if set to false + lazily initialize the ErrorCodeExceptionTranslator. + + + + Execute a ADO.NET operation on a command object using a delegate callback. + + The delegate called with a command object. + + A result object returned by the action or null + + This allows for implementing arbitrary data access operations + on a single command within Spring's managed ADO.NET environment. + + + + Callback to execute a IDbCommand. + + the callback to execute + object returned from callback + + + + Executes ADO.NET operations on a command object, created by the provided IDbCommandCreator, + using the interface based callback IDbCommandCallback. + + The command creator. + The callback to execute based on IDbCommand + A result object returned by the action or null + + + + Execute ADO.NET operations on a IDbDataAdapter object using an interface based callback. + + This allows for implementing abritrary data access operations + on a single DataAdapter within Spring's managed ADO.NET environment. + + The data adapter callback. + A result object returned by the callback or null + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The number of rows affected. + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The number of rows affected. + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The parameter collection to map. + The number of rows affected. + + + + Executes a non query with parameters set via the + command setter, returning the number of rows affected. + + The command type. + The command text to execute. + The command setter. + The number of rows affected. + + + + Executes a non query with a command created via IDbCommandCreator and + parameters. + + Output parameters can be retrieved via the returned + dictionary. + + More commonly used as a lower level support method within the framework, + for example StoredProcedure/AdoScalar. + + + The callback to create a IDbCommand. + The number of rows affected. + + + + Execute the query with the specified command text. + + No parameters are used. As with + IDbCommand.ExecuteScalar, it returns the first column of the first row in the resultset + returned by the query. Extra columns or row are ignored. + The command type + The command text to execute. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameter returning a scalar result + + The command type + The command text to execute. + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameters returning a scalar result + + The command type + The command text to execute. + The parameter collection to map. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameters set via the + command setter, returning a scalar result + + The command type + The command text to execute. + The command setter. + The first column of the first row in the result set + + + + Execute the query with a command created via IDbCommandCreator and + parameters + + Output parameters can be retrieved via the returned + dictionary. + + More commonly used as a lower level support method within the framework, + for example for StoredProcedure/AdoScalar. + + The callback to create a IDbCommand. + A dictionary containing output parameters, if any + + + + Execute a query given IDbCommand's type and text, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + + + + Execute a query given IDbCommand's type and text by + passing the created IDbCommand to a ICommandSetter implementation + that knows how to bind values to the IDbCommand, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + The command setter. + + + + Execute a query given IDbCommand's type and text and provided parameter + information, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + + + + Execute a query given static SQL/Stored Procedure name + and process a single result set with an instance of IResultSetExtractor + + The type of command. + The SQL/Stored Procedure to execute + Object that will extract all rows of a result set + An arbitrary result object, as returned by the IResultSetExtractor + + + + Execute a query given static SQL/Stored Procedure name + and process a single result set with an instance of IResultSetExtractor + + The type of command. + The SQL/Stored Procedure to execute + Delegate that will extract all rows of a result set + An arbitrary result object, as returned by the IResultSetExtractor + + + + Execute a query with the specified command text, mapping a single result + row to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters set via the + command setter, mapping a single result row to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The command setter. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The parameter collection to use in the query. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameter, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + object that will map one object per row + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text, mapping a single result + row to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters set via the + command setter, mapping a single result row to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The command setter. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameters, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The parameter collection to use in the query. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Execute a query with the specified command text and parameter, mapping a single result row + to an object via a RowMapper. + + The command type. + The command text to execute. + delegate that will map one object per row + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The single mapped object. + + If the query does not return exactly one row. + + + If there is any problem executing the query. + + + + + Fill a based on a select command that requires no parameters. + + The to populate + The type of command + SQL query to execute + The number of rows successfully added to or refreshed in the + + + + Creates the data reader wrapper for use in AdoTemplate callback methods. + + The reader to wrap. + The data reader used in AdoTemplate callbacks + + + + An instance of a DbProvider implementation. + + + + + Gets or sets a value indicating whether to lazily initialize the + IAdoExceptionTranslator for this accessor, on first encounter of a + exception from the data provider. Default is "true"; can be switched to + "false" for initialization on startup. + + true if to lazy initialize the IAdoExceptionTranslator; + otherwise, false. + + + + Gets or sets the exception translator. If no custom translator is provided, a default + is used. + + The exception translator. + + + + Gets or set the System.Type to use to create an instance of IDataReaderWrapper + for the purpose of having defaults values to use in case of DBNull values read + from IDataReader. + + The type of the data reader wrapper. + + + + Generic callback interface for code that operates on a + IDbDataAdapter. + + +

Allows you to execute any number of operations + on a IDbDataAdapter, for example to Fill a DataSet + or other more advanced operations such as the transfering + data between two different DataSets. +

+

Note that the passed in IDbDataAdapter + has been created by the framework and its SelectCommand + will be populated with values for CommandType and Text properties + along with Connection/Transaction properties based on the + calling transaction context. +

+ Execute(IDataAdapterCallback dataAdapterCallback) + method. +
+ Mark Pollack (.NET) +
+ + + Called by AdoTemplate.Execute with an preconfigured + ADO.NET IDbDataAdapter instance with its SelectCommand + property populated with CommandType and Text values + along with Connection/Transaction properties based on the + calling transaction context. + + An active IDbDataAdapter instance + The result object + + + + Generic callback interface for code that operates on a + IDbCommand. + + +

Allows you to execute any number of operations + on a single IDbCommand, for example a single ExecuteScalar + call or repeated execute calls with varying parameters. +

+

Used internally by AdoTemplate, but also useful for + application code. Note that the passed in IDbCommand + has been created by the framework.

+
+ Mark Pollack +
+ + + Called by AdoTemplate.Execute with an active ADO.NET IDbCommand. + The calling code does not need to care about closing the + command or the connection, or + about handling transactions: this will all be handled by + Spring's AdoTemplate + + An active IDbCommand instance + The result object + + + + Interface to be implemented by objects that can provide SQL strings + + Typically implemented by IDbCommandCreator and + ICommandCallbacks that want to expose the CommandText they + use to create their ADO.NET commands, to allow for better + contextual information in case of exceptions + Mark Pollack(.NET) + Juergen Hoeller + + + + Adapter implementation of the ResultSetExtractor interface that delegates + to a RowMapper which is supposed to create an object for each row. + Each object is added to the results List of this ResultSetExtractor. + + + Useful for the typical case of one object per row in the database table. + The number of entries in the results list will match the number of rows. +

+ Note that a RowMapper object is typically stateless and thus reusable; + just the RowMapperResultSetExtractor adapter is stateful. +

+

+ As an alternative consider subclassing MappingAdoQuery from the + Spring.Data.Objects namespace: Instead of working with separate + AdoTemplate and IRowMapper objects you can have executable + query objects (containing row-mapping logic) there. +

+
+ Mark Pollack (.NET) +
+ + + Callback interface to process all result sets and rows in + an AdoTemplate query method. + + Implementations of this interface perform the work + of extracting results but don't need worry about managing + ADO.NET resources, such as closing the reader or transaction management. +

+ This interface is mainly used within the ADO.NET + framework. An IResultSetExtractor is usually a simpler choice + for result set (DataReader) processing, in particular a + RowMapperResultSetExtractor in combination with a IRowMapper. +

+ Note: in contracts to a IRowCallbackHandler, a ResultSetExtractor + is usually stateless and thus reusable, as long as it doesn't access + stateful resources or keep result state within the object. + +
+ +
+ + + Implementations must implement this method to process all + result set and rows in the IDataReader. + + The IDataReader to extract data from. + Implementations should not close this: it will be closed + by the AdoTemplate. + An arbitrary result object or null if none. The + extractor will typically be stateful in the latter case. + + + + Initializes a new instance of the class. + + + + + Transaction Manager that uses EnterpriseServices to access the + MS-DTC. It requires the support of 'Services without Components' + functionality which is available on Win 2003 and Win XP SP2. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + This is indented only for unit testing purposes and should not be + called by production application code. + The tx adapter. + + + + Gets or sets a value indicating whether tracking is enabled. + + true if tracking is enabled; otherwise, false. + + + + Gets or sets a text string that corresponds to the application ID under which tracker information is reported. + The default value is 'Spring.NET' + + The name of the tracking app. + + + + Gets or sets a text string that corresponds to the context name under which tracker information is reported. + + The name of the tracking component. + + + + TransactionManager that uses TransactionScope provided by System.Transactions. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + This is indented only for unit testing purposes and should not be + called by production application code. + The tx adapter. + + + + No-op initialization + + + + + The transaction resource object that encapsulates the state and functionality + contained in TransactionScope and Transaction.Current via the ITransactionScopeAdapter + property. + + + + + Initializes a new instance of the class. + Will create an instance of . + + + + + Gets or sets the transaction scope adapter. + + The transaction scope adapter. + + + + Return whether the transaction is internally marked as rollback-only. + + + True of the transaction is marked as rollback-only. + + + + Convenient super class for ADO.NET data access objects using generics. + + + Requires a IDBProvider to be set, providing a + AdoTemplate based on it to subclasses. + This base class is mainly intended for AdoTemplate usage. + + + + + Create a AdoTemplate for a given DbProvider + Only invoked if populating the DAO with a DbProvider reference. + + + Can be overriden in subclasses to provide AdoTemplate instances + with a different configuration, or a cusotm AdoTemplate subclass. + + The DbProvider to create a AdoTemplate for + + + + Convenience method to create a parameters builder. + + Virtual for sublcasses to override with custom + implementation. + A new DbParameterBuilder + + + + The DbProvider instance used by this DAO + + + + + Set the AdoTemplate for this DAO explicity, as + an alternative to specifying a IDbProvider + + + + + This is the central class in the Spring.Data.Generic namespace. + It simplifies the use of ADO.NET and helps to avoid commons errors. + + Mark Pollack (.NET) + + + + Interface that defines ADO.NET related database operations using generics + + Mark Pollack (.NET) + + + + Execute a ADO.NET operation on a command object using a generic interface based callback. + + The type of object returned from the callback. + the callback to execute based on DbCommand + An object returned from callback + + + + Execute a ADO.NET operation on a command object using a generic interface based callback. + + The type of object returned from the callback. + The callback to execute based on IDbCommand + An object returned from callback + + + + Execute a ADO.NET operation on a command object using a generic delegate callback. + + The type of object returned from the callback. + This allows for implementing arbitrary data access operations + on a single command within Spring's managed ADO.NET environment. + The delegate called with a DbCommand object. + A result object returned by the action or null + + + + Execute a ADO.NET operation on a command object using a generic delegate callback. + + The type of object returned from the callback. + This allows for implementing arbitrary data access operations + on a single command within Spring's managed ADO.NET environment. + The delegate called with a IDbCommand object. + A result object returned by the action or null + + + + Executes ADO.NET operations on a command object, created by the provided IDbCommandCreator, + using the interface based callback IDbCommandCallback. + + The type of object returned from the callback. + The command creator. + The callback to execute based on IDbCommand + A result object returned by the action or null + + + + Execute ADO.NET operations on a IDbDataAdapter object using an interface based callback. + + This allows for implementing abritrary data access operations + on a single DataAdapter within Spring's managed ADO.NET environment. + + The type of object returned from the callback. + The data adapter callback. + A result object returned by the callback or null + + + + Execute ADO.NET operations on a IDbDataAdapter object using an delgate based callback. + + This allows for implementing abritrary data access operations + on a single DataAdapter within Spring's managed ADO.NET environment. + + The type of object returned from the callback. + The delegate called with a IDbDataAdapter object. + A result object returned by the callback or null + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The provider. + + + + Initializes a new instance of the class. + + The database provider. + if set to false + lazily initialize the ErrorCodeExceptionTranslator. + + + + Initializes a new instance of the class. + + Useful if you have a subclass of Spring.Data.Core.AdoTemplate. + The classic ADO template. + + + + Execute a ADO.NET operation on a command object using a interface based callback. + + the callback to execute + object returned from callback + + + + Execute a ADO.NET operation on a command object using a delegate callback. + + This allows for implementing arbitrary data access operations + on a single command within Spring's managed ADO.NET environment. + The delegate called with a command object. + A result object returned by the action or null + + + + Execute a ADO.NET operation on a command object using a interface based callback. + + the callback to execute + object returned from callback + + + + Execute a ADO.NET operation on a command object using a delegate callback. + + This allows for implementing arbitrary data access operations + on a single command within Spring's managed ADO.NET environment. + The delegate called with a command object. + A result object returned by the action or null + + + + Executes ADO.NET operations on a command object, created by the provided IDbCommandCreator, + using the interface based callback IDbCommandCallback. + + The type of object returned from the callback. + The command creator. + The callback to execute based on IDbCommand + + A result object returned by the action or null + + + + + Execute ADO.NET operations on a IDbDataAdapter object using an interface based callback. + + The type of object returned from the callback. + The data adapter callback. + + A result object returned by the callback or null + + This allows for implementing abritrary data access operations + on a single DataAdapter within Spring's managed ADO.NET environment. + + + + + Execute ADO.NET operations on a IDbDataAdapter object using an delgate based callback. + + This allows for implementing abritrary data access operations + on a single DataAdapter within Spring's managed ADO.NET environment. + + The type of object returned from the callback. + The delegate called with a IDbDataAdapter object. + A result object returned by the callback or null + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The number of rows affected. + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The number of rows affected. + + + + Executes a non query returning the number of rows affected. + + The command type. + The command text to execute. + The parameter collection to map. + The number of rows affected. + + + + Executes a non query with parameters set via the + command setter, returning the number of rows affected. + + The command type. + The command text to execute. + The command setter. + The number of rows affected. + + + + Executes a non query with a command created via IDbCommandCreator and + parameters. + + Output parameters can be retrieved via the returned + dictionary. + + More commonly used as a lower level support method within the framework, + for example StoredProcedure/AdoScalar. + + + The callback to create a IDbCommand. + The number of rows affected. + + + + Execute the query with the specified command text. + + No parameters are used. As with + IDbCommand.ExecuteScalar, it returns the first column of the first row in the result set + returned by the query. Extra columns or row are ignored. + The command type + The command text to execute. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameter returning a scalar result + + The command type + The command text to execute. + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameters returning a scalar result + + The command type + The command text to execute. + The parameter collection to map. + The first column of the first row in the result set + + + + Execute the query with the specified command text and parameters set via the + command setter, returning a scalar result + + The command type + The command text to execute. + The command setter. + The first column of the first row in the result set + + + + Execute the query with a command created via IDbCommandCreator and + parameters + + Output parameters can be retrieved via the returned + dictionary. + + More commonly used as a lower level support method within the framework, + for example for StoredProcedure/AdoScalar. + + The callback to create a IDbCommand. + A dictionary containing output parameters, if any + + + + Execute a query given IDbCommand's type and text by + passing the created IDbCommand to a ICommandSetter implementation + that knows how to bind values to the IDbCommand, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + The command setter. + + + + Execute a query given IDbCommand's type and text, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + + + + Execute a query given IDbCommand's type and text and provided parameter + information, reading a + single result set on a per-row basis with a . + + The type of command + The text of the query. + callback that will extract results + one row at a time. + + The name of the parameter to map. + One of the database parameter type enumerations. + The length of the parameter. 0 if not applicable to parameter type. + The parameter value. + + + + Execute a query given IDbCommand's type and text and provided IDbParameters, + reading a single result set on a per-row basis with a . + + Type of the command. + The text of the query. + callback that will extract results + one row at a time. + The parameter collection to map. + + + + Checks if DbProvider is not null and creates ExceptionTranslator if not LazyInit. + + + + + Creates the data reader wrapper for use in AdoTemplate callback methods. + + The reader to wrap. + The data reader used in AdoTemplate callbacks + + + + Derives the parameters of a stored procedure including the return parameter + + Name of the procedure. + if set to true to include return parameter. + The stored procedure parameters + + + + An instance of a DbProvider implementation. + + + + + Gets or sets a value indicating whether to lazily initialize the + IAdoExceptionTranslator for this accessor, on first encounter of a + exception from the data provider. Default is "true"; can be switched to + "false" for initialization on startup. + + true if to lazy initialize the IAdoExceptionTranslator; + otherwise, false. + + + + Gets or sets the exception translator. If no custom translator is provided, a default + is used. + + The exception translator. + + + + Gets or set the System.Type to use to create an instance of IDataReaderWrapper + for the purpose of having defaults values to use in case of DBNull values read + from IDataReader. + + The type of the data reader wrapper. + + + + Gets the 'Classic' AdoTemplate in Spring.Data + + + Useful to access methods that return non-generic collections. + + The 'Classic; AdoTemplate in Spring.Data. + + + + Gets or sets the command timeout for IDbCommands that this AdoTemplate executes. It also + sets the value of the contained 'ClassicAdoTemplate'. + + The command timeout. + Default is 0, indicating to use the database provider's default. + Any timeout specified here will be overridden by the remaining + transaction timeout when executing within a transaction that has a + timeout specified at the transaction level. + + + + + Generic callback interface for code that operates on a + IDbCommand. + + The return type from executing the + callback + +

Allows you to execute any number of operations + on a single IDbCommand, for example a single ExecuteScalar + call or repeated execute calls with varying parameters. +

+

Used internally by AdoTemplate, but also useful for + application code. Note that the passed in IDbCommand + has been created by the framework and will have its + Connection property set and the Transaction property + set based on the transaction context.

+

As an alternative to using this interface you can use + the delegate version which is particularly nice when using + anonymous delegates for writing more terse code and having + easy access to the variables in the calling class.

+

See for a version that has the + base class DbCommand as the callback argument.

+
+ Mark Pollack +
+ + + Called by AdoTemplate.Execute with an active ADO.NET IDbCommand. + The calling code does not need to care about closing the + command or the connection, or + about handling transactions: this will all be handled by + Spring's AdoTemplate + + An active IDbCommand instance + The result object + + + + Generic callback delegate for code that operates on a DbCommand. + + +

Allows you to execute any number of operations + on a single DbCommand, for example a single ExecuteScalar + call or repeated execute calls with varying parameters. +

+

Used internally by AdoTemplate, but also useful for + application code. Note that the passed in DbCommand + has been created by the framework and will have its + Connection property set and the Transaction property + set based on the transaction context.

+
+ The return type from executing the + callback + The ADO.NET DbCommand object + The object returned from processing with the + provided DbCommand + Mark Pollack +
+ + + Called by AdoTemplate.Execute with an preconfigured + ADO.NET IDbDataAdapter instance with its SelectCommand + property populated with CommandType and Text values + along with Connection/Transaction properties based on the + calling transaction context. + + An active IDbDataAdapter instance + The result object + + + + Generic callback interface for code that operates on a + DbCommand. + + The return type from executing the + callback + +

Allows you to execute any number of operations + on a single DbCommand, for example a single ExecuteScalar + call or repeated execute calls with varying parameters. +

+

Used internally by AdoTemplate, but also useful for + application code. Note that the passed in DbCommand + has been created by the framework and will have its + Connection property set and the Transaction property + set based on the transaction context.

+
+ Mark Pollack +
+ + + Called by AdoTemplate.Execute with an active ADO.NET IDbCommand. + The calling code does not need to care about closing the + command or the connection, or + about handling transactions: this will all be handled by + Spring's AdoTemplate + + An active IDbCommand instance + The result object + + + + Generic callback interface for code that operates on a + IDbDataAdapter. + + +

Allows you to execute any number of operations + on a IDbDataAdapter, for example to Fill a DataSet + or other more advanced operations such as the transfering + data between two different DataSets. +

+

Note that the passed in IDbDataAdapter + has been created by the framework and its SelectCommand + will be populated with values for CommandType and Text properties + along with Connection/Transaction properties based on the + calling transaction context. +

+ Execute(IDataAdapterCallback dataAdapterCallback) + method. +
+ Mark Pollack (.NET) +
+ + + Called by AdoTemplate.Execute with an preconfigured + ADO.NET IDbDataAdapter instance with its SelectCommand + property populated with CommandType and Text values + along with Connection/Transaction properties based on the + calling transaction context. + + An active IDbDataAdapter instance + The result object + + + + Generic callback delegate for code that operates on a IDbCommand. + + +

Allows you to execute any number of operations + on a single IDbCommand, for example a single ExecuteScalar + call or repeated execute calls with varying parameters. +

+

Used internally by AdoTemplate, but also useful for + application code. Note that the passed in DbCommand + has been created by the framework and will have its + Connection property set and the Transaction property + set based on the transaction context.

+
+ The return type from executing the + callback + The ADO.NET DbCommand object + The object returned from processing with the + provided DbCommand + Mark Pollack +
+ + + Callback interface to process all results sets and rows in + an AdoTemplate query method. + + Implementations of this interface perform the work + of extracting results but don't need worry about managing + ADO.NET resources, such as closing the reader. +

+ This interface is mainly used within the ADO.NET + framework. An IResultSetExtractor is usually a simpler choice + for result set (DataReader) processing, in particular a + RowMapperResultSetExtractor in combination with a IRowMapper. +

+ Note: in contracts to a IRowCallbackHandler, a ResultSetExtractor + is usually stateless and thus reusable, as long as it doesn't access + stateful resources or keep result state within the object. + +
+ +
+ + + Implementations must implement this method to process all + result set and rows in the IDataReader. + + The IDataReader to extract data from. + Implementations should not close this: it will be closed + by the AdoTemplate. + An arbitrary result object or null if none. The + extractor will typically be stateful in the latter case. + + + + Generic callback to process each row of data in a result set to an object. + + Implementations of this interface perform the actual work + of mapping rows, but don't need worry about managing + ADO.NET resources, such as closing the reader. +

+ Typically used for AdoTemplate's query methods (with RowMapperResultSetExtractor + adapters). RowMapper objects are typically stateless and thus + reusable; they are ideal choices for implementing row-mapping logic in a single + place. +

+

Alternatively, consider subclassing MappingSqlQuery from the Spring.Data.Object + namespace: Instead of working with separate AdoTemplate and RowMapper objects, + you can have executable query objects (containing row-mapping logic) there. +

+
+ Mark Pollack (.NET) +
+ + + Implementations must implement this method to map each row of data in the + result set (DataReader). This method should not call Next() on the + DataReader; it should only extract the values of the current row. + + The IDataReader to map (pre-initialized to the current row) + The number of the current row.. + The specific typed result object for the current row. + + + + Provides a name to a ResultSetProcessor for use with AdoOperation subclasses + such as StoredProcedure. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class with a + IRowCallback instance + + The name of the associated row callback for use with output + result set mappers. + A row callback instance. + + + + Initializes a new instance of the class with a + IRowMapper instance + + The name of the associated row mapper. + A IRowMapper instance. + + + + Initializes a new instance of the class with a + IResultSetExtractor instance + + The name of the associated result set extractor. + A IResultSetExtractor instance. + + + + Callback delegate to process all result sets and row in an + AdoTemplate query method. + + The type returned from the result set mapping. + The IDataReader to extract data from. + Implementations should not close this: it will be closed + by the AdoTemplate. + An arbitrary result object or null if none. + + + + Callback delegate to process each row of data in a result set to an object. + + The type of the object returned from the mapping operation. + The IDataReader to map + the number of the current row. + An abrirary object, typically derived from data + in the result set. + + + + Adapter implementation of the ResultSetExtractor interface that delegates + to a RowMapper which is supposed to create an object for each row. + Each object is added to the results List of this ResultSetExtractor. + + + Useful for the typical case of one object per row in the database table. + The number of entries in the results list will match the number of rows. +

+ Note that a RowMapper object is typically stateless and thus reusable; + just the RowMapperResultSetExtractor adapter is stateful. +

+

+ As an alternative consider subclassing MappingAdoQuery from the + Spring.Data.Objects namespace: Instead of working with separate + AdoTemplate and IRowMapper objects you can have executable + query objects (containing row-mapping logic) there. +

+
+ Mark Pollack (.NET) +
+ + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The row mapper. + The rows expected. + + + + A "AdoOperation" is a thread-safe, reusable object representing + an ADO Query, "NonQuery" (Create, Update, Delete), stored procedure + or DataSet manipualtions. + + + Subclasses should set Command Text and add parameters before invoking + Compile(). The order in which parameters are added is generally + significant when using providers or functionality that do not use + named parameters. + + + Mark Pollack (.NET) + + + + Abstract base class providing common functionality for generic and non + generic implementations of "AdoOperation" subclasses. + + Mark Pollack (.NET) + + + + Has this operation been compiled? Compilation means at + least checking that a IDbProvider and sql have been provided, + but subclasses may also implement their own custom validation. + + + + + Object enabling us to create IDbCommands + efficiently, based on this class's declared parameters. + + + + + Ensures compilation if used in an IApplicationContext + + + + + Compiles this operation. Ignores subsequent attempts to compile. + + + + + Check whether this operation has been compiled already; + lazily compile it if not already compiled. + + Automatically called by ValidateParameters and ValidateNamedParameters + + + + Validates the named parameters passed to an AdoTemplate ExecuteXXX method based on + declared parameters. + + + Subclasses should invoke this method very every ExecuteXXX method. + + The parameter dictionary supplied. May by null. + + + + Subclasses must implement to perform their own compilation. + Invoked after this class's compilation is complete. + Subclasses can assume that SQL has been supplied and that + a IDbProvider has been supplied. + + + + + Hook method that subclasses may override to react to compilation. + This implementation does nothing. + + + + + Gets or sets the type of the command. + + The type of the command. + + + + Gets or sets the db provider. + + The db provider. + + + + Gets or sets the SQL to execute + + The SQL. + + + + Gets or sets the declared parameters. + + The declared parameters. + + + + Gets a value indicating whether this is compiled. + + Compilation means that the operation is fully configured, + and ready to use. The exact meaning of compilation will vary between subclasses. + true if compiled; otherwise, false. + + + + Sets the command timeout for IDbCommands that this AdoTemplate executes. + + Default is 0, indicating to use the database provider's default. + Any timeout specified here will be overridden by the remaining + transaction timeout when executing within a transaction that has a + timeout specified at the transaction level. + + The command timeout. + + + + Initializes a new instance of the class. + + A DbProvider, SQL and any parameters must be supplied + before invoking the compile method and using this object. + + + + + Initializes a new instance of the class. + + A DbProvider, SQL and any parameters must be supplied + before invoking the compile method and using this object. + + Database provider to use. + + + + Initializes a new instance of the class. + + A DbProvider, SQL and any parameters must be supplied + before invoking the compile method and using this object. + + Database provider to use. + SQL query or stored procedure name. + + + + Compiles this operation. Ignores subsequent attempts to compile. + + + + + Gets or sets the ADO template. + + The ADO template. + + + + Gets or sets the db provider. + + The db provider. + + + + Sets the command timeout for IDbCommands that this AdoTemplate executes. + + Default is 0, indicating to use the database provider's default. + Any timeout specified here will be overridden by the remaining + transaction timeout when executing within a transaction that has a + timeout specified at the transaction level. + + The command timeout. + + + + Place together the mapping logic to a plain .NET object + for one result set within the same class. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The database provider. + The SQL to execute + + + + Convenient method to execute query without parameters or calling context. + + The type parameter for the returned collection + List of mapped objects + + + + Convenient method to execute query with parameters but without calling context. + + The type parameter for the returned collection + The parameters for the query. + + + + + Convenient method to execute query with parameters and access to output parameter values. + + The type parameter for the returned collection + The parameters for the query. + The returned output parameters. + + + + + Central execution method. All named parameter execution goes through this method. + + the type parameter for the returned collection + The in params. + The out params. + The calling context. + + + + + Reusable query in which concrete subclasses must implement the + MapRow method to map each row of a single result set into an + object. + + + Simplifies MappingSqlQueryWithContext API by dropping parameters and + context. Most subclasses won't care about parameters. If you don't use + contextual information, subclass this instead of MappingSqlQueryWithContext. + + Mark Pollack (.NET) + + + + Reusable query in which concrete subclasses must implement the + abstract MapRow method to map each row of a single result set into an + object. + + The MapRow method is also passed the input parameters and + a dictionary to provide the method with calling context information + (if necessary). If you do not need these additional parameters, use + the subclass MappingAdoQuery. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + + + + A superclass for object based abstractions of RDBMS stored procedures. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Execute the stored procedure using 'ExecuteScalar' + + Value of input parameters. + Dictionary with any named output parameters and the value of the + scalar under the key "scalar". + + + + Encapsulate Command.ExecuteNonQuery operations within a reusable class. + + Mark Pollack (.NET) + The default CommandType is CommandType.Text + + + + A "AdoOperation" is a thread-safe, reusable object representing + an ADO Query, "NonQuery" (Create, Update, Delete), stored procedure + or DataSet manipualtions. + + + Subclasses should set Command Text and add parameters before invoking + Compile(). The order in which parameters are added is generally + significant when using providers or functionality that do not use + named parameters. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + A DbProvider, SQL and any parameters must be supplied + before invoking the compile method and using this object. + + + + + Initializes a new instance of the class. + + A DbProvider, SQL and any parameters must be supplied + before invoking the compile method and using this object. + + Database provider to use. + + + + Initializes a new instance of the class. + + A DbProvider, SQL and any parameters must be supplied + before invoking the compile method and using this object. + + Database provider to use. + SQL query or stored procedure name. + + + + Compiles this operation. Ignores subsequent attempts to compile. + + + + + Gets or sets the ADO template. + + The ADO template. + + + + Gets or sets the db provider. + + The db provider. + + + + Sets the command timeout for IDbCommands that this AdoTemplate executes. + + Default is 0, indicating to use the database provider's default. + Any timeout specified here will be overridden by the remaining + transaction timeout when executing within a transaction that has a + timeout specified at the transaction level. + + The command timeout. + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + + + + Place together the mapping logic to a plain .NET object + for one result set within the same class. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Encapsulate Command ExecuteScalar operations within a reusable class. + + The default CommandType is CommandType.Text + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + + + + Reusable query in which concrete subclasses must implement the + MapRow method to map each row of a single result set into an + object. + + + Simplifies MappingAdoQueryWithContext API by dropping parameters and + context. Most subclasses won't care about parameters. If you don't use + contextual information, subclass this instead of MappingSqlQueryWithContext. + + Mark Pollack (.NET) + + + + Reusable query in which concrete subclasses must implement the + MapRow method to map each row of a single result set into an + object. + + The MapRow method is also passed the input parameters and + a dictionary to provide the method with calling context information + (if necessary). If you do not need these additional parameters, use + the subclass MappingAdoQuery. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Callback to process each row of data in a result set to an object. + + Implementations of this interface perform the actual work + of mapping rows, but don't need worry about managing + ADO.NET resources, such as closing the reader. +

+ Typically used for AdoTemplate's query methods (with RowMapperResultSetExtractor + adapters). RowMapper objects are typically stateless and thus + reusable; they are ideal choices for implementing row-mapping logic in a single + place. +

+

Alternatively, consider subclassing MappingSqlQuery from the Spring.Data.Object + namespace: Instead of working with separate AdoTemplate and RowMapper objects, + you can have executable query objects (containing row-mapping logic) there. +

+
+ Mark Pollack (.NET) +
+ + + Implementations must implement this method to map each row of data in the + result set (DataReader). This method should not call Next() on the + DataReader; it should only extract the values of the current row. + + The IDataReader to map (pre-initialized for the current row) + The number of the current row. + The result object for the current row. + + + + Initializes a new instance of the class. + + + + + A superclass for object based abstractions of RDBMS stored procedures. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The db provider. + Name of the stored procedure. + + + + Execute the stored procedure using 'ExecuteScalar' + + Value of input parameters. + Dictionary with any named output parameters and the value of the + scalar under the key "scalar". + + + + Summary description for AdoUtils. + + + + + Order value for TransactionSynchronization objects that clean up + ADO.NET Connections. + + + + + Property dispose of the command. Useful in finally or catch blocks. + + command to dispose + + + + Connection holder, wrapping a ADO.NET connection and transaction. + + AdoTransactionManager binds instances of this class to the + thread for a given DbProvider. + Jurgen Hoeller + Mark Pollack (.NET) + + + + Convenient base class for resource holders. + + +

+ Features rollback-only support transactions. Can expire after a certain number of + seconds or milliseconds, to determine transactional timeouts. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Clear the transaction state of this resource holder. + + + + + Increase the reference count by one because the holder has been requested. + + + + + Decrease the reference count by one because the holder has been released. + + + + + Mark the resource as synchronized with a transaction. + + + + + Get or set whether the resource is synchronized with a transaction. + + true if synchronized; otherwise, false. + + + + Return the expiration deadline of this object. + + + + + Return whether this object has an associated timeout. + + + + + Return the time to live for this object in seconds. + + +

+ Rounds up eagerly, e.g. '9.00001' to '10'. +

+
+ + If no deadline has been set. + +
+ + + Return the time to live for this object in milliseconds. + + + If no deadline has been set. + + + + + Sets the timeout for this object in milliseconds. + + Number of milliseconds until expiration. + + + + Sets the timeout for this object in seconds. + + Number of seconds until expiration. + + + + Return wheterh there are still open references to this holder + + + + + Create a new ConnectionHolder + + The connection to hold + The transaction to hold + + + + Callback for resource cleanup at end of transaction. + + + + + Adapter for the + interface. + + + Contains empty implementations of all interface methods, for easy overriding of + single methods. + + Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) + + + + Interface for transaction synchronization callbacks. + + + Supported by . + + Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) + + + + Suspend this synchronization. + + +

+ Supposed to unbind resources from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Supposed to rebind resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + Can e.g. flush transactional O/R Mapping sessions to the database + + + + This callback does not mean that the transaction will actually be + commited. A rollback decision can still occur after this method + has been called. This callback is rather meant to perform work + that's only relevant if a commit still has a chance + to happen, such as flushing SQL statements to the database. + + + Note that exceptions will get propagated to the commit caller and cause a + rollback of the transaction. + + (note: do not throw TransactionException subclasses here!) + + + + If the transaction is defined as a read-only transaction. + + + + + Invoked after transaction commit. + + Can e.g. commit further operations that are supposed to follow on + a successful commit of the main transaction. + Throws exception in case of errors; will be propagated to the caller. + Note: To not throw TransactionExeption sbuclasses here! + + + + + + Invoked before transaction commit/rollback (after + , + even if + + threw an exception). + + +

+ Can e.g. perform resource cleanup. +

+

+ Note that exceptions will get propagated to the commit caller + and cause a rollback of the transaction. +

+
+
+ + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Suspend this synchronization. + + +

+ Supposed to unbind resources from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Supposed to unbind resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit (before + ) + + + If the transaction is defined as a read-only transaction. + + +

+ Can flush transactional sessions to the database. +

+

+ Note that exceptions will get propagated to the commit caller and + cause a rollback of the transaction. +

+
+
+ + + Invoked after transaction commit. + + Can e.g. commit further operations that are supposed to follow on + a successful commit of the main transaction. + Throws exception in case of errors; will be propagated to the caller. + Note: To not throw TransactionExeption sbuclasses here! + + + + + Invoked before transaction commit/rollback (after + , + even if + + threw an exception). + + +

+ Can e.g. perform resource cleanup. +

+

+ Note that exceptions will get propagated to the commit caller + and cause a rollback of the transaction. +

+
+
+ + + Invoked after transaction commit/rollback. + + + Status according to + + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + Compares the current instance with another object of the same type. + + + + A 32-bit signed integer that indicates the relative order of the objects being compared. The return value has these meanings: Value Meaning Less than zero This instance is less than obj. Zero This instance is equal to obj. Greater than zero This instance is greater than obj. + + + An object to compare with this instance. + obj is not the same type as this instance. 2 + + + + Create a new instance. + + + + + + + Compares the current instance with another object of the same type. + + An object to compare with this instance. + + The value of the order property. + + + + + Suspend this synchronization. + + +

+ Supposed to unbind resources from + + if managing any. +

+
+
+ + + Resume this synchronization. + + +

+ Supposed to unbind resources from + + if managing any. +

+
+
+ + + Invoked before transaction commit/rollback (after + , + even if + + threw an exception). + + +

+ Can e.g. perform resource cleanup. +

+

+ Note that exceptions will get propagated to the commit caller + and cause a rollback of the transaction. +

+
+
+ + + Invoked after transaction commit/rollback. + + Status according to + + Can e.g. perform resource cleanup, in this case after transaction completion. +

+ Note that exceptions will get propagated to the commit or rollback + caller, although they will not influence the outcome of the transaction. +

+
+
+ + + A simple holder for the current Connection/Transaction objects + to use within a given AdoTemplate Execute operation. Used internally. + + + + + Initializes a new instance of the class. + + The connection. + The transaction. + + + + Gets the connection. + + The connection. + + + + Gets the transaction. + + The transaction. + + + + Summary description for DbProviderUtils. + + + + + Dispose of the given Connection, created via the given IDbProvider, + if it is not managed externally (that is, not bound to the thread). + + The connection to close if necessary. If + this is null the call will be ignored. + The IDbProvider the connection came from + + + + Get a ADO.NET Connection/Transaction Pair for the given IDbProvider. + Changes any exception into the Spring hierarchy of generic data access + exceptions, simplifying calling code and making any exception that is + thrown more meaningful. + + + Is aware of a corresponding Connection/Transaction bound to the current thread, for example + when using AdoPlatformTransactionManager. Will bind a IDbConnection to the thread + if transaction synchronization is active + + The provider. + A Connection/Transaction pair. + + + + Get a ADO.NET Connection/Transaction Pair for the given IDbProvider. + Same as but throwing original provider + exception. + + + Is aware of a corresponding Connection/Transaction bound to the current thread, for example + when using AdoPlatformTransactionManager. Will bind a IDbConnection to the thread + if transaction synchronization is active + + The provider. + + + + + Do the connection mgmt. + + + + + + + Applies the current transaction timeout, if any, to the given ADO.NET IDbCommand object. + + The command. + The db provider. + + + + Applies the specified timeout - overridden by the current transaction timeout, if any, to to the + given ADO.NET IDb command object. + + The command. + The db provider the command was obtained from. + The timeout to apply (or 0 for no timeout outside of a transaction. + + + + Implementation that delegates to ServiceDomain and ContextUtil for all functionality. + + Introduced for purposes of unit testing. + Mark Pollack (.NET) + + + + Provides the necessary transactional state and operations for ServiceDomainTransactionManager to + work with ServiceDomain and ContextUtil. + + Introduced for purposes of unit testing. + Mark Pollack (.NET) + + + + Creates the context specified by the ServiceConfig object and pushes it onto the context stack to + become the current context. + + A ServiceConfig that contains the configuration information for the services to be used within the enclosed code. + + + + Leaves this ServiceDomain. The current context is then popped from the context stack, and the + context that was running when Enter was called becomes the current context. + + One of the TransactionStatus values + + + + Sets the consistent bit and the done bit to true in the COM+ context + + + + + Sets the consistent bit to false and the done bit to true in the COM+ context. + + + + + Gets or sets the consistent bit in the COM+ context. + + My transaction vote. + + + + Gets a value indicating whether the current context is transactional. + + + true if this instance is existing transaction; otherwise, false. + + + + + Creates the context specified by the ServiceConfig object and pushes it onto the context stack to + become the current context. + + A ServiceConfig that contains the configuration information for the services to be used within the enclosed code. + + + + Leaves this ServiceDomain. The current context is then popped from the context stack, and the + context that was running when Enter was called becomes the current context. + + One of the TransactionStatus values + + + + Sets the consistent bit and the done bit to true in the COM+ context + + + + + Sets the consistent bit to false and the done bit to true in the COM+ context. + + + + + Gets or sets the consistent bit in the COM+ context. + + My transaction vote. + + + + Gets a value indicating whether the current context is transactional. + + + true if this instance is existing transaction; otherwise, false. + + + + + Uses and System.Transactions.Transaction.Current to provide + necessary state and operations to TxScopeTransactionManager. + + Mark Pollack (.NET) + + + + Provides the necessary transactional state and operations for TxScopeTransactionManager to + work with TransactionScope and Transaction.Current. + + Introduced for purposes of unit testing. + Mark Pollack (.NET) + + + + Creates the transaction scope. + + The tx scope option. + The tx options. + The interop option. + + + + Call Complete() on the TransactionScope object created by this instance. + + + + + Call Disponse() on the TransactionScope object created by this instance. + + + + + Gets a value indicating whether there is a new transaction or an existing transaction. + + + true if this instance is existing transaction; otherwise, false. + + + + + Gets a value indicating whether rollback only has been called (i.e. Rollback() on the + Transaction object) and therefore voting that the transaction will be aborted. + + true if rollback only; otherwise, false. + + + + Call Complete() on the TransactionScope object created by this instance. + + + + + Call Disponse() on the TransactionScope object created by this instance. + + + + + Creates the transaction scope. + + The tx scope option. + The tx options. + The interop option. + + + + Gets a value indicating whether there is a new transaction or an existing transaction. + + + true if this instance is existing transaction; otherwise, false. + + + + + Gets a value indicating whether rollback only has been called (i.e. Rollback() on the + Transaction object) and therefore voting that the transaction will be aborted. + + true if rollback only; otherwise, false. + + + + Implementation of IAdoExceptionTranslator that analyzes provider specific + error codes and translates into the DAO exception hierarchy. + + This class loads the obtains error codes from + the IDbProvider metadata property ErrorCodes + which defines error code mappings for various providers. + + Mark Pollack (.NET) + + + + Interface to be implemented by classes that can translate between properietary SQL exceptions + and Spring.NET's data access strategy-agnostic . + + +

+ Implementations can be generic (for example, ADO.NET Exceptions) or proprietary (for example, + using SQL Server or Oracle error codes) for greater precision. +

+
+ Rod Johnson + Griffin Caprio (.NET) + Mark Pollack +
+ + + Translate the given into a generic data access exception. + + A readable string describing the task being attempted. + The SQL query or update that caused the problem. May be null. + + The encountered by the ADO.NET implementation. + + + A appropriate for the supplied + . + + + + + The shared log instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + The data provider. + + + + Initializes a new instance of the class. + + The data provider. + The error code collection. + + + + Translate the given into a generic data access exception. + + A readable string describing the task being attempted. + The SQL query or update that caused the problem. May be null. + + The encountered by the ADO.NET implementation. + + + A appropriate for the supplied + . + + + + + Template method for actually translating the given exception. + given into a generic data access exception. + + A readable string describing the task being attempted. + The SQL query or update that caused the problem. May be null. + The error code. + The encountered by the ADO.NET implementation. + + A appropriate for the supplied + . + + + The passed-in arguments will have been pre-checked. furthermore, this method is allowed to + return null to indicate that no exception match has been found and that + fallback translation should kick in. + + + + + Subclasses can override this method to attempt a custom mapping from a data access Exception + to DataAccessException. + + Readable text describing the task being attempted. + SQL query or update that caused the problem. May be null. + The error code extracted from the generic data access exception for + a particular provider. + The exception thrown from a data access operation. + + null if no custom translation was possible, otherwise a DataAccessException + resulting from custom translation. This exception should include the exception parameter + as a nested root cause. This implementation always returns null, meaning that + the translator always falls back to the default error codes. + + + + + Builds the message. + + The task. + The SQL. + The exception. + + + + + Determines whether the specified exception is valid data access exception. + + The exception. + + true if is valid data access exception; otherwise, false. + + + + + Logs the translation. + + The task. + The SQL. + The error code. + The exception. + if set to true [b]. + + + + Sets the db provider. + + The db provider. + + + + Gets the error codes for the provider + + The error codes. + + + + Gets or sets the fallback translator to use in case error code based translation + fails. + + The fallback translator. + + + + Translates all exceptions to an UncategorizedAdoException. + + + This exception translator used when an exception is thrown using the + "primary" implementation of IAdoExceptionTranslator, i.e. AdoExceptionTranslator. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Translate the given into a generic data access exception. + + A readable string describing the task being attempted. + The SQL query or update that caused the problem. May be null. + + The encountered by the ADO.NET implementation. + + + A appropriate for the supplied + . + + + + + Provides a name to a ResultSetProcessor for use with AdoOperation subclasses + such as StoredProcedure. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class with a + IRowCallback instance + + The name of the associated row callback for use with output + result set mappers. + A row callback instance. + + + + Initializes a new instance of the class with a + IRowMapper instance + + The name of the associated row mapper. + A IRowMapper instance. + + + + Initializes a new instance of the class with a + IResultSetExtractor instance + + The name of the associated result set extractor. + A IResultSetExtractor instance. + + + + A data reader implementation that mapps DBNull values to sensible defaults. + + IDataRecord methods are virtual. + Mark Pollack (.NET) + + + + Custom data reader implementations often delegate to an underlying + instance. This interface captures that relationship for reuse in + the framework. + + Implementations will typically add behavior to standard IDataReader methods, + for example, by providing default values for DbNull values. + See as an example. + + Mark Pollack (.NET) + + + + The underlying reader implementation to delegate to for accessing data + from a returned result sets. + + The wrapped reader. + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The data reader to delegate operations to. + + + + Gets the 32-bit signed integer value of the specified field. + + The index of the field to find. + + The 32-bit signed integer value of the specified field or 0 if null + + The index passed was outside the range of 0 through . + + + + Return the value of the specified field, null if value equals DBNull.Value + + The index of the field to find. + + The which will contain the field value upon return. + Returns null if value equals DBNull.Value + + + The index passed was outside the range of 0 through . + + + + + Return whether the specified field is set to null. + + The index of the field to find. + + if the specified field is set to null, otherwise + . + + The index passed was outside the range of 0 through . + + + + Gets the with the specified name. + Returns null if value equals DBNull.Value + + + + + + Gets the with the specified i. + Returns null if value equals DBNull.Value + + Return the object or null if the value equals DBNull.Value + + + + Miscellaneous utility methods for manipulating parameter objects. + + Mark Pollack (.NET) + + + + The shared log instance for this class (and derived classes). + + + + + Initializes a new instance of the class. + + + + + Copies the parameters from IDbParameters to the parameter collection in IDbCommand + + The command. + The spring param collection. + + + + Copies the parameters in IDbCommand to IDbParameters + + The spring param collection. + The command. + + + + Adapter to enable use of a IRowCallback inside a ResultSetExtractor. + + We don't use it for navigating since this could lead to unpredictable consequences. + Mark Pollack + + + + Initializes a new instance of the class. + + The row callback. + + + + Initializes a new instance of the class. + + The row callback delegate. + + + + All rows of the data reader are passed to the IRowCallback + associated with this class. + + The IDataReader to extract data from. + Implementations should not close this: it will be closed + by the AdoTemplate. + + Null is returned since IRowCallback manages its own state. + + + + + A class that contains the properties of ServiceConfig used by ServiceDomainPlatformTransactionManager. + + This is done to enhance testability of the transaction manager since ServiceConfig does not override Equals or Hashcode + Mark Pollack (.NET) + + + + Using reflection on VS.NET 2005 a generated typed dataset, apply the + connection/transaction pair associated with the current Spring based + transaction scope. + + This avoids the limitations of using System.Transaction + based transaction scope for multiple operation on typed datasets withone one + transaction. Reflection was used rather than partial classes to provide + a general solution that can be written and applied once. + Usage within a DAO method, FindAll() is shown below. Note: Convenience methods + to simplify calling syntax maybe provided in the future, it is a trade off on type + safety calling the typed adapter defined outside the anonymous method as + compared to casting inside a "DoInDbAdapter(object dbAdapter) method. + + public PrintGroupMappingDataSet FindAll() + { + + PrintGroupMappingTableAdapter adapter = new PrintGroupMappingTableAdapter(); + PrintGroupMappingDataSet printGroupMappingDataSet = new PrintGroupMappingDataSet(); + + + printGroupMappingDataSet = AdoTemplate.Execute(delegate(IDbCommand command) + { + TypedDataSetUtils.ApplyConnectionAndTx(adapter, command); + adapter.Fill(printGroupMappingDataSet.PrintGroupMapping); + return printGroupMappingDataSet; + }) + as PrintGroupMappingDataSet; + + return printGroupMappingDataSet; + } + + See http://www.code-magazine.com/articleprint.aspx?quickid=0605031 for a + more complete discussion. + + + + + + Applies the connection and tx to the provided typed dataset. The connection and transaction + used are taken from the Spring's current transactional context. See ConnectionUtils.GetConnectionTxPair + for more information + + The typed data set adapter. + The db provider. + + + + Applies the connection and tx to the provided typed dataset. + + Generated dataset to not inherit from a common base + class so that we must pass in the generic object type. + The typed data set adapter. + The IDbCommand managed by Spring and set with + the connection/transaction of the current Spring transaction scope. + + + + Exception thrown when SQL specified is invalid. + + Mark Pollack (.NET) + + + + SQL that led to the problem + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A message about the exception. + + + + Initializes a new instance of the class. + + A message about the exception. + The inner exception. + + + + Initializes a new instance of the class. + + name of the current task. + The offending SQL statment + The root cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + When overridden in a derived class, sets the + with information about the exception. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is a null reference ( in Visual Basic). + + + + Fatal exception thrown when we can't connect to an RDBMS using ADO.NET + + Rod Johnson + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A message about the exception. + + + + Initializes a new instance of the class. + + A message about the exception. + The inner exception. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Callback delegate for code that operates on a IDbCommand. + + the ADO.NET command object. + +

Allows you to execute any number of operations + on a single IDbCommand, for example a single ExecuteScalar + call or repeated execute calls with varying parameters. +

+

Used internally by AdoTemplate, but also useful for + application code. Note that the passed in IDbCommand + has been created by the framework and will have its + Connection property set and the Transaction property + set based on the transaction context.

+
+ Mark Pollack +
+ + + Callback delegate to set any necessary parameters or other + properties on the command object. The CommandType and + CommandText properties will have already been supplied + + The database command object. + Mark Pollack + + + + Exception thrown when an attempt to insert or update data + results in violation of an primary key or unique constraint. + Note that this is not necessarily a purely relational concept; + unique primary keys are required by most database types. + + Thomas Risberg + Mark Pollack (.NET) + + + + SQL that led to the problem + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A message about the exception. + + + + Initializes a new instance of the class. + + A message about the exception. + The inner exception. + + + + Initializes a new instance of the class. + + name of the current task. + The offending SQL statment + The root cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + When overridden in a derived class, sets the + with information about the exception. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is a null reference ( in Visual Basic). + + + + Gets the SQL that caused the exception + + The SQL that caused the exception. + + + + Called by the AdoTemplate class to allow implementations + to set any necessary parameters on the command object. + The CommandType and CommandText will have already been supplied. + + Mark Pollack (.NET) + + + + Called by the AdoTemplate class to allow implementations + to set any necessary properties on the DbDataAdapter object. + + +

For example, this callback can be used to set the + AcceptChangesDuringFill property, register an event handler + for the FillErrors event, set update batch sizes if your provider + supports such functionality, set the ContinueUpdateOnError property, + or in .NET 2.0 to set the property AcceptChangesDuringUpdate. +

+

+ Downcast to the appropriate subtype to access vendor specific + functionality.

+

+ The DataAdapter SelectCommand will be already be + populated with values for CommandType and Text properties + along with Connection/Transaction properties based on the + calling transaction context. +

+
+ Mark Pollack (.NET) +
+ + + Lifecycle callback methods that can be registered when + performing Fill operations with AdoTemplate. + + +

+ The methods let you set various properties and invoke + methods on the DataSet before and after it gets filled by a DataAdapter. + For example, EnforceConstraints, BeginLoadData, and EndLoadData + can be called to optimize the loading of large DataSets with + many related tables. +

+

Vendors may expose other propriety methods on their DataSet + implementation, downcast to access this specific functionality. +

+
+ Mark Pollack (.NET) +
+ + + Called before a DataAdapter is used to fill a DataSet + the the provided tablename. + + The DataSet to be filled with a DataTable + The table collection to be filled + + + + Called after a DataAdapter is used to fill a DataSet + the the provided tablename. + + The DataSet to be filled with a DataTable + The table collection to be filled + + + + One of the central callback interfaces used by the AdoTemplate class + This interface creates a IDbCommand. Implementations are responsible + for configuring the created command with command type, command text and + any necessary parameters. + + Mark Pollack (.NET) + + + + Creates a IDbCommand. + + The IDbProvider reference that can be used to create the command in a + provider independent manner. The provider supplied is the same as used in configuration of AdoTemplate. + + + + + Helper class that can efficiently create multiple IDbCommand + objects with different parameters based on a SQL statement and a single + set of parameter declarations. + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + This interface creates a IDbDataAdapterCommand. + Implementations are responsible + for configuring the created command with appropriate + select and actions commands along with their parameters. + + + Generally used to to support the DataSet functionality in + the Spring.Data.Objects namespace. + + Mark Pollack (.NET) + + + + Creates the data adapter. + + A new IDbDataAdapter instance + + + + Exception thrown when a result set has been accessed in an invalid fashion. + + Mark Pollack (.NET) + + + + SQL that led to the problem + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A message about the exception. + + + + Initializes a new instance of the class. + + A message about the exception. + The inner exception. + + + + Initializes a new instance of the class. + + name of the current task. + The offending SQL statment + The root cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + When overridden in a derived class, sets the + with information about the exception. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is a null reference ( in Visual Basic). + + + + Gets the SQL that caused the exception + + The SQL that caused the exception. + + + + Callback to process each row of data in an AdoOperation's Query method. + + + Implementations of this interface perform the actual work of extracting + results. In contrast to a IResultSetExtractor, a IRowCallback object is typically + stateful. It keeps the result state within the object, to be available + for later inspection. + + + + + + Implementations must implement this method to process each row of data + in the data reader. + + + This method should not advance the cursor by calling Read() + on IDataReader but only extract the current values. The + caller does not need to care about closing the reader, command, connection, or + about handling transactions: this will all be handled by + Spring's AdoTemplate + + An active IDataReader instance + The result object + + + + Callback delegate to process all result sets and row in an + AdoTemplate query method. + + + Implementations of this delegate perform the work + of extracting results but don't need worry about managing + ADO.NET resources, such as closing the reader, or transaction management. + + The IDataReader to extract data from. + Implementations should not close this: it will be closed + by the AdoTemplate. + An arbitrary result object or null if none. + + + + Callback delegate to process each row of data in a result set to an object. + + The IDataReader to map + the number of the current row. + An abrirary object, typically derived from data + in the result set. + + + + Exception thrown when we can't classify a SQLException into + one of our generic data access exceptions. + + Mark Pollack (.NET) + + + + SQL that led to the problem + + + + + The error code, if available, that was unable to be categorized. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + A message about the exception. + + + + Initializes a new instance of the class. + + A message about the exception. + The inner exception. + + + + Initializes a new instance of the class. + + name of the current task. + the underlying error code that could not be translated + The offending SQL statment + The root cause. + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + When overridden in a derived class, sets the + with information about the exception. + + The that holds the serialized object data about the exception being thrown. + The that contains contextual information about the source or destination. + The parameter is a null reference ( in Visual Basic). + + + + Return the underlying error code if available from the underlying provider. + + + + + Return the SQL that resulted in this exception. + + + + + IObjectDefinitionParser implementation that allows users to easily configure all the + infrastructure objects required to enable attribute-driven transction demarcation. + + Rob Harrop + Juergen Hoeller + Mark Pollack (.NET) + + + + The 'proxy-target-type' attribute + + + + + The 'order' property/attribute + + + + + Central template method to actually parse the supplied XmlElement + into one or more IObjectDefinitions. + + The element that is to be parsed into one or more s + The the object encapsulating the current state of the parsing process; + provides access to a + + The primary IObjectDefinition resulting from the parsing of the supplied XmlElement + + + + + Configures the auto proxy creator. + + The parser context. + The element. + + + + Gets a value indicating whether an ID should be generated instead of read + from the passed in XmlElement. + + true if should generate id; otherwise, false. + Note that this flag is about always generating an ID; the parser + won't even check for an "id" attribute in this case. + + + + + The for the <tx:advice> tag. + + Rob Harrop + Juergen Hoeller + Adrian Colyer + Mark Pollack (.NET) + + + + NamespaceParser allowing for the configuration of + declarative transaction management using either XML or using attributes. + + This namespace handler is the central piece of functionality in the + Spring transaction management facilities and offers two appraoches + to declaratively manage transactions. + + One approach uses transaction semantics defined in XML using the + <tx:advice> elements, the other uses attributes + in combination with the <tx:annotation-driven> element. + Both approached are detailed in the Spring reference manual. + + + + + Register the for the 'advice' and + 'attribute-driven' tags. + + + + + This is a utility class to help in parsing the transaction namespace + + Mark Pollack + + + + The transaction manager attribute + + + + + The source of transaction metadata + + + + + The property asociated with the transaction manager xml element + + + + + Abstract implementation of + + that caches attributes for methods, and implements a default fallback policy. + + +

+ The default fallback policy applied by this class is: + + + most specific method + + + target class attribute + + + declaring method + + + declaring class + + +

+

+ Defaults to using class's transaction attribute if none is associated + with the target method. Any transaction attribute associated with the + target method completely overrides a class transaction attribute. +

+

+ This implementation caches attributes by method after they are first used. + If it's ever desirable to allow dynamic changing of transaction attributes + (unlikely) caching could be made configurable. Caching is desirable because + of the cost of evaluating rollback rules. +

+
+ Rod Johnson + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + Interface used by + to source transaction attributes. + + +

+ Implementations know how to source transaction attributes, whether from configuration, + metadata attributes at source level, or anywhere else. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Return the for this + method. + + The method to check. + + The target . May be null, in which case the declaring + class of the supplied must be used. + + + A or + null if the method is non-transactional. + + + + + Canonical value held in cache to indicate no transaction attibute was found + for this method, and we don't need to look again. + + + + + Cache of s, keyed by method and target class. + + + + + Creates a new instance of the + + class. + + +

+ This is an class, and as such exposes no public constructors. +

+
+
+ + + Subclasses should implement this to return all attributes for this method. + May return null. + + + We need all because of the need to analyze rollback rules. + + The method to retrieve attributes for. + The transactional attributes associated with the method. + + + + Subclasses should implement this to return all attributes for this class. + May return null. + + + The to retrieve attributes for. + + + All attributes associated with the supplied . + + + + + Return the transaction attribute for this method invocation. + + + Defaults to the class's transaction attribute if no method + attribute is found + + method for the current invocation. Can't be null + target class for this invocation. May be null. + for this method, or null if the method is non-transactional + + + + Return the transaction attribute, given this set of attributes + attached to a method or class. Return null if it's not transactional. + + + Protected rather than private as subclasses may want to customize + how this is done: for example, returning a + + affected by the values of other attributes. + This implementation takes into account + s, if + the TransactionAttribute is a RuleBasedTransactionAttribute. + + + Attributes attached to a method or class. May be null, in which case a null + will be returned. + + + The configured transaction attribute, or null + if none was found. + + + + + Does the supplied satisfy this matcher? + + +

+ Must be implemented by a derived class in order to specify matching + rules. +

+
+ The candidate method. + + The target (may be , + in which case the candidate must be taken + to be the 's declaring class). + + + if this this method matches statically. + +
+ + + Implementation of that uses + s. + + Rod Johnson + Griffin Caprio (.NET) + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + + implementation. + + + We need all because of the need to analyze rollback rules. + + The method to retrieve attributes for. + The transactional attributes associated with the method. + + + + + implementation. + + + The to retrieve attributes for. + + + All attributes associated with the supplied . + + + + + Transaction attribute approach to rolling back on all exceptions, no other + exceptions by default. + + Rod Johnson + Griffin Caprio (.NET) + + + + Default implementation of the + interface, offering object-style configuration and sensible default values. + + +

+ Base class for both and + . +

+
+ Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + Interface for classes that define transaction properties. Base interface for + . + + +

+ Note that isolation level, timeout and read-only settings will only + get applied when starting a new transaction. As only + and + can actually cause that, it doesn't make sense + to specify any of those settings else. Furthermore, not all transaction + managers will support those features and thus throw respective exceptions + when given non-default values. +

+
+ Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + Return the propagation behavior of type + . + + + + + Return the isolation level of type . + + +

+ Only makes sense in combination with + and + . +

+

+ Note that a transaction manager that does not support custom isolation levels + will throw an exception when given any other level than + . +

+
+
+ + + Return the transaction timeout. + + +

+ Must return a number of seconds, or -1. + Only makes sense in combination with + and + . + Note that a transaction manager that does not support timeouts will + throw an exception when given any other timeout than -1. +

+
+
+ + + Get whether to optimize as read-only transaction. + + +

+ This just serves as hint for the actual transaction subsystem, + it will not necessarily cause failure of write accesses. +

+

+ Only makes sense in combination with + and + . +

+

+ A transaction manager that cannot interpret the read-only hint + will not throw an exception when given ReadOnly=true. +

+
+
+ + + Return the name of this transaction. Can be null. + + + This will be used as a transaction name to be shown in a + transaction monitor, if applicable. In the case of Spring + declarative transactions, the exposed name will be the fully + qualified type name + "." method name + assembly (by default). + + + + + Gets the enterprise services interop option. + + The enterprise services interop option. + + + + The default transaction timeout. + + + + + Prefix for Propagation settings. + + + + + Prefix for IsolationLevel settings. + + + + + Prefix for transaction timeout values in description strings. + + + + + Marker for read-only transactions in description strings. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class + with the supplied + behaviour. + + + The desired behavior. + + + + + An override of the default method. + + The to compare to. + True if the objects are equal. + + + + An override of the default method that returns the + hashcode of the + + property. + + + The hashcode of the + + property. + + + + + An override of the default method that returns a string + representation of the + + property. + + + A string representation of the + + property. + + + + + Gets / Sets the propagation + behavior. + + + + + Return the isolation level of type . + + +

+ Only makes sense in combination with + and + . +

+

+ Note that a transaction manager that does not support custom isolation levels + will throw an exception when given any other level than + . +

+
+
+ + + Return the transaction timeout. + + +

+ Must return a number of seconds, or -1. + Only makes sense in combination with + and + . + Note that a transaction manager that does not support timeouts will + throw an exception when given any other timeout than -1. +

+
+
+ + + Get whether to optimize as read-only transaction. + + +

+ This just serves as hint for the actual transaction subsystem, + it will not necessarily cause failure of write accesses. +

+

+ Only makes sense in combination with + and + . +

+

+ A transaction manager that cannot interpret the read-only hint + will not throw an exception when given ReadOnly=true. +

+
+
+ + + Return the name of this transaction. Can be null. + + + + This will be used as a transaction name to be shown in a + transaction monitor, if applicable. In the case of Spring + declarative transactions, the exposed name will be the fully + qualified type name + "." method name + assembly (by default). + + + + + Gets the enterprise services interop option. + + The enterprise services interop option. + + + + Returns a representation of the + + property. + + + + + This interface adds a + + specification to . + + Griffin Caprio (.NET) + + + + Decides if rollback is required for the supplied . + + The to evaluate. + True if the exception causes a rollback, false otherwise. + + + + Prefix for rollback-on-exception rules in description strings. + + + + + Prefix for commit-on-exception rules in description strings. + + + + + Creates a new instance of the + + class. + + + + + Creates a new instance of the + + class, setting the propagation behavior to the supplied value. + + + The desired transaction propagation behaviour. + + + + + Decides if rollback is required for the supplied . + + +

+ The default behavior is to rollback on any exception. + Consistent with 's behavior. +

+
+ The to evaluate. + True if the exception causes a rollback, false otherwise. +
+ + + Return a description of this transaction attribute. + + +

+ The format matches the one used by the + , + to be able to feed any result into a + instance's properties. +

+
+
+ + + Advisor driven by a , + used to exclude a general advice from methods that + are non-transactional. + + + + To put it another way, use this advisor when you would like to associate other AOP + advice based on the pointcut specified by declarative transaction demarcation, + attibute based or otherwise. + +

+ Because the AOP framework caches advice calculations, this is normally + faster than just letting the + run and find out itself that it has no work to do. +

+
+ Mark Pollack (.NET) +
+ + + Creates a new instance of the + class. + + + + + Tests the input method to see if it's covered by the advisor. + + The method to match. + The to match against. + + True if the supplied is covered by the advisor. + + + + + ITransactionAttribute that delegates all calls to a give target attribute except for the + name, which is specified in the constructor. + + + + + Initializes a new instance of the class. + + The target attribute. + The identification. + + + + Decides if rollback is required for the supplied . + + The to evaluate. + + True if the exception causes a rollback, false otherwise. + + + + + Return a description of this transaction attribute. + + +

+ The format matches the one used by the + , + to be able to feed any result into a + instance's properties. +

+
+
+ + + Return the propagation behavior of type + . + + + + + + Return the isolation level of type . + + + +

+ Only makes sense in combination with + and + . +

+

+ Note that a transaction manager that does not support custom isolation levels + will throw an exception when given any other level than + . +

+
+
+ + + Return the transaction timeout. + + + +

+ Must return a number of seconds, or -1. + Only makes sense in combination with + and + . + Note that a transaction manager that does not support timeouts will + throw an exception when given any other timeout than -1. +

+
+
+ + + Get whether to optimize as read-only transaction. + + + +

+ This just serves as hint for the actual transaction subsystem, + it will not necessarily cause failure of write accesses. +

+

+ Only makes sense in combination with + and + . +

+

+ A transaction manager that cannot interpret the read-only hint + will not throw an exception when given ReadOnly=true. +

+
+
+ + + Return the name of this transaction. + + + + The exposed name will be the fully + qualified type name + "." method name + assembly (by default). + + + + + Gets the enterprise services interop option. + + The enterprise services interop option. + + + + Very simple implementation of + which will always return the same + for all methods fed to it. + + +

+ The + may be specified, but will otherwise default to PROPAGATION_REQUIRED. This may be + used in the cases where you want to use the same transaction attribute with all + methods being handled by a transaction interceptor. +

+
+ Colin Sampaleanu + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + + class. + + + + + Return the for this + method. + + The method to check. + + The target . May be null, in which case the declaring + class of the supplied must be used. + + + A or + null if the method is non-transactional. + + + + + Determines whether the specified is equal to the current . + + The to compare with the current . + + true if the specified is equal to the current ; otherwise, false. + + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Returns a that represents the current . + + + + A that represents the current . + + 2 + + + + Allows a transaction attribute to be specified, using the + form, for example, "PROPAGATION_REQUIRED". + + + + + Simple implementation of the + interface that allows attributes to be stored per method in a map. + + Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Add an attribute for a transactional method. + + + Method names can end or start with "*" for matching multiple methods. + + The class and method name, separated by a dot. + The attribute to be associated with the method. + + + + Add an attribute for a transactional method. + + + Method names can end or start with "*" for matching multiple methods. + + The target interface or class. + The mapped method name. + + The attribute to be associated with the method. + + + + + Add an attribute for a transactional method. + + The transactional method. + + The attribute to be associated with the method. + + + + + Does the supplied match the supplied ? + + + The default implementation checks for "xxx*", "*xxx" and "*xxx*" matches, + as well as direct equality. This behaviour can (of course) be overridden in + derived classes. + + The method name of the class. + The name in the descriptor. + True if the names match. + + + + Return the for this + method. + + The method to check. + + The target . May be null, in which case the declaring + class of the supplied must be used. + + + A or + null if the method is non-transactional. + + + + + Set a name/attribute map, consisting of "FQCN.method, AssemblyName" method names + (e.g. "MyNameSpace.MyClass.MyMethod, MyAssembly") and ITransactionAttribute + instances (or Strings to be converted to instances). + + +

+ The key values of the supplied + must adhere to the following form:
+ FQCN.methodName, Assembly. +

+ + MyNameSpace.MyClass.MyMethod, MyAssembly + +
+
+ + + Simple implementation of the + that allows attributes to be matched by registered name. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Logger available to subclasses, static for optimal serialization + + + + + Keys are method names; values are ITransactionAttributes + + + + + Creates a new instance of the + class. + + + + + Enumerate the string/ mapping entries. + + + + + Add a mapping. + + + + + Add a mapping. + + + + + Does the supplied match the supplied ? + + + The default implementation checks for "xxx*", "*xxx" and "*xxx*" matches, + as well as direct equality. Can be overridden in subclasses. + + The method name of the class. + The name in the descriptor. + True if the names match. + + + + Add an attribute for a transactional method. + + +

+ Method names can end with "*" for matching multiple methods. +

+
+ The transactional method name. + + The attribute to be associated with the method. + +
+ + + Parses the given properties into a name/attribute map. + + + Expects method names as keys and string attributes definitions as values, + parsable into + instances via + . + + The properties of the transaction. + + + + Return the for this + method. + + The method to check. + + The target . May be null, in which case the declaring + class of the supplied must be used. + + + A or + null if the method is non-transactional. + + + + + Set a name/attribute map, consisting of method names (e.g. "MyMethod") and + instances + (or Strings to be converted to ITransactionAttribute instances). + + + + + Parses the given properties into a name/attribute map. + + + Expects method names as keys and string attributes definitions as values, + parsable into + instances via + . + + The properties of the transaction. + + + + Tag class. Its class means it has the opposite behaviour to the + superclass. + + Rod Johnson + Griffin Caprio (.NET) + + + + Rule determining whether or not a given exception (and any subclasses) should + cause a rollback. + + +

+ Multiple such rules can be applied to determine whether a transaction should commit + or rollback after an exception has been thrown. +

+
+ Griffin Caprio (.NET) +
+ + + Could hold exception, resolving class name but would always require FQN. + This way does multiple string comparisons, but how often do we decide + whether to roll back a transaction following an exception? + + + + + Canonical instance representing default behavior for rolling back on + all s. + + + + + Creates a new instance of the + class + for the named . + + The exception name. + +

+ As always, the should be the full + assembly qualified version. +

+
+
+ + + Creates a new instance of the + class + for the suplied . + + +

+ The exception class must be or a subclass. +

+

+ This is the preferred way to construct a + , + matching the exception class and subclasses. +

+
+ + The class that will trigger a rollback. + +
+ + + Return the depth to the matching superclass execption . + + + A return value of 0 means that the matches. + + + The of exception to find. + + + Return -1 if there's no match. Otherwise, return depth. Lowest depth wins. + + + + + Return the depth to the matching superclass execption . + + + A return value of 0 means that the s + matches. + + + The exception object to find. + + + Return -1 if there's no match. Otherwise, return depth. Lowest depth wins. + + + + + Returns a representation of this instance. + + + A containing the exception covered by this instance. + + + + + Override of . + + The hashcode of the exception name covered by this instance. + + + + Override of . + + The object to compare. + True if the input object is equal to this instance. + + + + Strongly typed Equals() implementation. + + + The to compare. + + + True if the input object is equal to the supplied . + + + + + Returns the name of the exception. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + The class that will trigger a rollback. + + + + + The that drives this advisor. + + + + + implementation + that works out whether a given exception should cause transaction rollback by applying + a number of rollback rules, both positive and negative. + + + If no rules are relevant to the exception, it behaves like the + class + (rolling back on runtime exceptions).. +

+ The + creates objects of this class. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + + class. + + + The desired transaction propagation behaviour. + + + The rollback rules list for this transaction attribute. + + + + + Creates a new instance of the + + class. + + + + + Will a transaction be rolled back if the supplied + is thrown during the lifecycle of a transaction to which this attribute is applied? + + The offending . + True if the exception should cause a rollback, false otherwise. + + + + Returns a representation of this instance. + + + A representation of this instance. + + + + + Adds a to this + attributes list of rollback rules. + + + The to add. + + + + + Clears the rollback rules for this attribute. + + + + + Sets the rollback rules list for this transaction attribute. + + + + + Superclass for transaction aspects, such as the AOP Alliance-compatible + . + + +

+ This enables the underlying Spring transaction infrastructure to be used + to easily implement an aspect for any aspect system. +

+

+ Subclasses are responsible for calling methods in this class in the correct order. +

+

+ Uses the Strategy design pattern. A + implementation will perform the actual transaction management +

+

+ A transaction aspect is serializable if its + and + are serializable. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + The name in thread local storage where the TransactionInfo object is located + + + + + The currently referenced by + this aspect + + + + + The currently + referenced by this aspect. + + + + + Creates a new instance of the + class. + + + + + Checks that the required properties are set. + + + + + Create a transaction if necessary + + Method about to execute + Type that the method is on + + A object, + whether or not a transaction was created. +

+ The + + property on the + + class can be used to tell if there was a transaction created. +

+
+
+ + + Creates the transaction if necessary. + + The source transaction attribute. + The joinpoint identification. + Transaction Info for declarative transaction management. + + + + Identifies the method by providing the qualfied method name. + + The method info. + qualified mehtod name. + + + + Execute after the successful completion of call, but not after an exception was handled. + + +

+ Do nothing if we didn't create a transaction. +

+
+ + The + + about the current transaction. + +
+ + + Handle a exception, closing out the transaction. + + +

+ We may commit or roll back, depending on our configuration. +

+
+ + The + + about the current transaction. + + The encountered. +
+ + + Resets the + + for this thread. + + + + Call this in all cases: exceptions or normal return. + + + + The + + about the current transaction. May be null. + + + + + Gets and sets the for + this aspect. + + + + + Gets and sets the + for + this aspect. + + + + + Returns the + of the current method invocation. + + + Mainly intended for code that wants to set the current transaction + rollback-only but not throw an application exception. + + + If the transaction info cannot be found, because the method was invoked + outside of an AOP invocation context. + + + + + Subclasses can use this to return the current + . + + + Only subclasses that cannot handle all operations in one method + need to use this mechanism to get at the current + . + An around advice such as an AOP Alliance + can hold a reference to the + + throughout the aspect method. + A + will be returned even if no transaction was created. The + + property can be used to query this. + + + If no transaction has been created by an aspect. + + + + + Set properties with method names as keys and transaction attribute + descriptors (parsed via ) as values: + e.g. key = "MyMethod", value = "PROPAGATION_REQUIRED,readOnly". + + + + Method names are always applied to the target class, no matter if defined in an + interface or the class itself. + +

+ Internally, a + + will be created from the given properties. +

+
+
+ + + Opaque object used to hold transaction information. + + +

+ Subclasses must pass it back to method on this class, but not see its internals. +

+
+
+ + + Creates a new instance of the + + class for the supplied . + + The transaction attributes to associate with any transaction. + The info for diagnostic display of joinpoint + + + + Binds this + + instance to the thread local storage variable for the current thread and + backs up the existing + + object for the current thread. + + + + + Restores the previous + + object to the current thread. + + + + + Does this instance currently have a transaction? + + True if this instance has a transaction. + + + + Gets and sets the for this object. + + + + + Gets the current + for this + + object. + + + + + Gets the joinpoint identification. + + The joinpoint identification. + + + + .NET Attribute for describing transactional behavior of methods in a class. + + This attribute type is generally directly comparable + to Spring's class and + in fact will + directly convert the data to a + so that Spring's transaction support code does not have to know about + attributes. If no rules are relevant to the exception it will be treaded + like DefaultTransactionAttribute, (rolling back on all exceptions). + + The default property values are TransactionPropagation.Required, IsolationLevel.ReadCommitted, + DefaultTransactionDefinition.TIMEOUT_DEFAULT (can be changed, by default is the default + value of the underlying transaction subsystem) + ReadOnly = false, and Type.EmtptyTypes specified for Rollbackfor and NoRollbackFor exception + types. + + + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The transaction propagation. + + + + Initializes a new instance of the class. + + The transaction propagation. + The isolation level. + + + + Initializes a new instance of the class. + + The isolation level. + + + + Gets the transaction propagation. + + Defaults to TransactionPropagation.Required + The transaction propagation. + + + + Gets the isolation level. + + Defaults to IsolationLevel.Unspecified + The isolation level. + + + + Gets or sets the timeout. + + Defaults to the default timeout of the underlying transaction system. + The timeout. + + + + Gets or sets a value indicating whether the transaction is readonly. + + Defaults to false + true if read-only; otherwise, false. + + + + Gets or sets the zero or more exception types which + indicating which exception types must cause a transaction + rollback. + + This is the preferred way to construct a rollback rule, + matching the exception class and subclasses. + The rollback types. + + + + Gets or sets zero or more exceptions types which + indicationg which exception type must not + cause a transaction rollback. + + This is the preferred way to construct a rollback rule, + matching the exception type. + The no rollback for. + + + + Gets or sets the enterprise services interop option. + + The enterprise services interop option. + + + + Type converter for + objects. + + + Takes s of the form +

PROPAGATION_NAME,ISOLATION_NAME,readOnly,timeout_NNNN,+Exception1,-Exception2

+

where only propagation code is required. For example:

+

PROPAGATION_MANDATORY,ISOLATION_DEFAULT

+

+ The tokens can be in any order. Propagation and isolation codes + must use the names of the values in the + enumeration. Timeout values are in seconds. If no timeout is specified, the transaction + manager will apply a default timeout specific to the particular transaction manager. +

+

+ A "+" before an exception name substring indicates that transactions should commit even + if this exception is thrown; a "-" that they should roll back. +

+
+ Mark Pollack +
+ + + Returns whether this converter can convert an object of the given type to an ITransactionAttribute, using the specified context. + + An that provides a format context. + A that represents the type you want to convert from. + + true if this converter can perform the conversion; otherwise, false. + + + + + Converts from string to ITransactionAttribute + + The context. + The culture. + The string value to convert + An ITransactionAttribute instance + + + + Type converter for + objects. + + + Takes s of the form +

PROPAGATION_NAME,ISOLATION_NAME,readOnly,timeout_NNNN,+Exception1,-Exception2

+

where only propagation code is required. For example:

+

PROPAGATION_MANDATORY,ISOLATION_DEFAULT

+

+ The tokens can be in any order. Propagation and isolation codes + must use the names of the values in the + enumeration. Timeout values are in seconds. If no timeout is specified, the transaction + manager will apply a default timeout specific to the particular transaction manager. +

+

+ A "+" before an exception name substring indicates that transactions should commit even + if this exception is thrown; a "-" that they should roll back. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Parses the input properties string into a valid + instance + + + The string defining the transactional properties. + + + + + Gets the + from this editor. + + + + + Advisor driven by a , used to include + a for methods that + are transactional. + + +

+ Because the AOP framework caches advice calculations, this is normally + faster than just letting the + run and find out itself that it has no work to do. +

+
+ Rod Johnson + Griffin Caprio (.NET) +
+ + + Initializes a new instance of the class. + + +

+ This is an abstract class, and as such has no publicly + visible constructors. +

+
+
+ + + Creates a new instance of the + class. + + + The pre-configured transaction interceptor. + + + + + Tests the input method to see if it's covered by the advisor. + + The method to match. + The to match against. + + True if the supplied is covered by the advisor. + + + + + Sets the tx attribute source. + + The transaction interceptor. + + + + Sets the transaction interceptor. + + The transaction interceptor. + + + + Editor that can convert values into + instances. + + + The transaction attribute string must be parseable by the + in this package. +

+ Strings must be specified in the following syntax:
+ FQCN.methodName=<transaction attribute string> (sans <>). +

+ + ExampleNamespace.ExampleClass.MyMethod=PROPAGATION_MANDATORY,ISOLATION_DEFAULT + + + The specified class must be the one where the methods are defined; in the case of + implementing an interface, the interface class name must be specified. + +

+ This will register all overloaded methods for a given name. Does not support explicit + registration of certain overloaded methods. Supports wildcard style mappings (in + the form "xxx*"), e.g. "Notify*" for "Notify" and "NotifyAll". +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Parses the input properties into a valid + + instance + + The properties string to be parsed. + + + + Gets the + from this instance. + + + + + Internal class to parse property values. + + + + + Creates a new instance of the + class. + + The property values to be parsed. + + + + Indexer to return values based on index value. + + + + + Returns the collection of keys for properties. + + + + + An AOP Alliance providing + declarative transaction management using the common Spring.NET transaction infrastructure. + + +

+ That class contains the necessary calls into Spring.NET's underlying + transaction API: subclasses such as this are responsible for calling + superclass methods such as + + in the correct order, in the event of normal invocation return or an exception. +

+

+ s are thread-safe. +

+
+ Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + AOP Alliance invoke call that handles all transaction plumbing. + + + The method that is to execute in the context of a transaction. + + The return value from the method invocation. + + + + Proxy factory object for simplified declarative transaction handling. + + +

+ Alternative to the standard AOP + with a . +

+

+ This class is intended to cover the typical case of declarative + transaction demarcation: namely, wrapping a (singleton) target object with a + transactional proxy, proxying all the interfaces that the target implements. +

+

+ Internally, a + instance is used, but the user of this class does not have to care. Optionally, an + can be specified to cause conditional invocation of + the underlying . +

+

+ The + + and + + properties can be set to add additional interceptors to the mix. +

+
+ Juergen Hoeller + Dmitriy Kopylenko + Rod Johnson + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + + + + Returns the object wrapped by this proxy factory. + + The target object proxy. + + + + Method run after all the properties have been set for this object. + Responsible for actual proxy creation. + + + + + Set the target or . + + + The target. If this is an implementation of the + interface, it is used as our ; otherwise it is + wrapped in a . + + An for this object. + + + + Set the transaction manager for this factory. + + + It is this instance that will perform actual transaction management: this class is + just a way of invoking it. + + + + + Set the target object, i.e. the object to be wrapped with a transactional proxy. + + +

+ The target may be any object, in which case a + will + be created. If it is a , no wrapper + is created: this enables the use of a pooling + or prototype . +

+
+
+ + + Specify the set of interfaces being proxied. + + +

+ If left null (the default), the AOP infrastructure works + out which interfaces need proxying by analyzing the target, + proxying all of the interfaces that the target object implements. +

+
+
+ + + Set properties with method names as keys and transaction attribute + descriptors as values. + + +

+ The various transaction attribute descriptors are parsed via + an instance of the + class. +

+ + Method names are always applied to the target class, no matter if defined in an + interface or the class itself. + +

+ Internally, a + + will be created from the given properties. +

+
+ +

+ An example string (method name and transaction attributes) might be: +

+

+ key = "myMethod", value = "PROPAGATION_REQUIRED,readOnly". +

+
+
+ + + Set the transaction attribute source which is used to find transaction + attributes. + + +

+ If specifying a property value, an + appropriate + implementation will create a + + from the value. +

+
+
+ + + Set a pointcut, i.e an object that can cause conditional invocation + of the + depending on method and attributes passed. + + + + Additional interceptors are always invoked. + + + + + + Set additional interceptors (or advisors) to be applied before the + implicit transaction interceptor. + + + + + Set additional interceptors (or advisors) to be applied after the + implicit transaction interceptor. + + +

+ Note that this is just necessary if you rely on those interceptors in general. +

+
+
+ + + Specify the to use. + + The default instance is the global AdvisorAdapterRegistry. + + + + Returns the object for this proxy factory. + + + + + Is this object a singleton? Always returns true in this implementation. + + + + + Default implementation of the interface, + used by . + + +

+ Holds all status information that + + needs internally, including a generic transaction object determined by + the concrete transaction manager implementation. +

+

+ Supports delegating savepoint-related methods to a transaction object + that implements the interface. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + Representation of the status of a transaction, + consisting of a transaction object and some status flags. + + +

+ Transactional code can use this to retrieve status information, + and to programmatically request a rollback (instead of throwing + an exception that causes an implicit rollback). +

+

+ Derives from the interface to provide access + to savepoint management facilities. Note that savepoint management + is just available if the actual transaction manager supports it. +

+
+ Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + Set the transaction rollback-only. This instructs the transaction manager that the only possible outcome of + the transaction may be a rollback, proceeding with the normal application + workflow though (i.e. no exception). + + +

+ For transactions managed by a or + . + An alternative way to trigger a rollback is throwing an transaction exception. +

+
+
+ + + Returns true if the transaction is new, else false if participating + in an existing transaction. + + + + + Return whether the transaction has been marked as rollback-only, + (either by the application or by the transaction infrastructure). + + + + + Gets the current transaction object. + + + Returns the current transaction object for a given connection. +

+ Used to associate with the property. +

+
+
+ + + Creates a new instance of the + class. + + The underlying transaction object that can hold state for the internal + transaction implementation. + True if the transaction is new, else false if participating in an existing transaction. + True if a new transaction synchronization has been opened for the given + . + True if the transaction is read only. + if set to true, enable debug log in tx managers. + The suspended resources for the given . + + + + Determines whether there is an actual transaction active. + + + true if there is an actual transaction active; otherwise, false. + + + + + Set the transaction rollback-only. This instructs the transaction manager that the only possible outcome of + the transaction may be a rollback, proceeding with the normal application + workflow though (i.e. no exception). + + +

+ For transactions managed by a or + . + An alternative way to trigger a rollback is throwing an transaction exception. +

+
+
+ + + This implementation delegates to the underlying transaction object + (if it implements the interface) + to create a savepoint. + + + If the underlying transaction does not support savepoints. + + + + + This implementation delegates to the underlying transaction object + (if it implements the interface) + to rollback to the supplied . + + The savepoint to rollback to. + + + + This implementation delegates to the underlying transaction object + (if it implements the interface) + to release the supplied . + + The savepoint to release. + + + + Create a savepoint and hold it for the transaction. + + + If the underlying transaction does not support savepoints. + + + + + Roll back to the savepoint that is held for the transaction. + + + If no save point has been created. + + + + + Release the savepoint that is held for the transaction. + + + If no save point has been created. + + + + + Gets a value indicating whether the progress of this transaction is debugged. + This is used by AbstractPlatformTransactionManager as an optimization, to prevent repeated + calls to log.IsDebug. Not really intended for client code. + true if debug; otherwise, false. + + + + Returns the underlying transaction object. + + + + + Gets or sets a value indicating whether the Transaction is completed, that is commited or rolled back. + + true if completed; otherwise, false. + + + + Returns true if the underlying transaction is read only. + + + + + Flag indicating if a new transaction synchronization has been opened + for this transaction. + + + + + Returns suspended resources for this transaction. + + + + + Gets and sets the savepoint for the current transaction, if any. + + + + + Returns a flag indicating if the transaction has a savepoint. + + + + + Return the underlying transaction as a + , if possible. + + + If the underlying transaction does not support savepoints. + + + + + Return true if the underlying transaction implements the + interface. + + + + + Returns true if the transaction is new, else false if participating + in an existing transaction. + + + + + Determine the rollbackOnly flag via checking both this + + and the transaction object, provided that the latter implements the + interface. + + The property can only be set to true. + + + + Determine the rollback-only flag via checking this TransactionStatus. Will only + return true if the application set the property RollbackOnly to true on this + TransactionStatus object. + + true if [local rollback only]; otherwise, false. + + + + Callback interface for transactional code. + + +

To be used with 's Execute + methods. +

+

+ Typically used to gather various calls to transaction-unaware low-level + services into a higher-level method implementation with transaction + demarcation. +

+
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + + Gets called by TransactionTemplate.Execute within a + transaction context. + + The associated transaction status. + A result object or null. + + + + Interface specifying basic transaction exectuion operations. + + + Implemented by . Not often used directly, + but a useful option to enhance testability, as it can easily be mocked or stubbed. + + Juergen Hoeller + Mark Pollac (.NET) + + + + Executes the the action specified by the given delegate callback within a transaction. + + Allows for returning a result object created within the transaction, that is, + a domain object or a collection of domain objects. An exception thrown by the callback + is treated as a fatal exception that enforces a rollback. Such an exception gets + propagated to the caller of the template. + + The delegate that specifies the transactional action. + A result object returned by the callback, or null if one + + In case of initialization or system errors. + + + + + Executes the action specified by the given callback object within a transaction. + + Allows for returning a result object created within the transaction, that is, + a domain object or a collection of domain objects. An exception thrown by the callback + is treated as a fatal exception that enforces a rollback. Such an exception gets + propagated to the caller of the template. + + The callback object that specifies the transactional action. + A result object returned by the callback, or null if one + + In case of initialization or system errors. + + + + + Simple convenience class for TransactionCallback implementation. + Allows for implementing a DoInTransaction version without result, + i.e. without the need for a return statement. + + Mark Pollack (.NET) + + + + Gets called by TransactionTemplate.execute within a transactional context + when no return value is required. + + The status. + + Does not need to care about transactions itself, although it can retrieve + and influence the status of the current transaction via the given status + object, e.g. setting rollback-only. + A RuntimeException thrown by the callback is treated as application + exception that enforces a rollback. An exception gets propagated to the + caller of the template. + + + + + Gets called by TransactionTemplate.Execute within a + transaction context. + + The associated transaction status. + a result object or null + + + + Callback delegate for performing actions within a transactional context. + + +

To be used with 's Execute + methods. +

+

+ Typically used to gather various calls to transaction-unaware low-level + services into a higher-level method implementation with transaction + demarcation. +

+
+ The status of the transaction, can be used to + trigger a rollback the current transaction by settings its + RollbackOnly property to true. + A result object or null. +
+ + + Internal class that manages resources and transaction synchronizations per thread. + + + Supports one resource per key without overwriting, i.e. a resource needs to + be removed before a new one can be set for the same key. + Supports a list of transaction synchronizations if synchronization is active. +

+ Resource management code should check for thread-bound resources via GetResource(). + It is normally not supposed + to bind resources to threads, as this is the responsiblity of transaction managers. + A further option is to lazily bind on first use if transaction synchronization + is active, for performing transactions that span an arbitrary number of resources. +

+

+ Transaction synchronization must be activated and deactivated by a transaction + manager via + InitSynchronization + and + ClearSynchronization. + This is automatically supported by + . +

+

+ Resource management code should only register synchronizations when this + manager is active, and perform resource cleanup immediately else. + If transaction synchronization isn't active, there is either no current + transaction, or the transaction manager doesn't support synchronizations. +

+ Note that this class uses following naming convention for the + named 'data slots' for storage of thread local data, 'Spring.Transaction:Name' + where Name is either +
+ Juergen Hoeller + Griffin Caprio (.NET) + Mark Pollack (.NET) +
+ + + Check if there is a resource for the given key bound to the current thread. + + key to check + if there is a value bound to the current thread + + + + Retrieve a resource for the given key that is bound to the current thread. + + key to check + a value bound to the current thread, or null if none. + + + + Bind the given resource for teh given key to the current thread + + key to bind the value to + value to bind + + + + Unbind a resource for the given key from the current thread + + key to check + the previously bound value + if there is no value bound to the thread + + + + Activate transaction synchronization for the current thread. + + + Called by transaction manager at the beginning of a transaction. + + + If synchronization is already active. + + + + + Deactivate transaction synchronization for the current thread. + + + Called by transaction manager on transaction cleanup. + + + If synchronization is not active. + + + + + Clears the entire transaction synchronization state for the current thread, registered + synchronizations as well as the various transaction characteristics. + + + + + Register a new transaction synchronization for the current thread. + + + Typically called by resource management code. + + + If synchronization is not active. + + + + + Return all resources that are bound to the current thread. + + Main for debugging purposes. Resource manager should always + invoke HasResource for a specific resource key that they are interested in. + + IDictionary with resource keys and resource objects or empty + dictionary if none is bound. + + + + Return an unmodifiable list of all registered synchronizations + for the current thread. + + + A list of + instances. + + + If synchronization is not active. + + + + + Return if transaction synchronization is active for the current thread. + + + Can be called before + InitSynchronization + to avoid unnecessary instance creation. + + + + + Gets or sets a value indicating whether the + current transaction is read only. + + + Called by transaction manager on transaction begin and on cleanup. + Return whether the current transaction is marked as read-only. + To be called by resource management code when preparing a newly + created resource (for example, a Hibernate Session). +

Note that transaction synchronizations receive the read-only flag + as argument for the beforeCommit callback, to be able + to suppress change detection on commit. The present method is meant + to be used for earlier read-only checks, for example to set the + flush mode of a Hibernate Session to FlushMode.Never upfront. +

+
+ + true if current transaction read only; otherwise, false. + +
+ + + Gets or sets the name of the current transaction, if any. + + Called by the transaction manager on transaction begin and on cleanup. + To be called by resource management code for optimizations per use case, for + example to optimize fetch strategies for specific named transactions. + The name of the current transactio or null if none set. + + + + Gets or sets a value indicating whether there currently is an actual transaction + active. + + This indicates wheter the current thread is associated with an actual + transaction rather than just with active transaction synchronization. + Called by the transaction manager on transaction begin and on cleanup. + To be called by resource management code that wants to discriminate between + active transaction synchronization (with or without backing resource transaction; + also on PROPAGATION_SUPPORTS) and an actual transaction being active; on + PROPAGATION_REQUIRES, PROPAGATION_REQUIRES_NEW, etC) + + true if [actual transaction active]; otherwise, false. + + + + + Gets or sets the current transaction isolation level, if any. + + Called by the transaction manager on transaction begin and on cleanup. + The current transaction isolation level. If no current transaction is + active, retrun IsolationLevel.Unspecified + + + + Enumeration containing the state of transaction synchronization. + + Griffin Caprio (.NET) + + + + Always activate transaction synchronization, even for "empty" transactions + that result from . + + with no existing backend transaction. + + + + Activate transaction synchronization only for actual transactions, + i.e. not for empty ones that result from . + + with no + existing backend transaction. + + + + Never active transaction synchronization. + + + + + Enumeration of status values when synchronizing transactions. + + Griffin Caprio + + + + Completion status in case of proper commit. + + + + + Completion status in case of proper rollback. + + + + + Completion status in case of heuristic mixed completion or system error. + + + + + Helper class that simplifies programmatic transaction demarcation and + transaction exception handling. + + +

+ The central methods are + + and + supporting transactional code wrapped in the delegate instance. It handles the + transaction lifecycle and possible exceptions such that neither the delegate + implementation nor the calling code needs to explicitly handle transactions. +

+

+ Can be used within a service implementation via direct instantiation with + a transaction manager reference, or get prepared in an application context + and given to services as object reference. +

+ + The transaction manager should always be configured as an object in the application + context, in the first case given to the service directly, in the second case to the + prepared template. + +

+ Supports setting the propagation behavior and the isolation level by name, + for convenient configuration in context definitions. +

+
+ Juergen Hoeller + Mark Pollack (.NET) + Griffin Caprio (.NET) +
+ + + Creates a new instance of the + class. + + +

+ Mainly targeted at configuration by an object factory. +

+ + The + + property must be set before any calls to the + + or + method. + +
+ +
+ + + Creates a new instance of the + class. + + +

+ Mainly targeted at configuration by an object factory. +

+
+ + The transaction management strategy to be used. + +
+ + + Ensures that the + + has been set. + + + + + Executes the the action specified by the given delegate callback within a transaction. + + The delegate that specifies the transactional action. + + A result object returned by the callback, or null if one + + Allows for returning a result object created within the transaction, that is, + a domain object or a collection of domain objects. An exception thrown by the callback + is treated as a fatal exception that enforces a rollback. Such an exception gets + propagated to the caller of the template. + + + In case of initialization or system errors. + + + + + Executes the action specified by the given callback object within a transaction. + + The callback object that specifies the transactional action. + + A result object returned by the callback, or null if one + + Allows for returning a result object created within the transaction, that is, + a domain object or a collection of domain objects. An exception thrown by the callback + is treated as a fatal exception that enforces a rollback. Such an exception gets + propagated to the caller of the template. + + + In case of initialization or system errors. + + + + + Perform a rollback, handling rollback exceptions properly. + + The object representing the transaction. + The thrown application exception or error. + + + + Gets and sets the to + be used. + + + + + Exception thrown when a transaction can't be created using an + underlying transaction API such as COM+. + + Rod Johnson + Griffin Caprio (.NET) + + + + Base class for all transaction exceptions. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the TransactionException class. + + + + + Creates a new instance of the TransactionException class, with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the TransactionException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the TransactionException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception that represents a transaction failure caused by heuristics. + + Rod Johnson + Juergen Hoeller + Griffin Caprio (.NET) + + + + The outcome state of the transaction: have some or all resources been committed? + + + + + Returns a representation of the supplied + . + + + The value that + is to be stringified. + + A representation. + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class + with the specified + and inner exception. + + + The + for the transaction. + + + The inner exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Override of + to allow for private serialization. + + + The + that holds the serialized object data about the exception. + + + The + that contains contextual information about the source or destination. + + + + + Returns the transaction's outcome state. + + + + + Exception thrown when the existence or non-existence of a transaction + amounts to an illegal state according to the transaction propagation + behavior that applies. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception that gets thrown when an invalid isolation level is specified, + i.e. an isolation level that the transaction manager implementation + doesn't support. + + Juergen Hoeller + Griffin Caprio (.NET) + + +
+ Superclass for exceptions caused by inappropriate usage of + a Spring.NET transaction API. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception that gets thrown when an invalid timeout is specified, + for example when the transaction manager implementation doesn't support timeouts. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Invalid timeout value. + + + + + Creates a new instance of the + class + with the specified message and timeout value. + + + A message about the exception. + + The (possibly invalid) timeout value. + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Override of + to allow for private serialization. + + + The + that holds the serialized object data about the exception. + + + The + that contains contextual information about the source or destination. + + + + + Returns the invalid timeout for this exception. + + + + + Exception thrown when attempting to work with a nested transaction + but nested transactions are not supported by the underlying backend. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when an operation is attempted that relies on an existing + transaction (such as setting rollback status) and there is no existing transaction. + This represents an illegal usage of the transaction API. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Represents a transaction's current state. + + Griffin Caprio (.NET) + + + + The transaction state is unknown. + + + + + The transaction has been committed. + + + + + The transaction has been rolled back. + + + + + The transaction is in an unknown, mixed state. + + + + + Enumeration describing Spring.NET's + transaction propagation settings. + + Griffin Caprio (.NET) + + + + Support a current transaction, create a new one if none exists. + + +

+ Analogous to System.EnterpriseServices.TransactionOption value of the same name. + This is typically the default setting of a transaction definition. +

+
+
+ + + Support a current transaction, execute non-transactionally if none exists. + + +

+ Analogous to System.EnterpriseServices.TransactionOption.Supported. +

+
+
+ + + Support a current transaction, throw an exception if none exists. + + +

+ No corresponding System.EnterpriseServices.TransactionOption value. +

+
+
+ + + Create a new transaction, suspending the current transaction if one exists. + + +

+ Analogous to System.EnterpriseServices.TransactionOption value of the same name. +

+
+
+ + + Execute non-transactionally, suspending the current transaction if one exists. + + +

+ Analogous to System.EnterpriseServices.TransactionOption value of the same name. +

+
+
+ + + Execute non-transactionally, throw an exception if a transaction exists. + + +

+ Analogous to System.EnterpriseServices.TransactionOption.Disabled. +

+
+
+ + + Execute within a nested transaction if a current transaction exists, else + behave like . + + +

+ There is no analogous feature in TransactionOption. +

+
+
+ + + Exception thrown when attempting to suspend an existing transaction + but transaction suspension is not supported by the underlying backend. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception thrown when a general transaction system error is encountered, + for instance on commit or rollback. + + Juergen Hoeller + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Exception to be thrown when a transaction has timed out. + + + + + Create a new instance + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Thrown when an attempt to commit a transaction resulted in an unexpected rollback. + + Rod Johnson + Griffin Caprio (.NET) + + + + Creates a new instance of the + class. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Creates a new instance of the + class. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the + class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.dll b/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.dll new file mode 100644 index 0000000000000000000000000000000000000000..a09e91cc69b97ad76e92ec76a6e7244ce12d9eb5 GIT binary patch literal 111616 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 hcz^RtXZ=6$-0T literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.pdb b/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.pdb new file mode 100644 index 0000000000000000000000000000000000000000..5802b7aa87faa98d99dd83103801bb3e23028a68 GIT binary patch literal 331264 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 ?qyGPOt6Ey; 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 z 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%0Dj;(g`~nVvYH%nV2G!wkI09-w zO_0CUI1*|@9jFWSpguH!hHw-#0y$PRhGU=!$eeD+!f|jsWI$7B2F;-bw1g9&6|{yn z&=%zH7TQAx$b^oN1=-LEIzt!e3OUdXKSBhQMhc9~Peu!(cd^0V7}}jDpcH2FAjfa2A{m`7jQ~!vvTJ1uzK;VKPKv z3QUD*Fdb&VOelg`Pz)t78|FYM#6XU*b73Bw1M{IA&V>bV9xQ}Kuo#xWQdkD(!v(M$ zE`*EVVz>l;1;2(Buo8X)m%=Kz3@(Q&U^QF`zlAlh7OsM;;TpIWeh1gV@8Np50d9nw z;AXf5ZiU<6cDMuXguCEwxCicqb+8`pgAH&$JOCTvL3jurhE1>;9)U;UF?bxFfG6Q8 zcp9F8XW=<`9$tVK;U)M3{1IM;SKw864Yt7R@CN(|w!)jR4c>yc;T`xhya(^XU*NCs zK70Tl!r$N{*bX1VC-8Up6#fC9!RPP={1d)}9k3I=f?cp1_Q1d3-|#hj1K+}T@E`ad zet^C3BSfmQ-@_qL4Gx9FK>qgXa5w^LKuxFxM?!6o^SQcE59&h$Xb49^BRCow!!ghV zehJ6Iad13jKvQT2&7lRfgcG0@w1zg&7TQ63=m43J>a>tN7r|m!0!v{T{G5JnfuCF8 T=N9<61%7UUpIhMnZwvev@w=cT literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.xml b/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.xml new file mode 100644 index 00000000..3ea3a32d --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Messaging.Ems.xml @@ -0,0 +1,4922 @@ + + + + Spring.Messaging.Ems + + + + + A Connection object is a client's active connection to TIBCO EMS Server. + + + + + An interface containing all methods and properties on the TIBCO.EMS.Connection class. + Refer to the TIBCO EMS API documentation for more information. + + Mark Pollack + + + + Closes the connection and reclaims resources. + + + + + Creates the session. + + if set to true the session has transaction semantcis. + Indicates whether and how the consumer is to acknowledge received messages. + This version of CreateSession accepts an integer value associated with the acknowledge mode described by a Session member and should only be used for backward compatibility. + This parameter is ignored if the session is transacted. + A newly created session. + + + + Creates the session. + + if set to true [transacted]. + The acknowledge mode. + When true, the new session has transaction semantics. + Indicates whether and how the consumer is to acknowledge received messages. + Legal values are listed under SessionMode. + This parameter is ignored if the session is transacted. + + A newly created session. + + + + Starts (or restarts) a connection's delivery of incoming messages. + + + + + Temporarily stops a connection's delivery of incoming messages. + + + + + A String representation of the connection object + + + A that represents this instance. + + + + + Gets the native TIBCO EMS connection. + + The native connection. + + + + Occurs when the client library detects a problem with the connection. + + + + + Gets the URL of the server this connection is currently connected to + + The active URL. + + + + Gets or sets the client ID. + + The client ID. + + + + Gets the connection ID. + + The connection ID. + + + + Gets or sets the exception listener. + + The exception listener. + + + + Gets a value indicating whether the connection is closed. + + true if the connection is closed; otherwise, false. + + + + Gets a value indicating whether the connection communicates with a secure protocol + + true if the connection communicates with a secure protocol; otherwise, false. + + + + Gets the metadata for this connection + + The metadata for this connection. + + + + Initializes a new instance of the class. + + The underlying TIBCO EMS connection. + + + + Closes the connection and reclaims resources. + + + + + Creates the session. + + if set to true the session has transaction semantcis. + Indicates whether and how the consumer is to acknowledge received messages. + This version of CreateSession accepts an integer value associated with the acknowledge mode described by a Session member and should only be used for backward compatibility. + This parameter is ignored if the session is transacted. + A newly created session. + + + + Creates the session. + + if set to true [transacted]. + The acknowledge mode. + When true, the new session has transaction semantics. + Indicates whether and how the consumer is to acknowledge received messages. + Legal values are listed under SessionMode. + This parameter is ignored if the session is transacted. + A newly created session. + + + + Starts (or restarts) a connection's delivery of incoming messages. + + + + + Temporarily stops a connection's delivery of incoming messages. + + + + + Gets the native TIBCO EMS connection. + + The native connection. + + + + Occurs when the client library detects a problem with the connection. + + + + + Gets the URL of the server this connection is currently connected to + + The active URL. + + + + Gets or sets the client ID. + + The client ID. + + + + Gets the connection ID. + + The connection ID. + + + + Gets or sets the exception listener. + + The exception listener. + + + + Gets a value indicating whether the connection is closed. + + + true if the connection is closed; otherwise, false. + + + + + Gets a value indicating whether the connection communicates with a secure protocol + + + true if the connection communicates with a secure protocol; otherwise, false. + + + + + Gets the metadata for this connection + + The metadata for this connection. + + + + An interface containing all methods and properties on the TIBCO.EMS.ConnectionFactory class. + Refer to the TIBCO EMS API documentation for more information. + + + All the 'GetXXX()' methods in the TIBCO.EMS.ConnectionFactory were translated to .NET properties + + Mark Pollack + + + + Creates the connection. + + The newly created connection + + + + Creates the connection with the given username and password + + Name of the user. + The password. + + + + + Gets the native TIBCO EMS connection factory. + + The native connection factory. + + + + Gets the certificate store info object associated with this connection factory. + + The certificate store. + + + + Gets or sets the SSL proxy host. + + The SSL proxy host. + + + + Gets or sets the SSL proxy port. + + The SSL proxy port. + + + + Gets the SSL proxy password. + + The SSL proxy password. + + + + Gets the SSL proxy user. + + The SSL proxy user. + + + + Sets the type of the certificate store. + + The type of the certificate store. + + + + Sets the client ID. + + The client ID. + + + + Sets the client tracer to a given output stream + + The client tracer. + + + + Sets the number of connection attempts + + The number of connection attempts. + + + + Sets delay between connection attempts + + The delay between connection attempts. + + + + Sets the connection attempt timeout. + + The connection attempt timeout. + + + + Sets the custom host name verifier. Set to null to remove custom host name verifier. + + The host name verifier. + + + + Sets the load balance metric as an integer. + + The load balance metric as int. + + + + Sets the port on which the client will connect to the multicast daemon. + + The multicast daemon port. + + + + Sets whether MessageConsumers subscribed to a multicast-enabled topic will receive messages over multicast. + + true to enable multicast; false to disable. + + + + Gets or sets the the default length of time in milliseconds from its dispatch time + that a produced message should be retained by the message system. + + Time to live is set to zero by default. + The message time to live in milliseconds; zero is unlimited + + + + Market interface for EMS SSL store types + + + + + Namespace parser for the EMS namespace. + + Mark Fisher + Juergen Hoeller + Mark Pollack (.NET) + + + + Register a MessageListenerContainer for the 'listener-container' tag. + + + + + Parser for the EMS <listener-container> element. + + Mark Fisher + Juergen Hoeller + Mark Pollack (.NET) + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + The element to be parsed. + TThe object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + The primary object definition. + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+
+ + + EMS MessageConsumer decorator that adapts all calls + to a shared MessageConsumer instance underneath. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The target. + + + + Receives the next message produced for this message consumer. + + the next message produced for this message consumer, , or null if this message consumer is concurrently closed + + + + Receives the next message that arrives within the specified timeout interval. + + The timeout value. + the next message produced for this message consumer, or null if the timeout expires or this message consumer is concurrently closed + + + + Receives the next message if one is immediately available. + + the next message produced for this message consumer, or null if one is not available + + + + No-op implementation since it is caching. + + + + + Description that shows this is a cached MessageConsumer + + Description that shows this is a cached MessageConsumer + + + + Gets the target MessageConsumer, the consumer we are 'wrapping' + + The target MessageConsumer. + + + + Occurs when a message is received. + + + + + MessageProducer decorator that adapts calls to a shared MessageProducer + instance underneath, managing QoS settings locally within the decorator. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The target. + + + + Sends the specified message. + + The message. + + + + Sends the specified message. + + The message. + The delivery mode. + The priority. + The time to live. + + + + Sends a message to the specified destination. + + The destination. + The message. + + + + Reset properties. + + + + + Returns string indicated this is a wrapped MessageProducer + + + + + + Gets or sets a value indicating whether disable setting of the message ID property. + + true if disable message ID setting; otherwise, false. + + + + Gets or sets a value indicating whether disable setting the message timestamp property. + + + true if disable message timestamp; otherwise, false. + + + + + Gets or sets the producer's default delivery mode. + + The message delivery mode for this message producer + + + + Gets or sets the MSG delivery mode. + + The MSG delivery mode. + + + + Gets or sets the priority of messages sent with this producer. + + The priority. + + + + Gets or sets the the default length of time in milliseconds from its dispatch time + that a produced message should be retained by the message system. + + Time to live is set to zero by default. + The message time to live in milliseconds; zero is unlimited + + + + Gets the target MessageProducer, the producer we are 'wrapping' + + The target MessageProducer. + + + + Wrapper for Session that caches producers and registers itself as available + to the session cache when being closed. Generally used for testing purposes or + if need to get at the wrapped Session object via the TargetSession property (for + vendor specific methods). + + Juergen Hoeller + Mark Pollack + + + + Subinterface of Session to be implemented by + implementations that wrap an Session to provide added + functionality. Allows access to the the underlying target Session. + + Mark Pollack + + + + + + Gets the target session of the decorator. + This will typically be the native provider Session or a wrapper from a session pool. + + The underlying session, never null + + + + Initializes a new instance of the class. + + The target session. + The session list. + The CachingConnectionFactory. + + + + Creates the producer, potentially returning a cached instance. + + The destination. + A message producer. + + + + If have not yet reached session cache size, cache the session, otherwise + dispose of all cached message producers and close the session. + + + + + Creates the consumer, potentially returning a cached instance. + + The destination. + A message consumer + + + + Creates the consumer, potentially returning a cached instance. + + The destination. + The selector. + A message consumer + + + + Creates the consumer, potentially returning a cached instance. + + The destination. + The selector. + if set to true [no local]. + A message consumer. + + + + Creates the durable consumer, potentially returning a cached instance. + + The destination. + The name of the durable subscription. + The selector. + if set to true [no local]. + A message consumer + + + + Creates the durable consumer, potentially returning a cached instance. + + The destination. + The name of the durable subscription. + A message consumer + + + + Creates the consumer. + + The destination. + The selector. + if set to true [no local]. + The subscription. + + + + + Gets the queue. + + The name. + + + + + Gets the topic. + + The name. + + + + + Creates the temporary queue. + + + + + + Creates the temporary topic. + + + + + + Creates the message. + + + + + + Creates the text message. + + + + + + Creates the text message. + + The text. + + + + + Creates the map message. + + + + + + Creates the bytes message. + + + + + + Creates the object message. + + + + + + Creates the object message. + + The body. + + + + + Creates the stream message. + + + + + + Commits this instance. + + + + + Rollbacks this instance. + + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Gets the target, for testing purposes. + + The target. + + + + Gets a value indicating whether this is transacted. + + true if transacted; otherwise, false. + + + + Gets the acknowledgement mode. + + The acknowledgement mode. + + + + subclass that adds + Session, MessageProducer, and MessageConsumer caching. This ConnectionFactory + also switches the ReconnectOnException property to true + by default, allowing for automatic recovery of the underlying + Connection. + + + By default, only one single Session will be cached, with further requested + Sessions being created and disposed on demand. Consider raising the + SessionCacheSize property in case of a high-concurrency environment. + + NOTE: This ConnectionFactory requires explicit closing of all Sessions + obtained from its shared Connection. This is the usual recommendation for + native EMS access code anyway. However, with this ConnectionFactory, its use + is mandatory in order to actually allow for Session reuse. + + + Note also that MessageConsumers obtained from a cached Session won't get + closed until the Session will eventually be removed from the pool. This may + lead to semantic side effects in some cases. For a durable subscriber, the + logical Session.Close() call will also close the subscription. + Re-registering a durable consumer for the same subscription on the same + Session handle is not supported; close and reobtain a cached Session first. + + + + Juergen Hoeller + Mark Pollack (.NET) + + + + A ConnectionFactory adapter that returns the same Connection + from all CreateConnection() calls, and ignores calls to + Connection.Close(). According to the JMS Connection + model, this is perfectly thread-safe. The + shared Connection can be automatically recovered in case of an Exception. + + + + You can either pass in a specific Connection directly or let this + factory lazily create a Connection via a given target ConnectionFactory. + + + Useful for testing and in applications when you want to keep using the + same Connection for multiple + calls, without having a pooling ConnectionFactory underneath. This may span + any number of transactions, even concurrently executing transactions. + + + Note that Spring's message listener containers support the use of + a shared Connection within each listener container instance. Using + SingleConnectionFactory with a MessageListenerContainer only really makes sense for + sharing a single Connection across multiple listener containers. + + + Juergen Hoeller + Mark Pollack + Mark Pollack (.NET) + + + + Wrapped Connection + + + + + Proxy Connection + + + + + Whether the shared Connection has been started + + + + + Synchronization monitor for the shared Connection + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class + that alwasy returns the given Connection. + + The single Connection. + + + + Initializes a new instance of the class + that alwasy returns a single Connection. + + The target connection factory. + + + + Creates the connection. + + A single shared connection + + + + Creates the connection. + + Name of the user. + The password. + + + + + Initialize the underlying shared Connection. Closes and reinitializes the Connection if an underlying + Connection is present already. + + + + + Exception listener callback that renews the underlying single Connection. + + The exception from the messaging infrastructure. + + + + Prepares the connection before it is exposed. + The default implementation applies ExceptionListener and client id. + Can be overridden in subclasses. + + The Connection to prepare. + if thrown by any EMS API methods. + + + + Template method for obtaining a (potentially cached) Session. + + The connection to operate on. + The session ack mode. + the Session to use, or null to indicate + creation of a raw standard Session + + + + reate a JMS Connection via this template's ConnectionFactory. + + + + + + Closes the given connection. + + The connection. + + + + Ensure that the connection or TargetConnectionFactory are specified. + + + + + Close the underlying shared connection. The provider of this ConnectionFactory needs to care for proper shutdown. + As this object implements an application context will automatically + invoke this on distruction o + + + + + Resets the underlying shared Connection, to be reinitialized on next access. + + + + + Wrap the given Connection with a proxy that delegates every method call to it + but suppresses close calls. This is useful for allowing application code to + handle a special framework Connection just like an ordinary Connection from a + ConnectionFactory. + + The original connection to wrap. + the wrapped connection + + + + Gets or sets the target connection factory which will be used to create a single + connection. + + The target connection factory. + + + + Sets the exception listener. + + The exception listener. + + + + Gets or sets a value indicating whether the single Connection + should be reset (to be subsequently renewed) when a EMSException + is reported by the underlying Connection. + + + Default is false. Switch this to true + to automatically trigger recover based on your messaging provider's + exception notifications. + + Internally, this will lead to a special ExceptionListener (this + SingleConnectionFactory itself) being registered with the underlying + Connection. This can also be combined with a user-specified + ExceptionListener, if desired. + + + + true attempt to reconnect on exception during next access; otherwise, false. + + + + + Gets the connection monitor. + + The connection monitor. + + + + Gets a value indicating whether this instance is started. + + + true if this instance is started; otherwise, false. + + + + + Gets the client id. + + The client id. + + + + Initializes a new instance of the class. + and sets the ReconnectOnException to true + + + + + Initializes a new instance of the class for the given + IConnectionFactory + + The target connection factory. + + + + Resets the Session cache as well as resetting the connection. + + + + + Obtaining a cached Session. + + The connection to operate on. + The session ack mode. + The Session to use + + + + + Wraps the given Session so that it delegates every method call to the target session but + adapts close calls. This is useful for allowing application code to + handle a special framework Session just like an ordinary Session. + + The original Session to wrap. + The List of cached Sessions that the given Session belongs to. + The wrapped Session + + + + Gets or sets the size of the session cache. + + + This cache size is the maximum limit for the number of cached Sessions + per session acknowledgement type (auto, client, dups_ok, transacted). + As a consequence, the actual number of cached Sessions may be up to + four times as high as the specified value - in the unlikely case + of mixing and matching different acknowledgement types. + + Default is 1: caching a single Session, (re-)creating further ones on + demand. Specify a number like 10 if you'd like to raise the number of cached + Sessions; that said, 1 may be sufficient for low-concurrency scenarios. + + + The size of the session cache. + + + + Gets or sets a value indicating whether to cache MessageProducers per + Session instance. (more specifically: one MessageProducer per Destination + and Session). + + + Default is "true". Switch this to "false" in order to always, + recreate MessageProducers on demand. + + + true if should cache message producers; otherwise, false. + + + + Gets or sets a value indicating whether o cache JMS MessageConsumers per + EMS Session instance. + + + Mmore specifically: one MessageConsumer per Destination, selector String + and Session. Note that durable subscribers will only be cached until + logical closing of the Session handle. + + Default is "true". Switch this to "false" in order to always + recreate MessageConsumers on demand. + + + true to cache consumers per session instance; otherwise, false. + + + + Gets or sets a value indicating whether this instance is active. + + true if this instance is active; otherwise, false. + + + + Implementation of Spring IExceptionListener interface that supports + chaining allowing the addition of multiple ExceptionListener instances in order. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Adds the exception listener to the chain + + The listener. + + + + Called when an exception occurs in message processing. + + The exception. + + + + Gets the exception listeners as an array. + + The exception listeners. + + + Helper class for obtaining transactional EMS resources + for a given ConnectionFactory. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Releases the given connection, stopping it (if necessary) and eventually closing it. + + Checks , if available. + This is essentially a more sophisticated version of + + + The connection to release. (if this is null, the call will be ignored) + The ConnectionFactory that the Connection was obtained from. (may be null) + whether the Connection might have been started by the application. + + + + Return the innermost target Session of the given Session. If the given + Session is a decorated session, it will be unwrapped until a non-decorated + Session is found. Otherwise, the passed-in Session will be returned as-is. + + The session to unwrap + The innermost target Session, or the passed-in one if no decorator + + + + Determines whether the given JMS Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The session to check. + The ConnectionFactory that the Session originated from + + true if is session transactional, bound to current thread; otherwise, false. + + + + Obtain a EMS Session that is synchronized with the current transaction, if any. + the ConnectionFactory to obtain a Session for + + the existing EMS Connection to obtain a Session for + (may be null) + + whether to allow for a local EMS transaction + that is synchronized with a Spring-managed transaction (where the main transaction + might be a ADO.NET-based one for a specific DataSource, for example), with the EMS + transaction committing right after the main transaction. If not allowed, the given + ConnectionFactory needs to handle transaction enlistment underneath the covers. + + the transactional Session, or null if none found + + EMSException in case of EMS failure + + + + Obtain a EMS Session that is synchronized with the current transaction, if any. + + the TransactionSynchronizationManager key to bind to + (usually the ConnectionFactory) + the ResourceFactory to use for extracting or creating + EMS resources + whether the underlying Connection approach should be + started in order to allow for receiving messages. Note that a reused Connection + may already have been started before, even if this flag is false. + + the transactional Session, or null if none found + + EMSException in case of EMS failure + + + Callback interface for resource creation. + Serving as argument for the DoGetTransactionalSession method. + + + + Fetch an appropriate Session from the given EmsResourceHolder. + the EmsResourceHolder + + an appropriate Session fetched from the holder, + or null if none found + + + + Fetch an appropriate Connection from the given EmsResourceHolder. + the EmsResourceHolder + + an appropriate Connection fetched from the holder, + or null if none found + + + + Create a new EMS Connection for registration with a EmsResourceHolder. + the new EMS Connection + + EMSException if thrown by EMS API methods + + + Create a new EMS Session for registration with a EmsResourceHolder. + the EMS Connection to create a Session for + + the new EMS Session + + EMSException if thrown by EMS API methods + + + + Return whether to allow for a local EMS transaction that is synchronized with + a Spring-managed transaction (where the main transaction might be a ADO.NET-based + one for a specific IDbProvider, for example), with the EMS transaction + committing right after the main transaction. + Returns whether to allow for synchronizing a local EMS transaction + + + + + Callback for resource cleanup at the end of a non-native EMS transaction + + + + Connection holder, wrapping a EMS Connection and a EMS Session. + EmsTransactionManager binds instances of this class to the thread, + for a given EMS ConnectionFactory. + +

Note: This is an SPI class, not intended to be used by applications.

+ +
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + Create a new EmsResourceHolder that is open for resources to be added. + + + + Initializes a new instance of the class + at is open for resources to be added. + + The connection factory that this + resource holder is associated with (may be null) + + + + + Initializes a new instance of the class for the + given Session. + + The session. + + + Create a new EmsResourceHolder for the given EMS resources. + the EMS Connection + + the EMS Session + + + + + Initializes a new instance of the class. + + The connection factory. + The connection. + The session. + + + + Adds the connection to the list of resources managed by this holder. + + The connection. + + + + Adds the session to the list of resources managed by this holder. + + The session. + + + + Adds the session and connection to the list of resources managed by this holder. + + The session. + The connection. + + + + Gets the connection managed by this resource holder + + A Connection, or null if no managed connection. + + + + Gets the connection of a given type managed by this resource holder. This is used + when storing Queue or Topic Connections (from the older 1.0.2 API) as compared to the + 'unified domain' API , just Connection, in the newer 1.2 API. + + Type of the connection. + The connection, or null if not found. + + + + Gets the first session manged by this holder or null if not available. + + The session or null if not available. + + + + Gets the session managed by this holder by type. + + Type of the session. + The session or null if not available. + + + + Gets the session of a given type associated with the given connection + + Type of the session. + The connection. + The sessin or null if not available. + + + + Commits all sessions. + + + + + Closes all sessions then stops and closes all connections, in that order. + + + + + Determines whether the holder contains the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Gets a value indicating whether this is frozen, namely that + additional resources can be registered with the holder. If using any of the constructors with + a Session, the holder will be set to the frozen state. + + true if frozen; otherwise, false. + + + + A implementation + for a single EMS ConnectionFactory. Binds a + Connection/Session pair from the specified ConnecctionFactory to the thread, + potentially allowing for one thread-bound Session per ConnectionFactory. + + + + Application code is required to retrieve the transactional Session via + . Spring's + will autodetect a thread-bound Session and + automatically participate in it. + + + Transaction synchronization is turned off by default, as this manager might be used + alongside an IDbProvider based Spring transaction manager such as the + AdoPlatformTransactionManager, which has stronger needs for synchronization. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + The ConnectionFactory has to be set before using the instance. + This constructor can be used to prepare a EmsTemplate via a ApplicationContext, + typically setting the ConnectionFactory via ConnectionFactory property. + + Turns off transaction synchronization by default, as this manager might + be used alongside a dbprovider-based Spring transaction manager like + AdoPlatformTransactionManager, which has stronger needs for synchronization. + Only one manager is allowed to drive synchronization at any point of time. + + + + + + Initializes a new instance of the class + given a ConnectionFactory. + + The connection factory to obtain connections from. + + + + Make sure the ConnectionFactory has been set. + + + + + Get the EmsTransactionObject. + + he EmsTransactionObject. + + + + Begin a new transaction with the given transaction definition. + + Transaction object returned by + . + instance, describing + propagation behavior, isolation level, timeout etc. + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + Transaction object returned by + . + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + Transaction object returned by + . + The object that holds suspended resources as returned by + . + Transaction synchronization will be resumed afterwards. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + + In the case of system errors. + + + + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + Called after + and + + execution on any outcome. + + + + + + Check if the given transaction object indicates an existing transaction + (that is, a transaction which has already started). + + Transaction object returned by + . + + True if there is an existing transaction. + + + In the case of system errors. + + + + + Creates the connection via thie manager's ConnectionFactory. + + The new Connection + If thrown by underlying messaging APIs + + + + Creates the session for the given Connection + + The connection to create a Session for. + the new Session + If thrown by underlying messaging APIs + + + + Gets or sets the connection factory that this instance should manage transaction. + for. + + The connection factory. + + + + Gets the resource factory that this transaction manager operates on, + In tihs case the ConnectionFactory + + The ConnectionFactory. + + + + EMS Transaction object, representing a EmsResourceHolder. + Used as transaction object by EMSTransactionManager + + + + + Extension of the IConnectionFactory interface, + indicating how to release Connections obtained from it. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Shoulds we stop the connection, obtained from this ConnectionFactory? + + The connection to check. + wheter a stop call is necessary + + + + Internal chained ExceptionListener for handling the internal recovery listener + in combination with a user-specified listener. + + + + + Add information to show this is a shared EMS connection + + Description of connection wrapper + + + Exception thrown when a synchronized local transaction failed to complete + (after the main transaction has already completed). + + Jergen Hoeller + Mark Pollack (.NET) + + + + Creates a new instance of the SynchedLocalTransactionFailedException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the SynchedLocalTransactionFailedException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Delegate callback for browsing the messages in an EMS queue. + + + + + Convenient super class for application classes that need EMS access. + + + Requires a ConnectionFactory or a EmsTemplate instance to be set. + It will create its own EmsTemplate if a ConnectionFactory is passed in. + A custom EmsTemplate instance can be created for a given ConnectionFactory + through overriding the createEmsTemplate method. + + + + + + Creates a EmsTemplate for the given ConnectionFactory. + + Only invoked if populating the gateway with a ConnectionFactory reference. + Can be overridden in subclasses to provide a different EmsTemplate instance + + + The connection factory. + + + + + Ensures that the JmsTemplate is specified and calls . + + + + + Subclasses can override this for custom initialization behavior. + Gets called after population of this instance's properties. + + + + + Gets or sets the EMS template for the gateway. + + The EMS template. + + + + Gets or sets he EMS connection factory to be used by the gateway. + Will automatically create a EmsTemplate for the given ConnectionFactory. + + The connection factory. + + + Helper class that simplifies EMS access code. + + If you want to use dynamic destination creation, you must specify + the type of EMS destination to create, using the "pubSubDomain" property. + For other operations, this is not necessary. + Point-to-Point (Queues) is the default domain. + + Default settings for EMS Sessions is "auto-acknowledge". + + This template uses a DynamicDestinationResolver and a SimpleMessageConverter + as default strategies for resolving a destination name or converting a message, + respectively. + + + Mark Pollack + Juergen Hoeller + Mark Pollack (.NET) + + + Base class for EmsTemplate} and other + EMS-accessing gateway helpers, adding destination-related properties to + EmsAccessor's common properties. + + +

Not intended to be used directly. See EmsTemplate.

+ +
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + Base class for EmsTemplate and other EMS-accessing gateway helpers + It defines common properties like the ConnectionFactory}. The subclass + EmsDestinationAccessor adds further, destination-related properties. + + Not intended to be used directly. See EmsTemplate. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Verify that ConnectionFactory property has been set. + + + + + Creates the connection via the ConnectionFactory. + + + + + + Creates the session for the given Connection + + The connection to create a session for. + The new session + + + + Returns whether the Session is in client acknowledgement mode. + + The session to check. + true if in client ack mode, false otherwise + + + + Gets or sets the connection factory to use for obtaining EMS Connections. + + The connection factory. + + + + Gets or sets the session acknowledge mode for EMS Sessions including whether or not the session is transacted + + + Set the EMS acknowledgement mode that is used when creating a EMS + Session to send a message. The default is AUTO_ACKNOWLEDGE. + + The session acknowledge mode. + + + + Set the transaction mode that is used when creating a EMS Session. + Default is "false". + + + Setting this flag to "true" will use a short local EMS transaction + when running outside of a managed transaction, and a synchronized local + EMS transaction in case of a managed transaction being present. + The latter has the effect of a local EMS + transaction being managed alongside the main transaction (which might + be a native ADO.NET transaction), with the EMS transaction committing + right after the main transaction. + + + + + + Resolves the given destination name to a EMS destination. + + The current session. + Name of the destination. + The located Destination + If resolution failed. + + + + Gets or sets the destination resolver that is to be used to resolve + Destination references for this accessor. + + The default resolver is a DynamicDestinationResolver. Specify a + JndDestinationResolver for resolving destination names as JNDI locations. + + The destination resolver. + + + + Gets or sets a value indicating whether Publish/Subscribe + domain (Topics) is used. Otherwise, the Point-to-Point domain + (Queues) is used. + + + this + setting tells what type of destination to create if dynamic destinations are enabled. + true if Publish/Subscribe domain; otherwise, false + for the Point-to-Point domain. + + + Specifies a basic set of EMS operations. + + +

Implemented by EmsTemplate. Not often used but a useful option + to enhance testability, as it can easily be mocked or stubbed.

+ +

Provides EmsTemplate's send(..) and + receive(..) methods that mirror various EMS API methods. + See the EMS specification and EMS API docs for details on those methods. +

+
+ Mark Pollack + Juergen Hoeller + Mark Pollack (.NET) +
+ + Execute the action specified by the given action object within + a EMS Session. + + delegate that exposes the session + the result object from working with the session + + If there is any problem accessing the EMS API + + + Execute the action specified by the given action object within + a EMS Session. + + callback object that exposes the session + + the result object from working with the session + + If there is any problem accessing the EMS API + + + Send a message to a EMS destination. The callback gives access to + the EMS session and MessageProducer in order to do more complex + send operations. + + callback object that exposes the session/producer pair + + the result object from working with the session + + EMSException if there is any problem + + + Send a message to a EMS destination. The callback gives access to + the EMS session and MessageProducer in order to do more complex + send operations. + + delegate that exposes the session/producer pair + + the result object from working with the session + + If there is any problem accessing the EMS API + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ callback to create a message + + If there is any problem accessing the EMS API +
+ + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the destination to send this message to + + callback to create a message + + If there is any problem accessing the EMS API + + + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + callback to create a message + + If there is any problem accessing the EMS API + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ delegate callback to create a message + + If there is any problem accessing the EMS API +
+ + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the destination to send this message to + + delegate callback to create a message + + If there is any problem accessing the EMS API + + + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + delegate callback to create a message + + If there is any problem accessing the EMS API + + + Send the given object to the default destination, converting the object + to a EMS message with a configured IMessageConverter. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + If there is any problem accessing the EMS API +
+ + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. + + the destination to send this message to + + the object to convert to a message + + If there is any problem accessing the EMS API + + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message + + If there is any problem accessing the EMS API + + + Send the given object to the default destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + the callback to modify the message + + If there is any problem accessing the EMS API +
+ + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + + the object to convert to a message + + the callback to modify the message + + If there is any problem accessing the EMS API + + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message. + + the callback to modify the message + + If there is any problem accessing the EMS API + + + + Send the given object to the default destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + the callback to modify the message + If there is any problem accessing the EMS API +
+ + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + the object to convert to a message + the callback to modify the message + If there is any problem accessing the EMS API + + + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + the object to convert to a message. + the callback to modify the message + If there is any problem accessing the EMS API + + + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + + Browses messages in the default EMS queue. The callback gives access to the EMS + Session and QueueBrowser in order to browse the queue and react to the contents. + + The action callback object that exposes the session/browser pair. + the result object from working with the session + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The action callback object that exposes the session/browser pair. + the result object from working with the session + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The action callback object that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The EMS message selector expression (or null if none). + The action callback object that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The EMS message selector expression (or null if none). + The action callback object that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The EMS message selector expression (or null if none). + The action callback object that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Browses messages in the default EMS queue. The callback gives access to the EMS + Session and QueueBrowser in order to browse the queue and react to the contents. + + The action callback delegate that exposes the session/browser pair. + the result object from working with the session + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The action callback delegate that exposes the session/browser pair. + the result object from working with the session + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The action callback delegate that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The EMS message selector expression (or null if none). + The action callback delegate that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The EMS message selector expression (or null if none). + The action callback delegate that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The EMS message selector expression (or null if none). + The action callback delegate that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Timeout value indicating that a receive operation should + check if a message is immediately available without blocking. + + + + Create a new EmsTemplate. + + Note: The ConnectionFactory has to be set before using the instance. + This constructor can be used to prepare a EmsTemplate via an ObjectFactory, + typically setting the ConnectionFactory. + + + + Create a new EmsTemplate, given a ConnectionFactory. + the ConnectionFactory to obtain Connections from + + + + Initialize the default implementations for the template's strategies: + DynamicDestinationResolver and SimpleMessageConverter. + + + + Execute the action specified by the given action object within a + EMS Session. + + Generalized version of execute(SessionCallback), + allowing the EMS Connection to be started on the fly. +

Use execute(SessionCallback) for the general case. + Starting the EMS Connection is just necessary for receiving messages, + which is preferably achieved through the receive methods.

+
+ callback object that exposes the session + + Start the connection before performing callback action. + + the result object from working with the session + + If there is any problem accessing the EMS API +
+ + Execute the action specified by the given action object within a + EMS Session. + + Generalized version of execute(SessionCallback), + allowing the EMS Connection to be started on the fly. +

Use execute(SessionCallback) for the general case. + Starting the EMS Connection is just necessary for receiving messages, + which is preferably achieved through the receive methods.

+
+ callback object that exposes the session + + Start the connection before performing callback action. + + the result object from working with the session + + If there is any problem accessing the EMS API +
+ + + Extract the content from the given JMS message. + + The Message to convert (can be null). + The content of the message, or null if none + + + Fetch an appropriate Connection from the given EmsResourceHolder. + + the EmsResourceHolder + + an appropriate Connection fetched from the holder, + or null if none found + + + + Fetch an appropriate Session from the given EmsResourceHolder. + + the EmsResourceHolder + + an appropriate Session fetched from the holder, + or null if none found + + + + Create a EMS MessageProducer for the given Session and Destination, + configuring it to disable message ids and/or timestamps (if necessary). +

Delegates to doCreateProducer for creation of the raw + EMS MessageProducer

+
+ the EMS Session to create a MessageProducer for + + the EMS Destination to create a MessageProducer for + + the new EMS MessageProducer + + If there is any problem accessing the EMS API + + + + + + +
+ + + Determines whether the given Session is locally transacted, that is, whether + its transaction is managed by this template class's Session handling + and not by an external transaction coordinator. + + + The Session's own transacted flag will already have been checked + before. This method is about finding out whether the Session's transaction + is local or externally coordinated. + + The session to check. + + true if the session is locally transacted; otherwise, false. + + + + Create a raw EMS MessageProducer for the given Session and Destination. + + If CacheJmsResource is true, then the producer + will be created upon the first invocation and will retrun the same + producer (per destination) on all subsequent calls. + + the EMS Session to create a MessageProducer for + + the EMS Destination to create a MessageProducer for + + the new EMS MessageProducer + + If there is any problem accessing the EMS API + + + Create a EMS MessageConsumer for the given Session and Destination. + + the EMS Session to create a MessageConsumer for + + the EMS Destination to create a MessageConsumer for + + the message selector for this consumer (can be null) + + the new EMS MessageConsumer + + If there is any problem accessing the EMS API + + + + Send the given message. + + The session to operate on. + The destination to send to. + The message creator delegate callback to create a Message. + + + + Send the given message. + + The session to operate on. + The destination to send to. + The message creator callback to create a Message. + + + Send the given EMS message. + the EMS Session to operate on + + the EMS Destination to send to + + callback to create a EMS Message + + delegate callback to create a EMS Message + + If there is any problem accessing the EMS API + + + Actually send the given EMS message. + the EMS MessageProducer to send with + + the EMS Message to send + + If there is any problem accessing the EMS API + + + + Execute the action specified by the given action object within + a EMS Session. + + delegate that exposes the session + + the result object from working with the session + + + Note that the value of PubSubDomain affects the behavior of this method. + If PubSubDomain equals true, then a Session is passed to the callback. + If false, then a Session is passed to the callback.b + + If there is any problem accessing the EMS API + + + Execute the action specified by the given action object within + a EMS Session. +

Note: The value of PubSubDomain affects the behavior of this method. + If PubSubDomain equals true, then a Session is passed to the callback. + If false, then a Session is passed to the callback.

+
+ callback object that exposes the session + + the result object from working with the session + + If there is any problem accessing the EMS API +
+ + Send a message to a EMS destination. The callback gives access to + the EMS session and MessageProducer in order to do more complex + send operations. + + callback object that exposes the session/producer pair + + the result object from working with the session + + If there is any problem accessing the EMS API + + + Send a message to a EMS destination. The callback gives access to + the EMS session and MessageProducer in order to do more complex + send operations. + + delegate that exposes the session/producer pair + + the result object from working with the session + + If there is any problem accessing the EMS API + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ delegate callback to create a message + + If there is any problem accessing the EMS API +
+ + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the destination to send this message to + + delegate callback to create a message + + If there is any problem accessing the EMS API + + + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + delegate callback to create a message + + If there is any problem accessing the EMS API + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ callback to create a message + + If there is any problem accessing the EMS API +
+ + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the destination to send this message to + + callback to create a message + + If there is any problem accessing the EMS API + + + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the destination to send this message to + + callback to create a message + + If there is any problem accessing the EMS API + + + Send the given object to the default destination, converting the object + to a EMS message with a configured IMessageConverter. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + If there is any problem accessing the EMS API +
+ + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. + + the destination to send this message to + + the object to convert to a message + + If there is any problem accessing the EMS API + + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message + + If there is any problem accessing the EMS API + + + Send the given object to the default destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + the callback to modify the message + + If there is any problem accessing the EMS API +
+ + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + + the object to convert to a message + + the callback to modify the message + + If there is any problem accessing the EMS API + + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message. + + the callback to modify the message + + If there is any problem accessing the EMS API + + + + Send the given object to the default destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + the callback to modify the message + If there is any problem accessing the EMS API +
+ + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + the object to convert to a message + the callback to modify the message + If there is any problem accessing the EMS API + + + + Send the given object to the specified destination, converting the object + to a EMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + the object to convert to a message. + the callback to modify the message + If there is any problem accessing the EMS API + + + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + If there is any problem accessing the EMS API +
+ + + Receive a message. + + The session to operate on. + The destination to receive from. + The message selector for this consumer (can be null + The Message received, or null if none. + + + + Receive a message. + + The session to operate on. + The consumer to receive with. + The Message received, or null if none + + + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the EMS message selector expression (or null if none). + See the EMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + If there is any problem accessing the EMS API +
+ + + Browses messages in the default EMS queue. The callback gives access to the EMS + Session and QueueBrowser in order to browse the queue and react to the contents. + + The action callback object that exposes the session/browser pair. + the result object from working with the session + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The action callback object that exposes the session/browser pair. + the result object from working with the session + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The action callback object that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The EMS message selector expression (or null if none). + The action callback object that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The EMS message selector expression (or null if none). + The action callback object that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The EMS message selector expression (or null if none). + The action callback object that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Browses messages in the default EMS queue. The callback gives access to the EMS + Session and QueueBrowser in order to browse the queue and react to the contents. + + The action callback delegate that exposes the session/browser pair. + the result object from working with the session + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The action callback delegate that exposes the session/browser pair. + the result object from working with the session + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The action callback delegate that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The EMS message selector expression (or null if none). + The action callback delegate that exposes the session/browser pair. + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + The queue to browse. + The EMS message selector expression (or null if none). + The action callback delegate that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Browses messages in a EMS queue. The callback gives access to the EMS Session + and QueueBrowser in order to browse the queue and react to the contents. + + Name of the queue to browse, + (to be resolved to an actual destination by a DestinationResolver) + The EMS message selector expression (or null if none). + The action callback delegate that exposes the session/browser pair. + + If there is any problem accessing the EMS API + + + + Creates the queue browser. + + The session. + The queue. + The selector. + A new queue browser + + + + Gets or sets the default destination to be used on send/receive operations that do not + have a destination parameter. + + Alternatively, specify a "defaultDestinationName", to be + dynamically resolved via the DestinationResolver. + The default destination. + + + + Gets or sets the name of the default destination name + to be used on send/receive operations that + do not have a destination parameter. + + + Alternatively, specify a EMS Destination object as "DefaultDestination" + + The name of the default destination. + + + + Gets or sets the message converter for this template. + + + Used to resolve + Object parameters to convertAndSend methods and Object results + from receiveAndConvert methods. +

The default converter is a SimpleMessageConverter, which is able + to handle BytesMessages, TextMessages and ObjectMessages.

+
+ The message converter. +
+ + + Gets or sets a value indicating whether Message Ids are enabled. + + true if message id enabled; otherwise, false. + + + + Gets or sets a value indicating whether message timestamps are enabled. + + + true if [message timestamp enabled]; otherwise, false. + + + + + Gets or sets a value indicating whether to inhibit the delivery of messages published by its own connection. + + + true if inhibit the delivery of messages published by its own connection; otherwise, false. + + + + Gets or sets the receive timeout to use for recieve calls. + + The default is -1, which means no timeout. + The receive timeout. + + + + Gets or sets a value indicating whether to use explicit Quality of Service values. + + If "true", then the values of deliveryMode, priority, and timeToLive + will be used when sending a message. Otherwise, the default values, + that may be set administratively, will be used + true if use explicit QoS values; otherwise, false. + + + + Sets a value indicating the delivery mode QOS + + + This will set the delivery to persistent, non-persistent, or reliable delivery. + Default value is Message.DEFAULT_DELIVERY_MODE (aka TIBCO.EMS.DeliveryMode.PERSISTENT) + + Integer value representing the delivery mode [delivery persistent]; otherwise, false. + + + + Gets or sets the priority when sending. + + Since a default value may be defined administratively, + this is only used when "isExplicitQosEnabled" equals "true". + The priority. + + + + Gets or sets the time to live when sending + + Since a default value may be defined administratively, + this is only used when "isExplicitQosEnabled" equals "true". + The time to live. + + + + ResourceFactory implementation that delegates to this template's callback methods. + + + + Callback for executing any number of operations on a provided + Session + + +

To be used with the EmsTemplate.Execute(ISessionCallback)} + method, often implemented as an anonymous inner class.

+
+ Mark Pollack + + +
+ + Execute any number of operations against the supplied EMS + Session, possibly returning a result. + + the EMS Session + + a result object from working with the Session, if any (so can be null) + + EMSException if there is any problem + + + Creates a EMS message given a Session + +

The Session typically is provided by an instance + of the EmsTemplate class.

+
+ Mark Pollack +
+ + Create a Message to be sent. + the EMS Session to be used to create the + Message (never null) + + the Message to be sent + + EMSException if thrown by EMS API methods + + + + This is a TIBCO specific class so that we can reuse connections, session, and + message producers instead of creating/destroying them on each operation. + + + + + Callback for browsing the messages in an EMS queue. + + + To be used with EmsTemplate's callback methods that take a IBrowserCallback argument + + Juergen Hoeller + Mark Pollack (.NET) + + + + Perform operations on the given Session and QueueBrowser + + The session. + The browser. + The object from working with the Session and QueueBrowser, may be null + If there is any problem when accessing EMS API + + + To be used with EmsTemplate's send method that + convert an object to a message. + + + It allows for further modification of the message after it has been processed + by the converter. This is useful for setting of EMS Header and Properties. + + Mark Pollack + + + Apply a IMessagePostProcessor to the message. The returned message is + typically a modified version of the original. + + the EMS message from the IMessageConverter + + the modified version of the Message + + EMSException if thrown by EMS API methods + + + Callback for sending a message to a EMS destination. + +

To be used with the EmsTemplate.Execute(IProducerCallback) + method, often implemented as an anonymous inner class.

+ +

The typical implementation will perform multiple operations on the + supplied EMS Session and MessageProducer.

+
+ Mark Pollack +
+ + Perform operations on the given Session and MessageProducer. + The message producer is not associated with any destination. + + the EMS Session object to use + + the EMS MessageProducer object to use + + a result object from working with the Session, if any (can be null) + + + + + Delegate that creates a EMS message given a Session + + the EMS Session to be used to create the + Message (never null) + + the Message to be sent + + EMSException if thrown by EMS API methods + + + + Delegate that is used with EmsTemplate's ConvertAndSend method that converts + an object. + + + It allows for further modification of the message after it has been processed + by the converter. This is useful for setting of EMS Header and Properties. + + Mark Pollack + + + Perform operations on the given Session and MessageProducer. + The message producer is not associated with any destination. + + the EMS Session object to use + + the EMS MessageProducer object to use + + a result object from working with the Session, if any (can be null) + + + + + Callback delegate for code that operates on a Session. + + The EMS Session object. + + Allows you to execute any number of operations + on a single ISession, possibly returning a result a result. + + + A result object from working with the Session, if any (so can be null) + + EMSException if there is any problem + Mark Pollack + + + + Convenient superclass to access JndiProperties, JndiContextType or alternatively set the ILookupContext directly. + + Juergen Hoeller + Mark Pollack + + + + Create the JndiLookupContext if it has not been explicitly set. + + + + + Gets or sets the lookup context. + + The lookup context. + + + + Gets or sets the JNDI environment properties. + + The jndi properties. + + + + Gets or sets the type of the jndi context. The default is JndiContextType.JMS + + The type of the jndi context. + + + + The various JNDI Context types. + + + + + Create a tibjmsnaming context to lookup administered object inside the tibjmsnaming server. + + + + + Create a ldap context to lookup administered object in an ldap server. + + + + + Convenient superclass for JNDI-based service locators, + providing configurable lookup of a specific JNDI resource. + + + + Exposes a JndiName property. + + Subclasses may invoke the Lookup method whenever it is appropriate. + Some classes might do this on initialization, while others might do it + on demand. The latter strategy is more flexible in that it allows for + initialization of the locator before the JNDI object is available. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Ensure that the JndiName property is set and create the TIBCO EMS ILookupContext instance. + + + + + Lookups this instance using the JndiName and ExpectedType properties + + The object retrieved from Jndi + + + + Gets or sets the Jndi name to lookup. + + The name of the jndi. + + + + Gets or sets the type that the located JNDI object is supposed + to be assignable to, if any. + + The expected type. + + + + Return the Jndi object + + The Jndi object + + + + Sets the default object to fall back to if the JNDI lookup fails. + Default is none. + + + This can be an arbitrary bean reference or literal value. + It is typically used for literal values in scenarios where the JNDI environment + might define specific config settings but those are not required to be present. + + + The default object to use when lookup fails. + + + + Return type of object retrieved from Jndi or the expected type if the Jndi retrieval + did not succeed. + + Return value of retrieved object + + + + Returns true + + + + + Gets the template object definition that should be used + to configure the instance of the object managed by this factory. + + + + + + A Spring FactoryObject that returns TIBCO.EMS.ILookupContext. Use the returned + ILookupContext to do you lookups at runtime. + + + + Important properties to set are JndiProperties and JndiContexType. JndiContextType is set to + LookupContextFactory.TIBJMS_NAMING_CONT by default. + + To lookup objects at startup time and cache their values, as well as provide a + default value if lookup fail, + + + Mark Pollack + + + + Returns the TIBCO.EMS.ILookupContext + + TIBCO.EMS.ILookupContext + + + + Return typeof(TIBCO.EMS.ILookupContext) + + + + + Returns true + + + + + Exception thrown if a type mismatch is encountered for an object + located in a JNDI environment. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Creates a new instance of the + class. + + + A message about the exception. + + + + + Initializes a new instance of the class + building an explanation text from the given arguments. + + The Jndi name. + Type required type of the lookup. + The actual type that the lookup returned. + + + + Gets the actual type that the lookup returned, if available. + + The actual type that the lookup. + + + + Gets the required type for the lookup, if available. + + The equired type for the lookup + + + + Exception to be thrown when the execution of a listener method failed. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class, with the specified message + + The message. + + + + Initializes a new instance of the class, with the specified message + and root cause exception + + The message. + The inner exception. + + + + Message listener adapter that delegates the handling of messages to target + listener methods via reflection, with flexible message type conversion. + Allows listener methods to operate on message content types, completely + independent from the EMS API. + + + By default, the content of incoming messages gets extracted before + being passed into the target listener method, to let the target method + operate on message content types such as String or byte array instead of + the raw Message. Message type conversion is delegated to a Spring + . By default, a + will be used. (If you do not want such automatic message conversion taking + place, then be sure to set the property + to null.) + + If a target listener method returns a non-null object (typically of a + message content type such as String or byte array), it will get + wrapped in a EMS Message and sent to the response destination + (either the EMS "reply-to" destination or the + specified. + + + The sending of response messages is only available when + using the entry point (typically through a + Spring message listener container). Usage as standard EMS MessageListener + does not support the generation of response messages. + + Consult the reference documentation for examples of method signatures compliant with this + adapter class. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Variant of the standard EMS MessageListener interface, + offering not only the received Message but also the underlying + Session object. The latter can be used to send reply messages, + without the need to access an external Connection/Session, + i.e. without the need to access the underlying ConnectionFactory. + + + Supported by Spring's + as direct alternative to the standard MessageListener interface. + + Juergen Hoeller + Mark Pollack (.NET) + + + Callback for processing a received EMS message. + Implementors are supposed to process the given Message, + typically sending reply messages through the given Session. + + the received EMS message + + the underlying EMS Session + + EMSException if thrown by EMS methods + + + + The default handler method name. + + + + + Initializes a new instance of the class with default settings. + + + + + Initializes a new instance of the class for the given handler object + + The delegate object. + + + + Standard JMS {@link MessageListener} entry point. + Delegates the message to the target listener method, with appropriate + conversion of the message arguments + + + + In case of an exception, the method will be invoked. + Note + Does not support sending response messages based on + result objects returned from listener methods. Use the + entry point (typically through a Spring + message listener container) for handling result objects as well. + + The incoming message. + + + + Spring entry point. + + Delegates the message to the target listener method, with appropriate + conversion of the message argument. If the target method returns a + non-null object, wrap in a EMS message and send it back. + + + The incoming message. + The session to operate on. + + + + Initialize the default implementations for the adapter's strategies. + + + + + Handle the given exception that arose during listener execution. + The default implementation logs the exception at error level. + This method only applies when used as standard EMS MessageListener. + In case of the Spring mechanism, + exceptions get handled by the caller instead. + + + The exception to handle. + + + + Extract the message body from the given message. + + The message. + the content of the message, to be passed into the + listener method as argument + if thrown by EMS API methods + + + + Gets the name of the listener method that is supposed to + handle the given message. + The default implementation simply returns the configured + default listener method, if any. + + The EMS request message. + The converted JMS request message, + to be passed into the listener method as argument. + the name of the listener method (never null) + if thrown by EMS API methods + + + + Handles the given result object returned from the listener method, sending a response message back. + + The result object to handle (never null). + The original request message. + The session to operate on (may be null). + + + + Builds a JMS message to be sent as response based on the given result object. + + The JMS Session to operate on. + The content of the message, as returned from the listener method. + the JMS Message (never null) + If there was an error in message conversion + if thrown by EMS API methods + + + + Post-process the given response message before it will be sent. The default implementation + sets the response's correlation id to the request message's correlation id. + + The original incoming message. + The outgoing JMS message about to be sent. + if thrown by EMS API methods + + + + Determine a response destination for the given message. + + + The default implementation first checks the JMS Reply-To + Destination of the supplied request; if that is not null + it is returned; if it is null, then the configured + default response destination} + is returned; if this too is null, then an + is thrown. + + + The original incoming message. + Tthe outgoing message about to be sent. + The session to operate on. + the response destination (never null) + if thrown by EMS API methods + if no destination can be determined. + + + + Resolves the default response destination into a Destination, using this + accessor's in case of a destination name. + + The session to operate on. + The located destination + + + + Sends the given response message to the given destination. + + The session to operate on. + The destination to send to. + The outgoing message about to be sent. + + + + Post-process the given message producer before using it to send the response. + The default implementation is empty. + + The producer that will be used to send the message. + The outgoing message about to be sent. + + + + Gets or sets the handler object to delegate message listening to. + + + Specified listener methods have to be present on this target object. + If no explicit handler object has been specified, listener + methods are expected to present on this adapter instance, that is, + on a custom subclass of this adapter, defining listener methods. + + The handler object. + + + + Gets or sets the default handler method to delegate to, + for the case where no specific listener method has been determined. + Out-of-the-box value is ("HandleMessage"}. + + The default handler method. + + + + Sets the default destination to send response messages to. This will be applied + in case of a request message that does not carry a "JMSReplyTo" field. + Response destinations are only relevant for listener methods that return + result objects, which will be wrapped in a response message and sent to a + response destination. + + Alternatively, specify a "DefaultResponseQueueName" or "DefaultResponseTopicName", + to be dynamically resolved via the DestinationResolver. + + + The default response destination. + + + + Sets the name of the default response queue to send response messages to. + This will be applied in case of a request message that does not carry a + "EMSReplyTo" field. + Alternatively, specify a JMS Destination object as "defaultResponseDestination". + + The name of the default response destination queue. + + + + Sets the name of the default response topic to send response messages to. + This will be applied in case of a request message that does not carry a + "ReplyTo" field. + Alternatively, specify a JMS Destination object as "defaultResponseDestination". + + The name of the default response destination topic. + + + + Gets or sets the destination resolver that should be used to resolve response + destination names for this adapter. + The default resolver is a . + Specify another implementation, for other strategies, perhaps from a directory service. + + The destination resolver. + + + + Gets or sets the message converter that will convert incoming JMS messages to + listener method arguments, and objects returned from listener + methods back to EMS messages. + + + The default converter is a {@link SimpleMessageConverter}, which is able + to handle BytesMessages}, TextMessages, MapMessages, and ObjectMessages. + + + The message converter. + + + + Internal class combining a destination name and its target destination type (queue or topic). + + + + + Common base class for all containers which need to implement listening + based on a Connection (either shared or freshly obtained for each attempt). + Inherits basic Connection and Session configuration handling from the + base class. + + + This class provides basic lifecycle management, in particular management + of a shared Connection. Subclasses are supposed to plug into this + lifecycle, implementing the as well as + + + + + + Mark Pollack + + + + The monitor object to lock on when performing operations on the connection. + + + + + The monitor object to lock on when performing operations that update the lifecycle of the container. + + + + + Call base class method, then and then + + + + + Validates the configuration of this container. The default implementation + is empty. To be overriden in subclasses. + + + + + Calls when the application context destroys the container instance. + + + + + Initializes this container. Creates a Connection, starts the Connection + (if the property hasn't been turned off), and calls + . + + If startup failed + + + + Stop the shared connection, call , and close this container. + + + + + Starts this container. + + if starting failed. + + + + Start the shared Connection, if any, and notify all invoker tasks. + + + + + Stops this container. + + if stopping failed. + + + + Notify all invoker tasks and stop the shared Connection, if any. + + if thrown by EMS API methods. + + + + + Register any invokers within this container. + Subclasses need to implement this method for their specific + invoker management process. A shared Connection, if any, will already have been + started at this point. + + + + + Close the registered invokers. Subclasses need to implement this method + for their specific invoker management process. A shared Connection, if any, + will automatically be closed afterwards. + + + + + Establishes a shared Connection for this container. + + + + The default implementation delegates to + which does one immediate attempt and throws an exception if it fails. + Can be overridden to have a recovery process in place, retrying + until a Connection can be successfully established. + + + If thrown by EMS API methods + + + + Refreshes the shared connection that this container holds. + + + Called on startup and also after an infrastructure exception + that occurred during invoker setup and/or execution. + + If thrown by EMS API methods + + + + Creates the shared connection for this container. + + + The default implementation creates a standard Connection + and prepares it through + + the prepared Connection + if the creation failed. + + + + Prepares the given connection, which is about to be registered + as shared Connection for this container. + + + The default implementation sets the specified client id, if any. + Subclasses can override this to apply further settings. + + The connection to prepare. + If the preparation efforts failed. + + + + Starts the shared connection. + + If thrown by EMS API methods + + + + + Stops the shared connection. + + if thrown by EMS API methods. + + + + Gets or sets the client id for a shared Connection created and used by this container. + + + Note that client ids need to be unique among all active Connections + of the underlying JMS provider. Furthermore, a client id can only be + assigned if the original ConnectionFactory hasn't already assigned one. + + The client id. + + + Set whether to automatically start the listener after initialization. +

Default is "true"; set this to "false" to allow for manual startup.

+
+
+ + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Gets a value indicating whether this container is currently running, + that is, whether it has been started and not stopped yet. + + + true if this container is running; otherwise, false. + + + + + Gets a value indicating whether this container's listeners are generally allowed to run. + + + + >This implementation always returns true; the default 'running' + state is purely determined by /. + + + Subclasses may override this method to check against temporary + conditions that prevent listeners from actually running. In other words, + they may apply further restrictions to the 'running' state, returning + false if such a restriction prevents listeners from running. + + + true if running allowed; otherwise, false. + + + + Gets a value indicating whether this container is currently active, + that is, whether it has been set up but not shut down yet. + + true if active; otherwise, false. + + + Return whether a shared EMS Connection should be maintained + by this listener container base class. + + + + + + Gets the shared connection maintained by this container. + Available after initialization. + + The shared connection (never null) + if this container does not maintain a + shared Connection, or if the Connection hasn't been initialized yet. + + + + + + Exception that indicates that the initial setup of this container's + shared Connection failed. This is indicating to invokers that they need + to establish the shared Connection themselves on first access. + + + + + Initializes a new instance of the class. + + The message. + + + + Abstract base class for message listener containers. Can either host + a standard EMS MessageListener or a Spring-specific + + + + + + Validate that the destination is not null and that if the subscription is durable, then we are not + using the Pub/Sub domain. + + + + + Executes the specified listener, + committing or rolling back the transaction afterwards (if necessary). + + The session to operate on. + The received message. + + + + + + + + Executes the specified listener, + committing or rolling back the transaction afterwards (if necessary). + + The session to operate on. + The received message. + If thrown by EMS API methods. + + + + + + + Invokes the specified listener: either as standard EMS MessageListener + or (preferably) as Spring ISessionAwareMessageListener. + + The session to operate on. + The received message. + If thrown by EMS API methods. + + + + + Invoke the specified listener as Spring ISessionAwareMessageListener, + exposing a new EMS Session (potentially with its own transaction) + to the listener if demanded. + + The Spring ISessionAwareMessageListener to invoke. + The session to operate on. + The received message. + If thrown by EMS API methods. + + + + + + Invoke the specified listener as standard JMS MessageListener. + + Default implementation performs a plain invocation of the + OnMessage methods + The listener to invoke. + The received message. + if thrown by the EMS API methods + + + + Perform a commit or message acknowledgement, as appropriate + + The session to commit. + The message to acknowledge. + In case of commit failure + + + + Determines whether the given Session is locally transacted, that is, whether + its transaction is managed by this listener container's Session handling + and not by an external transaction coordinator. + + + The Session's own transacted flag will already have been checked + before. This method is about finding out whether the Session's transaction + is local or externally coordinated. + + The session to check. + + true if the is session locally transacted; otherwise, false. + + + + + + Perform a rollback, if appropriate. + + The session to rollback. + In case of a rollback error + + + + Perform a rollback, handling rollback excepitons properly. + + The session to rollback. + The thrown application exception. + in case of a rollback error. + + + + Handle the given exception that arose during listener execution. + + + The default implementation logs the exception at error level, + not propagating it to the JMS provider - assuming that all handling of + acknowledgement and/or transactions is done by this listener container. + This can be overridden in subclasses. + + The exceptin to handle + + + + Invokes the registered exception listener, if any. + + The exception that arose during EMS processing. + + + + + Checks the message listener, throwing an exception + if it does not correspond to a supported listener type. + By default, only a standard JMS MessageListener object or a + Spring object will be accepted. + + The message listener. + + + + Gets or sets the destination to receive messages from. Will be null + if the configured destination is not an actual Destination type; + c.f. when the destination is a String. + + The destination. + + + + Gets or sets the name of the destination to receive messages from. + Will be null if the configured destination is not a + string type; c.f. when it is an actual Destination object. + + The name of the destination. + + + + Gets or sets the message selector. + + The message selector expression (or null if none).. + + + + Gets or sets the message listener to register. + + + + + This can be either a standard EMS MessageListener object or a + Spring object. + + + The message listener. + + + + Gets or sets a value indicating whether the subscription is durable. + + + Set whether to make the subscription durable. The durable subscription name + to be used can be specified through the "DurableSubscriptionName" property. + Default is "false". Set this to "true" to register a durable subscription, + typically in combination with a "DurableSubscriptionName" value (unless + your message listener class name is good enough as subscription name). + + Only makes sense when listening to a topic (pub-sub domain). + + true if the subscription is durable; otherwise, false. + + + + Gets or sets the name of the durable subscription to create. + + + To be applied in case of a topic (pub-sub domain) with subscription durability activated. + The durable subscription name needs to be unique within this client's + client id. Default is the class name of the specified message listener. + Note: Only 1 concurrent consumer (which is the default of this + message listener container) is allowed for each durable subscription. + + + The name of the durable subscription. + + + + Gets or sets the exception listener to notify in case of a EMSException thrown + by the registered message listener or the invocation infrastructure. + + The exception listener. + + + + Sets an ErrorHandler to be invoked in case of any uncaught exceptions thrown + while processing a Message. By default there will be no ErrorHandler + so that error-level logging is the only result. + + The error handler. + + + + Gets or sets a value indicating whether to expose listener session to a registered + as well as to calls. + + + Default is "true", reusing the listener's Session. + Turn this off to expose a fresh Session fetched from the same + underlying Connection instead, which might be necessary + on some messaging providers. + Note that Sessions managed by an external transaction manager will + always get exposed to + calls. So in terms of EmsTemplate exposure, this setting only affects + locally transacted Sessions. + + + + true if expose listener session; otherwise, false. + + + + + Gets or sets a value indicating whether to accept messages while + the listener container is in the process of stopping. + + + + Return whether to accept received messages while the listener container + receive attempt. Switch this flag on to fully process such messages + even in the stopping phase, with the drawback that even newly sent + messages might still get processed (if coming in before all receive + timeouts have expired). + + + Aborting receive attempts for such incoming messages + might lead to the provider's retry count decreasing for the affected + messages. If you have a high number of concurrent consumers, make sure + that the number of retries is higher than the number of consumers, + to be on the safe side for all potential stopping scenarios. + + + + true if accept messages while in the process of stopping; otherwise, false. + + + + + Internal exception class that indicates a rejected message on shutdown. + Used to trigger a rollback for an external transaction manager in that case. + + + + + EmsResourceHolder marker subclass that indicates local exposure, + i.e. that does not indicate an externally managed transaction. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The session. + + + + Exception thrown when the maximum connection recovery time has been exceeded. + + Mark Pollack + + + + Initializes a new instance of the class, with the specified message + + The message. + + + + Initializes a new instance of the class, with the specified message + and root cause exception + + The message. + The inner exception. + + + + Message listener container that uses the plain EMS client API's + MessageConsumer.Listener method to create concurrent + MessageConsumers for the specified listeners. + + Juergen Hoeller + Mark Pollack (.NET) + + + + The default recovery time interval between connection reconnection attempts + + + + + The total time connection recovery will be attempted. + + + + + Call base class for valdation and then check that if the subscription is durable that the number of + concurrent consumers is equal to one. + + + + + Creates the specified number of concurrent consumers, + in the form of a JMS Session plus associated MessageConsumer + + + + + + Re-initializes this container's EMS message consumers, + if not initialized already. + + + + + Registers this listener container as EMS ExceptionListener on the shared connection. + + + + + + implementation, invoked by the EMS provider in + case of connection failures. Re-initializes this listener container's + shared connection and its sessions and consumers. + + The reported connection exception. + + + + Refresh the underlying Connection, not returning before an attempt has been + successful. Called in case of a shared Connection as well as without shared + Connection, so either needs to operate on the shared Connection or on a + temporary Connection that just gets established for validation purposes. + + + The default implementation retries until it successfully established a + Connection, for as long as this message listener container is active. + Applies the specified recovery interval between retries. + + + + + The amount of time to sleep in between recovery attempts. + + + + + Initialize the Sessions and MessageConsumers for this container. + + in case of setup failure. + + + + Creates a MessageConsumer for the given Session, + registering a MessageListener for the specified listener + + The session to work on. + the MessageConsumer"/> + if thrown by EMS methods + + + + Close the message consumers and sessions. + + EMSException if destruction failed + + + + Creates a MessageConsumer for the given Session and Destination. + + The session to create a MessageConsumer for. + The destination to create a MessageConsumer for. + The new MessageConsumer + + + + Gets or sets a value indicating whether to inhibit the delivery of messages published by its own connection. + Default is "false". + + true if should inhibit the delivery of messages published by its own connection; otherwise, false. + + + + Specify the number of concurrent consumers to create. Default is 1. + + + Raising the number of concurrent consumers is recommendable in order + to scale the consumption of messages coming in from a queue. However, + note that any ordering guarantees are lost once multiple consumers are + registered. In general, stick with 1 consumer for low-volume queues. + Do not raise the number of concurrent consumers for a topic. + This would lead to concurrent consumption of the same message, + which is hardly ever desirable. + + + The concurrent consumers. + + + + Sets the time interval between connection recovery attempts. The default is 5 seconds. + + The recovery interval. + + + + Sets the max recovery time to try reconnection attempts. The default is 10 minutes. + + The max recovery time. + + + + Always use a shared EMS connection + + + + Strategy interface that specifies a IMessageConverter + between .NET objects and EMS messages. + + + Mark Pollack + Juergen Hoeller + Mark Pollack (.NET) + + + Convert a .NET object to a EMS Message using the supplied session + to create the message object. + + the object to convert + + the Session to use for creating a EMS Message + + the EMS Message + + EMSException if thrown by EMS API methods + MessageConversionException in case of conversion failure + + + Convert from a EMS Message to a .NET object. + the message to convert + + the converted .NET object + + MessageConversionException in case of conversion failure + + + + Provides a layer of indirection when adding the 'type' of the object as a message property. + + Mark Pollack + + + + Convert from a type to a string. + + The type of object to convert. + + + + + Convert from a string to a type + + The type id. + + + + + Gets the name of the field in the message that has type information.. + + The name of the type id field. + + + Thrown by IMessageConverter implementations when the conversion + of an object to/from a Message fails. + + Mark Pollack + + + + Creates a new instance of the IMessageConverterException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the IMessageConverterException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + A simple message converter that can handle TextMessages, BytesMessages, + MapMessages, and ObjectMessages. Used as default by EmsTemplate, for + ConvertAndSend and ReceiveAndConvert operations. + +

Converts a String to a EMS TextMessage, a byte array to a EMS BytesMessage, + a Map to a EMS MapMessage, and a Serializable object to a EMS ObjectMessage + (or vice versa).

+ + +
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + Convert a .NET object to a EMS Message using the supplied session + to create the message object. + + the object to convert + + the Session to use for creating a EMS Message + + the EMS Message + + EMSException if thrown by EMS API methods + MessageConversionException in case of conversion failure + + + Convert from a EMS Message to a .NET object. + the message to convert + + the converted .NET object + + MessageConversionException in case of conversion failure + + + Create a EMS TextMessage for the given String. + the String to convert + + current EMS session + + the resulting message + + EMSException if thrown by EMS methods + + + Create a EMS BytesMessage for the given byte array. + the byyte array to convert + + current EMS session + + the resulting message + + EMSException if thrown by EMS methods + + + Create a EMS MapMessage for the given Map. + the Map to convert + + current EMS session + + the resulting message + + EMSException if thrown by EMS methods + + + Create a EMS ObjectMessage for the given Serializable object. + the Serializable object to convert + + current EMS session + + the resulting message + + EMSException if thrown by EMS methods + + + Extract a String from the given TextMessage. + the message to convert + + the resulting String + + EMSException if thrown by EMS methods + + + Extract a byte array from the given BytesMessage. + the message to convert + + the resulting byte array + + EMSException if thrown by EMS methods + + + Extract a IDictionary from the given MapMessage. + the message to convert + + the resulting Map + + EMSException if thrown by EMS methods + + + + Extracts the serializable object from the given object message. + + The message to convert. + The resulting serializable object. + + + + Provides a layer of indirection when adding the 'type' of the object as a message property. + + + + + Initializes a new instance of the + + + + + Convert from a type to a string. + + The type of object to convert. + + + + + Convert from a string to a type + + The type id. + + + + + Afters the properties set. + + + + + Gets or sets the id type mapping. + + The id type mapping. + + + + Gets the name of the field in the message that has type information.. + + The name of the type id field. + + + + Sets the default hashtable class. + + The default hashtable class. + + + + Gets or sets the default namespace. + + The default namespace. + + + + Gets or sets the default name of the assembly. + + The default name of the assembly. + + + + Convert an object via XML serialization for sending via an ITextMessage + + Mark Pollack + + + + Convert a .NET object to a EMS Message using the supplied session + to create the message object. + + the object to convert + the Session to use for creating a EMS Message + the EMS Message + EMSException if thrown by EMS API methods + MessageConversionException in case of conversion failure + + + + Gets the XML string for an object + + The object to convert. + XML string + + + + Convert from a EMS Message to a .NET object. + + the message to convert + the converted .NET object + MessageConversionException in case of conversion failure + + + + Gets the type of the target given the message. + + The message. + Type of the target + + + + Converts a byte array to a UTF8 string. + + The characters. + UTF8 string + + + + Converts a UTF8 string to a byte array + + The p XML string. + + + + + Sets the type mapper. + + The type mapper. + + + + Gets or sets a value indicating whether encoder should emit UTF8 byte order mark. Default is false. + + + true to specify that a Unicode byte order mark is provided; otherwise, false. + + + + + Gets or sets a value indicating whether to throw an exception on invalid bytes. Default is true. + + true to specify that an exception be thrown when an invalid encoding is detected; otherwise, false. + + + + Simple DestinationResolver implementation resolving destination names + as dynamic destinations. + + Juergen Hoeller + Mark Pollack (.NET) + + + Strategy interface for resolving EMS destinations. + + + Used by EmsTemplate for resolving + destination names from simple Strings to actual + Destination implementation instances. + + + The default DestinationResolver implementation used by + EmsTemplate instances is the + DynamicDestinationResolver class. Consider using the + JndDestinationResolver for more advanced scenarios. + + + Juergen Hoeller + Mark Pollack (.NET) + + + Resolve the given destination name, either as located resource + or as dynamic destination. + + the current EMS Session + + the name of the destination + + true if the domain is pub-sub, false if P2P + + the EMS destination (either a topic or a queue) + + EMSException if resolution failed + + + Resolve the given destination name, either as located resource + or as dynamic destination. + + the current EMS Session + + the name of the destination + + true if the domain is pub-sub, false if P2P + + the EMS destination (either a topic or a queue) + + EMSException if resolution failed + + + Resolve the given destination name to a Topic. + the current EMS Session + + the name of the desired Topic. + + the EMS Topic name + + EMSException if resolution failed + + + Resolve the given destination name to a Queue. + the current EMS Session + + the name of the desired Queue. + + the EMS Queue name + + EMSException if resolution failed + + + + Generic utility methods for working with EMS. Mainly for internal use + within the framework, but also useful for custom EMS access code. + + + + Close the given EMS Connection and ignore any thrown exception. + This is useful for typical finally blocks in manual EMS code. + + the EMS Connection to close (may be null) + + + + Close the given EMS Connection and ignore any thrown exception. + This is useful for typical finally blocks in manual EMS code. + + the EMS Connection to close (may be null) + + whether to call stop() before closing + + + + Close the given EMS Session and ignore any thrown exception. + This is useful for typical finally blocks in manual EMS code. + + the EMS Session to close (may be null) + + + + Close the given EMS MessageProducer and ignore any thrown exception. + This is useful for typical finally blocks in manual EMS code. + + the EMS MessageProducer to close (may be null) + + + + Close the given EMS MessageConsumer and ignore any thrown exception. + This is useful for typical finally blocks in manual EMS code. + + the EMS MessageConsumer to close (may be null) + + + + Commit the Session if not within a distributed transaction. + Needs investigation - no distributed tx in .NET messaging providers + the EMS Session to commit + + EMSException if committing failed + + + Rollback the Session if not within a distributed transaction. + Needs investigation - no distributed tx in EMS + the EMS Session to rollback + + EMSException if committing failed + + + + Closes the given queue browser and ignore any thrown exception. + This is useful for typical finally blocks in manual EMS code. + + The queue browser to close (may be null. + + + + Converts the acknowledgement mode from an integer to an enumeration. If the integer + does not match a valid enumeration, the returned enumeration is SessionMode.AutoAcknowledge + + The ack mode. + The corresponding SessionMode enumeration + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.Nms.dll b/Resources/Libraries/Spring.NET/Spring.Messaging.Nms.dll new file mode 100644 index 0000000000000000000000000000000000000000..012fbbe4b0b656d58b1fee74f70b95f128268bec GIT binary patch literal 99840 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 z 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.Nms.pdb b/Resources/Libraries/Spring.NET/Spring.Messaging.Nms.pdb new file mode 100644 index 0000000000000000000000000000000000000000..30300af6564c549d306b2b85645735d2e0b647ed GIT binary patch literal 253440 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 z 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 + + + Spring.Messaging.Nms + + + + + Parser for the NMS <listener-container> element. + + Mark Fisher + Juergen Hoeller + Mark Pollack (.NET) + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + The element to be parsed. + TThe object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + The primary object definition. + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+
+ + + Namespace parser for the nms namespace. + + Mark Fisher + Juergen Hoeller + Mark Pollack (.NET) + + + + Register a MessageListenerContainer for the 'listener-container' tag. + + + + + NMS MessageConsumer decorator that adapts all calls + to a shared MessageConsumer instance underneath. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The target. + + + + Receives the next message produced for this message consumer. + + the next message produced for this message consumer, , or null if this message consumer is concurrently closed + + + + Receives the next message that arrives within the specified timeout interval. + + The timeout value. + the next message produced for this message consumer, or null if the timeout expires or this message consumer is concurrently closed + + + + Receives the next message if one is immediately available. + + the next message produced for this message consumer, or null if one is not available + + + + No-op implementation since it is caching. + + + + + Dispose of wrapped MessageConsumer + + + + + Description that shows this is a cached MessageConsumer + + Description that shows this is a cached MessageConsumer + + + + Gets the target MessageConsumer, the consumer we are 'wrapping' + + The target MessageConsumer. + + + + Register for message events. + + + + + A Delegate that is called each time a Message is dispatched to allow the client to do + any necessary transformations on the received message before it is delivered. + + + + + + MessageProducer decorator that adapts calls to a shared MessageProducer + instance underneath, managing QoS settings locally within the decorator. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The target. + + + + Sends the specified message. + + The message. + + + + Sends a message to the specified message. + + The message to send. + The QOS to use for sending . + The message priority. + The time to live. + + + + Sends a message to the specified destination. + + The destination. + The message. + + + + Sends a message the specified destination. + + The destination. + The message to send. + The QOS to use for sending . + The priority. + The time to live. + + + + Creates the message. + + A new message + + + + Creates the text message. + + A new text message. + + + + Creates the text message. + + The text. + A texst message with the given text. + + + + Creates the map message. + + a new map message. + + + + Creates the object message. + + The body. + A new object message with the given body. + + + + Creates the bytes message. + + A new bytes message. + + + + Creates the bytes message. + + The body. + A new bytes message with the given body. + + + + Creates the stream message. + + A new stream message. + + + + Reset properties. + + + + + Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources. + + + + + Returns string indicated this is a wrapped MessageProducer + + + + + + Gets the target MessageProducer, the producer we are 'wrapping' + + The target MessageProducer. + + + + A delegate that is called each time a Message is sent from this Producer which allows + the application to perform any needed transformations on the Message before it is sent. + The Session instance sets the delegate on each Producer it creates. + + + + + + Gets or sets a value indicating what DeliveryMode this + should use, for example a persistent QOS + + + + + + Gets or sets the time to live value for messages sent with this producer. + + The time to live. + + + + Gets or sets the request timeout for the message producer. + + The request timeout. + + + + Gets or sets the priority of messages sent with this producer. + + The priority. + + + + Gets or sets a value indicating whether disable setting of the message ID property. + + true if disable message ID setting; otherwise, false. + + + + Gets or sets a value indicating whether disable setting the message timestamp property. + + + true if disable message timestamp; otherwise, false. + + + + + Wrapper for Session that caches producers and registers itself as available + to the session cache when being closed. Generally used for testing purposes or + if need to get at the wrapped Session object via the TargetSession property (for + vendor specific methods). + + Juergen Hoeller + Mark Pollack + + + + Subinterface of Session to be implemented by + implementations that wrap an Session to provide added + functionality. Allows access to the the underlying target Session. + + Mark Pollack + + + + + + Gets the target session of the decorator. + This will typically be the native provider Session or a wrapper from a session pool. + + The underlying session, never null + + + + Initializes a new instance of the class. + + The target session. + The session list. + The CachingConnectionFactory. + + + + Creates the producer, potentially returning a cached instance. + + A message producer, potentially cached. + + + + Creates the producer, potentially returning a cached instance. + + The destination. + A message producer. + + + + If have not yet reached session cache size, cache the session, otherwise + dispose of all cached message producers and close the session. + + + + + Creates the consumer, potentially returning a cached instance. + + The destination. + A message consumer + + + + Creates the consumer, potentially returning a cached instance. + + The destination. + The selector. + A message consumer + + + + Creates the consumer, potentially returning a cached instance. + + The destination. + The selector. + if set to true [no local]. + A message consumer. + + + + Creates the durable consumer, potentially returning a cached instance. + + The destination. + The name of the durable subscription. + The selector. + if set to true [no local]. + A message consumer + + + + Deletes the durable consumer. + + The name of the durable subscription. + + + + Creates the consumer. + + The destination. + The selector. + if set to true [no local]. + The durable subscription name. + + + + + Gets the queue. + + The name. + + + + + Gets the topic. + + The name. + + + + + Creates the temporary queue. + + + + + + Creates the temporary topic. + + + + + + Deletes the destination. + + The destination. + + + + Creates the message. + + + + + + Creates the text message. + + + + + + Creates the text message. + + The text. + + + + + Creates the map message. + + + + + + Creates the object message. + + The body. + + + + + Creates the bytes message. + + + + + + Creates the bytes message. + + The body. + + + + + Creates the stream message. + + + + + + Commits this instance. + + + + + Rollbacks this instance. + + + + + Call dispose on the target. + + + + + Creates the queue browser with a specified selector + + The queue. + The selector. + The Queue browser + + + + Creates the queue browser. + + The queue. + The Queue browser + + + + Returns a that represents the current . + + + A that represents the current . + + + + + Gets the target, for testing purposes. + + The target. + + + + A Delegate that is called each time a Message is dispatched to allow the client to do + any necessary transformations on the received message before it is delivered. + The Session instance sets the delegate on each Consumer it creates. + + + + + + A delegate that is called each time a Message is sent from this Producer which allows + the application to perform any needed transformations on the Message before it is sent. + The Session instance sets the delegate on each Producer it creates. + + + + + + Gets or sets the request timeout. + + The request timeout. + + + + Gets a value indicating whether this is transacted. + + true if transacted; otherwise, false. + + + + Gets the acknowledgement mode. + + The acknowledgement mode. + + + + subclass that adds + Session, MessageProducer, and MessageConsumer caching. This ConnectionFactory + also switches the ReconnectOnException property to true + by default, allowing for automatic recovery of the underlying + Connection. + + + By default, only one single Session will be cached, with further requested + Sessions being created and disposed on demand. Consider raising the + SessionCacheSize property in case of a high-concurrency environment. + + NOTE: This ConnectionFactory requires explicit closing of all Sessions + obtained from its shared Connection. This is the usual recommendation for + native NMS access code anyway. However, with this ConnectionFactory, its use + is mandatory in order to actually allow for Session reuse. + + + Note also that MessageConsumers obtained from a cached Session won't get + closed until the Session will eventually be removed from the pool. This may + lead to semantic side effects in some cases. For a durable subscriber, the + logical Session.Close() call will also close the subscription. + Re-registering a durable consumer for the same subscription on the same + Session handle is not supported; close and reobtain a cached Session first. + + + + Juergen Hoeller + Mark Pollack (.NET) + + + + A ConnectionFactory adapter that returns the same Connection + from all CreateConnection() calls, and ignores calls to + Connection.Close(). According to the JMS Connection + model, this is perfectly thread-safe. The + shared Connection can be automatically recovered in case of an Exception. + + + + You can either pass in a specific Connection directly or let this + factory lazily create a Connection via a given target ConnectionFactory. + + + Useful for testing and in applications when you want to keep using the + same Connection for multiple + calls, without having a pooling ConnectionFactory underneath. This may span + any number of transactions, even concurrently executing transactions. + + + Note that Spring's message listener containers support the use of + a shared Connection within each listener container instance. Using + SingleConnectionFactory with a MessageListenerContainer only really makes sense for + sharing a single Connection across multiple listener containers. + + + Juergen Hoeller + Mark Pollack + Mark Pollack (.NET) + + + + Exception handler for exceptions from the messaging infrastrcture. + + Mark Pollack + + + + Called when there is an exception in message processing. + + The exception. + + + + Wrapped Connection + + + + + Proxy Connection + + + + + Whether the shared Connection has been started + + + + + Synchronization monitor for the shared Connection + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class + that alwasy returns the given Connection. + + The single Connection. + + + + Initializes a new instance of the class + that alwasy returns a single Connection. + + The target connection factory. + + + + Creates the connection. + + A single shared connection + + + + Creates the connection. + + Name of the user. + The password. + + + + + Initialize the underlying shared Connection. Closes and reinitializes the Connection if an underlying + Connection is present already. + + + + + Exception listener callback that renews the underlying single Connection. + + The exception from the messaging infrastructure. + + + + Prepares the connection before it is exposed. + The default implementation applies ExceptionListener and client id. + Can be overridden in subclasses. + + The Connection to prepare. + if thrown by any NMS API methods. + + + + Template method for obtaining a (potentially cached) Session. + + The connection to operate on. + The session ack mode. + the Session to use, or null to indicate + creation of a raw standard Session + + + + reate a JMS Connection via this template's ConnectionFactory. + + + + + + Closes the given connection. + + The connection. + + + + Ensure that the connection or TargetConnectionFactory are specified. + + + + + Close the underlying shared connection. The provider of this ConnectionFactory needs to care for proper shutdown. + As this object implements an application context will automatically + invoke this on distruction o + + + + + Resets the underlying shared Connection, to be reinitialized on next access. + + + + + Wrap the given Connection with a proxy that delegates every method call to it + but suppresses close calls. This is useful for allowing application code to + handle a special framework Connection just like an ordinary Connection from a + ConnectionFactory. + + The original connection to wrap. + the wrapped connection + + + + Gets or sets the target connection factory which will be used to create a single + connection. + + The target connection factory. + + + + Gets or sets the client id for the single Connection created and exposed by + this ConnectionFactory. + + Note that the client IDs need to be unique among all active + Connections of teh underlying provider. Furthermore, a client ID can only + be assigned if the original ConnectionFactory hasn't already assigned one. + The client id. + + + + Gets or sets the exception listener implementation that should be registered + with with the single Connection created by this factory, if any. + + The exception listener. + + + + Gets or sets a value indicating whether the single Connection + should be reset (to be subsequently renewed) when a NMSException + is reported by the underlying Connection. + + + Default is false. Switch this to true + to automatically trigger recover based on your messaging provider's + exception notifications. + + Internally, this will lead to a special ExceptionListener (this + SingleConnectionFactory itself) being registered with the underlying + Connection. This can also be combined with a user-specified + ExceptionListener, if desired. + + + + true attempt to reconnect on exception during next access; otherwise, false. + + + + + Get/or set the broker Uri. + + + + + Get/or set the redelivery policy that new IConnection objects are + assigned upon creation. + + + + + A Delegate that is called each time a Message is dispatched to allow the client to do + any necessary transformations on the received message before it is delivered. The + ConnectionFactory sets the provided delegate instance on each Connection instance that + is created from this factory, each connection in turn passes the delegate along to each + Session it creates which then passes that along to the Consumers it creates. + + + + + + A delegate that is called each time a Message is sent from this Producer which allows + the application to perform any needed transformations on the Message before it is sent. + The ConnectionFactory sets the provided delegate instance on each Connection instance that + is created from this factory, each connection in turn passes the delegate along to each + Session it creates which then passes that along to the Producers it creates. + + + + + + Gets the connection monitor. + + The connection monitor. + + + + Gets a value indicating whether this instance is started. + + + true if this instance is started; otherwise, false. + + + + + Initializes a new instance of the class. + and sets the ReconnectOnException to true + + + + + Initializes a new instance of the class for the given + IConnectionFactory + + The target connection factory. + + + + Resets the Session cache as well as resetting the connection. + + + + + Obtaining a cached Session. + + The connection to operate on. + The session ack mode. + The Session to use + + + + + Wraps the given Session so that it delegates every method call to the target session but + adapts close calls. This is useful for allowing application code to + handle a special framework Session just like an ordinary Session. + + The original Session to wrap. + The List of cached Sessions that the given Session belongs to. + The wrapped Session + + + + Gets or sets the size of the session cache. + + + This cache size is the maximum limit for the number of cached Sessions + per session acknowledgement type (auto, client, dups_ok, transacted). + As a consequence, the actual number of cached Sessions may be up to + four times as high as the specified value - in the unlikely case + of mixing and matching different acknowledgement types. + + Default is 1: caching a single Session, (re-)creating further ones on + demand. Specify a number like 10 if you'd like to raise the number of cached + Sessions; that said, 1 may be sufficient for low-concurrency scenarios. + + + The size of the session cache. + + + + Gets or sets a value indicating whether to cache MessageProducers per + Session instance. (more specifically: one MessageProducer per Destination + and Session). + + + Default is "true". Switch this to "false" in order to always, + recreate MessageProducers on demand. + + + true if should cache message producers; otherwise, false. + + + + Gets or sets a value indicating whether o cache JMS MessageConsumers per + NMS Session instance. + + + Mmore specifically: one MessageConsumer per Destination, selector String + and Session. Note that durable subscribers will only be cached until + logical closing of the Session handle. + + Default is "true". Switch this to "false" in order to always + recreate MessageConsumers on demand. + + + true to cache consumers per session instance; otherwise, false. + + + + Gets or sets a value indicating whether this instance is active. + + true if this instance is active; otherwise, false. + + + + Implementation of Spring IExceptionListener interface that supports + chaining allowing the addition of multiple ExceptionListener instances in order. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Adds the exception listener to the chain + + The listener. + + + + Called when an exception occurs in message processing. + + The exception. + + + + Gets the exception listeners as an array. + + The exception listeners. + + + Helper class for obtaining transactional NMS resources + for a given ConnectionFactory. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Releases the given connection, stopping it (if necessary) and eventually closing it. + + Checks , if available. + This is essentially a more sophisticated version of + + + The connection to release. (if this is null, the call will be ignored) + The ConnectionFactory that the Connection was obtained from. (may be null) + whether the Connection might have been started by the application. + + + + Return the innermost target Session of the given Session. If the given + Session is a decorated session, it will be unwrapped until a non-decorated + Session is found. Otherwise, the passed-in Session will be returned as-is. + + The session to unwrap + The innermost target Session, or the passed-in one if no decorator + + + + Determines whether the given JMS Session is transactional, that is, + bound to the current thread by Spring's transaction facilities. + + The session to check. + The ConnectionFactory that the Session originated from + + true if is session transactional, bound to current thread; otherwise, false. + + + + Obtain a NMS Session that is synchronized with the current transaction, if any. + the ConnectionFactory to obtain a Session for + + the existing NMS Connection to obtain a Session for + (may be null) + + whether to allow for a local NMS transaction + that is synchronized with a Spring-managed transaction (where the main transaction + might be a ADO.NET-based one for a specific DataSource, for example), with the NMS + transaction committing right after the main transaction. If not allowed, the given + ConnectionFactory needs to handle transaction enlistment underneath the covers. + + the transactional Session, or null if none found + + NMSException in case of NMS failure + + + + Obtain a NMS Session that is synchronized with the current transaction, if any. + + the TransactionSynchronizationManager key to bind to + (usually the ConnectionFactory) + the ResourceFactory to use for extracting or creating + NMS resources + whether the underlying Connection approach should be + started in order to allow for receiving messages. Note that a reused Connection + may already have been started before, even if this flag is false. + + the transactional Session, or null if none found + + NMSException in case of NMS failure + + + Callback interface for resource creation. + Serving as argument for the DoGetTransactionalSession method. + + + + Fetch an appropriate Session from the given MessageResourceHolder. + the MessageResourceHolder + + an appropriate Session fetched from the holder, + or null if none found + + + + Fetch an appropriate Connection from the given MessageResourceHolder. + the MessageResourceHolder + + an appropriate Connection fetched from the holder, + or null if none found + + + + Create a new NMS Connection for registration with a MessageResourceHolder. + the new NMS Connection + + NMSException if thrown by NMS API methods + + + Create a new NMS ISession for registration with a MessageResourceHolder. + the NMS Connection to create a ISession for + + the new NMS Session + + NMSException if thrown by NMS API methods + + + + Return whether to allow for a local NMS transaction that is synchronized with + a Spring-managed transaction (where the main transaction might be a ADO.NET-based + one for a specific IDbProvider, for example), with the NMS transaction + committing right after the main transaction. + Returns whether to allow for synchronizing a local NMS transaction + + + + + Callback for resource cleanup at the end of a non-native NMS transaction + + + + + Extension of the ConnectionFactory interface, + indicating how to release Connections obtained from it. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Shoulds we stop the connection, obtained from this ConnectionFactory? + + The connection to check. + wheter a stop call is necessary + + + Connection holder, wrapping a NMS Connection and a NMS Session. + MessageTransactionManager binds instances of this class to the thread, + for a given NMS ConnectionFactory. + +

Note: This is an SPI class, not intended to be used by applications.

+ +
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + Create a new MessageResourceHolder that is open for resources to be added. + + + + Initializes a new instance of the class + at is open for resources to be added. + + The connection factory that this + resource holder is associated with (may be null) + + + + + Initializes a new instance of the class for the + given Session. + + The session. + + + Create a new MessageResourceHolder for the given NMS resources. + the NMS Connection + + the NMS Session + + + + + Initializes a new instance of the class. + + The connection factory. + The connection. + The session. + + + + Adds the connection to the list of resources managed by this holder. + + The connection. + + + + Adds the session to the list of resources managed by this holder. + + The session. + + + + Adds the session and connection to the list of resources managed by this holder. + + The session. + The connection. + + + + Gets the connection managed by this resource holder + + A Connection, or null if no managed connection. + + + + Gets the connection of a given type managed by this resource holder. This is used + when storing Queue or Topic Connections (from the older 1.0.2 API) as compared to the + 'unified domain' API , just Connection, in the newer 1.2 API. + + Type of the connection. + The connection, or null if not found. + + + + Gets the first session manged by this holder or null if not available. + + The session or null if not available. + + + + Gets the session managed by this holder by type. + + Type of the session. + The session or null if not available. + + + + Gets the session of a given type associated with the given connection + + Type of the session. + The connection. + The sessin or null if not available. + + + + Commits all sessions. + + + + + Closes all sessions then stops and closes all connections, in that order. + + + + + Determines whether the holder contains the specified session. + + The session. + + true if the holder contains the specified session; otherwise, false. + + + + + Gets a value indicating whether this is frozen, namely that + additional resources can be registered with the holder. If using any of the constructors with + a Session, the holder will be set to the frozen state. + + true if frozen; otherwise, false. + + + + A implementation + for a single NMS ConnectionFactory. Binds a + Connection/Session pair from the specified ConnecctionFactory to the thread, + potentially allowing for one thread-bound Session per ConnectionFactory. + + + + Application code is required to retrieve the transactional Session via + . Spring's + will autodetect a thread-bound Session and + automatically participate in it. + + + The use of as a target for this + transaction manager is strongly recommended. CachingConnectionFactory + uses a single NMS Connection for all NMS access in order to avoid the overhead + of repeated Connection creation, as well as maintaining a cache of Sessions. + Each transaction will then share the same NMS Connection, while still using + its own individual NMS Session. + + The use of a raw target ConnectionFactory would not only be inefficient + because of the lack of resource reuse. It might also lead to strange effects + when your NMS provider doesn't accept MessageProducer.close() calls + and/or MessageConsumer.close() calls before Session.commit(), + with the latter supposed to commit all the messages that have been sent through the + producer handle and received through the consumer handle. As a safe general solution, + always pass in a into this transaction manager's + ConnectionFactory property. + + + Transaction synchronization is turned off by default, as this manager might be used + alongside an IDbProvider based Spring transaction manager such as the + AdoPlatformTransactionManager, which has stronger needs for synchronization. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + The ConnectionFactory has to be set before using the instance. + This constructor can be used to prepare a NmsTemplate via a ApplicationContext, + typically setting the ConnectionFactory via ConnectionFactory property. + + Turns off transaction synchronization by default, as this manager might + be used alongside a dbprovider-based Spring transaction manager like + AdoPlatformTransactionManager, which has stronger needs for synchronization. + Only one manager is allowed to drive synchronization at any point of time. + + + + + + Initializes a new instance of the class + given a ConnectionFactory. + + The connection factory to obtain connections from. + + + + Make sure the ConnectionFactory has been set. + + + + + Get the MessageTransactionObject. + + he MessageTransactionObject. + + + + Begin a new transaction with the given transaction definition. + + Transaction object returned by + . + instance, describing + propagation behavior, isolation level, timeout etc. + + Does not have to care about applying the propagation behavior, + as this has already been handled by this abstract manager. + + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + Transaction object returned by + . + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + Transaction synchronization will already have been suspended. + + + in case of system errors. + + + + + Resume the resources of the current transaction. + + Transaction object returned by + . + The object that holds suspended resources as returned by + . + Transaction synchronization will be resumed afterwards. + + + In the case of system errors. + + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + + In the case of system errors. + + + + + Perform an actual rollback on the given transaction. + + The status representation of the transaction. + + In the case of system errors. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + + In the case of system errors. + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + Called after + and + + execution on any outcome. + + + + + + Check if the given transaction object indicates an existing transaction + (that is, a transaction which has already started). + + Transaction object returned by + . + + True if there is an existing transaction. + + + In the case of system errors. + + + + + Creates the connection via thie manager's ConnectionFactory. + + The new Connection + If thrown by underlying messaging APIs + + + + Creates the session for the given Connection + + The connection to create a Session for. + the new Session + If thrown by underlying messaging APIs + + + + Gets or sets the connection factory that this instance should manage transaction. + for. + + The connection factory. + + + + Gets the resource factory that this transaction manager operates on, + In tihs case the ConnectionFactory + + The ConnectionFactory. + + + + NMS Transaction object, representing a MessageResourceHolder. + Used as transaction object by MessageTransactionManager + + + + + Add information to show this is a shared NMS connection + + Description of connection wrapper + + + Exception thrown when a synchronized local transaction failed to complete + (after the main transaction has already completed). + + Jergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the SynchedLocalTransactionFailedException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the SynchedLocalTransactionFailedException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The SerializationInfo that holds the serialized object data about the exception being thrown. + The StreamingContext that contains contextual information about the source or destination. + + + Creates a NMS message given a Session + +

The Session typically is provided by an instance + of the MessageTemplate class.

+
+ Mark Pollack +
+ + Create a Message to be sent. + the NMS Session to be used to create the + IMessage (never null) + + the Message to be sent + + NMSException if thrown by NMS API methods + + + + Interfaced based approach to listen to messaging events. + + + + + Called when a message is delivered. + + The message. + + + To be used with NmsTemplate's send method that + convert an object to a message. + + + It allows for further modification of the message after it has been processed + by the converter. This is useful for setting of NMS Header and Properties. + + Mark Pollack + + + Apply a IMessagePostProcessor to the message. The returned message is + typically a modified version of the original. + + the NMS message from the IMessageConverter + + the modified version of the Message + + NMSException if thrown by NMS API methods + + + + Specifies a basic set of NMS operations. + + +

Implemented by NmsTemplate. Not often used but a useful option + to enhance testability, as it can easily be mocked or stubbed.

+

Provides NmsTemplate's + send(..) and + receive(..) methods that mirror various NMS API methods. + See the NMS specification and NMS API docs for details on those methods. +

+
+ Mark Pollack + Juergen Hoeller + Mark Pollack (.NET) +
+ + + Execute the action specified by the given action object within + a NMS Session. + + callback object that exposes the session + + the result object from working with the session + + NMSException if there is any problem + + + + Execute the action specified by the given action object within + a NMS Session. + + delegate that exposes the session + + the result object from working with the session + + NMSException if there is any problem + + + Send a message to a NMS destination. The callback gives access to + the NMS session and MessageProducer in order to do more complex + send operations. + + delegate that exposes the session/producer pair + + the result object from working with the session + + NMSException if there is any problem + + + Send a message to a NMS destination. The callback gives access to + the NMS session and MessageProducer in order to do more complex + send operations. + + callback object that exposes the session/producer pair + + the result object from working with the session + + NMSException if there is any problem + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ callback to create a message + + NMSException if there is any problem +
+ + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the destination to send this message to + + callback to create a message + + NMSException if there is any problem + + + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + callback to create a message + + NMSException if there is any problem + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ delegate callback to create a message + + NMSException if there is any problem +
+ + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the destination to send this message to + + delegate callback to create a message + + NMSException if there is any problem + + + Send a message to the specified destination. + The IMessageCreator callback creates the message given a Session. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + delegate callback to create a message + + NMSException if there is any problem + + + Send the given object to the default destination, converting the object + to a NMS message with a configured IMessageConverter. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + NMSException if there is any problem +
+ + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. + + the destination to send this message to + + the object to convert to a message + + NMSException if there is any problem + + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message + + NMSException if there is any problem + + + Send the given object to the default destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + the callback to modify the message + + NMSException if there is any problem +
+ + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + + the object to convert to a message + + the callback to modify the message + + NMSException if there is any problem + + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message. + + the callback to modify the message + + NMSException if there is any problem + + + + Send the given object to the default destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + the callback to modify the message + NMSException if there is any problem +
+ + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + the object to convert to a message + the callback to modify the message + NMSException if there is any problem + + + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + the object to convert to a message. + the callback to modify the message + NMSException if there is any problem + + + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Callback for sending a message to a NMS destination. + +

To be used with the MessageTemplate.Execute(IProducerCallback) + method, often implemented as an anonymous inner class.

+ +

The typical implementation will perform multiple operations on the + supplied NMS Session and MessageProducer.

+
+ Mark Pollack +
+ + Perform operations on the given Session and MessageProducer. + The message producer is not associated with any destination. + + the NMS Session object to use + + the NMS MessageProducer object to use + + a result object from working with the Session, if any (can be null) + + + + Callback for executing any number of operations on a provided + Session + + + To be used with the NmsTemplate.Execute(ISessionCallback)} + method. See for the equivalent callback + that can be used as a (anonymous) delegate. + + Mark Pollack + + + + + Execute any number of operations against the supplied NMS + Session, possibly returning a result. + + the NMS Session + + a result object from working with the Session, if any (so can be null) + + NMSException if there is any problem + + + + Delegate that creates a NMS message given a ISession + + the NMS Session to be used to create the + Message (never null) + + the Message to be sent + + NMSException if thrown by NMS API methods + + + + Delegate that is used with NmsTemplate's ConvertAndSend method that converts + an object. + + + It allows for further modification of the message after it has been processed + by the converter. This is useful for setting of NMS Header and Properties. + + Mark Pollack + + + + Convenient super class for application classes that need NMS access. + + + Requires a ConnectionFactory or a NmsTemplate instance to be set. + It will create its own NmsTemplate if a ConnectionFactory is passed in. + A custom NmsTemplate instance can be created for a given ConnectionFactory + through overriding the createNmsTemplate method. + + + + + Creates a NmsTemplate for the given ConnectionFactory. + + Only invoked if populating the gateway with a ConnectionFactory reference. + Can be overridden in subclasses to provide a different NmsTemplate instance + + + The connection factory. + + + + + Ensures that the JmsTemplate is specified and calls . + + + + + Subclasses can override this for custom initialization behavior. + Gets called after population of this instance's properties. + + + + + Gets or sets the NMS template for the gateway. + + The NMS template. + + + + Gets or sets he NMS connection factory to be used by the gateway. + Will automatically create a NmsTemplate for the given ConnectionFactory. + + The connection factory. + + + Helper class that simplifies NMS access code. + + If you want to use dynamic destination creation, you must specify + the type of NMS destination to create, using the "pubSubDomain" property. + For other operations, this is not necessary. + Point-to-Point (Queues) is the default domain. + + Default settings for NMS Sessions is "auto-acknowledge". + + This template uses a DynamicDestinationResolver and a SimpleMessageConverter + as default strategies for resolving a destination name or converting a message, + respectively. + + + Mark Pollack + Juergen Hoeller + Mark Pollack (.NET) + + + Base class for NmsTemplate} and other + NMS-accessing gateway helpers, adding destination-related properties to + MessagingAccessor's common properties. + + +

Not intended to be used directly. See NmsTemplate.

+ +
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + Base class for NmsTemplate and other NMS-accessing gateway helpers + It defines common properties like the ConnectionFactory}. The subclass + NmsIDestinationAccessor adds further, destination-related properties. + + Not intended to be used directly. See NmsTemplate. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Verify that ConnectionFactory property has been set. + + + + + Creates the connection via the ConnectionFactory. + + + + + + Creates the session for the given Connection + + The connection to create a session for. + The new session + + + + Returns whether the ISession is in client acknowledgement mode. + + The session to check. + true if in client ack mode, false otherwise + + + + Gets or sets the connection factory to use for obtaining NMS Connections. + + The connection factory. + + + + Gets or sets the session acknowledge mode for NMS Sessions including whether or not the session is transacted + + + Set the NMS acknowledgement mode that is used when creating a NMS + Session to send a message. The default is AUTO_ACKNOWLEDGE. + + The session acknowledge mode. + + + + Set the transaction mode that is used when creating a NMS Session. + Default is "false". + + + Setting this flag to "true" will use a short local NMS transaction + when running outside of a managed transaction, and a synchronized local + NMS transaction in case of a managed transaction being present. + The latter has the effect of a local NMS + transaction being managed alongside the main transaction (which might + be a native ADO.NET transaction), with the NMS transaction committing + right after the main transaction. + + + + + + Resolves the given destination name to a NMS destination. + + The current session. + Name of the destination. + The located IDestination + If resolution failed. + + + + Gets or sets the destination resolver that is to be used to resolve + IDestination references for this accessor. + + The default resolver is a DynamicDestinationResolver. Specify a + JndiDestinationResolver for resolving destination names as JNDI locations. + + The destination resolver. + + + + Gets or sets a value indicating whether Publish/Subscribe + domain (Topics) is used. Otherwise, the Point-to-Point domain + (Queues) is used. + + + this + setting tells what type of destination to create if dynamic destinations are enabled. + true if Publish/Subscribe domain; otherwise, false + for the Point-to-Point domain. + + + + Timeout value indicating that a receive operation should + check if a message is immediately available without blocking. + + + + + Timeout value indicating a blocking receive without timeout. + + + + Create a new NmsTemplate. + + Note: The ConnectionFactory has to be set before using the instance. + This constructor can be used to prepare a NmsTemplate via an ObjectFactory, + typically setting the ConnectionFactory. + + + + Create a new NmsTemplate, given a ConnectionFactory. + the ConnectionFactory to obtain IConnections from + + + + Initialize the default implementations for the template's strategies: + DynamicDestinationResolver and SimpleMessageConverter. + + + + Execute the action specified by the given action object within a + NMS Session. + + Generalized version of execute(ISessionCallback), + allowing the NMS Connection to be started on the fly. +

Use execute(ISessionCallback) for the general case. + Starting the NMS Connection is just necessary for receiving messages, + which is preferably achieved through the receive methods.

+
+ callback object that exposes the session + + Start the connection before performing callback action. + + the result object from working with the session + + NMSException if there is any problem +
+ + + Extract the content from the given JMS message. + + The Message to convert (can be null). + The content of the message, or null if none + + + Fetch an appropriate Connection from the given MessageResourceHolder. + + the MessageResourceHolder + + an appropriate IConnection fetched from the holder, + or null if none found + + + + Fetch an appropriate Session from the given MessageResourceHolder. + + the MessageResourceHolder + + an appropriate ISession fetched from the holder, + or null if none found + + + + Create a NMS MessageProducer for the given Session and Destination, + configuring it to disable message ids and/or timestamps (if necessary). +

Delegates to doCreateProducer for creation of the raw + NMS MessageProducer

+
+ the NMS Session to create a MessageProducer for + + the NMS Destination to create a MessageProducer for + + the new NMS MessageProducer + + NMSException if thrown by NMS API methods + + + + + + +
+ + + Determines whether the given Session is locally transacted, that is, whether + its transaction is managed by this template class's Session handling + and not by an external transaction coordinator. + + + The Session's own transacted flag will already have been checked + before. This method is about finding out whether the Session's transaction + is local or externally coordinated. + + The session to check. + + true if the session is locally transacted; otherwise, false. + + + + Create a raw NMS MessageProducer for the given Session and Destination. + + the NMS Session to create a MessageProducer for + + the NMS IDestination to create a MessageProducer for + + the new NMS MessageProducer + + NMSException if thrown by NMS API methods + + + Create a NMS MessageConsumer for the given Session and Destination. + + the NMS Session to create a MessageConsumer for + + the NMS Destination to create a MessageConsumer for + + the message selector for this consumer (can be null) + + the new NMS IMessageConsumer + + NMSException if thrown by NMS API methods + + + + Send the given message. + + The session to operate on. + The destination to send to. + The message creator delegate callback to create a Message. + + + + Send the given message. + + The session to operate on. + The destination to send to. + The message creator callback to create a Message. + + + Send the given NMS message. + the NMS Session to operate on + + the NMS Destination to send to + + callback to create a NMS Message + + delegate callback to create a NMS Message + + NMSException if thrown by NMS API methods + + + Actually send the given NMS message. + the NMS MessageProducer to send with + + the NMS Message to send + + NMSException if thrown by NMS API methods + + + + Execute the action specified by the given action object within + a NMS Session. + + delegate that exposes the session + + the result object from working with the session + + + Note that the value of PubSubDomain affects the behavior of this method. + If PubSubDomain equals true, then a Session is passed to the callback. + If false, then a ISession is passed to the callback.b + + NMSException if there is any problem + + + Execute the action specified by the given action object within + a NMS Session. +

Note: The value of PubSubDomain affects the behavior of this method. + If PubSubDomain equals true, then a Session is passed to the callback. + If false, then a Session is passed to the callback.

+
+ callback object that exposes the session + + the result object from working with the session + + NMSException if there is any problem +
+ + Send a message to a NMS destination. The callback gives access to + the NMS session and MessageProducer in order to do more complex + send operations. + + callback object that exposes the session/producer pair + + the result object from working with the session + + NMSException if there is any problem + + + Send a message to a NMS destination. The callback gives access to + the NMS session and MessageProducer in order to do more complex + send operations. + + delegate that exposes the session/producer pair + + the result object from working with the session + + NMSException if there is any problem + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ delegate callback to create a message + + NMSException if there is any problem +
+ + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the destination to send this message to + + delegate callback to create a message + + NMSException if there is any problem + + + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + delegate callback to create a message + + NMSException if there is any problem + + + Send a message to the default destination. +

This will only work with a default destination specified!

+
+ callback to create a message + + NMSException if there is any problem +
+ + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the destination to send this message to + + callback to create a message + + NMSException if there is any problem + + + Send a message to the specified destination. + The MessageCreator callback creates the message given a Session. + + the destination to send this message to + + callback to create a message + + NMSException if there is any problem + + + Send the given object to the default destination, converting the object + to a NMS message with a configured IMessageConverter. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + NMSException if there is any problem +
+ + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. + + the destination to send this message to + + the object to convert to a message + + NMSException if there is any problem + + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message + + NMSException if there is any problem + + + Send the given object to the default destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + the callback to modify the message + + NMSException if there is any problem +
+ + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + + the object to convert to a message + + the callback to modify the message + + NMSException if there is any problem + + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the object to convert to a message. + + the callback to modify the message + + NMSException if there is any problem + + + + Send the given object to the default destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + the callback to modify the message + NMSException if there is any problem +
+ + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the destination to send this message to + the object to convert to a message + the callback to modify the message + NMSException if there is any problem + + + + Send the given object to the specified destination, converting the object + to a NMS message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. + + the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + the object to convert to a message. + the callback to modify the message + NMSException if there is any problem + + + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message received by the consumer, or null if the timeout expires + + NMSException if there is any problem +
+ + + Receive a message. + + The session to operate on. + The destination to receive from. + The message selector for this consumer (can be null + The Message received, or null if none. + + + + Receive a message. + + The session to operate on. + The consumer to receive with. + The Message received, or null if none + + + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the default destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+

This will only work with a default destination specified!

+
+ the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the destination to receive a message from + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + Receive a message synchronously from the specified destination, but only + wait up to a specified time for delivery. Convert the message into an + object with a configured IMessageConverter. +

This method should be used carefully, since it will block the thread + until the message becomes available or until the timeout value is exceeded.

+
+ the name of the destination to send this message to + (to be resolved to an actual destination by a DestinationResolver) + + the NMS message selector expression (or null if none). + See the NMS specification for a detailed definition of selector expressions. + + the message produced for the consumer or null if the timeout expires. + + NMSException if there is any problem +
+ + + Gets or sets the default destination to be used on send/receive operations that do not + have a destination parameter. + + Alternatively, specify a "defaultDestinationName", to be + dynamically resolved via the DestinationResolver. + The default destination. + + + + Gets or sets the name of the default destination name + to be used on send/receive operations that + do not have a destination parameter. + + + Alternatively, specify a NMS IDestination object as "DefaultDestination" + + The name of the default destination. + + + + Gets or sets the message converter for this template. + + + Used to resolve + Object parameters to convertAndSend methods and Object results + from receiveAndConvert methods. +

The default converter is a SimpleMessageConverter, which is able + to handle IBytesMessages, ITextMessages and IObjectMessages.

+
+ The message converter. +
+ + + Gets or sets a value indicating whether Message Ids are enabled. + + true if message id enabled; otherwise, false. + + + + Gets or sets a value indicating whether message timestamps are enabled. + + + true if [message timestamp enabled]; otherwise, false. + + + + + Gets or sets a value indicating whether to inhibit the delivery of messages published by its own connection. + + + true if inhibit the delivery of messages published by its own connection; otherwise, false. + + + + Gets or sets the receive timeout to use for recieve calls (in milliseconds) + + The default is -1, which means no timeout. + The receive timeout. + + + + Gets or sets a value indicating whether to use explicit Quality of Service values. + + If "true", then the values of deliveryMode, priority, and timeToLive + will be used when sending a message. Otherwise, the default values, + that may be set administratively, will be used + true if use explicit QoS values; otherwise, false. + + + + Sets a value indicating whether message delivery should be persistent or non-persistent + + + This will set the delivery to persistent or non-persistent +

Default it "true" aka delivery mode "PERSISTENT".

+
+ true if [delivery persistent]; otherwise, false. +
+ + + Gets or sets a value indicating what DeliveryMode this + should use, for example a persistent QOS + + + + + + Gets or sets the priority when sending. + + Since a default value may be defined administratively, + this is only used when "isExplicitQosEnabled" equals "true". + The priority. + + + + Gets or sets the time to live when sending + + Since a default value may be defined administratively, + this is only used when "isExplicitQosEnabled" equals "true". + The time to live. + + + + ResourceFactory implementation that delegates to this template's callback methods. + + + + + Implemention of NMS ITrace interface that will log NMS messages to Common.Logging. + + Registering of this class is done by default in NmsTemplate and SimpleMessageListenerContainer if the value + of Apache.NMS.Tracer.Trace is null, indicating it was not set. + + Mark Pollack + + + + Initializes a new instance of the class. The log name used is typeof(NmsTrace). + + + + + Initializes a new instance of the class. + + The log instance to use for logging. + + + + Logs message at Debug Level. + + The message. + + + + Logs message at Info Level. + + The message. + + + + Logs message at Warn Level. + + The message. + + + + Logs message at Error Level. + + The message. + + + + Logs message at Fatal Level. + + The message. + + + + Gets a value indicating whether the debug log level is enabled. + + + true if this instance is debug enabled; otherwise, false. + + + + + Gets a value indicating whether the info log level is enabled. + + + true if this instance is info enabled; otherwise, false. + + + + + Gets a value indicating whether the warn log level is enabled. + + + true if this instance is warn enabled; otherwise, false. + + + + + Gets a value indicating whether the error log level is enabled. + + + true if this instance is error enabled; otherwise, false. + + + + + Gets a value indicating whether the fatal log level is enabled. + + + true if this instance is fatal enabled; otherwise, false. + + + + Perform operations on the given Session and MessageProducer. + The message producer is not associated with any destination. + + the NMS Session object to use + + the NMS MessageProducer object to use + + a result object from working with the Session, if any (can be null) + + + + + Callback delegate for code that operates on a Session. + + The NMS ISession object. + + Allows you to execute any number of operations + on a single ISession, possibly returning a result a result. + + + A result object from working with the Session, if any (so can be null) + + NMSException if there is any problem + Mark Pollack + + + + Exception to be thrown when the execution of a listener method failed. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class, with the specified message + + The message. + + + + Initializes a new instance of the class, with the specified message + and root cause exception + + The message. + The inner exception. + + + + Initializes a new instance of the class. + + The SerializationInfo that holds the serialized object data about the exception being thrown. + The StreamingContext that contains contextual information about the source or destination. + + + + Message listener adapter that delegates the handling of messages to target + listener methods via reflection, with flexible message type conversion. + Allows listener methods to operate on message content types, completely + independent from the NMS API. + + + By default, the content of incoming messages gets extracted before + being passed into the target listener method, to let the target method + operate on message content types such as String or byte array instead of + the raw Message. Message type conversion is delegated to a Spring + . By default, a + will be used. (If you do not want such automatic message conversion taking + place, then be sure to set the property + to null.) + + If a target listener method returns a non-null object (typically of a + message content type such as String or byte array), it will get + wrapped in a NMS Message and sent to the response destination + (either the NMS "reply-to" destination or the + specified. + + + The sending of response messages is only available when + using the entry point (typically through a + Spring message listener container). Usage as standard NMS MessageListener + does not support the generation of response messages. + + Consult the reference documentation for examples of method signatures compliant with this + adapter class. + + + Juergen Hoeller + Mark Pollack (.NET) + + + + Variant of the standard NMS MessageListener interface, + offering not only the received Message but also the underlying + Session object. The latter can be used to send reply messages, + without the need to access an external Connection/Session, + i.e. without the need to access the underlying ConnectionFactory. + + + Supported by Spring's + as direct alternative to the standard MessageListener interface. + + Juergen Hoeller + Mark Pollack (.NET) + + + Callback for processing a received NMS message. + Implementors are supposed to process the given Message, + typically sending reply messages through the given Session. + + the received NMS message + + the underlying NMS Session + + NMSException if thrown by NMS methods + + + + The default handler method name. + + + + + Initializes a new instance of the class with default settings. + + + + + Initializes a new instance of the class for the given handler object + + The delegate object. + + + + Standard JMS {@link MessageListener} entry point. + Delegates the message to the target listener method, with appropriate + conversion of the message arguments + + + + In case of an exception, the method will be invoked. + Note + Does not support sending response messages based on + result objects returned from listener methods. Use the + entry point (typically through a Spring + message listener container) for handling result objects as well. + + The incoming message. + + + + Spring entry point. + + Delegates the message to the target listener method, with appropriate + conversion of the message argument. If the target method returns a + non-null object, wrap in a NMS message and send it back. + + + The incoming message. + The session to operate on. + + + + Initialize the default implementations for the adapter's strategies. + + + + + Handle the given exception that arose during listener execution. + The default implementation logs the exception at error level. + This method only applies when used as standard NMS MessageListener. + In case of the Spring mechanism, + exceptions get handled by the caller instead. + + + The exception to handle. + + + + Extract the message body from the given message. + + The message. + the content of the message, to be passed into the + listener method as argument + if thrown by NMS API methods + + + + Gets the name of the listener method that is supposed to + handle the given message. + The default implementation simply returns the configured + default listener method, if any. + + The NMS request message. + The converted JMS request message, + to be passed into the listener method as argument. + the name of the listener method (never null) + if thrown by NMS API methods + + + + Handles the given result object returned from the listener method, sending a response message back. + + The result object to handle (never null). + The original request message. + The session to operate on (may be null). + + + + Builds a JMS message to be sent as response based on the given result object. + + The JMS Session to operate on. + The content of the message, as returned from the listener method. + the JMS Message (never null) + If there was an error in message conversion + if thrown by NMS API methods + + + + Post-process the given response message before it will be sent. The default implementation + sets the response's correlation id to the request message's correlation id. + + The original incoming message. + The outgoing JMS message about to be sent. + if thrown by NMS API methods + + + + Determine a response destination for the given message. + + + The default implementation first checks the JMS Reply-To + Destination of the supplied request; if that is not null + it is returned; if it is null, then the configured + default response destination + is returned; if this too is null, then an + is thrown. + + + The original incoming message. + Tthe outgoing message about to be sent. + The session to operate on. + the response destination (never null) + if thrown by NMS API methods + if no destination can be determined. + + + + Resolves the default response destination into a Destination, using this + accessor's in case of a destination name. + + The session to operate on. + The located destination + + + + Sends the given response message to the given destination. + + The session to operate on. + The destination to send to. + The outgoing message about to be sent. + + + + Post-process the given message producer before using it to send the response. + The default implementation is empty. + + The producer that will be used to send the message. + The outgoing message about to be sent. + + + + Gets or sets the handler object to delegate message listening to. + + + Specified listener methods have to be present on this target object. + If no explicit handler object has been specified, listener + methods are expected to present on this adapter instance, that is, + on a custom subclass of this adapter, defining listener methods. + + The handler object. + + + + Gets or sets the default handler method to delegate to, + for the case where no specific listener method has been determined. + Out-of-the-box value is ("HandleMessage"}. + + The default handler method. + + + + Sets the default destination to send response messages to. This will be applied + in case of a request message that does not carry a "JMSReplyTo" field. + Response destinations are only relevant for listener methods that return + result objects, which will be wrapped in a response message and sent to a + response destination. + + Alternatively, specify a "DefaultResponseQueueName" or "DefaultResponseTopicName", + to be dynamically resolved via the DestinationResolver. + + + The default response destination. + + + + Sets the name of the default response queue to send response messages to. + This will be applied in case of a request message that does not carry a + "NMSReplyTo" field. + Alternatively, specify a JMS Destination object as "defaultResponseDestination". + + The name of the default response destination queue. + + + + Sets the name of the default response topic to send response messages to. + This will be applied in case of a request message that does not carry a + "NMSReplyTo" field. + Alternatively, specify a JMS Destination object as "defaultResponseDestination". + + The name of the default response destination topic. + + + + Gets or sets the destination resolver that should be used to resolve response + destination names for this adapter. + The default resolver is a . + Specify another implementation, for other strategies, perhaps from a directory service. + + The destination resolver. + + + + Gets or sets the message converter that will convert incoming JMS messages to + listener method arguments, and objects returned from listener + methods back to NMS messages. + + + The default converter is a {@link SimpleMessageConverter}, which is able + to handle BytesMessages}, TextMessages, MapMessages, and ObjectMessages. + + + The message converter. + + + + Internal class combining a destination name and its target destination type (queue or topic). + + + + + Common base class for all containers which need to implement listening + based on a Connection (either shared or freshly obtained for each attempt). + Inherits basic Connection and Session configuration handling from the + base class. + + + + This class provides basic lifecycle management, in particular management + of a shared Connection. Subclasses are supposed to plug into this + lifecycle, implementing the as well as + + + Juergen Hoeller + Mark Pollack(.NET) + + + + The monitor object to lock on when performing operations on the connection. + + + + + The monitor object to lock on when performing operations that update the lifecycle of the container. + + + + + Call base class method, then and then + + + + + Validates the configuration of this container. The default implementation + is empty. To be overriden in subclasses. + + + + + Calls when the application context destroys the container instance. + + + + + Initializes this container. Creates a Connection, starts the Connection + (if the property hasn't been turned off), and calls + . + + If startup failed + + + + Stop the shared connection, call , and close this container. + + + + + Starts this container. + + if starting failed. + + + + Start the shared Connection, if any, and notify all invoker tasks. + + + + + Stops this container. + + if stopping failed. + + + + Notify all invoker tasks and stop the shared Connection, if any. + + if thrown by NMS API methods. + + + + + Register any invokers within this container. + Subclasses need to implement this method for their specific + invoker management process. A shared Connection, if any, will already have been + started at this point. + + + + + Close the registered invokers. Subclasses need to implement this method + for their specific invoker management process. A shared Connection, if any, + will automatically be closed afterwards. + + + + + Establishes a shared Connection for this container. + + + + The default implementation delegates to + which does one immediate attempt and throws an exception if it fails. + Can be overridden to have a recovery process in place, retrying + until a Connection can be successfully established. + + + If thrown by NMS API methods + + + + Refreshes the shared connection that this container holds. + + + Called on startup and also after an infrastructure exception + that occurred during invoker setup and/or execution. + + If thrown by NMS API methods + + + + Creates the shared connection for this container. + + + The default implementation creates a standard Connection + and prepares it through + + the prepared Connection + if the creation failed. + + + + Prepares the given connection, which is about to be registered + as shared Connection for this container. + + + The default implementation sets the specified client id, if any. + Subclasses can override this to apply further settings. + + The connection to prepare. + If the preparation efforts failed. + + + + Starts the shared connection. + + If thrown by NMS API methods + + + + + Stops the shared connection. + + if thrown by NMS API methods. + + + + Gets or sets the client id for a shared Connection created and used by this container. + + + Note that client ids need to be unique among all active Connections + of the underlying JMS provider. Furthermore, a client id can only be + assigned if the original ConnectionFactory hasn't already assigned one. + + The client id. + + + Set whether to automatically start the listener after initialization. +

Default is "true"; set this to "false" to allow for manual startup.

+
+
+ + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Gets a value indicating whether this container is currently running, + that is, whether it has been started and not stopped yet. + + + true if this container is running; otherwise, false. + + + + + Gets a value indicating whether this container's listeners are generally allowed to run. + + + + >This implementation always returns true; the default 'running' + state is purely determined by /. + + + Subclasses may override this method to check against temporary + conditions that prevent listeners from actually running. In other words, + they may apply further restrictions to the 'running' state, returning + false if such a restriction prevents listeners from running. + + + true if running allowed; otherwise, false. + + + + Gets a value indicating whether this container is currently active, + that is, whether it has been set up but not shut down yet. + + true if active; otherwise, false. + + + Return whether a shared NMS Connection should be maintained + by this listener container base class. + + + + + + Gets the shared connection maintained by this container. + Available after initialization. + + The shared connection (never null) + if this container does not maintain a + shared Connection, or if the Connection hasn't been initialized yet. + + + + + + Exception that indicates that the initial setup of this container's + shared Connection failed. This is indicating to invokers that they need + to establish the shared Connection themselves on first access. + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class, with the specified message + and root cause exception + + The message. + The inner exception. + + + + Initializes a new instance of the class. + + The SerializationInfo that holds the serialized object data about the exception being thrown. + The StreamingContext that contains contextual information about the source or destination. + + + + Abstract base class for message listener containers. Can either host + a standard NMS MessageListener or a Spring-specific + + + + + + Validate that the destination is not null and that if the subscription is durable, then we are not + using the Pub/Sub domain. + + + + + Executes the specified listener, + committing or rolling back the transaction afterwards (if necessary). + + The session to operate on. + The received message. + + + + + + + + Executes the specified listener, + committing or rolling back the transaction afterwards (if necessary). + + The session to operate on. + The received message. + If thrown by NMS API methods. + + + + + + + Invokes the specified listener: either as standard NMS MessageListener + or (preferably) as Spring SessionAwareMessageListener. + + The session to operate on. + The received message. + If thrown by NMS API methods. + + + + + Invoke the specified listener as Spring SessionAwareMessageListener, + exposing a new NMS Session (potentially with its own transaction) + to the listener if demanded. + + The Spring ISessionAwareMessageListener to invoke. + The session to operate on. + The received message. + If thrown by NMS API methods. + + + + + + Invoke the specified listener as standard JMS MessageListener. + + Default implementation performs a plain invocation of the + OnMessage methods + The listener to invoke. + The received message. + if thrown by the NMS API methods + + + + Perform a commit or message acknowledgement, as appropriate + + The session to commit. + The message to acknowledge. + In case of commit failure + + + + Determines whether the given Session is locally transacted, that is, whether + its transaction is managed by this listener container's Session handling + and not by an external transaction coordinator. + + + The Session's own transacted flag will already have been checked + before. This method is about finding out whether the Session's transaction + is local or externally coordinated. + + The session to check. + + true if the is session locally transacted; otherwise, false. + + + + + + Perform a rollback, if appropriate. + + The session to rollback. + In case of a rollback error + + + + Perform a rollback, handling rollback excepitons properly. + + The session to rollback. + The thrown application exception. + in case of a rollback error. + + + + Handle the given exception that arose during listener execution. + + + The default implementation logs the exception at error level, + not propagating it to the JMS provider - assuming that all handling of + acknowledgement and/or transactions is done by this listener container. + This can be overridden in subclasses. + + The exceptin to handle + + + + Invokes the error handler. + + The exception. + + + + Invokes the registered exception listener, if any. + + The exception that arose during NMS processing. + + + + + Checks the message listener, throwing an exception + if it does not correspond to a supported listener type. + By default, only a standard JMS MessageListener object or a + Spring object will be accepted. + + The message listener. + + + + Gets or sets the destination to receive messages from. Will be null + if the configured destination is not an actual Destination type; + c.f. when the destination is a String. + + The destination. + + + + Gets or sets the name of the destination to receive messages from. + Will be null if the configured destination is not a + string type; c.f. when it is an actual Destination object. + + The name of the destination. + + + + Gets or sets the message selector. + + The message selector expression (or null if none).. + + + + Gets or sets the message listener to register. + + + + + This can be either a standard NMS MessageListener object or a + Spring object. + + + The message listener. + + + + Gets or sets a value indicating whether the subscription is durable. + + + Set whether to make the subscription durable. The durable subscription name + to be used can be specified through the "DurableSubscriptionName" property. + Default is "false". Set this to "true" to register a durable subscription, + typically in combination with a "DurableSubscriptionName" value (unless + your message listener class name is good enough as subscription name). + + Only makes sense when listening to a topic (pub-sub domain). + + true if the subscription is durable; otherwise, false. + + + + Gets or sets the name of the durable subscription to create. + + + To be applied in case of a topic (pub-sub domain) with subscription durability activated. + The durable subscription name needs to be unique within this client's + client id. Default is the class name of the specified message listener. + Note: Only 1 concurrent consumer (which is the default of this + message listener container) is allowed for each durable subscription. + + + The name of the durable subscription. + + + + Gets or sets the exception listener to notify in case of a NMSException thrown + by the registered message listener or the invocation infrastructure. + + The exception listener. + + + + Sets an ErrorHandler to be invoked in case of any uncaught exceptions thrown + while processing a Message. By default there will be no ErrorHandler + so that error-level logging is the only result. + + The error handler. + + + + Gets or sets a value indicating whether to expose listener session to a registered + as well as to calls. + + + Default is "true", reusing the listener's Session. + Turn this off to expose a fresh Session fetched from the same + underlying Connection instead, which might be necessary + on some messaging providers. + Note that Sessions managed by an external transaction manager will + always get exposed to + calls. So in terms of NmsTemplate exposure, this setting only affects + locally transacted Sessions. + + + + true if expose listener session; otherwise, false. + + + + + Gets or sets a value indicating whether to accept messages while + the listener container is in the process of stopping. + + + + Return whether to accept received messages while the listener container + receive attempt. Switch this flag on to fully process such messages + even in the stopping phase, with the drawback that even newly sent + messages might still get processed (if coming in before all receive + timeouts have expired). + + + Aborting receive attempts for such incoming messages + might lead to the provider's retry count decreasing for the affected + messages. If you have a high number of concurrent consumers, make sure + that the number of retries is higher than the number of consumers, + to be on the safe side for all potential stopping scenarios. + + + + true if accept messages while in the process of stopping; otherwise, false. + + + + + Internal exception class that indicates a rejected message on shutdown. + Used to trigger a rollback for an external transaction manager in that case. + + + + + MessageResourceHolder marker subclass that indicates local exposure, + i.e. that does not indicate an externally managed transaction. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Initializes a new instance of the class. + + The session. + + + + Exception thrown when the maximum connection recovery time has been exceeded. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class, with the specified message + + The message. + + + + Initializes a new instance of the class, with the specified message + and root cause exception + + The message. + The inner exception. + + + + Initializes a new instance of the class. + + The SerializationInfo that holds the serialized object data about the exception being thrown. + The StreamingContext that contains contextual information about the source or destination. + + + + Message listener container that uses the plain NMS client API's + MessageConsumer.Listener method to create concurrent + MessageConsumers for the specified listeners. + + Mark Pollack + + + + The default recovery time interval between connection reconnection attempts + + + + + The total time connection recovery will be attempted. + + + + + Call base class for valdation and then check that if the subscription is durable that the number of + concurrent consumers is equal to one. + + + + + Creates the specified number of concurrent consumers, + in the form of a JMS Session plus associated MessageConsumer + + + + + + Re-initializes this container's NMS message consumers, + if not initialized already. + + + + + Registers this listener container as NMS ExceptionListener on the shared connection. + + + + + + implementation, invoked by the NMS provider in + case of connection failures. Re-initializes this listener container's + shared connection and its sessions and consumers. + + The reported connection exception. + + + + Refresh the underlying Connection, not returning before an attempt has been + successful. Called in case of a shared Connection as well as without shared + Connection, so either needs to operate on the shared Connection or on a + temporary Connection that just gets established for validation purposes. + + + The default implementation retries until it successfully established a + Connection, for as long as this message listener container is active. + Applies the specified recovery interval between retries. + + + + + The amount of time to sleep in between recovery attempts. + + + + + Initialize the Sessions and MessageConsumers for this container. + + in case of setup failure. + + + + Creates a MessageConsumer for the given Session, + registering a MessageListener for the specified listener + + The session to work on. + the MessageConsumer"/> + if thrown by NMS methods + + + + Close the message consumers and sessions. + + NMSException if destruction failed + + + + Creates a MessageConsumer for the given Session and Destination. + + The session to create a MessageConsumer for. + The destination to create a MessageConsumer for. + The new MessageConsumer + + + + Gets or sets a value indicating whether to inhibit the delivery of messages published by its own connection. + Default is "false". + + true if should inhibit the delivery of messages published by its own connection; otherwise, false. + + + + Specify the number of concurrent consumers to create. Default is 1. + + + Raising the number of concurrent consumers is recommendable in order + to scale the consumption of messages coming in from a queue. However, + note that any ordering guarantees are lost once multiple consumers are + registered. In general, stick with 1 consumer for low-volume queues. + Do not raise the number of concurrent consumers for a topic. + This would lead to concurrent consumption of the same message, + which is hardly ever desirable. + + + The concurrent consumers. + + + + Sets the time interval between connection recovery attempts. The default is 5 seconds. + + The recovery interval. + + + + Sets the max recovery time to try reconnection attempts. The default is 10 minutes. + + The max recovery time. + + + + Always use a shared NMS connection + + + + Strategy interface that specifies a IMessageConverter + between .NET objects and NMS messages. + + + Mark Pollack + Juergen Hoeller + Mark Pollack (.NET) + + + Convert a .NET object to a NMS Message using the supplied session + to create the message object. + + the object to convert + + the Session to use for creating a NMS Message + + the NMS Message + + NMSException if thrown by NMS API methods + MessageConversionException in case of conversion failure + + + Convert from a NMS Message to a .NET object. + the message to convert + + the converted .NET object + + MessageConversionException in case of conversion failure + + + + Provides a layer of indirection when adding the 'type' of the object as a message property. + + Mark Pollack + + + + Convert from a type to a string. + + The type of object to convert. + + + + + Convert from a string to a type + + The type id. + + + + + Gets the name of the field in the message that has type information.. + + The name of the type id field. + + + Thrown by IMessageConverter implementations when the conversion + of an object to/from a Message fails. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Creates a new instance of the IMessageConverterException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the IMessageConverterException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Initializes a new instance of the class. + + The SerializationInfo that holds the serialized object data about the exception being thrown. + The StreamingContext that contains contextual information about the source or destination. + + + A simple message converter that can handle ITextMessages, IBytesMessages, + IMapMessages, and IObjectMessages. Used as default by NmsTemplate, for + ConvertAndSend and ReceiveAndConvert operations. + +

Converts a String to a NMS ITextMessage, a byte array to a NMS IBytesMessage, + a Map to a NMS IMapMessage, and a Serializable object to a NMS IObjectMessage + (or vice versa).

+ + +
+ Juergen Hoeller + Mark Pollack (.NET) +
+ + Convert a .NET object to a NMS Message using the supplied session + to create the message object. + + the object to convert + + the Session to use for creating a NMS Message + + the NMS Message + + NMSException if thrown by NMS API methods + MessageConversionException in case of conversion failure + + + Convert from a NMS Message to a .NET object. + the message to convert + + the converted .NET object + + MessageConversionException in case of conversion failure + + + Create a NMS ITextMessage for the given String. + the String to convert + + current NMS session + + the resulting message + + NMSException if thrown by NMS methods + + + Create a NMS IBytesMessage for the given byte array. + the byyte array to convert + + current NMS session + + the resulting message + + NMSException if thrown by NMS methods + + + Create a NMS IMapMessage for the given Map. + the Map to convert + + current NMS session + + the resulting message + + NMSException if thrown by NMS methods + + + Create a NMS IObjectMessage for the given Serializable object. + the Serializable object to convert + + current NMS session + + the resulting message + + NMSException if thrown by NMS methods + + + Extract a String from the given ITextMessage. + the message to convert + + the resulting String + + NMSException if thrown by NMS methods + + + Extract a byte array from the given IBytesMessage. + the message to convert + + the resulting byte array + + NMSException if thrown by NMS methods + + + Extract a IDictionary from the given IMapMessage. + the message to convert + + the resulting Map + + NMSException if thrown by NMS methods + + + + Extracts the serializable object from the given object message. + + The message to convert. + The resulting serializable object. + + + + Provides a layer of indirection when adding the 'type' of the object as a message property. + + + + + Initializes a new instance of the [ERROR: invalid expression DeclaringTypeKind]. + + + + + Convert from a type to a string. + + The type of object to convert. + + + + + Convert from a string to a type. Will look into the IdTypeMapping dictionary first to resolve the + type, then check if it is the well known typeId of 'Hashtable' followed by a strategy to resolve a fully qualfied + name from a simple type name. This strategy requires that + + The type id. + The type associated with the string. + If the type can not be resolved. + + + + Afters the properties set. + + + + + Gets or sets the id type mapping. + + The id type mapping. + + + + Gets the name of the field in the message that has type information.. + + The name of the type id field. + + + + Sets the default hashtable class. + + The default hashtable class. + + + + Gets or sets a value indicating whether use the assembly qualified name when creating a string from a type reference. + + + By setting this property to true you will be able to easily share types that are available on both the publisher and + consumer with minimal configuration. However, this means that the publishers and subscribers would be tightly coupled + despite the use of loosely coupled messaging middleware. + + + true if to the assembly qualified name; otherwise, false. + + + + + Gets or sets the default namespace. + + The default namespace. + + + + Gets or sets the default name of the assembly. + + The default name of the assembly. + + + + Convert an object via XML serialization for sending via an ITextMessage + + Mark Pollack + + + + Convert a .NET object to a NMS Message using the supplied session + to create the message object. + + the object to convert + the Session to use for creating a NMS Message + the NMS Message + NMSException if thrown by NMS API methods + MessageConversionException in case of conversion failure + + + + Gets the XML string for an object + + The object to convert. + XML string + + + + Convert from a NMS Message to a .NET object. + + the message to convert + the converted .NET object + MessageConversionException in case of conversion failure + + + + Gets the type of the target given the message. + + The message. + Type of the target + + + + Converts a byte array to a UTF8 string. + + The characters. + UTF8 string + + + + Converts a UTF8 string to a byte array + + The p XML string. + + + + + Sets the type mapper. + + The type mapper. + + + + Gets or sets a value indicating whether encoder should emit UTF8 byte order mark. Default is false. + + + true to specify that a Unicode byte order mark is provided; otherwise, false. + + + + + Gets or sets a value indicating whether to throw an exception on invalid bytes. Default is true. + + true to specify that an exception be thrown when an invalid encoding is detected; otherwise, false. + + + + Simple DestinationResolver implementation resolving destination names + as dynamic destinations. + + Juergen Hoeller + Mark Pollack (.NET) + + + Strategy interface for resolving NMS destinations. + + + Used by MessageTemplate for resolving + destination names from simple Strings to actual + IDestination implementation instances. + + + The default DestinationResolver implementation used by + MessageTemplate instances is the + DynamicDestinationResolver class. Consider using the + JndiDestinationResolver for more advanced scenarios. + + + Juergen Hoeller + Mark Pollack (.NET) + + + Resolve the given destination name, either as located resource + or as dynamic destination. + + the current NMS Session + + the name of the destination + + true if the domain is pub-sub, false if P2P + + the NMS destination (either a topic or a queue) + + NMSException if resolution failed + + + Resolve the given destination name, either as located resource + or as dynamic destination. + + the current NMS Session + + the name of the destination + + true if the domain is pub-sub, false if P2P + + the NMS destination (either a topic or a queue) + + NMSException if resolution failed + + + Resolve the given destination name to a Topic. + the current NMS Session + + the name of the desired Topic. + + the NMS Topic name + + NMSException if resolution failed + + + Resolve the given destination name to a Queue. + the current NMS Session + + the name of the desired Queue. + + the NMS Queue name + + NMSException if resolution failed + + + + Generic utility methods for working with NMS. Mainly for internal use + within the framework, but also useful for custom NMS access code. + + + + Close the given NMS Connection and ignore any thrown exception. + This is useful for typical finally blocks in manual NMS code. + + the NMS Connection to close (may be null) + + + + Close the given NMS Connection and ignore any thrown exception. + This is useful for typical finally blocks in manual NMS code. + + the NMS Connection to close (may be null) + + whether to call stop() before closing + + + + Close the given NMS Session and ignore any thrown exception. + This is useful for typical finally blocks in manual NMS code. + + the NMS Session to close (may be null) + + + + Close the given NMS MessageProducer and ignore any thrown exception. + This is useful for typical finally blocks in manual NMS code. + + the NMS MessageProducer to close (may be null) + + + + Close the given NMS MessageConsumer and ignore any thrown exception. + This is useful for typical finally blocks in manual NMS code. + + the NMS MessageConsumer to close (may be null) + + + + Commit the Session if not within a distributed transaction. + Needs investigation - no distributed tx in .NET messaging providers + the NMS Session to commit + + NMSException if committing failed + + + Rollback the Session if not within a distributed transaction. + Needs investigation - no distributed tx in EMS + the NMS Session to rollback + + NMSException if committing failed + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.dll b/Resources/Libraries/Spring.NET/Spring.Messaging.dll new file mode 100644 index 0000000000000000000000000000000000000000..6f42daa455b78291411fca6a419d5f2ce3337dac GIT binary patch literal 56320 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ΜoO1I;-F&9AMx|X|!?2A!s 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.pdb b/Resources/Libraries/Spring.NET/Spring.Messaging.pdb new file mode 100644 index 0000000000000000000000000000000000000000..38ee9b4ab44aa4c6e594452898c5cb13189964d7 GIT binary patch literal 161280 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� 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%0A1R<%D9oLbHnG@8tmh`NTDxsCkF%)SYKi^NR z$L1JpZlL;8sG|6K1pcZdU%n64LEX0Ff->kOxT=xAH?0AU+!lt^^+jQhshnhv(Iy3szD8y1aM6VZ3#yS zJqc%A8Ny#eUBXU6RKid~S;ALBRl-g}PPzf%62f0XQ^HL`UBXYgmV{k7r~ndr9|WVo zXmACX3~E6gxCVR#Oaa#d3CE9tde8u-f@y%JiKc@Y;5sl9%mN<=zW`=~>%k4+6JQRw z5!?iB26MqJ;1|IsfyDTHAo~?Q1r~r?!KcAzz(UXj7J+8a0y5w>a64EGmVnQKJ3uQ~ z3fe$B=m5(=C+Gs*U^)04_&n$VE5H}P7r{z!C-`OXC9n$I1?~o42CKn6;49#(U=3Ic zz6SmWSO@L}zXI+9>%slt>)=gMYv3DT19%AhI`|E+5j+gO34Rl70*`>-0^b6g z!K2{Y;J3jRuoe7I@H^l!@HqHi;CI0`@C5ih@cUppcoO^p_(QM*JO%y;{BQ6ycn172 z_!F=bJPZC5{2AB;``Y{u=B7FM+=Se+ym)d%@p*{};RpUIX6+-vj%=>)`v~AHjZb0Q>;_6F3MCfqw>XfFFXx;9tOxz!C5!_*d|6 z;3#+t{22TM90PBIpMrk}$H58kAK+&oD&l`o4CHMUGWPWY{lVEl-ght%$h2}U7zAX0 e%6TB|m;`+?s67c^nvS2-e(r&vd*HvP2mTY#llT$< literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Messaging.xml b/Resources/Libraries/Spring.NET/Spring.Messaging.xml new file mode 100644 index 00000000..69cc921d --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Messaging.xml @@ -0,0 +1,2685 @@ + + + + Spring.Messaging + + + + + A implementation that caches MessageQueue and IMessageConverter + instances. The MessageQueue objects are created by retrieving them by-name from the + ApplicationContext. + + Mark Pollack + + + + An interface for creating MessageQueue and IMessageConverter objects from object definitions + defined in the application context. + + + MessageQueue and IMessageConverter objects have methods that are generally not thread safe, + (IMessageConverter classes rely on IMessageFormatter objects that are not thread safe). + As such, a major reason to for this interface is to provide thread-local instances such that + appliation code need not be concerned with these resource management issues. + + Mark Pollack + + + + Registers the message queue, its creation specified via the factory method + MessageQueueCreatorDelegate, with the provided name in the application context + + Name of the message queue object. + The message queue creator delegate. + + + + Creates the message queue given its name in the application context. + + Name of the message queue object. + A MessageQueue instance configured via the application context + + + + Determines whether the application context contains the message queue object definition. + + Name of the message queue object. + + true if the application context contains the specified message queue object name; otherwise, false. + + + + + Registers the message converter, its creation specified via the factory method + MessageConverterCreatorDelegate, with the provided name in the application context. + + Name of the message converter. + The message converter creator delegate. + + + + Creates the message converter given its name in the application context. + + Name of the message converter object. + A IMessageConverter instance configured via the application context + + + + Determines whether the application context contains the message queue object definition. + + Name of the message converter object. + + true if the application context contains the specified message message converter object name; otherwise, false. + + + + + The instance for this class. + + + + + Registers the message queue, its creation specified via the factory method + MessageQueueCreatorDelegate, with the provided name in the application context + + Name of the message queue object. + The message queue creator delegate. + + + + Creates the message queue given its name in the application context. + + Name of the message queue object. + + A MessageQueue instance configured via the application context + + + + + Determines whether the application context contains the message queue object definition. + + Name of the message queue object. + + true if the application context contains the specified message queue object name; otherwise, false. + + + + + Registers the message converter. + + Name of the message converter. + The message converter creator delegate. + + + + Creates the message converter given its name in the application context. + + Name of the message converter object. + + A IMessageConverter instance configured via the application context + + + + + Determines whether the application context contains the message queue object definition. + + Name of the message converter object. + + true if the application context contains the specified message message converter object name; otherwise, false. + + + + + Gets or sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Specifies a basic set of helper MSMQ opertions. + + + Implemented by . Not often used but a useful option + to enhance testability, as it can easily be mocked or stubbed. + + + Provides MessageQueueTemplate's + Send(..) and receive(..) methods that mirror various MSMQ MessageQueue + API methods. + + + Mark Pollack + + + + Send the given object to the default destination, converting the object + to a MSMQ message with a configured IMessageConverter. + + This will only work with a default destination queue specified! + The obj. + + + Send the given object to the default destination, converting the object + to a MSMQ message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + + the callback to modify the message + + if thrown by MSMQ API methods +
+ + Send the given object to the specified destination, converting the object + to a MSMQ message with a configured and resolving the + destination name to a using a + + the name of the destination queue + to send this message to (to be resolved to an actual MessageQueue + by a IMessageQueueFactory) + + the object to convert to a message + + NMSException if there is any problem + + + Send the given object to the specified destination, converting the object + to a MSMQ message with a configured and resolving the + destination name to a with an + The callback allows for modification of the message after conversion. + + the name of the destination queue + to send this message to (to be resolved to an actual MessageQueue + by a IMessageQueueFactory) + + the object to convert to a message + + the callback to modify the message + + if thrown by MSMQ API methods + + + + Receive and convert a message synchronously from the default message queue. + + The converted object + if thrown by MSMQ API methods. Note an + exception will be thrown if the timeout of the syncrhonous recieve operation expires. + + + + + Receives and convert a message synchronously from the specified message queue. + + Name of the message queue object. + the converted object + if thrown by MSMQ API methods. Note an + exception will be thrown if the timeout of the syncrhonous recieve operation expires. + + + + + Receives a message on the default message queue using the transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + A message. + + + + Receives a message on the specified queue using the transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + Name of the message queue object. + + + + + Sends the specified message to the default message queue using the + transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + The message to send + + + + Sends the specified message to the message queue using the + transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + Name of the message queue object. + The message. + + + + Sends the specified message on the provided MessageQueue using the + transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + + Note that it is the callers responsibility to ensure that the MessageQueue instance + passed into this not being access simultaneously by other threads. + + A transactional send (either local or DTC transaction) will be + attempted for a transacitonal queue, falling back to a single-transaction send + to a transactional queue if there is not ambient Spring managed transaction. + The DefaultMessageQueue to send a message to. + The message to send + + + + MessageQueueResourceHolder marker subclass that indicates local exposure, + i.e. that does not indicate an externally managed transaction. + + Mark Pollack + + + + MessageQueue resource holder, wrapping a MessageQueueTransaction. + MessageQueueTransactionManager binds instances of this class to the thread. + + + This is an SPI class, not intended to be used by applications. + + Mark Pollack + + + + Initializes a new instance of the class. + + The message queue transaction. + + + + Gets or sets the message queue transaction. + + The message queue transaction. + + + + Initializes a new instance of the class. + + The message queue transaction. + + + + To be used with MessageQueueTemplate's send method that + convert an object to a message. + + + It allows for further modification of the message after it has been processed + by the converter. This is useful for setting of Message properties (e.g. + CorrelationId, AppSpecific, TimeToReachQueue). + + Mark Pollack + + + + Convenient super class for application classes that need MSMQ access. + + + Override the InitGateway method to perform custom startup tasks. + + Mark Pollack + + + + Subclasses can override this for custom initialization behavior. + Gets called after population of this instance's properties. + + + + + Gets or sets the message queue template. . + + The message queue template. + + + + Gets the message queue factory, a convenience method. + + The message queue factory. + + + + Encapsulates additional metadata information about the MessageQueue that can not be easily obtained + from the MessageQueue itself. + + + + + Initializes a new instance of the class. + + if set to true [remote queue]. + if set to true [remote queue is transactional]. + + + + Gets or sets a value indicating whether the queue is a remote queue. + + + The operations that one can perform on the MessageQueue depend on if it is local or remote, for + example checking if it is transactional. This is very difficult to determine programmatically. + The property was made virtual so it can be overridden to take into account custom heuristics you + may want to use to determine this programmatically. + + true if remote queue; otherwise, false. + + + + Gets or sets a value indicating whether the remote queue is transactional. + + + true if the remote queue is transactional; otherwise, false. + + + + + Retrieves MessageQueueMetadata from the cache. + + The queue path. + + Item for the specified , or null. + + + + + Removes the specified queue path from the cache + + The queue path. + + + + Removes collection of MessageQueueMetaCache from the cache. + + + Array of MessageQueue paths to remove. + + + + + Removes all MessageQueueMetadata from the cache. + + + + + Gets the number of items in the cache. + + + + + Gets a collection of all cache queue paths. + + + + + Helper class that simplifies MSMQ access code. + + + + Using the System.Messaging.MessageQueue class directly in application code has a number of + shortcomings, namely that most operations are not thread safe (in particular Send) and + IMessageFormatter classes are not thread safe either. + + + The MessageQueueTemplate class overcomes these limitations letting you use a single instance + of MessageQueueTemplate across multiple threads to perform standard MessageQueue opertations. + Classes that are not thread safe are obtained and cached in thread local storage via an + implementation of the interface, specifically + . + + + You can access the thread local instance of the MessageQueue associated with this template + via the Property DefaultMessageQueue. + + + The template's Send methods will select an appropriate transaction delivery settings so + calling code does not need to explicitly manage this responsibility themselves and thus + allowing for greater portability of code across different, but common, transactional usage scenarios. + + A transactional send (either local or DTC transaction) will be + attempted for a transacitonal queue, falling back to a single-transaction send + to a transactional queue if there is not ambient Spring managed transaction. + + The overloaded ConvertAndSend and ReceiveAndConvert methods inherit the transactional + semantics of the previously described Send method but more importantly, they help to ensure + that thread safe access to instances are + used as well as providing additional central location to put programmic logic that translates + between the MSMQ Message object and the your business objects. This for example is useful if you + need to perform additional translation operations after calling a IMessageFormatter instance or + want to directly extract and process the Message body contents. + + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + Name of the message queue as registered in the Spring container. + + + + Invoked by an + after it has injected all of an object's dependencies. + + + Ensure that the DefaultMessageQueueObjectName property is set, creates + a default implementation of the interface + () that retrieves instances on a per-thread + basis, and registers in the Spring container a default implementation of + () with a + simple System.String as its TargetType. + + + + + Send the given object to the default destination, converting the object + to a MSMQ message with a configured IMessageConverter. + + The obj. + This will only work with a default destination queue specified! + + + + Send the given object to the default destination, converting the object + to a MSMQ message with a configured IMessageConverter. The IMessagePostProcessor + callback allows for modification of the message after conversion. +

This will only work with a default destination specified!

+
+ the object to convert to a message + the callback to modify the message + if thrown by MSMQ API methods +
+ + + Send the given object to the specified destination, converting the object + to a MSMQ message with a configured and resolving the + destination name to a using a + + the name of the destination queue + to send this message to (to be resolved to an actual MessageQueue + by a IMessageQueueFactory) + the object to convert to a message + NMSException if there is any problem + + + + Send the given object to the specified destination, converting the object + to a MSMQ message with a configured and resolving the + destination name to a with an + The callback allows for modification of the message after conversion. + + the name of the destination queue + to send this message to (to be resolved to an actual MessageQueue + by a IMessageQueueFactory) + the object to convert to a message + the callback to modify the message + if thrown by MSMQ API methods + + + + Receive and convert a message synchronously from the default message queue. + + The converted object + if thrown by MSMQ API methods. Note an + exception will be thrown if the timeout of the syncrhonous recieve operation expires. + + + + + Receives and convert a message synchronously from the specified message queue. + + Name of the message queue object. + the converted object + if thrown by MSMQ API methods. Note an + exception will be thrown if the timeout of the syncrhonous recieve operation expires. + + + + + Receives a message on the default message queue using the transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + A message. + + + + Receives a message on the specified queue using the transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + Name of the message queue object. + + + + + Sends the specified message to the default message queue using the + transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + The message to send + + + + Sends the specified message to the message queue using the + transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + Name of the message queue object. + The message. + + + + Sends the specified message on the provided MessageQueue using the + transactional settings as dicted by MessageQueue's Transactional property and + the current Spring managed ambient transaction. + + The DefaultMessageQueue to send a message to. + The message to send + + Note that it is the callers responsibility to ensure that the MessageQueue instance + passed into this not being access simultaneously by other threads. + + A transactional send (either local or DTC transaction) will be + attempted for a transacitonal queue, falling back to a single-transaction send + to a transactional queue if there is not ambient Spring managed transaction. + + + + Sends the message to the given message queue. + + If System.Transactions.Transaction.Current is null, then send based on + the transaction semantics of the queue definition. See + The message queue. + The message. + + + + Send the message queue selecting the appropriate transactional delivery options. + + + + If the message queue is transactional and there is an ambient MessageQueueTransaction + in thread local storage (put there via the use of Spring's MessageQueueTransactionManager + or TransactionalMessageListenerContainer), the message will be sent transactionally using the + MessageQueueTransaction object in thread local storage. This lets you group together multiple + messaging operations within the same transaction without having to explicitly pass around the + MessageQueueTransaction object. + + + If the message queue is transactional but there is no ambient MessageQueueTransaction, + then a single message transaction is created on each messaging operation. + (MessageQueueTransactionType = Single). + + + If there is an ambient System.Transactions transaction then that transaction will + be used (MessageQueueTransactionType = Automatic). + + + If the queue is not transactional, then a non-transactional send + (MessageQueueTransactionType = None) is used. + + + The mq. + The MSG. + + + + Does the send message transaction. + + The mq. + The transaction to use. + The MSG. + + + + Does the send message queue non transactional. + + The mq. + The transaction to use. + The MSG. + + + + Sends using MessageQueueTransactionType.Automatic transaction type + + The message queue. + The message. + + + + Template method to convert the message if it is not null. + + The message. + The converted message ,or null if no message converter is set. + + + + Checks if the default message queue if defined. + + + + + Gets or sets the message queue factory to use for creating MessageQueue and IMessageConverters. + Default value is one that support thread local instances. + + The message queue factory. + + + + Gets or sets the name of the default message queue as identified in the Spring container. + + The name of the message queue as identified in the Spring container. + + + + Gets or sets the name of the message converter object. The name will be passed to + the class to resolve it to an actual MessageQueue + instance. + + The default name is internally generated and will register an XmlMessageConverter + that uses an and a simple System.String as its TargetType. + The name of the message converter object. + + + + Gets the default message queue to be used on send/receive operations that do not + have a destination parameter. The MessageQueue instance is resolved using + the template's , the default implementaion + will return an unique instance per thread. + + The default message queue. + + + + Gets the message converter to use for this template. Used to resolve + object parameters to ConvertAndSend methods and object results + from ReceiveAndConvert methods. + + + The default + + The message converter. + + + + Gets or sets the receive timeout to be used on recieve operations. Default value is + MessageQueue.InfiniteTimeout (which is actually ~3 months). + + The receive timeout. + + + + Gets or sets the metadata cache. + + The metadata cache. + + + + Gets or sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + implementation for MSMQ. Binds a + MessageQueueTransaction to the thread. + + + + This local strategy is an alternative to executing MSMQ operations within + DTC transactions. Its advantage is that multiple MSMQ operations can + easily participate within the same local MessagingTransaction transparently when + using the class for send and recieve operations + and not pay the overhead of a DTC transaction. + + Transaction synchronization is turned off by default, as this manager might + be used alongside a IDbProvider-based Spring transaction manager such as the + ADO.NET . + which has stronger needs for synchronization. + + Mark Pollack + + + + Location where the message transaction is stored in thread local storage. + + + + + Initializes a new instance of the class. + + + Turns off transaction synchronization by default, as this manager might + be used alongside a DbProvider-based Spring transaction manager like + AdoPlatformTransactionManager, which has stronger needs for synchronization. + Only one manager is allowed to drive synchronization at any point of time. + + + + + Return the current transaction object. + + The current transaction object. + + If transaction support is not available. + + + In the case of lookup or system errors. + + + + + Check if the given transaction object indicates an existing transaction + (that is, a transaction which has already started). + + MessageQueueTransactionObject object returned by + . + + True if there is an existing transaction. + + + + + Begin a new transaction with the given transaction definition. + + Transaction object returned by + . + instance, describing + propagation behavior, isolation level, timeout etc. + + In the case of creation or system errors. + + + + + Suspend the resources of the current transaction. + + Transaction object returned by + . + + An object that holds suspended resources (will be kept unexamined for passing it into + .) + + + + + Resume the resources of the current transaction. + + Transaction object returned by + . + The object that holds suspended resources as returned by + . + + + + Perform an actual commit on the given transaction. + + The status representation of the transaction. + +

+ An implementation does not need to check the rollback-only flag. +

+
+
+ + + Perform an actual rollback on the given transaction, calls Transaction.Abort(). + + The status representation of the transaction. + + An implementation does not need to check the new transaction flag. + + + + + Set the given transaction rollback-only. Only called on rollback + if the current transaction takes part in an existing one. + + The status representation of the transaction. + Default implementation throws an IllegalTransactionStateException, + assuming that participating in existing transactions is generally not + supported. Subclasses are of course encouraged to provide such support. + + + In the case of system errors. + + + + + Cleanup resources after transaction completion. + + Transaction object returned by + . + + + Called after + and + + execution on any outcome. + + + + + + Utility methods to support Spring's MSMQ functionality + + + + + Registers the default message converter with the application context. + + The application context. + The name of the message converter to use for lookups with + . + + + + + Gets the message queue transaction from thread local storage + + The resource factory. + null if not found in thread local storage + + + Callback interface for resource creation. + Serving as argument for the GetMessageQueueTransaction method. + + + + + Return whether to allow for a local transaction that is synchronized with + a Spring-managed transaction (where the main transaction might be a ADO.NET-based + one for a specific IDbProvider, for example), with the MSMQ transaction + committing right after the main transaction. + Returns whether to allow for synchronizing a local MSMQ transaction + + + + + Provides basic lifecyle management methods for implementing a message listener container. + + + This base class does not assume any specific listener programming model + or listener invoker mechanism. It just provides the general runtime + lifecycle management needed for any kind of message-based listening mechanism. + + For a concrete listener programming model, check out the + subclass. For a concrete listener + invoker mechanism, check out the , + , or + classes. + + + Mark Pollack + + + + Delegates to and + + + + + Calls when the application context destroys the container instance. + + + + + Validates the configuration of this container + The default implementation is empty. To be overridden in subclasses. + + + + + Initializes this container. Calls the abstract method to + initialize the listening infrastructure (i.e. subclasses will typically + resolve a MessageQueue instance from a MessageQueueObjectName) and then calls + the abstract method DoStart if the property is set to true, + + + + + Sets the container state to inactive and not running, calls template method + + + + + + Starts this container. + + + + + Sets the state to running, can be overridden in subclasses. + + + + + Stops this instance. + + + + + Template method suitable for overriding that stops the container. + + + + + Check whether this container's listeners are generally allowed to run. + + + This implementation always returns true; the default 'running' + state is purely determined by and + + Subclasses may override this method to check against temporary + conditions that prevent listeners from actually running. In other words, + they may apply further restrictions to the 'running' state, returning + false if such a restriction prevents listeners from running. + + + false if such a restriction prevents listeners from running. + + + + Subclasses need to implement this method for their specific + listener management process. + + + + + Subclasses need to implement this method for their specific + listener management process. + + + + + Sets a value indicating whether to automatically start the container after initialization. + Default is "true"; set this to "false" to allow for manual startup though the + method. + + true if autostartup; otherwise, false. + + + + Gets a value indicating whether this Container is active, + that is, whether it has been set up but not shut down yet. + + true if active; otherwise, false. + + + + Gets a value indicating whether this Container is running, + that is whether it has been started and not stopped yet. + + true if running; otherwise, false. + + + + Return the object name that this listener container has been assigned + in its containing object factory, if any. + + + + + Defines a minimal programming model for message listener containers. They are expected to + invoke a upon asynchronous receives of a MSMQ message. Access to + obtain MessageQueue and instances is available through the + property, the default implementation + provides per-thread instances of these classes. + + Mark Pollack + + + + Most operations within the MessageListener container hierarchy use methods on the + MessageQueue instance which are thread safe (BeginPeek, BeginReceive, + EndPeek, EndReceive, GetAllMessages, Peek, and Receive). When using another + method on the shared MessageQueue instance, wrap calls with a lock on this object. + + + + + Validates that the is not null. If + is null, a is created. Can be be overridden in subclasses. + + + + + Template method that execute listener with the provided message if + is true. Subclasses will call + this method at the appropriate point in their processing lifecycle, for example + committing or rolling back a transaction if needed. + + Calls the template method + The message. + + + + Invokes the listener if it is not null. Invokes the method . + Can be overridden in subclasses. + + The message. + + + + Invokes the listener. Can be overriden in subclasses. + + The listener. + The message. + + + + Closes the queue handle. Cancel pending receive operation by closing the queue handle + To properly dispose of the queue handle, ensure that EnableConnectionCache=false on the + MessageQueue that this listener is configured to use. + + + + + Gets or sets the message queue factory. + + The message queue factory. + + + + Gets or sets the name of the message queue object, as refered to in the + Spring configuration, that will be used to create a DefaultMessageQueue instance + for consuming messages in the container. + + The name of the message queue object. + + + + Gets or sets the message listener. + + The message listener. + + + + Gets or sets the recovery time span, how long to sleep after an exception in processing occured + to avoid excessive redelivery attempts. Default value is 1 second. + + The recovery time span. + + + + Gets or sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Base class for listener container implementations which are based on Peeking for messages on + a MessageQueue. Peeking is the only resource efficient approach that can be used in + order to have MessageQueue receipt in conjunction with transactions, either local MSMQ transactions, + local ADO.NET based transactions, or DTC transactions. See SimpleMessageListenerContainer for + an implementation based on a synchronous receives and you do not require transactional support. + + + The number of threads that will be created for processing messages after the Peek occurs + is set via the property MaxConcurrentListeners. Each processing thread will continue to listen + for messages up until the the timeout value specified by ListenerTimeLimit or until + there are no more messages on the queue (which ver comes first). + + The default value of + ListenerTimeLimit is TimeSpan.Zero, meaning that only one attempt to recieve a message from the + queue will be performed by each listener thread. + + + The current implementation uses the standard .NET thread pool. Future implementations will + use a custom (and pluggable) thread pool. + + + + + + Retrieves a MessageQueue instance given the MessageQueueObjectName + + + + + Wait for all listener threads to exit and closes the DefaultMessageQueue. + + + + + Starts peeking on the DefaultMessageQueue. + + + + + Stops peeking on the message queue. + + + + + Starts peeking on the DefaultMessageQueue. This is the method that must be called + again at the end of message procesing to continue the peeking process. + + + + + The callback when the peek has completed. Schedule up to the maximum number of + concurrent listeners to receive messages off the queue. Delegates to the abstract + method DoReceiveAndExecute so that subclasses may customize the receiving process, + for example to surround the receive operation with transactional semantics. + + The async result. + + + + Execute the listener for a message received from the given queue + wrapping the entire operation in an external transaction if demanded. + + The DefaultMessageQueue upon which the call to receive should be + called. + + + + Subclasses perform a receive opertion on the message queue and execute the + message listener + + The DefaultMessageQueue. + true if received a message, false otherwise + + + + Waits for listener threads to exit. + + + + + Configures the initial peek thread, setting it to be a background thread. + Can be overridden in subclasses. + + The peek thread. + + + + Template method that gets called right when a new message has been received, + before attempting to process it. Allows subclasses to react to the event + of an actual incoming message, for example adapting their consumer count. + + The message. + + + + Template method that gets called right before a new message is received, i.e. + messageQueue.Receive(). + + It allows subclasses to modify the state of the MessageQueue + before receiving which maybe required when using remote queues + + + + + Gets or sets the listener time limit to continuously receive messages. + The value is specified in milliseconds. The default value is TimeSpan.Zero, + indicating to only perform one Receive operation per Peek trigger. + + The listener time limit in millis. + + + + Gets or sets the max concurrent listeners to receive messages. + + The max concurrent listeners. + + + + Gets or sets the message queue used for Peeking. + + The message queue. + + + + Provides common functionality to exception handlers that will send the exceptional message to + another queue. + + Allows for setting of MaxRetry limit and contains an internal dictionary to keep track + of the Message Ids of messages. + + Mark Pollack + + + + Synchronization object for access to messageMap protected variable + + + + + In-memory storage to keep track of Message Ids that have been already processed. + + + + + Ensure that the MessageQueueObject name is set and creates a + if no + is specified. + + Will attempt to create an instance of the DefaultMessageQueue to detect early + any configuraiton errors. + + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + + + + + Gets or sets the maximum retry count to reattempt processing of a message that has thrown + an exception + + The max retry count. + + + + Gets or sets the message queue factory. + + The message queue factory. + + + + Gets or sets the name of the message queue object to send the message that cannot be + processed successfully after MaxRetry delivery attempts. + + The name of the message queue object. + + + + Gets or sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + An implementation of a Peeking based MessageListener container that starts a transaction + before recieving a message. The implementation determines + the type of transaction that will be started. An exception while processing the message will + result in a rollback, otherwise a transaction commit will be performed. + + + The type of transaction that can be started can either be local transaction, + (e.g. , a local messaging transaction + (e.g. or a DTC based transaction, + (eg. . + + Transaction properties can be set using the property + and the transaction timeout via the property . + + + + + + Subclasses perform a receive opertion on the message queue and execute the + message listener + + The DefaultMessageQueue. + + true if received a message, false otherwise + + + + + Does the receive and execute using platform transaction manager. + + The message queue. + The transactional status. + true if should continue peeking, false otherwise. + + + + Rollback the transaction on exception. + + The transactional status. + The exception. + + + + Gets or sets the platform transaction manager. + + The platform transaction manager. + + + + Gets or sets the transaction definition. + + The transaction definition. + + + + Sets the transaction timeout to use for transactional wrapping, in seconds. + Default is none, using the transaction manager's default timeout. + + The transaction timeout. + + + + A MessageListenerContainer that uses distributed (DTC) based transactions. Exceptions are + handled by instances of . + + + + Starts a DTC based transaction before receiving the message. The transaction is + automaticaly promoted to 2PC to avoid the default behaivor of transactional promotion. + Database and messaging operations will commit or rollback together. + + + If you only want local message based transactions use the + . With some simple programming + you may also achieve 'exactly once' processing using the + . + + + Poison messages can be detected and sent to another queue using Spring's + . + + + + + + Set the transaction name to be the spring object name. + Call base class Initialize() functionality. + + + + + Does the receive and execute using TxPlatformTransactionManager. Starts a distributed + transaction before calling Receive. + + The message queue. + The transactional status. + + true if should continue peeking, false otherwise. + + + + + Handles the distributed transaction listener exception by calling the + if not null. + + The exception. + The message. + + + + Gets or sets the distributed transaction exception handler. + + The distributed transaction exception handler. + + + + Exception handler for use with DTC based message listener container. + such as . + See for + an implementation that detects poison messages and send them to another queue. + + + + + Determines whether the incoming message is a poison message. This method is + called before the is invoked. + + + The will call + if this method returns true and will + then commit the distibuted transaction (removing the message from the queue). + + The incoming message. + + true if it is a poison message; otherwise, false. + + + + + Handles the poison message. + + Typical implementations will move the message to another queue. + The will call this + method while still within a DTC-based transaction. + + The poison message. + + + + Called when an exception is thrown in listener processing. + + The exception. + The message. + + + + Exception handler called when an exception occurs during + non-transactional receive processing. + + + A non-transactional receive will remove the message from the queue. Non-transactional + receivers do not suffer from poison messages since there is no redelivery by MSMQ. + Typical actions to perform are to log the message or place it in another queue. + If placed in another queue, another message listener container can be used to + process the message later, assuming the root cause of the original exception is + transient in nature. + + + + + Called when an exception is thrown in listener processing. + + The exception. + The message. + + + + The callback invoked when a message is received. + + Mark Pollack + + + + Called when message is received. + + The message. + + + + The exception handler within a transactional context. + + + The return value indicates to the invoker (typically a + ) whether the + MessageTransaction that is associated with the delivery of this message + should be rolled back (placing the message back on the transactional queue + for redelivery) or commited (removing the message from the transactional queue) + + Mark Pollack + + + + Called when an exception is thrown during listener processing under the + scope of a . + + The exception. + The message. + The message queue transaction. + An action indicating if the caller should commit or rollback the + + + + + + Exception to be thrown when the execution of a listener method failed. + + Juergen Hoeller + Mark Pollack (.NET) + + + + Base exception class for exceptions thrown by Spring in Spring.Messaging + + Mark Pollack + + + Creates a new instance of the MessagingException class. + + + + Creates a new instance of the MessagingException class. with the specified message. + + + A message about the exception. + + + + + Creates a new instance of the MessagingException class with the specified message + and root cause. + + + A message about the exception. + + + The root exception that is being wrapped. + + + + + Creates a new instance of the MessagingException class. + + + The + that holds the serialized object data about the exception being thrown. + + + The + that contains contextual information about the source or destination. + + + + + Initializes a new instance of the class, with the specified message + + The message. + + + + Initializes a new instance of the class, with the specified message + and root cause exception + + The message. + The inner exception. + + + + Message listener adapter that delegates the handling of messages to target + listener methods via reflection , + with flexible message type conversion. + Allows listener methods to operate on message content types, completely + independent from the MSMQ API. + + + + By default, the content of incoming MSMQ messages gets extracted before + being passed into the target handler method, to let the target method + operate on message content types such as String or business object instead of + . Message type conversion is delegated to a Spring + By default, an + with TargetType set to System.String is used. If you do not want such automatic + message conversion taking place, then be sure to set the + MessageConverter property to null. + + + If a target handler method returns a non-null object (for example, with a + message content type such as String), it will get + wrapped in a MSMQ Message and sent to the response destination + (either using the MSMQ Message.ResponseQueue property or + ) specified default response queue + destination). + + + Find below some examples of method signatures compliant with this adapter class. + This first example uses the default that can + marhsall/unmarshall string values from the MSMQ Message. + + + public interface IMyHandler + { + void HandleMessage(string text); + } + + + The next example indicates a similar method signature but the name of the + handler method name has been changed to "DoWork", using the property + + + + public interface IMyHandler + { + void DoWork(string text); + } + + If your implementation will return multiple object + types, overloading the handler method is perfectly acceptible, the most specific matching + method will be used. A method with an object signature would be consider a + 'catch-all' method + + + public interface IMyHandler + { + void DoWork(string text); + void DoWork(OrderRequest orderRequest); + void DoWork(InvoiceRequest invoiceRequest); + void DoWork(object obj); + } + + + The last example shows how to send a message to the ResponseQueue for those + methods that do not return void. + + public interface MyHandler + { + string DoWork(string text); + OrderResponse DoWork(OrderRequest orderRequest); + InvoiceResponse DoWork(InvoiceRequest invoiceRequest); + void DoWork(object obj); + } + + + + Mark Pollack + + + + Out-of-the-box value for the default listener method: "HandleMessage" + + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The handler object. + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Called when message is received. + + The message. + + + + Gets the name of the handler method. + + The original message. + The extracted message. + The name of the handler method. + + + + Builds an array of arguments to be passed into the taret listener method. + + + Allows for multiple method arguments to be built from a single message object. +

The default implementation builds an array with the given message object + as sole element. This means that the extracted message will always be passed + into a single method argument, even if it is an array, with the target + method having a corresponding single argument of the array's type declared.

+

This can be overridden to treat special message content such as arrays + differently, for example passing in each element of the message array + as distinct method argument.

+
+ The converted message. + the array of arguments to be passed into the + listener method (each element of the array corresponding + to a distinct method argument) +
+ + + Invokes the specified listener method. This default implementation can only handle invoking a + single argument method. + + Name of the listener method. + The arguments to be passed in. Only the first argument in the list is currently + supported in this implementation. + The result returned from the listener method + + + + Initialize the default implementations for the adapter's strategies. + + + + + Extracts the message body from the given message. + + The message. + the content of the message, to be passed into the + listener method as argument + + + + Sends the given response message to the given destination. + + The destination to send to. + The outgoing message about to be sent. + + + + Builds a MSMQ message to be sent as response based on the given result object. + + The result. + the MSMQ Message (never null) + If no messgae converter is specified. + + + + Post-process the given response message before it will be sent. The default implementation + sets the response's correlation id to the request message's correlation id. + + The original incoming message. + The outgoing MSMQ message about to be sent. + + + + Determine a response destination for the given message. + + + The default implementation first checks the MSMQ ResponseQueue + of the supplied request; if that is not null + it is returned; if it is null, then the configured + default response destination} + is returned; if this too is null, then an + is thrown. + + + The request. + The response. + + + + + Gets or sets the handler object to delegate message listening to. + + + Specified listener methods have to be present on this target object. + If no explicit handler object has been specified, listener + methods are expected to present on this adapter instance, that is, + on a custom subclass of this adapter, defining listener methods. + + The handler object. + + + + Gets or sets the default handler method to delegate to, + for the case where no specific listener method has been determined. + Out-of-the-box value is "HandleMessage". + + The default handler method. + + + + Gets or sets the processing expression for use in custom subclasses + + The processing expression. + + + + Gets or sets the that this + object runs in. + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Gets or sets the message queue factory. + + The message queue factory. + + + + Sets the name of the default response queue to send response messages to. + This will be applied in case of a request message that does not carry a + "ResponseQueue" value. + Alternatively, specify a response queue via the property + . + + The name of the default response destination queue. + + + + Sets the default destination to send response messages to. This will be applied + in case of a request message that does not carry a "ResponseQueue" property + Response destinations are only relevant for listener methods that return + result objects, which will be wrapped in a response message and sent to a + response destination. + + Alternatively, specify a "DefaultResponseQueueName" + to be dynamically resolved via the MessageQueueFactory. + + + The default response destination. + + + + Gets or sets the name of the message converter object used to resolved a + instance. + + The name of the message converter object. + + + + Gets message converter that will convert incoming MSMQ messages to + listener method arguments, and objects returned from listener + methods back to MSMQ messages. + + + The converter used is the one returned by CreateMessageConverter on MessageQueueFactory. + + + The message converter. + + + + Sets the message queue template. + + If not set, will create one for it own internal use whne MessageListenerAdapter is constructed. + It maybe useful to share an existing instance if you have an extensively configured MessageQueueTemplate. + + The message queue template. + + + + An implementation of a Peeking based MessageListener container that does not surround the + receive operation with a transaction. + + + Exceptions that occur during message processing are handled by an instance + of . + + Mark Pollack + + + + Handles the listener exception. + + The exception. + The message delivered that resultd in an processing exception. + + + + Perform a receive opertion on the message queue and execute the + message listener + + The MessageQueue. + + true if received a message, false otherwise + + + + + Gets or sets the exception handler. + + The exception handler. + + + + detects poison messages by tracking the Message Id property in memory with a count of how many + times an exception has occurred. If that count is greater than the handler's MaxRetry count it + will be sent to another queue. The queue to send the message to is specified via the property M + essageQueueObjectName. + + Exception handler when using DistributedTxMessageListenerContainer + + + + Determines whether the incoming message is a poison message. This method is + called before the is invoked. + + The incoming message. + + true if it is a poison message; otherwise, false. + + + The will call + if this method returns true and will + then commit the distibuted transaction (removing the message from the queue). + + + + + Handles the poison message. + + The message. + + + + Called when an exception is thrown in listener processing. + + The exception. + The message. + + + + Sends the message to queue. + + The message. + + + + Keeps track of the Message's Id property in memory with a count of how many times an + exception has occurred. If that count is greater than the handler's MaxRetry count it + will be sent to another queue using the provided MessageQueueTransaction. The queue to + send the message to is specified via the property MessageQueueObjectName. + + + + + Called when an exception is thrown during listener processing under the + scope of a . + + The exception. + The message. + The message queue transaction. + + An action indicating if the caller should commit or rollback the + + + + + + Determines whether this exception was already processed. + + The exception. + + true if the exception was already processed; otherwise, false. + + + + + Sends the message to queue. + + The message. + The message queue transaction. + TransactionAction.Commit + + + + Template method called before the message that caused the exception is + send to another queue. The default behavior is to set the CorrelationId + to the current message's Id value for tracking purposes. Subclasses + can use other means, perhaps using the AppSpecific field or modifying the + body of the message to a known shared format that keeps track of + the full 'lifecycle' of the message as it goes from queue-to-queue. + + The message. + + + + Gets or sets the exception anmes that indicate the message has already + been processed. If the exception thrown matches one of these names then + the returned TransactionAction is Commit to remove it from the queue. + + The name test is thrownException.GetType().Name.IndexOf(exceptionName) >= 0 + The message already processed exception types. + + + + Action to perform on the MessageQueueTransaction when handling message listener exceptions. + + + + + Rollback the MessageQueueTransaction, returning the recieved message back onto the queue. + + + + + Commit the MessageQueueTransaction, removing the message from the queue. + + + + + A MessageListenerContainer that uses local (non-DTC) based transactions. Exceptions are + handled by instances of . + + + + This container distinguishes between two types of + implementations. + + If you specify a then + a MSMQ will be started + before receiving the message and used as part of the container's recieve operation. The + binds the + to thread local storage and as such will implicitly be used by + send and receive operations to a transactional queue. + + + Service layer operations that are called inside the message listener will typically + be transactional based on using standard Spring declarative transaction management + functionality. In case of exceptions in the service layer, the database operation + will have been rolled back and the + that is later invoked should decide to either commit the surrounding local + MSMQ based transaction (removing the message from the queue) or to rollback + (placing the message back on the queue for redelivery). + + + The use of a transactional service layer in combination with + a container managed is a powerful combination + that can be used to achieve "exactly one" transaction message processing with + database operations that are commonly associated with using transactional messaging and + distributed transactions (i.e. both the messaging and database operation commit or rollback + together). + + + The additional programming logic needed to achieve this is to keep track of the Message.Id + that has been processed successfully within the transactional service layer. + This is needed as there may be a system failure (e.g. power goes off) + between the 'inner' database commit and the 'outer' messaging commit, resulting + in message redelivery. The transactional service layer needs logic to detect if incoming + message was processed successfully. It can do this by checking the database for an + indication of successfull processing, perhaps by recording the Message.Id itself in a + status table. If the transactional service layer determines that the message has + already been processed, it can throw a specific exception for thise case. The + container's exception handler will recognize this exception type and vote to commit + (remove from the queue) the 'outer' messaging transaction. + Spring provides an exception handler with this functionality, + see for more information. + + If you specify an implementation of + (e.g. or HibernateTransactionManager) then + an local database transaction will be started before receiving the message. By default, + the container will also start a local + after the local database transaction has started, but before the receiving the message. + The will be used to receive the message. + If you do not want his behavior set + to false. Also by default, the + will be bound to thread local storage such that any + send or recieve operations will participate transparently in the same + . If you do not want this behavior + set the property to false. + + In case of exceptions during processing + when using an implementation of + (e.g. and starting a container managed + ) the container's + will determine if the + should commit (removing it from the queue) + or rollback (placing it back on the queue for redelivery). The listener + exception will always + trigger a rollback in the 'outer' (e.g. + or HibernateTransactionManager) based transaction. + + + PoisonMessage handing, that is endless redelivery of a message due to exceptions + during processing, can be detected using implementatons of the + interface. A specific implementation + is provided that will move the poison message to another queue after a maximum number + of redelivery attempts. See for more information. + + + + + + Determine if the container should create its own + MessageQueueTransaction when a IResourceTransactionManager is specified. + Set the transaction name to the name of the spring object. + Call base class Initialize() funtionality + + + + + Does the receive and execute using platform transaction manager. + + The message queue. + The transactional status. + + true if should continue peeking, false otherwise. + + + + + Does the recieve and execute using message queue transaction manager. + + The message queue. + The transactional status. + true if should continue peeking, false otherise + + + + Does the recieve and execute using a local MessageQueueTransaction. + + The mqessage queue. + The transactional status. + true if should continue peeking, false otherwise. + + + + Handles the transactional listener exception. + + The exception thrown while processing the message. + The message. + The message queue transaction. + The TransactionAction retruned by the TransactionalExceptionListener + + + + Invokes the transactional exception listener. + + The exception thrown during message processing. + The message. + The message queue transaction. + TransactionAction.Rollback if no exception handler is defined, otherwise the + TransactionAction returned by the exception handler + + + + Gets or sets a value indicating whether the MessageListenerContainer should be + responsible for creating a MessageQueueTransaction + when receiving a message. + + + + Creating MessageQueueTransactions is usually the responsibility of the + IPlatformTransactionManager, e.g. TxScopePlatformTransactionManager (when using DTC) + or MessageQueueTransactionManager (when using local messaging transactions). + + + For all other IPlatformTransactionManager implementations, including when none is + specified, the MessageListenerContainer will itself create a MessageQueueTransaction + (assuming the container is consuming from a transactional queue). + + + Set the ExposeContainerManagedMessageQueueTransaction property to true if you want + the MessageQueueTransaction to be exposed to Spring's MessageQueueTemplate class + + + + true to use a container managed MessageQueueTransaction; otherwise, false. + + + + + Gets or sets a value indicating whether expose the + container managed to thread local storage + where it will be automatically used by send + and receive operations. + + + Using an will always exposes a + to thread local storage. This property + only has effect when using a non-DTC based + + + true if [expose container managed message queue transaction]; otherwise, false. + + + + + Gets or sets the message transaction exception handler. + + The message transaction exception handler. + + + + An implementation that delegates to an instance of + to convert messages. + + Mark Pollack + + + + An interface specifying the contract to convert to and from objects. + + + + + Convert the given object to a Message. + + The object to send. + Message to send + + + + Convert the given message to a object. + + The message. + the object + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message formatter. + + + + Convert the given object to a Message. + + The object to send. + Message to send + + + + Convert the given message to a object. + + The message. + the object + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + An implementation that delegates to an instance of + to convert messages. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The binary message formatter. + + + + Convert the given object to a Message using the + + The object to send. + Message to send + + + + Convert the given message to a object using the + + The message. + the object + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Gets or sets the type format used in the + + The type format. + + + + Gets or sets the top object format used in the + + The top object format. + + + + Delegate for creating IMessageConverter instance. Used by + to register a creation function with a given name. + + + + + Internal class to that users can specify a delegate function to register with the application context that + will create a IMessageConverter instance easily at runtime. + + Mark Pollack + + + + Gets the template object definition that should be used + to configure the instance of the object managed by this factory. + + The object definition to configure the factory's product + + + + Converts an to a Message and vice-versa by using the message's + body stream. + + Mark Pollack + + + + Convert the given object to a Message. + + The object to send. + Message to send + + + + Convert the given message to a object. + + The message. + the object + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + An implementation that delegates to an instance of + to convert messages. + + Mark Pollack + + + + Initializes a new instance of the class. + + + + + Initializes a new instance of the class. + + The message formatter. + + + + Convert the given object to a Message. + + The object to send. + Message to send + + + + Convert the given message to a object. + + The message. + the object + + + + Creates a new object that is a copy of the current instance. + + + A new object that is a copy of this instance. + + + + + Gets or sets the target types used by the + + The target types. + + + + Gets or sets the target type names used by the + + The target type names. + + + + Delegate for creating MessageQueue instance. Used by + to register a creation function with a given name. + + + + + Factory for creating MessageQueues. This factory will create prototype instances, i.e. every call to GetObject + will return a new MessageQueue object. + + All MessageQueue constructor arguments are exposed as properties of the factory object. As this + is a use the PropertyTemplate property to specify additional + configuration of the MessageQueue. + + Mark Pollack + + + + Retrun a configured MessageQueue object. + + A newly configured MessageQueue object + + + + Gets or sets an instance of the MessageQueueCreator delegate that will be used to create the + MessageQueue object, instead of using the various public properties on this class such + as Path, AccessMode, etc. Not intended for end-users but rather as a means to help + register MessageQueueFactoryObject at runtime using convenience method on the IMessageQueueFactory. + + + Can also be specifed using an instance of MessageCreatorDelegate. If both are specifed, the + Interface implementation has priority. + + The function that is responsbile for creating a message queue. + + + + Gets or sets the path used to create a MessageQueue instance. + + The location of the queue. + + + + Gets or sets a value indicating whether to create the MessageQueue instance with + exclusive read access to the first application that accesses the queue + + + true to grant exclusive read access to the first application that accesses the queue; otherwise, false. + + + + + Gets or sets the queue access mode. + + The queue access mode. + + + + + Gets or sets a value indicating whether [enable cache]. + + true to create and use a connection cache; otherwise false. + + + + Sets a value indicating whether to enable connection cache. The default is false, which + is different than the default value when creating a System.Messaging.MessageQueue object. + + + true if enable connection cache; otherwise, false. + + + + + Sets a value indicating whether to retrieve all message properties when receiving a message. + + + true if should etrieve all message properties when receiving a message; otherwise, false. + + + + + Sets a value indicating whether to set the filter values of common Message Queuing properties + to true and the integer-valued properties to their default values.. + + + true if should set the filter values of common Message Queuing properties; otherwise, false. + + + + + Gets or sets a value indicating whether the queue is a remote queue. + + + The operations that one can perform on the MessageQueue depend on if it is local or remote, for + example checking if it is transactional. This is very difficult to determine programmatically. + The property was made virtual so it can be overridden to take into account custom heuristics you + may want to use to determine this programmatically. + + true if remote queue; otherwise, false. + + + + Gets or sets a value indicating whether the remote queue is transactional. + + + true if the remote queue is transactional; otherwise, false. + + + + + Return the of object that this + creates, or + if not known in advance. + + The type System.Messaging.MessageQueue + + + + Is the object managed by this factory a singleton or a prototype? + + return false, a new object will be created for each request of the object + + + + Gets the template object definition that should be used + to configure the instance of the object managed by this factory. + + The object definition to configure the factory's product + + + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.dll b/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.dll new file mode 100644 index 0000000000000000000000000000000000000000..0bd3f2c36c088cdafd1502ba58b395cc3d909aeb GIT binary patch literal 34304 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.pdb b/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.pdb new file mode 100644 index 0000000000000000000000000000000000000000..79d1557b6f3dd2b6c0786714742c958d58fcc763 GIT binary patch literal 99840 zcmeIb4S-cux&MC#W=23zMqUI(9S{{2#u?sGv>6!Q3KV55G|U-h4lpvzjPrs}Sff&5 zX<<=mSz(c3VNq&gVbKlC?xoVgu6pfW?NZmuTiB0#Fa3UI|Ic@=XYI4+aON;GF#a#e zg6}+M@AW+ES+CD}*=w)8pticHp}ApMOX19mW?pz<;eti83#Swn7Z2!nTKS>`u9y3t z_yIq6_tuR>Vwd}S{LkM*4($5darb7*wbD+oQi6vhSe_pMT#?zyIr-FDH-96d$efUv>5m$F2L-n!l|c+Whi|FMC(pv6&lh zzE~fv^52m^x^?0m|NPWR{a1bP*R@8xQO`V^c-( zwI6+`qVJcF&D?nN#rkNK|Hmpy9(eeP+s6I))Nd~T<2|S6z4>zT*i7-!D*wFCElIrn zu1!xo^Nas;%c|KQzxde9jW=Jck5>5)Jb2RRcfD)y!3PI^;hInW$DU372e6c=S<-hv0xu-2YdG#l+{M@8Z{_;OQ|J<7| zCy&h(AFcAg?y|E6{A~0qV@9v3IQz3#@BH(znHz7uSRbwOKcmlYbJsn#`TR@!lzjKK zJJ)^Z&6ktMW{Qti`7izbFV3m|!tbB{e$hEAzFG7yyN=D=c=N^jXqEq?mtXiFm)|j~ z;lFTIGM| zf-n8{z<;0m5C3n=;Elg+{pEl+UrrvIDLz`|f5Fr%PTEm7y3f$+kNt35^(ehAaNHdO zIdHVf|J|iqzjgTW9m z6r2i%f#KjZa5@+P&H!hEvp^vj2}Xglfegnv;9PJX7z54+Y(Gp~2*!eOpa@(9iotj= z0Zaswz+^B5=)Hz%Ko6rX0n@>y;4<(QPzuU`7OQ81axe?b26Mn%Fb}*Hyba6;3&7>z z3a}7d39bTqSFQqF4c-pk0TzR6z_s9=K%1hj1MdRYgGx{ZmV#O`sXHfL5T%*G*szSPR|_-UHTwo56d*`#>AG1>6d51M9*2!3V$x z!3JtH+h2KXj;2s{iP0p9|Tf*s&7@NMuNuoFBE zz6-twc7YOb+>x(CeJ%ugJWt*nIq>?QUjI`LNnJRQKh+m6xxTUKh9%97O||vQ$JHlW zmb5gr)~{UB+*G|}k-KT6Xi@cwWKC-wY(-bLRyDP}dr9if61!7YQ`Oi~wX`nz)`q3C ztEyWXn${LoW2myK@wzPvMa?NSH+nUxJ4@_NRZw$7!_s9bHCeTEJux$z8tN;WYL_oh zHeIpwhGcb%l9E+N*Hgl)*!3-5M?>dybUhvA$-3n7sul{4Qt5#-)I{M^9ET0R>+vVn z<;j+++PWSq1>#-fH1t>*%x|c!sw=N*san*~+ElIPv53ZzJZx@ty++kZQw^G$ohFjj z+$l|6FBg}limK+7v(_Z5TTxQ6qA6Kbv#_C|uBXyPs#YdVTZ_}y*cokIPuqfI%Zi4Y zdG)IsR`yuCS><%pnhpx;u(@^=(&1Z@+2$T=P=_SVH!ri*J=V(Fm)cdW_4VqD4x6oA zZ)EM$M~B%tMO`mH->+gWdaS5?mrCvHu~NAz=}i%-NR1d|3l}yuR41F88=88cgqln# z2}_M1WELAct+eZ{|MrG5}wl7LjPg^@n z5&hGwHPy++mfD8;9%x9G9JC}mt)&|^u69*pT{1O*hz~1zB2i9VY6KAsp1H_FFp@FMF`XPA!GsZWJIKLMJ zr}dH*;2%jx5plcf1lAsbbLc(aejW?t^j{a}JV_b+;M?!18FA&F9Hp%*ZZOQ}0*Wt@ z`?t!=rkk+JW(>a-{;&S!;6km1tE^O>@=HR4Q<(HM3Xt6|dTfc;y%8RT~MsOFq>1MDeO^ ziC2DcUbT(D``(h*ZxFBAjCkc2=T-X&yr19n!sFsqyArSb;=F2;f%loKe)$XWs;!Dw zesNy4^T6A8P4i>oRr?pO{NlW7w}JPb+#B94UbScO$}i3t%)s^W#QnXE zM}gO!V(0%fCtI$6M^$ah?1m;fndXXynGG7KwIr{oU$mmNrKaJgdI=3p^e#}idw{|U z^8FH{3$9+Ywz(y_3ZCe9kss(Wri9n=_<1hR6yfo|ixz1(ga2tx&h^kmzKd=yvK|^6 zl+Uxg+}t0(<@Y~)=$c>7+j&mkUf=oZ!MdS;lO8uCHTi2MBk;&M;Wvz)SC*pytBY-(P#qM@l}e(maH zjRxY)N0h!jrjV*0xeucEGeK{8ZF6HobGOr1Wa%r$rpU$1Z3B9?20cZ39--&RT`#LY z6K*l^^*SeNFG|{IAa@aFQ@Ta_QMwa&IvwPE-N}jK7MHsmeoUvHFSq6LWW9GH*U43I z&)0z*_xzhnS8wO)2kss4E6F@>ZW{#Ud2`!H=ylMsP@Xrp`ckEh$YJRQ&D>2(NO zarWh&6V(S*!(l+K2HAeJ*bskTRyl4Tfc)d}r;WDt=iVx4F1Z`m;qyL~?zoOW{^|8L zg>?YPW~lF#Q$EX01oJ^7pd1sM!49wwyar^u#)47>dfat72Xf&Iw(ezca;?tapzV${wVIgY_Z4r z?a-Y%6>Pn4&zbwUN!WPRYtcc>dM{vyR*>^;DYG2w0!~hJ5WBt3Wv7?qMg!k2GWQX) z;U7Rw2OYj%XV#&9RB;oH$88PweErOE`@y($cB@W5a13DE)PCq^+6F?KprfGbpA9gPWA zxCHurqOdu~_%}Zp(yqQUmiDgLROMlOPWi0qDl|PJwDo-Tr_RfC>8WU0^MWdkdAp-8 zlxw-QH`%q|PD9_WxIW)^xItZabX{g+E3JRY#dV#It|#NV${HK%YW=ctDDNZDIaVDa zEgX(FRA5Nez>Bnwq@m2!gW^&w~Yc3g$VEgq0Hw9km zgZ5>&T?oAxIv%Qijd0X+ws9{}3e978c0N14^G$0$JIHgHxk}Gm;M+@1qLANm%982s zm($m#B6>UFXg<6cs&Ujc&;t7DA?(`jL+=*CQy=ErL+0_s3glG3MEkLW{Y*w>iihNU z-Oenx!Q@2yrHyrb{meYpx!v)Pj&%5Xm08FArbDzJD-Ol%YF6CV179CUGG|J(ER@ZywamJa=B8VvfByvg8iTmg*670f=aLkYz8~Pi{Ky_Ljjk98Wr?$ zcT{pfSsB*MUa$~PiG@6q<~xLn@A@TMGYkFxCiuh~{7;Il>CU@C?}((qCa1n^9f55GTfrW%59Dgl_;>6`V$}XOTRJUE z+|@1A+4(ebsuzrY&0KX(a`dUrt_T14xWBt?SbEaiaIjCgE)xEIG}xTGmH1Vp#jh)M zTj^6=Rlig(eOfa2v&_@o7+@f@H}xrApM4y1+`Dp$SiC+nmU8_pV|?VUXjlLAtWu6J z6C%-}Nh7ZR-?~BhL+xHuO&e;B*?@QwH6-`z3&AcGO1eEcco|wKg{L zw5!{F5cc+v`Wv3Pg?V4Rea#_%TSES-54vJ?vgxL#+Lq+3HMPz5nnrWi<_an^)#=$` zz1#YtxZb(&tc&YqW@1aH6p7|2+R*Rk>RoA1>AL%?bHHf~9^5>1ukVy@-@h#;{?7u1 z5#-b_Dm0k0cl@@QmgT8CeL_;10UHeQ|ynNn< zt}St0Gpp*7^)*#Z-K+~i*FrUTTs&R$m-*Y`y6inCRCOy4!&<;@(-lt_Yn1tq#dSsN z_4BFj$$B0)ACbJO{LTMyTxUCN-OJZt zM+);@5xTzD|8irT{HNpkd>XAJk1U;`JU3;~dnM_7F0S_wjonLY(AkHu<>KXe6*^yP zuQM|23##g?ctx*UbtshQnhZJ@q4RffokuWN2<<zZxPP+#SHCOJ_iE60RdTr+ zhud^hR$miqo^JdvJKjPVk`FSnkDBWJ;G!)cT$%bm#yVmeToot)*)BO{dbw1@=T^YE_XwC zUD4!&Y%ZBkJxDxavZo;{a~YRS@-nE_2_@5rE(S_2o==#J(kRmtm#MaH!atq&<)~(x ziHF;Vq-i=jMsfc<^eO)oFS56te2d>y-Yzd1k(&#j_Ekzwc}O(d$#s4H>ExA9?bgqS z*_c`NFu1GX*=f2HWi>UJ+lq#$Z#gm>G@Z~3Tw7kHI#>$txgoXh>^WARtO z*o`RPYPk+=QZffkrVr^4^-wgM%vkhG&*Yel+J82gN|ULH$*ApTli7sKh46eVCZjf= zNv6BwSIuL!9^&U@Inf%u;--2eH;;K}KJ;x+=B94Fq%S!zfHj)%oLanoUXpn(OnY;4 zVbMXXH*1HRbW6_9D>BP1H965i=$pbREkVwY?Q^2Jg34etkZXYd6r+PUrDZlJv;;Xn zCeOSdZ9Q^S37u=wRzMsFklR7dkFPVw^Dg*h_eA4+6qG(cR?e*NOQuhBklXb)DbnZ1 zy_xkrX!=A4F?!J|eu$?ZyJnXAmdS~x%lYwVX1O1joai8S8Ef}O(C5dIndN?Ba-xIM z_BHx(U}m|0F*(seJkuFR8iPJRmdh;nTayz_PoE!;WtRKDCMP<`?MxZ#^v$PI`7u&X zG~T+1GA&hQ!}ZEZwCQJWC}t;-2i5bczR{F1f6X6r`q*wXbJbPuqedJnW5`UNOqw{3yWg?0rp@B zlzrZ$M$g5oIb*4UCudjSH-<6ZTipFKu{p!BALHH5Q0-fpfd6^elT!1afd33I8!U!v zvb$e^oh#APN8Fjz!r|yEGRvsFIt8@6;cg_OFr}jwoW=bju1|+*56p$o%OYE;agQH+ zLo?@Ozt7j()6=6OB1e;od$Vw+cC) z^(N|}W1*B&o5s|XQ(Gyt6-wWmxCvSVeK&MD^u5p)sOrROXdBlzK`BpH2Pw~6w{Xq# zgtl$a4?&-RivLGY_V%>B2>lpTb?%eU0hG@G@}hv8A3{D4;R)+-R~Dn8+M%R;obK+O z!3w?n&PY_+{l)FleFycyj{$O`afF`P5>MwgqfcW>>XmDoikECV^~*im)qS;5QRVZO zp(^zUpi`mZ*R$oXa;-M1`&SxW0{t4-%CGIvWl-_2fPRzf_t^dS8T}CS5$=Bs`Y3c0 zRQ#WWKF0L}cK<=6JD@wczY9wJZ~FmM{L0^5Tt8>`|IO$hpg-Wg+QraBAy>-Bh1Bku z)Y8ky^N#MH8{;qM`TC{sPldlYc7HK%L(Jj+4DMeLyFZ_h%eX(?)$If5RDOp=?T!3w z$)kRN&EQG!A{dyD-2oM#4%`8@fL-8OZ~*kDGo1+L1C1;00P06~gZ-cnipGL+PzTn7 ztzZ{;87K~gU@BMwTEHf7+#OjCCcYBI+C8P%Ei<6 z7-{=@JZ;f@G3-j}+PqPDrMQQ6q`P~0onP_9{rxsPj|QDHdGy+V4Zg-Xxa5ufF4q zp{aS2q8sP0sDqtMlo)FAsQbKzeZerndi9jSKJ2yjS1xD!LJJNR_G|`eCQY` z{h1q6TmjX%gMQ8RaaTd##q}cSGU(ON6;Sm(H$dOPwbmOJL)SsCh291g-v^DVkGqcR zd!Um0477^tFGA@r+XfJe0nEt?h@BrNjfZM)@f0vQHkO-19hyl0Kc4t6U`#icK24)% z^=*>~Bef6Qmu+f}rMf)Kak?`u(K$KVSEP3>~(lH^rCsu9Y>D3mOqTPul#rWf9?D@OjTs>@8-8;0$)eZfwR8nY0qM>ZmF#!sBZTG zN>6$p5cUt0yF_T*pK_;=zOzF5y75k+@<(%{I)b?zgdzRU`MdzT6$ask7SC z7vJmP(~=XVk)*jeL3Dm@8_Qc-AEb?**KV%^^9ASBj*WbsQwzqvYHgRsPU*UKWzh9e zbWMrt>gKx#>AEt#2f&;)|1Ck6y}#o3Y;}%V8I$E-9&}~c>#uS9y~J@KvXTqDpn>aPdq(DxKU{d;rtX$jvBQ)5C^t(>%fLM9ishscS3I~C{45ls|PtzU83tHx4nB1 ze${8zo!vg#Z$L+I{Sfp#=p#_dPG_sPT?Ks%%6vg*tGBI$?u4#`eis^lFFuoJupj=Rq1 z0Old;|Ld$j8W|JkmWGGE|GPYS6Ww1l?k~nO@bWX!QUBl3xIezvGg=F>^IpO{K=w-Q zobcoJs@?wgiTED`YR7VlOR#e(IliM14o<~i{jhALWXHm!YJ)j-vSIBcE*pPNJ~`2e zGeZb#Fi`%=$qq_qu<0)-k~mA0`%OCYNAk;gWmp^Pid`m*cJq?(4&b|-CjW=-A%A?( z=T7cZ>2|HJ3VLK;WdG%I_@{Kp#qB>f-`N-0f0dQy9LjUeHO_)+EhLYblx#yTv;90q zN@3n1`=~G#cE~eyM{5F?Bb!SPqIlE+pROGDtqm>{velLPfx8}F*|{p{$sUHZ z$vr<<4!w};TIfvZDjtz|yLAS2>>~8ffa-bEyNKh2XdOcFksAiI4`CoSZ48(TD#04? zzs<$le;-T0@K_{Es3VIhMCX+@{@(?kc!Phu{dabpKPt8l+tz=>c}{v4cv&rlk!hZA zr2Dj0FVoiv!W=%#1L9*l>QnxWAs;lhvxUyCv`OVzUKk(AwCw zHW~DU@qTFgaXr|*{9EFB$n5IYrY82Bb!ohxu4}uDHBRjU=M;3_9oN~-`AmBHa;@`-rw<#Nzd5d} zqN<53jcM#&`a-|dl0hf-I$wL7U3FESdTrf0Lnfp#w6zyZU%bBXj5dFJ(8qgnUS0Rn z70PWc;mMJIk)!{~e>CV(z4VIQ@dn+gBOwoWm@aDyP9N)P`G1P*n%BID7cDqEkC#z! zN2Je<(EPWKLgMIC^Ir}6I+!2s#D6`qk0BIzN7=dy%jX3lEXGZK%4{}IdqPzg(s*3H zX-svHaN7v?TzGDRidSPQVR0gt3k0 zsJ?H>JfCA+<-!x~#}l_~^BmXaxzssQiCy}E>y_i51!&LP z8C)|Sbk7pC=j{rv`$LyO2SA&k?0Iu%31JM{KEU-L=mw~s5q=0dgzL}R{rik=gAV8Z z4(MsnT=rw;vJ#ZbSMYL~3FNvpf-|9KfRTxQZWe_xu87$~A(GG|nwxC)f*K0l6o!z5u3!3eX5PfNfwm*auz%g=E}R zuoyIg4PZ0a1)c>5!N7s+c>(i5BlzFwa*0$}|F5wKlDx=~jC}Sp`MmAM^D#_tyD{&> zR!CPy8ptPjeiU?+HDBJkYAJ8<_~(l&pl$exKk$S#0pf0bRQq@0<*#8{n*U_I`%=Pv z`77ON{!`>Xp8Ia?6uJ(*TAvJh)$ef`lVcxJ>?|bqdb%^P3gOY%p8u}j6HV#j`;K&c z>hl7+()We@{4-&yzwu?0qdnx#Dc!~PoA%xYzs}uu{m{>#eR(FYGrYpO>PGy1`f^+z zOEkVF_zPszhp0_6rA_EsneYr$b3fUrQBc_^<*oP_4?8~P-LJTR1@vE`XJb3%hPwTf zlPJ7G+B36$Tp{*s0BHt^?O@G#h;8^_&I$pN*4(EfcR_umQ)f!|Bp zykv0u_OJFKIrS&+0l`14r#;EN7Eoq#VN5wRYOmPCswQS*ywhffiK$Kc_7d7O-$ms$ z&Dpidx*Ea?Z9X1G?J8dNGluT8rH`9!3gh-L?^it!j{YnETOs|LBQTDv;W?ZQg}XF{ zOxO3K5{y$D4eoPX{zK5GxzFL{SYXR}}eF1&H4f=fgj+#C_ z%aekIR^0~ylCcs>91pf6T_Gg@ow zIHRZAbu{Q)VdKGg8t+GEzaeJxVr6)wI#CqjX*)t) z!B&L#4dUtgI=U7IUG3^=d2~){chVPh_R(M*7q6q+xvU8~+ttw{(;40aSZ_Mx>HG#d zZwNXwq%-WgR$RN2-k@6ty2!=T`%Nxa2i+Ocd!)LP}f- zYyBV-KIh{3{Vnu;BChZ1=2W+rGQsoeqrNb;yHJ50Nqn>(Bp1(r_PXTX7viJ*e*@y9 zxjp4>^Qs&-$5Ol$J^E+o)-j(}Jl_k|{WktHOwv0bZH3TVp<|)9K_@{!0G$uj{Coj) z1J`edei*vS?$<*%a{X>7V_nt?wEtJ{g^TK4v2vg@&a2_jehZxmUgLgieKM>mjOLD? zGo|(jYpN60%bzRw&kwz*w={n$KnxIA}(*Pqp@wE1y$=5W8A7Oo!?XAbuVj@Q43 zqHz6KHgmYU)57&*(9Gff#PRxbeig1CCuR;;YfkZU^JBTp;r_GZof4IsAAe;ISL;mi zaQ&DmbGR=#-cYeyOtlx!p?E9(A;qoqe zyKsG|;&wAQ;Hv zW-*uxR)99J1?&Vbf`ee#De!=WUi< zBRq@e9e?M_W6T%Q|ILBPdBxsc32T7+;T3=2iSPS~pU3DQt^4;6r^3GjjE~9b`7oCn zdpN4!OK(c8pU3a(Jw~nfDGmyYHYPcDeyidco;Am1;`{fy^WK1#vT}R1|3=)OxwjGc zwCA{d;IiHNIcwl;iW{rkZK`gi&@-WB&Pka-8M~!Bug&Idgf&zp~z?c~m7~D*nNaY%{&* z2c^)Z@Z2BtcH=p6&=JxW_Wl*cbTBK)|5?zXxmxr-zvXf_=Bz<)m?LlM?G-wEV7hD2 z``3(m-SSqq@-pblvz1`9m)|=MIAmHNZTZX;?aecmB*|G;8 zJ%zt3^X^K*Q+)|(d^v;8ugs$yQeSIoyt6=uzea=pzn;hzNqe4i?p1xpaebZmW^;G)IMk;t8RF1D9G1l6 z5F0HViLQaR-ajxDCX_`WYFE0| zuEJa~oTU-Z8~TC#&jp>`{El;FS{a1r0oJTsI$Pk`74*#M{`XUZu8=0ZZzvbn)rzhk z#dLLNFM4HKn)F?IxwAZRe^_wl8oX&fdT;L67K+|Zf-Ne4r8agNVJKui%vz z<0;2^cafvx$^QlS-K}}`wW*KvrW9+=^BQs1UQx*gezkWEX->_N((cg&K! z#!;gom0u%K|2UO!uOpl<(oriO;l0GTTr&+_@z@0aMEFbLd)WB3Us2^A=dY`+XZYx4 zb|X`ajMg2#WipDJhPdf6^IDRtG|p3A$I%^I9`d~fopSR$aesOCkbfP9(&hUCWlCz8 zIj_E@L0>~udRvrM=?~i5z?C^6w9M;NJs{#ztaNJl7D%9q>pl@P>LfxPAJgcV*?T zA!wTa`1rn9g`e{0`?q`yIgG@#k56?Y?mzvq=IgI#=CQJ(YGtxsXAF{u#7+A&m%{rs zONZLB$|f$Gv@e{*6DJ)iqc~rE@}@Y;5#@WB1JsyBc?Y_JAgNEh2D(b)}Yso4O7YOPTdOg@bxrexwAcSe|cV*zqg$(U!QbO>)GNB z{wm8{?&+IIGV8xLxzHY1hUSiU@%7asiStw%nOr>1?<3CtlZtagBmRn;*4=aA7jN*_ z{T@|z?c=QCoPw#S;e|&{CTZkKg!ID?Sj`obE_a+zvh$U>?xP5Q>Wg0 zX@gf|t=pj_(S4&@%d4BX9s~UZv@ep{v)-4z;{#YV56_tA;_ugbau~;Yr#@F}=5kw+ zJstWL=(*5s&~eZQp#`k*4oNgqd5Z`$bso51!^!*}ke<~luKt;A`){55wV2FuKQcMd z_&L2{rl0HW*EcfD{g26ss;t8|M5WKKPh^%G z$}=_Pi|8QAX9nlfs!pjK{CYx8w9e3*dkRlZ=TJ+IGbGyRa^3mU1&Ps=iS`?$%EYe| zWY%43VTcZ*j!fm85$To=Kfli`H_zlm^_)?sp9eWVPtPp(4wDm2&s#s=&Ma4Ba-xIS zOEH~iI6TA8bqw1&*5ruR7dIph^Sh@U;~}OQAfcP0WB!fX;&Ic@}5gyYsCVKsC;}0$K-M z1icB$_judrTXnW;+a1trpUq2l{z z=t{16-zQNA{dedp=m18j1DIi)kSJt*q6m5>^aAS0cJUeN7EA(qn>_y@sXdUzs=*`d_(A%Mp zK?h(-3KFH{*ZZNv$d`FQ?N2Gu;Ou5_4fn=CFMw|`TyJ-N!{PB~u~%^a5_eB$fuEEp zcV$$-4l?Dl_Iic)vShQACw{(_6V2Pywkm<#4~SQPsM069u4~ziC!p$obv?=amG3{| zdNgOK$T3Dk-y}--Y(s$%(45|Wk6v%+ z0M6hn;OX@MP(TkiB+&$28tGgEzn??o=zVYJq(gC$JBct(fewU@f-;e78v|9IX|6kj zYvs+Uy%V=8&Zl$zF6bFhox`T@9Tb?g^L1&Wi$_RvCA@y#koq=nygxaga1@_$P?e4J zGJi;1#Pv{U2~_c#2-P0LA=EuN|K9UEqjXks&yV#p>$wDZ>3It@uBVJ^>6r=mF6+zqya-QWd~OGi8cOa~QU4cG`C27ACOAeY8A7L;bQV!3>Hgg885htOq;5Q(!;nLscFFO2HD)0`3J5gFRp$V4F!|7$^pF!3v-k#y5i< z;016145M-vgTs>elBK!SE zs}IG<4J^dwgXv%~XaskFEnp|u3-*IPM6_6uJqDfXL3kE5%oz>;o>52&Z7zQ!7tTxj z2y}oJdm3#!lxyn><0+v2H1Kw2-)FqPxGK4<&L2C_es5={eZ=7jY<%x!I4`!leFy10 zr0)neVx#4Y+D359=kh)LC&;^|@vl>fb;E7Y@YoSmMotJK=FY)Wv9-SU6LMU;o# zJnKGP*EZ7?&qIcT`TK${<>3+P3T<_<8XfM_p18lXzx+S&%cZM>eHPn^<7i|h7kJe# zD*%ecQCh+w-&*KSd53w$L5u4|DKWbvBqVeRiR!WP`d%RSAiT=MuR||{egmp8z(Y{REbcsd%BS6V z^fg?62mc1><51>z3G%|7OScPp57++y_1_yUP3Vliyu_){p;WGLPW@=EPvd^-oO;Dq z`QYnhj;o(sx^bh@EH{;K$3e9g)K_od;tl}Wxu5C+H&+3_P2B21mo?5=gKqzA?IYlcJ!DXr~{BDMxo?m;K2j^XgYOtkfZG zVJ@h;Sq1`cNBw`ipFiBZFjL>(6X!mM^dE4EbZY`it#cQV{yic6_Wm3DkdjUHRdr%; z=|^rCP+beWx?jpYy$_>y^?xjkFqffDm@P}qWrEC3WK{2q^L)NbhFhvfhsbEW&=uRP z^7Jx(J%(pL&Z%7ow+o(`rkgb%x9HOy9cnY!KdTctu6{@dLA!RK-?SIz3akS|HNGl= zvP`M{5Vw{>Cvjci)`Q$aOXJDrgP#YAEYQ?wfi3*~l{D<7dSKh;~O&3O3aL*DQb&VgVIW7cTB??O)@U@Tp4wYD?7qA4W!Ufj9ns)|q-oD)xR>QCUp` zL&-(#?@vmVvjgTI#_{pC@7|#b4IlpQj`5Y&^!1^Tc0FU0tMbJC9ZA}GZjiElX=(3D zn<%t)7v>aNACc2MJ2=We{|iCioMg-84fPAE>N(@CreZO>&+J$>Z*v-n@5?~)K_;9} zN&AZIL}OKLlfv)3o$zg_(Bd2N=MIbSDGJOSRW5&5i0{lgUg3zxvTN%jg{JS%gst}A z>rv*h4sDh8?7!zOBkap4Cn`JD!%84m2CuGXKsBb34HyHR4OM%bi=DXyI-fOYIAX9>rU3F=1#Na}9I=r)mzcy#UhZ^DD>Mck#yM zs-157eJ8i9-7})o$Y;4i@WR=Q6~JH=P6YEo3%CPp16^^sFo$va-P9+!vpjKsKTf&) z6NcG&#m4E9TgXlE2LE`U@8{L+#3>VNN+y;h$4^QYYgww>wu!mqA+{;31LUfb z;8drA+eEqiK9q~!BdkQS(XeanPUS1x5cV>z$)M{K@ceg1U3MZKk?M*q3_62tc{zj5 zPbyw?hOXX)^rcMT5$RiOZ7H6gpF-bB?e#?`3@OjMlfLjgKy6;mrN#eD+>O4|g1&C9 z(}#QvWj9fc5*JSw^PT+DgC6zYDHFY@rOCgz)Sa{iom)-k0I%BpWo;qfTaB}f+%4g6yG3Zn}gCT&gJLywDMBiYxE%UlL&p_JLZkd~6=Xvf9Re!88ZQsP( zu=^K)dCrc9e$BVp)N@7EiD5u)vI{45E|PC^nRzv~)i;nsxW27q<|Q5Qrp`t3^*l2# z<6d}EXXf}int7f7T6n|Qb~N$#^(=F^OW_@4@l`+Q>qq7_muh%bhehN2I;F#xaprMB zo#Q_{nse{7N~v<(jqtNzKj?oBeKnX1DuFg^+zobsr@+gAZB&WTU^=J-YrrP(_vUg* zQ0V^$nt=-SQE8=~<$pClbN~M&{^AY(@&3P~zP>wi{;=L3pA-0H@8+T~E$Hr?fTSJL z?}oDo@38zh6`tTq$&Vj|{P6Rk)eY6|GxM`~K*(@mL9)4-F*^cXu{+9Vr6Kf*VeLO| zuLp2b9aAGLQy^}??c zxcjW*CKB)F{s_CTe&}Yd&w{=W%DRfjKs{<@~yZaz?+kUg3W$E(f^R2e?du z7J_Z(CK9{Avmp08_M?GPuo%>VwD3w15ad+AC-R|eWvR3?Ocnp{^scW zM|t`j6;b#9iwY!}NOb*-g?p#n|NhDT{!2EmxP{5N_@1-- ztEfx5{yuRMT}yovT}6cyeVPR{(U5>0WEPYQ~`sUgFzgT=rEL}gb z@~X0Uf63zg*Ry>%yffm$%d_-8XnaptdJ2rMpwRO@X5oLs@;k@qZ%ohaM(?tGzSQ#V zCCk@Vi`P7(XBfTN@<)5*mA?Dz{;QS`C00JShxm{5d{ zeVwJ_8q22}3%&gLrnlD8%eS3exSzH7-eUFbaifo&b_?@-4+F)NS9aUED&sjVkv~*o+ z`Scr$&*Qy(I=*D-y2a9Ur=@FwrGL1Ef1{P#Z!Dg_vizQ9<@95#$4QI#0!!!nExsx% z;S-kL|FrbnXW{2r{O&WpzgRuuT^lD?Yw?_C@jTz!(WMrjNfzHK^Z$wYPqKLY&f2;`_AmJ!bW0p84Nr<@bcer_Ac-85XaX zEFIH~?=KXV%Ih&p_fISyYporQG}?Eh=ex(!|5wwy!0N%(Cii%-la?>jtp5I`x0nBm z^_NduIA1cpGfe&(i_e1=|KSYA6~8JA=Xchgs!Y#07S1dyrv;WjpRnuSSiFB?_sh)g ze8S?r%If#4me0QlhhAF%igALaFynf&dR4&F;~`7_PxQ?2R$o#jhk3+Fz&|Ek6N z8jE+1rSo?4f7;@GsolTY;(x|@Ue7ZYkH;*Y1y;`=w{~4-@h!3ZTtL|o<-}Tx_sy2> z;Z}~%ncm@6FRrnA^>pYTtbD?m>fg8YeBb2yhI(l2;TsnJwMJjHe0d;*Z}dJ3zpvHr zYwSA5{L3ud$3nfecGGJ0q1DQBt@;1N(p6&dYBjwN8m%%tLo7WvTKdaO-_53PfZ2yT zjXoCSEPZROp50|~&scfRvwBo(^{B7KD=)84q91iVm;4{oD<@}QX`aH}Fa1+Y+}TU%0-oFgIri#m{}|@6&6b!tYfG|J;FXdVtj{kNXNgm*CEqd_f|o zFoAy126FR|gI|vKQWL{UUHG|*Ut6K`?HdJ0gWH z>h4A<0jFF}Y3jFMQ>W^=xqC5mI+zP8KqaUHYruN25!?&5f``E#@GRH|_Jh|zA7Z8N z1r~y_KxZ$P13gpIyQ?ce3upschtjjTEkJuio&t!!wG0F!z!)$Q%m<4>4QK@Gzy`1xYy&&MZtxU%0lW+j02YK2 z{lPFW8We-+U@oWtm7or+0XlPTBe)lA1rLK=U=Mf}>;wD3Ye4ONFpwS5*>O`rIammm zfEAzx+yU+eTfla(6YK>qf>*#nkc++4+QA4g222E{U@@oxjbI(v1h#=4U^jRQyZ~MX z2Y?=0^#{YiXiyBM1Dy+20V+WqSOeCBjo@Ce6+8@ffj!_^pfkDpFuo}SV?jAs2z1uM z3ZQcjSa3_+0qzD{z;>_`JPG!K7r{ZG@4?mpoe{PU=v%Oxz-FLt!tMb2F6>j_1@JOB z0Cea@e=rP;2E{<;cb$ePBO$4fMfg4+eBAiLqcR zCK>wB@t&7WO?~uLd6m)ri zlcT+ccK$*n7keRxI0rfJZ*o<7yzK46T=K%lF?Ku{`z74L^D%kPXY#b)AivYeD_^q9 zdp?t=9E(hUF=M)p^y_sWa=@K89n#_XEgZ@;*!=A-oa{E=^O!7U8|D%th~L13=bc)T;@v`k>Ae1)@s3aNDvg}2(XJoy_bd+dQK6h`i2DFnm#VHC0WibbCLOp?w6Imm`^q zrrPDp86c$UiT5*^>Qr7=PzXMLk$sw9+uV|@chV_&&u8*ADS6Fzy!;%#U|m&5j%Sqj zd?rtO2=#P&UXX7u8OqrEo7}Qg*=&pCyk1LjM%|v*hcT%*)s8i%@^L>@I_UR2CQIE9 zb@c9-Y*l@8RdownD*X=TcJ0&inLOekwZIIM9re6EjHR^W5bqbG zFru_Zy-v{Yc}zCeek-sgLlb^eCfOBs#YcJN{Y{Sc8*I?M*p8uzdCjxxYM0mY-Avx9 zw6lzA>;4+>+F4C4#$?{!SYCWSKBT9B9P z;6>wDzIk2?qb8+WYehbc*h{D}Iqz?BF?%FC?&UI%ZM?t9VUL3C)wkxO@e`MjW{m|rKPIBOwW*0uAI0;^`>qlVdFEl|^OX?;C$rstjIq{2J$b0hD7veU_BZ&RMfWNTuwj05^57B)1uVBV|Q4oOj3 z^N-@Y)A5)rwkB>%duOQkJVJ2mOvTujkcTU%guN4Ge200}QvWWh?>GE?&tHOViHAKT zL)b$s>}jMwmzA%YwvGzF*`VsHWPHZ*G|&p zyuZm|dxE|#PEPeWdcDF)hWhCJO)h4G^xVPnwW>Uqdl)pRYU)~<>5hn~;mv1390fRlIiJ*&LuGx@4i zeW+vH?)A@FQ=M$ojGqaVhmOw0VVbvg;e^Zw_dooKFW!!+Lug!pVWExei_+(LOg1(S*0|B@JoICWL9gdA z+1NOET_oE+SA(4QH#zD|$fs8#xhS1PTr1Ij5j@CyK9i>}34N2E))f5{1VAG7PL^dFTC2jy@&WipBIvJ|5XWEEx2AehVko$2=Q_)BXd2LC*V| zT&$0oOW$PmrKPH=rM1yM^cUp3zsc3;tPB4vU`Hg^`Dd_R#=@fC3FEBk^jAI(u@CRX z^3MC49Bn(uZH?sOv!GOc_5NON3T-;f_4M64-=^zUj z#>Rau>~T0b(ZL70V)e}PnS5;Ar+p76+d4{Q8)9d3Xl&fp>-D^)K>;c=>x4F69$=748Wc!ac#l9Z#JP z?dnCx>*jRP0lFc4@8`oGPkj$E^BDu2;Od?ogi9Df#`~E}Y)td8lS#cSANc)!w`|F<3nGAyyr9dSiM%h^~$!s>-@c3G5Hb3+9ODtmplCW zuIIHd$e&<)Hbr4%w%y*}Su_UFD3UeEc%Yd4H3mtq1$I-N|KN!}2^P8*A^{*Vrqq{`-5z8|!OT=6zk6 z`&oQA94+Lb_xEz+<8qW&-!Mjx9V!;dIe(MGW`sWJpu2AebH&ZZPwtlGE>?Io6VXQ8w=b^90yzf6An%Z;d?(H{A&#EMWU&RIolPZ^2fKRGv8?AY*{YNs+2&-WH+5h~(C7V3W@-C!J~2Z%pJ?Sg zfwmIt>R`(GM63H9y{I4bd0ww?BJCigZ=(w%yB+a7CQDlgbrK_j{`P&Yzh}JE`~N?k z_W0e@w}gH4?A_%vwv!SKt0&X2hcO#^1UHl)!`;OncZGX@`6f$%cUJNGY;|p4_9dDxMO@=6=Of$|sghnnbmAF6hau z_oBpWYW%ns^hIuN2vJjZSPgUAs+JacAw$o;c#g? z%e^WgK0Qm2>ZdxRFB%?LZkEj+KY7NKnKKm-E_)hF5*w}V6rxZ%+d89D3oUhexW35k z5F-lyticHrXP1?iOe%Al52w2*(TGiy+iJSEccv_z?)bWk|6YJTEs>ZoY1-_P$uoRS zI-LFs64RAn=?Cs-XX>wSJ|x-ldsf-3^77fUI;XQ(-+pth!qQxL$x45Nza6&K*s#ay z)$H*lv!|5Jp6z6_m+^UtV%9z6o+Q7O&V`*x=OH@%6GmGmvcylEHg&?(*%Rm&<+8_P zf_wKxeC3w*&7CRl_VLi-hm2ODc-r{!Q%WY&6L^D~d8$~GX~yKe7%UQ^J~gRew!N%^cumUgO)YgaYaB~!*MZsHQI|`Rv)nozpu$ zF)Yu=Z;zG7i=EQjsMGsWi@R>T#4d>Ovq~nEk1y|>?(-9yti9{~JEeL5#htMCz9R?& z_Mmz8gpvs}iaRwY&Cj(p%Z7Ht*8x8#*>GJQ66IHKVv>hGuHsWiRIo6E7Oy zT&Q#>I-?tXDN|n^9r%^3Nj1aCQ^rpzn_29Jr{lg|^lA<>cDa%6Z~H&etNSb~9^&Mu z5#YNH@$vE9$bBm|AAjSM+-Cv9cIR{*oPKWyn04pU{dREIy5U2@{2qQC$^8gFUS)SK zJah>yw+v9EAjn^KUa3(Hw@+w z7pr=a+*$bXI=OS{ewX6czXQK{_>C|>Gac?qaY^ELNe6zL@hi;eH`IMIE97;0m`@_t zk)Pf_3+YRj`{yijdfeRJ?DH+><0bg6ji z`v+y_7s@L5?ZNM+4*Ya3{E!a(^p5m!^W%|O+?l%OX&{i0pMo#+9%i=c;zq5@yU2X|}Aq~N< ziB)0hJ@-(T(*5+_L`Qz>@e6%Uy43(pWdVID9mkHKhEO!bQZto zviQA}#qW1n{B(}lKUqaf&lf%K_A5ZCz9*E?AMx9#3tYO~GKc&|hJzDq?2c^%3_ ztct=9v-tfKKcebfy4*8a75a{J zzdzv@+F!cgFSzj`Yt!j|*O4jnI!L>|ZNH`iKYd639Ub`Td+*nG;HSL_p$|xpi@u-U zk)OVK9&As#+sCg;-qwr0_%??#6-lSPqJJoPC<`kAz#w{bbftD zembwdBR`!_-;rPR%>;C(>(lx39m(mu`A`n&aynB!@iTG?^Xpms9>wn~#+@!##WGoFo9TY__`SvC{A!xN=!NwkAf@yo;rZ`_FlhgU zT(~ECs+*bV7(IOzI*)pL0%_0*=O>Z}`l{2(j9ChpYYpOYzz|mL^u3GD|9gP-hYv8f z7ycdn&!NA9jK7rzQo&qP=Zu|<-*>rp32`0@PXj!|xgVb4D$X+r=lAdl?}q1F$W~vx z@8)ktp}2oD#2)(x#zT`im4}bWL&%N0Y&XLIP^gH z)`a2@e0o4jhV3sspe6N0W2Jv^pWz{T52!t4k4+Eg@V4=g=VLvfDQ(Ba5o$q}NCoc!9Ubg8>H$sdQxhI{OHtzWKfV4Z4To$q7seC2@iS8q9o3H?R$YwK6e zt6$cTxTxNp!f+7-kBe3$b>`O6x`yhN33p>zZC$eYqO5}zKZ3D=Oi^>RU!~~AR$h{N z_mb3|C3dGur)6k2%?%ApmvNd2-KuEB7seIvY;w%WTsS~8^gA` zo=vPNO*U28cDgrM-5Zg|Q5xUCikm9TWH@W0hjZ5L4NDoKxOsX*G{13uneW|emeNF4 z*D^M6eRr~{hg0e1l)k#sSbJcMK&UBm=XZTA<1>%Rnszlv5B|>uT6=o^=pbeqCLj~+B!$AXY#XR@NE4Icl_f{+%uo`;|3r*3l?w-V!65YmH; zRovGmf!7IF3wrv^&&0=p7UlG@4e8cKAuXsiA*=t)Y7E z0He95ckXsk_xE#O?|kg#zTUsk`|>-uewlW(AD)Te?n3TE=Tn_`Qjhn*w-@L=0)3N0 z&pyYZV?Al%c47z6exGlH?|_})ae#`%7Vsr-Kln1(3LXGjtNtq31|9@o178Q*!8gD+ z!9(C-@Cf)8cob;go1T>wf{{Q??QAd_oCD4UM9bv?(RIyM&rQ{o)#PO!)O2MY)Rfii z)g;wyWlGfS)ud%6WIBccnGQAI(}DIQYCq=r-~wRK{coWNw5qo2P;4=xB;vLbzl{!2MwSR z+z6ULGiU*=U^Tc2tO0AmyTN!@p+$ literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.xml b/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.xml new file mode 100644 index 00000000..be5b5be2 --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Scheduling.Quartz.xml @@ -0,0 +1,2040 @@ + + + + Spring.Scheduling.Quartz + + + + + JobFactory implementation that supports + objects as well as standard Quartz instances. + + Juergen Hoeller + Marko Lahma (.NET) + + + + + + Called by the scheduler at the time of the trigger firing, in order to + produce a instance on which to call Execute. + + + It should be extremely rare for this method to throw an exception - + basically only the the case where there is no way at all to instantiate + and prepare the Job for execution. When the exception is thrown, the + Scheduler will move all triggers associated with the Job into the + state, which will require human + intervention (e.g. an application restart after fixing whatever + configuration problem led to the issue wih instantiating the Job. + + The TriggerFiredBundle from which the + and other info relating to the trigger firing can be obtained. + the newly instantiated Job + SchedulerException if there is a problem instantiating the Job. + + + + Create an instance of the specified job class. +

+ Can be overridden to post-process the job instance. +

+
+ + The TriggerFiredBundle from which the JobDetail + and other info relating to the trigger firing can be obtained. + + The job instance. +
+ + + Adapt the given job object to the Quartz Job interface. + + + The default implementation supports straight Quartz Jobs + as well as Runnables, which get wrapped in a DelegatingJob. + + + The original instance of the specified job class. + + The adapted Quartz Job instance. + + + + + Convenience subclass of Quartz's CronTrigger type, making property based + usage easier. + + +

+ CronTrigger itself is already property based but lacks sensible defaults. + This class uses the Spring object name as job name, the Quartz default group + ("DEFAULT") as job group, the current time as start time, and indefinite + repetition, if not specified. +

+

+ This class will also register the trigger with the job name and group of + a given . This allows + to automatically register a trigger for the corresponding JobDetail, + instead of registering the JobDetail separately. +

+
+ Juergen Hoeller + + + + + + + + +
+ + + Interface to be implemented by Quartz Triggers that are aware + of the JobDetail object that they are associated with. + + +

+ SchedulerFactoryObject will auto-detect Triggers that implement this + interface and register them for the respective JobDetail accordingly. +

+ +

+ The alternative is to configure a Trigger for a Job name and group: + This involves the need to register the JobDetail object separately + with SchedulerFactoryObject. +

+
+ Juergen Hoeller + + + + +
+ + + Return the JobDetail that this Trigger is associated with. + + The associated JobDetail, or null if none + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Register objects in the JobDataMap via a given Map. + + + These objects will be available to this Trigger only, + in contrast to objects in the JobDetail's data map. + + + + + + Set the misfire instruction via the name of the corresponding + constant in the CronTrigger class. + Default is . + + + + + + + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Set the JobDetail that this trigger should be associated with. + + + This is typically used with a object reference if the JobDetail + is a Spring-managed object. Alternatively, the trigger can also + be associated with a job by name and group. + + + + + + + Set the start delay as . + + + + The start delay is added to the current system UTC time + (when the object starts) to control the + of the trigger. + + + If the start delay is non-zero it will always + take precedence over start time. + + + the start delay, as object. + + + + Helper class to map constant names to their values. + + + + + Simple Quartz IJob adapter that delegates to a + given instance. + + + Typically used in combination with property injection on the + Runnable instance, receiving parameters from the Quartz JobDataMap + that way instead of via the JobExecutionContext. + + Juergen Hoeller + Marko Lahma (.NET) + + + + + + Create a new DelegatingJob. + + + The Runnable implementation to delegate to. + + + + + Delegates execution to the underlying ThreadStart. + + + + + Return the wrapped Runnable implementation. + + The delegate. + + + + Callback interface to be implemented by Spring-managed + Quartz artifacts that need access to the SchedulerContext + (without having natural access to it). + + + Currently only supported for custom JobFactory implementations + that are passed in via Spring's SchedulerFactoryObject. + + Juergen Hoeller + + + + + + Set the SchedulerContext of the current Quartz Scheduler. + + + + + + + + + + + + + + + + Executes this instance. + + + + + Gets a value indicating whether´this instance prefers short lived tasks. + + + true if prefers short lived tasks; otherwise, false. + + + + + Convenience subclass of Quartz' JobDetail class that eases properties based + usage. + + + itself is already a object but lacks + sensible defaults. This class uses the Spring object name as job name, + and the Quartz default group ("DEFAULT") as job group if not specified. + + Juergen Hoeller + + + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Overridden to support any job class, to allow a custom JobFactory + to adapt the given job class to the Quartz Job interface. + + + + + + Register objects in the JobDataMap via a given Map. + + + These objects will be available to this Job only, + in contrast to objects in the SchedulerContext. +

+ Note: When using persistent Jobs whose JobDetail will be kept in the + database, do not put Spring-managed objects or an ApplicationContext + reference into the JobDataMap but rather into the SchedulerContext. +

+
+ +
+ + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + + Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. + + + + + Gets or sets the that this + object runs in. + + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Set the key of an IApplicationContext reference to expose in the JobDataMap, + for example "applicationContext". Default is none. + Only applicable when running in a Spring ApplicationContext. + + +

+ In case of a QuartzJobObject, the reference will be applied to the Job + instance as object property. An "applicationContext" attribute will correspond + to a "setApplicationContext" method in that scenario. +

+

+ Note that ObjectFactory callback interfaces like IApplicationContextAware + are not automatically applied to Quartz Job instances, because Quartz + itself is responsible for the lifecycle of its Jobs. +

+

+ Note: When using persistent job stores where JobDetail contents will + be kept in the database, do not put an IApplicationContext reference into + the JobDataMap but rather into the SchedulerContext. +

+
+ + +
+ + + Subclass of Quartz's JobStoreCMT class that delegates to a Spring-managed + DataSource instead of using a Quartz-managed connection pool. This JobStore + will be used if SchedulerFactoryObject's "dbProvider" property is set. + + +

Operations performed by this JobStore will properly participate in any + kind of Spring-managed transaction, as it uses Spring's DataSourceUtils + connection handling methods that are aware of a current transaction.

+ +

Note that all Quartz Scheduler operations that affect the persistent + job store should usually be performed within active transactions, + as they assume to get proper locks etc.

+
+ Juergen Hoeller + Marko Lahma (.NET) + + +
+ + + Name used for the transactional ConnectionProvider for Quartz. + This provider will delegate to the local Spring-managed DataSource. + + + + + + + Gets the non managed TX connection. + + + + + + Closes the connection. + + The connection and transaction holder. + + + + Gets or sets the name of the instance. + + The name of the instance. + + + + Quartz ThreadPool adapter that delegates to a Spring-managed + TaskExecutor instance, specified on SchedulerFactoryObject. + + Juergen Hoeller + + + + + Logger available to subclasses. + + + + + Initializes a new instance of the class. + + + + + Called by the QuartzScheduler before the is + used, in order to give the it a chance to Initialize. + + + + + Called by the QuartzScheduler to inform the + that it should free up all of it's resources because the scheduler is + shutting down. + + + + + + Execute the given in the next + available . + + + + + The implementation of this interface should not throw exceptions unless + there is a serious problem (i.e. a serious misconfiguration). If there + are no available threads, rather it should either queue the Runnable, or + block until a thread is available, depending on the desired strategy. + + + + + Determines the number of threads that are currently available in in + the pool. Useful for determining the number of times + can be called before returning + false. + + + the number of currently available threads + + + The implementation of this method should block until there is at + least one available thread. + + + + + Gets the size of the pool. + + The size of the pool. + + + + Quartz Job implementation that invokes a specified method. + Automatically applied by MethodInvokingJobDetailFactoryObject. + + + + + Simple implementation of the Quartz Job interface, applying the + passed-in JobDataMap and also the SchedulerContext as object property + values. This is appropriate because a new Job instance will be created + for each execution. JobDataMap entries will override SchedulerContext + entries with the same keys. + + +

+ For example, let's assume that the JobDataMap contains a key + "myParam" with value "5": The Job implementation can then expose + a object property "myParam" of type int to receive such a value, + i.e. a method "setMyParam(int)". This will also work for complex + types like business objects etc. +

+ +

+ Note: The QuartzJobObject class itself only implements the standard + Quartz IJob interface. Let your subclass explicitly implement the + Quartz IStatefulJob interface to mark your concrete job object as stateful. +

+
+ Juergen Hoeller + + + + + + + +
+ + + This implementation applies the passed-in job data map as object property + values, and delegates to ExecuteInternal afterwards. + + + + + + Execute the actual job. The job data map will already have been + applied as object property values by execute. The contract is + exactly the same as for the standard Quartz execute method. + + + + + + Invoke the method via the MethodInvoker. + + + + + + Set the MethodInvoker to use. + + + + + IFactoryObject that exposes a JobDetail object that delegates job execution + to a specified (static or non-static) method. Avoids the need to implement + a one-line Quartz Job that just invokes an existing service method. + + +

+ Derived from ArgumentConverting MethodInvoker to share common properties and behavior + with MethodInvokingFactoryObject. +

+

+ Supports both concurrently running jobs and non-currently running + ones through the "concurrent" property. Jobs created by this + MethodInvokingJobDetailFactoryObject are by default volatile and durable + (according to Quartz terminology). +

+

NOTE: JobDetails created via this FactoryObject are not + serializable and thus not suitable for persistent job stores. + You need to implement your own Quartz Job as a thin wrapper for each case + where you want a persistent job to delegate to a specific service method. +

+
+ Juergen Hoeller + Alef Arendsen + + +
+ + + Initializes a new instance of the class. + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + If this method is being called in the context of an enclosing IoC container and + returns , the IoC container will consider this factory + object as not being fully initialized and throw a corresponding (and most + probably fatal) exception. + + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Callback for post-processing the JobDetail to be exposed by this FactoryObject. +

+ The default implementation is empty. Can be overridden in subclasses. +

+
+ the JobDetail prepared by this FactoryObject +
+ + + Set the name of the job. + Default is the object name of this FactoryObject. + + + + + + Set the group of the job. + Default is the default group of the Scheduler. + + + + + +
+ + + + Gets the job detail. + + The job detail. + + + + Set a list of JobListener names for this job, referring to + non-global JobListeners registered with the Scheduler. + + + A JobListener name always refers to the name returned + by the JobListener implementation. + + + + + + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + + Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. + + + + + Set the name of the target object in the Spring object factory. + + + This is an alternative to specifying TargetObject + allowing for non-singleton objects to be invoked. Note that specified + "TargetObject" and "TargetType" values will + override the corresponding effect of this "TargetObjectName" setting + (i.e. statically pre-define the object type or even the target object). + + + + + Sets the object factory. + + The object factory. + + + + Return the of object that this + creates, or + if not known in advance. + + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + + Adapter that implements the Runnable interface as a configurable + method invocation based on Spring's MethodInvoker. + + +

+ Derives from ArgumentConvertingMethodInvoker, inheriting common + configuration properties from MethodInvoker. +

+ +

+ Useful to generically encapsulate a method invocation as timer task for + java.util.Timer, in combination with a DelegatingTimerTask adapter. + Can also be used with JDK 1.5's java.util.concurrent.Executor + abstraction, which works with plain Runnables. +

+

+ Extended by Spring's MethodInvokingTimerTaskFactoryObject adapter + for TimerTask. Note that you can populate a + ScheduledTimerTask object with a plain MethodInvokingRunnable instance + as well, which will automatically get wrapped with a DelegatingTimerTask. +

+
+ Juergen Hoeller + + +
+ + + Logger instance shared by this instance and its sub-class instances. + + + + + Initializes a new instance of the class. + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + This method has to be implemented in order that starting of the thread causes the object's + run method to be called in that separately executing thread. + + + + + Gets the invocation failure message. + + The invocation failure message. + + + + Subclass of Quartz' JobSchedulingDataProcessor that considers + given filenames as Spring resource locations. + + Juergen Hoeller + + + + + Initializes a new instance of the class. + + + + + Returns an from the fileName as a resource. + + Name of the file. + + an from the fileName as a resource. + + + + + Sets the + that this object runs in. + + + + Invoked after population of normal objects properties but + before an init callback such as + 's + + or a custom init-method. Invoked before setting + 's + + property. + + + + + Common base class for accessing a Quartz Scheduler, i.e. for registering jobs, + triggers and listeners on a instance. + + + For concrete usage, check out the and + classes. + + Juergen Hoeller + Marko Lahma (.NET) + + + + Logger instance. + + + + + Resource loader instance for sub-classes + + + + + Initializes a new instance of the class. + + + + + Register jobs and triggers (within a transaction, if possible). + + + + + Add the given job to the Scheduler, if it doesn't already exist. + Overwrites the job in any case if "overwriteExistingJobs" is set. + + the job to add + true if the job was actually added, false if it already existed before + + + + Add the given trigger to the Scheduler, if it doesn't already exist. + Overwrites the trigger in any case if "overwriteExistingJobs" is set. + + the trigger to add + true if the trigger was actually added, false if it already existed before + + + + Register all specified listeners with the Scheduler. + + + + + Template method that determines the Scheduler to operate on. + To be implemented by subclasses. + + + + + + Set whether any jobs defined on this SchedulerFactoryObject should overwrite + existing job definitions. Default is "false", to not overwrite already + registered jobs that have been read in from a persistent job store. + + + + + Set the locations of Quartz job definition XML files that follow the + "job_scheduling_data_1_5" XSD. Can be specified to automatically + register jobs that are defined in such files, possibly in addition + to jobs defined directly on this SchedulerFactoryObject. + + + + + + Set the location of a Quartz job definition XML file that follows the + "job_scheduling_data" XSD. Can be specified to automatically + register jobs that are defined in such a file, possibly in addition + to jobs defined directly on this SchedulerFactoryObject. + + + + + + + Register a list of JobDetail objects with the Scheduler that + this FactoryObject creates, to be referenced by Triggers. + This is not necessary when a Trigger determines the JobDetail + itself: In this case, the JobDetail will be implicitly registered + in combination with the Trigger. + + + + + + + + + + Register a list of Quartz ICalendar objects with the Scheduler + that this FactoryObject creates, to be referenced by Triggers. + + Map with calendar names as keys as Calendar objects as values + + + + + + Register a list of Trigger objects with the Scheduler that + this FactoryObject creates. + + + If the Trigger determines the corresponding JobDetail itself, + the job will be automatically registered with the Scheduler. + Else, the respective JobDetail needs to be registered via the + "jobDetails" property of this FactoryObject. + + + + + + + + + + Specify Quartz SchedulerListeners to be registered with the Scheduler. + + + + + Specify global Quartz JobListeners to be registered with the Scheduler. + Such JobListeners will apply to all Jobs in the Scheduler. + + + + + Specify named Quartz JobListeners to be registered with the Scheduler. + Such JobListeners will only apply to Jobs that explicitly activate + them via their name. + + + + + + + + Specify global Quartz TriggerListeners to be registered with the Scheduler. + Such TriggerListeners will apply to all Triggers in the Scheduler. + + + + + Specify named Quartz TriggerListeners to be registered with the Scheduler. + Such TriggerListeners will only apply to Triggers that explicitly activate + them via their name. + + + + + + + + Set the transaction manager to be used for registering jobs and triggers + that are defined by this SchedulerFactoryObject. Default is none; setting + this only makes sense when specifying a DataSource for the Scheduler. + + + + + Sets the + that this object runs in. + + + + Invoked after population of normal objects properties but + before an init callback such as + 's + + or a custom init-method. Invoked before setting + 's + + property. + + + + + Spring class for accessing a Quartz Scheduler, i.e. for registering jobs, + triggers and listeners on a given instance. + + Juergen Hoeller + Marko Lahma (.NET) + + + + + + Template method that determines the Scheduler to operate on. + + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Finds the scheduler. + + Name of the scheduler. + + + + + Specify the Quartz Scheduler to operate on via its scheduler name in the Spring + application context or also in the Quartz {@link org.quartz.impl.SchedulerRepository}. + + + Schedulers can be registered in the repository through custom bootstrapping, + e.g. via the or + factory classes. + However, in general, it's preferable to use Spring's + which includes the job/trigger/listener capabilities of this accessor as well. + + + + + Return the Quartz Scheduler instance that this accessor operates on. + + + + + Return the Quartz Scheduler instance that this accessor operates on. + + + + + FactoryObject that sets up a Quartz Scheduler and exposes it for object references. + + +

+ Allows registration of JobDetails, Calendars and Triggers, automatically + starting the scheduler on initialization and shutting it down on destruction. + In scenarios that just require static registration of jobs at startup, there + is no need to access the Scheduler instance itself in application code. +

+ +

+ For dynamic registration of jobs at runtime, use a object reference to + this SchedulerFactoryObject to get direct access to the Quartz Scheduler + (). This allows you to create new jobs + and triggers, and also to control and monitor the entire Scheduler. +

+ +

+ Note that Quartz instantiates a new Job for each execution, in + contrast to Timer which uses a TimerTask instance that is shared + between repeated executions. Just JobDetail descriptors are shared. +

+ +

+ When using persistent jobs, it is strongly recommended to perform all + operations on the Scheduler within Spring-managed transactions. + Else, database locking will not properly work and might even break. +

+

+ The preferred way to achieve transactional execution is to demarcate + declarative transactions at the business facade level, which will + automatically apply to Scheduler operations performed within those scopes. + Alternatively, define a TransactionProxyFactoryObject for the Scheduler itself. +

+
+ Juergen Hoeller + Marko Lahma (.NET) + + + +
+ + + Default thread count to be set to thread pool. + + + + + Property name for thread count in thread pool. + + + + + Initializes a new instance of the class. + + + + + Shut down the Quartz scheduler on object factory Shutdown, + stopping all scheduled jobs. + + + + + Template method that determines the Scheduler to operate on. + To be implemented by subclasses. + + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + If this method is being called in the context of an enclosing IoC container and + returns , the IoC container will consider this factory + object as not being fully initialized and throw a corresponding (and most + probably fatal) exception. + + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Load and/or apply Quartz properties to the given SchedulerFactory. + + the SchedulerFactory to Initialize + + + + Merges the properties into map. This effectively also + overwrites existing properties with same key in map. + + The properties to merge into given map. + The map to merge to. + + + + Create the Scheduler instance for the given factory and scheduler name. + Called by afterPropertiesSet. + + + Default implementation invokes SchedulerFactory's GetScheduler + method. Can be overridden for custom Scheduler creation. + + the factory to create the Scheduler with + the name of the scheduler to create + the Scheduler instance + + + + + + Expose the specified context attributes and/or the current + IApplicationContext in the Quartz SchedulerContext. + + + + + Start the Quartz Scheduler, respecting the "startDelay" setting. + + the Scheduler to start + the time span to wait before starting + the Scheduler asynchronously + + + + Starts this instance. + + + + + Stops this instance. + + + + + Handles the application context's refresh event and starts the scheduler. + + + + + Return the IDbProvider for the currently configured Quartz Scheduler, + to be used by LocalDataSourceJobStore. + + + This instance will be set before initialization of the corresponding + Scheduler, and reset immediately afterwards. It is thus only available + during configuration. + + + + + + + Return the TaskExecutor for the currently configured Quartz Scheduler, + to be used by LocalTaskExecutorThreadPool. + + + This instance will be set before initialization of the corresponding + Scheduler, and reset immediately afterwards. It is thus only available + during configuration. + + + + + Set the Quartz SchedulerFactory implementation to use. + + + Default is StdSchedulerFactory, reading in the standard + quartz.properties from Quartz' dll. To use custom Quartz + properties, specify "configLocation" or "quartzProperties". + + The scheduler factory class. + + + + + + + Set the name of the Scheduler to fetch from the SchedulerFactory. + If not specified, the default Scheduler will be used. + + The name of the scheduler. + + + + + + Set the location of the Quartz properties config file, for example + as assembly resource "assembly:quartz.properties". + + + Note: Can be omitted when all necessary properties are specified + locally via this object, or when relying on Quartz' default configuration. + + + + + + Set Quartz properties, like "quartz.threadPool.type". + + + Can be used to override values in a Quartz properties config file, + or to specify all necessary properties locally. + + + + + + Set the Spring TaskExecutor to use as Quartz backend. + Exposed as thread pool through the Quartz SPI. + + + By default, a Quartz SimpleThreadPool will be used, configured through + the corresponding Quartz properties. + + The task executor. + + + + + + Register objects in the Scheduler context via a given Map. + These objects will be available to any Job that runs in this Scheduler. + + + Note: When using persistent Jobs whose JobDetail will be kept in the + database, do not put Spring-managed object or an ApplicationContext + reference into the JobDataMap but rather into the SchedulerContext. + + + Map with string keys and any objects as + values (for example Spring-managed objects) + + + + + + Set the key of an IApplicationContext reference to expose in the + SchedulerContext, for example "applicationContext". Default is none. + Only applicable when running in a Spring ApplicationContext. + + +

+ Note: When using persistent Jobs whose JobDetail will be kept in the + database, do not put an IApplicationContext reference into the JobDataMap + but rather into the SchedulerContext. +

+ +

+ In case of a QuartzJobObject, the reference will be applied to the Job + instance as object property. An "applicationContext" attribute will + correspond to a "setApplicationContext" method in that scenario. +

+ +

+ Note that ObjectFactory callback interfaces like IApplicationContextAware + are not automatically applied to Quartz Job instances, because Quartz + itself is reponsible for the lifecycle of its Jobs. +

+
+ The application context scheduler context key. + +
+ + + Set the Quartz JobFactory to use for this Scheduler. + + +

+ Default is Spring's , which supports + standard Quartz instances. Note that this default only applies + to a local Scheduler, not to a RemoteScheduler (where setting + a custom JobFactory is not supported by Quartz). +

+

+ Specify an instance of Spring's here + (typically as an inner object definition) to automatically populate a job's + object properties from the specified job data map and scheduler context. +

+
+ + +
+ + + Set whether to expose the Spring-managed instance in the + Quartz . Default is "false", since the Spring-managed + Scheduler is usually exclusively intended for access within the Spring context. + + + Switch this flag to "true" in order to expose the Scheduler globally. + This is not recommended unless you have an existing Spring application that + relies on this behavior. + + + + + Set whether to automatically start the scheduler after initialization. + Default is "true"; set this to "false" to allow for manual startup. + + + + + Set the time span to wait after initialization before + starting the scheduler asynchronously. Default is 0, meaning + immediate synchronous startup on initialization of this object. + + + Setting this to 10 or 20 seconds makes sense if no jobs + should be run before the entire application has started up. + + + + + Set whether to wait for running jobs to complete on Shutdown. + Default is "false". + + + true if [wait for jobs to complete on Shutdown]; otherwise, false. + + + + + + Set the default DbProvider to be used by the Scheduler. If set, + this will override corresponding settings in Quartz properties. + + +

+ Note: If this is set, the Quartz settings should not define + a job store "dataSource" to avoid meaningless double configuration. +

+

+ A Spring-specific subclass of Quartz' JobStoreSupport will be used. + It is therefore strongly recommended to perform all operations on + the Scheduler within Spring-managed transactions. + Else, database locking will not properly work and might even break + (e.g. if trying to obtain a lock on Oracle without a transaction). +

+
+ + +
+ + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Gets a value indicating whether this is running. + + true if running; otherwise, false. + + + + Sets the that this + object runs in. + + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Return the of object that this + creates, or + if not known in advance. + + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + + Generic scheduling exception. + + + + + Initializes a new instance of the class. + + The message. + + + + Initializes a new instance of the class. + + The message. + The original exception. + + + + Subclass of Quartz's SimpleThreadPool that implements Spring's + TaskExecutor interface and listens to Spring lifecycle callbacks. + + Juergen Hoeller + + + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Executes the specified task. + + The task. + + + + Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources. + + + + + Set whether to wait for running jobs to complete on Shutdown. + Default is "false". + + + true if [wait for jobs to complete on shutdown]; otherwise, false. + + + + + This task executor prefers short-lived work units. + + + + Convenience subclass of Quartz's + class, making properties based usage easier. + + +

+ SimpleTrigger itself is already a PONO but lacks sensible defaults. + This class uses the Spring object name as job name, the Quartz default group + ("DEFAULT") as job group, the current time as start time, and indefinite + repetition, if not specified. +

+ +

+ This class will also register the trigger with the job name and group of + a given . This allows + to automatically register a trigger for the corresponding JobDetail, + instead of registering the JobDetail separately. +

+
+ Juergen Hoeller + + + + + + + + + +
+ + + Initializes a new instance of the class. + + + + + Invoked by an + after it has injected all of an object's dependencies. + + +

+ This method allows the object instance to perform the kind of + initialization only possible when all of it's dependencies have + been injected (set), and to throw an appropriate exception in the + event of misconfiguration. +

+

+ Please do consult the class level documentation for the + interface for a + description of exactly when this method is invoked. In + particular, it is worth noting that the + + and + callbacks will have been invoked prior to this method being + called. +

+
+ + In the event of misconfiguration (such as the failure to set a + required property) or if initialization fails. + +
+ + + Register objects in the JobDataMap via a given Map. +

+ These objects will be available to this Trigger only, + in contrast to objects in the JobDetail's data map. +

+
+ +
+ + + Set the misfire instruction via the name of the corresponding + constant in the SimpleTrigger class. + Default is . + + + + + + + + + + + Set the delay before starting the job for the first time. + The given time span will be added to the current + time to calculate the start time. Default is . + + + This delay will just be applied if no custom start time was + specified. However, in typical usage within a Spring context, + the start time will be the container startup time anyway. + Specifying a relative delay is appropriate in that case. + + + + + + Set the name of the object in the object factory that created this object. + + The name of the object in the factory. + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Set the JobDetail that this trigger should be associated with. +

+ This is typically used with a object reference if the JobDetail + is a Spring-managed object. Alternatively, the trigger can also + be associated with a job by name and group. +

+
+
+ + + Adapts Spring's to Quartz's + . + + + + + Initializes a new instance of the class. + + The Spring db provider. + + + + Creates the command. + + + + + + Creates the command builder. + + + + + + Creates the connection. + + + + + + Creates the parameter. + + + + + + Shutdowns this instance. + + + + + Gets or sets the connection string. + + The connection string. + + + + Gets the metadata. + + The metadata. + + + + Helper class to map between Quartz and Spring DB metadata. + + + + + Initializes a new instance of the class. + + The metadata to wrap and adapt. + + + + Gets or sets the name of the product. + + The name of the product. + + + + Gets or sets the type of the connection. + + The type of the connection. + + + + Gets or sets the type of the command. + + The type of the command. + + + + Gets or sets the type of the parameter. + + The type of the parameter. + + + + Gets or sets the type of the command builder. + + The type of the command builder. + + + + Gets or sets the command builder derive parameters method. + + The command builder derive parameters method. + + + + Gets or sets the parameter name prefix. + + The parameter name prefix. + + + + Gets or sets the type of the exception. + + The type of the exception. + + + + Gets or sets a value indicating whether [bind by name]. + + true if [bind by name]; otherwise, false. + + + + Gets or sets the type of the parameter db. + + The type of the parameter db. + + + + Gets or sets the parameter db type property. + + The parameter db type property. + + + + Gets or sets the parameter is nullable property. + + The parameter is nullable property. + + + + Gets the type of the db binary. + + The type of the db binary. + + + + Gets or sets a value indicating whether [use parameter name prefix in parameter collection]. + + + true if [use parameter name prefix in parameter collection]; otherwise, false. + + + + + Subclass of AdaptableJobFactory that also supports Spring-style + dependency injection on object properties. This is essentially the direct + equivalent of Spring's QuartzJobObject in the shape of a + Quartz JobFactory. + + + Applies scheduler context, job data map and trigger data map entries + as object property values. If no matching object property is found, the entry + is by default simply ignored. This is analogous to QuartzJobObject's behavior. + + Juergen Hoeller + + + + + + Create the job instance, populating it with property values taken + from the scheduler context, job data map and trigger data map. + + + + + Return whether the given job object is eligible for having + its object properties populated. +

+ The default implementation ignores QuartzJobObject instances, + which will inject object properties themselves. +

+
+ + The job object to introspect. + + +
+ + + Specify the unknown properties (not found in the object) that should be ignored. + + + Default is null, indicating that all unknown properties + should be ignored. Specify an empty array to throw an exception in case + of any unknown properties, or a list of property names that should be + ignored if there is no corresponding property found on the particular + job class (all other unknown properties will still trigger an exception). + + + + + Set the SchedulerContext of the current Quartz Scheduler. + + + + + + + Extension of the MethodInvokingJob, implementing the StatefulJob interface. + Quartz checks whether or not jobs are stateful and if so, + won't let jobs interfere with each other. + + + + + Summary description for TaskRejectedException. + + + + + Exception that wraps an exception thrown from a target method. + Propagated to the Quartz scheduler from a Job that reflectively invokes + an arbitrary target method. + + Juergen Hoeller + + + + + Constructor for JobMethodInvocationFailedException. + + the MethodInvoker used for reflective invocation + the root cause (as thrown from the target method) + + + diff --git a/Resources/Libraries/Spring.NET/Spring.Services.dll b/Resources/Libraries/Spring.NET/Spring.Services.dll new file mode 100644 index 0000000000000000000000000000000000000000..1836814d7d4cb5ee7ee2dc48d42ac88e10bd410e GIT binary patch literal 85504 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 Fe*=zJ_dWms literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Services.pdb b/Resources/Libraries/Spring.NET/Spring.Services.pdb new file mode 100644 index 0000000000000000000000000000000000000000..c0aa150d8a5b76214b5e1fa24ee0cd7d51554b0e GIT binary patch literal 181760 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

r~&i9av%?ZZUH;M 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 {Gwg&H8o2$B=kKISyLH1U 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 AiU0rr literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Services.xml b/Resources/Libraries/Spring.NET/Spring.Services.xml new file mode 100644 index 00000000..369778a6 --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Services.xml @@ -0,0 +1,2127 @@ + + + + Spring.Services + + + +

+ Exports components as ServicedComponents using the specified s. + + + + This class will create ServicedComponent wrapper for each of the + specified components and register them with the Component Services. + + + First you need to generate and register your components. This is done by writing a simple e.g. console application using a configuration as shown below: + + <!-- actual objects 'calculatorService' and 'simpleCalculatorService' are defined elsewhere --> + + <!-- Define the component for exporting 'calculatorService' --> + <object id="calculatorComponent" type="Spring.EnterpriseServices.ServicedComponentExporter, + Spring.Services"> + <property name="TargetName" value="calculatorService" /> + <property name="TypeAttributes"> + <list> + <object type="System.EnterpriseServices.TransactionAttribute, System.EnterpriseServices" /> + </list> + </property> + <property name="MemberAttributes"> + <dictionary> + <entry key="*"> + <list> + <object type="System.EnterpriseServices.AutoCompleteAttribute, System.EnterpriseServices" /> + </list> + </entry> + </dictionary> + </property> + </object> + + <!-- Define the component for exporting 'simpleCalculatorService' --> + <object id="simpleCalculatorComponent" type="Spring.EnterpriseServices.ServicedComponentExporter, + Spring.Services"> + <property name="TargetName" value="simpleCalculatorService" /> + </object> + + <!-- Export components into assembly and autoregister with COM+ --> + <object type="Spring.EnterpriseServices.EnterpriseServicesExporter, Spring.Services"> + <!-- assembly name to generated - will generate 'Spring.Calculator.EnterpriseServices.dll' --> + <property name="Assembly" value="Spring.Calculator.EnterpriseServices" /> + + <!-- + use Spring's ContextRegistry for managing services. If true, requires a file + 'Spring.Calculator.EnterpriseServices.dll.spring-context.xml' containing a + <spring/context /> section placed next to the generated assembly. + --> + <property name="UseSpring" value="true" /> + + <property name="ApplicationName" value="Spring Calculator Application" /> + <property name="ActivationMode" value="Library" /> + <property name="Description" value="Spring Calculator application" /> + <property name="Components"> + <list> + <ref object="calculatorComponent" /> + <ref object="simpleCalculatorComponent" /> + </list> + </property> + </object> + + + + To load your objectdefinitions at runtime of the components, place a configuration file next to the assembly + generated by the exporter, using the filename of the exported assembly, postfixing it with '.spring-context.config'. + Taking the example above, the file must be named 'Spring.Calculator.EnterpriseServices.dll.spring-context.xml' and look like: + + <-- --> + <spring> + <context> + <resource uri="Config/services.xml" /> + </context> + </spring> + + This file should point to the service object definitions you exported using with a + configuration as shown above. + + + + Aleksandar Seovic + Erich Eichinger + + + + Creates new enterprise services exporter. + + + + + Called by Spring container after object is configured in order to initialize it. + + + + + Creates ServicedComponent wrappers for the specified components and registers + them with COM+ Component Services. + + + + + Generates all configured to the given assembly. + + + + + Generates service types from the list of instances + into the given assembly. + + the module to export types to + the object factory to resolve target types + the list of instances. + whether to generate context lookups, + + + + + + + + + + + + + + + + Reads key pair from embedded resource. + + Key pair as a byte array. + + + + Applies custom attributes to generated assembly. + + Dynamic assembly to apply attributes to. + + + + Replaces roles expressed using string with appropriate SecurityRoleAttribute instance. + + + + + Parses string representation of SecurityRoleAttribute. + + Role definition string. + Configured SecurityRoleAttribute instance. + + + + Creates the SpringServicedComponent base class to derive all s from. + + + + internal class SpringServicedComponent: BaseType + { + protected delegate object GetObjectHandler(ServicedComponent servicedComponent, string targetName); + + protected static readonly GetObjectHandler getObjectRef; + + static SpringServicedComponent() + { + // first look for a local copy + System.Reflection.Assembly servicesAssembly; + string servicesAssemblyPath = Path.Combine( + new FileInfo(System.Reflection.Assembly.GetExecutingAssembly().Location).DirectoryName + , "Spring.Services.dll" ); + servicesAssembly = System.Reflection.Assembly.LoadFrom(servicesAssemblyPath); + if (servicesAssembly == null) + { + // then let the normal loader handle the typeload + servicesAssembly = System.Reflection.Assembly.Load("Spring.Services, culture=neutral, version=x.x.x.x, publicKey=xxxxxxxx"); + } + + Type componentHelperType = servicesAssembly.GetType("Spring.EnterpriseServices.ServicedComponentHelper"); + getObjectRef = (GetObjectHandler) Delegate.CreateDelegate(typeof(GetObjectHandler) + , componentHelperType.GetMethod("GetObject")); + } + } + + + + + + Gets or sets list of components to export. + + + + + Gets or sets COM+ application name. + + + + + Gets or sets application identifier (GUID). Defaults to generated GUID if not specified. + + + + + Gets or sets application activation mode, which can be either Server or Library (default). + + + + + Gets or sets application description. + + + + + Gets or sets access control attribute. + + + + + Gets or sets application queuing attribute. + + + + + Gets or sets application roles. + + + + + Gets or sets name of the generated assembly that will contain serviced components. + + + + + Use Spring context to configure the serviced components within COM. + + + + + Sets object factory instance. + + + + + SUBJECT TO CHANGE -FOR INTERNAL USE ONLY!
+ Holds configuration information from a given configuration file, obtained by . + You may use to replace the active configuration system. +
+ + +
+ + + initializes this instance with a path to be passed into + + + + + + Purges cached configuration + + + + + Set the nested configuration system to delegate calls in case we can't resolve a config section ourselves + + + + + Get the specified section + + + + + + + Only true if the underlying config system supports this. + + + + + Handles loading of <spring/context> configuration sections for + in-process s generated by + . + + Erich Eichinger + + + + Prevent auto-registering the context with the global ContextRegistry + + + + + Encapsulates information necessary to create ServicedComponent + wrapper around target class. + + + + Instances of this class should be used as elements in the Components + list of the class, which will + register them with COM+ Services. For a full description on how to export + and use services with COM+, see the reference. + + + + Aleksandar Seovic + Erich Eichinger + + + + Creates a new instance of the + class. + + + + + Validate configuration. + + + + + Creates ServicedComponent wrapper around target class. + + Dynamic module builder to use + + Type of the exported object. + whether to generate lookups in ContextRegistry for each service method call or use a 'new'ed target instance + + if is true, each ServicedComponent method call will look similar to + + class MyServicedComponent { + void MethodX() { + ContextRegistry.GetContext().GetObject("TargetName").MethodX(); + } + } + +
+ if is false, the instance will be simply created at component activation using 'new': + + class MyServicedComponent { + TargetType target = new TargetType(); + + void MethodX() { + target.MethodX(); + } + } + +
+ The differences are of course that in the former case, the target lifecycle is entirely managed by Spring, thus avoiding + issues with ServiceComponent activation/deactivation as well as removing the need for default constructors. +
+
+ + + Gets or sets name of the target object that should be exposed as a serviced component. + + + + + Gets or sets the list of interfaces whose methods should be exported. + + + The default value of this property is all the interfaces + implemented or inherited by the target type. + + The interfaces to export. + + + + Gets or sets a list of custom attributes + that should be applied to a proxy class. + + + + + Gets or sets a dictionary of custom attributes + that should be applied to proxy members. + + + Map key is an expression that members can be matched against. Value is a list + of attributes that should be applied to each member that matches expression. + + + + + Set the name of the object in the object factory + that created this object. + + + + + Suppress output to avoid Spring.Core dependency + + + + + Implements default constructor for the proxy class. + + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Factory Object that instantiates and configures ServicedComponent. + + +

+ This factory object should be used to instantiate and configure + serviced components created by . +

+
+ Aleksandar Seovic +
+ + + Creates new instance of serviced component factory. + + + + + Returns configured instance of the serviced component. + + Configured instance of the serviced component. + + + + Initializes factory object. + + + + + Creates new instance of serviced component. + + New instance of serviced component. + + + + Gets or sets component name, as registered with COM+ Services. + + + + + Gets or sets name of the remote server that COM+ component is registered with. + + + + + Returns type of serviced component. + + + + + Gets or sets whether serviced component should be treated as singleton. Default is false. + + + + + Gets or sets the template object definition + that should be used to configure proxy instance. + + + + + This class supports s exported using . + and must never be used directly. + + Erich Eichinger + + + + Reads in the 'xxx.spring-context.xml' configuration file associated with the specified . + See for an in-depth description on how to export and configure COM+ components. + + + + + Called by a exported by + to obtain a reference to the service it proxies. + + + + + Implementation of the custom configuration parser for remoting definitions. + + Bruno Baia + + + + Initializes a new instance of the class. + + + + + Parse the specified element and register any resulting + IObjectDefinitions with the IObjectDefinitionRegistry that is + embedded in the supplied ParserContext. + + The element to be parsed into one or more IObjectDefinitions + The object encapsulating the current state of the parsing + process. + + The primary IObjectDefinition (can be null as explained above) + + + Implementations should return the primary IObjectDefinition + that results from the parse phase if they wish to used nested + inside (for example) a <property> tag. + Implementations may return null if they will not + be used in a nested scenario. + + + + + + Parses remoting definitions. + + Validator XML element. + The name of the object definition. + The parser context. + A remoting object definition. + + + + Parses the RemotingConfigurer definition. + + The element to parse. + The name of the object definition. + The parser context. + RemotingConfigurer object definition. + + + + Parses the SaoFactoryObject definition. + + The element to parse. + The name of the object definition. + The parser context. + SaoFactoryObject object definition. + + + + Parses the CaoFactoryObject definition. + + The element to parse. + The name of the object definition. + The parser context. + CaoFactoryObject object definition. + + + + Parses the RemoteObjectFactory definition. + + The element to parse. + The name of the object definition. + The parser context. + RemoteObjectFactory object definition. + + + + Parses the SaoExporter definition. + + The element to parse. + The name of the object definition. + The parser context. + SaoExporter object definition. + + + + Parses the CaoExporter definition. + + The element to parse. + The name of the object definition. + The parser context. + CaoExporter object definition. + + + + Parses the LifeTime definition. + + + + + Gets the name of the object type for the specified element. + + The element. + The name of the object type. + + + + This class extends to allow users + to define object lifecycle details by simply setting its properties. + + +

+ Remoting exporters uses this class as a base proxy class + in order to support lifecycle configuration when exporting + a remote object. +

+
+ Aleksandar Seovic +
+ + + Initializes a new instance of the class. + + + + + Obtains a lifetime service object to control the lifetime policy for this instance. + + +

+ This method uses property values to configure for this object. +

+

+ It is very much inspired by Ingo Rammer's example in Chapter 6 of "Advanced .NET Remoting", + but is modified slightly to make it more "Spring-friendly". Basically, the main difference is that + instead of pulling lease configuration from the .NET config file, this implementation relies + on Spring DI to get appropriate values injected, which makes it much more flexible. +

+
+ + An object of type used to control the + lifetime policy for this instance. This is the current lifetime service object for + this instance if one exists; otherwise, a new lifetime service object initialized to the value + of the property. + + The immediate caller does not have infrastructure permission. +
+ + + Gets or sets a value indicating whether this instance has infinite lifetime. + + + if this instance has infinite lifetime; + otherwise, . + + + + + Gets or sets the initial lease time. + + The initial lease time. + + + + Gets or sets the amount of time lease should be + extended for on each call to this object. + + The amount of time lease should be + extended for on each call to this object. + + + + Gets or sets the amount of time lease manager will for this object's + sponsors to respond. + + The amount of time lease manager will for this object's + sponsors to respond. + + + + Configurable implementation of the interface. + + Bruno Baia + + + + Defines lifetime's properties of remote objects that is used by Spring. + + Bruno Baia + + + + Gets or sets a value indicating whether this instance has infinite lifetime. + + + true if this instance has infinite lifetime; otherwise, false. + + + + + Gets the initial lease time. + + The initial lease time. + + + + Gets the amount of time lease + should be extended for on each call to this object. + + The amount of time lease should be + extended for on each call to this object. + + + + Gets the amount of time lease manager + will for this object's sponsors to respond. + + The amount of time lease manager will for this object's + sponsors to respond. + + + + Gets or sets a value indicating whether this instance has infinite lifetime. + + + true if this instance has infinite lifetime; otherwise, false. + + + + + Gets or sets the initial lease time. + + The initial lease time. + + + + Gets or sets the amount of time lease + should be extended for on each call to this object. + + The amount of time lease should be + extended for on each call to this object. + + + + Gets or sets the amount of time lease manager + will for this object's sponsors to respond. + + The amount of time lease manager will for this object's + sponsors to respond. + + + + Interface for a CAO based object factory. + + +

+ Provides a well known location for clients to retrieve + references to CAO references. +

+
+ Aleksandar Seovic + Mark Pollack + Bruno Baia +
+ + + Returns the CAO proxy. + + The remote object. + + + + Returns the CAO proxy using the + argument list to call the constructor. + + + The matching of arguments to call the constructor is done + by type. The alternative ways, by index and by constructor + name are not supported. + + Constructor + arguments used to create the object. + The remote object. + + + + Builds a proxy type based on to wrap a target object + that is intended to be remotable. + + Bruno Baia + + + + Creates a new instance of the + class. + + + The lifetime properties to be applied to the target object. + + + + + Creates a remotable proxy type based on . + + The generated proxy class. + + If the is not + an instance of . + + + + + Implements constructors for the proxy class. + + + The to use. + + + + + Generate initialization code for 's lifetime properties. + + ILGenerator + + + + Registers an object type on the server + as a Client Activated Object (CAO). + + Aleksandar Seovic + Mark Pollack + Bruno Baia + + + + Creates a new instance of the class. + + + + + Publish the object + + + + + Disconnect the remote object from the registered remoting channels. + + + + + Gets or sets the name of the target object definition. + + + + + Gets or sets the list of interfaces whose methods should be exported. + + + The default value of this property is all the interfaces + implemented or inherited by the target type. + + The interfaces to export. + + + + Sets the that this + object runs in. + + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Sets object factory to use. + + + + + This class extends to allow CAOs + to be disconnect from the client. + + + + + Create a new instance of the RemoteFactory. + + + + + Returns the CAO proxy. + + The remote object. + + + + Returns the CAO proxy using the + argument list to call the constructor. + + + The matching of arguments to call the constructor is done + by type. The alternative ways, by index and by constructor + name are not supported. + + Constructor + arguments used to create the object. + The remote object. + + + + Set infinite lifetime. + + + + + Factory for creating a reference to a + client activated object (CAO). + + Aleksandar Seovic + Mark Pollack + Bruno Baia + + + + Creates a new instance of the class. + + + + + Callback method called once all factory properties have been set. + + if an error occured + + + + Return the CAO proxy. + + the CAO proxy + + + + The remote target name to activate. + + + + + The Uri of the remote type. + + + + + Argument list used to call the CAO constructor. + + + + + Always return false. + + + + + The type of object to be created. + + + + + Factory for creating MarshalByRefObject wrapper around target class. + + Bruno Baia + + + + Creates a new instance of the MarshalByRefObjectFactory. + + + + + Initializes factory object. + + + + + Creates new instance of the remotable target proxy. + + New instance of the remotable target proxy. + + + + Gets or sets the target object. + + + + + Gets or sets the class or subclass + that the proxy must inherit from. + + + + + Gets or sets the list of interfaces to wrap. + + + The default value of this property is all the interfaces + implemented or inherited by the target type. + + The interfaces to export. + + + + Returns type of the remotable target proxy. + + + + + Always returns false. + + + + + Convenience class to configure remoting infrastructure from the IoC container. + + Bruno Baia + + + + Initializes a new instance of the class. + + + + + Modify the application context's internal object factory after its + standard initialization. + + + The object factory used by the application context. + + + + + + Gets or sets the name of the remoting configuration file. + + + If filename is or not set, + current AppDomain's configuration file will be used. + + + + + Indicates whether a configuration file is used. + Default value is . + + + If , default remoting configuration will be used. + + + + + Gets or sets if security is enabled. + + + This property is only available since .NET Framework 2.0. + + + + + Return the order value of this object, + where a higher value means greater in terms of sorting. + + + + + Publishes an instance of an object under + a given url as a Server Activated Object (SAO). + + + Remoting servers exported by always correspond to . + Objects can be exported either as SingleCall or Singleton by marking the exported object identified by + as either singleton or prototype. + + Aleksandar Seovic + Mark Pollack + Bruno Baia + Erich Eichinger + + + + Holds EXPORTER_ID to SaoExporter instance mappings. + + + + + Returns the target object instance exported by the SaoExporter identified by . + + + + + + + Creates a new instance of the class. + + + + + Cleanup before GC + + + + + Publish the object + + + + + Disconnect the remote object from the registered remoting channels. + + + + + Stops exporting the object identified by . + + true to release both managed and unmanaged resources; false to release only unmanaged resources. + + + + Gets or sets the name of the target object definition. + + + + + Gets or sets the name of the remote application. + + + + + Gets or sets the name of the exported remote service. + + The name that will be used in the URI to refer to this service. + This will be of the form, tcp://host:port/ServiceName or + tcp://host:port/ApplicationName/ServiceName + + + + + + Gets or sets the list of interfaces whose methods should be exported. + + + The default value of this property is all the interfaces + implemented or inherited by the target type. + + The interfaces to export. + + + + Sets object factory to use. + + + + + Builds a proxy type based on to wrap a target object + that is intended to be remotable. + + + The wrapped target object is retrieved by name from the IoC container. + + + + + Creates a new instance of the + class. + + + The exporter to be associated with the proxy. + + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Implements constructors for the proxy class. + + + The to use. + + + + + Deaclares a field that holds the target object instance. + + + The builder to use for code generation. + + + + + Factory for creating a reference to a + remote server activated object (SAO). + + + This is useful alternative to adminstrative type registration on + the client when you would like the client to have only + a reference to the interface that an SAO implements and not the + actual SAO implentation. + + Aleksandar Seovic + Mark Pollack + Bruno Baia + + + + Creates a new instance of the SaoFactoryObject class. + + + + + Callback method called once all factory properties have been set. + + if an error occured + + + + Return the SAO proxy. + + the SAO proxy + + + + The remote service interface. + + + + + The URI of the well known object + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + The type of object to be created. + + + + + Factory that provides instances of + to host objects created by Spring's IoC container. + + Bruno Baia + + + + Creates a for + a specified Spring-managed object with a specific base address. + + + A reference to a Spring-managed object or to a service type. + + + The of type that contains + the base addresses for the service hosted. + + + A for the Spring-managed object. + + + If the Service attribute in the ServiceHost directive was not provided. + + + + + Factory that provides instances of + to host objects created with Spring's IoC container. + + Bruno Baia + + + + The owning factory. + + + + + The instance managed by this factory. + + + + + Creates a new instance of the + class. + + + + + Return a instance + managed by this factory. + + + An instance of + managed by this factory. + + + + + Publish the object. + + + + + Close the SpringServiceHost + + + + + Validates the configuration. + + + + + Gets or sets the name of the target object that should be exposed as a service. + + + The name of the target object that should be exposed as a service. + + + + + Gets or sets the base addresses for the hosted service. + + + The base addresses for the hosted service. + + + + + Controls, whether the underlying should cache + the generated proxy types. Defaults to true. + + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Return the of object that this + creates. + + + + + Always returns + + + + + Factory that provides instances of + to host objects created by Spring's IoC container. + + Steve Bohlen + + + + Creates a for + a specified Spring-managed object with a specific base address. + + + A reference to a Spring-managed object or to a service type. + + + The of type that contains + the base addresses for the service hosted. + + + A for the Spring-managed object. + + + If the Service attribute in the ServiceHost directive was not provided. + + + + + The for the <wcf:channelFactory> tag. + + Bruno Baia + + + + Parse the specified XmlElement and register the resulting + ObjectDefinitions with the IObjectDefinitionRegistry + embedded in the supplied + + The element to be parsed. + The object encapsulating the current state of the parsing process. + Provides access to a IObjectDefinitionRegistry + The primary object definition. + +

+ This method is never invoked if the parser is namespace aware + and was called to process the root node. +

+
+
+ + + Namespace parser for the WCF namespace. + + Bruno Baia + + + + Register the for the WCF tags. + + + + + Builds a WCF service type. + + Bruno Baia + + + + Target instance calls should be delegated to. + + + + + Creates a new instance of the + class. + + The name of the service within Spring's IoC container. + The to use. + Whether to cache the generated service proxy type. + + + + Creates a new instance of the + class. + + The name of the service within Spring's IoC container. + The name of the generated WCF service . + The to use. + Whether to cache the generated service proxy type. + + + + Creates a proxy that delegates calls to an instance of the target object. + This overriden implementation caches the generated proxy type + and sets the '__objectFactory' field. + + + If the + does not implement any interfaces. + + + + + Implements constructors for the proxy class. + + + This implementation generates a constructor + that gets instance of the target object using + . + + + The builder to use. + + + + + Creates an appropriate type builder. Add a field to hold a reference to the application context. + + The name to use for the proxy type name. + The type to extends if provided. + The type builder to use. + + + + that creates a channel that is used by clients + to send messages to a specified endpoint address. + + The type of channel produced by the channel factory. + Bruno Baia + + + + Creates a new instance of the class. + + + The configuration name used for the endpoint. + + + + + Return an instance (possibly shared or independent) of the channel + managed by this factory. + + + An instance (possibly shared or independent) of the channel managed by + this factory. + + + + + Gets the configuration name used for the endpoint. + + + + + Return the of channel that this + creates. + + + + + Is the object managed by this factory a singleton or a prototype ? + + + Default value is . + + + + + Exports an object as a WCF service. + + Bruno Baia + + + + The name of the object in the factory. + + + + + The owning factory. + + + + + The generated WCF service wrapper type. + + + + + Creates a new instance of the class. + + + + + Publish the object + + + + + Return an instance (possibly shared or independent) of the object + managed by this factory. + + + + If this method is being called in the context of an enclosing IoC container and + returns , the IoC container will consider this factory + object as not being fully initialized and throw a corresponding (and most + probably fatal) exception. + + + + An instance (possibly shared or independent) of the object managed by + this factory. + + + + + Validates the configuration. + + + + + Generates the WCF service wrapper type. + + + + + Gets or sets the name of the target object definition. + + + + + Gets or sets the service contract interface type. + + + If not set, uses the unique interface implemented or inherited by the target type. + An error will be thrown if the target type implements more than one interface. + + The service contract interface type. + + + + Gets or sets a list of custom attributes + that should be applied to the WCF service class. + + + + + Gets or sets a dictionary of custom attributes + that should be applied to the WCF service members. + + + Dictionary key is an expression that members can be matched against. + Value is a list of attributes that should be applied + to each member that matches expression. + + + + + Controls, whether the underlying should cache + the generated proxy types. Defaults to true. + + + + + Gets or sets the name for the <portType> element in + Web Services Description Language (WSDL). + + + The default value is the name of the class or interface to which the + System.ServiceModel.ServiceContractAttribute is applied. + + + + + Gets or sets the namespace of the <portType> element in + Web Services Description Language (WSDL). + + + The WSDL namespace of the <portType> element. The default value is "http://tempuri.org". + + + + + Gets or sets the name used to locate the service in an application configuration file. + + + The name used to locate the service element in an application configuration file. + The default is the name of the service implementation class. + + + + + Gets or sets the type of callback contract when the contract is a duplex contract. + + + A that indicates the callback contract. The default is null. + + + + + Specifies whether the binding for the contract must support the value of + the ProtectionLevel property. + + + One of the values. + The default is . + + + + + Gets or sets whether sessions are allowed, not allowed or required. + + + A that indicates whether sessions are allowed, + not allowed, or required. + + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Return the of object that this + creates, or + if not known in advance. + + + + + Is the object managed by this factory a singleton or a prototype? + + + + + Set the name of the object in the object factory that created this object. + + + The name of the object in the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Builds a WCF service type. + + + + + Applies attributes to the proxy class. + + The type builder to use. + The proxied class. + + + + + + Provides a host for Spring-managed services. + + Bruno Baia + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The base addresses for the hosted service. + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The name of the Spring context to use. + The base addresses for the hosted service. + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The to use. + The base addresses for the hosted service. + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The to use. + Whether to cache the generated service proxy type. + The base addresses for the hosted service. + + + + Provides a host for Spring-managed services. + + Bruno Baia + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The base addresses for the hosted service. + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The name of the Spring context to use. + The base addresses for the hosted service. + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The to use. + The base addresses for the hosted service. + + + + Creates a new instance of the class. + + The name of the service within Spring's IoC container. + The to use. + Whether to cache the generated service proxy type. + The base addresses for the hosted service. + + + + Factory Object that dynamically implements service interface for web service. + + +

+ This factory object should be used to obtain reference to a web service + that can be safely cast to a service interface, which allows client code to code + against interface, and not directly against the web service. +

+

+ The WSDL contract needs to conform to WS-I Basic Profiles. +

+
+ Bruno Baia + Aleksandar Seovic +
+ + + The web service proxy default constructor. + + + + + Creates a new instance of the + class. + + + + + Creates new instance of the web service proxy. + + New instance of the web service proxy. + + + + Initializes factory object. + + + + + Validates the configuration. + + + + + Generates the web service proxy type. + + + + + Gets XML Web Services documents from a Spring resource. + + + + + Gets or sets the base type that web service proxy should inherit. + + + Default is + + + + + Gets or sets the URI for an + that contains the web service description (WSDL). + + + + + Gets or sets type of the proxy class to wrap. + + + + + Gets or sets service interface that proxy should implement. + + + + + Gets or sets the instance + to use when connecting to a server that requires authentication. + + + + + Gets or sets the url of the proxy server to use for retrieving the WSDL. + + +

+ This only applies when using an as uri. +

+

+ The default is to use the system proxy setting. +

+
+
+ + + Gets or sets the instance + to use when connecting to a proxy server that requires authentication. + + +

+ This only applies when using an as uri. +

+
+
+ + + Gets or sets the web service binding name to use for the proxy. + + + + + Gets or sets a list of custom attributes + that should be applied to a proxy class. + + + + + Gets or sets a dictionary of custom attributes + that should be applied to web service members. + + + Dictionary key is an expression that members can be matched against. + Value is a list of attributes that should be applied + to each member that matches expression. + + + + + Returns type of the web service proxy. + + + + + Always returns false. + + + + + Gets or sets the template object definition + that should be used to configure proxy instance. + + + + + Proxy type builder that can be used to create a proxy for + derived classes. + + + + + Creates a new instance of the + class. + + The URI that contains the Web Service meta info (WSDL). + The XML Web Service documents to use to create the proxy. + The name of the Web Service binding to use. + + + + Creates the proxy type. + + The generated proxy class. + + + + Generates the IL instructions that pushes + the target instance on which calls should be delegated to. + + The IL generator to use. + + + + Implements constructors for the proxy class. + + + The to use. + + + + + Search and returns the binding for the specified name. + + + + + Search and returns the url for the specified binding. + + + + + Search and returns the operation that matches the specified method. + + + + + Search and returns the OperationBinding that matches the specified Operation. + + + + + Search and returns the type mapping between method parameters/return value + and the element parts of a literal-use SOAP message. + + + + + Creates a that should be applied to proxy type. + + + + + Creates a or a + that should be applied to proxy method. + + + + + Proxy method builder that can be used to create a proxy method + for web services operation invocation. + + + + + Creates a new instance of the method builder. + + The type builder to use. + + The implementation to use. + + + + + Generates the proxy method. + + The IL generator to use. + The method to proxy. + + The interface definition of the method, if applicable. + + + + + Proxy type builder that can be used to create a proxy for + .Net-generated proxy class that can be safely cast to a service interface. + + + + + Creates a new instance of the + class. + + + + + Gets the mapping of the interface to proxy + into the actual methods on the target type + that does not need to implement that interface. + + +

+ As the proxy type does not implement the interface, + we try to find matching methods. +

+
+ + The of the target object. + + The interface to implement. + + An interface mapping for the interface to proxy. + +
+ + diff --git a/Resources/Libraries/Spring.NET/Spring.Template.Velocity.dll b/Resources/Libraries/Spring.NET/Spring.Template.Velocity.dll new file mode 100644 index 0000000000000000000000000000000000000000..3d590db84e31188b3dc2dec2ab0c338b1f54ebe3 GIT binary patch literal 32256 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 Va^R!#cSRm!!|}hL|L-{P{{R7j)f@l- literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Template.Velocity.pdb b/Resources/Libraries/Spring.NET/Spring.Template.Velocity.pdb new file mode 100644 index 0000000000000000000000000000000000000000..6eba287885271dfd17200b229665c07f9d5e1449 GIT binary patch literal 40448 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Template.Velocity.xml b/Resources/Libraries/Spring.NET/Spring.Template.Velocity.xml new file mode 100644 index 00000000..d79c57ec --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Template.Velocity.xml @@ -0,0 +1,698 @@ + + + + Spring.Template.Velocity + + + + + Implementation of the custom configuration parser for template configurations + based on + + + Erez Mazor + + + + + Initializes a new instance of the class. + + + + + + + + Parse a template definition from the templating namespace + + the root element defining the templating object + the parser context + + + + + Parses the object definition for the engine object, configures a single NVelocity template engine based + on the element definitions. + + the root element defining the velocity engine + the parser context + + + + Parses child element definitions for the NVelocity engine. Typically resource loaders and locally defined properties are parsed here + + the XmlNodeList representing the child configuration of the root NVelocity engine element + the parser context + the MutablePropertyValues used to configure this object + + + + Configures the NVelocity resource loader definitions from the xml definition + + the root resource loader element + the MutablePropertyValues used to configure this object + the properties used to initialize the velocity engine + + + + Set the caching and modification interval checking properties of a resource loader of a given type + + the properties used to initialize the velocity engine + type of the resource loader + caching flag + modification interval value + + + + Set global velocity resource loader properties (caching, modification interval etc.) + + the properties used to initialize the velocity engine + the type of resource loader + the suffix property + the value of the property + + + + Creates a nvelocity file based resource loader by setting the required properties + + a list of nv:file elements defining the paths to template files + the properties used to initialize the velocity engine + + + + Creates a nvelocity assembly based resource loader by setting the required properties + + a list of nv:assembly elements defining the assemblies + the properties used to initialize the velocity engine + + + + Creates a spring resource loader by setting the ResourceLoaderPaths of the + engine factory (the resource loader itself will be created internally either as + spring or as file resource loader based on the value of prefer-file-system-access + attribute). + + list of resource loader path elements + the MutablePropertyValues to set the property for the engine factory + + + + Create a custom resource loader from an nv:custom element + generates the 4 required nvelocity props for a resource loader (name, description, class and path). + + the nv:custom xml definition element + the properties used to initialize the velocity engine + + + + Parses the nvelocity properties map using ObjectNamespaceParserHelper + and appends it to the properties dictionary + + root element of the map element + the parser context + the properties used to initialize the velocity engine + + + + Gets the name of the object type for the specified element. + + The element. + The name of the object type. + + + + constructs an nvelocity style resource loader property in the format: + prefix.resource.loader.suffix + + the prefix + the suffix + a concatenated string like: prefix.resource.loader.suffix + + + + This method is overriden from ObjectsNamespaceParser since when invoked on + sub-elements from the objets namespace (e.g., objects:objectMap for nvelocity + property map) the element.SelectNodes fails because it is in + the nvelocity custom namespace and not the object's namespace (http://www.springframwork.net) + to amend this the object's namespace is added to the provided XmlNamespaceManager + + The element to be searched in. + The name of the child nodes to look for. + + The child s of the supplied + with the supplied . + + + + + + Template definition constants + + + + + Engine element definition + + + + + Spring resource loader element definition + + + + + Custom resource loader element definition + + + + + uri attribute of the spring element + + + + + prefer-file-system-access attribute of the engine factory + + + + + config-file attribute of the engine factory + + + + + override-logging attribute of the engine factory + + + + + template-caching attribute of the nvelocity engine + + + + + default-cache-size attribute of the nvelocity engine resource manager + + + + + modification-check-interval attribute of the nvelocity engine resource loader + + + + + resource loader element + + + + + nvelocity propeties element (map) + + + + + PreferFileSystemAccess property of the engine factory + + + + + OverrideLogging property of the engine factory + + + + + ConfigLocation property of the engine factory + + + + + ResourceLoaderPaths property of the engine factory + + + + + VelocityProperties property of the engine factory + + + + + resource.loader.cache property of the resource loader configuration + + + + + resource.loader.modificationCheckInterval property of the resource loader configuration + + + + + the type used for file resource loader + + + + + the type used for assembly resource loader + + + + + the type used for spring resource loader + + + + + NVelocity LogSystem implementation for Commons Logging. + + Erez Mazor + + + + Shared logger instance. + + + + + Initializes the specified runtime services. No-op in current implementatin + + the runtime services. + + + + Log a NVelocity message using the commons logging system + + LogLevel to match + message to log + + + + NVelocity's abstract ResourceLoader extension which serves + as an adapter that loads templates via a Spring IResourceLoader. + +
+ Used by VelocityEngineFactory for any resource loader path that + cannot be resolved to a File or an Assembly or for + implementations which rely on spring's IResourceLoader + mechanism. + +
+ Important: this loader does not allow for modification detection. +
+ Expects "spring.resource.loader" (IResourceLoader implementations) + and "spring.resource.loader.path" application attributes in the + NVelocity runtime. +
+ + + + + + Erez Mazor (.NET) +
+ + + Prefix used for the NVelocity Configuration + + + + + The IResourceLoader implementation type + + + + + A flag indicating weather a template cache is used + + + + + Fully qualified name of the IResourceLoader implementation class + + + + + A comma delimited list of paths used by the spring IResourceLoader implementation + + + + + Shared logger instance. + + + + + Initialize the template loader with a resources class. + + The ExtendedProperties representing the Velocity configuration. + + + + Get the System.IO.Stream that the Runtime will parse to create a template. + + the source template name + a System.IO.Stream representation of the resource + + + + Given a template, check to see if the source of InputStream has been modified. + + The resource. + + true if the source of the InputStream has been modified; otherwise, false. + + + + + Get the last modified time of the InputStream source + that was used to create the template. We need the template + here because we have to extract the name of the template + in order to locate the InputStream source. + + The resource. + + + + + Common Velocity constants. + + + + + File. + + + + + Type. + + + + + Assembly. + + + + + Class. + + + + + Name. + + + + + Description. + + + + + Path. + + + + + Separator. + + + + + Factory that configures a VelocityEngine. Can be used standalone, + but typically you will use VelocityEngineFactoryObject + for preparing a VelocityEngine as bean reference. + +
+ The optional "ConfigLocation" property sets the location of the Velocity + properties file, within the current application. Velocity properties can be + overridden via "VelocityProperties", or even completely specified locally, + avoiding the need for an external properties file. + +
+ The "ResourceLoaderPath" property can be used to specify the Velocity + resource loader path via Spring's IResource abstraction, possibly relative + to the Spring application context. + +
+ If "OverrideLogging" is true (the default), the VelocityEngine will be + configured to log via Commons Logging, that is, using the Spring-provided + CommonsLoggingLogSystem as log system. + +
+ The simplest way to use this class is to specify a ResourceLoaderPath + property. the VelocityEngine typically then does not need any further + configuration. + +
+ + + + Erez Mazor +
+ + + Shared logger instance. + + + + + Create and initialize the VelocityEngine instance and return it + + VelocityEngine + + + + + + + + + This is to overcome an issue with the current NVelocity library, it seems the + default runetime properties/directives (nvelocity.properties and directive.properties + files) are not being properly located in the library at load time. A jira should + be filed but for now we attempt to do this on our own. Particularly our + concern here is with several required properties which I don't want + to require users to re-defined. e.g.,: +
+ + Pre-requisites:
+ resource.manager.class=NVelocity.Runtime.Resource.ResourceManagerImpl
+ directive.manager=NVelocity.Runtime.Directive.DirectiveManager
+ runtime.introspector.uberspect=NVelocity.Util.Introspection.UberspectImpl
+
+
+ + + Return a new VelocityEngine. Subclasses can override this for + custom initialization, or for using a mock object for testing.
+ Called by CreateVelocityEngine() +
+ VelocityEngine instance (non-configured) + +
+ + + Initialize a Velocity resource loader for the given VelocityEngine: + either a standard Velocity FileResourceLoader or a SpringResourceLoader. +
Called by CreateVelocityEngine(). +
+ velocityEngine the VelocityEngine to configure + + paths the path list to load Velocity resources from + + + + +
+ + + Initialize a SpringResourceLoader for the given VelocityEngine. +
Called by InitVelocityResourceLoader. + + Important: the NVeloctity ResourceLoaderFactory.getLoader + method replaces ';' with ',' when attempting to construct our resource + loader. The name on the SPRING_RESOURCE_LOADER_CLASS property + has to be in the form of "ClassFullName; AssemblyName" in replacement + of the tranditional "ClassFullName, AssemblyName" to work. +
+ velocityEngine the VelocityEngine to configure + + resourceLoaderPath the path to load Velocity resources from + + +
+ + + To be implemented by subclasses that want to to perform custom + post-processing of the VelocityEngine after this FactoryObject + performed its default configuration (but before VelocityEngine.init) +
+ Called by CreateVelocityEngine +
+ velocityEngine the current VelocityEngine + + + +
+ + + Populates the velocity properties from the given resource + + ExtendedProperties instance to populate + The resource from which to load the properties + A flag indicated weather the properties loaded from the resource should be appended or replaced in the extendedProperties + + + + Set the location of the Velocity config file. Alternatively, you can specify all properties locally. + + + + + + + Set local NVelocity properties. + + + + + + Single ResourceLoaderPath + + + + + + Set the Velocity resource loader path via a Spring resource location. + Accepts multiple locations in Velocity's comma-separated path style. +
+ When populated via a String, standard URLs like "file:" and "assembly:" + pseudo URLs are supported, as understood by IResourceLoader. Allows for + relative paths when running in an ApplicationContext. +
+ Will define a path for the default Velocity resource loader with the name + "file". If the specified resource cannot be resolved to a File, + a generic SpringResourceLoader will be used under the name "spring", without + modification detection. +
+ Take notice that resource caching will be enabled in any case. With the file + resource loader, the last-modified timestamp will be checked on access to + detect changes. With SpringResourceLoader, the resource will be throughout + the life time of the application context (for example for class path resources). +
+ To specify a modification check interval for files, use Velocity's + standard "file.resource.loader.modificationCheckInterval" property. By default, + the file timestamp is checked on every access (which is surprisingly fast). + Of course, this just applies when loading resources from the file system. +
+ To enforce the use of SpringResourceLoader, i.e. to not resolve a path + as file system resource in any case, turn off the "preferFileSystemAccess" + flag. See the latter's documentation for details. +
+ + + + + +
+ + + Set the Spring ResourceLoader to use for loading Velocity template files. + The default is DefaultResourceLoader. Will get overridden by the + ApplicationContext if running in a context. + + + + + + + + + Set whether to prefer file system access for template loading. + File system access enables hot detection of template changes. +
+ If this is enabled, VelocityEngineFactory will try to resolve the + specified "resourceLoaderPath" as file system resource. +
+ Default is "true". Turn this off to always load via SpringResourceLoader + (i.e. as stream, without hot detection of template changes), which might + be necessary if some of your templates reside in a directory while + others reside in assembly files. +
+ +
+ + + Set whether Velocity should log via Commons Logging, i.e. whether Velocity's + log system should be set to CommonsLoggingLogSystem. Default value is true + + + + + + FactoryObject implementation that configures a VelocityEngine and provides it + as an object reference. This object is intended for any kind of usage of Velocity in + application code, e.g. for generating email content. + + See the base class VelocityEngineFactory for configuration details. + + + Erez Mazor + + + + Get the velocity engine underlying object + + An instance of a configured VelocityEngine + + + + + Facilitate the creation of the velocity engine object + + + + + Get the type of the velocity engine + + + + + Singleton + + + + + Generalized Utility class for merging velocity templates into a text writer or return the result as a string + + Erez Mazor + + + + Shared logger instance. + + + + + Merge the specified Velocity template with the given model and write + the result to the given Writer. + + VelocityEngine to work with + the location of template, relative to Velocity's resource loader path + encoding the encoding of the template file + the Hashtable that contains model names as keys and model objects + writer the TextWriter to write the result to + thrown if any exception is thrown by the velocity engine + + + + Merge the specified Velocity template with the given model into a string. + + VelocityEngine to work with + the location of template, relative to Velocity's resource loader path + the encoding string to use for the merge + the Hashtable that contains model names as keys and model objects + the result as string + thrown if any exception is thrown by the velocity engine + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.dll b/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.dll new file mode 100644 index 0000000000000000000000000000000000000000..a807b27fb0e3f1b81b95d75debd8981db39062ad GIT binary patch literal 14848 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.pdb b/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.pdb new file mode 100644 index 0000000000000000000000000000000000000000..6e0988edd7d59196edcd8dca538cb2bb2570b441 GIT binary patch literal 34304 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.xml b/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.xml new file mode 100644 index 00000000..42acb336 --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Testing.Microsoft.xml @@ -0,0 +1,521 @@ + + + + Spring.Testing.Microsoft + + + + + Convenient superclass for tests depending on a Spring context. + The test instance itself is populated by Dependency Injection. + + + +

Really for integration testing, not unit testing. + You should not normally use the Spring container + for unit tests: simply populate your objects in plain NUnit tests!

+ +

This supports two modes of populating the test: +

    +
  • Via Property Dependency Injection. Simply express dependencies on objects + in the test fixture, and they will be satisfied by autowiring by type.
  • +
  • Via Field Injection. Declare protected variables of the required type + which match named beans in the context. This is autowire by name, + rather than type. This approach is based on an approach originated by + Ara Abrahmian. Property Dependency Injection is the default: set the + "populateProtectedVariables" property to true in the constructor to switch + on Field Injection.
  • +

+ +

This class will normally cache contexts based on a context key: + normally the config locations String array describing the Spring resource + descriptors making up the context. Unless the SetDirty() method + is called by a test, the context will not be reloaded, even across different + subclasses of this test. This is particularly beneficial if your context is + slow to construct, for example if you are using Hibernate and the time taken + to load the mappings is an issue.

+ +

If you don't want this behavior, you can override the ContextKey + property, most likely to return the test class. In conjunction with this you would + probably override the GetContext method, which by default loads + the locations specified by the ConfigLocations property.

+ +

WARNING: When doing integration tests from within VS.NET, only use + assembly resource URLs. Else, you may see misleading failures when changing + context locations.

+
+ + Rod Johnson + Rob Harrop + Rick Evans + Aleksandar Seovic (.NET) +
+ + + Superclass for NUnit test cases using a Spring context. + + +

Maintains a cache of contexts by key. This has significant performance + benefit if initializing the context would take time. While initializing a + Spring context itself is very quick, some objects in a context, such as + a LocalSessionFactoryObject for working with NHibernate, may take time to + initialize. Hence it often makes sense to do that initializing once.

+

Normally you won't extend this class directly but rather extend one + of its subclasses.

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Map of context keys returned by subclasses of this class, to + Spring contexts. + + + + + Static ctor to avoid "beforeFieldInit" problem. + + + + + Disposes any cached context instance and removes it from cache. + + + + + Indicates, whether context instances should be automatically registered with the global . + + + + + Logger available to subclasses. + + + + + Default constructor for AbstractSpringContextTests. + + + + + Set custom locations dirty. This will cause them to be reloaded + from the cache before the next test case is executed. + + + Call this method only if you change the state of a singleton + object, potentially affecting future tests. + + Locations + + + + Returns true if context for the specified + is cached. + + Context key to check. + + true if context for the specified + is cached, + false otherwise. + + + + + Converts context key to string. + + + Subclasses can override this to return a string representation of + their contextKey for use in logging. + + Context key to convert. + + String representation of the specified . Null if + contextKey is null. + + + + + Caches application context. + + Key to use. + Context to cache. + + + + Returns cached context if present, or loads it if not. + + Context key. + Spring application context associated with the specified key. + + + + Loads application context from the specified resource locations. + + Resources to load object definitions from. + + + + Loads application context based on user-defined key. + + + Unless overriden by the user, this method will alway throw + a . + + User-defined key. + + + + Controls, whether application context instances will + be registered/unregistered with the global . + Defaults to true. + + + + + Application context this test will run against. + + + + + Holds names of the fields that should be used for field injection. + + + + + Default constructor for AbstractDependencyInjectionSpringContextTests. + + + + + Called to say that the "applicationContext" instance variable is dirty and + should be reloaded. We need to do this if a test has modified the context + (for example, by replacing an object definition). + + + + + Test setup method. + + + + + Inject dependencies into 'this' instance (that is, this test instance). + + +

The default implementation populates protected variables if the + property is set, else + uses autowiring if autowiring is switched on (which it is by default).

+

You can certainly override this method if you want to totally control + how dependencies are injected into 'this' instance.

+
+
+ + + Loads application context from the specified resource locations. + + Resources to load object definitions from. + + + + Retrieves the names of the fields that should be used for field injection. + + + + + Injects protected fields using Field Injection. + + + + + Called right before a field is being injected + + + + + Subclasses can override this method in order to + add custom test setup logic. + + + + + Test teardown method. + + + + + Subclasses can override this method in order to + add custom test teardown logic. + + + + + Gets or sets a flag specifying whether to populate protected + variables of this test case. + + + A flag specifying whether to populate protected variables of this test case. + Default is false. + + + + + Gets or sets the autowire mode for test properties set by Dependency Injection. + + + The autowire mode for test properties set by Dependency Injection. + The default is . + + + + + Gets or sets a flag specifying whether or not dependency checking + should be performed for test properties set by Dependency Injection. + + +

A flag specifying whether or not dependency checking + should be performed for test properties set by Dependency Injection.

+

The default is true, meaning that tests cannot be run + unless all properties are populated.

+
+
+ + + Gets the current number of context load attempts. + + + + + Gets a key for this context. Usually based on config locations, but + a subclass overriding buildContext() might want to return its class. + + + + + Subclasses must implement this property to return the locations of their + config files. A plain path will be treated as a file system location. + + An array of config locations + + + + Subclass of AbstractTransactionalSpringContextTests that adds some convenience + functionality for ADO.NET access. Expects a IDbProvider object + to be defined in the Spring application context. + + + This class exposes a AdoTemplate and provides an easy way to delete from the + database in a new transaction. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Convenient superclass for tests that should occur in a transaction, but normally + will roll the transaction back on the completion of each test. + + +

This is useful in a range of circumstances, allowing the following benefits:

+
    +
  • Ability to delete or insert any data in the database, without affecting other tests
  • +
  • Providing a transactional context for any code requiring a transaction
  • +
  • Ability to write anything to the database without any need to clean up.
  • +
+ +

This class is typically very fast, compared to traditional setup/teardown scripts.

+ +

If data should be left in the database, call the SetComplete() + method in each test. The "DefaultRollback" property, which defaults to "true", + determines whether transactions will complete by default.

+ +

It is even possible to end the transaction early; for example, to verify lazy + loading behavior of an O/R mapping tool. (This is a valuable away to avoid + unexpected errors when testing a web UI, for example.) Simply call the + endTransaction() method. Execution will then occur without a + transactional context.

+ +

The StartNewTransaction() method may be called after a call to + EndTransaction() if you wish to create a new transaction, quite + independent of the old transaction. The new transaction's default fate will be to + roll back, unless setComplete() is called again during the scope of the + new transaction. Any number of transactions may be created and ended in this way. + The final transaction will automatically be rolled back when the test case is + torn down.

+ +

Transactional behavior requires a single object in the context implementing the + IPlatformTransactionManager interface. This will be set by the superclass's + Dependency Injection mechanism. If using the superclass's Field Injection mechanism, + the implementation should be named "transactionManager". This mechanism allows the + use of this superclass even when there's more than one transaction manager in the context.

+ +

This superclass can also be used without transaction management, if no + IPlatformTransactionManager object is found in the context provided. Be careful about + using this mode, as it allows the potential to permanently modify data. + This mode is available only if dependency checking is turned off in + the AbstractDependencyInjectionSpringContextTests superclass. The non-transactional + capability is provided to enable use of the same subclass in different environments.

+ +
+ + Rod Johnson + Juergen Hoeller + Rick Evans + Mark Pollack (.NET) +
+ + + The transaction manager to use + + + + + Should we roll back by default? + + + + + Should we commit the current transaction? + + + + + Number of transactions started + + + + + Default transaction definition is used. + Subclasses can change this to cause different behaviour. + + + + + TransactionStatus for this test. Typical subclasses won't need to use it. + + + + + Initializes a new instance of the class. + + + + + Prevents the transaction. + + + + + Creates a transaction + + + + + Callback method called before transaction is setup. + + + + + Callback method called after transaction is setup. + + + + + rollback the transaction. + + + + + Callback before rolling back the transaction. + + + + + Callback after rolling back the transaction. + + + + + Set the complete flag.. + + + + + Ends the transaction. + + + + + Starts the new transaction. + + + + + Sets the transaction manager to use. + + + + + Sets the default rollback flag. + + + + + Set the to be used + + + Defaults to + + + + + Holds the that this base class manages + + + + + Did this test delete any tables? If so, we forbid transaction completion, + and only allow rollback. + + + + + Initializes a new instance of the class. + + + + + Convenient method to delete all rows from these tables. + Calling this method will make avoidance of rollback by calling + SetComplete() impossible. + + + + + + Overridden to prevent the transaction committing if a number of tables have been + cleared, as a defensive measure against accidental permanent wiping of a database. + + + + + Counts the rows in given table. + + Name of the table to count rows in. + The number of rows in the table + + + + Sets the DbProvider, via Dependency Injection. + + The IDbProvider. + + + + Gets or sets the AdoTemplate that this base class manages. + + The ADO template. + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Testing.NUnit.dll b/Resources/Libraries/Spring.NET/Spring.Testing.NUnit.dll new file mode 100644 index 0000000000000000000000000000000000000000..7406240afc1ea296adcf5c28a34161a74798a37a GIT binary patch literal 18432 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%0AXY-gtd3Pp9`GLST zoG<1s%iclq0m14Vjw5+}DxVrf)dkhYnx$b`Ql*>Vk0bFy~XPB|G46Wm~CxQtyDPYxlTRwtsv2s<+) z>Q7nSM$#hL<}ICByh!F`W)wjsR?YcQs9>eGMv~^`qfySHGAGc0C4$BA-0J8^JTab| zM^MF#V*JzwqsU|nVQxv_+B~mCB+Xknt8BN`KN{OE`SR69J_@pxTHeu4Aytq-^W%h` zd`57=!!d`7AU>2!I(f0HEDN`$$!xOek414Fi04xcm*9Ei7Cd|0LP>mWx){Hvt-<^K zCsXm0o`#omT+B(8Q5qtP2FRolO5xpwDBjmF@wSEym`2YiWW|{BnbqivgTus#5V$Nr z3u8>k3E?^D1=NXa8r(McQs4;DHnc5B4iPoyIWo>HBVw%N%gbJY=dMk(m#AhCvssXb zheNm~#N074GZr1l;P>c$V65>d=A|O0bkQ*8q|z8hB++AnhBr{wv_d0ZUmWsyL|pW< z+&otZnzAI;D2X1v4nhKBqhfwq*aH~HezU+hl z#MpVg&@Ck_DD~l4^STR-7IuTDkQ$<0(1C5j){jCanMliZ{f>@pVmG%z!}ZwP1F%n%@Irys{@cDi|Ed4| z;i`L{tN5_1>>K^$d0_XJ4OL5Cy+#X>;`uAjm49*Iy+zk+MzBOP0s+ac>FG?;#ax5ib0pI5Pr6Ud_VM30uxtp z+cR++e!?Vu0&icU+fV_3_w~0n^G}fc=G&3KvL1fy_PbWR^iTEQn}6Il@25je$Bob{ zhp6T3*O$HV4|lJv{=(n?<+V%yvT@DoTb^IGvH857rHB9dt3SWieP(*@zIz^f@BV+a zzV3hi?w+#EEuTq!{hq|1l+t(JxmSN>UdaVV-n!?1w%q@@`Z>SZ{pkHaed*gTeE;)B zGwXF!>`Q-e;t3(}NnoD9#BEYo%{OR`;Xlfd~I>x54vvs;MO0H|KP2eJSMhc z%hr^A*_O2UmA(O9*pjhFlRLHyj>Z#1TNsCBw>a+DGS#XZQ$vH)z6HXZ&n4UrWwFWE z?B5VeDt@rB+Y^Z{JkTKV3%F^DR|B~BnG8!>T-lOC-$*zFs zTaLfJP;&O&0A3qX^Rk-pCi7x^7vZ}E7H$DtEOe>DxV%;Q4meS;l25BcBkaoMHh&J_ zEhz;>wk-JZ@Ez+Hj=w#ebtlXQ@`ChU8@f8-GyO+@^(hT~{EdP2~dpW1M=@x5(5D3dM8IyQ>< z+=6$_6zng#CiV&2E$h?lbA-upa4H`b+AoDdU%}tfbHolIa`=J3C&d;=U} literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Testing.NUnit.pdb b/Resources/Libraries/Spring.NET/Spring.Testing.NUnit.pdb new file mode 100644 index 0000000000000000000000000000000000000000..5a434e3fa340847f02b36cec8b225fe875accf83 GIT binary patch literal 42496 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 v1k3_10L}+41Zsd + + + Spring.Testing.NUnit + + + + + Holds status for an active transaction. You *must* dispose this object! + + + + Usage Pattern: + + TBD + + + + + + + Mark transaction for commit on disposal + + + + + Throw exception and rollback any uncommitted commands + + + + + TBD + + Erich Eichinger + + + + TBD + + + + + TBD + + + + + TBD + + + + + TBD + + + + + TBD + + + + + TBD + + + + + TBD + + + + + TBD + + + + + TBD + + + + + Execute the given script + + + + + Execute the given script + + + + + Execute the given script + + + + + Execute the given script + + + + + Execute the given script + + + + + Execute the given script + + + + + Execute the given script + + + + + TBD + + + + + Convenient superclass for tests depending on a Spring context. + The test instance itself is populated by Dependency Injection. + + + +

Really for integration testing, not unit testing. + You should not normally use the Spring container + for unit tests: simply populate your objects in plain NUnit tests!

+ +

This supports two modes of populating the test: +

    +
  • Via Property Dependency Injection. Simply express dependencies on objects + in the test fixture, and they will be satisfied by autowiring by type.
  • +
  • Via Field Injection. Declare protected variables of the required type + which match named beans in the context. This is autowire by name, + rather than type. This approach is based on an approach originated by + Ara Abrahmian. Property Dependency Injection is the default: set the + "populateProtectedVariables" property to true in the constructor to switch + on Field Injection.
  • +

+ +

This class will normally cache contexts based on a context key: + normally the config locations String array describing the Spring resource + descriptors making up the context. Unless the SetDirty() method + is called by a test, the context will not be reloaded, even across different + subclasses of this test. This is particularly beneficial if your context is + slow to construct, for example if you are using Hibernate and the time taken + to load the mappings is an issue.

+ +

If you don't want this behavior, you can override the ContextKey + property, most likely to return the test class. In conjunction with this you would + probably override the GetContext method, which by default loads + the locations specified by the ConfigLocations property.

+ +

WARNING: When doing integration tests from within VS.NET, only use + assembly resource URLs. Else, you may see misleading failures when changing + context locations.

+
+ + Rod Johnson + Rob Harrop + Rick Evans + Aleksandar Seovic (.NET) +
+ + + Superclass for NUnit test cases using a Spring context. + + +

Maintains a cache of contexts by key. This has significant performance + benefit if initializing the context would take time. While initializing a + Spring context itself is very quick, some objects in a context, such as + a LocalSessionFactoryObject for working with NHibernate, may take time to + initialize. Hence it often makes sense to do that initializing once.

+

Normally you won't extend this class directly but rather extend one + of its subclasses.

+
+ Rod Johnson + Aleksandar Seovic (.NET) +
+ + + Map of context keys returned by subclasses of this class, to + Spring contexts. + + + + + Static ctor to avoid "beforeFieldInit" problem. + + + + + Disposes any cached context instance and removes it from cache. + + + + + Indicates, whether context instances should be automatically registered with the global . + + + + + Logger available to subclasses. + + + + + Default constructor for AbstractSpringContextTests. + + + + + Set custom locations dirty. This will cause them to be reloaded + from the cache before the next test case is executed. + + + Call this method only if you change the state of a singleton + object, potentially affecting future tests. + + Locations + + + + Set context with dirty. This will cause + it to be reloaded from the cache before the next test case is executed. + + + Call this method only if you change the state of a singleton + object, potentially affecting future tests. + + Locations + + + + Returns true if context for the specified + is cached. + + Context key to check. + + true if context for the specified + is cached, + false otherwise. + + + + + Converts context key to string. + + + Subclasses can override this to return a string representation of + their contextKey for use in logging. + + Context key to convert. + + String representation of the specified . Null if + contextKey is null. + + + + + Caches application context. + + Key to use. + Context to cache. + + + + Returns cached context if present, or loads it if not. + + Context key. + Spring application context associated with the specified key. + + + + Loads application context from the specified resource locations. + + Resources to load object definitions from. + + + + Loads application context based on user-defined key. + + + Unless overriden by the user, this method will alway throw + a . + + User-defined key. + + + + Controls, whether application context instances will + be registered/unregistered with the global . + Defaults to true. + + + + + Application context this test will run against. + + + + + Holds names of the fields that should be used for field injection. + + + + + Default constructor for AbstractDependencyInjectionSpringContextTests. + + + + + Called to say that the "applicationContext" instance variable is dirty and + should be reloaded. We need to do this if a test has modified the context + (for example, by replacing an object definition). + + + + + Test setup method. + + + + + Inject dependencies into 'this' instance (that is, this test instance). + + +

The default implementation populates protected variables if the + property is set, else + uses autowiring if autowiring is switched on (which it is by default).

+

You can certainly override this method if you want to totally control + how dependencies are injected into 'this' instance.

+
+
+ + + Loads application context from the specified resource locations. + + Resources to load object definitions from. + + + + Retrieves the names of the fields that should be used for field injection. + + + + + Injects protected fields using Field Injection. + + + + + Called right before a field is being injected + + + + + Subclasses can override this method in order to + add custom test setup logic after the context has been created and dependencies injected. + Called from this class's [SetUp] method. + + + + + Test teardown method. + + + + + Subclasses can override this method in order to + add custom test teardown logic. Called from this class's [TearDown] method. + + + + + Gets or sets a flag specifying whether to populate protected + variables of this test case. + + + A flag specifying whether to populate protected variables of this test case. + Default is false. + + + + + Gets or sets the autowire mode for test properties set by Dependency Injection. + + + The autowire mode for test properties set by Dependency Injection. + The default is . + + + + + Gets or sets a flag specifying whether or not dependency checking + should be performed for test properties set by Dependency Injection. + + +

A flag specifying whether or not dependency checking + should be performed for test properties set by Dependency Injection.

+

The default is true, meaning that tests cannot be run + unless all properties are populated.

+
+
+ + + Gets the current number of context load attempts. + + + + + Gets a key for this context. Usually based on config locations, but + a subclass overriding buildContext() might want to return its class. + + + + + Subclasses must implement this property to return the locations of their + config files. A plain path will be treated as a file system location. + + An array of config locations + + + + Subclass of AbstractTransactionalSpringContextTests that adds some convenience + functionality for ADO.NET access. Expects a IDbProvider object + to be defined in the Spring application context. + + + This class exposes a AdoTemplate and provides an easy way to delete from the + database in a new transaction. + + Rod Johnson + Juergen Hoeller + Mark Pollack (.NET) + + + + Convenient superclass for tests that should occur in a transaction, but normally + will roll the transaction back on the completion of each test. + + +

This is useful in a range of circumstances, allowing the following benefits:

+
    +
  • Ability to delete or insert any data in the database, without affecting other tests
  • +
  • Providing a transactional context for any code requiring a transaction
  • +
  • Ability to write anything to the database without any need to clean up.
  • +
+ +

This class is typically very fast, compared to traditional setup/teardown scripts.

+ +

If data should be left in the database, call the SetComplete() + method in each test. The "DefaultRollback" property, which defaults to "true", + determines whether transactions will complete by default.

+ +

It is even possible to end the transaction early; for example, to verify lazy + loading behavior of an O/R mapping tool. (This is a valuable away to avoid + unexpected errors when testing a web UI, for example.) Simply call the + endTransaction() method. Execution will then occur without a + transactional context.

+ +

The StartNewTransaction() method may be called after a call to + EndTransaction() if you wish to create a new transaction, quite + independent of the old transaction. The new transaction's default fate will be to + roll back, unless setComplete() is called again during the scope of the + new transaction. Any number of transactions may be created and ended in this way. + The final transaction will automatically be rolled back when the test case is + torn down.

+ +

Transactional behavior requires a single object in the context implementing the + IPlatformTransactionManager interface. This will be set by the superclass's + Dependency Injection mechanism. If using the superclass's Field Injection mechanism, + the implementation should be named "transactionManager". This mechanism allows the + use of this superclass even when there's more than one transaction manager in the context.

+ +

This superclass can also be used without transaction management, if no + IPlatformTransactionManager object is found in the context provided. Be careful about + using this mode, as it allows the potential to permanently modify data. + This mode is available only if dependency checking is turned off in + the AbstractDependencyInjectionSpringContextTests superclass. The non-transactional + capability is provided to enable use of the same subclass in different environments.

+ +
+ + Rod Johnson + Juergen Hoeller + Rick Evans + Mark Pollack (.NET) +
+ + + The transaction manager to use + + + + + Should we roll back by default? + + + + + Should we commit the current transaction? + + + + + Number of transactions started + + + + + Default transaction definition is used. + Subclasses can change this to cause different behaviour. + + + + + TransactionStatus for this test. Typical subclasses won't need to use it. + + + + + Initializes a new instance of the class. + + + + + Prevents the transaction. + + + + + Creates a transaction + + + + + Callback method called before transaction is setup. + + + + + Callback method called after transaction is setup. + + + + + rollback the transaction. + + + + + Callback before rolling back the transaction. + + + + + Callback after rolling back the transaction. + + + + + Set the complete flag.. + + + + + Ends the transaction. + + + + + Starts the new transaction. + + + + + Sets the transaction manager to use. + + + + + Sets the default rollback flag. + + + + + Set the to be used + + + Defaults to + + + + + Holds the that this base class manages + + + + + Did this test delete any tables? If so, we forbid transaction completion, + and only allow rollback. + + + + + Initializes a new instance of the class. + + + + + Convenient method to delete all rows from these tables. + Calling this method will make avoidance of rollback by calling + SetComplete() impossible. + + + + + + Overridden to prevent the transaction committing if a number of tables have been + cleared, as a defensive measure against accidental permanent wiping of a database. + + + + + Counts the rows in given table. + + Name of the table to count rows in. + The number of rows in the table + + + + Execute the given SQL script using + + + + + + + + Sets the DbProvider, via Dependency Injection. + + The IDbProvider. + + + + Gets or sets the AdoTemplate that this base class manages. + + The ADO template. + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Web.Extensions.dll b/Resources/Libraries/Spring.NET/Spring.Web.Extensions.dll new file mode 100644 index 0000000000000000000000000000000000000000..dc8b5e7c8d5976159ad307329c538c682eba0603 GIT binary patch literal 7680 zcmeHLeRLGpb-!Y)F66##g0 zuJF6KsYC~&mTe_Kl)iNV@#Cq+Q`EZPebmxZCIs16I)I05&2zYmXbY$%?OBd18vEuU zAN|)__>GX2OKJfOscvWsl*O@!KJ{+-zJYCT_P^5+pQ^s=OBXhbU42bt!}ABy7nA!& z4qx-+PZHniePO(1)47Awm!A>K*H5RP``G;tT=nTk&eWeOZ#a0{pUiBXS@N#(dyyYJ zlSrMfxns#1@m6+YZGZZWoezwSTwHqTcJsuuLv3GZ{@WkkUH;GC(8`~F>%pl_o6mjW zt%{GIE^oQ$IVO;;6-`$W1sw!Id=wE=JWZHW@EH1v=PoALVf4)iz;#rG;6|W@|FG9Y zLV_k%Ua)C7K=2qAg|ckLy>;MMm50l#{inm_CNdCo)__#uHCF%+m@5I7lx@C%uy}k; zHRx6PnpWXerG%Aob2YFgKnVM1J}_&b+H7E2S-9-eMs;i3F$LbQbe#`|gVkYpA6!v= z&$W;TX2NuENq!1t<~sD;@OTwpNHMQL|GJHNiit6T*R8Uf@VXN*3(#4fD`Hj{-Gtqs zg*ax->wrxIQ)E6Y4YW0l=6a@b7Ut{RH>cxe9R_O}m#w@PhzRmnTb`x1b;%ro&n37xZMGdCYY^_LD`U==~|3pb+-$ zGk`y*OMvZy;U2&seNLPJ{3>9C-VpyNLUho>lG7fRIVIsa315`(ml6iN%vB}qlrS#g zAqhY4{R8hFdJ?k>(T}~~^oHm?3EPx2n8T>DLkZGxg~xpuFhtLR9-v=6PaYZl`ddIY^8Td1ylv&J)#kCOf*qFeN;5ljLH^1x$-lj z1sX~{_x_5`hz|7Du629g5I4bMi|jo|eors_-Xwb`SHA84oWP=hbS;wRp+-P2wE!yA z0Vt?P!X1DfDdUwg3XOo`qYry{b=*py5ks^Oa5rfZ8WMg)!YK)lOL#)UlYm2Xzr?>R z;iG`J(RsiF^liWv`fIvT35aruzbIin9aTc2o9FbFlW3|1J@h@eC8k@m9gU)sP50DE3MD8d@DV4VxbdJO(%rxFDib zK`#SV(N6$Z)2{&=sL2zh^|TqVoiczsq)d$d2>9*v=YR?N72qNAdZT3167O*_Ba~^* zffuoV^AxWWooZ3nvlI}3$N7bP6SnnM>(6 zQ7p@wNOX@r7TtQ((KEJTX6$G(m7-X}GP2G#Et5>?R-cw|OlzuG+~r4Ox^>t{=ynmS z2#v;a*{o?f)IDZ97L3fdH)T6|nun+UZH|+j$4=V`(@Gg*6q9lkpUUcFFXEVFxI)ok zeLSTn9884z3_X?X&y1UkDvch|$MWva8@Isd)f`P4??GG~E5~7w21`XonNB-(XVP@X zo5#LIcY3tMq`pI+TGSPaN(03)AdUw{mDe-q=Ut>>J*8{5KHJSFu*bCY*|^Ut^#d6< zCUTZGmeRYk*_4scI4raL9!uApSwsDpo|Z}Il*kWh=^x4Iwj(E>vr?4RoXNPQW$YA` zk~HZq4AQc5PFmWL-7GjcWn-k&5EQ6qAl751F|?L(x*eQYV>w5sZrj$=W2vb*2idKK z>>&%QG_j~&I;&--7HagE*(uAIm|R2$z9;pxW*u5YE0=O|mcEcNqFY=L3mLt7N}Gxq z6N|9ohJ$D?m};-?uGF(%hmM&Se}U ztw%Y&25NM!5?z8!H5Q9@RAP3)rMx1Gfi-5N45uiRi|z>2jeL?Om{}KR8E&`d)QrIG@(1A#dsekBiGJ|VL3T>9qo3cmlQX#k(eo7L%YTfqRR6% zw*?hJ{h7n&Ayk397tKZqzC^k75IvG5D93X#R26Y$PU?w6dUBBp$xn_)Cm7Sg>q(c?tB)HQBfp_#l5k`J zo%LCRz09X!>rvi#b&K-p=0bKi4W0q_`Ybb@rz}1J>M!-F-)6O)nv&x3C!lb&6jK+RAaY~RyI)wYJF!*h?xqXVJvrMk({o&#wwNY1#0;`;>o{lzO(%cm z=*g`|6M9z0Et-(~>+HTG*T7t7i;+oUdGw_;+@>*vJT-`^h~AKfF9oU;K{*xp2lr@58h*V$8ZO*$e=7Z+|$uJjD7-`J&(T)H?0gMapz~L zKJ*gMGJ#JKwU5#fX|vSE6?J0&GoM`FOULPjHx3?JaSOa~s7HD?348}0_=onL(fbB( zzV_P#PyB4@r%o+>^))KfUw2;Y{^=covZrny{aE-Pf}6{pxpV(WO~-2|y#7cfo-m%} zcxv#JdsPzUsuHP-)Q3VLpDIM8u0r*pzfMvVP&^DIFT9V@vgt43eoe|W;YSFr@3_Kp ze>m3N%6A~Xbf10FeD?V-Kf3vqe{cSJ<9oq|i^-Pv{OYR@Q0E7Ky76Z}cx+qkAHMYP zJvTfYy`}HIOB?sL-n8q6)9*a^_xA*@x7Qwf;`z6p{+D8X6Sbx``7r7zV>(D8T`s{ z>q8g(Y=nOe&(R114B6RC_$ zpR5C`u9kn5$`KwfQ$3MzC_H^8jIb}qJ2HK?E>c++o<1Kz;A@ywAe99?%*4?0in&@) zbw+nK@GsUQMy9>(gDO4%@eKt(I|Y3pzq1T(jjMfJNk>fUklGq;kG84frlm%i0bTrf z7qr9`j+r?N7ZLn=By6Gi16^%vX=&R4(5WtJGOlZB{Crgft?th9RZAVfwG?|ovzkA} z)ixexm7wK$1AH_T?M$>w(Dr`Zx2$mu7g`k;95s>Ba862dBm3SocsRB zs;D$l@m);C2cY3tZ|s}xk9HkzxO>O_+upcv``i8h!5WFp`$x0Z!Tq+p$!|a|_T!$K zIkbN)XQYz*xsUkn&nIR7qH~XClVj}Q*Ye-s82=l_RmK*!*>82FoKajtdsC^Mnvo%S zbJunGOM;~?uOqdqRQ!rP{>4m$Pg&EYVjMtxgIt8pa{TRZZx_)^3isUhlF|WW1iS7i z;8q$2)=#@=5dD6@KH%IgC~v;UTZI?To2NW;@0%sp{VnCDGf%*)7mt8dP43i&+_U?! zdyiwk=GG{GfyKe)J>3SM_fG@djN}tNrF6ho0iPU58K6(VqxqJWN|_eS+x_dnse%~L zQ`mR$OCI*p_|u{7U=+f<7~}I}93#4?j4FLdBBcrGhYd+SeN;$JO21T`PZn(P$&>_7 zrEd5&g!5?-af{3TcF^_$YX!9hZ<}(^%0kP69aYXig%(?KXT#cjR&cwKD(C#oN`I!n z)uivtFV>5}W)4=^dv0;6hVE=^dZq7$Q?(G&VjG1Mcq<*15#cPjvK*&P_^MT~IRcy3 z9G}PJS+?V8!_$HJb^>x)#Ay}u3Q^8r4ymG<{PsRX+J&?DfHx8|x!7Uxy$W$9PQRFMmV_@Lj6d2Y2Q2 zT1Z36!Z!?#8et7^_7d=lSIGc8HGH$!_bK>>EahuI4_jnbT zu7fM*un@m2HNp2G*ftT<96Z8haL(dG^Sce|^ru|GI_+f=|`-8W-6AxBqhy_;0|g5dZ)H literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Web.Extensions.pdb b/Resources/Libraries/Spring.NET/Spring.Web.Extensions.pdb new file mode 100644 index 0000000000000000000000000000000000000000..58d59a5e1a4555b67c6855a8587f0797df2290ae GIT binary patch literal 13824 zcmeHNU2IfE6rOEs>9$>DE3LF(tymHSy1NC$YLLGcq-l|#<(~z+-QLor%kH{+X(b_X zOB9XKgs4$5`e2BP@ewdaso}v8Q6q^U;lcRe1Br_KX(BO*e&5X8_EMlNgdnu{z`5U@ zIdkUc%*>f{XS*mGNhQ*WRbsjhh|f9F zvc2(>v-6I1r9Rxnuz_^=>d}CGIFhgc)OT0alPDMgNnW@3I%4qh@f5tT8>1ZOJ z4j~x|MpDtF844Pyj%dV4>-55Kyd`F&7K9^aBDK{QNe|GBYFl@~*NJ9~-e!;trByR& zs~MGUQ_ZyYHp3H)BijgW1CyL+SJ|QWIris(D}&@W&v$PaxAa@r^~QNDPuD@TbZPC0 zU|IK?hV`qp%$f-UX@_nP3vieC#3V0!Q==zvs;z6t%4JfDeB8rAl!$CE^)7;~vXtkG zO7Du`*0gDCMwy;>-!h{$W<*Rl3L!??^5HZ@`Q>S!aw0yLtyse&xy095m^PWTn)6w^C=ya(1WZ!54d)?t=(wZ(Y33Y34+*3E?%ZymqjCL3+ zqbYMsIJP8g!f}+KEbVNsE1qbPcAJ6@2GG!(kiTPVn+w!lULOt1wg` zQ#giXoqJH{6x4Yi(x0kwvJWHr=yawHIp}LtTufS=}hQLmY_2yz$|OYxn8M*>CtQE%Kbn)T}@ss^K);g|L38* z5KMC6pXJ|Z!kIExh{uKKD#3d#a2#-f5Zl>iy$~6Y6A0Q)-QL9aZ}@QAtKiI@ZfybRn4egGq^ z019|NBP-;TsPoiexo z+!Az-{uOIj`kyY1yEM|~Vp<8c(A~AtSkKodC z2^HX%h=*)>ff)=z12~w+yb2APItAu z_rdq&O9dj)QHWi$4ddDgW=vz+#>lw0RHjcKw6fK&L-yZ?ED6yqM(J;X0M2e6QhWY} zGts1O73FnepHF{%6>$0ep_o5!YR%lh)LN=nedaso68FoR;A*ZQw#9ra=C&80jPa<) zo~hp{W6a6eu`f}^7?a;BeJKmUiH8L+O4^lgyid>5F^iQ)se?n<0{#8|{~E^aZ;Zy<>*K8n;pbISTKMr>fWOTMw-~ABSR&G{ zGI-UL_V@ey!A-r`=hoyh=AWgK#)Elf!?=YqUX^LDBSRY`9lDwY=>Hg({|2rBkJY~F zJl-?l)nI<(#$er-A>(<#J5hvX@>`I`=3T~UFz+vEcuqtfxB$$!pKXi;-wkHGQ3RF& eCeWe(*8)7x9daz-SirG>V*$qkjs=F71^xru2chx+ literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Web.Extensions.xml b/Resources/Libraries/Spring.NET/Spring.Web.Extensions.xml new file mode 100644 index 00000000..c2970ec2 --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Web.Extensions.xml @@ -0,0 +1,50 @@ + + + + Spring.Web.Extensions + + + + + An implementation that + creates a handler object for either ASP.NET AJAX 1.0 or Spring web services. + + Bruno Baia + Thomas Broyer + + + + Creates a new instance of the class. + + + + + Retrieves an instance of the + implementation for handling web service requests + for both Spring and ASP.NET AJAX 1.0 web services. + + The current HTTP context. + The type of HTTP request (GET or POST). + The url of the web service. + The physical application path for the web service. + The web service handler object. + + + + Enables a factory to reuse an existing handler instance. + + The object to reuse. + + + + Create a handler instance for the given URL. + + the application context corresponding to the current request + The instance for this request. + The HTTP data transfer method (GET, POST, ...) + The requested . + The physical path of the requested resource. + A handler instance for the current request. + + + diff --git a/Resources/Libraries/Spring.NET/Spring.Web.Mvc.dll b/Resources/Libraries/Spring.NET/Spring.Web.Mvc.dll new file mode 100644 index 0000000000000000000000000000000000000000..7da13f5d99c9bc1b81741cbb1925a53405bd2b70 GIT binary patch literal 13824 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 KEs(c>QvVM^xx + + + Spring.Web.Mvc + + + + + Application Context for ASP.NET MVC Applications + + + + + Create a new MvcApplicationContext, loading the definitions + from the given XML resource. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + Names of configuration resources. + + + + Create a new MvcApplicationContext with the given parent, + loading the definitions from the given XML resources. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + The parent context. + Names of configuration resources. + + + + Initializes a new instance of the class. + + The args. + + + + Create a new MvcApplicationContext, loading the definitions + from the given XML resource. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + Names of configuration resources. + Configuration resources. + + + + Create a new MvcApplicationContext, loading the definitions + from the given XML resource. + + Names of configuration resources. + + + + An array of resource locations, referring to the XML object + definition files that this context is to be built with. + + + +

+ Examples of the format of the various strings that would be + returned by accessing this property can be found in the overview + documentation of with the + class. +

+
+ + An array of resource locations, or if none. + +
+ + + An array of resources that this context is to be built with. + + + +

+ Examples of the format of the various strings that would be + returned by accessing this property can be found in the overview + documentation of with the + class. +

+
+ + An array of s, or if none. + +
+ + + Encapsulates arguments to the class. + + + + + Initializes a new instance of the MvcApplicationContextArgs class. + + + + + Initializes a new instance of the MvcApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + + + + Initializes a new instance of the MvcApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + if set to true [case sensitive]. + + + + Context Handler for ASP.NET MVC Applications + + + + + The of + created if no type attribute is specified on a context element. + + + + + + Get the context's case-sensitivity to use if none is specified + + + +

+ Derived handlers may override this property to change their default case-sensitivity. +

+

+ Defaults to 'true'. +

+
+
+ + + ActionInvoker implementation that enables the to satisfy dependencies on ActionFilter attributes. + + + + + Initializes a new instance of the class. + + The IApplicationContext. + + + + Retrieves information about the action filters. + + The controller context. + The action descriptor. + Information about the action filters. + + + + Controller Factory for ASP.NET MVC + + + + + Creates the specified controller by using the specified request context. + + The context of the HTTP request, which includes the HTTP context and route data. + The name of the controller. + A reference to the controller. + The parameter is null. + The parameter is null or empty. + + + + Retrieves the controller instance for the specified request context and controller type. + + The context of the HTTP request, which includes the HTTP context and route data. + The type of the controller. + The controller instance. + + is null. + + cannot be assigned. + An instance of cannot be created. + + + + Adds the action invoker to the controller instance. + + The controller. + + + + Gets the application context. + + The application context. + + + + Gets or sets the name of the application context. + + + Defaults to using the root (default) Application Context. + + The name of the application context. + + + + Spring.NET-specific HttpApplication for ASP.NET MVC integration. + + + + + Handles the Start event of the Application control. + + The source of the event. + The instance containing the event data. + + + + Configures the instance. + + + You must override this method in a derived class to control the manner in which the + is configured. + + + + + Executes custom initialization code after all event handler modules have been added. + + + + + Registers the areas. + + + Override this method in a derived class to modify the registered areas as neeeded. + + + + + Registers the routes. + + + Override this method in a derived class to modify the registered routes as neeeded. + + + + + Registers the controller factory with the Mvc Framework. + + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Web.Mvc3.dll b/Resources/Libraries/Spring.NET/Spring.Web.Mvc3.dll new file mode 100644 index 0000000000000000000000000000000000000000..bcfcaf1b54c3dded880985a7b876b0f507b56b47 GIT binary patch literal 8704 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 Rai_su1NiJP4O3VH{|Cc + + + Spring.Web.Mvc3 + + + + + Application Context for ASP.NET MVC Applications + + + + + Create a new MvcApplicationContext, loading the definitions + from the given XML resource. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + Names of configuration resources. + + + + Create a new MvcApplicationContext with the given parent, + loading the definitions from the given XML resources. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + The parent context. + Names of configuration resources. + + + + Initializes a new instance of the class. + + The args. + + + + Create a new MvcApplicationContext, loading the definitions + from the given XML resource. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + Names of configuration resources. + Configuration resources. + + + + Create a new MvcApplicationContext, loading the definitions + from the given XML resource. + + Names of configuration resources. + + + + An array of resource locations, referring to the XML object + definition files that this context is to be built with. + + + +

+ Examples of the format of the various strings that would be + returned by accessing this property can be found in the overview + documentation of with the + class. +

+
+ + An array of resource locations, or if none. + +
+ + + An array of resources that this context is to be built with. + + + +

+ Examples of the format of the various strings that would be + returned by accessing this property can be found in the overview + documentation of with the + class. +

+
+ + An array of s, or if none. + +
+ + + Encapsulates arguments to the class. + + + + + Initializes a new instance of the MvcApplicationContextArgs class. + + + + + Initializes a new instance of the MvcApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + + + + Initializes a new instance of the MvcApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + if set to true [case sensitive]. + + + + Context Handler for ASP.NET MVC Applications + + + + + Spring.NET-specific HttpApplication for ASP.NET MVC integration. + + + + + Executes custom initialization code after all event handler modules have been added. + + + + + Handles the BeginRequest event of the Application control. + + The source of the event. + The instance containing the event data. + + + + Builds the dependency resolver. + + The instance. + You must override this method in a derived class to control the manner in which the + is created. + + + + Configures the instance. + + + You must override this method in a derived class to control the manner in which the + is configured. + + + + + Registers the DependencyResolver implementation with the MVC runtime. + + You must override this method in a derived class to control the manner in which the + is registered. + + + + + + Thread-safe class that ensures that the is registered only once. + + + + + Registers the specified resolver. + + The resolver. + + + + Spring-based implementation of the interface. + + + + + Initializes a new instance of the class. + + The context. + + + + Resolves singly registered services that support arbitrary object creation. + + The type of the requested service or object. + The requested service or object. + + + + Resolves multiply registered services. + + The type of the requested services. + The requested services. + + + + Gets the application context. + + The application context. + + + + Gets or sets the name of the application context. + + + Defaults to using the root (default) Application Context. + + The name of the application context. + +
+
diff --git a/Resources/Libraries/Spring.NET/Spring.Web.dll b/Resources/Libraries/Spring.NET/Spring.Web.dll new file mode 100644 index 0000000000000000000000000000000000000000..c9b1c7e9e81e19b953cf52eaa3b9be98876284df GIT binary patch literal 165888 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 z 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%0A*xBU5fmc1^HX6Dw|cz<)`Ezu25 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�myAL_Tb7zITRs=)D@7I^a`&?|2w>yEo|@o5Hj* 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 Wy9NGkfxlbe?-uyG1^#zh;Qs(ywO5(| literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Web.xml b/Resources/Libraries/Spring.NET/Spring.Web.xml new file mode 100644 index 00000000..91d4d3bd --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Web.xml @@ -0,0 +1,9254 @@ + + + + Spring.Web + + + + + An implementation backed by ASP.NET Cache (see ). + + + + Because ASP.NET Cache uses strings as cache keys, you need to ensure + that the key object type has properly implemented ToString method. + + + Despite the shared underlying , it is possible to use more than + one instance of without interfering each other. + + + Aleksandar Seovic + Erich Eichinger + + + + Initializes a new instance of + + + + + Initializes a new instance of + with the specified implementation. + + + + + + Retrieves an item from the cache. + + + Item key. + + + Item for the specified , or null. + + + + + Removes an item from the cache. + + + Item key. + + + + + Inserts an item into the cache. + + + Items inserted using this method have default and default + + + Item key. + + + Item value. + + + Item's time-to-live (TTL). + + + + + Inserts an item into the cache. + + + Item key. + + + Item value. + + + Item's time-to-live. + + + Flag specifying whether the item's time-to-live should be reset + when the item is accessed. + + + + + Inserts an item into the cache. + + + Item key. + + + Item value. + + + Item's time-to-live. + + + Flag specifying whether the item's time-to-live should be reset + when the item is accessed. + + + Item priority. + + + + + Generate a key to be used for the underlying implementation. + + + + + + + Gets/Sets a flag, whether to use sliding expiration policy. + + + + + Gets/Sets a default priority to be applied to all items inserted into this cache. + + + + + Gets a collection of all cache item keys. + + + + + Abstracts the underlying runtime cache + + + + + Insert an item into the cache. + + + + + Removes an item from the cache. + + The key of the item to remove + The object that has been removed from the cache + + + + Retrieve an item with the specified key from the cache. + + The key of the item to be retrieved + The item, if found. null otherwise + + + + Actually delegates all calls to the underlying + + + + + + + Erich Eichinger + + + + Holds shared application Template + + + + + Holds shared modules Templates + + + + + Configures the instance and its modules. + + + When called, configures using the instance + provided in and the templates available in + and . + + the application context instance to be used for resolving object references. + the instance to be configured. + + + + Gets or Sets the shared application template + + + + + Gets the dictionary of shared module templates + + + to synchronize access to the dictionary, use property. + + + + + Web application context, taking the context definition files + from the file system or from URLs. + + Treats resource paths as web resources, when using + IApplicationContext.GetResource. Resource paths are considered relative + to the virtual directory. + + Note: In case of multiple config locations, later object definitions will + override ones defined in earlier loaded files. This can be leveraged to + deliberately override certain object definitions via an extra XML file. + + Aleksandar Seovic + + + + Create a new WebApplicationContext, loading the definitions + from the given XML resource. + + Names of configuration resources. + + + + Create a new WebApplicationContext, loading the definitions + from the given XML resource. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + Names of configuration resources. + + + + Create a new WebApplicationContext, loading the definitions + from the given XML resource. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + Names of configuration resources. + Configuration resources. + + + + Create a new WebApplicationContext with the given parent, + loading the definitions from the given XML resources. + + The application context name. + Flag specifying whether to make this context case sensitive or not. + The parent context. + Names of configuration resources. + + + + Initializes a new instance of the class. + + The args. + + + + returns detailed instance information for debugging + + + + + + Since the HttpRuntime discards it's configurationsection cache, we maintain our own context cache. + Despite it really speeds up context-lookup, since we don't have to go through the whole HttpConfigurationSystem + + + + + EventHandler for ContextRegistry.Cleared event. Discards webContextCache. + + + + + Returns the root context of this web application + + + + + Returns the web application context for the given (absolute!) virtual path + + + + + Initializes object definition reader. + + Reader to initialize. + + + + Creates web object factory for this context using parent context's factory as a parent. + + Web object factory to use. + + + + Returns the application-relative virtual path of this context (without leading '~'!). + + + + + + Create a reader instance capable of handling web objects (Pages,Controls) for importing o + bject definitions into the specified . + + + + + Returns the web application context for the current request's filepath + + + + + An array of resource locations, referring to the XML object + definition files with which this context is to be built. + + + An array of resource locations, or if none. + + + + + + An array of resources instances with which this context is to be built. + + + An array of s, or if none. + + + + + + Encapsulates arguments to the class. + + + + + Initializes a new instance of the WebApplicationContextArgs class. + + + + + Initializes a new instance of the WebApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + + + + Initializes a new instance of the WebApplicationContextArgs class. + + The name. + The parent context. + The configuration locations. + The configuration resources. + if set to true [case sensitive]. + + + + Creates an instance + using context definitions supplied in a custom configuration and + configures the with that instance. + + + This class extends ContextHandler with + web specific behaviour. It uses WebApplicationContext + as default Context-Type. + + Erich Eichinger + + + + Gets the context name from the given + + + + + Throws a configuration exception, if child contexts are specified. + + + Nesting contexts in webapplications is done by explicitly declaring + spring context sections for each directory. + + + + + Handles web specific details of context instantiation. + + + + + Sets default context type to + + + + + Sets default case-sensitivity to 'false' for web-applications + + + + + Provides various support for proper handling requests. + + Erich Eichinger + + + + Identifies the Objectdefinition used for the current IHttpHandler instance in TLS + + + + + For webapplications always +
    +
  • convert IResources using the current context.
  • +
  • use "web" as default resource protocol
  • +
  • use as default threading storage
  • +
+
+
+ + + Registers this module for all events required by the Spring.Web framework + + + + + Configures the current IHttpHandler as specified by . + + + + + Configures the specified handler instance using the object definition . + + + TODO + + + + + + + + + + + TODO + + + + + + + + TODO + + + + + + + + + Disposes this instance + + + + + Holds the handler configuration information. + + + + + implementation specifically + for resources served up from a web server. + + +

+ Uses the System.Web.HttpContext.Current.Server.MapPath + method to resolve the file name for a given resource. +

+
+ Aleksandar Seovic +
+ + + Creates a new instance of the class. + + + The name of the file system resource (on the server). + + + + + Resolves the handle + for the supplied . + + + The name of the file system resource. + + + The handle for this resource. + + + + + Resolves the root location for the supplied . + + + The name of the file system resource. + + + The root location of the resource. + + + + + Resolves the path for the supplied . + + + The name of the file system resource. + + + The current path of the resource. + + + + + Resolves the presence of the + value + in the supplied into a path. + + + The name of the resource. + + + The string that is a placeholder for a base path. + + + The name of the resource with any + value having been resolved into an actual path. + + + + + Does the supplied relative ? + + + The name of the resource to test. + + + if resource name is relative; + otherwise . + + + + + Factory Method. Create a new instance of the current resource type using the given resourceName + + + + + The ResourceLoader to be used for resolving relative resources + + + + + Gets those characters that are valid path separators for the + resource type. + + + Those characters that are valid path separators for the resource + type. + + + + + + This formatter acts as an adapter to a datasource. It parses a given datasource into + a table to allow converting back and forth between objects and their keys during formatting. + + + + The DataSourceItemFormatter expects the "source" to have 2 properties named "DataSourceField" and "DataValueField". + + + + + + + + + + + Sets the binding context of this formatter. + + + + + + + + + Clears the binding context of this formatter. + + + + + Initialize this instance. + + The name of the "source"s property containing the dataSource + The name of the "source"s property containing the name of the key property + + + + Sets the bindingContext for the current thread. + + The source object + The target object + Variables to be used during binding + The current binding's direction + + + + Reset the current thread's binding context. + + + + + Initialize a new instance. + + The datasource containing list items + The name of the listitem's property that evaluates to the item's key + The direction of the current binding + + + + Returns the key of the specified value object. + + The value to extract the key from. + Key extracted from . + + + + Return the object with the specified key from the datasource. + + The key of the object. + Parsed . + + + + Binds agroup of HTTP request multi-valued items to the data model. + + + Due to the fact, that browsers don't send the values of unchecked checkboxes, you + can't use for binding to checkboxes. + + Aleksandar Seovic + + + + Creates a new instance of . + + + Comma separated list of multi-valued request parameters that + should be used to create a target item. + + + Expression that identifies a target list items should be added to. + + + The type of the target item. + + + + + Adds the binding. + + + This is a convinience method for adding SimpleExpressionBinding, + one of the most often used binding types, to the bindings list. + + + The source expression. + + + The target expression. + + + Binding direction. + + + to use for value formatting and parsing. + + + Added instance. + + + + + Binds source object to target object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + Binds target object to source object. + + + The source object. + + + The target object. + + + Validation errors collection that type conversion errors should be added to. + + + Variables that should be used during expression evaluation. + + + + + A page or control must implement this interface to support spring's databinding infrastructure. + + + + + + + + + + Return the UniqueID of this page or control. + + + + + Return the where + instances should be optained from. + + + + + This event is raised to initialize bindings for . + + + + + Handles binding of a multiple selection ListControl to a target's IList property. + + + + + Creates a new instance of this binding. + + The expression that will evaluate to the acting as the source + The expression that will evaluate to an property acting as the target + Binding's direction + An optional formatter converting target items into and back + + If no formatter is specified, a will be used. + + + + + Actually performs unbinding the ListControl's selected values into the target's + + + + + Actually performs binding the targetlist to the ListControl. + + + + + Setting source value is not allowed in this bindingType. + + + + + Setting target value is not allowed in this bindingType. + + + + + Culture resolver that uses cookie to store culture information. + + Aleksandar Seovic + + + + Default culture resolver for web applications. Contains some common utility methods for web culture resolvers. + + Aleksandar Seovic + + + + Returns default culture. If property is not set, + it tries to get culture from the request headers + and falls back to a current thread's culture if no headers are available. + + Default culture to use. + + + + Extracts the users favorite language from "accept-language" header of the current request. + + a language string if any or null, if no languages have been sent with the request + + + + Resolves a culture by name. + + the name of the culture to get + a (possible neutral!) or null, if culture could not be resolved + + + + Resolves the culture from the context. + + Culture that should be used to render view. + + + + Not supported for this implementation. + + The new culture or null to clear the culture. + + + + Resolves the culture from the request. + + + If the culture cookie doesn't exist, this method will return + the value of the 'Accept-Language' request header, or if no + headers are specified, the culture of the current server thread. + + Culture that should be used to render view. + + + + Sets the culture. + + The new culture or null to clear the culture. + + + + Creates cookie for the specified culture. + + Culture to store in a cookie. + Created cookie. + + + + Culture resolver that uses request headers to determine culture. If no languages + are specified in the request headers, it returns default culture specifed, and + if no default culture was specifed it returns current culture for the executing + server thread. + + + Note: This culture resolver cannot be used to change the culture + because request headers cannot be modified. In order to change the culture + when using this culture resolver user has to change language settings in + the web browser. + + Aleksandar Seovic + + + + Tries to determine culture from the request headers. If no languages + are specified in the request headers, it returns default culture specifed, and + if no default culture was specifed it returns current culture for the executing + server thread. + + Culture that should be used to render view. + + + + Not supported for this resolver implementation + + The new culture or null to clear the culture. + + + + Culture resolver that uses HTTP session to store culture information. + + Aleksandar Seovic + + + + Resolves the culture from the request. + + + If culture information doesn't exist in the session, it will be created and its value will + be set to the value of the 'Accept-Language' request header, or if no + headers are specified to the culture of the current server thread. + + Culture that should be used to render view. + + + + Sets the culture. + + The new culture or null to clear the culture. + + + + Gets/Sets the current session's culture. + + + + + Resource cache implementation that uses ASP.NET to cache resources. + + Aleksandar Seovic + + + + Gets the list of resources from cache. + + Cache key to use for lookup. + A list of cached resources for the specified target object and culture. + + + + Puts the list of resources in the cache. + + Cache key to use for the specified resources. + A list of resources to cache. + + + + Web object definitions extend + by adding scope property. + + +

+ This is the most common type of object definition in ASP.Net web applications +

+
+ Aleksandar Seovic +
+ + + Defines additional members web object definitions need to implement. + + Aleksandar Seovic + + + + Gets or sets scope for the web object (application, session or request) + + + + + Returns true if web object is .aspx page. + + + + + Gets the rooted url of the .aspx page, if object definition represents page. + + + + + Creates a new instance of the + class + for a singleton, providing property values and constructor arguments. + + Name of the parent object definition. + The class of the object to instantiate. + + The + to be applied to a new instance of the object. + + + The to be applied to + a new instance of the object. + + + + + Creates a new instance of the + class + for a singleton, providing property values and constructor arguments. + + Name of the parent object definition. + The class name of the object to instantiate. + + The + to be applied to a new instance of the object. + + + The to be applied to + a new instance of the object. + + + + + Creates a new instance of the + class + for an .aspx page, providing property values. + + Name of the parent object definition. + Name of the .aspx page to instantiate. + + The to be applied to + a new instance of the object. + + + + + Overrides this object's values using values from other argument. + + The object to copy values from. + + + + A that represents the current + . + + + A that represents the current + . + + + + + Object scope. + + + + + Returns true if web object is .aspx page. + + + + + Gets the rooted url of the .aspx page, if object definition represents page. + + + + + Forces ASP pages to be treated as prototypes all the time inorder to comply with ASP.Net requirements. + + + + + + Erich Eichinger + + + + Web object definitions extend + by adding scope property. + + +

+ This is the most common type of object definition in ASP.Net web applications +

+
+ Aleksandar Seovic +
+ + + Creates a new instance of the + class + for a singleton, providing property values and constructor arguments. + + + The type of the object to instantiate. + + + The to be applied to + a new instance of the object. + + + The + to be applied to a new instance of the object. + + + + + Creates a new instance of the + class + for a singleton, providing property values and constructor arguments. + + + The assembly qualified of the object to instantiate. + + + The to be applied to + a new instance of the object. + + + The + to be applied to a new instance of the object. + + +

+ Takes an object class name to avoid eager loading of the object class. +

+
+
+ + + Creates a new instance of the + class + for an .aspx page, providing property values. + + + Name of the .aspx page to instantiate. + + + The to be applied to + a new instance of the object. + + + + + Creates a new instance of the + class + + + The definition that is to be copied. + + +

+ Deep copy constructor. +

+
+
+ + + Overrides this object's values using values from other argument. + + The object to copy values from. + + + + A that represents the current + . + + + A that represents the current + . + + + + + Object scope. + + + + + Returns true if web object is .aspx page. + + + + + Gets the rooted url of the .aspx page, if object definition represents page. + + + + + Forces ASP pages to be treated as prototypes all the time inorder to comply with ASP.Net requirements. + + + + + Object instantiation strategy for use in + . + + +

+ This strategy checks if objects id ASP.Net page and if it is uses + PageParser to compile and instantiate page instance. Otherwise it + delagates call to its parent. +

+
+ Aleksandar Seovic +
+ + + Creates a new instance of the + class. + + + + + Instantiate an instance of the object described by the supplied + from the supplied . + + + The definition of the object that is to be instantiated. + + + The name associated with the object definition. The name can be the null + or zero length string if we're autowiring an object that doesn't belong + to the supplied . + + + The owning + + + An instance of the object described by the supplied + from the supplied . + + + + + Custom implementation of + for web applications. + + +

+ This implementation adds support for .aspx pages and scoped objects. +

+
+ Aleksandar Seovic +
+ + + Factory style method for getting concrete + + instances. + + If no parent is specified, a RootWebObjectDefinition is created, otherwise a + ChildWebObjectDefinition. + The of the defined object. + The name of the parent object definition (if any). + The against which any class names + will be resolved into instances. + + An + + instance. + + + + + Concrete implementation of + that knows + how to handle s. + + +

+ This class should only be used within the context of an ASP.NET web application. +

+
+ Aleksandar Seovic +
+ + + Holds the virtual path this factory has been created from. + + + + + Holds the handler reference for creating an object dictionary + matching this factory's case-sensitivity + + + + + Registers events handlers with to ensure + proper disposal of 'request'- and 'session'-scoped objects + + + + + Creates a new instance of the + class. + + The virtual path resources will be relative resolved to. + Flag specifying whether to make this object factory case sensitive or not. + + + + Creates a new instance of the + class. + + The virtual path resources will be relative resolved to. + Flag specifying whether to make this object factory case sensitive or not. + + The parent object factory. + + + + + Creates a dictionary matching this factory's case sensitivity behaviour. + + + + + Creates the root object definition. + + The template definition. + Root object definition. + + + + Tries to find cached object for the specified name. + + + This implementation tries to find object first in the Request scope, + then in the Session scope and finally in the Application scope. + + Object name to look for. + Cached object if found, null otherwise. + + + + Looks up an in the specified cache dictionary. + + the name to lookup. + the cache dictionary to search + the found instance. null otherwise + + + + Creates a singleton instance for the specified object name and definition. + + + The object name (will be used as the key in the singleton cache key). + + The object definition. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. It is invalid to use a non-null arguments value + in any other case. + + The created object instance. + + + + Creates a singleton instance for the specified object name and definition + and caches the instance in the specified dictionary + + + The object name (will be used as the key in the singleton cache key). + + The object definition. + + The arguments to use if creating a prototype using explicit arguments to + a static factory method. It is invalid to use a non-null arguments value + in any other case. + + the dictionary to be used for caching singleton instances + The created object instance. + + If the object is successfully created, + contains the cached instance with the key . + + + + + Add the created, but yet unpopulated singleton to the singleton cache + to be able to resolve circular references + + the name of the object to add to the cache. + the definition used to create and populated the object. + the raw object instance. + + Derived classes may override this method to select the right cache based on the object definition. + + + + + Remove the specified singleton from the singleton cache that has + been added before by a call to + + the name of the object to remove from the cache. + the definition used to create and populated the object. + + Derived classes may override this method to select the right cache based on the object definition. + + + + + Configures object instance by injecting dependencies, satisfying Spring lifecycle + interfaces and applying object post-processors. + + + The name of the object definition expressing the dependencies that are to + be injected into the supplied instance. + + + An object definition that should be used to configure object. + + + A wrapped object instance that is to be so configured. + + + + + + Disposes all 'request'-scoped objects at the end of each Request + + + + + Disposes all 'session'-scoped objects at the end of a session + + + + + Creates a case insensitive hashtable instance + + + + + Creates a case sensitive hashtable instance + + + + + Returns the virtual path this object factory is associated with. + + + + + Convinience accessor for HttpContext + + + + + Get the table of 'request'-scoped objects. + + + + + Get the table of 'session'-scoped objects. Returns null, if Session is disabled. + + + + + Miscellaneous utility methods to support web functionality within Spring.Objects + + Aleksandar Seovic + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Creates an instance of the ASPX page + referred to by the supplied . + + + The URL of the ASPX page. + + Page instance. + + If this method is not called in the scope of an active web session + (i.e. the implementation this method depends on this code executing + in the environs of a running web server such as IIS); or if the + page could not be instantiated (for whatever reason, such as the + ASPX not actually existing). + + + + + Creates the raw handler instance without any exception handling + + + + + + + Returns the of the ASPX page + referred to by the supplied . + + +

+ As indicated by the exception that can be thrown by this method, + the ASPX page referred to by the supplied + does have to be instantiated in order to determine its + see cref="System.Type"/> +

+
+ + The filename of the ASPX page. + + + The of the ASPX page + referred to by the supplied . + + + If the supplied is or + contains only whitespace character(s). + + + If this method is not called in the scope of an active web session + (i.e. the implementation this method depends on this code executing + in the environs of a running web server such as IIS); or if the + page could not be instantiated (for whatever reason, such as the + ASPX not actually existing). + +
+ + + Calls the underlying ASP.NET infrastructure to obtain the compiled page type + relative to the current . + + + The filename of the ASPX page relative to the current + + + The of the ASPX page + referred to by the supplied . + + + + + Gets the controls type from a given filename + + + + + An capable of handling web objects (Pages,Controls). + + Erich Eichinger + + + + Creates an instance for the given + and element. + + + + + An capable of handling web objects (Pages,Controls) + + Erich Eichinger + + + + Initializes a new instance of the class. + + used for generating object definition names from web object types (page, control) + The reader context. + The root element of the xml document to parse + + + + Gets the scope out of the supplied . + + +

+ If the supplied is invalid + (i.e. it does not resolve to one of the + values), + then the return value of this method call will be + ; + no exception will be raised (although the value of the invalid + scope will be logged). +

+
+ The string containing the scope name. + The scope. + +
+ + + An capable of handling web object definitions (Pages, Controls) + + Erich Eichinger + + + + Creates a new instance of the + class. + + the (rooted) virtual path to resolve relative virtual paths. + + The + instance that this reader works on. + + the to use for resolving entities. + + + + Creates the to use for actually + reading object definitions from an XML document. + + + + + Create an object definition name for the given control path + + + + + Create an object definition name for the given page path + + + + + A custom implementation of the + + interface that properly handles web application specific attributes, + such as object scope. + + +

+ Parses object definitions according to the standard Spring.NET schema. +

+
+ Aleksandar Seovic + +
+ + + Creates a new instance of the + class. + + + + + Implements by using . + + Erich Eichinger + + + + Retrieves an object with the specified name. + + The name of the item. + The object in the context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the call context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + + Implements by using both and and choosing dynamically between them. + + + In web applications a single Request may be executed on different threads. In this case HttpContext.Current is the only invariant.
+ This implementation dynamically chooses between System.Runtime.Remoting.Messaging.CallContext + and System.Web.HttpContext to store data. +
+ Erich Eichinger +
+ + + Retrieves an object with the specified name. + + The name of the item. + The object in the context associated with the specified name or null if no object has been stored previously + + + + Stores a given object and associates it with the specified name. + + The name with which to associate the new item. + The object to store in the call context. + + + + Empties a data slot with the specified name. + + The name of the data slot to empty. + + + + Performs a . Original path will be restored on + + + Rewrites the current HttpContext's filepath to <directory>/currentcontext.dummy.
+ This affects resolving resources by calls to and
+ Original path is restored during . +
+ + + using( new HttpContextSwitch( "/path" ) ) + { + Response.Write( Request.FilePath ); // writes "/path/currentcontext.dummy" to response. + } + // Request.FilePath has been reset to original url here + + + Erich Eichinger +
+ + + Performs an immediate call to + + a directory path (without trailing filename!) + + + + Restores original path if necessary + + + + + Abstracts HttpSession + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Abstracts the underlying infrastructure of a HttpRequest + + + + + Maps a virtual path to it's physical location + + + + + Rewrites the , thus also affecting + + + + + Get the compiled type for the given virtual path + + the absolute (=rooted) virtual path + + + + + Creates an instance from the given virtual path + + the absolute (=rooted) virtual path + the required base type + + + + The virtual (rooted) path of the current Application with trailing slash + + + For the site rooted applications, "/" will be returned, for all others "/..someappdir../" + + + + + The virtual (rooted) path of the current Request including + + + + + The virtual (rooted) path of the current Request without trailing + + + + + The virtual (rooted) path of the currently executing script + + + Normally this property is the same as . + In case of , this property returns the current script + whereas CurrentVirtualPath returns the original script path. + + + + + The query parameters + + + + + Returns the current Session's variable dictionary + + + + + Returns the current Request's variable dictionary + + + + + Returns the current Request's parameter dictionary + + + + + Utility class to be used from within this assembly for executing security critical code + NEVER EVER MAKE THIS PUBLIC! + + Erich Eichinger + + + + Provides platform independent access to HttpRuntime methods + + + For e.g. testing purposes, the default environment implementation may be replaced using . + + Erich Eichinger + + + + Replaces the current enviroment implementation. + + the new environment implementation to be used + the previously set environment instance + + + + Maps a virtual path to it's physical location + + + + + Rewrites the , thus also affecting + + + + + Returns an instance of the specified file. + + + + + Returns an the compiled type of the specified file. + + + + + Receives EndRequest-event from an instance + and dispatches it to all handlers registered with this module. + + the HttpApplication instance sending this event + always + + + + Receives the EndSession-event and dispatches it to all handlers + registered with this module. + + + + + Signals, that VirtualEnvironment is ready to accept + handler registrations for EndRequest and EndSession events + + + + + Ensures, that WebSupportModule has been initialized. Otherwise an exception is thrown. + + + + + The virtual (rooted) path of the current Application containing a leading '/' as well as a trailing '/' + + + + + The virtual (rooted) path of the current Request including + + + + + The virtual (rooted) path of the current Request including + + + + + The virtual (rooted) path of the current Request without trailing + + + + + The virtual (rooted) path of the currently executing script + + + + + The query parameters + + + + + Returns the current Request's variable dictionary () + + + + + Returns the current Request's parameter dictionary () + + + + + Register with this event to receive any EndRequest event occuring in the current AppDomain. + + + + + Register with this event to receive any EndSession event occuring in the current AppDomain + + + This event may be raised asynchronously on it's own thread. + Don't rely on e.g. being available. + + + + + Is this VirtualEnviroment ready to accept handler registrations + for EndRequest and EndSession events ? + + + + + Represents a method that handles Request related events + + + + + Represents a method that handles Session related events + + + + + Implementation for running within HttpRuntime + + + + + Miscellaneous web utility methods. + + Aleksandar Seovic + + + + Creates a new instance of the class. + + +

+ This is a utility class, and as such exposes no public constructors. +

+
+
+ + + Default protocol used for resolving resources in web applications + + + + + Extracts the bare ASPX page name without any extension from the + supplied . + + +

+ Examples of what would be returned from this method given a url would be: +

+

+ + 'Login.aspx' => 'Login' + '~/Login.aspx' => 'Login' + '~/B2B/SignUp.aspx' => 'SignUp' + 'B2B/Foo/FooServices.aspx' => 'FooServices' + +

+
+ The full URL to the ASPX page. + + The bare ASPX page name without any extension. + + + If the supplied is or + contains only whitespace character(s). + +
+ + + Returns only the directory portion of a virtual path + + + The returned path is guaranteed to always have a leading and a trailing slash.
+ If a path does not end with a file-extension it is assumed to be a directory +
+
+ + + Returns absolute path that can be referenced within plain HTML. + + +

+ If relative path starts with '/' (forward slash), no concatenation will occur + and it will be assumed that the relative path specified is indeed the absolute path + and will be returned verbatim.

+

+ Otherwise, relative path will be appended to the application path, while making sure that + path separators are not duplicated between the paths.

+
+ Application path. + Relative path to combine with the application path. + Absolute path. +
+ + + Combines a rooted base path with a relative path. + + Must be a path starting with '/' + the path to be combined. May start with basepath Placeholder '~' + the combined path + + If relativePath starts with '~', rootPath is ignored and '~' resolves to the current AppDomain's application virtual path
+ If relativePath start with '/', rootPath is ignored and relativePath is returned as-is. +
+
+ + + Gets the application-relative virtual path portion of the given absolute URL. + + the absolute url + the url relative to the current application's virtual path + + + + Gets the virtual path portion of the given absolute URL + relative to the given base path. + + + Base path comparison is done case insensitive. + + the absolute base path + the absolute url + the url relative to the given basePath + + + + Returns the 'logical' parent of the specified control. Technically when dealing with masterpages and control hierarchy, + the order goes controls->masterpage->page. But one often wants the more logical order controls->page->masterpage. + + the control, who's parent is to be determined. + the logical parent or null if the top of the hierarchy is reached. + if is null + + + + Encode for use in URLs. + + the text to be encoded. + the url-encoded + + This method may be used outside of a current request. If executed within a + request, is used. + will be used otherwise. + + + + + A spring configurable version of + + Erich Eichinger + + + + An Interface for class. + + Damjan Tomic + + + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute is mandatory. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Adds a new membership user to the data source. + + + + A object populated with the information for the newly created user. + + + Whether or not the new user is approved to be validated. + The password answer for the new user + The user name for the new user. + The unique identifier from the membership data source for the user. + The password for the new user. + The password question for the new user. + The e-mail address for the new user. + A enumeration value indicating whether the user was created successfully. + + + + Processes a request to update the password question and answer for a membership user. + + + + true if the password question and answer are updated successfully; otherwise, false. + + + The new password question for the specified user. + The new password answer for the specified user. + The user to change the password question and answer for. + The password for the specified user. + + + + Gets the password for the specified user name from the data source. + + + + The password for the specified user name. + + + The user to retrieve the password for. + The password answer for the user. + + + + Processes a request to update the password for a membership user. + + + + true if the password was updated successfully; otherwise, false. + + + The new password for the specified user. + The current password for the specified user. + The user to update the password for. + + + + Resets a user's password to a new, automatically generated password. + + + + The new password for the specified user. + + + The user to reset the password for. + The password answer for the specified user. + + + + Updates information about a user in the data source. + + + A object that represents the user to update and the updated information for the user. + + + + Verifies that the specified user name and password exist in the data source. + + + + true if the specified username and password are valid; otherwise, false. + + + The name of the user to validate. + The password for the specified user. + + + + Clears a lock so that the membership user can be validated. + + + + true if the membership user was successfully unlocked; otherwise, false. + + + The membership user to clear the lock status for. + + + + Gets information from the data source for a user based on the unique identifier for the membership user. Provides an option to update the last-activity date/time stamp for the user. + + + + A object populated with the specified user's information from the data source. + + + The unique identifier for the membership user to get information for. + true to update the last-activity date/time stamp for the user; false to return user information without updating the last-activity date/time stamp for the user. + + + + Gets information from the data source for a user. Provides an option to update the last-activity date/time stamp for the user. + + + + A object populated with the specified user's information from the data source. + + + The name of the user to get information for. + true to update the last-activity date/time stamp for the user; false to return user information without updating the last-activity date/time stamp for the user. + + + + Gets the user name associated with the specified e-mail address. + + + + The user name associated with the specified e-mail address. If no match is found, return null. + + + The e-mail address to search for. + + + + Removes a user from the membership data source. + + + + true if the user was successfully deleted; otherwise, false. + + + The name of the user to delete. + true to delete data related to the user from the database; false to leave data related to the user in the database. + + + + Gets a collection of all the users in the data source in pages of data. + + + + A collection that contains a page of pageSize objects beginning at the page specified by pageIndex. + + + The total number of matched users. + The index of the page of results to return. pageIndex is zero-based. + The size of the page of results to return. + + + + Gets the number of users currently accessing the application. + + + + The number of users currently accessing the application. + + + + + + Gets a collection of membership users where the user name contains the specified user name to match. + + + + A collection that contains a page of pageSize objects beginning at the page specified by pageIndex. + + + The total number of matched users. + The index of the page of results to return. pageIndex is zero-based. + The user name to search for. + The size of the page of results to return. + + + + Gets a collection of membership users where the e-mail address contains the specified e-mail address to match. + + + + A collection that contains a page of pageSize objects beginning at the page specified by pageIndex. + + + The total number of matched users. + The index of the page of results to return. pageIndex is zero-based. + The e-mail address to search for. + The size of the page of results to return. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + + Indicates whether the membership provider is configured to allow users to retrieve their passwords. + + + + true if the membership provider is configured to support password retrieval; otherwise, false. The default is false. + + + + + + Indicates whether the membership provider is configured to allow users to reset their passwords. + + + + true if the membership provider supports password reset; otherwise, false. The default is true. + + + + + + Gets a value indicating whether the membership provider is configured to require the user to answer a password question for password reset and retrieval. + + + + true if a password answer is required for password reset and retrieval; otherwise, false. The default is true. + + + + + + The name of the application using the custom membership provider. + + + + The name of the application using the custom membership provider. + + + + + + Gets the number of invalid password or password-answer attempts allowed before the membership user is locked out. + + + + The number of invalid password or password-answer attempts allowed before the membership user is locked out. + + + + + + Gets the number of minutes in which a maximum number of invalid password or password-answer attempts are allowed before the membership user is locked out. + + + + The number of minutes in which a maximum number of invalid password or password-answer attempts are allowed before the membership user is locked out. + + + + + + Gets a value indicating whether the membership provider is configured to require a unique e-mail address for each user name. + + + + true if the membership provider requires a unique e-mail address; otherwise, false. The default is true. + + + + + + Gets a value indicating the format for storing passwords in the membership data store. + + + + One of the values indicating the format for storing passwords in the data store. + + + + + + Gets the minimum length required for a password. + + + + The minimum length required for a password. + + + + + + Gets the minimum number of special characters that must be present in a valid password. + + + + The minimum number of special characters that must be present in a valid password. + + + + + + Gets the regular expression used to evaluate a password. + + + + A regular expression used to evaluate a password. + + + + + + Initializes the provider. + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + Values may be overridden by specifying them in list. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + The ConnectionString to be used + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + + + + + + Erich Eichinger + + + + An Interface for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute is mandatory. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Returns the collection of settings property values for the specified application instance and settings property group. + + + + A containing the values for the specified settings property group. + + + A describing the current application use. + A containing the settings property group whose values are to be retrieved.2 + + + + Sets the values of the specified group of property settings. + + + A describing the current application usage. + A representing the group of property settings to set.2 + + + + When overridden in a derived class, deletes profile properties and information for the supplied list of profiles. + + + + The number of profiles deleted from the data source. + + + A of information about profiles that are to be deleted. + + + + When overridden in a derived class, deletes profile properties and information for profiles that match the supplied list of user names. + + + + The number of profiles deleted from the data source. + + + A string array of user names for profiles to be deleted. + + + + When overridden in a derived class, deletes all user-profile data for profiles in which the last activity date occurred before the specified date. + + + + The number of profiles deleted from the data source. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are deleted. + A that identifies which user profiles are considered inactive. If the value of a user profile occurs on or before this date and time, the profile is considered inactive. + + + + When overridden in a derived class, returns the number of profiles in which the last activity date occurred on or before the specified date. + + + + The number of profiles in which the last activity date occurred on or before the specified date. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + A that identifies which user profiles are considered inactive. If the of a user profile occurs on or before this date and time, the profile is considered inactive. + + + + When overridden in a derived class, retrieves user profile data for all profiles in the data source. + + + + A containing user-profile information for all profiles in the data source. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The size of the page of results to return. + + + + When overridden in a derived class, retrieves user-profile data from the data source for profiles in which the last activity date occurred on or before the specified date. + + + + A containing user-profile information about the inactive profiles. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + A that identifies which user profiles are considered inactive. If the of a user profile occurs on or before this date and time, the profile is considered inactive. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The size of the page of results to return. + + + + When overridden in a derived class, retrieves profile information for profiles in which the user name matches the specified user names. + + + + A containing user-profile information for profiles where the user name matches the supplied usernameToMatch parameter. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The user name to search for. + The size of the page of results to return. + + + + When overridden in a derived class, retrieves profile information for profiles in which the last activity date occurred on or before the specified date and the user name matches the specified user name. + + + + A containing user profile information for inactive profiles where the user name matches the supplied usernameToMatch parameter. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + A that identifies which user profiles are considered inactive. If the value of a user profile occurs on or before this date and time, the profile is considered inactive. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The user name to search for. + The size of the page of results to return. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + Gets or sets the name of the currently running application. + + + + A that contains the application's shortened name, which does not contain a full path or extension, for example, SimpleAppSettings. + + 2 + + + + Initializes the provider. + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + Values may be overridden by specifying them in list. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + The ConnectionString to be used + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + + + + A spring-configurable version of + + Erich Eichinger + + + + An Interface for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute is mandatory. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Gets a value indicating whether the specified user is in the specified role for the configured applicationName. + + + + true if the specified user is in the specified role for the configured applicationName; otherwise, false. + + + The user name to search for. + The role to search in. + + + + Gets a list of the roles that a specified user is in for the configured applicationName. + + + + A string array containing the names of all the roles that the specified user is in for the configured applicationName. + + + The user to return a list of roles for. + + + + Adds a new role to the data source for the configured applicationName. + + + The name of the role to create. + + + + Removes a role from the data source for the configured applicationName. + + + + true if the role was successfully deleted; otherwise, false. + + + If true, throw an exception if roleName has one or more members and do not delete roleName. + The name of the role to delete. + + + + Gets a value indicating whether the specified role name already exists in the role data source for the configured applicationName. + + + + true if the role name already exists in the data source for the configured applicationName; otherwise, false. + + + The name of the role to search for in the data source. + + + + Adds the specified user names to the specified roles for the configured applicationName. + + + A string array of the role names to add the specified user names to. + A string array of user names to be added to the specified roles. + + + + Removes the specified user names from the specified roles for the configured applicationName. + + + A string array of role names to remove the specified user names from. + A string array of user names to be removed from the specified roles. + + + + Gets a list of users in the specified role for the configured applicationName. + + + + A string array containing the names of all the users who are members of the specified role for the configured applicationName. + + + The name of the role to get the list of users for. + + + + Gets a list of all the roles for the configured applicationName. + + + + A string array containing the names of all the roles stored in the data source for the configured applicationName. + + + + + + Gets an array of user names in a role where the user name contains the specified user name to match. + + + + A string array containing the names of all the users where the user name matches usernameToMatch and the user is a member of the specified role. + + + The user name to search for. + The role to search in. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + Gets or sets the name of the application to store and retrieve role information for. + + + + The name of the application to store and retrieve role information for. + + + + + + Initializes the provider. + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + Values may be overridden by specifying them in list. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + The ConnectionString to be used + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + + + + A spring-configurable version of + + Erich Eichinger + + + + An Interface for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute is mandatory. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Retrieves a object that represents the currently requested page using the specified object. + + + + A that represents the currently requested page; otherwise, null, if no corresponding can be found in the or if the page context is null. + + + The used to match node information with the URL of the requested page. + + + + Retrieves a object based on a specified key. + + + + A that represents the page identified by key; otherwise, null, if no corresponding is found or if security trimming is enabled and the cannot be returned for the current user. The default is null. + + + A lookup key with which a is created. + + + + When overridden in a derived class, retrieves a object that represents the page at the specified URL. + + + + A that represents the page identified by rawURL; otherwise, null, if no corresponding is found or if security trimming is enabled and the cannot be returned for the current user. + + + A URL that identifies the page for which to retrieve a . + + + + When overridden in a derived class, retrieves the child nodes of a specific . + + + + A read-only that contains the immediate child nodes of the specified ; otherwise, null or an empty collection, if no child nodes exist. + + + The for which to retrieve all child nodes. + + + + Provides an optimized lookup method for site map providers when retrieving the node for the currently requested page and fetching the parent and ancestor site map nodes for the current page. + + + + A that represents the currently requested page; otherwise, null, if the is not found or cannot be returned for the current user. + + + The number of ancestor site map node generations to get. A value of -1 indicates that all ancestors might be retrieved and cached by the provider. + upLevel is less than -1. + + + + Provides an optimized lookup method for site map providers when retrieving the node for the currently requested page and fetching the site map nodes in the proximity of the current node. + + + + A that represents the currently requested page; otherwise, null, if the is not found or cannot be returned for the current user. + + + The number of ancestor generations to fetch. 0 indicates no ancestor nodes are retrieved and -1 indicates that all ancestors might be retrieved and cached by the provider. + The number of child generations to fetch. 0 indicates no descendant nodes are retrieved and a -1 indicates that all descendant nodes might be retrieved and cached by the provider. + upLevel or downLevel is less than -1. + + + + When overridden in a derived class, retrieves the parent node of a specific object. + + + + A that represents the parent of node; otherwise, null, if the has no parent or security trimming is enabled and the parent node is not accessible to the current user. + + + The for which to retrieve the parent node. + + + + Provides an optimized lookup method for site map providers when retrieving an ancestor node for the currently requested page and fetching the descendant nodes for the ancestor. + + + + A that represents an ancestor of the currently requested page; otherwise, null, if the current or ancestor is not found or cannot be returned for the current user. + + + The number of descendant node levels to retrieve from the target ancestor node. + The number of ancestor node levels to traverse when retrieving the requested ancestor node. + walkupLevels or relativeDepthFromWalkup is less than 0. + + + + Provides an optimized lookup method for site map providers when retrieving an ancestor node for the specified object and fetching its child nodes. + + + + A that represents an ancestor of node; otherwise, null, if the current or ancestor is not found or cannot be returned for the current user. + + + The number of descendant node levels to retrieve from the target ancestor node. + The that acts as a reference point for walkupLevels and relativeDepthFromWalkup. + The number of ancestor node levels to traverse when retrieving the requested ancestor node. + The value specified for walkupLevels or relativeDepthFromWalkup is less than 0. + node is null. + + + + Provides a method that site map providers can override to perform an optimized retrieval of one or more levels of parent and ancestor nodes, relative to the specified object. + + + The number of ancestor generations to fetch. 0 indicates no ancestor nodes are retrieved and -1 indicates that all ancestors might be retrieved and cached. + The that acts as a reference point for upLevel. + upLevel is less than -1. + node is null. + + + + Provides a method that site map providers can override to perform an optimized retrieval of nodes found in the proximity of the specified node. + + + The number of ancestor generations to fetch. 0 indicates no ancestor nodes are retrieved and -1 indicates that all ancestors (and their descendant nodes to the level of node) might be retrieved and cached. + The number of descendant generations to fetch. 0 indicates no descendant nodes are retrieved and -1 indicates that all descendant nodes might be retrieved and cached. + The that acts as a reference point for upLevel. + upLevel or downLevel is less than -1. + node is null. + + + + Retrieves a Boolean value indicating whether the specified object can be viewed by the user in the specified context. + + + + true if security trimming is enabled and node can be viewed by the user or security trimming is not enabled; otherwise, false. + + + The that contains user information. + The that is requested by the user. + context is null.- or -node is null. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + + Gets the object that represents the currently requested page. + + + + A that represents the currently requested page; otherwise, null, if the is not found or cannot be returned for the current user. + + + + + + Gets or sets the parent object of the current provider. + + + + The parent provider of the current . + + + + + + Gets the root object in the current provider hierarchy. + + + + An that is the top-level site map provider in the provider hierarchy that the current provider belongs to. + + + There is a circular reference to the current site map provider. + + + + Gets the root object of the site map data that the current provider represents. + + + + The root of the current site map data provider. The default implementation performs security trimming on the returned node. + + + + + + Initializes the provider. + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + Values may be overridden by specifying them in list. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + The XML file to be used for reading in the sitemap + + + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + + + + + Wrapper for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Reference to wrapped provider (defined in Spring context). + + + + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute may be used to override the name being used for looking up an object definition. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Adds a new membership user to the data source. + + + + A object populated with the information for the newly created user. + + + Whether or not the new user is approved to be validated. + The password answer for the new user + The user name for the new user. + The unique identifier from the membership data source for the user. + The password for the new user. + The password question for the new user. + The e-mail address for the new user. + A enumeration value indicating whether the user was created successfully. + + + + Processes a request to update the password question and answer for a membership user. + + + + true if the password question and answer are updated successfully; otherwise, false. + + + The new password question for the specified user. + The new password answer for the specified user. + The user to change the password question and answer for. + The password for the specified user. + + + + Gets the password for the specified user name from the data source. + + + + The password for the specified user name. + + + The user to retrieve the password for. + The password answer for the user. + + + + Processes a request to update the password for a membership user. + + + + true if the password was updated successfully; otherwise, false. + + + The new password for the specified user. + The current password for the specified user. + The user to update the password for. + + + + Resets a user's password to a new, automatically generated password. + + + + The new password for the specified user. + + + The user to reset the password for. + The password answer for the specified user. + + + + Updates information about a user in the data source. + + + A object that represents the user to update and the updated information for the user. + + + + Verifies that the specified user name and password exist in the data source. + + + + true if the specified username and password are valid; otherwise, false. + + + The name of the user to validate. + The password for the specified user. + + + + Clears a lock so that the membership user can be validated. + + + + true if the membership user was successfully unlocked; otherwise, false. + + + The membership user to clear the lock status for. + + + + Gets information from the data source for a user based on the unique identifier for the membership user. Provides an option to update the last-activity date/time stamp for the user. + + + + A object populated with the specified user's information from the data source. + + + The unique identifier for the membership user to get information for. + true to update the last-activity date/time stamp for the user; false to return user information without updating the last-activity date/time stamp for the user. + + + + Gets information from the data source for a user. Provides an option to update the last-activity date/time stamp for the user. + + + + A object populated with the specified user's information from the data source. + + + The name of the user to get information for. + true to update the last-activity date/time stamp for the user; false to return user information without updating the last-activity date/time stamp for the user. + + + + Gets the user name associated with the specified e-mail address. + + + + The user name associated with the specified e-mail address. If no match is found, return null. + + + The e-mail address to search for. + + + + Removes a user from the membership data source. + + + + true if the user was successfully deleted; otherwise, false. + + + The name of the user to delete. + true to delete data related to the user from the database; false to leave data related to the user in the database. + + + + Gets a collection of all the users in the data source in pages of data. + + + + A collection that contains a page of pageSize objects beginning at the page specified by pageIndex. + + + The total number of matched users. + The index of the page of results to return. pageIndex is zero-based. + The size of the page of results to return. + + + + Gets the number of users currently accessing the application. + + + + The number of users currently accessing the application. + + + + + + Gets a collection of membership users where the user name contains the specified user name to match. + + + + A collection that contains a page of pageSize objects beginning at the page specified by pageIndex. + + + The total number of matched users. + The index of the page of results to return. pageIndex is zero-based. + The user name to search for. + The size of the page of results to return. + + + + Gets a collection of membership users where the e-mail address contains the specified e-mail address to match. + + + + A collection that contains a page of pageSize objects beginning at the page specified by pageIndex. + + + The total number of matched users. + The index of the page of results to return. pageIndex is zero-based. + The e-mail address to search for. + The size of the page of results to return. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + + Indicates whether the membership provider is configured to allow users to retrieve their passwords. + + + + true if the membership provider is configured to support password retrieval; otherwise, false. The default is false. + + + + + + Indicates whether the membership provider is configured to allow users to reset their passwords. + + + + true if the membership provider supports password reset; otherwise, false. The default is true. + + + + + + Gets a value indicating whether the membership provider is configured to require the user to answer a password question for password reset and retrieval. + + + + true if a password answer is required for password reset and retrieval; otherwise, false. The default is true. + + + + + + The name of the application using the custom membership provider. + + + + The name of the application using the custom membership provider. + + + + + + Gets the number of invalid password or password-answer attempts allowed before the membership user is locked out. + + + + The number of invalid password or password-answer attempts allowed before the membership user is locked out. + + + + + + Gets the number of minutes in which a maximum number of invalid password or password-answer attempts are allowed before the membership user is locked out. + + + + The number of minutes in which a maximum number of invalid password or password-answer attempts are allowed before the membership user is locked out. + + + + + + Gets a value indicating whether the membership provider is configured to require a unique e-mail address for each user name. + + + + true if the membership provider requires a unique e-mail address; otherwise, false. The default is true. + + + + + + Gets a value indicating the format for storing passwords in the membership data store. + + + + One of the values indicating the format for storing passwords in the data store. + + + + + + Gets the minimum length required for a password. + + + + The minimum length required for a password. + + + + + + Gets the minimum number of special characters that must be present in a valid password. + + + + The minimum number of special characters that must be present in a valid password. + + + + + + Gets the regular expression used to evaluate a password. + + + + A regular expression used to evaluate a password. + + + + + + Wrapper for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Reference to wrapped provider (defined in Spring context). + + + + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute may be used to override the name being used for looking up an object definition. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Returns the collection of settings property values for the specified application instance and settings property group. + + + + A containing the values for the specified settings property group. + + + A describing the current application use. + A containing the settings property group whose values are to be retrieved.2 + + + + Sets the values of the specified group of property settings. + + + A describing the current application usage. + A representing the group of property settings to set.2 + + + + When overridden in a derived class, deletes profile properties and information for the supplied list of profiles. + + + + The number of profiles deleted from the data source. + + + A of information about profiles that are to be deleted. + + + + When overridden in a derived class, deletes profile properties and information for profiles that match the supplied list of user names. + + + + The number of profiles deleted from the data source. + + + A string array of user names for profiles to be deleted. + + + + When overridden in a derived class, deletes all user-profile data for profiles in which the last activity date occurred before the specified date. + + + + The number of profiles deleted from the data source. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are deleted. + A that identifies which user profiles are considered inactive. If the value of a user profile occurs on or before this date and time, the profile is considered inactive. + + + + When overridden in a derived class, returns the number of profiles in which the last activity date occurred on or before the specified date. + + + + The number of profiles in which the last activity date occurred on or before the specified date. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + A that identifies which user profiles are considered inactive. If the of a user profile occurs on or before this date and time, the profile is considered inactive. + + + + When overridden in a derived class, retrieves user profile data for all profiles in the data source. + + + + A containing user-profile information for all profiles in the data source. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The size of the page of results to return. + + + + When overridden in a derived class, retrieves user-profile data from the data source for profiles in which the last activity date occurred on or before the specified date. + + + + A containing user-profile information about the inactive profiles. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + A that identifies which user profiles are considered inactive. If the of a user profile occurs on or before this date and time, the profile is considered inactive. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The size of the page of results to return. + + + + When overridden in a derived class, retrieves profile information for profiles in which the user name matches the specified user names. + + + + A containing user-profile information for profiles where the user name matches the supplied usernameToMatch parameter. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The user name to search for. + The size of the page of results to return. + + + + When overridden in a derived class, retrieves profile information for profiles in which the last activity date occurred on or before the specified date and the user name matches the specified user name. + + + + A containing user profile information for inactive profiles where the user name matches the supplied usernameToMatch parameter. + + + One of the values, specifying whether anonymous, authenticated, or both types of profiles are returned. + A that identifies which user profiles are considered inactive. If the value of a user profile occurs on or before this date and time, the profile is considered inactive. + When this method returns, contains the total number of profiles. + The index of the page of results to return. + The user name to search for. + The size of the page of results to return. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + Gets or sets the name of the currently running application. + + + + A that contains the application's shortened name, which does not contain a full path or extension, for example, SimpleAppSettings. + + 2 + + + + Wrapper for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Reference to wrapped provider (defined in Spring context). + + + + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute may be used to override the name being used for looking up an object definition. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Gets a value indicating whether the specified user is in the specified role for the configured applicationName. + + + + true if the specified user is in the specified role for the configured applicationName; otherwise, false. + + + The user name to search for. + The role to search in. + + + + Gets a list of the roles that a specified user is in for the configured applicationName. + + + + A string array containing the names of all the roles that the specified user is in for the configured applicationName. + + + The user to return a list of roles for. + + + + Adds a new role to the data source for the configured applicationName. + + + The name of the role to create. + + + + Removes a role from the data source for the configured applicationName. + + + + true if the role was successfully deleted; otherwise, false. + + + If true, throw an exception if roleName has one or more members and do not delete roleName. + The name of the role to delete. + + + + Gets a value indicating whether the specified role name already exists in the role data source for the configured applicationName. + + + + true if the role name already exists in the data source for the configured applicationName; otherwise, false. + + + The name of the role to search for in the data source. + + + + Adds the specified user names to the specified roles for the configured applicationName. + + + A string array of the role names to add the specified user names to. + A string array of user names to be added to the specified roles. + + + + Removes the specified user names from the specified roles for the configured applicationName. + + + A string array of role names to remove the specified user names from. + A string array of user names to be removed from the specified roles. + + + + Gets a list of users in the specified role for the configured applicationName. + + + + A string array containing the names of all the users who are members of the specified role for the configured applicationName. + + + The name of the role to get the list of users for. + + + + Gets a list of all the roles for the configured applicationName. + + + + A string array containing the names of all the roles stored in the data source for the configured applicationName. + + + + + + Gets an array of user names in a role where the user name contains the specified user name to match. + + + + A string array containing the names of all the users where the user name matches usernameToMatch and the user is a member of the specified role. + + + The user name to search for. + The role to search in. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + Gets or sets the name of the application to store and retrieve role information for. + + + + The name of the application to store and retrieve role information for. + + + + + + Wrapper for class. + + +

+ Configuration for this provider requires providerId element set in web.config file, + as the Id of wrapped provider (defined in the Spring context). +

+
+ Damjan Tomic +
+ + + Reference to wrapped provider (defined in Spring context). + + + + + Initializes the provider. + + + A collection of the name/value pairs representing the provider-specific + attributes specified in the configuration for this provider. + The providerId attribute may be used to override the name being used for looking up an object definition. + + The friendly name of the provider. + The or is null. + An attempt is made to call on a provider after the provider has already been initialized. + The has a length of zero or providerId attribute is not set. + + + + Retrieves a object that represents the currently requested page using the specified object. + + + + A that represents the currently requested page; otherwise, null, if no corresponding can be found in the or if the page context is null. + + + The used to match node information with the URL of the requested page. + + + + Retrieves a object based on a specified key. + + + + A that represents the page identified by key; otherwise, null, if no corresponding is found or if security trimming is enabled and the cannot be returned for the current user. The default is null. + + + A lookup key with which a is created. + + + + When overridden in a derived class, retrieves a object that represents the page at the specified URL. + + + + A that represents the page identified by rawURL; otherwise, null, if no corresponding is found or if security trimming is enabled and the cannot be returned for the current user. + + + A URL that identifies the page for which to retrieve a . + + + + When overridden in a derived class, retrieves the child nodes of a specific . + + + + A read-only that contains the immediate child nodes of the specified ; otherwise, null or an empty collection, if no child nodes exist. + + + The for which to retrieve all child nodes. + + + + Provides an optimized lookup method for site map providers when retrieving the node for the currently requested page and fetching the parent and ancestor site map nodes for the current page. + + + + A that represents the currently requested page; otherwise, null, if the is not found or cannot be returned for the current user. + + + The number of ancestor site map node generations to get. A value of -1 indicates that all ancestors might be retrieved and cached by the provider. + upLevel is less than -1. + + + + Provides an optimized lookup method for site map providers when retrieving the node for the currently requested page and fetching the site map nodes in the proximity of the current node. + + + + A that represents the currently requested page; otherwise, null, if the is not found or cannot be returned for the current user. + + + The number of ancestor generations to fetch. 0 indicates no ancestor nodes are retrieved and -1 indicates that all ancestors might be retrieved and cached by the provider. + The number of child generations to fetch. 0 indicates no descendant nodes are retrieved and a -1 indicates that all descendant nodes might be retrieved and cached by the provider. + upLevel or downLevel is less than -1. + + + + When overridden in a derived class, retrieves the parent node of a specific object. + + + + A that represents the parent of node; otherwise, null, if the has no parent or security trimming is enabled and the parent node is not accessible to the current user. + + + The for which to retrieve the parent node. + + + + Provides an optimized lookup method for site map providers when retrieving an ancestor node for the currently requested page and fetching the descendant nodes for the ancestor. + + + + A that represents an ancestor of the currently requested page; otherwise, null, if the current or ancestor is not found or cannot be returned for the current user. + + + The number of descendant node levels to retrieve from the target ancestor node. + The number of ancestor node levels to traverse when retrieving the requested ancestor node. + walkupLevels or relativeDepthFromWalkup is less than 0. + + + + Provides an optimized lookup method for site map providers when retrieving an ancestor node for the specified object and fetching its child nodes. + + + + A that represents an ancestor of node; otherwise, null, if the current or ancestor is not found or cannot be returned for the current user. + + + The number of descendant node levels to retrieve from the target ancestor node. + The that acts as a reference point for walkupLevels and relativeDepthFromWalkup. + The number of ancestor node levels to traverse when retrieving the requested ancestor node. + The value specified for walkupLevels or relativeDepthFromWalkup is less than 0. + node is null. + + + + This method is marked as protected and should never be called. + + + + A that represents the root node of the set of nodes that the current provider manages. + + + + + + Provides a method that site map providers can override to perform an optimized retrieval of one or more levels of parent and ancestor nodes, relative to the specified object. + + + The number of ancestor generations to fetch. 0 indicates no ancestor nodes are retrieved and -1 indicates that all ancestors might be retrieved and cached. + The that acts as a reference point for upLevel. + upLevel is less than -1. + node is null. + + + + Provides a method that site map providers can override to perform an optimized retrieval of nodes found in the proximity of the specified node. + + + The number of ancestor generations to fetch. 0 indicates no ancestor nodes are retrieved and -1 indicates that all ancestors (and their descendant nodes to the level of node) might be retrieved and cached. + The number of descendant generations to fetch. 0 indicates no descendant nodes are retrieved and -1 indicates that all descendant nodes might be retrieved and cached. + The that acts as a reference point for upLevel. + upLevel or downLevel is less than -1. + node is null. + + + + Retrieves a Boolean value indicating whether the specified object can be viewed by the user in the specified context. + + + + true if security trimming is enabled and node can be viewed by the user or security trimming is not enabled; otherwise, false. + + + The that contains user information. + The that is requested by the user. + context is null.- or -node is null. + + + + Gets the friendly name used to refer to the provider during configuration. + + + + The friendly name used to refer to the provider during configuration. + + + + + + Gets a brief, friendly description suitable for display in administrative tools or other user interfaces (UIs). + + + + A brief, friendly description suitable for display in administrative tools or other UIs. + + + + + + Gets the object that represents the currently requested page. + + + + A that represents the currently requested page; otherwise, null, if the is not found or cannot be returned for the current user. + + + + + + Gets or sets the parent object of the current provider. + + + + The parent provider of the current . + + + + + + Gets the root object in the current provider hierarchy. + + + + An that is the top-level site map provider in the provider hierarchy that the current provider belongs to. + + + There is a circular reference to the current site map provider. + + + + Gets the root object of the site map data that the current provider represents. + + + + The root of the current site map data provider. The default implementation performs security trimming on the returned node. + + + + + + Exports an object as a web service. + + +

+ The exporter will create a web service wrapper for the object that is + to be exposed and additionally enable its configuration as a web + service. +

+

+ The exported object can be either a standard .NET web service + implementation, with methods marked using the standard + , or it can be a + plain .NET object. +

+
+ Aleksandar Seovic +
+ + + Holds EXPORTER_ID to WebServiceExporter instance mappings. + + + + + Returns the target object instance exported by the WebServiceExporter identified by . + + + + + + + The name of the object in the factory. + + + + + The owning factory. + + + + + The generated web service wrapper type. + + + + + Creates a new instance of the class. + + + + + Cleanup before GC + + + + + Disconnect the remote object from the registered remoting channels. + + + + + Stops exporting the object identified by . + + true to release both managed and unmanaged resources; false to release only unmanaged resources. + + + + Exports specified object as a web service. + + + In the event of misconfiguration (such as failure to set an essential + property) or if initialization fails. + + + + + Returns the Web Service wrapper type for the object that is to be exposed. + + + + + + Validates the configuration. + + + + + Generates the web service wrapper type. + + + + + Gets or Sets the Web Services Interoperability (WSI) specification + to which the Web Service claims to conform. + + + Default is + + + + + Gets or sets the base type that web service should inherit. + + + Default is + + + + + Gets or sets the name of the target object that should be exposed as a web service. + + + The name of the target object that should be exposed as a web service. + + + + + Gets or sets the description of the web service (optional). + + + The web service description. + + + + + Gets or sets the name of the web service (optional). + + +

+ Defaults to the value of the exporter's object ID. +

+
+ + The web service name. + +
+ + + Gets or sets the web service namespace. + + + The web service namespace. + + + + + Gets or sets the list of interfaces whose methods should be exposed as web services. + + + If not set, all the interfaces implemented or inherited + by the target type will be used. + + The interfaces. + + + + Gets or sets a list of custom attributes + that should be applied to a proxy class. + + + + + Gets or sets a dictionary of custom attributes + that should be applied to web service members. + + + Dictionary key is an expression that members can be matched against. + Value is a list of attributes that should be applied + to each member that matches expression. + + + + + Callback that supplies the owning factory to an object instance. + + + Owning + (may not be ). The object can immediately + call methods on the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+ + In case of initialization errors. + +
+ + + Set the name of the object in the object factory that created this object. + + + The name of the object in the factory. + + +

+ Invoked after population of normal object properties but before an init + callback like 's + + method or a custom init-method. +

+
+
+ + + Implements constructors for the proxy class. + + + This implementation generates an empty noop default constructor + + + The builder to use. + + + + + An implementation that + retrieves configured WebService objects from the Spring.NET web + application context. + + + This handler factory uses web service name from the URL, without the extension, + to find web service object in the Spring context. + + Aleksandar Seovic + + + + Retrieves instance of the page from Spring web application context. + + current HttpContext + type of HTTP request (GET, POST, etc.) + requested page URL + translated server path for the page + instance of the configured page object + + + + Provides base functionality for Spring.NET context-aware + implementations. + + +

+ Provides derived classes with a default implementation of + method. +

+
+ Aleksandar Seovic +
+ + + Holds all handlers having == true. + + + + + Holds an instance of the instrinsic System.Web.UI.SimpleHandlerFactory + + + + + Holds the shared logger for all factories. + + + + + Creates a new instance of the + class. + + + + + Returns an appropriate implementation. + + + An instance of the class that + provides references to intrinsic server objects. + + + The HTTP method of the request. + + The request URL. + + The physical path of the requested resource. + + + A new object that processes + the request. + + + + + Enables a factory to release an existing + instance. + + + The object to release. + + + + + Create a handler instance for the given URL. + + the application context corresponding to the current request + The instance for this request. + The HTTP data transfer method (GET, POST, ...) + The requested . + The physical path of the requested resource. + A handler instance for processing the current request. + + + + Get the application context instance corresponding to the given absolute url and checks + it for contract and being not null. + + the absolute url + + if no context is found + + + if context is not an + + teh application context instance corresponding to the given absolute url. + + Calls to obtain a context instance. + + + + + Returns the unchecked, raw application context for the given virtual path. + + the virtual path to get the context for. + the context or null. + + Subclasses may override this method to change the context source. + By default, is used for obtaining context instances. + + + + + DO NOT USE - this is subject to change! + + + + + This method requires registrars to follow the convention of registering web object definitions using their + application relative urls (~/mypath/mypage.aspx). + + + Resolve an object definition by url. + + + + + Apply dependency injection stuff on the handler. + + the handler to be intercepted + the context responsible for configuring this handler + + + + Get the global instance of System.Web.UI.SimpleHandlerFactory + + + This factory is a plaform version agnostic way to instantiate + arbitrary handlers without the need for additional reflection. + + + + + Holds a named + + Erich Eichinger + + + + Creates a new name/objectdefinition pair. + + + + + Get the name of the attached object definition + + + + + Get the . + + + + + implementation that allows users to monitor state + of the Spring.NET web application context. + + +

+ +

+
+ Aleksandar Seovic +
+ + + Initializes a new instance of the class. + + + + + Processes HTTP request. + + An object that provides references to the intrinsic server objects (for example, , , , and ) used to service HTTP requests. + + + + Gets a value indicating whether another request can use + this instance. + + True if this handler is reusable, False otherwise. + + + + Helper class for easier access to reflected Control members. + + Erich Eichinger + + + + Instantiates a new Accessor. + + + + + + Returns the underlying ControlCollection instance. + + + + + Gets or sets the ControlCollection of the target without accessing the target's property. + + + If the underlying collection is null, it is automatically created. + + + + + Helper class for easier access to reflected ControlCollection members. + + Erich Eichinger + + + + Returns the underlying ControlCollection instance. + + + + + Returns the type of the underlying ControlCollection instance. + + + + + Creates a new Accessor for a given . + + The to be accessed + + + + Gets or sets the owner of the underlying ControlCollection. + + + + + Support Class providing a method to ensure a control has been intercepted + + Erich Eichinger + + + + Holds all available interception strategies + + + + + The last resort interception strategy... + + + + + Holds a control.GetType()->IInterceptionStrategy table. + + + + + Holds well-known Type/Strategy mappings. + + + + + Ensures, a control has been intercepted to support Web-DI. If not, the control will be intercepted. + + + + + Any concrete interception strategy must implement this interface + + Erich Eichinger + + + + Any implementation must never throw an exception from this method. + Instead false must be returned to indicate interception failure. + + + true, if interception succeeded. false otherwise. + + + + + SimpleHandlerFactory is used to wrap any arbitrary to make it "Spring-aware". + + + By default, an instance of is used as underlying factory. + + Erich Eichinger + + + + Creates a new instance, using a as underlying factory. + + + + + Create a new instance, using an instance of as underlying factory. + + a type that implements + + + + Create a new instance, using as underlying factory. + + the factory to be wrapped. + + + + Create a handler instance for the given URL. + + the application context corresponding to the current request + The instance for this request. + The HTTP data transfer method (GET, POST, ...) + The requested . + The physical path of the requested resource. + A handler instance for processing the current request. + + + + Enables a factory to release an existing + instance. + + + The object to release. + + + + + This result factory implementation creates instances from a given string representation. + + + For a larger example illustrating the customization of result processing, . + + + + + + Erich Eichinger + + + + A result factory is responsible for create an instance from a given string representation. + + + For a larger example illustrating the customization of result processing, . + + + + + + Erich Eichinger + + + + Create an instance from the given string representation. + + the resultMode that caused triggering this factory. + the remainder string to be interpreted and converted into an . + An instance. Must never be null! + + Note to implementors: This method must never return null. Instead exceptions should be thrown. + + + + + Create a new from the specified . + + the result mode. + the string representation of the result. + the instance created from . + + + + The default implementation of the interface. + + + + + Defines the interface, all hierarchical navigators capable of + dealing with instances must implement. + + + + + An extension of that must be implemented by + navigators that can be part of a hierarchy. + + Erich Eichinger + + + + Any component capable of navigating and participating in the navigation logic must implement this interface. + + + + + + Erich Eichinger + + + + Determines, whether this navigator or one of its parents can + navigate to the destination specified in . + + the name of the navigation destination + true, if this navigator can navigate to the destination. + + + + Instruct the navigator to navigate to the specified navigation destination. + + the destination to navigate to. + the sender that issued the navigation request. + the context to evaluate this navigation request in. + if this navigator cannot navigate to the specified (). + + + + Creates an uri poiniting to the specified navigation destination. + + the destination to navigate to. + the sender that issued the navigation request. + the context to evaluate this navigation request in. + if this navigator cannot navigate to the specified (). + + + + If any, get the parent navigator of the current navigator instance. May be null. + + + + + Contains the mappings of navigation destination names to + instances or their corresponding textual representations.
+ See for more information on how textual representations are resolved. +
+ + + + + +
+ + + Creates and initializes a new instance. + + + + + Creates and initializes a new instance. + + the parent of this instance. May be null. + a dictionary of result name to result mappings. May be null. + sets, how this navigator treats case sensitivity of result names + + + + Create the dictionary instance to be used by this navigator component. + + a dictionary of intitial result mappings + the dictionary, that will be used by this navigator. + + Implementors may override this for creating custom dictionaries. + + + + + Determines, whether this navigator or one of its parents can + navigate to the destination specified in . + + the name of the navigation destination + true, if this navigator can navigate to the destination. + + + + Redirects user to a URL mapped to specified result name. + + Name of the result. + the instance that issued this request + The context to use for evaluating the SpEL expression in the Result. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + the instance that issued this request + The context to use for evaluating the SpEL expression in the Result + A redirect url string. + + + + Obtain the named result instance from the dictionary. If necessary, the actual representation of the result + will be converted to an instance by this method. + + + + + + + Handle an unknown result object. + + the name of the result + the result instance obtained from the dictionary + + By default, this method throws a . + + + + + Handle an unknown destination. + + the destination that could not be resolved. + the sender that issued the request + the context to be used for evaluating any dynamic parts of the destination + the uri as being returned from + + By default, this method throws a . + + + + + Indicates, whether result names are treated case sensitive by this navigator. + + + + + Get/Set the parent of this navigator. + + if this navigator already has a parent. + + + + Gets or sets map of result names to instances or their textual representations. + See for information on parsing textual representations. + + + + + + + + + Holds a list of url expressions and their corresponding names of responsible + or objects managed by the container. + + Erich Eichinger + + + + Maps the specified url pattern expression to an object name denoting a or object. + + the string pattern (see conform to syntax) + an object name denoting the spring-managed handler definition + + + + Maps the specified url pattern expression to an object name denoting a or object. + + the url pattern + an object name denoting the spring-managed handler definition + + + + Maps the to a handler object name by matching against all registered patterns. + + the virtual path + the object name + + + + Add a new mapping + + an url pattern string + a handler object name string + + + + Clear the mapping table. + + + + + Copies all entries to the specified array. + + + + + Get an enumerator for iterating over the list of registered mappings. + + + + + Not supported by this implementation. + + + + + Not supported by this implementation. + + + + + Not supported by this implementation. + + + + + Add or replace a mapping + + + Getter will throw a ! + + an url pattern string + + + + Always returns false. + + + + + Gets a value indicating whether the object has a fixed size. + + + + true if the object has a fixed size; otherwise, false. + + 2 + + + + Get the number of registered mappings. + + + + + Gets an object that can be used to synchronize access. + + + + + Always returns false. + + + + + Not supported by this implementation. + + + + + Not supported by this implementation. + + + + + Holds pairs of (url pattern, handler object name). + + + + + Erich Eichinger + + + + Create a new instance. + + + + + + + Create a new instance + + + + + + + Return a string representation of this entry. + + + + + Get the url pattern + + + + + Get the handler object name + + + + + This strategy replaces the original collection's owner with an intercepting proxy + + Erich Eichinger + + + + This strategy enhances a ControlCollection's type by + dynamically implementing ISupportsWebDependencyInjection on this type + + Erich Eichinger + + + + The list of methods to be intercepted for a ControlCollection + + + + + Holds a table of already known intercepted ControlCollection types + + + + + Intercepts the given by dynamically deriving + the original type and let it implement . + + the ApplicationContext to be set on the collection instance. + a wrapper around the owner control instance. + a wrapper around the collection instance. + true, if interception was successful. false otherwise + + + + Holds a reference to the static(!) callback-method to be used during generation of intercepted ControlCollection-Types + + + + + An encapsulates concrete navigation logic. Usually executing a + result will invoke or . + + + For a larger example illustrating the customization of result processing . + + + + + + + + Erich Eichinger + + + + Execute the result logic within the given . + + the context to evaluate this request in. + + + + Returns an url representation of the result logic within the given . + + the context to evaluate this request in. + the url corresponding to the result instance. + + The returned url is not necessarily fully qualified nor absolute. Returned urls may be relative to the + given context.
+ To produce a client-usable url, consider applying e.g. or + before writing the result url to the response. +
+
+ + + "Contract"-interface of the Web-DI infrastructure. + + + This interface supports Spring's DI infrastructure and normally doesn't need to be implemented
+
+ Any Page, Control or ControlCollection implementing this interface guarantees to + call on any control being added + before it is actually added to the child-collection. +
+ +

The following example shows, how to make a Control support the DI-infrastructure:

+ + class MyControl : Control, ISupportsWebDependencyInjection + { + private IApplicationContext _defaultApplicationContext; + + public IApplicationContext DefaultApplicationContext + { + get { return _defaultApplicationContext; } + set { _defaultApplicationContext = value; } + } + + override protected AddedControl( Control control, int index ) + { + WebUtils.InjectDependenciesRecursive( _defaultApplicationContext, control ); + base.AddedControl( control, index ); + } + } + +
+ +

The following example shows, how to make a ControlCollection support the DI-infrastructure:

+

Note, that you MUST implement the single-argument constructor ControlCollection( Control owner )!

+ + class MyControlCollection : ControlCollection, ISupportsWebDependencyInjection + { + private IApplicationContext _defaultApplicationContext; + + public MyControlCollection( Control owner ) : base( owner ) + {} + + public IApplicationContext DefaultApplicationContext + { + get { return _defaultApplicationContext; } + set { _defaultApplicationContext = value; } + } + + override public Add( Control child ) + { + WebUtils.InjectDependenciesRecursive( _defaultApplicationContext, child ); + base.Add( child ); + } + + override public AddAt( int index, Control child ) + { + WebUtils.InjectDependenciesRecursive( _defaultApplicationContext, child ); + base.AddAt( index, child ); + } + } + +
+ Erich Eichinger +
+ + + Holds the default instance to be used during injecting a control-tree. + + + + + Any component participating in the navigation infrastructure must implement this interface. + + Erich Eichinger + + + + Return the associated with this component. + + + + + This ResourceManager implementation swallows s and + simply returns null from if no resource is found. + + Erich Eichinger + + + + Avoid beforeFieldInit + + + + + Returns the value of the specified resource. + + + The value of the resource localized for the caller's current culture settings. If a match is not possible, null is returned. The resource value can be null. + + The name of the resource to get. + The name parameter is null. + + + + Gets the value of the resource localized for the specified culture. + + + The value of the resource, localized for the specified culture. If a "best match" is not possible, null is returned. + + The object that represents the culture for which the resource is localized. Note that if the resource is not localized for this culture, the lookup will fall back using the culture's property, stopping after checking in the neutral culture.If this value is null, the is obtained using the culture's property. + The name of the resource to get. + The name parameter is null. + + + + Returns the value of the specified resource. + + + The value of the resource localized for the caller's current culture settings. If a match is not possible, null is returned. The resource value can be null. + + The name of the resource to get. + The name parameter is null. + + + + Gets the value of the resource localized for the specified culture. + + + The value of the resource, localized for the specified culture. If a "best match" is not possible, null is returned. + + The object that represents the culture for which the resource is localized. Note that if the resource is not localized for this culture, the lookup will fall back using the culture's property, stopping after checking in the neutral culture.If this value is null, the is obtained using the culture's property. + The name of the resource to get. + The name parameter is null. + + + + MappingHandleryFactory allows for full Spring-managed <httpHandlers> configuration. + It uses regular expressions for url matching. + + + + The example below shows, how to map all url requests to spring and let + resolve urls to container-managed or objects. + + // web.config + + <httpHandlers> + <!-- map all requests to spring (just for demo - don't do this at home!) --> + <add verb="*" path="*.*" type="Spring.Web.Support.MappingHandlerFactory, Spring.Web" /> + </httpHandlers> + + // spring-objects.config + + <object type="Spring.Web.Support.MappingHandlerFactoryConfigurer, Spring.Web"> + <property name="HandlerMap"> + <dictionary> + <entry key="\.ashx$" value="standardHandlerFactory" /> + <!-- map any request ending with *.whatever to standardHandlerFactory --> + <entry key="\.whatever$" value="specialHandlerFactory" /> + </dictionary> + </property> + </object> + + <object name="standardHandlerFactory" type="Spring.Web.Support.DefaultHandlerFactory, Spring.Web" /> + + <object name="specialHandlerFactory" type="MySpecialHandlerFactoryImpl" /> + + + + + + + + Erich Eichinger + + + + Holds the cache of handler/factory pairs handed out by this factory. This is required + for proper handling of . + + + + + Create a handler instance for the given URL. Will try to find a match of onto patterns in . + If a match is found, delegates the call to the matching method. + + the application context corresponding to the current request + The instance for this request. + The HTTP data transfer method (GET, POST, ...) + The requested . + The physical path of the requested resource. + A handler instance for processing the current request. + + + + Obtains a handler by mapping to the list of patterns in . + + the application context corresponding to the current request + The instance for this request. + The HTTP data transfer method (GET, POST, ...) + The requested . + The physical path of the requested resource. + + + A handler instance for processing the current request. + + + + Enables a factory to release an existing + instance. + + + The object to release. + + + + + Removes the handler from the handler/factory dictionary and releases the handler. + + the handler to be released + a dictionary containing (, ) entries. + + + + Holds the global list of mappings from url patterns to handler names. + + + + + Configures . + + Erich Eichinger + + + + Contains mappings of url patterns to handler objects. + + + + + Represents a MIME media type as defined by http://www.iana.org/assignments/media-types/ + + Erich Eichinger + + + + Parses a string into a instance. + + a valid string representation of a mediaType + a new instance + + + + Creates a new media type instance representing a generic "application/octet-stream" + + + + + Creates a new media type instance representing a generic content type + with an unspecified subtype (e.g. "text/*") + + + + + Creates a new media type instance representing a particular media type + + + + + Returns a string representation of this instance. + + + + + Compares this instance to another + + another instance + + + + Determines whether the specified is equal to the current . + + + true if the specified is equal to the current ; otherwise, false. + + The to compare with the current . + + + + Serves as a hash function for a particular type. is suitable for use in hashing algorithms and data structures like a hash table. + + + A hash code for the current . + + + + + Gets the content type of this media type instance + + + + + Gets the subtype of this media type instance + + + + + Predefines common application media types + + + + + Represents "application/octet-stream" + + + + + Represents "application/pdf" + + + + + Represents "application/rtf" + + + + + Represents "application/soap+xml" + + + + + Represents "application/zip" + + + + + Predefines common image media types + + + + + Represents "image/gif" + + + + + Represents "image/jpeg" + + + + + Represents "image/tiff" + + + + + Predefines common text media types + + + + + Represents "text/html" + + + + + Represents "text/plain" + + + + + Represents "text/richtext" + + + + + Represents "text/xml" + + + + + Represents "text/javascript" + + + + + Represents "text/css" + + + + + Implementation of that retrieves + configured instances from Spring web application context. + + + + This handler factory uses the page name from the URL, without the extension, + to find the handler object in the Spring context. This means that the target object + definition doesn't need to resolve to an .aspx page -- it can be any valid + object that implements interface. + + + If the specified page is not found in the Spring application context, this + handler factory falls back to the standard ASP.NET behavior and tries + to find physical page with a given name. + + + In either case, handlers that implement + and will be provided with the references + to appropriate Spring.NET application context (based on the request URL) + and a that should be used to store the information + that needs to be shared by all instances of the handler. + + + Aleksandar Seovic + + + + Retrieves instance of the configured page from Spring web application context, + or if page is not defined in Spring config file tries to find it using standard + ASP.Net mechanism. + + Current HttpContext + Type of HTTP request (GET, POST, etc.) + Requested page URL + Translated server path for the page + Instance of the IHttpHandler object that should be used to process request. + + + + Create a handler instance for the given URL. + + the application context corresponding to the current request + The instance for this request. + The HTTP data transfer method (GET, POST, ...) + The requested . + The physical path of the requested resource. + A handler instance for the current request. + + + + Represents the ASPX result page that an operation maps to. + + +

+ Parameters can reference variables accessible from the page using the + standard NAnt style property notation, namely ${varName}. +

+

+ The result that is passed as the sole + parameter to the parameterized constructor + () must adhere to the + following format: +

+ + [<mode>:]<targetPage>[?param1,param2,...,paramN] + +

+ Only the targetPage is mandatory. +

+
+ +

+ Examples of valid values that can be passed + to the the parameterized constructor + () include: +

+

+ + Login.aspx + ~/Login.aspx + redirect:~/Login.aspx + transfer:~/Login.aspx + transfer:Services/Register.aspx + Login.aspx?username=springboy,password=7623AAjoe + redirect:Login.aspx?username=springboy,password=7623AAjoe + +

+
+ Aleksandar Seovic + Matan Shapira +
+ + + The default . + + +

+ Currently defaults to . +

+
+ +
+ + + Creates a new instance of the class. + + + + + Creates a new instance of the class. + + +

+ See both the class documentation () + and the reference documentation for the Spring.Web library for a + discussion and examples of what values the supplied + can have. +

+
+ The result descriptor. + + If the supplied is or + contains only whitespace character(s). + + if the result mode is unknown. +
+ + + Creates a new instance of the class. + + +

+ See both the class documentation () + and the reference documentation for the Spring.Web library for a + discussion and examples of what values the supplied + can have. +

+
+ The desired result mode. May be null to use default mode. + The result descriptor (without resultMode prefix!). + + If the supplied is or + contains only whitespace character(s). + + if the result mode is unknown. +
+ + + Navigates to the + defined by this result. + + + The context object for parameter resolution. This is typically + a . + + + + + Performs a server-side transfer to the + defined by this result. + + + The context object for parameter resolution. This is typically + a . + + + + + + Resolves transfer parameters and stores them into instance. + + + + + + + Performs a redirect to the + defined by this + result. + + + The context object for parameter resolution. This is typically + a . + + + + + + Returns a redirect url string that points to the + defined by this + result. + + + A redirect url string. + + + + + Construct the actual url to be executed or returned. + + the already evaluated + the already evaluated parameters. + the url to be returned by + + + + Append the url parameter to the url being constructed. + + the containing the url constructed so far. + the parameter key + the parameter value + the to use for further url construction. + + + + Evaluates within and returns the evaluation result. + + the context to be used for evaluation. + the string that might need evaluation + the evaluation result. Unodified if no evalution occured. + + + + Checks, if value is a SpEL expression ${expression} or %{expression}. + + + + + If is a SpEL expression (${expression} or %{expression}), evaluates + the value against . + + + + + Extracts and sets this instance's + property from the supplied descriptor. + + +

+ The supplied descriptor is typically + something like /Foo.aspx or + redirect:http://www.springframework.net/. +

+
+ + The result descriptor. + + + The supplied without the result mode + prefix (if any). + + + If the supplied starts with an illegal + result mode (see ). + +
+ + + Set the actual from the parsed string. + + the parsed result mode + + + + Resolves dynamic expression contained in if any by calling . + + the context to be used for evaluating the expression + the evaluated expression + + + + Parses query parameters from the supplied . + + + The query string (may be ). + + + + + The . Defines which + method will be used to navigate to the + . + + + + + The target page. + + +

+ This is the (relative) path to the target page. +

+
+ +

+ Examples of valid values would be: +

+

+ + Login.aspx + ~/Login.aspx + ~/B2B/SignUp.aspx + B2B/Foo/FooServices.aspx + +

+
+
+ + + The parameters thar are to be passed to the + upon + navigation. + + + + + Indicates, if should be called with preserveForm='true' | 'false'. Only relevant for ResultMode.TransferXXXX modes. + + + + + Indicates, if should be called with endResponse='true' | 'false'. Only relevant for ResultMode.RedirectXXXX modes. + + + + + A result factory is responsible for create an instance from a given string representation. + + + + Factories get registered with the for a certain resultMode string. + uses for converting strings into instances + implementing the corresponding navigation logic. + + + Result string representations are always of the form:
+ "<resultmode>:<textual result representation>"
+ Calling on the registry will cause the registry to first extract the leading resultmode to obtain + the corresponding instance and handle the actual instantiation by delegating to + . +
+ + The following example illustrates the usual flow: + + class MySpecialResultLogic : IResult + { + ... + } + + class MySpecialResultLogicFactory : IResultFactory + { + IResult Create( string mode, string expression ) { /* ... convert 'expression' into + MySpecialResultLogic */ } + } + + // register with global factory + ResultFactoryRegistry.RegisterResultFactory( "mySpecialMode", new MySpecialResultLogicFactory ); + + // configure your Results + <object type="mypage.aspx"> + <property name="Results"> + <dictionary> + <entry key="continue" value="mySpecialMode:<some MySpecialResultLogic string representation>" /> + </dictionary> + </property> + + // on your page call + myPage.SetResult("continue"); + + +
+ + + + + + + Erich Eichinger +
+ + + Resets the factory registry to its defaults. Mainly used for unit testing. + + + + + Set a new default factory + + the new default factory instance. Must not be null. + the previous default factory. + + + + Registers a for the specified . + + the resultMode. Must not be null. + the factory respponsible for handling results. Must not be null. + the factory previously registered for the specified , if any. + + See overview for more information. + + + + + Creates a result from the specified by extracting the result mode from + the text and delegating to a corresponding , if any. + + the 'resultmode'-prefixed textual representation of the result instance to create. + + the instance corresponding to the textual represenation, + created by the + + + if either is null or returned null. + + This method guarantees that the return value will always be non-null.
+ must always be of the form "<resultmode>:<textual result representation>". + The resultmode will be extracted and the corresponding (previously registered + using ) is called to actually create the instance. If no factory matches + resultmode, the call is handled to the . +
+
+ + + Returns the current set by . Will never be null. + + + The default factory is responsible for handling any unknown result modes. + + + + + The various result modes. + + Aleksandar Seovic + + + + + A server-side transfer. + + +

+ Issues a server-side transfer using the + method. +

+
+ +
+ + + A redirect. + + +

+ Issues a redirect (to the user-agent - typically a browser) using + the method. +

+
+ +
+ + + A server-side transfer. + + +

+ Issues a server-side transfer using the + method with parameter 'preserveForm=false'. +

+
+ +
+ + + A redirect. + + +

+ Issues a redirect (to the user-agent - typically a browser) using + the method. +

+
+ +
+ + + Base class that describes client side script block or file. + + +

+ Classes that extend this class are used by Spring.Web client-side + scripting support. +

+
+ Aleksandar Seovic +
+ + + Initialize a new Script object of the specified language + + Script language. + + + + Initialize a new script object of the specified type + + a + + + + Gets or sets script language. + + + + + Gets or sets script mime type + + + + + Class that describes client side script block. + + +

+ Script blocks are used to insert script code directly into the page, + without references to an external file. +

+
+ Aleksandar Seovic +
+ + + Default constructor. + + Script language. + The script text. + + + + Initialize a new script block instance. + + the script language's + the script body + + + + Gets or sets the script text. + + The script text. + + + + Class that describes client side script file. + + +

+ Script file references script code in the external file. +

+
+ Aleksandar Seovic +
+ + + Initialize a new instance. + + Script language. + The name of the script file. + + + + Initialize a new instance. + + the script language's + the (virtual) path to the script + + + + Gets or sets the name of the script file. + + The name of the script file. + + + + Class that describes client side script file. + + +

+ Script file references script code in the external file. +

+
+ Aleksandar Seovic +
+ + + Initialize a new instance. + + Script language. + Element ID of the event source. + Name of the event to handle. + Script text. + + + + Initialize a new instance. + + the script language's + Element ID of the event source. + Name of the event to handle. + Script text. + + + + Gets or sets the element ID. + + The element ID. + + + + Gets or sets the name of the event. + + The name of the event. + + + + Resource cache implementation that uses Spring.NET page/handler state to cache resources. + + Aleksandar Seovic + + + + Creates a new cache instance and attaches it to the given + + the holder of the shared state dictionary to be used for caching. + + + + Gets the list of resources from cache. + + Cache key to use for lookup. + A list of cached resources for the specified target object and culture. + + + + Puts the list of resources in the cache. + + Cache key to use for the specified resources. + A list of resources to cache. + + + + This MethodBuilder emits a Callback-call before calling the base method + + Erich Eichinger + + + + Initializes a new instance of a SupportsWebDependencyInjectionMethodBuilder + + + + + Inserts a call to a callback-method before actually calling the base-method. + + The IL generator to use + The method to proxy + The interface definition of this method, if applicable + + + + Emits the callback invocation. + + + + + Wraps a ControlCollection.Owner control to make it DI aware + + Erich Eichinger + + + + Wraps a control to make it DI aware + + + + + + + Performs DI before adding the control to it's parent + + + + + + + Delegates call to decorated control + + + + + + Wraps a ControlCollection.Owner control implementing INamingContainer to make it DI aware + + Erich Eichinger + + + + This TypeBuilder dynamically implements the contract on a given type. + + Erich Eichinger + + + + Creates a new TypeBuilder instance. + + The base type the proxy shall be derived from + The methods to be injected with a call to staticCallbackMethod + The static callback method to be injected into methodsToIntercept + + + + Creates a proxy that inherits the proxied object's class. + + + The generated proxy type. + + + + Actually implements the interface. + + + + + Declares field that holds the . + + + + + Determines if the specified + is one of those generated by this builder. + + The type to check. + + if the type is a SpringAwareControl-based proxy; + otherwise . + + + + + Utilities for dependency injection in the web tier. + + + + + Injects dependencies into all controls in the hierarchy + based on template definitions in the Spring config file. + + ApplicationContext to be used + Control to inject dependencies into. + + + + Aquires an ApplicationContext according to a Control's TemplateSourceDirectory + + if availabe, the control's IApplicationContext instance - defaultContext otherwise + + + + An implementation of specific for s. + The navigator hierarchy equals the control hierarchy when using a . + + + + This implementation supports 2 different navigator hierarchies: +
    +
  • The default hierarchy defined by
  • +
  • The hierarchy defined by a web form's hierarchy.
  • +
+
+ + This implementation always checks the standard hierarchy first and - if a destination cannot be resolved, falls back + to the control hierarchy for resolving a specified navigation destination. + +
+
+ + + Finds the next up the control hierarchy, + starting at the specified . + + + This method checks both, for controls implementing or . In addition + when MasterPages are used, it interprets the control hierarchy as control->page->masterpage. (). + + the control to start the search with. + include checking the control itself or start search with its parent. + requires s to hold a valid instance. + If found, the next or . + null otherwise + + + + Creates a new instance of a for the specified control. + + the control to be associated with this navigator. + the direct parent of this navigator + a dictionary containing results + specifies how to handle case for destination names. + + + + Determines, whether this navigator or one of its parents can + navigate to the destination specified in . + + the name of the navigation destination + true, if this navigator can navigate to the destination. + + + + Check, whether this navigator can navigate to the specified . + + the destination name to check. + + whether the check shall include the control hierarchy or + the standard hierarchy only. + + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + the instance that issued this request + The context to use for evaluating the SpEL expression in the Result + A redirect url string. + + + + Redirects user to a URL mapped to specified result name. + + Name of the result. + the instance that issued this request + The context to use for evaluating the SpEL expression in the Result. + + + + The that this is associated with. + + + + + Return the next available within + this control's parent hierarchy. + + + + + Holds the result match from . + + + + + The matching control + + + + + The instance associated with the control. May be null. + + + + + Initializes the new match instance. + + the matching control. Must not be null! + + + + Adapts a concrete instance as a . + + Erich Eichinger + + + + Create a new adapter instance, wrapping the specified + into a interface. + + the instance to be adapted. May be null. + + + + Returns the wrapped that was passed into . + + + + + Provides functions required for implementing validators + but are unfortunately not accessible from + + Erich Eichinger + + + + Registers a javascript-block to be rendered. + + + + + Checks, if a certain javascript-block is already registered. + + + + + Adds an attribute to be rendered for clientside validation. + + + + + Is "XHTML 1.0 Transitional" rendering allowed? + + + + + Provides common functionality to all validation renderer controls. + + Erich Eichinger + + + + Create the default + for this ValidationControl if none is configured. + + + + + Gets the MessageSource to be used for resolve error messages + + + By default, returns 's MessageSource. + + the to resolve message texts. May be null + + + + Gets the list of validation errors to render + + the to render. May be null + + + + Gets the , who's + shall be rendered by this control. + + + First, it tries to resolve the specified , if any. If no explicit name + is set, will probe the control hierarchy for controls implementing . + + + + + Resolves the list of validation errors either explicitely specified using + or obtained from the containing + resolved by to a list + of elements containing the error messages to be rendered. + + + + The list of validation errors may either be explicitely specified using + or will automatically be obtained from the containing resolved by + . + + + Error Messages are resolved using either an explicitely specified or the + obtained from the validation container. + + + a list containing elements. May return null + + + + Renders error messages using the specified . + + + + + + Set a particular message source to be used for + resolving error messages to display texts. + + + If not set, the control will probe the control hierarchy + for containing controls implementing + and use the container's . + + + + + Allows to set a particular instance of the validation errors + collection to render. + + + If not set, the control will probe the control hierarchy for + containing controls implementing + and use the container's + + + + + If set, will resolve to the named control specified + by this property. The behavior of name resolution is identical to + , except that if the name + starts with "::", the resolution will start at the page level instead of relative to this + control + + + + + Gets or sets the provider. + + The provider. + + + + Gets or sets the validation errors renderer to use. + + + If not explicitly specified, defaults to . + + The validation errors renderer to use. + + + + Displays a pop-up DHTML calendar. + + +
+ + Aleksandar Seovic + + + + Registers necessary scripts and stylesheet. + + + An object that contains the event data. + + + + + Renders a hidden input field that stores the value for the radio button group. + + + to use for rendering. + + + + + Raises the SelectionChanged event. + + + + + Loads postback data into the control. + + + The key that should be used to retrieve data. + + The postback data collection. + if data has changed. + + + + The method that is called on postback if the date has changed. + + + The event argument (empty and unused). + + + + + Gets a reference to the instance that contains the + server control. + + + A reference to the instance that contains the + server control. + + + + + The selected date. + + The selected date. + + + + The date format that is to be used. + + A valid date format string. + + + + Is direct editing of the date allowed? + + + if direct editing of the date is allowed? + + + + The (CSS) style. + + The style for the calendar. + + + + Occurs when the value of the radio button group changes between postbacks to the server. + + + + + Adds the property to the framework's control. + + + When using Spring.Web's DataBinding, you should use this control for easier binding declaration. + + Erich Eichinger + + + + Gets or Sets the list of selected values and checks the es accordingly + + + + + This validator allows for validating a CheckBox's "Checked" state. + + Erich Eichinger + + + + Validates this validator's properties are set correctly. + + + + + + Returns the state of the checkbox's Checked property + + + + + + Adds attributes required for clientside validation + + + + + + Ensures the evaluation javascript functionblock is registered + + + + + + Represents Content control that can be used to populate or override placeholders + within the master page. + + + Any content defined within this control will override default content + in the matching control + within the master page + + Aleksandar Seovic + + + + Represents ContentPlaceHolder control that can be used to define placeholders + within the master page. + + + Any content defined within this control will be treated as a default content + for the placeholder and will be rendered unless the child page overrides it + by defining matching control. + + Aleksandar Seovic + + + + Represents Content control that can be used to populate or override placeholders + anywhere within the page. + + + + Any content defined within this control will override default content + in the matching control specified by anywhere + within the page. + + + In contrast to control, ContentReplacer can replace the content of + any control within the current page - it is not limited to replacing ContentPlaceholders on master pages. + + + This technique is useful if you want to group e.g. rendering navigation elements on 1 ascx control, but your + design requires navigation elements to be distributed across different places within the HTML code. + + + Erich Eichinger + + + + Overriden to correctly redirect rendermethod calls. + + + + + Renders child controls + + + + + Render nothing. + + + + + Specifies the unique id of the control, who's content is to be replaced. + + + + + May be used to wrap controls for databinding that don't accept unknown attributes. + + + + + Overridden to ensure only 1 control is wrapped by this adapter + + + + + + Overridden to render wrapped control only. + + + + + Returns the control wrapped by this adapter or null. + + + + + Any WebControl placed on a DataBindingPanel may be bound + to a model by adding an attribute "BindingTarget" + + Erich Eichinger + + + + This panel provides the same features as , but provides additional means with regards to Spring. + + + In some cases, automatic dependency injection can cause performance problems. In this case,you can use a Panel for finer-grained control + over which controls are to be injected or not. + + Erich Eichinger + + + + Overridden to set according to if necessary. + + + + + Renders the HTML opening tag of the control to the specified writer. + + An that represents the output stream to render HTML content on the client. + + + + Renders the HTML closing tag of the control to the specified writer. + + An that represents the output stream to render HTML content on the client. + + + + This method is invoked right before InitRecursive() is called for this Panel and + ensures, that dependencies get injected on child controls before their Init event is raised. + + + + + Injects dependencies into control before adding it. + + + + + Overridden to automatically aquire a reference to + root application context to use for DI. + + + + + An optional SpEL expression to control this Panel's state. + + + This panel instance is the context for evaluating the given expression. If no expression is specified, visibility behavior + reverts to standard behavior. + + + + + This flag controls, whether DI on child controls will be done or not + + By default, DI will be done + + + + This flag controls, whether this Panel's tag will be rendered. + + + + + Expose the context of this panel for medium trust safe access in e.g. . + + + + + Sets / Gets the ApplicationContext instance used to configure this control + + + + + Registers this control for the event of it's container. + + + + + Overridden to remove custom binding attributes before rendering. + + + + + + Overriden to suppress rendering this control's tag + + + + + + Called by the containing if bindings must be initialized. + + + + + Adds all controls on this panel to the containing 's binding collection. + + the usercontrol containing this panel + the of controls to be bound + action to be performed on matching controls + + + + Retrieves custom binding attributes from a webcontrol and adds a new binding + instance to the container's if necessary. + + + + + Removes custom binding attributes from a webcontrol to avoid them being rendered. + + + + + Probe for bindingType of know controls + + the control, who's bindingType is to be determined + null, if standard binding is to be used or the fully qualified typename of the binding implementation + + + + Probes for a few know controls and their properties. + + + The 'BindingSource' expression to be used for binding this control. + + + + + This control allows for suppressing output of the 'action' attribute. + + + the 'action' attribute rendered by the default control causes troubles + in case of URL-rewriting. See e.g. 'thescripts.com' forum + and also JIRA SPRNET-560 for more info. + + Erich Eichinger + + + + Renders attributes but performs 'action' suppressing logic. + + + + + + Sets or Gets a value indicating if the 'action' attribute shall be rendered. Defaults to 'false' + + + The following possibilites are available: + + If is 'true', rendering of the 'action' attribute is suppressed. + If is 'false' and is not set, + 'action' attribute will.be rendered to + + If is 'false' and is set, + 'action' attribute will.be rendered to + + + + + + + Sets or Gets an explicit url to be rendered + + + The url specified here is only rendered, if is true. + + + + + This wrapper suppresses output of 'action' attributes. + + + + + This control should be used instead of standard HTML head tag + in order to render dynamicaly registered head scripts and stylesheets. + + + If you need to use ASP.NETs built-in <head> tag, you should nest Spring's within ASP.NET's: + + <html> + <head> + <title>Some Title</title> + <spring:head> + <-- will render styleblocks etc. here --> + </spring:head> + </head> + </html> + + + Aleksandar Seovic + + + + Sends server control content to a provided object, which writes the content to + be rendered on + the client. + + The object that receives the server control content. + + + + Gets or sets the default mimetype for the <style> element's 'type' attribute + + + Defaults to "text/css" + + + + + Gets a reference to the instance that contains the + server control. + + + + + + This control should be used instead of standard HTML head tag + in order to render dynamicaly registered head scripts and stylesheets. + + Aleksandar Seovic + + + + Tries to determine full URL for the localized image before it's rendered. + + + + + + Name of the image file. + + + + + Gets a reference to the instance that contains the + server control. + + + + + + Groups radio button controls and returns the value of the selected control + + + This control alows radio buttons to be data-bound to a data model of the page. + + Aleksandar Seovic + + + + Overloaded to track addition of contained controls. + + + + + Overloaded to track removal of a RadioButton + + + + + + Registers the RadioButtonGroup for PostBack. + + + + + Renders only children of this control. + + HtmlTextWriter to use for rendering. + + + + Loads postback data into the control. + + Key that should be used to retrieve data. + Postback data collection. + True if data has changed, false otherwise. + + + + Raises SelectionChanged event. + + + + + Method that is called on postback if selected radio button has changed. + + Empty event argument. + + + + Gets or sets the ID of the selected radio button. + + ID of the selected radio button. + + + + Gets or sets whether form should be posted back on every selection change + within the radio group. + + + + + Occurs when the value of the radio button group changes between postbacks to the server. + + + + + Provides information about a command raised from a + + Erich Eichinger + + + + Initializes a new instance. + + The name of the command raised by a . + The index of the tab that raised this event. + + + + Returns the index of the tab that raised this command. + + + + + Represents the method that will handle the TabCommand event. + + The source of the event. + A that contains the event data. + Erich Eichinger + + + + This control is responsible for rendering tabs. + + + By default, this TabContainer implementation uses controls to + render tabs. Override to change this behaviour. + + Erich Eichinger + + + + Represents the command name of the tab to be selected. + + + + + Key into the eventhandler table. + + + + + Catches with name '' and + raises the event. + + The source of the event. + contains event information. + + + + + Raises the event. + + + + + Creates a new tab for the specified view within the given container. + + The containing the view + The for which a new tab is to be created. + The index of the tab to be created. + + By default, controls are used for rendering tabs. Override this method to + change this behaviour. + + + + + Occurs, when a tab control is clicked. + + + + + The control allows you to build ASP.NET Web pages that present + the user with content arranged in tabular form. + + Erich Eichinger + + + + Initializes a new instance. + + + + + Initializes a new instance with the given container tag to be used for rendering. + + + + + Create the container for tab items. + + + + + Creates TabContainer and MultiView + + + + + keeps parsed views until multiView is created + + + + + Initialize this control. + + + + + Creates child controls. + + + + + Adds the element to the collection of child controls. + + + + + Called if ActiveViewIndex is changed + + + + + Set the style class of the panel containing the Tabs. + + + + + Set the style class of each Tab item. + + + + + Set the style class of the currently selected Tab item. + + + + + Set the style class of the panel containing all controls. + + + + + Gets or sets the index of the active View control within a control. + + + + + Occurs, if the active tab has changed. + + + + + Represents a control that acts as a container for a group of controls within a control. + + Erich Eichinger + + + + Indicates if this view is currently active. + + + + + Get or Set the name of the tab item associated with this view. + + + + + Get or Set the tooltip text of the tab item associated with this view. + + + + + Holds the collection of controls in a . + + Erich Eichinger + + + + Initialize a new instance. + + + + + + Add the specified control to the collection. + + + + + Add the specified control to the collection. + + + + + Obtain the specified control from the collection. + + + + + This control should be used to display field-level validation errors. + + Aleksandar Seovic + Jonathan Allenby + + + + Create the default + for this ValidationControl if none is configured. + + + + + This control should be used instead of standard ValidationSummary control + to display validation errors identified by the Spring.NET validation framework. + + Aleksandar Seovic + Jonathan Allenby + + + + Create the default + for this ValidationControl if none is configured. + + + + + This class provides common members for all validation errors renderers. + + Aleksandar Seovic + + + + This interface should be implemented by all validation errors renderers. + + + + Validation errors renderers are used to decouple rendering behavior from the + validation errors controls such as and + . + + + This allows users to change how validation errors are rendered by simply pluggin in + appropriate renderer implementation into the validation errors controls using + Spring.NET dependency injection. + + + Aleksandar Seovic + + + + Renders validation errors using specified . + + Web form instance. + An HTML writer to use. + The list of validation errors. + + + + Renders validation errors using specified . + + Web form instance. + An HTML writer to use. + The list of validation errors. + + + + Gets or sets the name of the CSS class that should be used. + + + The name of the CSS class that should be used + + + + + Implementation of that renders + validation errors within a div element, using breaks between the + errors. + + + This renderer's behavior is consistent with standard ASP.NET behavior of + the validation summary, and is used as default renderer for Spring.NET + control. + + Aleksandar Seovic + + + + Renders validation errors using specified . + + Web form instance. + An HTML writer to use. + The list of validation errors. + + + + Implementation of that + displays an error image to let user know there is an error, and + tooltip to display actual error messages. + + + + This renderer's behavior is similar to Windows Forms error provider. + + + Aleksandar Seovic + + + + Renders validation errors using specified . + + Web form instance. + An HTML writer to use. + The list of validation errors. + + + + Gets or sets the name of the image file to use as an error icon. + + + + Image name should be relative to the value of the + property, and should not use leading path separator. + + + The name of the image file to use as an error icon. + + + + Implementation of that renders + validation errors within a span element, using breaks between the + errors. + + + This renderer's behavior is consistent with standard ASP.NET behavior of + the control validators, and is used as the default renderer for Spring.NET + control. + + Aleksandar Seovic + + + + Renders validation errors using specified . + + Web form instance. + An HTML writer to use. + The list of validation errors. + + + + Convinience implementation of the wizard-like page controller. + + +

+ Wizard steps are encapsulated within custom user controls. Wizard + controller takes care of navigation through steps and loading of the + appropriate user control. +

+

+ Developer implementing wizard needs to inherit from this class and implement + abstract, read-only StepPanel property that will be used as a container + for the wizard steps. Navigation event handlers should call Previous and Next methods + from this class to change current step. +

+
+ Aleksandar Seovic +
+ + + Represents an .aspx file, also known as a Web Forms page, requested from a + server that hosts an ASP.NET Web application. + + +

+ The Page class is associated with files that have an .aspx extension. + These files are compiled at run time as Page objects and cached in server memory. +

+

+ This class extends and adds support for master + pages similar to upcoming ASP.Net 2.0 master pages feature. +

+

+ It also adds support for automatic localization using local page resource file, and + simplifies access to global resources (resources from the message source for the + application context). +

+
+ Aleksandar Seovic +
+ + + Abstracts access to properties required for + handling validation and error rendering + + Erich Eichinger + + + + Gets the MessageSource to be used for + resolving error ids into messages + + + + + Gets the list of validation errors kept by this container. + + + + + Creates and initializes the new page instance. + + + Calls . + + + + + Initializes Spring.NET page internals and raises the PreInit event. + + The instance containing the event data. + + + + Initializes the culture. + + + + + Initializes data model and controls. + + + + + Raises the event after page initialization. + + + + + Raises the PreLoadViewState event for + this page and all contained controls. + + + + + Recursively raises PreLoadViewState event. + + + + + Overridden to add support for + + + If necessary override instead of this method. + + + + + If ViewState is disabled, calls recursively for all controls. + + + If ViewState is disabled, DropDownLists etc. might not fire "Changed" events. + + + + + Calls recursively for all controls. + + + + + Recursively calls for all controls. + + + + + If necessary override this method instead of + + + + + Initializes dialog result and unbinds data from the controls + into a data model. + + Event arguments. + + + + Binds data from the data model into controls and raises + PreRender event afterwards. + + Event arguments. + + + + Raises InitializeControls event. + + Event arguments. + + + + Obtains a object from a user control file + and injects dependencies according to Spring config file. + + The virtual path to a user control file. + + Returns the specified object, with dependencies injected. + + + + + Obtains a object by type + and injects dependencies according to Spring config file. + + The type of a user control. + parameters to pass to the control + + Returns the specified object, with dependencies injected. + + + + + Retrieves data model from a persistence store. + + + The default implementation uses to store and retrieve + the model for the current + + + + + Saves data model to a persistence store. + + + The default implementation uses to store and retrieve + the model for the current + + + + + Initializes data model when the page is first loaded. + + + This method should be overriden by the developer + in order to initialize data model for the page. + + + + + Loads the saved data model on postback. + + + This method should be overriden by the developer + in order to load data model for the page. + + + + + Returns a model object that should be saved. + + + This method should be overriden by the developer + in order to save data model for the page. + + + A model object that should be saved. + + + + + Stores the controller to be returned by property. + + + The default implementation uses a field to store the reference. Derived classes may override this behaviour + but must ensure to also change the behaviour of accordingly. + + Controller for the page. + + + + Returns the controller stored by . + + + The default implementation uses a field to retrieve the reference. Derived classes may override this behaviour + but must ensure to also change the behaviour of accordingly. + + + The controller for this page. + + If no controller is set, a reference to the page itself is returned. + + + + + + Registers single CSS style with the page. + + Style name. + Style definition. + + + + Returns True if specified style is registered, False otherwise. + + Style name. + True if specified style is registered, False otherwise. + + + + Registers CSS file with the page. + + Style file key. + Style file name. + + + + Returns True if specified style file is registered, False otherwise. + + Style file key. + True if specified style file is registered, False otherwise. + + + + Registers script block that should be rendered within the head HTML element. + + Script key. + Script text. + + + + Registers script block that should be rendered within the head HTML element. + + Script key. + Script language. + Script text. + + + + Registers script block that should be rendered within the head HTML element. + + Script key. + Script language MIME type. + Script text. + + + + Registers script file that should be referenced within the head HTML element. + + Script key. + Script file name. + + + + Registers script file that should be referenced within the head HTML element. + + Script key. + Script language. + Script file name. + + + + Registers script file that should be referenced within the head HTML element. + + Script key. + Script language MIME type. + Script file name. + + + + Registers script block that should be rendered within the head HTML element. + + Script key. + Element ID of the event source. + Name of the event to handle. + Script text. + + + + Registers script block that should be rendered within the head HTML element. + + Script key. + Script language. + Element ID of the event source. + Name of the event to handle. + Script text. + + + + Registers script block that should be rendered within the head HTML element. + + Script key. + The scripting language's MIME type. + Element ID of the event source. + Name of the event to handle. + Script text. + + + + Returns True if specified head script is registered, False otherwise. + + Script key. + True if specified head script is registered, False otherwise. + + + + Ensure, that is set to a valid instance. + + + If is not already set, creates and sets a new instance.
+ Override this method if you don't want to inject a navigator, but need a different default. +
+
+ + + Redirects user to a URL mapped to specified result name. + + Result name. + + + + Redirects user to a URL mapped to specified result name. + + Name of the result. + The context to use for evaluating the SpEL expression in the Result. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + A redirect url string. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + The context to use for evaluating the SpEL expression in the Result + A redirect url string. + + + + Instructs any validation controls included on the page to validate their assigned information. + + + + + + Instructs the validation controls in the specified validation group to validate their assigned information. + + + The validation group name of the controls to validate. + + + + Evaluates specified validators and returns True if all of them are valid. + + +

+ Each validator can itself represent a collection of other validators if it is + an instance of or one of its derived types. +

+

+ Please see the Validation Framework section in the documentation for more info. +

+
+ Object to validate. + Validators to evaluate. + + True if all of the specified validators are valid, False otherwise. + +
+ + + Creates the validator parameters. + + + + This method can be overriden if you want to pass additional parameters + to the validation framework, but you should make sure that you call + this base implementation in order to add page, session, application, + request, response and context to the variables collection. + + + + Dictionary containing parameters that should be passed to + the data validation framework. + + + + + Initializes the data bindings. + + + + + Returns the key to be used for looking up a cached + BindingManager instance in . + + a unique key identifying the instance in the dictionary. + + + + Creates a new instance. + + + This factory method is called if no could be found in + using the key returned by .
+
+ +
+ a instance to be used for DataBinding +
+ + + Initializes binding manager and data bindings if necessary. + + + + + Raises the event. + + + + + Bind data from model to form. + + + + + Unbind data from form to model. + + + + + Raises DataBound event. + + Event arguments. + + + + Raises DataBound event. + + Event arguments. + + + + Initializes local message source + + + + + Creates and returns local ResourceManager for this page. + + + + In ASP.NET 1.1, this method loads local resources from the web application assembly. + + + However, in ASP.NET 2.0, local resources are compiled into a dynamic assembly, + so we need to find that assembly and load the resources from it. + + + Local ResourceManager instance. + + + + Returns message for the specified resource name. + + Resource name. + Message text. + + + + Returns message for the specified resource name. + + Resource name. + Message arguments that will be used to format return value. + Formatted message text. + + + + Returns resource object for the specified resource name. + + Resource name. + Resource object. + + + + Raises UserLocaleChanged event. + + Event arguments. + + + + Creates a key for shared state, taking into account whether + this page belongs to a process or not. + + Key suffix + Generated unique shared state key. + + + + Injects dependencies into control before adding it. + + + + + PreLoadViewState event. + + + + This event is raised if is true + immediately before state is restored from ViewState. + + + NOTE: Different from , this event + will also be raised if the control has no ViewState or ViewState is disabled. + + + + + + This event is raised before Init event and should be used to initialize + controls as necessary. + + + + + Set the strategy for storing model + instances between requests. + + + By default the strategy is used. + + + + + Gets or sets controller for the page. + + + + Application pages should shadow this property and change its type + in order to make calls to controller within the page as simple as possible. + + + If external controller is not specified, page will serve as its own controller, + which will allow data binding to work properly. + + + Controller for the page. Defaults to the page itself. + + + + Returns a thread-safe dictionary that contains state that is shared by + all instances of this page. + + + + + Overrides the default PreviousPage property to return an instance of , + and to work properly during server-side transfers and executes. + + + + + Publish associated with this page for convenient usage in Binding Expressions + + + + + Gets the master page that determines the overall look of the page. + + + + + Returns true if page uses master page, false otherwise. + + + + + Gets a dictionary of registered styles. + + Registered styles. + + + + Gets a dictionary of registered style files. + + Registered style files. + + + + Gets a dictionary of registered head scripts. + + Registered head scripts. + + + + Gets or sets the CSS root. + + The CSS root. + + + + Gets or sets the scripts root. + + The scripts root. + + + + Gets or sets the images root. + + The images root. + + + + Gets/Sets the navigator to be used for handling calls. + + + + + Gets or sets map of result names to target URLs + + + Using requires to implement . + + + + + A convenience, case-insensitive table that may be used to e.g. pass data into SpEL expressions"/>. + + + By default, e.g. passes the control instance into an expression. Using + is an easy way to pass additional parameters into the expression + + This example shows how to pass an arbitrary value 'age' into a result expression. + + // config: + + <property Name="Results"> + <dictionary> + <entry key="ok_clicked" value="redirect:~/ShowResult.aspx?age=%{Args['age']}" /> + </dictionary> + </property> + + // code: + + void OnOkClicked(object sender, EventArgs e) + { + Args["result"] = txtAge.Text; + SetResult("ok_clicked"); + } + + + + + + + Gets or sets the validation errors container. + + The validation errors container. + + + + Expose BindingManager via IDataBound interface + + + + + Gets the binding manager. + + The binding manager. + + + + This event is raised after as been initialized. + + + + + This event is raised after all controls have been populated with values + from the data model. + + + + + This event is raised after data model has been populated with values from + web controls. + + + + + Gets or sets the that this + object runs in. + + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Gets or sets the localizer. + + The localizer. + + + + Gets or sets the culture resolver. + + The culture resolver. + + + + Gets or sets the local message source. + + The local message source. + + + + Gets or sets user's culture + + + + + This event is raised when the value of UserLocale property changes. + + + + + Holds default ApplicationContext instance to be used during DI. + + + + + Moves to the previous step in the list, if one exists. + + + + + Moves to the next step in the list, if one exists. + + + + + Initializes wizard steps. + + Event arguments. + + + + + + + + + + Loads new step into a step panel if step has changed. + + Event arguments. + + + + Initializes all the steps. + + List of step control names. + List of step control instances. + + + + Loads step control. + + + + + Gets or sets a list of user controls representing wizard steps. + + + + + Gets or sets current step using step index. + + + + + Returns true if there are no steps before the current step. + + + + + Returns true if there are no steps after the current step. + + + + + Panel that should serve as a container for wizard steps. + + + + + Specifies that page should be treated as a dialog, meaning that after processing + is over user should return to the referring page. + + +

+ Pages marked with this attribute will have "close" result predefined. +

+

+ Developers should call SetResult("close") from the event handler + in order to return control back to the calling page. +

+
+ Aleksandar Seovic +
+ + + Abstracts storage strategy for storing model instances between requests. + All storage providers participating in UI model management must implement this interface. + + + Erich Eichinger + + + + Load the model for the specified control context. + + the control context. + the model for the specified control context. + + + + Save the specified model object. + + the control context. + the model to save. + + + + Spring.NET Master Page implementation for ASP.NET 2.0 + + Aleksandar Seovic + + + + Initialize a new MasterPage instance. + + + + + Initializes user control. + + + + + Binds data from the data model into controls and raises + PreRender event afterwards. + + Event arguments. + + + + Raises InitializeControls event. + + Event arguments. + + + + Obtains a object from a user control file + and injects dependencies according to Spring config file. + + The virtual path to a user control file. + + Returns the specified object, with dependencies injected. + + + + + Obtains a object by type + and injects dependencies according to Spring config file. + + The type of a user control. + parameters to pass to the control + + Returns the specified object, with dependencies injected. + + + + + Raises DataBound event. + + Event arguments. + + + + Raises DataBound event. + + Event arguments. + + + + Initializes local message source + + + + + Creates and returns local ResourceManager for this page. + + + + In ASP.NET 1.1, this method loads local resources from the web application assembly. + + + However, in ASP.NET 2.0, local resources are compiled into the dynamic assembly, + so we need to find that assembly instead and load the resources from it. + + + Local ResourceManager instance. + + + + Returns message for the specified resource name. + + Resource name. + Message text. + + + + Returns message for the specified resource name. + + Resource name. + Message arguments that will be used to format return value. + Formatted message text. + + + + Returns resource object for the specified resource name. + + Resource name. + Resource object. + + + + Ensure, that is set to a valid instance. + + + If is not already set, creates and sets a new instance.
+ Override this method if you don't want to inject a navigator, but need a different default. +
+
+ + + Redirects user to a URL mapped to specified result name. + + Result name. + + + + Redirects user to a URL mapped to specified result name. + + Name of the result. + The context to use for evaluating the SpEL expression in the Result. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + A redirect url string. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + The context to use for evaluating the SpEL expression in the Result + A redirect url string. + + + + Evaluates specified validators and returns True if all of them are valid. + + +

+ Each validator can itself represent a collection of other validators if it is + an instance of or one of its derived types. +

+

+ Please see the Validation Framework section in the documentation for more info. +

+
+ Object to validate. + Validators to evaluate. + + True if all of the specified validators are valid, False otherwise. + +
+ + + Creates the validator parameters. + + + + This method can be overriden if you want to pass additional parameters + to the validation framework, but you should make sure that you call + this base implementation in order to add page, session, application, + request, response and context to the variables collection. + + + + Dictionary containing parameters that should be passed to + the data validation framework. + + + + + Injects dependencies before adding the control. + + + + + This event is raised before Load event and should be used to initialize + controls as necessary. + + + + + This event is raised after all controls have been populated with values + from the data model. + + + + + This event is raised after data model has been populated with values from + web controls. + + + + + Gets or sets the that this + object runs in. + + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Gets or sets the localizer. + + The localizer. + + + + Gets or sets the local message source. + + The local message source. + + + + Gets or sets user's culture + + + + + Gets/Sets the navigator to be used for handling calls. + + + + + Gets or sets map of result names to target URLs + + + Using requires to implement . + + + + + A convenience, case-insensitive table that may be used to e.g. pass data into SpEL expressions"/>. + + + By default, e.g. passes the control instance into an expression. Using + is an easy way to pass additional parameters into the expression + + // config: + + <property Name="Results"> + <dictionary> + <entry key="ok_clicked" value="redirect:~/ShowResult.aspx?result=%{Args['result']}" /> + </dictionary> + </property> + + // code: + + void OnOkClicked(object sender, EventArgs e) + { + Args["result"] = txtUserInput.Text; + SetResult("ok_clicked"); + } + + + + + + Gets the validation errors container. + + The validation errors container. + + + + Overrides Page property to return + instead of . + + + + + Holds the default ApplicationContext to be used during DI. + + + + + implements -based storage for + UI model management. + + Erich Eichinger + + + + Load the model for the specified control context. + + + The key used for loading the model from the session dictionary is obtained by calling + + the control context. + the model for the specified control context. + + + + + Save the specified model object to session. + + + The key used for storing the model into the session dictionary is obtained by calling + + the control context. + the model to save. + + + + + Create the key to be used for accessing the dictionary. + + + + + + + Abstracts session access for unit testing. + + + + + Abstracts session access for unit testing. + + + + + Extends standard .Net user control by adding data binding and localization functionality. + + Aleksandar Seovic + + + + Initialize a new UserControl instance. + + + + + Initializes user control. + + + + + Raises the event after page initialization. + + + + + This method is called during a postback if this control has been visible when being rendered to the client. + + + If the controls has been visible when being rendering to the client, + has been called during + + true if the server control's state changes as a result of the post back; otherwise false. + + + + This method is called during a postback if this control has been visible when being rendered to the client. + + true if the server control's state changes as a result of the post back; otherwise false. + + + + When implemented by a class, signals the server control object to notify the + ASP.NET application that the state of the control has changed. + + + + + When implemented by a class, signals the server control object to notify the + ASP.NET application that the state of the control has changed. + + + + + First unbinds data from the controls into a data model and + then raises Load event in order to execute all associated handlers. + + Event arguments. + + + + Binds data from the data model into controls and raises + PreRender event afterwards. + + Event arguments. + + + + Raises InitializeControls event. + + Event arguments. + + + + Obtains a object from a user control file + and injects dependencies according to Spring config file. + + The virtual path to a user control file. + + Returns the specified object, with dependencies injected. + + + + + Obtains a object by type + and injects dependencies according to Spring config file. + + The type of a user control. + parameters to pass to the control + + Returns the specified object, with dependencies injected. + + + + + Retrieves data model from a persistence store. + + + The default implementation uses to store and retrieve + the model for the current + + + + + Saves data model to a persistence store. + + + The default implementation uses to store and retrieve + the model for the current + + + + + Initializes data model when the page is first loaded. + + + This method should be overriden by the developer + in order to initialize data model for the page. + + + + + Loads the saved data model on postback. + + + This method should be overriden by the developer + in order to load data model for the page. + + + + + Returns a model object that should be saved. + + + This method should be overriden by the developer + in order to save data model for the page. + + + A model object that should be saved. + + + + + Stores the controller to be returned by property. + + + The default implementation uses a field to store the reference. Derived classes may override this behaviour + but must ensure to also change the behaviour of accordingly. + + Controller for the control. + + + + Returns the controller stored by . + + + + The default implementation uses a field to retrieve the reference. + + + If external controller is not specified, control will serve as its own controller, + which will allow data binding to work properly. + + + You may override this method e.g. to return in order to + have your control bind to the same controller as your page. When overriding this behaviour, derived classes + must ensure to also change the behaviour of accordingly. + + + + The controller for this control. + If no controller is set, a reference to the control itself is returned. + + + + + Ensure, that is set to a valid instance. + + + If is not already set, creates and sets a new instance.
+ Override this method if you don't want to inject a navigator, but need a different default. +
+
+ + + Redirects user to a URL mapped to specified result name. + + Result name. + + + + Redirects user to a URL mapped to specified result name. + + Name of the result. + The context to use for evaluating the SpEL expression in the Result. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + A redirect url string. + + + + Returns a redirect url string that points to the + defined by this + result evaluated using this Page for expression + + Name of the result. + The context to use for evaluating the SpEL expression in the Result + A redirect url string. + + + + Evaluates specified validators and returns True if all of them are valid. + + +

+ Each validator can itself represent a collection of other validators if it is + an instance of or one of its derived types. +

+

+ Please see the Validation Framework section in the documentation for more info. +

+
+ Object to validate. + Validators to evaluate. + + True if all of the specified validators are valid, False otherwise. + +
+ + + Creates the validator parameters. + + + + This method can be overriden if you want to pass additional parameters + to the validation framework, but you should make sure that you call + this base implementation in order to add page, session, application, + request, response and context to the variables collection. + + + + Dictionary containing parameters that should be passed to + the data validation framework. + + + + + Initializes the data bindings. + + + + + Returns the key to be used for looking up a cached + BindingManager instance in . + + a unique key identifying the instance in the dictionary. + + + + Creates a new instance. + + + This factory method is called if no could be found in + using the key returned by .
+
+ +
+ a instance to be used for DataBinding +
+ + + Initializes binding manager and data bindings if necessary. + + + + + Raises the event. + + + + + Bind data from model to form. + + + + + Unbind data from form to model. + + + + + Raises DataBound event. + + Event arguments. + + + + Raises DataBound event. + + Event arguments. + + + + Initializes local message source + + + + + Creates and returns local ResourceManager for this page. + + + + In ASP.NET 1.1, this method loads local resources from the web application assembly. + + + However, in ASP.NET 2.0, local resources are compiled into the dynamic assembly, + so we need to find that assembly instead and load the resources from it. + + + Local ResourceManager instance. + + + + Returns message for the specified resource name. + + Resource name. + Message text. + + + + Returns message for the specified resource name. + + Resource name. + Message arguments that will be used to format return value. + Formatted message text. + + + + Returns resource object for the specified resource name. + + Resource name. + Resource object. + + + + Creates a key for shared state, taking into account whether + this page belongs to a process or not. + + Key suffix + Generated unique shared state key. + + + + Injects dependencies into control before adding it. + + + + + PreLoadViewState event. + + + + This event is raised if is true + immediately before state is restored from ViewState. + + + NOTE: Different from , this event will always be raised! + + + + + + This event is raised before Load event and should be used to initialize + controls as necessary. + + + + + Set the strategy for storing model + instances between requests. + + + By default the strategy is used. + + + + + Gets or sets controller for the control. + + + + Internally calls are delegated to and . + + + Controller for the control. + + + + Returns a thread-safe dictionary that contains state that is shared by + all instances of this control. + + + + + Gets/Sets the navigator to be used for handling calls. + + + + + Gets or sets map of result names to target URLs + + + Using requires to implement . + + + + + A convenience, case-insensitive table that may be used to e.g. pass data into SpEL expressions"/>. + + + By default, e.g. passes the control instance into an expression. Using + is an easy way to pass additional parameters into the expression + + // config: + + <property Name="Results"> + <dictionary> + <entry key="ok_clicked" value="redirect:~/ShowResult.aspx?result=%{Args['result']}" /> + </dictionary> + </property> + + // code: + + void OnOkClicked(object sender, EventArgs e) + { + Args["result"] = txtUserInput.Text; + SetResult("ok_clicked"); + } + + + + + + Gets or sets the validation errors container. + + The validation errors container. + + + + Gets the binding manager for this control. + + The binding manager. + + + + This event is raised after as been initialized. + + + + + This event is raised after all controls have been populated with values + from the data model. + + + + + This event is raised after data model has been populated with values from + web controls. + + + + + Gets or sets the that this + object runs in. + + + +

+ Normally this call will be used to initialize the object. +

+

+ Invoked after population of normal object properties but before an + init callback such as + 's + + or a custom init-method. Invoked after the setting of any + 's + + property. +

+
+ + In the case of application context initialization errors. + + + If thrown by any application context methods. + + +
+ + + Gets or sets the localizer. + + The localizer. + + + + Gets or sets the local message source. + + The local message source. + + + + Gets or sets user's culture + + + + + Overrides Page property to return + instead of . + + + + + Publish associated with this page for convenient usage in Binding Expressions + + + + + Holds the default ApplicationContext to be used during DI. + + + + diff --git a/Resources/Libraries/ZXing/zxing.dll b/Resources/Libraries/ZXing/zxing.dll new file mode 100644 index 0000000000000000000000000000000000000000..709a55abbbdc5994f4f424bf860c2cdb9398ee9f GIT binary patch literal 217088 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

6t)frv<+8ht~6Wpn9# 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/ZXing/zxing.pdb b/Resources/Libraries/ZXing/zxing.pdb new file mode 100644 index 0000000000000000000000000000000000000000..73a011568e8e2cc349c973be81353d1e83da7df7 GIT binary patch literal 796160 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%0DKI*5_}rG8hin~7W@^c@_!9pNBB43_27Si zH-di#H-UcvKM4L6ycv88{1EsysPzBiQFEOSbA2zU{0~47LcQNFIvE(D-t)({We)>y z2Zw-nfG2`?gQtU{n+o1Tcp7*wcrkb%c!`g%1Ro$=1wIH~3w{*ji~@UhvKib$*tMtL zVbETAJ>SqdvjgB#R#fLm3XMKOT?PCh=3Ck)Myh#C-m<6@AkpgYSjT4Z?Rb zZyE5T=UGRw_q8w2RDx5vCA4A*Z-ePMj-2D=Ov7Awp@nq@QFz|;8Su*>dadsR*thAv3Vwm`*FY!x6I1zhJcioKS8%;6l%ei=MkOzqNInD8dJibn z8$00dnbXPrc5HXPo^tix32H3-CU_Y5Ezt3yws-rH-{3m+@b|8{_dt4aZ5v*07wJ$T zd!M5>_&vgs*Y`omYd1I=l$>UO3=#Gm@F$?;^c*-J{5iM~{3UokNdL2EvHu1-zAj3Y zV0oPG4T3_ps}H_sgxWiulf`6c-2GxYx$o@4wXsT!qYoSJ{|OEx{4(guYDwg&`n&tL zbaF2k*Z;qK9)ARfLHj3g7KrSUGkum2#!lF|P;Y{l68$I}N>C0H2gxSZ<;dcIj0o|y2yi-vLcRq5njO+4;UgW*cjuKuN<>eK_2E*uCR z0UiVn0mb78kh4gvO?fBX#s%JOHoM##9PjBSfY`8Xg%3*~v1QigWuWTb7gSyQfsG)0 zlI^{_0brK!Kv4Es<$ee}k}x(ibrg6PsPmYxd8u*`n`d4 zc6~Uw2OI(Z4CDxd?2F)W;D3QShY9)H`Abgb>U-K_BD>g^m>~B_^gK6T(6t`^?Niq# z^N1^lUVZZvyxz;(S6WFn?sCH!xv1j*ZfFlW?2_6Sd0mpz-!EqpCi?weBcpBjup!)Jm zP8~)1Mot^KLmB|j`U#}_%o2P)6VVD zIY%!NRz5F*m4vYo_I=aegVluT=XSnPHw3t+;MjGcOM`Uk^tSo=(oND1Zb+L1g;L*N=x(391o1t;~ zU^or>)erqT4BrRe8-IwQ)79gkmDkyjvMciXcK6}TAf+uKkAb9-FSBbJw@XPU=iVDV z#8B7eT>L2eyD&aKk0VJTuWv@`-Bekkkly|6(rf;3C|-3ag-5;FdNMO+SBBf?p}ii9 z5<4i}aQBGm?+UtC`PjpzPco z;5p!(U%`C{1SXUUW3g&_{Z?O@Gs)u#+Pqo zFD8B|z8QZDek=Yd{0n#uiv96Z@JsQV@LTY^@Gs&^Zoq!y$KszjfU^P_T=Wl{V{Q_^ zk8)k^WZ2MUu9>}(yoVA-_Ss?Jsh~zXWN&k>Gr?(uMK=?iLUjBlo@LxQ=%8*EYlhj4e3aV=K%?rgzw)t`HyF+T5;5)ZY z<<>vd&y-GmcMp|weJXAJi%T|(+@(t6M$&gR799(A2N_|_CNj#|oNP2GlP;T~G2(c_ z8k@#|^Za$$z!L~#k8BTl6*!LYavxs?dCqfYB3#<%(^~~P9ppg9aZ?Va);OVcX%6(q3aK!1i~k;cKC~- z4!?;wb^Ulcuy863DIB!Oq3l=~177EEIao*>eZKT1?d+#{Ovh1%b!MQI5NWKsLE*HZG59S<^n z+m{i`6nk0PHUnO)TKlDbZ)G1&qM-`;T_g35)uykn>egq>EOU) zL)H4_nW@dq89ljiZLhgvJ?WGt&;>r}i!q-} zO**9sbm9~CvG>LKly1L3x(d>r3tg?xUvmf*noGC;?-7SK(3l`Q?fOsgXG)lqtoR)X zQg-ydnAVTnyI!-o?({YtDn*>j8?dpx8#takWGgA(o~uj%yD&mKTb;i?>h!NTPw0p7 zg#3*sjqxsz+?v!j%5l1pPIOCp{QzE$dRrdokd1K~iw@^HCfMHPnF0#(m~I z%zfRO({zw}*!Yi`wDDiEoXK^^3o{O!8;><=hVew-9@g1ETF2;WbyquR-NorhI?*xl zQ!e4-!q_~Q{22y}uO6VrYPHKeQ1uhP2ZI_THJWLx9^tQxe})uWOIrXUN23>~3kj

;SpU%~4^SbzLj{5*UO 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

j&t01W8mUJJQ}zvD;lwq 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/fastJSON/fastJSON-SL.dll b/Resources/Libraries/fastJSON/fastJSON-SL.dll new file mode 100644 index 0000000000000000000000000000000000000000..50b6c6af69fbd4c6ab46183b34a089165121bb26 GIT binary patch literal 23552 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 D(ZE^T literal 0 HcmV?d00001 diff --git a/Resources/Libraries/fastJSON/fastJSON-SL.pdb b/Resources/Libraries/fastJSON/fastJSON-SL.pdb new file mode 100644 index 0000000000000000000000000000000000000000..bd845c61f741e956d273e2b780a9c0675ae826a2 GIT binary patch literal 48640 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/fastJSON/fastJSON.dll b/Resources/Libraries/fastJSON/fastJSON.dll new file mode 100644 index 0000000000000000000000000000000000000000..b7ee2f3dd95813e6eba2131d8b2e2f0d555d3618 GIT binary patch literal 30208 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 HXa9cz*(_x( literal 0 HcmV?d00001 diff --git a/Resources/Libraries/fastJSON/fastJSON.pdb b/Resources/Libraries/fastJSON/fastJSON.pdb new file mode 100644 index 0000000000000000000000000000000000000000..1405a0be8bd9d495a7952d4ecd1b621d082bb593 GIT binary patch literal 56832 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%0DV!Oknd{SPJ6ZyXl=-t*{RQIv-;+ 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

S0f0vVz#;(P0083vKo|g&1Ax&0U^oD% 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

@EuQ94Kw&I1p3}qDhMy8Ai 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

2JU)&<{=nlJyyIzHcf$l~>;zU^!6w%FVf81Sky@ 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

JJ|iNJUPv%Ck7`oa<;b?vT> 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∈A4GYj130X`T`d-P@C88veKKJ~vL! z-^iYs>}82KGM1oQM;J6^n&Hh1s{7~*Fm)1GGX|6GI8%Rfd5y=>t@e9xW_;idxd?Md z((yQFzdes0ZLyNRhfq6&qsRPci-9>=^VNqNY;n9&kHmnBw09)?LKtpbh#@4}$ao87 zVNX%VMvTHTHl`Wug}lv7Fesq%BV_Xf zsM~ru&i18P>trvs2Zf;AA^erg4W7`;k%yy{6og8+;1EV_7{p9LqJJv^2eqkB%N&Ep z0vRV|PBGye(i-*|&u(=*6sK%EFqq244$Kw?PIbRN`{4&$mF^))HV1%`$N|P#zm~x9 zwhzgIPBXtlvYVwiG_a+tQFVfr* zLYaI32{9FViEVIfO^ep{pocBEB}wfIpEWaBBb@Z**{w}<+HfYlL)vK*Co4Lb#~n2a zVi?2R9itU`$_0lE=LN%a_AujbE{-`Ni#M3LyLgmD7>bW$B|3bMACvmQV|&L?(H?6LfFf@V#GY*=$o6way9 z9-p?BV3d1XNVE@gx*_*uFO&=DL*mu~hLZzXFJP2El8q3e zsC(md=fOj?XxUnJ!TRcNPc+7TxxRV*2Jfx(ozOklS{B5Ivg^`!DE6TARP0eKpC{Ws zdzi%~_9wxP;Awm2;*5Q`*+Zhr1yle;I;<=n5)$kWW`hLpFi-m+PxMfUJcqciB7l=b zkQqKpex}@jHJR`tU=N#ei5Y&bUxSeb`r0X`wen~*6}Tjc+gh(J_q&Cm;lyswrKR?* ztc{>~nf=9#M&`J=gm&MaDdhFp9(+A9V|c}bQH+gn~nwSaG1(q3;&b{#{%~Hh7|Dqhm>tb{(LW*wxiaQ-K>bvv78-I%N^r@8w-4& zM3*Os@IqL9E&J<>pDtdjMYgh>gz1nA4`i;}Lb|k|=O5{(IIk=+uc3xPIz2no>O=rl# z61B4b6C>tW>O~(kk~H$jWva6m+3c)=rPH5L_HRzyk`?cwm0pqQsfo4m{UuTrTpV87 z!2crsjBPwjlJsX6YybUR?_HB7^f60%Br;atp32(2s;yVxZdTk!9Nv@XW>fvX>L*~N z5PH@2>=7f8rN@>Y(j2CXaU|20c?&VL`W9gxTF3g&x{G)QYWohWsCqm~j){eMZ+=EG zHe&Cbi_mT8kZI1^+_KWJ2ddmB*n2MX^RZ8|ebRcBpB;?7`YikqGvHwlQ%hTVE=C$u|1MNgPOwoy6Fi^dlEJHJr^6V|jtHx{w`;ldO<2dK;IU(c^_ z^r^ASCh{Q`$;W-dJy!lKysteFI>H0i6O86_yL~y@4YN!&TY4fmHp1_`OTT#kaGeUz zhV<^9l~x>MQx7Qke8gGD-c3l~w^d_KJJ$UwP0%%+%gz;Vua0H@mOZLJA6k3V^S9SG zx*LVn1;%i+6En%N`X?l=%u?F}MT{@YZ1XH4NbQZ)?>c_I32xCocGKi3;F|w+=u`K! z+Znd?eC-8wpU1m(|MkN}#fkc&YE)1=L?Sy37uPo}CS^i*44Tz z(L4x#_qw%~9>kK>nU7_$G94b?eYm{4cz^k^bzUC$$nGSjQE~og?7Lk~$T~VgM6V|} z&%n9K@QkqL2sw* zP(aQ)An@cE+&nB^-dz89e$^kT!2dAC#G?wC3gPd((9QV|7xDzcc2a-WZ0^elRvGLh z!NTF!@%mLx`2BRtI^o}b!1YM|0Y}>dMF_UNaNl(wjqxzjO?TOKVBqrH4$G_s#7)CZEZ}`SK*F3z_P4C~aD)@|t z^fskz`2yLj?<0-UrfV-nNthqEIglQF^zD+d*j%9Lp2dY2x=6W7Q6lGh_(` z@#9(U*v1Q5*tLgiQY4?S8H+p!+qJO>4zhNn2PyaUu?sG^5Fy;umo{znyYxM~OTB5e zO@4Mxb^S9FZiJ>F*<|nM6GmyDgtR`a@61c~9-f-OLSbi@{DoL4;VX`vY1M8bYW%)_ z*fmziXF5!31OxKXdhmHN3~??umhtO7k{4vS-?iTV{QUAxPvx}p6!6j`d5AJ~Y&;jS z32r(iv7RO3%y62);i**H?!{i|ju~9?RhD|`uJ1myc>}x?>p0on-?d#~A4Lf(h~q6C zJHG=ah1!-W%Iw|-d`J=9hAXsigcx0~2<*E%(u7UHkJC}_F(ldq8E0~DFfQs&D>eb| z9pVWJHnNZ8S^3n6-*DnoPnU@ndbT5Rp553}eBDyOF3Q^IUyn;o8RBK%A|LA<#d#DF z-Z%Nz3GMFY>^0uIzR{CNm^bXB)vjH*VL9y^^JOZOq-c-EnR^f_veu#yIq=~Qrp~R zXG}dC-NZAl%-Pln<GaS*OjiSI+bm35)cv(x#*DqqOPs9nvQ(o6VuH zS+w+!SaHjHZSuTa2JgLo*k^3!t8psXpRX==OYB?J(kIR8J2%JEw>O&ONyk;NiXCAY08$)Y}PWP@286U>dGM-F!O~BEs7(S65 z?%_bDoOnE3+9iDhP#WT)zhyT#+tnR z{K+j|wZHn|pC1C0a+l{9cOP!fq?A%V`Nw~F^ZLyvZ^4fG;U}Nq9mcEI|NPa}zy05@ zE?V_peE!AeN}9saQM@0Hf$18hY*Xa!?b%f;cK*wI97sKX{m=jLzy8M!j+ETu^cgt+ z@gLs*M)gmp)k~>cxftM=oAWo+ua1cb^P+#i|NU?O`%Uijz;CJ37Am@;A#=4!S#MTZ*a+K|t2K@VP6WIHW z+XVin8&Z{rvzKSMMZs5V*KanDE)Xyu-=E+66HaGt9(=jMS)u=eXFL~ox0~A!FK@9? zf(Pa2w{pXTUper*uOm3h*AcWE72-OAlYP`l*Ad_VFaW)dU{BmduOm1S-)I+XP%0|d z5l9mKJ=YQJxASR_H*_6=9M8Qc12hBG- zp$$`6nbAd$r0cjH;24k8rAPS|0xZwl?6>U&bg?mVNfB356FZLi;!)}WT9-hGX0Y{_ z%H&H3a2^U%uVZ{X3j<^CnxDw?c3PQe2V;6GBi*hbl!N~liGY75T=1Ldqj`7*l&?pfqDqG3zOJ%{QzbR za#C1&FSjBXznRJzX6V;H6`PnocqEZz=5#f3ORT z#emrL1k(v(HoMA8%)+d94q&rb-j9)J=u(m-OPUx5>pb=vCB}}i<3g-vA6JoHJ79@KGEUfB_Uv2MF$+D_THCW647X7yf;p-E zFO9L)iNHUWGd11i`x{B-oX@nU6xd*8OeR_dDNL5 z9-f*y`a&5siyq_9GRb5{ay@;ktP+@LI(f3}b4X85E$qK*tk|Of=cx?f-Jp`th0`nj zt5zzbcY7WajDwZFZ;XgNVPwnq3kS@X^uhsg_#AEiPLVtOc;5hehJ9(g+=gX;^jEev zrN5q#^K}E$fg1^?6&V_e$xw3(X-USFE-;4ZR!oj+v`jc$HX!fcLFw{378Npc`d~EN zH6THX=afRNHw}3I+LW-rrMN}#w<#e;-0)d6terCh>oZNgSPEUj5GJEg^I9yW8mo6n zZyJ#O9n1jQFb(}Er*S`MOdLuOuQ)}t8WrUx?Zqu!fI-Q)C< zfi}+UVV9ISEkK=9FB!n++-+qmlRm1~Oz0i3XL}MS686Ms2J~v}#Z2j{On#ZuW7H-$ zddWcR>Tx@CVPc4cOaNbS5WT34dz?*dn7fH3gZ?($S zDE2N!UQedhgTFUknM*fjL_c@JjOAW&V->?G@Nk_O%~(D--YTO^?ZA7GD;>;r*Ld-~ zLU{M&9XYI-Zwc1-(T;9b(2MuTfZAKKFL7(k+YrPAhV3>!G~N7;hWls?KbOzD3Z^Jz$Y^ z05>Do!L%sZZMa&XO~El{MsDBw99+&{i7@G60c^|bY&dU@Y~?8|yN6#baIZbdkyj35 zl>T0&-{)le>eVON0OO#R8Jwwh~&{YiB8jI7k-@$ifT{e-80S4uHBrEF8Ax zVQnO&n+2p1tZ(I|F=`0yH_6?DeJ808p;#Kr2$~lJJ6p+m;SwftEE%wnQT{N}yLgS?Z zl2cCc_)hNI=z-+({}4^LCVKvD`!`Ud+_^|b7^m}eDg#3{R+f9s6Onz?H+&xNkryXx zP?PZQV{ktb4>x`bBj+C;CPVyINHSO7-wB$*<~jJF8LeI;0WA`wQqjXMNH*C<4H2*3)m^yXcheusds`soevJo|6rdita* z1lr06I+f+jp=`&ufYT8R-FJ;%>mpYaB;Chsih48d;ty8{pmuCzh@TRydNmX{z54>t!;k)^Nm#Q{yp^4t>JcoBjwNY`?hT@;4@$=>TpF}y37?+p+?#}h8u zHj34AO|tRaL0-j3>b?QlW8&o1JAd36K*13c2xoUC zl{*6@b>e^ytcUqP-^%r3J^PcjTlR;YtF3#VVunebs+rSOR4)y%jfA}O@161ikM0bh z=UqFx6?07PR-a_{`fW-u+!?UL1tTf+7a{P#UB4N`pT0b?hg>9+)e zJJ}Afz~}?97ja9_odG&*!xB}q2W_qXc*A!Fz~wNeV%R>$o?&)A*C^c?fGIvI26xSw z?n~v)0C}D#F_a(Zxdc5E4C@0`l@7m3`86 zhtiD!5~wl}&pZAuw|n_;VSt2@Jm0Aa?a;O(;=X`p=|fqil?ZiV`M!Ymct*C)PbP_` z+nPeU+q$N2>kHi%fNn^-m&bQC*5rJ@OkwH10PKuPBphNMFV_}j&-3o5`vPb@Dc0&< z)E7?SKQ-;`+oHT&7SNVWSZ&F3m%az%7V}QgT>-4pq9o_1y8^=B*4(iq4ertxpO&TD z0+6y~D-gq{Jl0B+fUch~Zz!lH3U^MvDL}kIGH;E1Ik6+w9WM$%vXF}cT5^G@=RL|7 z1*BP4-(emtKoIhAuG&_&`kl(k8r3qbd%FX0ZnXqF16<7ivq|)uq&2(@jt_hH5BXYa1Y;?;^W)Q(~o0$_)YSMUz9sOMQFQ&E+=)v;df| z0DJ&UHw5T2Z^R26s1698Udjyt*a~Sgp8QzZ&9#pXi-q}y0DV}xFS8^p8?v8z;PV9m zE%IeGmY({13odrLA3%mrl*ngc#u9WrK#V@cZeD-BA0P@W7nJt3aGBS7?vh+r7VR!F z-4D>8q*iXX1K$q-OY8O|M2-!qQCzwoVCPWY!ytxFj)G=2~_1aFdPK1F+a7_(#CHH#opClczz{O9!Q+6`|PMEehmL2%ICDGk3(k_mH z${y&h;ke!m;GWbbonr#_6v-C@w1F0WozH=dilvJIe6Ee5rE0c)kwDUse10um41j=c zBO9_()vhl`(!~I>2xv>5=>%G?HWv4|jC9{NjrZ}KX1xZe7Xye3%HBjv`D3=OA>b(=u!YaG*|chJ@kf40oq6*7ar}7 zyS}N!OYf4yBTn&78#c}RF&m9lEYGH~>Kd+>0&oH?@pNFbSGp7cL4>#GFpkZpP_8oj zo^qQQ__AZRgB7#1E8{e)*W}16vE(W(*8#}#UGl76 z471F$d4 zct#j*1c<3=N&KFh=|+IaIK^AtLHI@hXtGUY^UDjaPB(VB5dgMpMo33sdntRU7Z(Cx zX}xDJ$?UDWHEg3`LmY7}V^S&N{i6E-BAu75S)WPO`v9;m5;5{A(ou}zIsnMhZUcZR zWwnyvznxWGW$z9S*8%uV;_%2fb7fE-J;(_(%V zK$k-fw2hCRy7$IBAw0L(#HB7b0m#ZqY?9A6yMBG1KHLO=L7+|4+hS(yn46z30%#j_ z@=>PcDEs^F0ch{zetmv(g^$diL3jQ4)3XcQe}(T}$jiN7Km99Sy7~{Mt6r1NHOkd_q zkd7-1{U!DKITF@(+l8<_3}NTR$*RlP79kWTnHKKCIWZzr@WAkP^S^F#r@g_8K% z*uu!S5P3iB_8rchgd=?q;{70gZ!#q;tjBOW7pW%=lahYITQBmmxjO34Xl<|m`j~%N zW6Th31*&W*01UDUA}|auq2PFp2c@K-Fi4+uPyiUd2oI&E7%@oykVy=mM~e|d5#e7( zDsE%=DtL@s9mohJj0`Waq<9J_g>qCGW=5cJbHXCNl$?UhApKJ`xCl2ZwAP?)8P)oB zYtSF~)pB<9uoA{#)UM@-R4j$1LOC`K(?1-vMhI~!N|m+##%L<}2VV%YH-!%9gpY>@t;7&d$n!%9stY>@RbV$tw<3>z^NQOcDV zwjwJJG;)n$Ba|36yu`5LDTWowF>F|kVJ9qNSjj1d4O(b$5yMt!t-%_@R%EvZCoyd0 zY784;jA4ay3@esmSfL!lhM6iTPK^-a7TO|)wP1>2g;ESFlw#N*>&h6Y@!*@nn|wV5 zGUHZXL^BghNGD>AYa*xMW?bc<2xsCV%!wt%I^)G%nMnVpoKI+M>o4df{<-kVg_);j z0;ZO9z{HXhh?o)s;W;}np{9sLUE~SkNy&ooT_#wh4K5zR6xo;QyG*d0hjRrxO)#08 zbJ;Pe5G`jGBBb;}c+N3QFbz^NVQMI7&ag;1R7J`=gs0>~c*;PGTSp@eF){iX^p2%W z6sT1gc_>IF3lXX2piWE~DA1CBg0#p!ogw9(K#SW4iL^p_CFuQMQ)+Se&Ym~Yr-iGt zN9mGnf>d%%C#6i&(VS-ju33g?iyYHAQich1t>{H|iK6{qGhNlGNoQZ?mEhQ+=t)kA za$`p6l$=jGoU%zrb1n(kbVZ3GX#HQjD(T=Ni*$O*AstN_q@yW+1Ztg|WQXZIM&lqQ z4uhI7fMOV!l05V3}2)PrKTKVQ1M&C=h?xCU0dX_M$$hOUrj@-Sann* zlyqQt$pwn1M4(X40*2KT;Dkl|D>((fK?@Bo!rlt4HCO}QitN_lWG!Ol>RQAIV~{JH zBV4f*-U{W|Hq2B(fo+5kx6l?Ltp!s&E0ls+p%lpmSyv*A4Ue7#$(%0*v13+GM6nY} z7#I?~=U^})_=OVPd*ba5p;Pyhlq0UKod&wH#P8kE-@EqX=rVuwQ z$GC&06$)ghgy5C92y-i%;@q$l=!T_8cg#9e;(0n=o3>J{J7yI{tUIB^dMDIaH&Tjq z$4aa_VG-*_POnpMq&#`XBQ>+`7W8Fd13Wc*% zLhwpl#JUwtv2GY*{jfjTGYqj_F*j3Tj{ZcUmj6HMwSh=85YdkAnqFLb*%MDJE+>ji{3e_k!d=bNq znj%<{xzZNVt3{SdtC6b(b}DTWwOY#DnPOA%_TLfB@!D8Yv^FHiszN3|1*762|CUZb%x76|qjlNUU)5At>rIDL4(XN+LQ9FX8EUjZdYd05zyYsNstcRceY+ zgNnZyK95o(h9Y9{HByOF!&g3M?;p&7%yec^btU(J6 zE<)A{tu~iJ29d%a-ZRt zTR*_`>BdiCF~r?vJi5!Mb(f*+e@t;f7;`}wQ$afNx#+#8NBlCqGc@KoaIqlF8iFut zf-vOWWz4(Fn0A*D(>p@{^zCnoe^oU<39YfLOKs7TZ%@|bFV|dY#;d4b9 zF`AD48>y(w@TxZ>ROK0A)S$sdjfy8-DwGteP|~VFMYV>9kfh(6>$AJ;d9M_z`c=H@ zSMh~@l^9Kvew9@9tN28}N|@+Z2}QpOSN%3T>$gE!zYWUzRjBG$@es1>_X|;NKkJBJ zR+b@CC_}7E#-jyBO@j=%@)&cyF{UbG#I!}w8Iq|lKfc(UnFI`(1PrkRjE4k_ngk5F z1dO=^jHv{Sm;?m1X`ozZXQxcR*jy)>?6cV{CcpfZ@Tmay`cGmU28ht0zl)x@ZDL2A zw(nswmwm}51o;1zP$c@988;3D94kKoq4t>4BG`x=z z_+=6>#NA~)y343_m!WJ5rnn%CnJE~uUK50`@9nuszuwrTdI{2`o1u%FS0CQJxjg?R zmkvR=&bV?RRbuinr%S<@n}aYoeV;acy>X{!C}}#xiE|uD7fh)s^jNMMg^5}MGE=9q znOH(?bBoa%)nw^ZMG4+Sb)7A$cgLHPQ*?8+HP90^`AZMG#1eu>^d<)PmwE9VUW+PR z_66DfW!{4O%aocD2zR^Yl0;?2M64&4P|Sj%B%4$`D`ruJD`r7#vy+tlpQ29xkU`Ftd+Mke~QF=1o{s)u({ zs5J=PXXlSLo|qYm>H<}TBpD4Vf;v8zR;gKJ#gg0#W#J9eKdcoaM88QpN}KCKX-Odl z=^s**;n75>Minq`L20Q4gGvjAPg@{WCKIsFR*%b6s)HPrd9qQMl1#&dY@kFj0m&4J z9C9u=778UXvRau?mCMvrX@Mxl|M!sekvtInNvVEKaWJ@fDc<^96T3~b>KT)TreP;7q&zL57M#jO= zZW~Nus1Q{a!;3(M&!sZrOf(}E`3$c@8lg&Rgi&0Bi_Ge_NoIqz1ew(EBD3LhnTi0js4^R2l-b}aGlgW9oC#HardBO5b)gGpnQDX?s$Q5n(GHU*I%0Cs6cdZS z6iAvfsOZS>q8-EMdNJZmBStE^FuZEP2vvR~jFKCyf5O?Hq-=&?qojaFApuS013nQA z=qMGSA`q}53$Q^9AXNg4QhgKoNuOyZh|JEs7?#?n(dE7KCo<9OY4geEuc=myOvLH4 zPKHACKvkLSP_~^_)oiRq*M`p(Zp3Ih`fsG7dc&*!jZlqXgwYZP7jr0{Y+{h6Dbl~= zbL%KInMk2zCxw!+6iOB|NdJ%}4G#r|?MUOvfQ(yxp>-w}Q!dGuP-?a*RNWTLh^% zMUbdfa*3e#e@&^y9Xk6Y*9NV+LeNG>2ug8-PD)M?XmJ4|%^jdKB=dJP8NZ{+^c_ux z544y)Nc~@wDpbMA;szCS8(wT}_}tJ&jHV;27)k$-^$oAVZiH%FBaD_cxR_P(WK)BR zK^>o4Q>n?63MD%#l#HlQvYkjT4HyIAQK6PL1}%MVwZg!wL46+{P)@A)GS0g5$*rjF8OlSTTGj%uR0OWNgEd znGH(@HY}Oev0_vwggV2Vy1SFCX;3ky;l-AQ&rNB>XgVxuq+&?Jt=D8nBUCdQVYH&b z#fXY08yZwh==j`%N=*h-DA`Y;WIlzG^$aS;GdvU+wo}29?F=fmGrZW&@VV`b7)^)m zj8trAc(t7os_l$0+RkA8Lq4EDvYkQ2c8_4Ii1sFEdp?oeC&P<TxSEw2+sq#N1Wh;ra~$t zSDwiO-Xni(k6&g%hQd;TDqFI?LB$0OpX>x-vJ#_*DV*F)q2y}{C5JOe z|BxdZ9)1z7r`k`hXOPtrE@b#zokol%O1Yv=E3$GuBUg1Ap}3ym#q|_Vu4j<`q3q@O z-1U^2T+g6|uF@bgDrD+Z(kw4olSRwoFjXvhyY?{aEm1M<)I{ z5c6S=l~Z#Czom134{mOewVQJryLCQuc`jWXpNQH0iI9VU2ssp(Py>Rgp{E`e&)YJ? zuR+HztKpO&UuF=*fxxWM0;A^g47oZP^GPdXsyIf>e+fb~Z%^z9-19zn=k%ESchhFlGVBkoB4%EROoT?s;DvF=TpYhy`Ih1nEAGI>%H4$h*sIu6M3b_0Gtc zH=g6m*O%8<^sHA9d}fA@AU@yVyz#NGIPlB7iy=!a38Le~jE9u{U^MEaqyEfn!ZYN; zb7>cz_}+ee|Mnb$^~LS;%>_N~#xE12?{)z4dI-Bt7WR|Gq|@}C4C5gvqb3nU*)N&m zvNC3V$&gup&IHhX%0HOML`c*)1c z&l)O)LQREax+=JsU$Iil@A7kjWf*(r}io5JR>?GT92AouQCj^g<}9 z-TGJZyW%Oy8&v$l@RIHgXVFKuISbJvqgy!-fu4R1ciBn-H*0BR91N_YG9oDM!9BEF z#s=k11B5}Qp-9Pw>mM3W9H;Rja=Q^jLzQ%WXWvAtb(;1{A6$E-GS}W%qK+oou{5L@ zWP(Q;HQehS32B5;-a5<}zRQj19ktQ;{&r@;a|9K#>!}dRAY}b3Baz~DI8r=~Nd_&{ zS4St~=XC}RQA(YTQ%XvMl|j~a3>Sv8+6ys!vyeP``(R`BWwn=LuJ%H37b=8tP}6qO z$fi&l-V8FSMRpgs$qRBB9=Y>% zkR)mzDw$yVqJfI3tdRvvXk@`)8d*@YKQ5SDZ3}W8R9S{Pv=TKBuuQ0~$<#X7GL_Xv zzRfJ5HX28n!2>vkL8iJ!7KPoB7LAtynX9hDGEwW`oQT8njT2-ZsHs$4)TLsYDR_Y8 zvaD$uQkf+*y<(US<6MQ=Vo~00K_fR8c3aHJli{5T=Ruwc=AJa7Gu7Lilk>1oK`s*zYClgyh>#~EOxT(C zXA_ebvIW}nFn+ntJ#z!H;exr6?unHYPN-{{psqE-x~d2>{SY!{c-uiwVyF;R7Q>4` zhR>xk;!L#vm$o-qlj}IT1pi+3Yushk_cc_Rk+ZY{K~SPd0ThTq&@PA!09j0ALOGBG zU!)(lH*My2%e7HkERO|y@jf9|D3c+YD;9@iNG#Spgm8Iaa zu(*JQ^!G~fnKP)AKgbg)!@}womR8@ebaW8QikEsXlaB%|9tu(MPl%{V@=nP6UsGwx zm9E}zzYnj4ta>G6qfbIoJYuaUcK|BB0A3sceC`DZdk@G35ZOn?Yf_*Ek>1$m9#cvqPSD2VE*q1Oi zE(yZ21jDR^xlIXlgA!=gBnYN3Chs`zcW}O5{0F!hN=tSU$SF&ocwYAl$qcc*jEA|5 zjzN?<6WyfN+zng-wn7Zm*lqd#)Ytt=a@?OPn8&W)$0``xa^gSPEqK_%C~RTKd(2pm z8@GhGF$6QHC{8B&WyjZkHFQ-XEg;`z#1!5)5k+=ABNU z_d0ujs-Hjn_PceeL+W`r^_JgW7on0A% z{~2OK7!N}jg&_=icNufnGiIJ=1QrkkW<59ojlOYa?Kil*QDUVM&Z`W8Rue?mT^SE6 z`^+UR5UsK@jAu^cW67f;6h4}hYMQ=LsF~r%*c$mj1%ws5<#}YS>F%JP_mdAw1 z0pE$=5c8(LYL21kT}R($zLc+pF9j=nDHyvTs7(aXN`m2pgt@H=bYl}Z@};!n#MAlm zZF;${e1j?dB8EWRYsRC~jH1sB<-oDTjbRLV$q>3tkS<62n*`r>!c3S)fc4mxq#VZd zC5u!GV;J%-GuGYDO~L&P!44`4*6hRUt+QqF@)eU}73oy5$2z-1NK?-D%hM~1Bm|F#IS(SAAN<)P|VNfMe6UfRl7zz-K zFF2c6gkfP3!N7v&pcb*4Uj&70(eJ{zhG*IZ1{;YpAn*VOAwa;^*J5FQ&&OFjPX^3_;4NU}Q+cRl&>^W*vKugqRh~IWg04=geefB8oQ4T+~H*Itth`BN#Yjo*6S4`-bQ{3irR_Q1xxc z>TV%KZhA~mA?s-|>r$DfqMWD2q*$4)dZ~6*LYHZNW*Ys^b5<`gnYKb!XD*V>C$CWG zf6ctPGKKXryE2P~=mBrfwkf^fWIF4zG@}KIRExPQL>||PEKhB{NIw&g`72~8IcEx8 zHEx59;MVODl_h?LZA*=IU$jX%0MUz>t%cc`wm*%-IU?26dD+yV4UZ0gh zq5l;ZX~KDR8`ahCGwsp57AoC&lXg8xrUl12al8B?KU(9b#@j`1TK9hELoG1L9F#t ze>YD*-2F)(EbL*CZ^%T3$a6`x`zWE{Hm)G&8B09981uAZ%(96Pv9zbpJN-Q*{^p~} zuRMuD^feSsEtLgSDgZvK#io%|3!qX9@M$ghLE>DGgS94?%<9scJ(u>Q1?N9q-due6 zct_6|+a$_AY0!Cbw|pQ!$~RwcxE}?Y-x;uLgFDnD>H3ei?3UkBt!&}0pIi5+2sE(? z6M5>NIi+?I_)1Srssp8W*PzsAgHp#0O1%eUACZCR?9>iRfn*1u;%wk6c9=BTVNkNe zpk#+Z$qqop4&bwR5GQ0~V&POH!-dw&it^dEz_WpYXDb8GrV?K5CE?8IjwO==Eg=li zin(1O8QalhYDbfy9ZhBiT8s=)|BF&Lu0duS`x7KJs#Ijn%3eB~+2L$whqIv_&XxvT zO%2)1R-37koq$Rpfv?zS(qx-K$u5JEO$H@<02Nz+&+Nb?nhbHQSmJ^eQy@;Z087RI zOV$8O<~UaDalyjQc`Fm0BQeOOT`pA14gmOc>VcR9WAj_dd%gzuev4>Q*xJ-qSStUayYz z6`Fj5kp$7Iqi-xfsBe5KmMLj#^Bg{!S^+3{?_#w$hZzN&y zNs<=NBeM8zIl$tS4oUE!Thh&Ikq)VXKQi2pC|8Q-1CSM^hi$L9l{#3` zjHSGQ`8f&PG1D}g<>6&Jxbxs&T6tMWb(=1^{v@!$!O)fRUq6bvN+UzQjhz#S;^1Ar zGPP8bL2Nd(YMoG>Rcym0Rg4`m9cWwuDxC#Bt(YFi&DE12^`4ztZAj8tgO(ksDT7iY zfQlu+Clz070Q=F+wdO`YR=IBB^h}X&UN1pZWk*dd)oW0y+#v1#P_Q-w)md9KJ){N+ zPpuN3nr7UZqkge))`^a#E_5_?prfhzKuhBx>VHw!`hp>1Xi#d@pwuFu(j4$vTZsdc zsY#MrPLkAtEGhlS;#qgVwy7h)QWt=w#vLoox?t9z(O+t>Ghz%HgHmgNN@KuhZT0aU zaWyEJhH=ef2vBJY_@u4RX_(8mv8+I|V!NA*>+{u9YFuHX4P#sw^pow&-TOPeow?r_ zo(1T~iWEDN6)6qbwd%vBl{#!FtQAM5tciW0vr@P1OICyytD)w(vkaYj%0yE)nP}Zd zCSP-qNvGa1(cCpAoBPFNGpCqj-6Jh!no|5MJSE*Zopvz%?&f+c7ghR62+1yKI59j9 z3zqTx9qh~+HrA&yQk&W!FLjyq(_d0LmD$>5UM_WZR$3kw?58`_xm$Q(D)R3~?kroCSzR-q4NghP;&* z2m2lY2z)xi;h--0MNg;u>P)_&C_@MZLmURiqXkCceumujjJewxGnX?0cN2sW&>sT) zrJeP8l;j(1>T5-TJQk$IHnD2hlu$bBqe@^ZYr3h7xv7N7;ZEnoU;0@eL)<~eql1jP z(>*n$&a`Prt$8200!+yax$mP+ALrfqzott;^39#^Wdw5WA&713J6=%@+Zc5(Qw44T zt937vo+T7(!6<^pg!*;ilQ;QRZJM94iR#pVa+)TJIXKjt>xpUQuuLkbc9h`!mPUqr zb3;6X1sX?&LVR#as$?6ZlaV2nc+5z%8%9`(|@6t$q9E`s(f-M;ic-u=&I|LpYW|IvR>+P`P|@7Z4a_n`fIBF~~; z|Fm0v{BnD@`*gc}d-d-6=JWN<_HK9nr)7D3dAYpMo1t!(7rWct%`bv-V>i3)-G%&I zgY>vDj@9@ui$J(AgA@1FKb#?Kd``x!+FNX(v$Hydi{g3>-uK7kc7Cs|LIm<8nV5)*xhPU zJeAZrzqtDF z^*QaYcm7?xt9kU}-TB|%EQhKpf4+XR>~A#t+n~@`VZba0Eu>GDgU#}n<;}mA&C#Cx z@ocfh%wLwTmOcFUFH&6e4ovUh^sMRaetUPh{Um>WwH%*Ff*dRdCwtPV!v*^Cht_*^ zbky|QPDt(?Y$f&&j+cY8)8$A$k55IxnovzGBDtbnxw`-KlScf*RV(yJy09lj4we&D zup-B~$oci<<@UzZHMpVS;P`Ag*xQiphiWpF z`MkZ^U9}?wEwVY4W=^Ec;USmVpOi6b(?X9#xs}?S>~kpu+`YUNUc0%t{kfTQe6(y1 z&xB(*E{6#Hkpx&h@cHuowrPuf8jur-n8cxZOWJI9csd!?x9%KkJj6-+qO*VCd2)!L zyR)#vX;v@$$H$BIe$#z>h=6-(G54ON!_?MXUEM?9DqWbZG2@w)e|?o+W)^3&pZ z*)sy7Fsd?a;?k&>8D9tQC3?icw%A9eQ8Mmw@O;+lt{Ym}$TTJ?c=I{5@~ zbe~+wv;iA8qAo5xk;=nLgweCg9{8N? z$FR^FnOc_)#F5HvXUmafjJf96V+!Tnf9|)&g))ft_hbmkFgg$#fx3qj>K}9+A*A2j zGpl}xsw^RH+l;COBtGU)=4Y|L_5QR?077ebt@2}a{^@ce?FKOmD>U6>VR|Ki$4&K- ze3PImS$4n6cuksLndatDG>_%qNUTXm29*H)>F z8S5lfia2_uPtm+~^!P|R+Vi^km74#?G$rpuQzA>6h@7|n*QO~enC2%TzVOotqUKY@ z-_X2Tf1*=FG>>@sZ2GNfiusbsT4!hu1Mu&rDaJpN8jq4sWe6nie~0$>wSAp#qE?U7 zzFPNe`5u~Wn4Tr`eZIuJ{|{(tPHmPmp+%~72-Gv^Ds>($Cx;T)=mA3IZhhW#g$-N$ z&v?c<#XvhoXMgC`N=GGPQR(RrtAF-NH+#}}t`))ZTzP?7&ol#sC8$;(Trw-FvwpN% zTThQRoB+D|(OKMk`m$*XSxc2l+1+|w^QfX*|Eejrg_I0Fo#jK-LxsWj+Eg1QEhpkv zQXOLThE>mGi9xCem0SO>ruxVR>RD>v#}vH(wrQTUfg%JNRZ7|<#Zd~Hf zG@WjLk{!g)JGm27F1j=I-%`mJmiZKl%Y zkIW=0l~>}qO^B|$qOBFXBlczC*Vc+c3}h6-?CosLX^oO}Ry$f`tKjt`&aV5D>B_v+ zrUcEjKI!Nm>fgh*hwq-q`nj4umW9zf8t6@&m|BYIOLZuTYlE9jyp4K}1 zr!L!4{E@Cyq_Z-&awiZ^?}V)(tP?uM$mve7SozvsP1mr}VdWi)rmUZ=2XF&6Tsp^y z7sP8lpX8~`+*vGRv1U8mPr3-EC&_2{L3d^zOs;we-G7?8WK`3YZ2;>ca6W~4`AxET|Bzf}MebW_2ZeGg{M%a7={9>xg zJ<`045AK2!E(rfu);-oeNJK+CnNsJsru#@&2U@X=8de^L;TKaDgPMnj5#APC!UpcP z-%+(hS~BWD7G;OJ{jpIex!U@1aHxhpTa?jvoyOW+bs{HPI#-H=Q3fI0G$W)8Htw>9 zY$rwgviCUY8$YGa+5{1~JisqT%jU&4*3k?inyB24ZFT%gBl|L$9qr4Bgznd^Z@yf2 z%PF=_jUU|vg5s;zUiS@n>hECCnZG=bX`b=;5+Zw7i`Pg2L4zknV7_M%bkpP ze|as(_g1}lS0>Bjwplq*+Jd)yAowP67hRH=o9Vh%=tn*KzNYscy}Q4W1CMt|Nm*3M z0fDZqjv`-lo@G{TQ{}C=OAaX2_%>MzWpAWzYROmn-jW|gMRv;3mDGKtE6M1f&`ol~ zhx?1m%iSk^UInWZS^i3h4s{^Nn1?HT3*hsY7HfU%#iWe>Pv;^k=Ho|GP{vO$76~qC zAmx;TxE#jN5s14@h;sC^e<~+NN}IX^J<&PQBIP@Tu5a^)=at0OjZQ;U z$oB;K97qS8yjmJZb8>DZ3p+Vq7l!QtQbOS|DhF-)nv%~jN(#tI@XgagEAY%~P<*i07?JP$~Nf&NZ0JQ2+rb~A4L7P^DsgHGY zWCKKOORdCIBy*=8h#v~E9_y(&^bsF#1lRAhfg@RtXi#-%=nRYk2#go73%{x_oYp#| zCw#gpgg(Zf>&Md;&2(AX9!b`3bTQo5ta>>oS<$cHwSFm&=s||=TAWKZ@+}o<7lm6B zvg>dClB7A2@LRuhwVw3-jx8-B_aREA$VpL~je3b89_i|?7Hc#w9&QVJkNd`#>+S$t z4Q*X(gH%rbWJ}bKtaS;Wd$zs71T6WXmK@3|IYO>y4^6+P{q9qt(X&LO8(;05VK4Uh zsZ=3$%k;k|r!G8WZ^V7A`c0dC>7bq>UHtH}PPj16=v%&T?XS$ISn_bsK2Qm>G zKFOy0UM~+e%VmN)6xo3s=#vq$-)K#Er?$kcGALwW7wg}RUuy8ZQ-AnWJ!@O21DVhI z>Utvs(j1E|)Mc3bNSI2m;pour8Cxy~kiKq^WZ8HqJwDQtV{=iPPROa()_+^R>v072 zMn-$QT7P;Z7irP|TOI-=?AZNYX$`NIy=y-Cn{sE4X1n zy`;lIm$4dakDaS~zi_8XOIJUW5atQS=>@Q8$!`qOa<+#$)|GE*ruWM3nV?=Jp7lmN zz27FY`|(w^+V=_P7r$JbTR0^3by{jyy84x+(m+fXz4o)dlIq%6w)2~>o2LY~!}QZ) zad&LAUl8wNk=-O9E7 zk+h_Y8X4?9@Rs-%7Yd{BLvW{;=_d7AgN)Jp32ZNZkEMgK2$5M zL|~|i8hl@M-%}Hs>UwQS*Dcjmemwg$*mQ(lewF5?M^ey2AV8j(S#1*Xc}6&lfDboX;M3N>S}@bB7+EOhWEi z6^l>qRvo*}S1-qINeo)A@`VKNm3#L|q@pmpMnfmr2l^Gu&)zSY#bfm$8cqRk+BK2bs#1#okI%if2{#KVE-+#?*a^Qhj{t*7o)F0X&zUCGT3(7&62xK4$NmUBud@ben_zyld|H^2>%u~jo2L!*x+tkGtao03{F=RP@LU3w(K3?o;g{w;c9@45` zHL48PN65$P8=OnYh!qoL+N}iVF?mk3)7GmpG9=MYi_Pw%7cr7_^0$~z1`-xAKZd%E zyCWgas(#$|0?(Fn&L}+>(bcNZl!{XddjDTh|7nt`{qNb-c`)**vfu&usoi6uXABo| z^I97fda5Jm8WQd}Nc5HhNW z;`8N~)_+;M%f9ER9nhAk!WW(qv+z+Rjh=83Ga+M12wgRo#g|iz94y^kY%k9*-rF@S z$!Hy%Dn2RmsgInvN4EK>ufO!-WIqxZqwp-uP&)Q&?bWZHD@W3h^{s4XreoTN!_%=$ z8*^<9Qe4o^t|PTm){3ez3ZKlt10()I7G0Su5Iy4 za-c*0m_SP=-QwGRCr;yfcYL0s`uiMLyW^DeZ%U@FUQ_9)ojk~81G`NuZZ4B6DB>W= z)i~4l9(mZF-r?x`fn9<-^9i59>H1P9_I$IJSMOYt-rUjLq!+`q+$LSG_HqX}#JbCt z>m^k=Pdd^25!3wGd4u*;*iz{o#&t{OcE6$mHld1_WM^EL5N`crid|ncO=9PhU1Bnt zz)E^|8zNVY$kc+$OrER1Q-5Sc>t)$?c3h~;V{t(y%W;v8QN5{A*sq_`dKlbG`1vah z+=DZ`Q$C*3N#kM4uD&lKcGc;zO%US1I)dD4Jn`FF@ZH38jCQM293=Vlz9NZpnS#2_ z!&FCx*P-WyUPbIIn_4nWvO_MW=u+tG-Q}I#xYKT9)Z5eaib~3DcdA?>@s+OpjDn0F zIoz`wVf^UP!`7E`zh3iVPOcluS>k~%GWAMUYQznAp50_eMQw>(^0i&U78^d@x22Z6 ztX}(Mhxl<*fcL4#Aw1NAu+b~RC0E_%{Ad>C(~(@ktHpebK20g!j1Z&cq@)gOZ|R&) zN?Hc$1rKdwbZ%R=iP>$fEcfr;$OLJ#u(l)Q)b0fw{p;)TADKHrf%)!1ci2I@Mk$-r zpupy^Lsu@hRqeVv&CCU-PzKyNJhMG$=9&D1n^mHTTj) z=e0c36StKy=%f7GNERGX%fg`cs;e`N*g`^X;i#LVZgjZzQ8W5jPN?$F#W>xuQ06J&h_)q_o;@a4D+^s-)d%kdh4W;EZWSFacN_>*X0 z^fmhN!8hBex~G1Oc*{_dIO}!OO6H+HoM=BdUOR&p|6=CQT&e!m%UPOS=kk;$p6`%+ zIuJ(GtMrrH@--(94KYTRoN`fVof4mf?Yd;cif!F^{I-Jzg!Vg?sIlghr{ON%;aLV* zjqAN5BqmOZY!>Fel^D$71v7Vxz@KD2KNuj%~SPL$Gpe$JlW%rhDsEe>`Edfi-j zBH~$I9(@m(^IbEG+ zLR*qZuaqDPYxN@i$S78;>(^GEhl6>AR8|Wf$lvoU@CZv*y_2wVmUrnXC5yD8hc2^$ z>ur3?Mq9Sa@X%A&GC6tJ)2j=cb0vB$9QoGU9uBEZhi&Y^g`+p}9F#uksCSg)DWvyo zSX9!5*HXr52yX$jh&O)M#45+;zQDRG2`RB?mgE~(M@ufRKj;XS2U#1RiaGnT9947T zfg~^EUW-TUdA#Ul-ZG`THTP+O>C_@jS4)6eq(?D{Y5~EI2xIXzly~pE?{IIV)XirZHi=W%W!}=&bp1tqi+oSoC z{0IJOpvTJ-xkts{A|T&v?T{ezUWRbJfWf~?Mg9tj#|sXZ62x9*!E<_l%j5n7&i&O& z0?}BES1t+OGc=(#-zF%{^hpB$C(LdGNsw_TL;s|=^gLc(=5O#>f8C8JB-{1{(gr0btW7kGyp~*zw0R?=u>XkL##F#mVkYB_HhcXtw z`{7^m{N=Cd+n4;!{S)eOS%E4swKQGn5CFUv48R|9-;^RyZpD3h(^;Z5VGPvgqhj>ytC2fQKM{yQnMDjsR07C8h+=?8t^}!= zXwEDqOY{QBK8SXJv#(>ULm15$QK1|Z$*Ee3d8!tH`??558nSj07a5cY$)Lnafb64? z(3GEyC=x#bLM_2hzzaV)Uirx+iJt)32dyW7uke#e6F&h$FC%|}bI^-0f?h;rfT6w| z^is@&UIc}oP+#FE!xKLll=uly;U~xE{AAL^Pk>h3x3YRcp>_AwbqtC;?7j&MoQR8Y z>o2hv3s)$NR1%Ld4nrc@SxA4=1W)L6W5x2qZ7j@LGw*_@&Rklkj;k+xN5VvUgeT@> zywG0~&N+}&5)m@~kpEXGk&8$EP90RqkqiGf{6C>duEEFeyzy~CM68=_r!tOKgSS{nf78;C&^R$$kr$rj!Z~d7F8HvSOFe9J>Bzm* zb|PTH6AKfbsF-n&TIXXHQq;P$ zy}UxRQMCUx^KzxwuD-fO4vh!A?DsKE8y%^&*O-X4qnTDaoJciLADo?1L)8DGU3JIi zblSyAD5w9dY7fjzR_QZp9?7#y5_NVo5obpeZ3gOb zsiZjFXPfs4*_SvSNh|QqPYKA3B1LWhT^BM3kHdcownlqWn5{&^u3qcmZIaP}=nlBLa~8yjv>aRWb%a8(10gG1C|I4m=M}Q=Pk$FCq+P3cUkK|qBBEKNsyVr zg~|X|B5Q&~V}=wGGkAr zbk&eVR)!R+0z4?moeyp zbEJzfLS00KdQe{ub}8o3E`q{7sLwuVFd2~e$Dl+&fC>XSKBpj)CJq9$;=UCYLZNl{ zRUSf-hut?}B9!ydGWxYFkxW04kwKY_3`=wb$j3}y9sv(ygOE%#XC#v)N&k7o(>})J}^pa6@h9U0@W8M|QuIVACZ~Ctt_XV6l+!My5 zCyb&e4CN`8CEiEIunk}c`9KhUe=#M*4NX+vEO?_*%v}N*&t@oX1AG|$JnKN$0vF*Y!!G%=Fp-}R@tdzj@LEMN#0FvJ!x9u_be|BR?2LuNlhx#uD!}W8gQ2;C_N6(ffG+uFq`@A<+{= ziOzT!lF<0+c7|aeLv96Qp6G;0qVu7yq)tBo}Ioj#Vk z@f??L-fMz5KUkG|P1@dTf^vRv6}{J_-91Yf_&yLhE1-Jt?(_uBddEkGXTyNoj|{I&klN4rveL%GwpXf1Efm&Z zX(Es$@OS73aG<4IlO}TwN;Vsm3d#ga1st+YT954Ui_Bj0Im1E0CeL~}=(EV&5KN((c$=x@x&c0s;*S!X|iuxsuM4}qA<87CX4f^qdD6*viV zVP{^(jBXhjmoj)Mdosg}sI~wv1_7U21>wvzh>Cr{tC0{?OCcD|1zc>llub4RvJwTGm2FN}rlEA}(5j*mD3LxXCFS3t?C6p|rzbPRJr3(V{>Puv~a1Ad@ zYm8Ys2AX9h+9XUNXS~Ec3FpBlm6QR5r!*iuM8i&7ES^91M$Df}Hx!S84aeMeK^ z11(_>QU8mm!W^6;4yc41c!@Red7vSTrXySs*#|`*cpdBz)ZjueMiy`htKli8fJ#6e zpGVWADU=4KI2x3KXi$nEpb|dd;lSYXbjp=Nm?b5WSzH2|#q+pko#BsYiQ>{|KT^bHB{^JxPf8n?)P!)!mNh5FlOOk#BAX{Z|PXzhkDDDKx4WI#1`~)5F;QJ(h(EB7QNPf>0L&&oP(XAwmhfxWQ3)2k4R)*YG#@trI zjW`#l0c$FReO{eTCtbjOwQWX-r;3ytUR%|zg&&=hVlPG zpW5ixxnJlBCw&t(=Wm{OehK{rpJ|4osio)xDk%Vb?iUDW$pBID5b(9MfVlb!f|4M> zOO_a(QUy@S7suyGW73p4fb4@Z3iw05nkEv;t@vs+rBH0mSCiyIi7~?rPHARP$~A*h z!U3`mN<`q17m<4A{giruP)iI2;B$9E7)_LN#hoa!mU<9ZcS2B74|qvE!&B-3vJYY} z$LFbM(v*6DR(zEvnb9HB)I)tMzFJK^6kGGvB=t~YOg)2B>KT+$&!CigfJ*8CkG!DN zBQNI!WI=T;OIMPSRibH%04r2yvvf5*S!v>U7S~i|X-!y?=Coyjd6ttmN$JaqPEKUf zuM;uf^|F@KT)`jt+@HdpM`S(Cxs8W?K1+EnT@s&!IsHkH2LTE4P+&nF5G)Np^6!~=oxXn|3rJVWkI#(dGrm^qFS&7Awxgg>A`P297u7!O}D3STjleZ>;@ z6=Rcl-rJxctzT2GzvOSobyA<*jED_vVqx=UrDEWPkAbs?f*v6ZHx-eOl%4}9;%+Gg z+&4uqvNb9ylx=w8Z9wA$2KS_sh#*lE3fqbZwiP@lLlL{_MNp_6T`2r+cp`Z~g#&>X zx(Ci-jX?=vm|jFq7o7l6#BD1DJgh}9P6nvRxnpRc3~o~|bA!QYf&jGQA%FO0?BDJo z577hPLHlTj9{MhI`k)w$>(7Ih%GSJBXA^5ZO(}p1WdQfOgG)@1W*9*3ykRu2%rz)P zX*8DeG#c?df?`fVjXlf8a%B=i0nesEzfMP{pXMY$EAI0r!bk6|O;J|cbe=L%nydh= zw7oKIp-{Me?AtxuUhwSpB6hbI!CDHHNzJ;JW;TP;^ag0f>iI-R3xYh|u>dvF)WXs_ z^|6$BV5Nfa_=!QH!3*qyv0F4H4dT_;JB=Bbhe@E1)~EM0^t_iBP)eHkygZI zLguQSNT&_g$(f4QDVl_NqGrK^o}NtFT=tJWJ)gk2j`=js8a}9}E}2c~T=?NwOs01# zoF{n}z-h$OEcG_$;ymqBIe$u*W@DBnXHN-ky7T0noL^*JX(6-0ic-)0c^B#efo<^Y zo|c^~7N~4qGO*ymU`&<|T$a5<`&@?SO9`qZFDO{>V9(YT7hFN`)I66a3k@!w1G-X$ z2XsaJa5C2g2(_P=AtcC)5f(h?vDw1pReONO^GUv;hC_ldT`;qnngrHgq!DuevVl(wL8P2$sC9kls zxPXQ9_e$}ZGpN+#;t>{Bx3IMOhNYu}SXR8$dzpL`Xz@^pihn{xO_Fy)-v63Pi)Xre zJm}EJUdXCfLN@v&B*i1vdU6M#;tSx#5y0nOfUx&~TmX@MRJ7|jM;Y)&km zOwW?yfh;bL$l|#_vd+vcS)+I-i>s5ey!tB3N0()3@f?~FtF?x=f5``ij+VYoclF9QSlI8Q6$sWb#FjB0 zRxt{T7;l(cO-z50D-v-GL8_IYX$|wwF zD3MHR&0WCS*Z?sEdkNZ#z5DyPe*C&$KTeoCf%Vvyq#VX17}g}rJDoreTmmg}34$q% zjfWDi{X%lQ3HEh+6D%3xw>Wb>e%6pNx|o~O!{mrJY z7daQ`XN2+%AiwYe(glODhN>xJI* zcZD)!mt>L_Tgj?nWq%w)>g01&YRX3sL2f*kcH^lXCq7c+1JO5~`1-+-Kwb}FLVTyu zy7L}GY$)SlD5D-usx#*$E4!_XAuk#7s79U6cQn9=?kLzycW?U3Nm+r-V?4}b)B_en z?C$$dYgMv6=q*N%;l~7~<|S9^GXW-DN0;izRLdW5`B^&})K(CHuvsx1A*! zg5McpLl_T37=qNYUs?s1-3l{=sEXgSZqp z+ZF@{Vc1qgu&v-ZRg2h7FM>j==tALE!xIq!vJc8s;Du^|v+0pY5QgbRRI(RE+_qA{ z!&(IMl=U_1s9q@9+QsU1)XwB=s&yNWl&pLCE|_vPstYFtdU z4-$J>k;>$TCprgYAF+;ti4$Ts&CKq=P)X^?8qcFxc&e6!H>x0yr7CxKRY{!y(2qI` zn4nGthEL}M6QxN3kbRUPm@b`Tb(UX%pFsj@;oYnaU}M5rTHUJ7#c(! zqB4twh#6;Av}?xM#@mkhHO^T~|vO`4uM z_8d7dE0_n!Ov4>Bla(na+AOn97o~|OP*@*%6{0fzgoqt8E7~<_M0IRi21kh8>{+Fr z4>Q^7FsO4&s9BpG%LU6LoKfZ;|Ww2;-E1j(keRLJ{Zk78=+7$3znRRV#CX2%TFW&xj&~I9s)}2S}RK;C7 z71oI@+O2b2m(}U5i>5PNm!?TB(DmWIGSx-V{?}|w`~6{)vAH_u^$PFZbFVH~(l8wC|t^KsP^ZEn5Kc!#zk#BHE|7{6@nA#Zcy^UYi5pC!AXml`_t8gp<`*pAnQ5t{L8&;Pl{$>MQXK}RIsmQJA*Umkm)mT^JAkptT2mJ(kNj|QuoeE^);AWI>j{!#!;HQxf1PEK^Pu!O9~|il5{N{l9JoL z(n3j+RCvsntK}DZt=5$}AVHQ48KN7ulfY_c=vwRV*MzSZxg)&qoUWJOh{~?@r52!JyOwgHi_omG*(pn(t&1 z^kGnH-k{XHL8*B_rFr0!=CQI_Th_98T-UZTm%I0Ow(Mf9|{-OmVFh6d*{Y&NFW-SS*E*Z91B zC(E8$)#A~9QwsIwF4Z~H;1O`+>;GfFJ>#ZtX9F_hTgA(x5%x86;O38_Ztz5%Vp0o{ zuoS&*-jNgNZYB^!YlLyqIKnjTl$v5Fjirp2O93!Y!TTD{UrK|n+9rIg+y?Sk$!p03 zU#?s6HwAfH5zpORG!D+A(qB9sdVhXtce;9V$Tw8hN0&h3fK!MT)vOxsOlT~h8HR@$ za_=(co+V6|#L?%zrzB{lgS^!t?b?%Zt3%3@KKgIHa;Fetf;_*w^M76BG`+7O<(oU- zBPkGanzfQ`q)N^w)NLcETR>R%GGUgx+_W1NN*K{(6CWk~8VMCedO|V82}StSrgUIU z%GK0S3`V`f(3cIT@*#H+m#Llaf=r*N7 zPp{6u+udCKu)Vmsm8Tr=_3Q23*1mmneRcPb-QCT_I~D(z{^$Sx^Z)fz{VZk6&)@ zcAsvSZ?E26-+aEl+1~BW|FkTRFE5uDdQf@0yx86DZhjGzo4MJ^~H>jaQf%XfwrXcl6UOY)y04Aci(=!93Jc)>D@Ulc>Rz2+wF(la&WSD ze6}2(?wzSrEqu29v|IkRyZmK$ckxcW^3DC_Wd*mNE-t?m_|2{zv;IRCOZT6o?6-H@ z%Zqo9uRdJv7R`-sZ@;imCQ-z*oB1h@A;-CmquY;P`hx0(n~C0))hu0H(u?&D6P z)N)Bu^XhzibM7)xd$RrfHw(l`JD>d*z8!52MEdyloqG6YG2z!c|1K9QGc7@eEnuQ)id5U0yI(>9m_$R@SZFOo8>Rdn}02vlT-QQ*<$ONzbs!Zd-(5Pq`2rE zWWC*Q?=H8W1p8_^Q_cO;6YbFg?L*T(I67*zwuP}A<2U`2z2)%uVA-4=aS2tFejFVg zw-Q(PpMKI~L?`i!qosH=_+n(6yT?5x8*D|66%EdAQv?5^7OPKz9$%COlxSvF^9%ZX~Vt{v`A z${2@fp#$k#D|9TKi$aL?0UWRu7Q4B){aLD#BElmwC=U*$nI6YOME&Sg11ep+yuWpA ziHDeewCC;>f0*gWB%^e#T2kZD{^5zRn^4`Jgw0Gq#NBLMYSsc$)kb2tk$xViBTXOi z_DsdZfCeN3bL|MWYuiMv%8&N7J7?lh^^K@m?TEGK-|xGdYqQj}kEBFohBztZ-u2b4 zDev#?OP(Gav96?4(!KlDD&8DxN=sy;+9O2OJ8}2%W@i;^K&1yq;tf(qJYD_$_5Drj zhOn%TmIK!HNMd}wzxV|;>sXPR_YY}o9U+!p^XObo#-@DARS!e=cK3_CC{QV~O#g7wD`zr_27n4DaLRP}0g$>e!K}Bu zAUva(3MV`;`C_Thn=jDw3mNxir}k5nFC36h|hP{c(Yt4S5icL zd<1%K9HR3qY8>oFbljKEo1!Ft^QC--FHb!_m}-A$ zs;A8y<-G19NrDzguk)Y1PD%NbT;~v<7gndPB#vc_QJsj7XVH&MQ8-@vd8})Q9`iOf zg}#oFM=zVIaHsIx8GBO}H`Y&N`>UpSf;uJZsrg|9y>6<~tmaXw6A?OVQ|&YP*%uw^ zlIOCXPRXHbBwo1u%M{OAjhsboA)w~K?Qc!74PIHRL?4xp z^j!Z*_69%iz0!gtgZ z#@L~3oEi(>zPq@voptM=u>P_Ut~?Z4h-phnUG4W#bgxTrIXAws*=SE%l1W#kkNSF3 ztTdyL0&Ni-jyPHlg_ZWD8z)i}en5o1nQiNm%qqIlJUS3(%M1)v#Mo7TYN|(Sv#1JZ zQ1CDgk3cK$tXA!`cH)F;mED(h+N-s-?!l4i>Ke2UMP2M9r(kBbdUeu_-tO-W5q{tL z&<4)tSf?p9=X-es{{2P!<8pZ~b7f18eO-{V^FOq*vTT<9q|S1(dg*T27m7~GADgmF zXR66Gwy!H!t=8A-+OQ<3^7p>%TiDPclK;DD%9d7ouwS)3h;X;9uUoxG;xeumG4vkT z>R{RfgwV;^c3#b@6UiX5U;2~mx0P78pEZZ@VZE!NK9tp?E@wR1_V*D!Pm9mZ1Db8R z&CqmXIs(g4RwNuTAmu~}ZnsS>(4`dI(nmz{M*ITPr7lM+;GGtlTBZg_* z$VcpYBs(eDeI4uQx9pO>Cx_j)YIWPC)e1xELfUnG(4h;zG+muhbgjjTh?lPoer<{^ z-B0#Xm6E~MJgWT7G<9)sD6C6$N<@<87uS>|RKCj9dcaWa?@d`Ycv7t@Im z)poqvMyl*4W!<2r9LQ!0J@Zw!=aU^&oL~QH17Tn2OJ;?mWur71UJwp4=e7;Xv!$O5 z$ezs3682?2ApIf7bt^3gSw>B=f>Lrg(&b3dWnX}cZ`9H6_1H`gv(y+nACvWl_B(bo z`@RnMf%nC?Ruae~nWAHg(gU_+!u!i>xiWy-#fmmkm4NzcX211>rnTE$^hoyp;wWJO z8T(wshk!fk{zi@~-dQpViz^$;$8kSJ(HXAwODj{m+dOzHzLHZ#HC;AhdLFbdqn*6v zD|U~gA0hS36bjJ^^gwseeFEM0^}GA)!@b;&y8EQ}Qep)n%e4JHDXY!OG978-i+OKO z%e6lCa`(d%{UMs?+YcXn&#CbjC+W!m#|6=J2U`h0 z+iOWv3;FWiSA}+VqhoA$v$G|JF#f*q-9{D)ayIGxJN03yIV!+^O*!tTaZDflNP+-t9qY@BSU}M-XclW8?q(Pqq{i6 z+V^F?r;TT6FDJy*%IRqnm%~^c%SF~m!FEb2<;eSTl$OSLPwyx=&u`xnw9|L>q#RdY ze7=yZmDJsD~kdB?myzTl3itESi-e&r~^h!1`%Gv#-b<^V4rg$^GUtH5NLJF;j7|%s8 z@VuRNjak)&jE;mXH!{dibP8zE*!U9N)%}kD)_^YjB+yz!5(x!{Xr#-oT1rgTcpS=V zDdMqFn{2USmf$jF>zItt){KmiXl96qT~$@}X}mW=@U8wBCZ7fZZIWP6Z84X4{8Rur z^p;MX$>Jdf??#W}TIbu`_H4PnIe#y|d(_V~Wl?n~o00=PJnD0_9)!12PPpIG#<(34 zMzZ2oGp zZ;AIcd-WXXC~=4z(i@4ea|^3cyr&l0C0KElUIPr$@fJL>o+dNw=vqc#&0O!&*LFj$ zy0xA4rYjp>yPlKk+N)hn-M;JFQoW|C;oFx3arwFF(Y07Ezw39lXe)ZIBU?I|w{?vp zlhJg5Jf$^Dx8hWsmeqaV@-C)SIiGB2CbE>DBqH{UayNwUlH*u2RuXQvJL%bI_(==5 zUU%n9EMBZn01@C*l+pLaQEQV6!hTTQt;v&Z4$iBBDjxQ>z9Se0}SF58D3+m1=`Hr4wCu; z+f6uZ`}Swc<@N8oE4i^r)#W5p533|s^>8@ls(bWB^j|hOc3r3X(^o=&9m6KehGs#& zuIGJnLg#0MwO@2JIPsLnZeVo|V6ol<=n)*Kadb^6x8UW+>l-_Anq0f{>OCIMiD`Uk zDxcNh9_|=G4}{zM@?&VzwY-`h$L%f`SxH1P;d;k$x(v{}uLDph`4x4a=9Jp~o=Bbg zIEDHq%Io*=w!1&{AmKvpC)1$G7D^AiglA&E?S;BeiOOv9)r+DNqj3m{x3#2AW3yEkr?CY}yOg6K;to_gD~IAJm>W_S@{3pt$g6Cz&t)gqW4@D>7f)qiU( zfCocc!21QdVzzh4-y6}?BR}FW#q+5LA_nw-BM{$4*yM;xVjx#MYS=ut^-eh1y4Ty` z{7A$*)31=+T>reg;_D>)vb56^_!ISBp5Cy0yV-rX&IwL5Ci!N&-j*^Ud0z$G%c~jsl?&Nv%1yg6FUWeVWQKF`)1ajXvelVSE{xpY z*&?7{2&^>VdEqzax3tsF*wxFL7tS01j_PAdD?_JiM;1MxebkN= zQc~|+8p4c;h-HrUhJS< z4t=)Vh1I&a)pJXkne})qWva)(AJ%ADhqXn%1Hc<_Q(n;qOJ~n!NxCn_OLz|9eVE#W zbV*z_-G+DVL|;*0bx*mA6lJojbc9jxdt_0+tXh-QHzfY{KJEP@(YFw!ThH8HAIQ(C zfrqAYj{%;q8iqmblIw42{X#QB9XGy$#M76pfroYr&Mb28JIx^d46Cw4w|JP?Xi-?1 zxF=G?jaFe*|G3@5@ND^dcX?;`)wIc3QaY}odI;P_a=8P`S-#a_GHP%ULhkM51)Chi z%l2GP{2y4bB`2}PtC{-gzOAU*v4q}Gk*@r^2|Wnmo<}VN`*Lu$o)r0kxo{`?w0}#E#UR$~h>Jy5T1-D*!Dn#iGd^hrIKcGmrVR~5H{O@CMx3!6$H`ko) zNAmH^iH1ZLlm{}^p2=00+A(i|p1x~k=uo&!)1EBf)?|@|K$#l5Ix&deRX9(m zL87kt~_|aU^M}wk((q*FI?!4>O6D+&#qfeJ=Ao9%w$iNK=}Yi27_ty=!N@n|Ijwmk&th=ImaE@r;o5F9 z-ZM4&v>b4H?Jveo$u`9@MCY_Z(caAWV=<@beC5=8=lT0MY>DM#v88L%45%ySmbmFj ziBf+*4vOmQMH1Y=_&hqp>0P?xYqj6=t}a%nh5Oxrr<5OUWuzA`%JAvbPv$=IEAP{Z z(tGst7zG*j%}e>FSoe}|w9_Vgqj%NGysuA&2Vc?2ceg7=MAJ6 zduZl*u=8!DqZyaiA9T3N!=jBqC5C!4nc5Oh0QE9p>39pmI6_Jg-IjPs^++VO2zIQ} zrI<8jjr>TKW9{m>GFZV>TF2X!pevhC;?v|i<)$(Ai z97)jSF$rYLExqMCuFSiGo#bSNk(TTFQ0jiWAH2?L9{&qk^XQq?Ms9{#pJ<=n<1s?L zmZASukIG}~^eC7upLjb_wVgNcRls>mkB&xo=AZFIeqzN>x2ZE=Q4z&e+K2Z z5vd~oZA6CHsjT}vmBcnRDbOHHc;D+J)E1oyN^^RW!2JocyFC(Qbji>^Q?Fmj0;a!m z_3?tE3kN|IOdD@PH7SBL>a>;T5Y0gS={3}pwf#2vsG$T;%|okD#iA)?~9bMO5O5c5-5uVl|>DSH?K-GSCfAquro9gEDadvkztz2*O&T z5R)Yy0fc(SBw1k;6pA)Vxs{w;B^cD`9xe5`M~h(O8>=XhjzNie3`+C^$UcacfQPL? zM8*h-hybCM=q>OoQKh9!jy zHRvc;hzNKgBEu6A8I*|#SS2DCtPqij6A=M|2V4Bu5VCoB_~&j2*uo^r78Dl z5sXA+6(u4vC=roCiHHEfp(ESGZ4$&$HXxDI$BI>Qso8I&mw zSmiettdN_D6SDz=2ZJMk&p8dk@L(xt8bov`l08_8xd)4&k{Bu+8O-2BUj`-aGAI)l zFnEGk3xcq=$P!TqP(JbB~s$+@nP>@{(1QNXekYNCqW3 z0tAN!7Xc4{h6ue)OypP@+A|8d9mLU7(@50QkW4%V!F*yC!^6f=lqjbuSHdxveK=&wlx(cjJn>eE#tOL) z$7bAzBi>38^|bGaU>cI>r6Gx241o&=`k1bWEa4Ng04ie_c;ObuE4i2?u?wI=FThv$ z#iWT~0Il?LgKWe=8O?!hAP0aFAm*NJtkokTkZCEhV86Av(Wg6IW;u(rq& z_n3MmAK>iKF@vV`gK{f5xk^AN<{m9gxkrn@JUYUOgskqwLIx!o0tAN!4*?H5z+`tZr1nvslV#KD%YVW z{io+#=}A}WzQ&#KsBVPuV?jX|cs#498!t@MLC&=R1f|H=avycv4I|&iUJ4Ts@19EPui!-UaO3WtemI1HbJ!vvFXn4pBi;2MsG=WsMA zhoeC`90t{J7#>DaIGU)2qroK{-zcw~`pA=SXo?~DpCNWVA$Dj7bpV30*2TE#=`Gd1^P1io{ z$Tx(AAsb*xi;ZH{Fe;(_1%Ig$*vgu2D`RdeVb`h8{tL~lu+qVJHj#URholpf*9=_s zq>ug!&8!CJ6Xaupy?-NA6QDpo!Wg0-4Cm5eNJ4|(7>0cexfP6g zrV%Fm#@}k6ui4YAI_;qI8!Ki{vt-go=Qmb^rwQUc@pp@7bx(VNxYvwFuNj5^7|Ok7 ziT9c@_bg+U)r80fmJ$eWs7_GyE)6sN~BQ|N2!JDM+vz6*S@#f+*y180k$gC9O zd|6TXBf~2br1o>ZthDj4?UgE03xzdUng}EbkS{T8law8^q7sf-Q7B}STF8!Bslpwz zBKD+M5s$>g?I(^(f(IFfPX7Dg{(jMe<$jVSUoqM;mX4E2Teg<0DBH@u;r@P+9p!#c z8u^OOB`gBLu>Sy&{T@)NrHLFr_Br}{ecru$QofBDB2Y9Hil&xb0Id4K1uM=larTH| z$t?zD-vF}@HWz~EI(f-t>#ibs^_K~g(*W5AITLvFA>3y^%I*VJ-RFW8_nA1m&#>e^ zgR=X8q37fx2%_snw(dSFyOM4uOzs0z+y^}RK<*<~3{GT;)xZOd$9#H?|C-X^R;oQa zmjr{0Su$}ni^EiQH)%ZJ^iiv3F58|1KxOOrPsO5#5e!?{7jSU|M|1o%8E5JvyPbr6;K0IxxUphgOUF|dkk07zI zM4pB8cbrS{trU;Lgn9KP5vWT4d61Q=Yf5n0F)vtFl7oaPLl`eg{0(97p3e8wB!zn=9$wKQr>hlWlcv@&U7?oOrRxSLe&2vO6pk2l`g57Vo^zH z0;uE&@RA_F=h*>a?*XL-MD|hfI?jV!Mz zlI3HjWNAs5Bu;sgB_(|Z@jQ!?Qc9*INja4yDYcR$WmuM!M9bm`QRG|FC~23ZHTw{< zly{DmjB`QBH5bgY%%#!!$S;?b%yI!fDd${Lv&ki69ywkz2!fP5j+LzGf_c6`oH7Mi z$`N2GJAkFUaI9p63&Nd|3y_s80AAy7+szbyKqdOXOYniuV-I2UH9`+ji9B$0nF0?% zjXMNm*a4TQ8=is=sKngydB{zgB5qI$xIro22BmNVD$xcW4vb)%sKnaf8fx=H3N@e- zYTzZ*z~`ZcFnSuHhNy%ZcnviKHPjG{p$2RplrjdSPy;HVc6=UclcrD`ltOJ#3bjEg z)PPE;frkSl)FvvSHn@cP2R$i@HByQ$pl&y6J!>p z&Tr{Z=7)X{SU*<~2$nF!hAFbXpmaw`~fBN#Iq7=Z}{A#VHq#Z$3KwQkOuSKmB5y;9&`)J`AXWYzZs7C5*YZ8N=xCI$!ABK%G+M z8+y$U_nPtOHKXV?L%G*1@m@1#GfnCg{7+g!zWu27ML+UQ5K}G*rPMPhr5>P?dceb0NXCL`m&;v6PfgVxkPEiQug_ZO89(5p(Z%DkbS;V zh5LL(JV|+Oq9i^EbNZ7Y4+0Y8p}>MVAXplH>ciqkf5frp(vSUi_kgTgY&%BS7sP>E zt`v2HC+hhTN2+Id#E~RqR&9rbrL~uNFDqZ+v)DEYR`#-jaUv$=aBG5*bP4k;N}%UX z0xe?_gptdb5Lr*imwgG(5cit#=rp6_K#@9EMu$k;7_I=^!w|YnknF(Oi0vc-z6bC3 zVZ2Iet0kAa07MQf3`F3a(TJ<4{4{eAHRJ5xDx~8zNMGTbvDQEc;>FBeR~qj zyY4&pq?+?Ci9GShB;UIyy&5p516Gp6AejX0Sf(`h2^UY^h}lq(lQ zurfd(ow^LN$_x;=hsYa{Oh^Kf;w<2mu1%0Q8xZ^#90{CFEW)s`hzgIRzMLGTn44b& zh1OAD;da9_!2_!~0s#U%X2}}gqf}U5g0)?X?}YwQ+iH00M1T^7TnsM*-(mTk$TVmS z&yxeNHBU{Z36$VGDejn07$`ZPH6Scg2XN1mF=Vqz#EML25)7-<$JTn1XYkzHyLa_%z zFqy4T=nq0LnYU1Ib=2a$es zH73l+Vo!E<9Lr}8XL+3qSvr{!Nu1|J7Qk^dE3uRvv!W7ySy8C-CAX0CbEOJ*-HN!* zpxi>8M@c%&8!UM^rRpY%IbwBw?%)VT@GA&8#Oq_&e zJ|^ifE3@QbkI!akF3q{R;?R}Znrm5^vstCi+$?=KDAQS-iqGb95)U&vOCEOK>g>){ z{9!`QW_qq559XC1%w~PA1fzMa^n-ahTL)0x!)kyf54&%+GT_oY_Ibz4_wG3+o zmOR|M)pY|`@rS{kts%IA|5k8k>j|#p4>)PEwxH6(3WFrWI)fz-yKc7Tc%{dfeX5af zsDdFZC>Ub?VLTkq=r}7%GtL~W=Kf;L76OcnQ`{>*DD23Hr6VaZR7TUkmN78Z}Okp5mNKJy)wdR!dH z!sdugj z&J0O$Wfv7kc1d-kbvgMEP;nse;yvJV*Fo5OKz@VBJ}O>Q5Cy8cAQ*iGxH!u2;w6Kt zi_+wkJe4KIVOd=Kmc?`TWu2K9vxeC~&dlQK(=4y9&GOO1Sy~*O#Kqr9THTJmCWkv# zT(ZHHT~=J`0(_FQT~giXlF@;V7uP{hoCdtQ3vDKMIab`|g5oY0%-!YE znY&z8+~orFoZRISd`={zySzkk7X-y!z^l7j&B>(tlFU&qJ^)STg02uYVux?b0-_5!h?Trdn}bd0l9kT{R~S+ClQ_INlY&=}s= z%a-1QAm0$N{!D>DZ~;SX2;*T0qcDUaj~HVfF~%%njKBhda3VymL%Qy7{0*M3^-g*U zvfoM1kR1^xEjE)?!_0)no%9UXeC-$NSxO5ZDG}EpZ!#Y6?2ZU z#Dm5da*Uxmrkp4^Aao`{k&}Z6imYEvXNY6Mc-Y5iO}*g-oUH8jG3H@mY)HyC%6k3Q zEBS_~FoZG05F5gH7{VwFVaU77n0J>k>nkv0We#Rf6b|AI8I`ga%PD3{x3$QyFtp33H+%!-S|v!EYyGh~vQcw9igdte6vu zC6jLZbzN3NI0$m0qId`+k%BW4Lo0^RD}hrJefx|F%;a zL)>e|qtlF{&kW@ZWQiNYm`|0|DRi5(gwo=+ytkdx5;iW#M2$^Jx?xL#Jpg^gN*&(k zKGg}<{m+WJL_@#7c}nPE*BU-G{P?2ql5`pave^V30n&=y*NMVPYk=x>6+9%_6bD7CTtRD zCr#F))g2{(US=YCaWYL&EFf1%07+CNe)gpHDi=gl> zx=_g1@XWx#?1P6X1ci%%v+*=AAPwuQ%;OtOgF!JNw>eZW;Ktd4?few^?-O04>E!t_=o(LEshh~*ca-<=S@X=e5Z zhDu6yr0so`KHw~0LDxcgTvhp6-uaTcmT>kM6J|0~n4#0@!bEw_0Osx)=_%iiP^9FZ zBJ*@9g26pS?(QkGLSLy@Nuk}|vpl^7TrCb+on%6mcqsZF3jHsh);j2ydC7#3O)L*# zA561GAF$tZXHqOpKD{M>!$I(Vh}im>ylc|z)v@PgA_`GXidog}oSCf5NKtW_l)5O- zO96Xk#9#|qnVmw!uAvbe3jHsh^*Y#Z5S%sZw#WPu<$7Ms3YPgQ%9Sari^{A;61yF6 z(o~+idWp&O6|y>mk!(JRg+l*p>duv^tQXojJTrORsb?t#w(N*#bqf#pWeM z9@vR2PjS7-WTO+ZKg!Sf#wW@@;IQ?LP!xBc&W6Th;){aLUz0#hroUcpIsd%;g>zzr>2m z-jSIabit^>G7>{`1qqE6Bs8T+YDnQxGfJ7E9fd+e3Wb&oN=+F)XzSJT3gR*!vwMXt#Nu`UNEwUsX$*xzi=uq3TdWVP!4cSIh0;*!{ZMx@Gi$TdZt$T-@&I>Xjz0~$oz7Sg?o4EAx+`lFExol=N7z)FYisaEKtLHeg< zs+Au0cAOgas5SRi)kAL;3cXb*^j4wJTZ2+>4IlZI7$P~CWP^UUT}teH!=nWak7hJH z+Cq3Xh=e1nDwb@jl59~G1$!zQtf^?QrJ})-h9*0jsQ!zRtUYPUX4L2I13RiL8dBkC zNrj^+6^^zvI2+SsBWrYaNtP&_tx!Bzpit<&LZRmhgG_{?i!x^Yl6^W z!$OY@3tcuW^x3i0X%~!oZ4+?nwc)wfCJ4PYEcDv2&}+j&uN_OhcEO<6ujR$TI)UJm z6=q2HDM5?aDd4RIu0TT_6wQ$Vvu*}VS1??eE(%%6JWfg&yqCNEUJgG_?T6T3hc|NY zDI1#J$br_xP`U<6&GP9F!`c4&@PgF__T$8bH2k22p-BhnScSE7Pr5@CRvyI2k4#uC z2gFmIwBiz|K1+VR6oD>&>Z<9@BG)W^k%UhcD~5Dh4O%4+{Dt18tLYnRG$>VTc&giR zx)n$*bGxCLAV`e`X=*Y`hYi0ChbH*cr!=6!fc!y5LS6RZlNDpgx)Y!_?T6B>1=eoU zXHd5MV@=O8#(X3YhLOOZa-YK^HC7#V&>y3*;$*+|!&2`Xvv$8rgqn?nro}-FP7i`) zOOU2eMCmXpL1korRH$nQa&gc|VGGh6!644TWO0aV5IpFXNwh-+zh-#Oflz#w4ngT* z+np}Q8Ikhk-699X&U^S|E?|iHp7CZZqZT-ZqFF3)TNv};F{X1eAy|df9pJl4Lkv;x zeBXZ+jK!zkSU^K#fm3zvEug)zfF{O5l8gnGj0M&idle3`uY`fCo%rN7G$V_F(%I5F+p~b33@*%jJ0jeeKRq5OtrGx3@5{?N0kqQ z?+nsHZ2(;vKK7jnsfp@y6D8jnKJ%T4v+qoheP@E+cM1pJDHMEXkXzk3Xqb0QUD1QI zz{mqJ6q|UHD;WBe6|!epI`uCr4ZO_afv;JdJWj&scM?SJvmnQSrR0tpBwZ?m7#QSr z)oe6;>~|AV6MeblYb!GIvWc^QO^`ing5IYJ2X87A{AiF{-8pEK#n*l?T2JGz>%k~N zXt)yYwH%DnC*De5hgCE_Sy$@j1yFNuLshK|4Z6N!TQuJRwf?Aj=#)aCX9|VxDFmPO zP3Ml9>ZrGrJ*mqi%l#%{=se-U0>XnCga=y~*Zz~CEF4)?v1C(~WQ(dO*i+G9O+|w( z6%Cd&G}+Na^ELh-J>bna@z1BS`PV|nPM{Nh< z$9f6ZlZ~uTBQFbE)2Tj9oLt0uodrIfq?&X(NwCfrsUAEI?p4nQka;ty>RKvSab^$w zvP35M<0UUUOoirA;&aMWY!bnGVwnoeBKSHR z_+|i2GVo0qdVZSMH~KbLgu~um%kS+Z{Gsf=nEUNw;+u}A=>dD*Jy-zys@`bd)h7I*Y@vguRBn@YFCqgVV>TB7SX;^3U z5SAJB#dXudDx=r(okYSL751WEvWI_}WWz6$Z1{zq5j3N9aFposwn||i4{ckecvy8Q z6c$|yg*BH#Vaa8XnbEdehBs$a(T#6K4}B)TsasKkxRsl{!2~p_dv|+reXh^P&R<=o z_k+wA^!yAbU%vS_p}me&AGgJ)a3-zJEYi!}>pN|<{Oi%ti9JB2hGdoFEivpXoq>$h zhE)oE4T@C?8_7JchB7*U8P+UxHYivrZ6tf3L87){$zSb`zBpEg*{wX6uSe|oWLe3O zt(+KQGGn~u7o$dD3^_e9<_kQ=y2BoHP)7;(Sub?d!E)<^rTYDLxmfC{3_hrhjF3GH zS92ItYZx(O7&2Q3`hmL;R$QcX$x8MzDT{eFVq8~NguGkoml@qISK)(N&tlEDfKVPW zuFfaqW+A^jZIa{LJq6OcTPhdaE@6fx{GMH5vnmA zX-UA3?1uN@gSwlnZzSA6RSHAVApJw>Zg?7$hEpczLe)80l*Xvlmj|i|@@O?dKV%I~ z<5uy0@H$$yy)BUx=3#7z{%N5wnB0(L)eA||4{fU~<%HpBkSoq3-H`FPRUwagL-bGI zy|BAV!kz-O4(0(xm<$ZjKW$VS+|z=?LvAo(PY?<-OBkZ7jy5;i3_RisEy1K=2z#|L zhYFcK4ADQm^%$ge z5LFnSsK;;`bGcCUWELgrvHCLgm>^S+33}==I8l${J@q)+QIEn*J%*@%T0R*}Zb-7~ zg(T^z$0|!1V|bz-#hH2x;X%^3%G9IkY0Y8qgSGV3qh*+S6k+NyM19z($6)=F;UV={ znVxzSX6i8{QIFyy>QM<(k0I=jMm;KI>M>-TDr4%gBGXh!)MEuE)ML^~B4z3^{f>GR zW$ICcsmBntwNa13)gF>iI3oeEK!8H?-=0qitCKUP=ls)szKpggW|CUdzzZ-Fu|Y}lf-(+ceySS4(cOm zsI&emaDRnUKfk2oLPONRwo`JLTIhw}rdqzELvF3$dpuS4BSb?q7zwV!qnDJ!R-75@ z32w`Qa>iJMDyiqfKgwxiWg>jC78$Y$ogtchLh05q*0%YYA)llf^O>13osJo?IhY_z zg!+}QKbC6_elCws*(Sg6L$!oQ>WmL<;s@!hoK3Bd&sl9?s=N;0`s|N58Jakq9&EC9 z?n(DJla&YI@Q0YJmVNKztUCXva(wNE;FCGO5)2?;A(9r`#;VQvjGAo>xdn{5ml?D5 z9X0KXx&~Q7)j{%;Bvd^E$0xVRM=K!X1l9^Rkt*55XuFHSmAI*-SxqIZn%XcV6jkI2 z#n7aKlu)dld(tHoD-ZhU3B_ve`_^kusOtQm!}UFUGUr!v17yw*5M7U9yg5Ih&G`(Q z$qcz+jJfkG_P(&H8--8KKm<9f62$SSFVCZN>ocR)IflG*jCto6GghUhePlPtr`P&q z@qM^GhELfj4+OOpX|+|4*?o7r+h5>m9Bb2)VTQA6iOfa)IKCxYs* zgX!iF6vKLxt;x5?pshQRpq8EQqo6(4wI}s5TUUcM06Dn~PZ?(TIL%Brvf4x`2!`jZ zGeHiA3HtmqIQc>GoQaC_y*hJG&Ph`>hUk4a$xbUY_eGfgyLk9Fy`{EheyU&b)|Uvm zt9{A|Z1_V#9j3CCn*?>5)K+X}OHOYqFp2FT(W}=(t~XRGq+!rRDdU@H?4KsD{~A`D zyj0cem#(+qHCY}2P1cWrCP}WUqC66+C=7;%&YhLHx|RABXAQZ#l^$|<6VH7);Ph7P z0bho3QcL8a(nP;v;BdgS(sK)@!=@F^Bd5vI+|Wexq{u_)m$F{<^(;PF7SwexAYZSN z7CVJiYbV-88dN}0W@YmYLvAr+9!F>7EV;n&Y^@1$SX2;VW03wyhKKc3Z^$rIR^Ozv z)1X(~Gb1M9>p*i+cG;WbvdXUOPw&pybf}9J_ug*W+-CljUy|~@u?N$5u z(e`eupFY06y8C>0cYARr;@`>t{lEYF|Mt7D@3yyhBwIEIE6AVWKzDa_w>-PPd9QEb z{^9J8%j(JL(VyhMC*{9SuoyS>|; zA1uq$%gg1fi#KoY_RCkh{qFWhpxoH)4sTRmUoGhM?$681xA)8E+xN?|T2|{nA07Ys z=t$a=cXPda-&|e%>wfpiN6Y5$@i7a&{rrBveY0COCnxKZ<>>U}XpLfG=Zo#T-SYC{ z-ERNrle_KZ#hKvumzND+8oqsZarwSUp!(fT`oDaRh2Z@=d{*73S8p!M=sS?P@RR+= z7eDXLzr46Rd%L{eUha1QpS|7UwW7P-?bo}z<@wKdyQ}lv`B&H{UqL7x`|!hSysW)C zeu91O>SS3xUOiq;PY)M}zk%-U<;B(R%j^9`@et0pWbai4FW+9A{cwe^e_G0GYTxc| z_u|OMkJkr}i{=Y_@dm!7@qd0ii)$AgZfuvk+wD0Pwzv3}nAgi^7gyJJ?{9XG{GFA4D+X>)#Y_2%odw>w0uU?{9?lP!7 z+ur<5!*P6ch|mA9Pn(UT@Kd~=EPh*#Peu6A&OeKL0epRT{i3r_Yb_i`WXLsvFKxpzbqdvkL~~eg5uCSRK3IUj~C1C=d;W0 zJ76C!hY0Ozg%>i{%klBaV)`4^->kJ>e~wW~tTvlvvtA*+rO2@tInp9WkG06v{kvBZ z@Hbbb&>Hox3@+4aE03vPnOM-ljQ{ewmzYAqJL^OV4V$L z-jxC;V#MKc@+35Hss&C?Sbe;# zrJZUytSTMzLO0vn-Bo$6BV{&gX$KBo9ia^BF9F%WDlsOMQBErjmCik0*6;!qvS_=< zw&1hdi~SG9p4IvkX>bImaa1-I_~R1^&x_^e@_t{`Pmd)au;b{l2Lxd)eez_|-K})z z(FQiGpDe3GklkYs$i^b>HrTh{7o(wzeymUNKlI6Lwt##6wowv&(4i#Z>hKix!=36Q z3;5dNr@OJzpW~wvyhB()aj$%-6tWPx<${l(AfhsV-~BMjYRI8L1`(cw|J-~G7L5sQp@bh;cJo^Z|Gm{p>a zkQ|n}H%~B{nl~(f-j6Fx7NsK?bB{2alvHin7CuiWeSb&lMgSx`*2frqGH^1`!b74ft92z@@sP=YxpjRs_z zb|0RTk^i*lJ_3WG=cw}d82(m6EvUz)`Jrl_isI?%f@#bZEuLkbK$XvmB6v_*KQ2^N zys@U@D|KEmoeIpESio#Fi8-LYu;+FP6WnqIzf}gS6S>@sUXv z9{RMXo=Ds98R_|uJCc9ASU%G#OLQ;>NYSF>^W*2Lh|plkc7k!)nzrD09ABs=vI<)+ zG#^a2__&Y0D7qL(CFW0Ldh(c`b`korsLDd*_%TNalVNcCzZE^$f+}HotkXx8Mg6Oy zD|3CHoLH2WTAggZE}CE&>FCj8BxqgTAY`g)E`3>4(E-UhcGRiG$c_I->%>y2B$JSN zb*d175UD5fw?!B1RvZ<^(Piu>PM~rK|^zL)%E#qIigrEt&TUTZJEX_&!(MODr5K9Y#+N%jDxE0S+yt zeAa%2LNs%Ozs1VK6=x1+jZsUq9ukjBQ<5OZwJ9HMMl##|*~Nt(N|p{j#;k-XLxxjL z(kB*DPm_CDjpNeut#mL=O~xK;T20^-l` zBM`4KcNQB~k1g76@0(Hq=CC!=Pi8!B%!jJ&D&7`dB+nyk56}qPV3GC2lZLVU*6qz& zW;|IJSr;s#uKVvr7oo>GKx|keK&)=TbobbbTUNzz4;BjC4U48%txJZI_E^HmqK@2d z;dFk{9U0sW>rNhHm({$EAE-S2wD5B zLE0N^SXjG@+`o!8(hkZ{gkh{~p>z7UEy|dyv9^sFg`5n-e_u3LLY)}$7`hv5qAYSi zL-ySjT`W?|3K1jqXafz6GDchQ*?rM18!{PKVYGmgimr$F$D)g+var==&Es{2^eehP zfBsZ-OMj7(o8aKGRHKpgbJ2a|(ZHY~m!Y}PiT9>lvJzd0-6*Vws@=iAm^PNO*luDr z-e5~;t^k{8%{GpN%XgK@u_(lP99==`AIt2d{=;Y}h1SA^G6C53e1*)=;~-GqNlRxW zLT;pyIQAZ;l|zh4Zp9*cB*~6e3XAI@Vi~}Xmlc{g0__}%71}jloV)FMpmBcvla32n zOi2D7!bifOUaHIXc77mT!(Lg~=SX%5){1$}M~CdUapI+fg%SA(>4qdbmbIysFqf@t zRrgws*W}PkOwn^RlslA7Ro(cke5vluytf?~l0@cYUXiS1B4bv6eR+*1*QI(Hhq8h? zDp9N>rt}19;@V%OQ|8&;|B< z`{s@9QDqH)HI~pg+Gx3e87s7*Met5@2`iF72TnMESou~U9`(p@!%Jp%{)TalrM@1G z)$t>?mCP%Ih4U($PveQqjT(goFXm{B2XJj$`3gOhLWgz=`U)rKIL~(WK-Xk#COK|y z@C|^+vnA`R?OyX08#pv2{X3*1ua)lz`h2bBj)X~2ZUe`+qq3Fn4*GH}f&6T76ZStV z-z#`Z)I@J3;gyopN+&_x82RnEZB;Zu6o3#9jA0zm z-MziWGYdO1Ed&FX$U}e=tkuk$zEAKj`bkD*V@yNJ#byfGFf} z=n%`RcKoq=V#CS9rccjG0h#R}76)(v8&6(H1v)+n5IV&wZ0abz$V8>CLCw;;11@twkVu#cY!#6U{C7Z1U8-re;J#CXh zLL^5U?5U7)$946yExYN~~OjT3^>LLD&gdM-Uhf;BE(`)bDvJbjJ|V0M|cpGf9n3bNh+E0xQ>LPpm0 z?fGlmbEyZSSd(sG;$b*UUL$i#DJPB3Xdj)=f7WFfA>h87_@b$o^BM^?$fbzYNjP9D z4Lq^qsxQ<8*)!oFq8t+XC|~2~zvv2;nhEc)RJ)fafB-(kf<|osskF6?O!uXjua&o| z3=)?G`!NF6*1v0iqTqWcZKr}+25Zfx*TIr2K&?Z@or7e8K{Ye2vl zr9<*i3pPbR)dt$6(Q2xCcY!y=uVhOp4`W%!`$XV{ zs!eU;U~B3WnDj%~g9lQ^*9@jPpro*zRUndWFs4>o>_ZbN{N99LJQcgku|a79V^>%$ z3`0+t=fMzkK=OAp$Y1x=NBUK5C61Eq@#%=0H&c7+32Z>O3;YnW=piJYAVt35}~Xq4Mo zw|xG1*1CmlmIUJ%l=VQjXa#CiEmLP*fY$nf%FO&cE)OA|C1In6?X8_r*s0qF(_d!k zrjIv`@U{k;!}ReWjd(2VE9FWC>XGcBEG3g~%l-gHTwedOyTZFtr3HD~Bjk26wfU=- zf$iZ?W=|h=e@&4C=gLSDg|_*1&sIL@sG5!vv$MR=wkuS)O3oj7`ROhB0DQ^=us*ZR zBhVvq+w9j9R(W<>_cUI68?O{UU#7>$2VTT;{hwV@`QxI&%xr1+^6mAl9!$w2z#~v+ z9;qIWFUVYawwUd8|9sWP5XakBtF`w=IA1sQ;(mQ1I2dxa5I%42vJnmp)_9VW?c$F^0_U7*vNc*`+bTMuz`>nCN?&;6SGxx1?~i zG>PHp7xZ;6M)A{)7;-l)B0S6G4Lj`Y?{&Y2Jqfrkyk_V9sZUjIuYcHGg=Z@(7_yRQ zD{?3i64BRmx4SnN@-)H@Q_J#Zwy1M9_-h-k^g7IG8n4yvj`GEJdEI3|`4)@)J-$|{ zKJF;Y3F{G!c3SAx*R&|C5$9ys+|qDmRGPb-8Wo2c*r z*jw;K{f0`|Y`Q7i;koD zR~Qw2+1KDW_FebYk6YqL>y=&<`}cX_9K8y(iN z^6Q7FdkGInY?UkT3zf$la(tMVigoz>bj|BH%iMXYdOm(@K54-0yu+fE*YElE+@@6SHUyn>|k%^Yi3VLc45!>(xCUu z<9OL<&<+>$?TJ1MouEJMx183BWNGF#pJP62gSH$3A7SZ~6Zc7Z-ui;>wur;9v0LN) zk|%iDmm8?O7AJY;wloUs!k}eK=~P)1qy~?Wx*A}o0fzfhd z3QZr%3wr2s>4w&hh%rjegM%G{X)I6dik2z1j-+(gjcH z^LTO&`KnJ6nK;UUalFvroL<>Bm9qnOq1{YE-rUpHJzq*<-;k`S>O2c#v0A3VBZR+Q z$?%TVBK5%B8^AVfdK&db>knsn>X3(#e*dQgQP->T24UXSdyk$|qBQF1C%-xeu*vYL ztZw7Y3AfnED*XP3^h#cJl_UT7x~&)U-FMh|ufZg;AX#GyiHTMF)vYIWe!`Reob#TG z_FLB8B|Is{oRen)Us;78?~p>i#|p2i_GVmOzmZ{!%c+G)(f<{W0>qYf;mFH)$J%!} zlxA#eHayMoBJEeTq(~){(E*TeW6`BHePRbBR}tinSb2Lh994KD;r9cj9iL0Ekjv)+ zUTSAsUmx%CJSio7O<+n!P2SD${M#!JzkDZMs>yZ2Z&JI5eaVOUjhF6ttxlHiYgs9$ z3BlvxRODZ)@^rD|qyRC0vfvB)a@D7c?OY$# z?=S{L12N!r=Mzv}fCeZ`@IhkBo`C6FA^}p;Wa!^QuV2D?{|T3#f^{nMT#kRw$sj8}uKg8Ge?cHWgouIc-JmWHoN!WcG4m-#ea4WEo=m4+d0kp7_| zWH?8!4SEx{5GGL?=2j#IGZpiQCP5nYR$m(Wiih#9P#^(=oINW!I6kHWl?F~QNdM3n zG@RYnhOr5o`;sW}gcXVIOU2xMN#LU*33~3(b|Qf&7Fa}~KqUt0pENSs+hIvGW)`g{ z(2GIVLL1J8v#*n|`8tUbAcRVjIR1)~fApJx9WcY-iR2ulnAnRr01;aV$N!Ws(M2VlQz8LgW z%!8f;iJz>##7~L`eo`p#lR+MX%1@4u`AMaLpA7O;>4G^~y;z~L$URY4Hinb2ooLKYS}gFBLDoVW{)Tg^CShwni4s3q zebLvcnEN^j+}BCa^OLp{_(`F_PYMNoGHBxJAwQ9G0!cA$^);qqp%0as;X#-=i^PGr z7*{)py;wM*Fj5IT#<&^MNQ8y-Z(5EK`bEo?aSe&vxNyvxaRr__V`-u~u0HV{2?Oa7 z9+;1Dk7=d9ARKcbsRSZq+!J$@D-%lO;?4h!u2`PPk%iI!;|kpWW2ukdv9u>lYCEzf z2?BKz9{7`ScVJ~o7Lt2L@-dxK1%Xo;w^kc(v5@{vJ5oa1iP=P+c$N#tu#LOmVH-<5 zY-4H9z0`IfV8R0n6CS9T@rR-|B;^{(K*tkNxs z#$;O+0@XIuGcISrgl1dO`Y+m4SIpiE8H(aaZ6w(WyO&2YAEhH%Pp!4aNURkOv|7AIYmG(P+i&A?HvO12d}H12d9&U`Dc@ zJZpCXbyhSGXGH^THgq1BA!X|D4}58mRn*ARa36Jbj5wZYQYC>S4N3%Q_=Fu*8mQ4A z>t!P#!#OLGuzHI~&C2PYjK^e1HF_o_L1IB`CsCl{f&UZ=so zTe@IQ*v<+y_chirk^Ui`Gd#L46?69`fsdjj=($bXiNvN@U^RsTr5WU&sC;HP8QY1* zOs2&GjTvMuG(s?(Q#A=&^GT$|iMp)5=<8I>eVqjE>m=yuO4|usrBEO$g#t?%G;#Hi zpRBimpd7P$8bi6jheyroD##pVqCirPC6;o*gr-a!c*-&BY$FI4aQL&d#Xrl`oy1jM zWz2wF(DVi+6J2?giLXo$2+Od*SdMv2DrHr{n6peANXs!#pgz76+VWz}myJ$bX1>gV z=*uj(3W)N&N*_AT-B3CY8{tU`%Kx4us~IXHXyC388th=F7%0E=z>wg6PX!(0!RDRs&I;*Vz-A z;gQe`41{J_AT-C^DV4NbKxX%{F`-$(KxmFxD~%~!z-gSNtq)n22+gaEuFnPC^;u#y z5Y>5|J)s#M2+goSXodwsb8P1MA)%EH1Ugg1Drsb>IP>bD}q2{iX;+KctT-C z7zj)e>t5p$g*ocIti`;SB;wM_V!Zo89_=1al%GaxX~)q?JYI_J!QJJ?_r!@lq!dQu!QcryzlJ3KA$s zk+E-wbfd!{@Qp!MNh2J?J^O3kI-V&gmqLJXvZMyWgGN{bEK27g*u56 z^;mr|*r}LDI|&l|Sbh43R#*xI{!u6pkU<`U%0P~fDM+P(gADRa>4G_7AuH6}*OB?(HR6BlVak&F}zY@|@2BZJ%%m30g!V>{89k+fK#B!jGlHt-GS zR87Lxd=e#EvihR0Q!)2-61cCEKz-fAft$4HKu!t;b~0$<>JdMEh_~P$t=;kX#NB1Qb(c}=E<-WoEOA2^ zb3+(YLn`u-_`O~kz$f!NLp_H>iw$AbW(cEZ2t(do#=N_XX?GbhzY_#9sC4|%0ve!C zU;zGP)-lw&+)$<6;2DFGdkjxLGJNbP6Sk(CH6}_fGd%mv1lf5e=sjp~a--tGmkI@k zDipkGP;#x|%}Da^?KOTGDf(BT>|e#Re-)qjSB0%<@~?`re-$72R|NzAsv!AS;q2dn zNBbC~nJL7!=)o0W>b+ z!sa$s+u|qDoOeH7wq^=LW(h-V2;E0sag23{MORYrgpO@lt>Jyk3R^#(inGq#$UW39zR!*U?Y6&3gahBD#Qus%;Yx>h+AKdhKTw zLqgorb)=7RDg5mI4mnb9Z~?M}2oP@rs^IT3{3{vYQ%@a$Y{;+{JB;z>FGf9hzTiQf zHF$*8;1Q-nhAT545rjcsN6X*qpl7I`5un8uuxhh_QL}&{w}3IXfU%DA(X?4WN;c^0 zYW43j=J}IFg&_-Zfau4x8E-ZPwEc88!)7W&ZYpDLDq$FD{3-W2j5AgpcF=$Fnib<9 zW67Y8KEznfd{2-MFoLjAqu}@jMusNYL+_KacFvyo{oA26H-sy2XEWC2)u#(iLh6nf zpPUtZFahFTvublcqtY?cD1wt66!_YyUd#(5sH`KV5KEK=s)7qz7o^Q$8{b<01&s5D8NDMoZYB(wd$q zq%jnV#~@FtaL-M|X^@2$(s*NO7^nN`$1*F83ySea+2Y#h2|CxXK+psBo{^L*ioz#+{J?6G!_Kc z1%a8@ycDF($g#rMnOsG1X%HmG25D=#xmO7=)vcFnBCRL*#7fl(uEhMa^M^XZr| zrCUa9YHE=7IGABjvc>RZkl|yiOgJ*lM9DtGvympqmYSe9*WhHcrfjg;AT2>5H9XmD z_}FF>j%+qjvf1!#vk9`zCg^Q8INMCaF0?4@6SG~@{6iOD-zbQC` zKBYblt51W93+M2%G{=~weV|#EqD{gOa>i5KgK!*tQVAJAct``nLoN^=5`uA$;wbdP z)Tp5eiP2E6u*R*4Qc^S#b%|1<$?Ly{(v%KWy*@E&l-XoC6`HJ1geFO8P(>jL8k$mo zMB@ag3L*Rz4Z*Ky2z^CE;2Y{us$p-U`Y)mib#REdL0(Y}x8W()hK~bnLTb9NPcQG<>i9UCDh;7jD8x~r5JZJS1PyYp*YFum4y>YZ{1-wP zC0=Lsd=#gEM)5eVQHOdrX++JSD8~wNu%kT3Jj(mfM`_A{AP$KTB`F^|@i;AlQpk=V z2}u$pAy=yLI0W0U5N5+dfDH?wb`c(d&S3pRIiNs@ok1yfj*nxf z(hxg^LhKX@u~R6-&LH=Cjh*4-Ko@-}hYe5Yla*!2g2fQWiSgC~qZS>8JTQ!TOc>K} zFrv0_pSSo8vu1(6C&`dmzz|!&c(Z^}vw$JDfHAj#F|~jZvw)y-?$7T@ekt!vk%GTU z!jR=zfaq~G<3po%^kABmv#s@25>^}7iigdl;jfY~H1RsUn#kI@C-KL7-P??5W>w@Xd1TCW+3y=IB`nlYVALZ{6Cqy=B|r`+q{YgQfh+P^xD6{o$fzGiLr zHDl^)LO|H7Q+wj{m7G)3CvY-<^6Y8qG>bMxRSPjRD7nP&aWqXha*l~oTn(SO$;3Ir zCP-m6JjGh^5O9O^4<&-(51IJQ+{By&R^P)W4${HO<(x1`*AAh(aMx4AMW8 zKZZA3TgK=N5HiLftEJ_u;bV82ur-m&rHrv6Gk2OeXN(C_#u%P5M)8m_22D(ykcAbR zo0v1kiac!MAY-gt&KMK)8KZE>7==Q{C=@crpp-F&H(M!VXbl?kh6UNRES=;KtF)#m zlUO0=6HBKqXQe@Iu{dWKOLLx)G-ewM9(2qs^SFXvbIc$Mx%h8!%qSzdjzM0sIAtdZ zV~&y_W-19{zOo=^ElZo9YVN))k41f*k55)ZeeMLvx0R&D*~+S|1x76|8S*@1%zen1 zI*t)bGJ-JV$R1yyF~r?vymgmR>n=kvMOfm7FlM8KA?r0k*k3(a+fwIcy^_L^?+{6g z4Pn)02%}~QL*8A+-0zI3-x)Cr2s*pIyuPA`>Ms}Dah+_cUD$9@3Eyxrq`Vrm*vg}3 zJzY!-XnS{`>-D6g@@_nr9vJ`j{mt7Q3?nmeSFJu&db#*rHHN$%!mfkuzHy^IhC2X^ z55wt~U05;ZB}?2^#w;%x%2D-=8(Ghn$zJBmWPmJ)WPJFgPYHBBv$b_BQMTfNw+-qiFnhT<+)HXCYK59@ zNo2MqJSIaDyXi@gsNK4d_+9Zp@&=iSZ4?@w=-zM+Ybw-CPa-ot;ciSGv>ENA}+HuP+kao{G8KlVFxY zX;M>r!px>nnBELBtNTGcp6F;R5~n*BxF6fp!qPnTu{8L4TtQ28ng+QJ_xrebb?;bQ zojew&>5&`GlO##wRLKJK7fnDNtJELQ!7d11j_<* z4Dk<3^JL3XcH5+a=C+A~xoskKk4(g#NE30Ikh$}jNJ*L}=OFB-XcESWngtJfdN65o zS@twdsjSjGJyRG?<6MOg>Nc6P)MGKJ{^3{*rgy44PVy{po@@NhQg4%JoWyb3XTgJ^ zm@NUgg68aT>J63yTs*SDqzd=C z#03Ql9_-m{alsX|fR1x%u+ZS*F`$zwJfIWt!^xZ%Ak=*?b z{2Ms}ttaaEWHm5k(*;A!T#UCC7&QiB$i2pxyNWR-dq!*w5M&2$^$SYAS$rroNX-hi z8k7t+JXvk{*mM()>^D(zg5lW{CdlqELGKfTlVcQ5-cdNahztvUVqD8o!mu!TjD_^? zN%4{IsFYuFX@O^9_99EOD_Pq6lV!=NBut(qS$1zVFF3cM$+b%WH5 zl#^AxUMFboZnEsoChMKqB*~RklpI+l*^S!e;6sCw0}W5!Gkoki6V@J(-%O-`GM-b= z3S@Vgp!b!*$x(_YFDaZ|6sE1WsV?HPi-jW)x?iMtOE^l=mKv z(&XqMPW}$k>~`yGaJXa1)h$#o`3PBT2a z%i0X?axA&a1<7457`w}*BX_whxyuFCb8?qU?C(I*yUR-?cbOo$%kb>3Qgd*YBFR+> zCr2qfc9Y6RPEtv7k;2(Qif8vIUj9o?Q#84zz{xQMO>X&CmaoTt;Dk@+4u;GX46z#+ zZ!Tce%xB0=XUxrJOigCQ%q0lNTlH%vzOAoVGQ{0wymgmR>n=lqxk77h2y5FOlp*Ui zL0i0cuv*!p?r-ZO{D7I~1ID%lK{F=6W=+7n(*bn%2T=VVATx!r{)z0j{w#mBeo`&O z5fGR0r}+WXgW;$*GngLepEN)68`Pm{^8>588yFjT!B1)G4)xmwM>BPgh)*_Z7~*c% z-6B+5m>Bh(^9Q?7^xm~TPpaQJsge#KtAAI& z+>{lJQ3FIbQW$Sm*0XHXNjFkh*^FmRH=eP9@y@1){!LKd37b}K#V1QKhP)oa_#FGY z`X#B<$MK0ZRGXo!ox|C29xJ=8jP*y)Xeme4`Hl(_-PL!Rz6Yv8Yw=xv0f7(8?E)ZDW9r-*<(>HN_lAUB>%4~%z~tV@aS!k*4owH_<{K#)l-ShpM5%_eajCMFN=f9& zUYXPCbBj^|&#WZq3D+u0tgCpSUW4=xQL^D|TjN0!HrtZOY)klzldVQKJ(WxBYy}cU zD;{{-ApJv`YItI7!`bwfNG5EiCsE2?E8@1L0v^^R7^iF|b!{LqyTcv5D;zl9ApMg( zl-b_&AM((U_pRKJ{7vSAqRs$@yZ72OV1k+V@`RuT_$0!ZF4{qr3tEuIFm<3 zt0ql{74s+Iqk?YmNak5RlJ!$oYb?!LRTL(!hMGs(oY6#V_DEheY38fg7nTE~f^l$+ zG~6*GS(?pSn`uI;qA;g5)U0p0-9%|-Ya({csA$!s5mm8m8XQgJW{)cMd>F~5!yr$0 zwXrngk))gSswB*N4V`;2&wj1cuXu4d2e#6~X|RdS$!)@GB6spg_JEV~lvt|_vtmQd zEp1wABDTHFXH8!J^=KqD<3=JkZX|Q#1|14hWo_J#_XjCAnJ`Lsu{4ENQJzJsXgHBpX_!kJIv)>{8MPIy{~Ec?kJSc-Pp8&e;r#<{8%(gR zTt_b3|?6MV1DkCdX1$E|}D1j1uZ{EY;RYMxmAY4QR8xP{0-tP{GeoHoRBLzxYCO&r#HA5SeE2fv zjLw)2*NU7iZ|Si3Z25s~z^7n+E2O4{k_v_522JYFW6n^ALZJ?WW_4f{aCy0nHk=t4 z>v3>WQ#q$CKS6T->hkvD&0Arn8rxE6;a@0evYj9DR)*UN1=h0oWVyvq=mrUVuBj{A z-SQ&^Xt&@!a+3W_;o5~?D#9mA!1|sCpq6M2RW&uSF}J-E5iC*7Y>wd*n^c+&Q#@Fw zP%u%UV5dTOy3^Z`EjHDW*_v6&Y=wi_2Bjz(J~3OR*=)sw*$M@-6$)l66wEeAtt59C zJ~X>MO31c1S#$v5*$X6`xuU5I{LzHbDGiUFX?S!`!=sM~&yFJD$XgXlzN(VosfH#$ zHPOUNRU!MRih_qK8vIky;GK#F-!wFNritpmD8btHDm$h=eTtrGaCS|T&3sce2F|In z=$#5j_f$Cgr^3-e4bC2FvXP5)_D=4x)fZ0?1|_!`K5>akvpWJ~_k`^5Gv8J z5+KW-fVsI;Blwd)S&lFivV#Q4QMP95bJF189Bn3h$nfMQ$J}Km3L?WPSU&_Bz^C5xfO>ZeH1aX>3m zkRM>LLmQuRpTl7*s}4KphpVg@j}=%l=%asYHmlj;DM6S;_*3pR?M0g+hmQwLIEct$ z3&m0dqjVU|pfYk>R2YRgXryQdX?AK5=Nw>hNQWRuJ`U1x76+AIGd!nGC_c-gp!Bfq zIk!ULlx8dq85aZ(I%brIS90i5Pi3yOe1J5`B1E_IgFt)D&~-Q@$ETj_0I>yaC|#H1 zAU|F=GGGpMDAlM&%&M&>*0IQ}5*naH%Kc{H!~#-*Pg;95`$B6CO%^rLq@}75+R?EY z8ZjufVECkZm4>>*5C}~~NopyICk+Or(5{WD(4u3hEf-8$F>$D0pPPm14NA2eKB-)# zp>8{9=TtB#)ou8s?mEtDPT2}zdaldzbm&`3UG84r=_aH6i>^1(Y4ACAF8*pW!)LeG zTbv`0WTZB(6JPN%DtBvKHk8@SHlNrj8C!hxxTEt$Vbmf|WDn$gyhF8Gq zj86^egBtFQ<~J8SgCqRr%I$Jy7BFNH3Xlhe!SeirynVYMsY&77a+x4Rhd<@UeJ#ye z>^{bu`vTe)S`3?48FH^O=3XTX491@idJL(a|tt`wpEnvPdXNaw3yjjbr znZ;0G{Lq>k%-Tw>LCtc8wCb*?j;!0|U%@S4g36$`ixU7tmQ?}rtO_8H@+Qz!3B%7I zOQM$bhNppOI6F8MYFScCKr<)z_i=sND6ZfR?h zG>8=sBiW!doD~ma+93Ut`j2pl_E~4wZ+ui;GDV9Z}!ESY?5pTH1D^=$4>IH!S zv=U#$Ce;ZQXsOHxiU(3KNdM5dG@L!vMyLs!r;;cUg%z2xg^Ar+slLP;Rv?jw;sXXz zL7)+Z0+$%1e~4oYPpsm&Cw$K!`w*cf)rtbY801Y?+BQ7#i{TuhHuO!{B9uglU#y6S zAQkX@O@f|ZtfIs(iU)o%$ZT%uZMgoSap<_aJC#WMq9p>q7?k)$@xU(zP5PJl#q>EQ zeHVxPV&&*yE)`4sVr4vDses3;7X*IMN;1C~9&j}kol3N>~W$lR%sreC}hUu;#1yaC3pIyh0LK` zI5R0pM|?`+$f_iW+{%K?uq@3y8>Bu|X}uQY^r12Gz8nWV#TfP%1`P48bgpME-Q{;Pm zOGebOo0|!44ypxy^j9tFrI8=&o6!~eDJlJwmEOBj{hE*WRjEN5?P4;0O^dzv>3QDN zYmZZjDhY+2U!8xtyS@5ydvUwRcZJ!61Upd_uDtS zxvocei`-+~dcG2ak*93w&z>PN4sn1n@b+e138D=IgV!J9xL`021r!e0zKD zGIa9U_U3Qu#-n4o!~GBYv{@hH)6+dJ)WGcJxO~ywM?3$F6Jv?_*LUZC`))as?8HC6 zt^Y*+ilZ&Bm&3B;d$t^|m%l9E{bM~i}K z*oVvd@EA09v>YBIg-%eP7TClB3l(EqLhmV*dkBlvy1w>!Xup zbGkuVz+1&6v5kw|T;A`C`srhIX*pWs&j~D0}qW;V7 z_FCQZSkry;1ny}DbP>P4+7)f2-eaV!)a>~L4hx>V`$;Q?_oNdXr=u>qcW-ZZS}*!4 zHg1lQ+O6g;tgpe}r57isr5BtyM_oK$U;Jo2UTe*8cZ)t|htTK!#m}W;Jh*Gxtsh-9 z_q!kQ`;_AA)3w-mddO9GkyPr_$a`0KI3hDcSFXVSrEa*oxa9N+yQB-FUU=@)``7(eSrIw75*oo!5@yi6 z72e`;_eN%a(7$vC!I$bWlBoJFu9*1uWoj(_x1q6lf?};lU2yRr2dWpf5G4@EYi_d38adT2!6dLd1^SLUD9=b{ucENd3 z^dyBa#bfFw%`Q4$XpJ(D!aW$?&6g5-_T`sa>66k+_9ez;Q2e)6r;MmrX&0cciZ0Y( z(rKu)3((ivI!Fm4^aw+VI@*QkCDn-)LNi{7hAsN0D6Yg$Xd1*ws$Gb_Evk3AtxKva_tzDe{QB<+GhDjLl)O;7F?^SVA6gl!wx*+|tD4v#yZ^gZQ(go=i zmi<5MaAN>3-w5HX+Y)C@lmo5`#=Sx*n!Vw-GJ7Mv+w6^mi)FMaS{NOnm@KE_!U%JE zD7W38UD$Wrl`cYlSawQ0?LO&ZdN1p9Jhi&jc}Z4aSYpTu8=Gz8GK`(jP+1{1Ppr|7 zED#ac77-9^D6=hH0WK5cW}#_Qdm1B?!zQWEp-8YTa=MQGWa=zR#>xzYNg>17sMKxvYwN5h;^Wg<-ZqA z)CR9$8NI@?iY7_8M$jEQu#2HC5?Tl9Qnf5{nN)ON_DH&VjINUT=u0q4S7q2E z$>@)oUHEj3ipi^l8f?k6cHz5GSE>C+N3q^6TK_7#HCo6auDFZVZBfQ@3*8O*zQS5K z7`88(aA@f+SdeS&;-&0^p{AyxZds#gY{AT--uqJT+V+WX2X^IEw+q;hMHemy(O?e5 z!k2WrQTJ2PE#xji!-}ryVzvo=_*wf*ESGFx*BhSh~&LJ#3knE|`U}^|V#SD@v_oVTy(1q4-hTN^9_PnsI*plZ^*G(ZCr6jx=y)R*Q8mtLFx? z_1IuN0De3MX?ZK1-(-`G(<nAHTl5#&LBCyi5&Xp(C8Ekav%}^xyAVcUBlxkFc}c$f8MB zYSy1_6rA1P;vD15QV}gcdo5Pfanmo?%UrmJqi|?g)&&^qWi|wjx7l#jFW&uxsbwbY zDW^=>tZ}(+ki5Caw@d8a$<;+$h#-+s`4Mtwv#Gu8*Y#4Ybg~v(Aq7xwgIzn9>$0Gh zqud@B>~le9Am3}zOd+cZ=6{(Rk^3XfE}l3_-0pP_L?v>}a)fc%j#*ZSZ>aiw`{s@9 zK351wiNEaUTKrEsX44Y&S;e^J6zCNi=1eZ_!+f!Z<^uYRyR;yYmj#qWUM4K-SwCdnRX%-O=u}d_(doKh#zO1EE@&{|9TsQz^1QAXEt?~?Ko$ix*s@n+!?&ibhx$h{!HSCd zANz)&T)%)oVpg|GZ7sV-4u=Al&ETp|=EA{2-EJ;Q?XndT|H%1L9oh1LG8Txv51W>C zf4q;G6;C}eRVwA8uVqI9UT$4_)Vb%A`i#4ntdAQuSXleq)fce$mWm0s$wxzN)b#rH zdkmsaM-7c>dj0q%gi_3ROYqjb8GB)>?^YdZeKX$&yD>Tu3XILU-RBoSUYu(*FhL5J z$*xcqxFwZR{rVC@>AzPlkDbTb{L3Ix#Ft(tG8Yf)w-*ORncZ6FuD(Ct^ixqgGMqPJ zuS`fIv;ce-<_9IbjZ_Y$-dAxb)ult&l7o+GW6FsA>LeM zn(15O`{H9b_ef$tHRPKXbZTK9cK^yuF}h^Av=BD>z17cy8R(TTEM97u8u5|7V=XOU zSt?1+N2-1G_f@FFSxa=dr^JDf)eltps*oLblU!XFnex1!^SbEOmMP%kBzqEs1(Lx!qs~buzX1 ztCoB9AE+w&TRn5aQ31xNETHP< zwXgmQ;+e8fhO(?kr%dxz8$T57*}VOA)5bvd=X&$ecHVNyo_fgZX!F(CH`INaQRdy( z-#62kbi^{dni<7{K@QvR7OX#?jP7&zrA zl5>?fwC+x>Ocm!-fofcCvCqHjmq z7;sZ<|AOnAO6IQ5YrY#xZ4yd;M`yT2(XOV2VB z9!*zbuWqk@*j!#PA<+D|y$RV$KuepRM{j zsm(j{&z44{JZ9hq*d3W&h!4}byrMnZ_4+rT)zOc59f2<9OT%wy6IW(XDG}b2>HGAw1HC{yeMg8{TUFK`#%Up8V1}Qy;C)*~`BUQ>vE$$N^=1*`PP}i&p<{n#t|^ zD@y;{D46%ie>qbM(DHOXZ0w69M4xvH({b5;DbkF#iETQ6e9=v8WcK_ZCK4jG3RV!-@^h6Us3t&afU>v4x42 zZAMha{d#v_Rz12C(WBXR5ZdR_MRU+^*n!30XW?Xe@Qm*{jpdR|lHPb0KVSaa-Arl0 z*4sznEu-FyvL40@wYQiJ^$-=CZk&|M^6D7Nld-41X1+w9uxik4&wRgk*@#d5Ro;^I z=K_7VKJD2RYf5ETJR6x?{}~N#e=~EQvv;@Kb9~$6t-ett_hr^t>mK9pyaoCm%MwL8 z5S|XePbgJ>eF^jl?SSg4VZQ(Qtoe2DyrTCj-m-tYz0{>TRz0#Y#Iwovazw8$FJ}LD zO}hN`c%0^l-+Wtt)sAG^igkKC@lAf3B{M1Zxj0CiNBeopjo+|V@^2ySf;^{jyT;oF zo)8Gup!ES`?^=Yy#$90@i-tV-tq(E#B44*y%b-KT$x*|6bM|#Vib^Rt=0mahQ2in~ z*y$5wHFxkirh2<(zUot?5$!{#OrQ0|z&&QnL#ORen=y6eI5p)dO@0y%#O)aGIn25FX*~n4mCMt` zVeIUO*2Pbr+#tibUw`SgbN<%feB1uKWe4%iESEkZW5N2ikbTIP;k$p`j*?HZq?me@ zcGvR29kVHDWGyfF4E^*;w|J~G(tPQ7)eLWJK7A~C*Jlz=TQrlfFKX|V_QT@x`i+d$ ztLr;I2$OeU(f7D74X1~^o@Kc!ZW)`?>Evnc)Jvn`g(P|fwaGo{^-N&%X7iI zYw3&Q58O>RmH&Y^)60vnLRBYtUE~z6VxedC2KxVstLgud82ZKY|G$^g59J#Je%qz= zQwgPBN?$#eyX@s#6)4mHhu%uZVVdyBA@=U=s$>89lD|_~Sa*eI;`bA zfScLY09Z7=!}wp`GqdI&8qHF5Zg6Ccbq}9`kbN zN}=}dsSNB=>JYc~s1z8LONBe>*z~W_Sb6nbE*2FpW2F;H)GO(7IakO-R_s3AAU;94 zObLMS2pJa3cjBT92um(oYV9~}=l+B%=~!dnJw|!o{}6Mu73hLaSJGGV>OPWjgV|3U zZ3ViZ)2nDW9zY_>f$%YM#nii)*Bj}w#E=;iJt24YZ?4%}cknqTZ+XkVCX=ix*;2od zj-cW}BIZ|8?Lylwq~oZebOO;K^)9CMLb@&?<(nK@FS=;f3+Z?iSZc;{<+#Rvb|D>m z=BnJP?n2q_qvN1XOq4G=@Tg!w2XD0d=vY;%pF_91Al4T&@o-zUv3zYk>0;Qfqpy(S zqF>%emDfZ|5@IhEI@4W8_so^N+SEew4i(3M&fex$BKF#-5#az0a<_HMX#e{wO3AL;92Tu7fZd4u5}`#sPQg{ z&x`R0m+T1Sf4-KKhu+*vy^fBt3MI%$u^WbZ9o>5=jbqcK0h8kauJdo&czKl!N>pbT zDZP%4m_jMc3Br(Eqg_WA62ih*V%ZGp;-lBmF_2Lwc!dEtWM4$p) z5Xp0+N^Tg&p{f2Zx||Tmu0yURP^m7U|MAP{atBOTh8&Up3X481lebJ|4ggzi>Kkk_ zc?6%~qrPPdP2uzAsxHiW7afbxQYj)LFXE_ICwI|tj!|^WQzDPRv~hhqxDAxNeKGKBS6)#Q+G^ z?u#bA`vu3KV4;x3GTPY-cV27BVmZ&OjJ1-tDp>cv=oZ`H2b_Lwz;HG?;K!i*qwC5% zDVOS+W*4%bOw-w#ROOJ6JMeQ+)hFa~QM%TN89pe!*E-7`W2AQM0Fomp>qT_kr=Ufy zwu@JH5gltO+l}%XaefgUY+FtN4?!&d9T(Bd?ph`W@JHia`J%aCMt2ciR?{*?BW(|5 zi&3VARa$*_7tzs7p$=JqZ{#wP73*A9&kC^4Ef>*cCH5OHqGN&h2$x;um9*b_5nbjh zS-6(Fa0s<^s!Mynh>n3SLmK~Usobx}=^{FQ^anP}O=NjOQfI?ezcS~m=(01D1+t8< zx>#Fb#D$22o9LLG;LmbIBIC+T=*B|3=Bsa;%dI?_3J*_sz4Plg(Gh$pCS#wRAO`_F zoa#N@dZYYQ?vu;Pj_;Fqv9I^ZYbm*yU5HNJ+pejGE~nPY{dHQ1j0<+eSH6Npj!jBf zd8H$7Duy=fBKlCZBQv^*j$K_jU4ggS>B@sQ(J}8y{AD9g@&A>Z=;K2D5`SUx!jVw|LQ3}`>X|FlFpLY@pHM3*t}fJ8?abOZ}0-8cfSp&>D>xq_LKz2a)%PN z-xP#v=wMl0VB*^&8#nygHFO;B>DkQ*{t~D3n*cwZs5jANL0^_`h3_l>_DlNqMvR2) z2n+K=Ij$9US7J$P`TFYW8t+$1feqM-3v?r?du}OTdL&X?SRZ zULRp79?R*pb*meM^z2HuU(z)ckkz0U=qRueSr49)rAHza!N6*m(`A-(Y4t zL=qfhU#x|G?rHFRreUJfUN|b_X5H zp+co{;L)gbb_@Lx#=R^LdC~dn_s}thg%IUi0UEPCbPpZNM2vYk0;%hPhwh=vL5!Sl zlrs}dMH-F%L5|%+$9k^JN=!t*;U@anhW6qF42{2a`8ML;Z9UT^39@E-ITF?Dfn;{i*)7E@9-5P8d|ydenWH#==@8 zUPYH6$i5zdZhh)sVu)AKs}U!a2KxeZ6`l6tjRkvsx{6K*4Rif`72P&V#~_h;F}jK# zy5-BnzFYAsx-NFWw{yGcD!Ob7uq439lZQzfx>SFA)vr}93xP5edhPxydOZz4sVn2Y z2;D{hO@8g~qRYMx!x_mjZ-cI)mjQ$gwv3>86w+OE@T9Rhd;}+HQQ)HxMtP zD{W$_IZxVj5nUGBmBIV!(;GKsP6a37rv}Q4x?|V=$1b8bD`ZX_jt;tr?wJARKCZKA zZ%4a`&Lg9)BYO385#4e&K5^(v(M9yin)CFdi|E{^Y4W9u=7xuuKE}p;jouZ5A zH4<}*;*01w(ZH$(%aRl1)j0R)B6@wgb0QBchMAf!qL+mbM$l2%<@Ofz7ttXvGdI?n zZKKc^>Mx>m0H>tM7tz}!GaY$!6TKdq&SMvDqRU8?h4fK)0?-@L-9!g9NkAT&huckb zdxVFKnlc*SME3y!9+@bMlpa8@U)$cj|r2zGypV_UY71bP>I!++4eDPk)1UyozqG5MhHl zwVAG>vyZ0yWxwqt4a`Uy_D37W2{6j(8W{XLq=*9TW7X(_M7eFROvs z%8%}%W5Fv_3~x>2&3Dl$LE3Rj-yOP(PLY_-5Of#4PFC}{#k=ToB8~N%>^tOf)o=#t z?xM@%l5!VaTqGyG!$SYDyXZ~=nBwM^ba&C4?bAq1?xM@<=zbQ~$Aa#nQ@YMJU33?n zCbwA{@m=)tv;#Y9IR~xhY<*|wE_$2RrnEkmFtS2R8!Y zF1m!bOyu(PXgc=OU35fP7p%fE@||9nl7U|eF@!7_31KteY`r?=F8|3fnsjq`PuA4 zm(hJ7%L-|lsB{^fhQYi?d>Nglg!#Ck%jjXpFdLZhGI}Kzd1+~!L;Yp+VD@ZfPnXeY zB{ua^e-|AOx8)JZFsJD*Iv)S((;PWmpAVYuGCCd?l~Z|a+a6f8g~^$1o~E8%MlaK# zyjv08R_N)DE~B>?Osme9(Jh&d5%YO6@nv){yr#E2o}2Cf=rX!3x%D#ol#t}ty254j zM?y^CzGL~$h^ay0I(pd*$lfQs-`9JLuA{5Rn0kX( zvF9vJ_t7~`rnE!%(Vf!ez;C*6r2FWF*5#R-+-aIku6!RIYzxMfpE<$y@npKgrYq?% z0e+Qz!L&o^N_q_kmYVZb9bHMMT~~e4w5M9SlFn|Oj;C}b9s4d_%|1-F{Ruh<$WCqf z$!Xs^x{}@&kW*XuPCC@f9C(cJJLkA|DZN%dKdGi$>7G%t9-MZkyOrM7s8jZ*Tj`B< zrU}Bg(!u_9MLRb)-Ab2iJH^25F3MMAul9!AJ)(Hd{1qZ9SOdK&k5D;>K^7$hfS zvVR-*E8R*jU9)-Qq`oWJyTEUyc1`jb^YHK z(OcwO5lnB{UM;G(h~9zLcA<4`5AN<>AG}752d^(KceN7yf{9eIU0%NYco8vvMGg%~ z*{!M`++1JCPt6>xOCel26OF}C>4_-6y0|;o%09=hrXQT&?+)&+5Ad7oyDNFQ^WYZ0{)!*6m+xWR7u&SZ zf?uEaLJJBlch^fTv~VG9>H6Ib@(zyOADFXihqYE$_{08>i}|~1i0|-gh`0AQ;-`Oq zeewE0zNTtdyn)D?WcmBYpM1Qiq_m2bBrUFfxWW%}9pFj94Svmif3Uy958%ST#i;G= z`_cilDXF2li|Z~$7d~`d=}N2?Bje3Zf`>1w9Mpsj19Dfz-YIc9at*&;e{lEy28BJ@ zYNCm35n0Q$kfYbgQ>4q?-C38ewFac>pO!C>ugHd%FQ0X3TPyoX9frp zA+i$SR13%uPd{(&iZ{?pq?vHb-CN1D-Q{`b=&PlvFGamj2-HzE)O&}c`q%Fy`)=?j zlBFlW)$;V?&!vA~;!h;ZclZ0dgSXoscL%4!hx-G(AC19n^iT$ns4SwgoGzlWKn0`R z8AOKQ)oyzWlDgVqD!>)!`*&9dho!6tKt#B!4$l1(N{MXwuZM+yW!&Kg`PKQsc3(Uz zR)DMUE9Ym*_Rv6op|NcD#j#?9Yn0Rob+|;E=CUp+W$v#kmFZA3jw+MIpFuiRTn3v_ zm}UC*;AVS=spaYb%v+`m@bLA<_| zbLj4!$q%ltF5jc!T95X9(R!pkt7nmV5JszKk$Pm3F_vGX9_iiBH{w{Q$nF!VF4(k6APQm9lk;X&d@=m zbz@Ou?kxip3!S31tZb-huP@|RDrIo(-{L#u@J~u%89*U}!QtuIBk2bbITSWQSnfPMY3#o7}v)X&fHd!?5L zvxTA7KBpo$TDhk=H&tMV}8 zvS7N~{VaPrEPOtA3i7BW3!T@JB^yu@O?yeqr$5WSPgYo^Rh`xFn{_|PO7SH`tn2P46UjPiPh1yQkC=zj>niSQ-0m-+dAps z4Aa;f$!*C?TU5vlDRb=o{)4BbtWNXw0Km#FUbf_DD_iF0`+e84#QOrgj0ExJOwF0X z+wk^}SfgM^ia{g;`@OCmu5oh%xK7q5}dTA8jPtTO4_JuJrK z7|@{%kvpt5Ug0+kgzVm3phj71i z$w?K3XQfWr8Q`71?GKnqsyXWqAS#=NA}XC`6Xftl3S+QdoMG$rnkW(9PP~#sWpg&wl?Ce#x>F5d>aSq_lx`s4SmLbkC7^a^&+KX)TLN=_RIJ zm*Y^v!0i7uszru;0NBzW?_4KyG5u!y#Be)1zY@Js)?}% zfml40_JXxGne;aj^wSSMgw`W;?NQwh)=F1@TGoGBHh+?!pK^tIQigzIkce@0vsG#< zn@d%ZnaJ0ERY_{Pl%Y_V2s=;I;0vM;MW8ezMJ4e}B&Dvee~^7%8Ap=9GSA3(lB0(Y zJ~U|=JCe3Cm&h0rX(^3GPT|5f<)X0g9XhM$MyLcU5>={hKpjw$<3T+@lDh8YB(a>d ztUk~WU(10?nRr3XWgm5LbH9IkAm2t)Ci7SC?{*(N!)Bo@^+dLatjyaY`_KPL3c?lV z=kP4{p5^6N^ab1PGJ}>?nndXmgrWFeD*QcsbdECx_zT<4&*j&fo|RHBW%evgv;B!|`EX#lz1tpKzxsC!lMm1xRINJ8m!CfS`sC}P^AU6w)$xj6 zgPV}qe)_bsZvB6>z3XyZN3t%q&tF9-{0hsl9U*OpK%u+Q-GF9ePVg#GqDT%eqBIfq zi3ZRBF$4h&8W2hOh5R^vB!6FCsxnut1#0Yl&SgYoW?k}9nORv?s|kiZd%3AdhuHuc za7g;s;IK3m#UjQpK4Fn5chZd!C+{Y_DRB`!tw{nB>XGo+r{|jHLer22_WbA2>xx0j3T3VEGeo+I^Oh1@yleczg2aK%^~EJc zfD4ddc>lh(QghB*Ozh*>N}>c?Q5xC`Hr|fLloWDY9UMxfL`VGWXv|9?(y#8`yZ->& z@r{o8?Z9~4v}$n;OLv1`hP{IX6E?MdXF8vQ58$nuX82C<-8PPB<}zbYAhED>0CybN zB9@%(PRz%!de|olH&*et7Th_O7ThV9w2R3M))3mr-Ws2WzB)N@FX%o@J0(GPe|7fa z`+M#IeL|^^+dCL*&GOvg1)?79TeRZatK#ENuJ5e>3E8o*a)uy;>gREB8(@M}yxIj- zdKaxlsSKv9|mB(oDu=v;BS9ZF4-URaW0U!6p?3vxEK|S0;|gg%9w;Ty{iZ?^(6l zFrAgMyzH(Jifcp?*UIu44#W@+5d1H7kEGiPZn!53rp=V@w6-XFFQgHrJLL(BOS+T9 z;PQ@c(sV<@k_O$i45T&%7q4YNaSPZDY8HSnAXURtu*f4VI#bL*sACCIsOkP!-Sea4 z$432}9+|?^-no;po!*@fSEtw)BHmm`1jK?urc!$5j>h+dM#;_@29;8J_2Z*U_;8lY z(cI6Cox3I>HZ(tnXqY4Z=}ZAL7w) zw(}qaET&8Y2~Ry@yTdJj;$J= zwo3>fH`lmvFCWg3HG5-OFy^v!iMPgbhb%^qIl5>ie&bCgnaZXXIO-8O}E_wr64q>kLIl zD%AHbc1Xx_mY^sTKWFge4~KZ?@azJG^!*2ZsNf48xK43s>3a@Zv`(bM+YW9YlofqP`0mMR)70w@B z#Lnx^0TTarcdl;E_e&9uWIQsVBaq)_#4^7}vJPaQ>+i$cQ$)AV_V}-YH;_aR22OpA*)dVA>uT`?>6Tz-@S4vH9xeq8A8$&I%LYIpQbx6-c9{ z|L;nT3ZCs_P4y($qG9(nTmA=HK1IuWX!)Ha?7cy$I&R)%X;(MVi~%~YVxTxvybXoy zh5O%gvOR!=E@ALU~%T;*wC1tNWu(%?(g>AA)BjrrcFy?}$ zOam1bsqx6wl>_`}=lQ|0NU%ux5Vazy1~A*eAL1ch*d|*RYS>M8|L4^umT>9jn=17G z>;AKsFQp?UCivqiT&-5SDg7X8X9s(%&9$>*!0y?>KVDwHcR@I*&d@k_QUyAxbC(>B$|x6+>j&BoZLCN-hb#V{wm=U zsPDS}1c%@LH4Jh3_6U0!y>(I=JpSRqi*`0)+TQcfr2la_ecSZ-HM=2W?)i=0_gJk#k>f$|C+asai8U{u8>g8P?LkUGk3OULA z3LPCCd(y&XD?7pcM-Lu(-oXv8oaNRefx}BN{1_1o*&A)XUxK0M3zgpeM{?nyHtSUv5DAPMj zaZ=m+OcloWAZr1h4hpKJ{WiPm&>a>T;c*hP42kpQ#F!$aii$E%N4u4%U~Tz;~%*lT#Od%I|-C&ys`h)Wu?9zIwblwxaw-oRE=xu|gY$*!2JDm6G{L>xTf=b_Lp;xB-7!NJr z=OM*)XDtv%KgofWO;-kxBgXegoah%gNkZWouS5;7}Xk7rm@lUHHYL$_RDPd zNU_-1`GP}+WP9UdJZX|Wc3tG3_X=pk9e7vUxZtaeG>!rOj3>HWdwvj%eH)K2;B`N8 z(CI#Cc#O?;=Lfbz(=nUCQQSw4Bm1WD-frnc*YOEXhl+oML*c#;C(--gRuE3OM%k=^E{;!C?D2`&c$Xei)>{R#SitalGk6jG2WzfhJ;j(&D?czU`!*A-t{mSm4E4l3Y(yi{Z<7gMy&Q~ct!Jj<| zUD^c^7v%G%k8)mShv{6%XE*`m@-z7`RkLq^>H#`^j?nZ*vsz@C_KRjTxoN5e2&@R4 zsgyC~o~dBC4q*7`n`d6Gqu+a+{L=KT-O{mRJI3^xE*?<^SD3Zd;zH0-=+2)zAvN;q z@uPB&v5dOz5Bso=i=tLKp+a?~9%1dn@fh09r@DB6MJ+NnkQ0Ej)dA$qZG!x%yU|*< zvxUfHT7JZiTOw$kmx@S_eGi(;K2QF%<|X9#kDGvBY0fljqT_qPdZ;d~RbknadKDHb zlf4WwJ{+rUI0fqgXN@e2_e#`SCYCU2T~N2O&9N?I8hX@%ZP(@MY>gys{}hpsXEw+| z3`A)mU)r4F!UVz_F3roWna2SLM=3z-vd}Wt;NVGW+_-UuBkGT|ar`_`*-w*`+Pg$2 zw&?C6RG|sZsoA9CFADiidh_3PN~p3OA`#FUo1R=luhb52gwySLAxsP$W+uCq({ohz zxHs17$JxcjC7LLVx95;s5%w3}>5)VcTr&ztb>a#l#Hk47C<^~tGLv&?fC zU77gN=@APg$U@K|nn=dOW9U;P-zf8;yo*h#8@m@SID130pk(OIY8bxeg+!-6c*jbI z&^pbQK0;{jSt*TnqW{~wsFgbrl3P3ZaCHIQYN_3mNVpj=>6Lm3yC|*0^9Tnv!7XSV zO|4w-O?mGM_jzia|1T1b_ti7u#_TaJ6P(f_c?w9e6-X!Nf+FbxgJWfQ$aLoLNeMgU zVOubD9MV2EFkDozQ8}FjJ*4$kghCTv@nr_6e{kSq1F~!QJS6TY5Xmi041(;4>KBJh zg$n^INJfDB*d&lE7DeU%rM;Y*IApcx@VIuS;wbmYeC7uzLm{uy#TMHk%+R_9$*v-ub2!Mcuj^8axjJO9EwiVmbw6u69f zpbTkXnOID&+9W%WS|s!QL@A|5*%L%+93}QU1xV~Pj{PrfI^CfD#m%N0CyRTm<jt!n@5*c!Clm)+raBM(M(D#n|ngz{}g~>&sd)se}CR>ecg7DCw=y)5AlS2)TPN zV?4%{8-vv;*>0o|$=|)s@Z#-Sv<92Jsr?cBiqC@t944%HloZN*>;OBoG!wn1Bm`3J zy7%*QKl^e~u~Y(wB~GYJPJrf_!gzYKqAyZ~w&Ii=t2(+7PbiVKQr+SXr9V|?umEYV z(4I6|H`i-Zw1cWn!0kE};Jr48?YL7Ih!xPIVrgwsErlx!an6mKWi>tt_^Q|ppQgY^ zSu}$>5F$j+JofCrJg5^T$$J%-YXA)&OAYgHKSAFJP2 zcUB*;hlk~&YKcufZhs^E@B$>$a@OZjR4H_iN!JNoXLKxK8(q_(gnoNj_+h2h6xqm} zeq5hz`rS%KpwtkHP|GU16zc!=%P-FOWTM_O^pXvCT>He;YldZ$pnEPh#bbl!LdgCT z0rzixKr*1m@wQ(pll$cxQUmC>$rMOhmdZR+=`|s)b6jqz4WVgSXmSG%bvL~)rpJ@4 zF6a9Q*s&rj+kb*y@f1teA{(aDG9<-l*t>b44LR9AKHNd2=XX47k@9OXko_lrf5RFO zF;WI87_^d~9_Z_H4Y`s+SwwKCy>5z>8c`TqC>DxgE(m}u5l!}S zn8Tf!Iu@lThZ9;q_fJA!&d($``ki5mqWeGV9b%+Taz+mh>{2lR%-rxu5^sU=u!7Fh zi65pP8|NbK_sxpoSX0&uf7Wh?n&Oe~`Q-`)-Db?6fO$?#(@gfmqtkuK-ST}fGd3#I z2|N#klrQ80jwg2r4TWdW@S!qyf6w?nR{WM<+kx14tufp>lC2fq=c&Kk@85a^8s_Yd z@yjn5YmotKW+Q9duZ=zh#ocfIouz73&&z!e(Z8ORQ49~}t6HytUs8wQ2$9dySn zeb7o+mBkGe_>LpCB8Yo$17Ve8swZckF5eb1Q53`C4FAIVL@OomMxrFA5sCmXHv)}L~4oWAvJ#O#* z`_eA$;$a;aMZL{QKi4TM>R1M{A560v=v8TD<7eISyx<%I%1(g~TkJ(D(owE0y?^GF zC@IO6Klsvw_jcs2>-zlS=H#u!&5bh0Q-<0zjDWYv%FPiJ23b_{&bqJDU(z+INpc}p zyOzkhVL=JArDx$6A2>x=`jM^$KFh*=C4JqEP_}vJ=WdisY0`0V9O>$?lQ(UGkcOv7 zdQ``8_~=nC)M5GX<^loTGv39+x&eSB@-_lBAH+*}XopBKbk-;#%a)zAVfJZl=+B2v z7{v~x&6i)e5tZ>EE*LIP1`YN3fuHHwh|ZbgQ{>Wzo8F(9$l>M^zD~9X@LgBy-!I<5 zcRjoR@_C0ygPjBYmx19QE;7A+Z=z3cVA4~A+{7{OLdx|4AF+V87!5zXKi+@FhnU>L z0Zn5vG)4I4=SNUlY0qnqXmN*!QOp_iZYgtRjTSYPI>1pPq0mjPebSnZIGr z-*n&OQyV;Il<226A~|a52l<9b^aVaq@J0&3HXCN@n?qb$h5M2{rcS`Zkq-7FXkH49 z?fx`u)sQ88`4#W0Yu<8aT6A^#p8uq<)*rD)rkuzO(@^c%E_mO)y1s`C?}*>8(1!n{ z1f`AIpB8vsf_Mrq={e(*E)FW0!p8+x$QJ447ij1LF$t(QA zd6~xkGmsTALu(`}`;9`T{Yj~F_^=V(2$tzzxsMx98D$fJXE;_7WrpR|`zhB@x%@iY zmu&<4F=7egUe3p+S_-JxQ1YIOuS z34LqGSSKUE#d9ka?Xi;)cvJt3mZ$5AL+EzvXAFT?urf#|+BZh)Fo6-+hCIHK{To+_ zyeyKcA8G^yRDVu!ZEl$|42XT{mJUtz0g~JwfQ=GR{jBtLn~0GNiF&TqmutMpXC^9t z%M&gFc_VgwGUpe%?F`Mk=d=ScD0*Y<;kGI091qslAJ$kyI9$gHo~W&$t|PrwnO4tne%RMqEEFI?nSOEBd$}N|pL@^(aS3*hYOFOQG_qSe!V7u%EwIP zAvj}%Mn@Qay-~wHxZY|0o{jCtPn*a|AAIxVLLsh;Oh!4&jAE>FT351&1{k#(sW8ACDFfh&x{TqcoI5*dAEV* z!+5TROEH*+n1Q6J14MGJpEUbcn=!$qcfuWQ*+%eo7n*fw_TRN&1C8PVyJY4i=%YUZVK9u11uXN!IW@?6 zG^!`@w&RtvB$Psk#pbQxZQJ`T@f47LbqV|U3mMX`WFl?5K7n&V*_hjbPcV1c++yd2 z9XPLDGk97S0x?=I*f_}yt(OirW50jNUSw18=}z}rx}i|48-~Y{u3$c_1NbRCbWd+r zUhq!#r5s>r>YCEbb(dP=dlm z4xR(-ZDVw$C<}jue<=kmV~-#Dz=a3opvZVW`%G_N??yN&d+T+Kat8zh>x3tNLA-FCM!p#`9KA1nGn|ldx>IdVHZD=|NQ(8LH-5`_j4G(>0TI zD(=lz^?0t(g>89(iLFbLOz~eIjlKnbd3|)tb6~9*z`p!_9nTNyu{i<-gPU=q&%U^$ z)2|0;eZgubTzd$+wefchGmL}AB{<^_275dIxPX))5j4t&M9SuHy05oT^mML#ETn7% zC0L-;hsMFE(C9?6NzTO$?aMD%5~RoWRrtBI0=qU_6T+`U2#oFOEOgs9e|_Fo}G*9=}(p!-n>o)d&9k!juKuPEBco!?K((N z93rUQbJl!^$tpgK$^PYLyADz`RmnB|QF2%s`oc|dOcujvDu3C;`5epuqer9WPF zlC2*&=d7&!Og?$^AlBh!J0;hB95`pa&5O~(rgm;3^jbGM$Eoc|&n7>kWzYCH?LfCE zuwYfmzR9nepeVv3HL7ket33!W?;F#WSPki2FIUjQ3L z#TtR}lP5JBk(;-Zn|y5NZzsFoaM=5%)!W=Pwi4|Hmq@1~VmH+M*q zs`^AFVdh+MK)Aw+QU?GD<@uT%*qkY=e8Eskc5E+G#&O;X3!${{PdiLtwCjO3I$@J) znXHBWjpj1+mdI9{ZrOHVrj`|KG{dpR{h>XE$oR;9@zjFfeq&YEmDrQMyEKsz5?yW4 zvHn_G{0pNTODABD^0YK=Q4>KA-Aaj2V$_&KGmvN-XrFN}v)avsIS@bGeLCG@oM-z&) z*?P;IRmgm5%bZg5TAEF=q-f9Qu#e`K=U!o=wGT6X)&>2QosR7sAk8n6@JP?KuP1v_ zcd#yb3$pzr`X@VM6v{G3$;d|hlx192QKO^lyC^-*g=hcB@)i7@TeKI|^kW}WTuYHp zrpjO$KUTz3&AJ+*tImUgEM~`CJnj=r$>4*`~v8A>z~o$>;J%2 zcG#q5N-7{R@YTTvR|R-2-@fFEBrJB%Q*<$CCoKC5CU@E=zoLMQ7uV1c3~WDMzp{$@ zjYJITmETmLChg9;5!WxMg4pUtsc%>>UyR{Xi_F`nKFAS1#Y|CnudrS|AtPD$SYA_o z!*I&_04k!a-BSd5yi%7T0~_CH$YmmSCj^$H_;TdM3BJT2kxdQB=GCcw@~BwcLgu3w zebeSPwXjxlG9so21Zq{pY?PR$4=$RVmhjJ&G6jGB3Vr;Yq4G zQ7(QOgcNP~&e!UyGUalbD&EDoF2}RpW65JRm6sloHq;(9uA#?J^Vc3-+GQZE8ObEE zAF)rC!-HX)f(sgO8!kP6h$Bzp{=l^jQE5F>u#Px4>{OoXrY>|;_E`QTN8WL;Bb!sH zCwg?UFNHE{!Lm^agr8cS@L93EoMvTH=HLxWkd0vt6+#pR@pBE*QeRZFr47o0oFB3j zPQ^4P(zg`sj7c|H)K&O|hzc{qm!;z0PlYSySH6z%*#=gGtQ$E;lGWnhPF1?j>Ac6c z7x>hPT*n&AP%kUVZ5e7wnDLSpH$3EdEpE2TyR2(|g0~4+^8>22i6YB%6rALZ)I1BhlRkeOZAlu5sS@xj<4h~#fee04wkrl{k^k_5~Ha%_oXGfJx zO(KYzS!L-@4=*_!yRf%c&b?fhF}`hoD77|vFMgDc>d@;27Vz%t4)h+s9RWSp8X!Mp zh5zrxpPHvgQf@|lXENR8XrgEM2(&0gpxQzba%<6{1&5Y&NM?Jc|Nytu1WoHD7l#C6g*(M*jxs2Ivt7@fKHrG_1piDjZNaroAgyxjC+ zJ+<|$Gry!s57bPJ@R51&Hzlglb*aiP zN>p|F(!@1E+&?(@2V#wVt^E~2-B*C&`yvM9Jg#`;9lp}HZ;)JG#K%SPnNQ?-hfR`m zxZ-95i#yPWmw+7Y@Z!7f+rw42Zy8gd^M|5Ep7=RpyqCZ5-(k=ay{tK88ljHha_itp0mP??)#u;4$JV=uvZ zzl4|V`MF2*PAbmVe;G$_s>|d-CHGaR9eMXvKeKeTM)HLX77QL{j^BF2K-4tmTi$>v zHTza-SsuL6hVP{awcSzhM;;oG%of*c*2-~-6Lu}f1H6@lJQK^-e_~<(mA&@RC}_qi z4f$<(x+|U)OyJPOfe}C^Dr=UHPlTI3ym-vchvd#h+Y zE_~s>ajgCCx3~YL-(KsdVMGPkeGVT50T+)Q&rVQdxPHs8wfX#h0HV9=2zA@uh}+zu zHb0@tH`2uJ%tOfdVT3Y>LK(!r{V5HxZ$nX>C1#f|jZ+f%f7|G%Aj{XqyM4J965Ap1 zl!Q+fFg~-)$E)x&;tvt`kljccB?r%`PvoC+3(FgJuknf%j^`ykskXe!1Wa0f4cFi6 z8J~2*rOY)pfpUCfhvGgiu>3s_L+?^$6vzo4t3R$qpu(HM?_u?Pw3??RK?T`8jVoxxTFjC zB>$iqZSN-4=3id|%{Bg;{DVs3HU#^#zdwBO43llnvsd7rflpv9h&NL(FO>1<|j1{xBr%&=BYw-w^b`)tNsVCZe10L+H6CQpc zGlU;dN8gO4u|R59$Tj(eD4q>V66!l^c#HKFT+je-)|z!J)bYHvWTL*kF0F$s?GghF zKxF9OsWj2~RRzvih4vEHba}U;YQwKV_$>%oevJ3trA&rGaZ!1%cnoA8jt+vcVWbi7 zus0(WmH1C8>enXt3J+HtkRHERR(RD??p*hVE$Ug>cEj6$BX=CwfzE*!F#XcDD@&Q> zr$O+V|2+yXGz(aCm=yon8?w;jR1OVj<6##3XTv262jqZS!7AVe8-MotWibFynXVG? z&(xPx&?XY2Sdzg1G14*ks}pjPkGD(7RO4sC3fu#UlQne~-&rc2oIW z6q|Ot^gdNa2!vv`{0JCdVc?WZKmDm&sNj~1|Pg2JkEfvHTm(@Ow&lk)$kWik2O4= zK%-Q0_*PJ90w^M!Z}@3>IHz;`%A~wNGw+PGNX>%(%eVNzodjkL_F)dC19&U%zz_V` z0nRGHe(gZRzs*53k3kSZaMFD$^>WNvUZ~;iZvD9cab{2+f2WrZLSzDB0Nk3_)}jz* zL`U)0am1^!wUifOrfLX2x?Z1y0PJYfD!;t0U>PYsQ=u+p!+R;UqMxRr-9QZ1jc&W8 zTx$8Lchj+(Q09;GL5`=lUNlgWHwo96Oqq~WSHqnE9%$g_B@XdrkxiWvdlGr*Ry_1n z=Oh)_=k<2ML+J^(!O)YqgrDrvGRAfBA3!hCKc1`VkTs z{|dy;oynJ9esTZeJ>yz;|Kjo!9*(@_cjo`2o9yk*zv2Hb<$w41zkA#Azxd%6{CnBm zJ-R?H@RG^H`%U-w9H-&9%7o>0bf?3v>#Tdh-uPlfFFxFfgTb^Jx4H+Q{|-OBa)U2` zf9g<*oJ_x)xH@{7ltNBH>7(eqP$ zmR>LdBJRI>j%Wo?(X-zxbZD4l)q-q{PPq)Z7A>KG1-SO7Dk|#hluWLwIrD5Iex14 z$Z;UUhj@QbMJ$#J{Qax_wIeFNyE){=+pBJ|I|C9AOYComcL@M4=l}4g+u6~7{_>`q z%=YBpSO!#_Fu z8ZP8LVE4M+2^2R&50h@OH|dOiN9pJDx%B(bn+vRwgEMV0>vpzxx}D`Twjd#9f_GVsb7aJt6s2xCf*V1A# z-2oRn-R^RUIYB5o#I82kHLj)Juz|{?&0>lsn9(kq6vp?oi3>^?R~N&XE%&+^*7<=wq_G-A$*n zZbFMtdegYG{TAPQ!N~}F-`VLV%Sp%C^Zy&YDco%p`a8w9^o8DRaI%g5%Y01X(8I>dsDPiGdCsiVopolLC1wu)>bfW z-ZLQSWJyxYE|8j9z1QovcxtZ1Gy^OeSVAE0DHPjZT>+Cl>3SY%U6r=Lj`1x5>3Iq} z-o-q&J9r%9Zf?5td2CKUDlHs27W>XJ_1s&!8|EvKLs(Sp*|g|AtFIF=d*4ZRrbH({ zN5IgTP#&BKR#KI;snAV|g=L+|E*GnMDf%7N;k>t4H|zKOoKtKLQb8EkMDOJc8^Lr*%u!qsWZN52j&)L04ISUp%lGq@@vcXb-M-@6&@zNb?8xod_< zHki`|KtMZGRT;tbx;NAHjNJrjC)PLOp`~T9!^IxDkfi|m z2;E{qWj#fI(&vJN=(Ory@K^}m;e8?8p?3gT@}n^GH1-4SlVN}Zhdxb*KKR2hIGki9 z6q#c1#e_)S}!ni`8 zrl}b^aiVRSMiSSZ|iKV7yWD0ujy<(p5 zS#@}197*bbt9^o(W$x59WH$UlXs5Kzdb@n15M2<%;G+(UsWyuIb24 z?v;{K>rBT(pROVs{Iw7wXAtI-oOVq~zBGQRqj!kjSX zDYB)I*~)`9e~mZ>ZZ(|Qb~KzlUtE@^*+?}TLY6B-(UXUve5r{&J;krU;^!?6Pp=M9 zOrirrWSPMf=i52(@M98gc z0b5NGgAb#56nd5%0P&7-&w4i%yWt+lrpQ8fu!Q44u3lq6Q$H*|=B?3CC)=h|w>b`sm`F-y#8oR3=DN|Q{~?rH47F2C zE~oX3?>b$Zf#%s*V3+}&RPj9wze4FV(0x*!L7+4h`j$jZRVa6v9u~8hAQw)fYgQn! ziAhSNH1)Z$X?E&nfw3d4sn4zLQY3(20s+A8kt#=G*Ov+4pF#}bD=~a!BsP7yab5{A zwsJ5_G>Md^FAt_0rBrj9A?J#;J&j!}t*leHCZs#egv9ksux66PZiE)Hm6e190DJI4 z>#NSP>EE?q?n5xwUF@R*ZO^xUP+A0a&@N#mfp+RzvwlD79B4B;h&z$8r?pRIw$#K9 zqG=>HwYhNr@acjILq&6vn$Xfn%Ft&$`%y3{-MZyV|czAB}7y z4u7k4A2_!qQgA1C1;#O|y9Tiig7hj5Vyc|mAmXoaeGeZU=6Z#tOkn*xh&$q2bY`A` zySvfC#SuOmB#pQ&kd-^1!f6-nVr#FKU|J}3g1IOS0-Gb%FWU}O;W9n<)hKP5e=?(B zX@RMOP0U0#v7{NVD)m&JylBO2GDUp`!6%Gkg7cO7$@W=W3;NGFx9-(dcv|kn$NYAr zvQ6{nULP72KN_P`egpL?_S(nIyk~dC=YKvR&{E$D&llTuLWQ^Nt za9=0U(5k!=b}=thho<=d!Sj0d?sM~kQn5@dWroomBvP?iZ;_nf>q0p1yTA=jw`fFp z^+P+zo@|bu*SpoQnM|=XL$wRdW?X5ZnXes7L`t)2+Xz-@H-+8Bc4iCiR3-Ew0*O*V z9vN~AFqg{U$Y3=@>h8>p7==SGfS^o*q=&Mca<`+3k$pr^{}I1@t6ms}g}o%)59~iq z##HG_(H36j!^RVhz$m5~8hM(Z%Q#$N^5eJU2K%<@&TcnF2-~4k*7?zYF!;`;UWWQz z`OPf0p-DscbM7ST8t|-sX7$Yj6vI)fW&`X&Q0hmD2Njm|bK<$ZYra}1f96CQVi%^> zEUfxk&6>dHr={Q)TG~NJ(vBsZ*v{RWsma?_n?XY{ZI*sYp>g8d02h8S?b;AkK(TE^ zm};c-CKO}YKA?1cdWqkC66WX-u~zpW_F74s$gVZELG6vVXiF`W3D91*hwM1`6W;;& z481&2yf0i3yf5N4oJ#P%{d^wZ*0fR;oGup76eZDRbtn=JU$Al^LFmK*b18 zk=_*L^qTS?pW!Vs?P3d&fQ?`uOZXr&K5V~5YTl^E9oB&9d1u(mEVzAFYxNA?8_0L# z)%#-Qp|mnX!DxY`!s$&dPJe)p$to96olFRO>!5zm<((eCaLVtJdOaK2=$wuQajG`L zcb_vCN2geGu6i=gaugVs&7JTuMTs;qE+2}aoKOgx!@#D9xl67{Bk#FD-1vpZ)$I%H zSF(XAG*%n*wDI=l{A6`?^BzAnt?QKLNd9+_kX9`+;ZO6rI6(zgGi+>8vBBogE>03oJ0jvdB`@am(ZJWgvAsjpTHc~GTO z@&=yT7C_O^)yZoi)$z3$;nN#LVbsX9I+jyOslRpABNK^9@eMj zg8eP=4Iik5sFrUp#2=mherj6*8WX&$98VSNZU(4wD!uRFfGSJXr*pR#CAL8@|onJeOn-fY^IF$>Lf^*~1eBL*^u&VZ? zE>?o1b9Ac;Uzb=Bd7IQ@D4&$=y^r8d`C*?87%rS%%Y^g&052u&97c{z((#7(?%8r*eay_MK5k;S z%2~I!S^~{Y{9(Bv!FUIyNdcO*!IDpUlfp(!SY%#gg8e1sxq%$E%Nuc_UEXDN6x(o9 z;^HWIgwMuh^t8{n=z>kKJZfC^W*#r_7}I?r8eq4BnA)!KGN+no#z~b-(|dOjz3NYj zM}SmDJ_Yb*&ddEeDZ~|Of=6GsOsnRaVOllS^!|NX4|}PgD{rsVH@ro43MCh^5oXxi zw92dWA**AHaR=g>IIT>pCa|Swz0{5sgw8Jhz&&{lt=I%&8;HDP$!s7QpG)*bFg|k2 zlbzOQdK&b7qc&SZ`E1XHR6N0ue@2BJ0j8ByF{xgopuo0~vvW5rJ&!ZvEAJ{W@5R!# z@48M0REO(j11{6;>F?Q|kc#V3Pis$pwEF7p#g%P!#Q5N?+coOycow*2T1uCUw6tZ| z#q*+?5e2=Phn^ot!8 z&nM(&L5=5|S%{MxAgm#r;$9iOH;)mDxM;Pcn66=iqscWO;|jh)JGBJXK#&KDRjG;=AB}X_9O1Jx8$xw}MO`M$oQhUziVj zZ6GhrHCo^2tl$QF*zpH%)NsrsMmqR&#FQyb_0<`;G4Du=U{lLc0O<9QBMTV6v)m63* z8zxZ#D>~r)mMvLmA?p(@hSPfI{%+M3#lCZaX8VUk$7p7J%S0vWDGHY?=XB zJ7@yp0ZYcM*`IHAJ zoOO6Y%e7`V9oj`xlC}@{70H^i@t6$-f4Hf3h{AJ{QsB6?RG-!R8<{?}DU}*Dw3- z6&a5Vk}qTWATF>cbunS%!}N7`U~^K=AnNNA8ZHhuc>J)(n+2@{w@Y5@URc*n4PA2U zb9{+EuEtU-&h1Jn)X{@@*3fQ%3d=#R!ZPk&49L|^Y;mgdc6FxN`WDj|Xgb|KcZqu7 zIulMWc5v7^8|KDS%&;(QAq@ssSN#2I>#^21 z%Kc64Uo6C`1MSX3GySpv&)D)Z`lbPr0crTfIrE92#gY#TEC?!a}!h6Ve4qqJ}@x7VKH$FokjTJdJo z6F1)cB`@_2P-){HC*_49Hi^novA}t`Nlk(u8E9gD1XHRp6MMTYz~o>F9MH6D_i8QF16zV7S-_FNr7E#~S7YE0I7t)&fW zC7BMP7LUG|-y??^4YUt$@ab13Y_voEU&`j;`B8Y03xK>;{|UcRhWFvC`1kV_e(@TQ zCwHcR{`CA;JjA+>!#=*?wZAk^NFWtm23hGp0>4ikS;;67M5#u^GZ;yog6&chD6GN+ zFXow`8u=0^#q@+R`6rlO-AEwyml5>0H0xKm;!$~cWim^k5Hcd|Yo4|i1-y0z1W@EY zl2+~`)VPnJ%zeZ-_Yr2UIL%5zON9IaA03qT27k`#lz+pY@~&R3>NjI5!RqWI_!3UM z%294G>McZEGAcs4Ng}&xMRqeHvg*$wFP17L(5T3~W}K)8M0V4N?Ds5`53raju}{23 zRT#9(7ztG6RSA{zw1f@hGAXh&c(a%t-mYlHq-AX&&Gy3*Hu%T_S8Q742Gak8Rb}v~ zzG`KLtb%Az&C0hXS({BWUj+@KaRk<1;|&y^T!MmWsT~T`XX!nmNmIu1p|J|+Ks88@mort{g%R#-%?QWTLv;o^qo_^su5gT zFwo?@BHSfgGOvhi+*m@kzAT`VLyK_bBY3rl9C2-dB>A@pH%6*+iOBHpkiG@zvuZ5E zJv2TqHqK@<+<`COVQk|9WA}|849MgR13Y=e2yfhCLJs@JK$09}gu5XXFBy^H-y!)3 z(AQP|b+JZ#<1`~O%YV27m;W%fUBI#bz9S8|>`enAyVQWlel;RYgu#JEY?aV3L2|R9 z;jpg_1j*q>_-!g3alNs5o$#Q{TPGYF{|S{2xZ~KvttxFCb7+~pb3h~)9pK4NN4N>F zI_rq6;;HxoOa8h-T_eR?S5)Jx1FH4Z1)2PGg*INgqDFjlAxIv<&2R{Z&+uO7PAV zU;Z_SZ9H=!f0m7CXlVBeL%7B#*Nz*HTu{j$7ijXv725dXfExD1g&_Ii3Uvc1Ubv#7 zl~#w```iM~9=C!`SizlET=`er zqZeTEwFNrtX$v~}*$N$3*@%y=P0PQARMz^}LY|+p4K}_-WjD8|tnsU5%3>>yUcgO{ZVC;eaga7n;~f>AT%&@LUo=qT6dgY75fz)i&>(Z>r?J5{Z6s_Hu3K}=2^x20gEIBX*CGTY*lSFl0 z2CvLklvzx2Tn=-I7SH8~#&s1$>$?n zWs5Uewumgt7H^#gSLnmF3(7Hlr)Kc%)eM;3ngO$4bD)VOI4{Rk&Rb-1ZPsAew;3`y zH;0X>WW>FBvpTUxvaN&jMxRm1fQ$2%qbg~foVCba&Vb3y87%oZhnY|sZ#I~r+1!$+ zbC^rFcsfTko~|HTPiLs)=^WO0I!BCnIzuN<=P;XWbvurTtFy&cQ)qFGr}HkeDYOku z6T#DY%f{0=qVaTwNS@AM${X zvpTUxeyykTMxRm1fT#18_TN?|ji)op?CA`cJe|Sd>1O4=i^EJPEuykrabgt7&nd(u zTfCft8y{!j*24)R`8S0$-c7+HzD!5c^9 z@YWM4Cb=R5HNME;BhE;%$r~BSW?6lK!Q<*`kW~;3s_{tHU)FZh%vV^0Xq=Mur~e5V znF5kqQc&_s25KCW!-qYSVv}n!kSn?PCWA-u)%9S=D!vBQxF>6p#n&`*@imBcxmbr{ z(ZNM2IQuAtWhbSu?4=B5vIxG&5S8BsmmHOn4|^)bC0Avj5fzL$D{EAz)E8OnuB^%J zDj0BB)^1D%jmuK{?6VY>oR)%;*D{bvqVJrB_KEj!^M9*c*v4PhHiFE@L{K#A2(RLd zP&4KTazl+U7f^($c}9rx80U=jIPrCNuk(xZ5frBz;dQzZYSWFNtn-L*Mk34^i7;iP zKpu$PJtW{SmwN!Y+yf{wG7Ip^NQAoF1EEhhlKFHa%;X+gy4))WPGZO9{-A?<2!Fvb z#J`NY2&z*KQ2PNcJRG$v@bG2E2yzleQtlZmAlf9$X$_jN3t58~DrN+8gMltJ|irwKmDQ~0PtB5qmrSNVx- zfYpmMXZwgtY;-Xqbo{8OeV;2)w=>C~^hm@5>aZ^%C$d)dz9jH#Gba5XQ;vea+yeyy zcRm3WnJWndT36;G)R>DPXCcB|%n@epB@FGJrGl^~NIW2XUjdPr2}ULu3_Vh}GwB(6Bp#Tf z8+s%&Ne580>YuvCssW0#E~W-}6>Eg{tr~>cJ|eNtI>KDC5!P5WcHE^p^;73BbR($F zu0mr$F0G4%XqHIAMrl+VP9$~c5rSq7rRG^&BVD-UM$pY7OCvPvEn;Jq^;1GLt1w}k z1(~sfYcr8lu~qZT1Vbw}Q8Y^?VO?e;-Mirpqtoh+-L?xoVWYi_^!z!-FK%UP)G4HC z+|GOJDpKRdYeZ~vAPHgiQWtWU|;y6>3c_{m2l zgb8NYF@*|YA$ZcUaPB)H{AG(Rfl|4=(qbze$gqnJe_;b1|FU^SP*p*IN>v!YcVZud zC^^!TF4l|d=HW>PS(I1A_{#>0pgK^6Dp_LPKn?#69~OdQlOz04A#GkNrepLw?fs^84LQWKp&FhI-tugSmS;osc{Xs%b6BpK^N48qkJwfU5j!G_ zNHQpqNYKh9Vh5xX(E~Dy=tfcz*~m))Nm2%CWMuG0ItCw>iy?<3VyH$I25+Tch?ajt z^f@=M{-+xIGkUXf+ zg4!bjA*-C{KjYD4`0LlyE5cU5`3K4(sIp$6D$FEd12tkccq40r4-4Fob?7PwLp7o| zcq@NHv`R2UUlRsy)S>XC69YAharm%y6q{6}prj`SC1oinY0NVt1&JpG zM!5A?r5=%uDkC!dI~ZhuhVzHv?iUEp2}=Vg&EUmGNT)XX7sRLGfkacRd1$HHiDKjx>a_@w>r=GzUni! zv4Dh5hLAChJ@nASW|4@JbtFtOl7vaNk}%0+GN!SdjIJuG24qrCrsJ^2XdKa)iz9{& z#j$n#Y9fwnjKdN3-(WV5X$`_LeN%9FV+4js>UUV9_<|T#xuKJ?4VKhwu%uvvCDl5t zQK}=VIIB9fx|6hNphlSnZ**z!VO1Kk4qY{As78?nw^;{08lqLBA^KW0aHB+pCmkB7 zQK7?!HK^F6Km{fJDJZE=K}mZCYLsX2D!{5cWi08=K#lGU-ssNY!@4tM9lGkyP>t>k z-s;W}t?mrb*PVg&KfwkRkaTCDMt2S$)}3OL?i7@Cr=X-e1tr}XsL`Fls{o7cp0n6c zuAAd8Ya2nPtO$yFitsu@gqn6D$Q2V|u9FB;bwr5r66d_a6&o+4KCd^l0?0UsRFQ)S zuN*|EaS%byL4-L65vCkOh;a}=axM@~)t<{$mdZf6$`U|kW~Hi(Hj$?YuRJAaI2aH8 z8mp1gS&cAfHNbe-T{|i#+yOK)!FZJ=P`5MbpIQgvfjO4*=|E<(5A*apTlGNgZ(V$s zfWK@_6omm4If?Kp>Im(d4?0K*PPJcPoRiprOFP1PhV{43IVsG&NcXt#moZYVe*hF2 ziSWuugc>6elo^Q_XC%Tjiqy+xn1QJzP(`o$q8wWnr%%wJFMUD9g??Od5j4VY_||5m zZu#vgE)oy$``Q&3=~Qt6Lg(*qBwn!QS#H$7=-}VuU#`JQ{#(#gfht+Ntz|9oYrK_^bFmK(-4j68N4w)g(uT9kp8Epi7y;J?5`A?OwT|gvPyBMdJtv2q01Eyy!`lhGgWO@oprl+7}dIoYq^z3WU>&2*$4KRqm^?<3_h%v?v z2E`l+T46`*sCh=B0l`OfYpN038f?I3vyBLqcr@OG4S$T#WJ3=0Z6J;^A2aIM!RKT? zVBoR&pOJY19 zh;c?D%obn-*{lNy8`E-2>Q&j8Mv%#U?iVjX6&Z=}%1DG7BN61&jj$s3Fp$YTK#YUX z@bKd7;ye@xUUg#g34*KNfhFInMvys{1PV91BYcp{_`E0*x6GI4MS%zZ5&AgGx1TQG zuEAL7?KGL#sV$PAP5-s_Xo(l83*YjFUeiOp2(OGrs4t_cl-`y%61$=!%m(lv|XLlVp= zZdaZ{+g0##4&5{;4x`_q@2zcYH?kgi^4m)4`Bz<829LZo$jV!TGTs_^Hiic67SSLY z*KYG`{JX-FlQ)p7wJbSln$CeB;aps2M!v%cM1M@>Xfc(b@2 zj30=O>qWsSKp1F5LjFLnE=i-05^9j+5*m&i*5`=y24aXc7?WNbO|(G@DF!me`&Ks) zT(m)oFa{bC-bk#mMpa0C`T0ws2A)??gLW%x5KR!WDY%p98DATYls?5I0~zZz3K?Ag z6M~S#heMQN2ji5YQm``6h}cKMmNgm|dmF&4$?ak`$4Ft@HjS>l7C6ZK$j1aUTG&axnIMRiSZ3Nv0)i^>MS_3u**obgLs{SNm+h7~9 zQEVYhMv^MF5rQ^=#O5xMk;cW4hG*Zb+1Pa(mIJm8&I#EM(E*tQbwu1M>4Bgf+eS$T zpA|_yC+U$e9=o_z7egUEHojdK1K~Y1&OtsROlZR^VkqE;#yRXq#I33rO95gBRoKJY z7)S?V^Xv^qx^UYcLAMD)9Kqe>;KCS47DC&cGDL)lEhG*RtFbPo4+$Io7@-+XB|^KL zP(;M73LQ%>Vh5j7=s=a%X)|)3l|X-Jy(QRfk&u$pa}A15MeH=2vcVtA+`nr$O>=e=FaPK-d{n=R^rt_ z4Z{X+xHkAO>xLZS-%yPZ4Bkq@5Un^2(U*yV8^I{Nk&c4hTT~GR#*&;OT-yeNiO5D` z5gGnH(tJpEq1D|+fDzeBF=AU$Mr>c65!VPcAREaBTr1wfUJ`DFHlnSlMz9qXh74k@ z`0}qoY$MV_Ug}?UomE^b&Wh^`vtk-i7E~k1f@#I5Q%*88P$NKtH_|isu;>g~W)S3N zDE&_hZ%xn|wBj;EUseWg1f}psN(yd8l)_e$RK_#{%jiaK89gk%Ofw|KOrbmkVPixv24Op<6{BPN z0(5vIIzu!g)DYy}of``SVxFI1arV){XTLCG&6_3K@e}m8z+K5KLjbH@Yh~*ci zuaj~O5PzCH63m2=U{MkYQN@tJCW8cX0VJSvpMc7G0vX>Ch95&HH!ObXzPD*dkcee< zc(^{lPP8bIm5&?!Qf>i6P~HGvk&y_mj6|q05-HnCdJ-jDrBOic*3|8EG=zvr8Gj@Wy)mZ2H+g+WVrMbJTp1D8TQG0LH;IeAiJzxYybw+q)G(wG|2+DRDF|OzcGrNo+(`o>@=L<>h_{)-(|5p5E1jSiLc%5{F+MFXOD=uQ3 znFuqxj3AqK0Ks4G`fB>E_{#_~`A1M>B*H5r5o(M?kWV+lT=Ws9l8+GMAb|QA>2Hm{ z{7n+l$;9FY{w#JDV4jdhy2$7xA}XiL(8W>6MKfwnZyz#mQkE~ZGXvoTXgEH0|xbxN^T(b?L?~`rp#xX0r@y-sG zqCtNNuy9a4fszh5YeTdi+YuqtZTqWIs?OIM4m)r|nh2XlF2V-kB5bD6I&~c))){P_ zx9;6Yz4Pkh6_Fji!Sp|^Y||Z)W}3r(-?}W$qBv>f&lKZ7i@Zi_hqd)kXzv z5Hjn&g{AnQ)Xnn)6aDag3rAKfYKAb;H1I5$2JM1r5U%P5(T^i#PC1lRureIOOvSZ% zcEv@n6I^{IDE}JnyBJGx`lUfRcOC54Ssz3;A*Oa(ET$bW1)9>LjWrb&xvw#x;>*9n z2B5&68Sg_4vq20|xJ?Y#I1biff})zzqkiN>Ki_RijLS#ad19 zsugdN9%|~69>Te#hx%+oSQ#!wu?jWW)Ob}HL>bKX_Skh$uJ@Ji-W>49LupK#DZ#HzOUZXo^`KSC0)Nu#@82@rJsN^ZdkEDgK)Pb8p z=%8l?0aMH%z|6tLk<70Jkh`Ktr>O_9qu3TvrLvs4Za|4QA}1G80LdSh0dkFr?x{;W8d> zUxYf0Zfzj;oy;L2Tr5Qi2|H{gi6k&S+=sI@j2*M0G)CclxR1uRQsc(VA~soELfk5t zAv-*$%PRT9xwcQB5)&&`95T_Cl%>#KB$s$0A=+)hvi0cl48*8isDe5ZX@DpCqT57W zpov!1oCp<^sFJ!9al)iFru{^1utcY3kjNC2sES~#SQHegER5xlS-%??(f!=X+nlYB zujTmFrJoUQUc*=~6%Av9x~g(>_eDoz1imVVM<@$!7~MFVJh&#MMZOv7%Q5vlEG&f% zN=i|KVp7z&j1)g6AjJ+!M^VF~QQWXx6gMOk#f(ctBqu~$i2t)P_n2>n4&pIP0K3@-P%-xaD`s9{Cn3ySb+%Qgz6YQf=_11GTtypK9ljM+(n)ei#^jyYfMQ8)|evF8dFeSV?oAwrA35mu1+LkwcE&V z!Vavxi08j!x)#kXufx!)jd-cqtuq>1nX&spo%bC>WzqY z4M%L0QAimhcwjw;9`dS=2)B^B8Y9;AF@g=G(F+9dxi5vm9`c$G%?4I}#Ez{0Nb)&D z81MzL`KU*TM7P_*fOm+ET`+@7Gkc2AY{*{(boLqn5q-x-wsv>J&p#N%Y@wWe7}#vH z4~|OcC6a!wLFzPtoD)}eSi=0l9zO68x3Gr4`sx5^kTt*uWDjVcHGq1q zv(BdGQ32*h76H^}?L#?&Ev$WNSo@SL4S)4n1IVM9k44bXffnEc+!7j+htNr12%v1V z2v}ojpVFB+{<1lj<7jv8Pu3HYt&|NmrK)Gt3YjmMOCF^ApK7ZAJ(Tes*E)KHJY_1 zW9l`u^V0O!DB2n{+E#e0@-o*(>jje(U!mG#u!)Ll)E`iT7Etl!UxOVF+CgcuZcL$~ zT!PgaDy}t%f=f10p~ibvM@0==M#YzZ1*0l3cf>;-kC{kq>^u&&ZVaV1Yiy;UlDRxQ zKl*8Xb^d&HdbPpXjs5vxb-mKR9$lPY|Gd7wIz1%%-|&C_pTGXwzrDO(U0nxMw{wS= z74IWO;}<&aUtE6D!=JAY|D&7i?e2Yp|J~b`|DDMH&g6fWc&d4Euy)byb6-a+y5U<{z9=fD!`>V?z zRDkmZrS+@*wKJnO?{4sc7%2|4F{PUML-DG8q7?_baybhAvi{&;w{dJovWZaSGm zvGZf~G+?e205)Gc-< z-C{oRVHUZ~(FG12uaq9PGMO&A#caD7_^v3sBfcgUbF6H4s#Bxw=}P%b~NhSy0N`({8>u z4U>Z~+D7V_grfnr%CtJBRp;b^kN>?V5{XcuPTf+lZic4s#mC7EgAT7xuaw6})|O(t|ta77?f`kv~ooFpt@ zqHR%eH79tlH1q2Z+A$0Xq$g{H?H6p(Q0Mq>=((rWW4Lsg#jbQc-;1<8 zbsnGoZavdrxCGF1QU1KA&dupZ=@?(QQtElM$$3wioAvMb*&)^C5=<_ppss!QG^xH% zs4)+j%XShH4k0Cx*Ea`ZDsH@xXl=9T zX_PmamE9?9oUR1cTlj^Z(+KN--mKIsVg*emSaY(Vd?nF4MjJR`MgadW(}97*2zIgh zYWF?GB93n)DvCsRXOQTQ_>ejHR-P9-9=YDFxm-i!`6 z&ikGaV$qXO*MyDU)8~C5glE9PK(~NW!$f<^d=UBs6JhY479R>Bl#Icbad7;RX8A~a z6n1uFkMtvvo$rNkaFz^#k@N>4g(+-zOGMc^%VkehkF`%(A}KP^O~xL76v8>;Aw;yq zN)3JX^z)MrP6x0+;0T00{X7vuICAP|5ea+x`B@0Jrep^TIrP}m&Ql@eB&XdnsT=_& z@$*b5U6_dRRpm6&$og|3-Pz?dlZ>z;6XD;4Q0#pMJ0eTP;CFi(dLgva9d?R`EdStR<1Y64KoT`vkwC&z^=}3!$bS&?eH3K-*K&FWM<5x+Pf1nJIZ8&wThajzlhZL zS8T0vx0VGXhhn$P&r1$Pn@&?uad^Mm*fNyaGDl6c$2te*PYcV={?a|co1o)UV4iem z-7%u3&8esD6KRWl8nF(1!m-4GdMbV^#Bih-h%AKZ_teUP?{%0A^v{0bfPDfzRsKUL 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%0D`j%GsYSOXO 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

-gd1(LqtT9GP>=)i= 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 z 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∨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 literal 0 HcmV?d00001

+ Credit: this control uses a slightly modified version of the + Dynarch.com DHTML Calendar, + written by Mihai Bazon. +

+ Specify whether or not multiple jobs should be run in a concurrent + fashion. The behavior when one does not want concurrent jobs to be + executed is realized through adding the interface. + More information on stateful versus stateless jobs can be found + here. +

+ The default setting is to run jobs concurrently. +

+

mtxK< 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 F{||{RwK@O* literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.pdb b/Resources/Libraries/Spring.NET/Spring.Data.pdb new file mode 100644 index 0000000000000000000000000000000000000000..388bf9192c42ae623b69e5230b835e8c900440a1 GIT binary patch literal 708096 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'W-(fObHtSRBPVM+WV||9)JFuUk8q+RL9wr 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%0DlFH1O65`3HUlN9*Cb%2c`hc^dARI23q>30TaO6 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

n!rB+y%C(sO10=28UN?W{+%<%QSuxB}oEfFF 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 literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.xml b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.xml new file mode 100644 index 00000000..fab25108 --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Data.NHibernate21.xml @@ -0,0 +1,6711 @@ + + + + Spring.Data.NHibernate21 + + + +

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 %(2<28ZH6 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 Z;t&2LDq@{egdP8Ow7`xQ_}^=Re*%Fc1e5>( literal 0 HcmV?d00001 diff --git a/Resources/Libraries/Spring.NET/Spring.Aop.xml b/Resources/Libraries/Spring.NET/Spring.Aop.xml new file mode 100644 index 00000000..e2d4986c --- /dev/null +++ b/Resources/Libraries/Spring.NET/Spring.Aop.xml @@ -0,0 +1,11751 @@ + + + + Spring.Aop + + + +

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˹nL||BCC0Z&MMJfHwYyUT;k!PQ@$bY>8wFfSR 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