lucene-queryparser-8.11.2-150200.4.7.1<>,=lf^~p9|ޟQ AHLi"DsῚ̺,djqWO@n:ܟ!'J莌zum-/[1q~Rɾ0t@NJdU H/~tYC69aiH ,7`.1DCY'$p;mޖ%m+sƨR.u%!K*8 HX>&ct8?L&bmOb C²^v(gz>>P?@d ) G! 7Rms|     (@   (8(9|:FGH,IDXLY\\]^ bc,defluvwxyz<Clucene-queryparser8.11.2150200.4.7.1Queryparser module for luceneApache Lucene is a full-text search engine written entirely in Java. This package provides the "queryparser" module for lucene.f^~h04-ch1bSUSE Linux Enterprise 15SUSE LLC Apache-2.0https://www.suse.com/Development/Libraries/Javahttps://lucene.apache.org/linuxnoarch AA큤f^wf^uf^uf^uf^wf^u7759ee0dac7c434debf386a0a7bbb3d10de98a2b5021193bddef63310859ad2202c48a169a328ab330e077c3f9b726a668ee15895cf84ee2fbb81e296beeac8e5aaa72c0627ed83712adbaea265c40a6011d50087f71a35dc4051565ace82358lucene/lucene-queryparser.jarrootrootrootrootrootrootrootrootrootrootrootrootlucene-8.11.2-150200.4.7.1.src.rpmlucene-queryparsermvn(org.apache.lucene:lucene-queryparser)mvn(org.apache.lucene:lucene-queryparser:pom:)osgi(org.apache.lucene.queryparser)@@@@@    java-headlessjavapackages-filesystemmvn(org.apache.lucene:lucene-core)mvn(org.apache.lucene:lucene-queries)mvn(org.apache.lucene:lucene-sandbox)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)8.11.28.11.28.11.23.0.4-14.6.0-14.0-15.2-14.14.1ee @dQdgb7@^@^x]n]?]@]@]@]@\b@\'@[Y5Ycl@YTY@U hgus.kenion@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comidonmez@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comfstrba@suse.comjengelh@inai.debadshah400@gmail.comdziolkowski@suse.comtchvatal@suse.com- Use %patch -P N instead of deprecated %patchN.- Upgrade to version 8.11.2 * API Changes + LUCENE-9265: SimpleFSDirectory is deprecated in favor of NIOFSDirectory. + LUCENE-9304: Removed ability to set DocumentsWriterPerThreadPool on IndexWriterConfig. The DocumentsWriterPerThreadPool is a packaged protected final class which made it impossible to customize. + LUCENE-9339: MergeScheduler#merge doesn't accept a parameter if a new merge was found anymore. + LUCENE-9330: SortFields are now responsible for writing themselves into index headers if they are used as index sorts. + LUCENE-9340: Deprecate SimpleBindings#add(SortField). + LUCENE-9345: MergeScheduler is now decoupled from IndexWriter. Instead it accepts a MergeSource interface that offers the basic methods to acquire pending merges, run the merge and do accounting around it. + LUCENE-9349: QueryVisitor.consumeTermsMatching() now takes a Supplier to enable queries that build large automata to provide them lazily. TermsInSetQuery switches to using this method to report matching terms. + LUCENE-9366: DocValues.emptySortedNumeric() no longer takes a maxDoc parameter + LUCENE-7822: CodecUtil#checkFooter(IndexInput, Throwable) now throws a CorruptIndexException if checksums mismatch or if checksums can't be verified. + LUCENE-7020: TieredMergePolicy#setMaxMergeAtOnceExplicit is deprecated and the number of segments that get merged via explicit merges is unlimited by default. + LUCENE-9437: Lucene's facet module's DocValuesOrdinalsReader.decode method is now public, making it easier for applications to decode facet ordinals into their corresponding labels + LUCENE-9449: Field comparators for numeric fields and _doc were moved to their own package. TopFieldCollector sets TotalHits.relation to GREATER_THAN_OR_EQUAL_TO, as soon as the requested total hits threshold is reached, even though in some cases no skipping optimization is applied and all hits are collected. + LUCENE-9515: IndexingChain now accepts individual primitives rather than a DocumentsWriterPerThread instance in order to create a new DocConsumer. + LUCENE-9680: Removed deprecation warning from IndexWriter#getFieldNames(). + LUCENE-9902: Change the getValue method from IntTaxonomyFacets to be protected instead of private. Users can now access the count of an ordinal directly without constructing an extra FacetLabel. Also use variable length arguments for the getOrdinal call in TaxonomyReader. + LUCENE-9962: DrillSideways allows sub-classes to provide "drill down" FacetsCollectors. They may provide a null collector if they choose to bypass "drill down" facet collection. + LUCENE-10027: Add a new Directory reader open API from indexCommit and a custom comparator for sorting leaf readers + LUCENE-10036: Replaced the ScoreCachingWrappingScorer ctor with a static factory method that ensures unnecessary wrapping doesn't occur. * New Features + LUCENE-7889: Grouping by range based on values from DoubleValuesSource and LongValuesSource + LUCENE-8962: Add IndexWriter merge-on-commit feature to selectively merge small segments on commit, subject to a configurable timeout, to improve search performance by reducing the number of small segments for searching + LUCENE-8962: Add IndexWriter merge-on-refresh feature to selectively merge small segments on getReader, subject to a configurable timeout, to improve search performance by reducing the number of small segments for searching. + LUCENE-9378: Doc values now allow configuring how to trade compression for retrieval speed. + LUCENE-9385: Add FacetsConfig option to control which drill-down terms are indexed for a FacetLabel + LUCENE-9386: RegExpQuery added case insensitive matching option. + LUCENE-9413: Add CJKWidthCharFilter and its factory + LUCENE-9444: Add utility class to retrieve facet labels from the taxonomy index for a facet field so such fields do not also have to be redundantly stored + LUCENE-9484: Allow sorting an index after it was created. With SortingCodecReader, existing unsorted segments can be wrapped and merged into a fresh index using IndexWriter#addIndices API. + LUCENE-9507: Custom order for leaves in IndexReader and IndexWriter + LUCENE-9537: Added smoothingScore method and default implementation to Scorable abstract class. The smoothing score allows scorers to calculate a score for a document where the search term or subquery is not present. The smoothing score acts like an idf so that documents that do not have terms or subqueries that are more frequent in the index are not penalized as much as documents that do not have less frequent terms or subqueries and prevents scores which are the product or terms or subqueries from going to zero. Added the implementation of the Indri AND and the IndriDirichletSimilarity from the academic Indri search engine: http://www.lemurproject.org/indri.php. + LUCENE-9552: New LatLonPoint query that accepts an array of LatLonGeometries. + LUCENE-9553: New XYPoint query that accepts an array of XYGeometries. + LUCENE-9572: TypeAsSynonymFilter has been enhanced support ignoring some types, and to allow the generated synonyms to copy some or all flags from the original token + LUCENE-9574 A token filter to drop tokens that match all specified flags. + LUCENE-9575: PatternTypingFilter has been added to allow setting a type attribute on tokens based on a configured set of regular expressions + LUCENE-9594: FeatureField supports newLinearQuery that for scoring uses raw indexed values of features without any transformation. + LUCENE-9641: LatLonPoint query support for spatial relationships. + LUCENE-9694: New tool for creating a deterministic index to enable benchmarking changes on a consistent multi-segment index even when they require re-indexing. + LUCENE-9950: New facet counting implementation for general string doc value fields (SortedSetDocValues / SortedDocValues) not created through FacetsConfig + LUCENE-10035: The SimpleText codec now writes skip lists. + LUCENE-10083: Analyzer and stemmer for Telugu language * Improvements + LUCENE-9276: Use same code-path for updateDocuments and updateDocument in IndexWriter and DocumentsWriter. + LUCENE-9279: Update dictionary version for Ukrainian analyzer to 4.9.1 + LUCENE-8050: PerFieldDocValuesFormat should not get the DocValuesFormat on a field that has no doc values. + LUCENE-9304: Removed ThreadState abstraction from DocumentsWriter which allows pooling of DWPT directly and improves the approachability of the IndexWriter code. + LUCENE-9324: Add an ID to SegmentCommitInfo in order to compare commits for equality and make snapshots incremental on generational files. + LUCENE-9342: TotalHits' relation will be EQUAL_TO when the number of hits is lower than TopDocsColector's numHits + LUCENE-9353: Metadata of the terms dictionary moved to its own file, with the '.tmd' extension. This allows checksums of metadata to be verified when opening indices and helps save seeks when opening an index. + LUCENE-9359: SegmentInfos#readCommit now always returns a CorruptIndexException if the content of the file is invalid. + LUCENE-9393: Make FunctionScoreQuery use ScoreMode.COMPLETE for creating the inner query weight when ScoreMode.TOP_DOCS is requested. + LUCENE-9392: Make FacetsConfig.DELIM_CHAR publicly accessible + LUCENE-9397: UniformSplit supports encodable fields metadata. + LUCENE-9396: Improved truncation detection for points. + LUCENE-9402: Let MultiCollector handle minCompetitiveScore + LUCENE-8574: Add a new ExpressionValueSource which will enforce only one value per name per hit in dependencies, ExpressionFunctionValues will no longer recompute already computed values + LUCENE-9416: Fix CheckIndex to print an invalid non-zero norm as unsigned long when detecting corruption. + LUCENE-9440: FieldInfo#checkConsistency called twice from Lucene50(60)FieldInfosFormat#read; Removed the (redundant?) assert and do these checks for real. + LUCENE-9446: In BooleanQuery rewrite, always remove MatchAllDocsQuery filter clauses when possible. + LUCENE-9501: Improve coverage for Asserting* test classes: make sure to handle singleton doc values, and sometimes exercise Weight#scorer instead of Weight#bulkScorer for top-level queries. + LUCENE-9511: Include StoredFieldsWriter in DWPT accounting to ensure that it's heap consumption is taken into account when IndexWriter stalls or should flush DWPTs. + LUCENE-9514: Include TermVectorsWriter in DWPT accounting to ensure that it's heap consumption is taken into account when IndexWriter stalls or should flush DWPTs. + LUCENE-9523: In query shapes over shape fields, skip points while traversing the BKD tree when the relationship with the document is already known. + LUCENE-9539: Use more compact datastructures to represent sorted doc-values in memory when sorting a segment before flush and in SortingCodecReader. + LUCENE-9458: WordDelimiterGraphFilter should order tokens at the same position by endOffset to emit longer tokens first. The same graph is produced. + LUCENE-5309: Optimize facet counting for single-valued SSDV / StringValueFacetCounts. + LUCENE-9023: GlobalOrdinalsWithScore should not compute occurrences when the provided min is 1. + LUCENE-9177: ICUNormalizer2CharFilter no longer requires normalization-inert characters as boundaries for incremental processing, vastly improving worst-case performance. + LUCENE-9455: ExitableTermsEnum should sample timeout and interruption check before calling next(). + LUCENE-9662: Make CheckIndex concurrent by parallelizing index check across segments. + LUCENE-9663: Add compression to terms dict from SortedSet/Sorted DocValues. + LUCENE-9675: Binary doc values fields now expose their configured compression mode in the attributes of the field info. + LUCENE-9725: BM25FQuery was extended to handle similarities beyond BM25Similarity. It was renamed to CombinedFieldQuery to reflect its more general scope. + LUCENE-9877: Reduce index size by increasing allowable exceptions in PForUtil from 3 to 7. + LUCENE-9687: Hunspell support improvements: add API for spell-checking and suggestions, support compound words, fix various behavior differences between Java and C++ implementations, improve performance + LUCENE-9917: The BEST_SPEED compression mode now trades more compression ratio in exchange of faster reads. + LUCENE-9935: Enable bulk merge for stored fields with index sort. + LUCENE-9944: Allow DrillSideways users to provide their own CollectorManager without also requiring them to provide an ExecutorService. + LUCENE-9945: Extend DrillSideways to support exposing FacetCollectors directly. + LUCENE-9946: Support for multi-value fields in LongRangeFacetCounts and DoubleRangeFacetCounts. + LUCENE-9965: Added QueryProfilerIndexSearcher and ProfilerCollector to support debugging query execution strategy and timing. + LUCENE-9981: Operations.getCommonSuffix/Prefix(Automaton) is now much more efficient, from a worst case exponential down to quadratic cost in the number of states + transitions in the Automaton. These methods no longer use the costly determinize method, removing the risk of TooComplexToDeterminizeException + LUCENE-9981: Operations.determinize now throws TooComplexToDeterminizeException based on too much "effort" spent determinizing rather than a precise state count on the resulting returned automaton, to better handle adversarial cases like det(rev(regexp("(.*a){2000}"))) that spend lots of effort but result in smallish eventual returned automata. + LUCENE-9983: Stop sorting determinize powersets unnecessarily. + LUCENE-10030: Lazily evaluate score in DrillSidewaysScorer.doQueryFirstScoring + LUCENE-10043: Decrease default for LRUQueryCache's skipCacheFactor to 10. This prevents caching a query clause when it is much more expensive than running the top-level query. + LUCENE-10103: Make QueryCache respect Accountable queries * Optimizations + LUCENE-9254: UniformSplit keeps FST off-heap. + LUCENE-8103: DoubleValuesSource and QueryValueSource now use a TwoPhaseIterator if one is provided by the Query. + LUCENE-9287: UsageTrackingQueryCachingPolicy no longer caches DocValuesFieldExistsQuery. + LUCENE-9286: FST.Arc.BitTable reads directly FST bytes. Arc is lightweight again and FSTEnum traversal faster. + LUCENE-7788: fail precommit on unparameterised log messages and examine for wasted work/objects + LUCENE-9273: Speed up geometry queries by specialising Component2D spatial operations. Instead of using a generic relate method for all relations, we use specialize methods for each one. In addition, the type of triangle is computed at deserialization time, therefore we can be more selective when decoding points of a triangle. + LUCENE-9087: Build always trees with full leaves and lower the default value for maxPointsPerLeafNode to 512. + LUCENE-9148: Points now write their index in a separate file. + LUCENE-9280: Add an ability for field comparators to skip non-competitive documents. Creating a TopFieldCollector with totalHitsThreshold less than Integer.MAX_VALUE instructs Lucene to skip non-competitive documents whenever possible. For numeric sort fields the skipping functionality works when the same field is indexed both with doc values and points. To indicate that the same data is stored in these points and doc values SortField#setCanUsePoints method should be used. + LUCENE-9395: ConstantValuesSource now shares a single DoubleValues instance across all segments + LUCENE-9447, LUCENE-9486: Stored fields now get higer compression ratios on highly compressible data. + LUCENE-9373: FunctionMatchQuery now accepts a "matchCost" optimization hint. + LUCENE-9510: Indexing with an index sort is now faster by not compressing temporary representations of the data. + LUCENE-9449: Enhance DocComparator to provide an iterator over competitive documents when searching with "after". This iterator can quickly position on the desired "after" document skipping all documents and segments before "after". + LUCENE-9021: QueryParser: re-use the LookaheadSuccess exception. + LUCENE-9346: WANDScorer now supports queries that have a 'minimumNumberShouldMatch' configured. + LUCENE-9536: Reduced memory usage for OrdinalMap when a segment has all values. + LUCENE-9636: Faster decoding of postings for some numbers of bits per value. + LUCENE-9673: Substantially improve RAM efficiency of how MemoryIndex stores postings in memory, and reduced a bit of RAM overhead in IndexWriter's internal postings book-keeping + LUCENE-9827: Speed up merging of stored fields and term vectors for smaller segments. + LUCENE-9932: Performance improvement for BKD index building + LUCENE-9996: Improved memory efficiency of IndexWriter's RAM buffer, in particular in the case of many fields and many indexing threads. + LUCENE-10014: Lucene90DocValuesFormat was using too many bits per value when compressing via gcd, unnecessarily wasting index storage. + LUCENE-10022: Rewrite empty DisjunctionMaxQuery to MatchNoDocsQuery. + LUCENE-10031: Slightly faster segment merging for sorted indices. + LUCENE-10196: Improve IntroSorter with 3-ways partitioning + LUCENE-10481: FacetsCollector will not request scores if it does not use them * Bug Fixes + LUCENE-9300: Fix corruption of the new gen field infos when doc values updates are applied on a segment created externally and added to the index with IndexWriter#addIndexes(Directory). + LUCENE-9350: Partial reversion of LUCENE-9068; holding levenshtein automata on FuzzyQuery can end up blowing up query caches which use query objects as cache keys, so building the automata is now delayed to search time again. + LUCENE-9259: Fix wrong NGramFilterFactory argument name for preserveOriginal option + LUCENE-8849: DocValuesRewriteMethod.visit wasn't visiting its embedded query + LUCENE-9258: DocTermsIndexDocValues assumed it was operating on a SortedDocValues (single valued) field when it could be multi-valued used with a SortedSetSelector + LUCENE-9164: Ensure IW processes all internal events before it closes itself on a rollback. + LUCENE-8908: Return default value from objectVal when doc doesn't match the query in QueryValueSource + LUCENE-9133: Fix for potential NPE in TermFilteredPresearcher for empty fields + LUCENE-9309: Wait for #addIndexes merges when aborting merges. + LUCENE-9337: Ensure CMS updates it's thread accounting datastructures consistently. CMS today releases it's lock after finishing a merge before it re-acquires it to update the thread accounting datastructures. This causes threading issues where concurrently finishing threads fail to pick up pending merges causing potential thread starvation on forceMerge calls + LUCENE-9314: Single-document monitor runs were using the less efficient MultiDocumentBatch implementation. + LUCENE-9362: Fix equality check in ExpressionValueSource#rewrite. This fixes rewriting of inner value sources. + LUCENE-9405: IndexWriter incorrectly calls closeMergeReaders twice when the merged segment is 100% deleted. + LUCENE-9400: Tessellator might build illegal polygons when several holes share the shame vertex. + LUCENE-9417: Tessellator might build illegal polygons when several holes share are connected to the same vertex. + LUCENE-9418: Fix ordered intervals over interleaved terms + LUCENE-9443: The UnifiedHighlighter was closing the underlying reader when there were multiple term-vector fields. This was a regression in 8.6.0. + LUCENE-9478: Prevent DWPTDeleteQueue from referencing itself and leaking memory. The queue passed an implicit this reference to the next queue instance on flush which leaked about 500byte of memory on each full flush, commit or getReader call. + LUCENE-9427: Fix a regression where the unified highlighter didn't produce highlights on fuzzy queries that correspond to exact matches. + LUCENE-9467: Fix NRTCachingDirectory to use Directory#fileLength to check if a file already exists instead of opening an IndexInput on the file which might throw a AccessDeniedException in some Directory implementations. + LUCENE-9501: Fix a bug in IndexSortSortedNumericDocValuesRangeQuery where it could violate the DocIdSetIterator contract. + LUCENE-9401: Include field in ComplexPhraseQuery's toString() + LUCENE-9578: Fix TermRangeQuery when there is no upper bound and the lower bound is the empty string excluded. This would previously match no strings at all while it should match all non-empty strings. + LUCENE-9524: Fix NPE in SpanWeight#explain when no scoring is required and SpanWeight has null Similarity.SimScorer. + LUCENE-9508: DocumentsWriter was only stalling threads for 1 second allowing documents to be indexed even the DocumentsWriter wasn't able to keep up flushing. Unless IW can't make progress due to an ill behaving DWPT this issue was barely noticeable. + LUCENE-9581: Japanese tokenizer should discard the compound token instead of disabling the decomposition of long tokens when discardCompoundToken is activated. + LUCENE-9595: Make Component2D#withinPoint implementations consistent with ShapeQuery logic. + LUCENE-9606: Wrap boolean queries generated by shape fields with a Constant score query. + LUCENE-9617: Fix per-field memory leak in IndexWriter.deleteAll(). Reset next available internal field number to 0 on FieldInfos.clear(), to avoid wasting FieldInfo references. + LUCENE-9635: BM25FQuery - Mask encoded norm long value in array lookup. + LUCENE-9642: When encoding triangles in ShapeField, make sure generated triangles are CCW by rotating triangle points before checking triangle orientation. + LUCENE-9661: Fix deadlock in TermsEnum.EMPTY that occurs when trying to initialize TermsEnum and BaseTermsEnum at the same time + LUCENE-9744: NPE on a degenerate query in MinimumShouldMatchIntervalsSource $MinimumMatchesIterator.getSubMatches(). + LUCENE-9762: DoubleValuesSource.fromQuery (also used by FunctionScoreQuery.boostByQuery) could throw an exception when the query implements TwoPhaseIterator and when the score is requested repeatedly. + LUCENE-9791: BytesRefHash.equals/find is now thread safe, fixing a Luwak/Monitor bug causing registered queries to sometimes fail to match. + LUCENE-9870: Fix Circle2D intersectsLine t-value (distance) range clamp + LUCENE-9887: Fixed parameter use in RadixSelector. + LUCENE-9953: LongValueFacetCounts should count each document at most once when determining the total count for a dimension. Prior to this fix, multi-value docs could contribute a > 1 count to the dimension count. + LUCENE-9958: Fixed performance regression for boolean queries that configure a minimum number of matching clauses. + LUCENE-9963: FlattenGraphFilter is now more robust when handling incoming holes in the input token graph + LUCENE-9964: Duplicate long values in a document field should only be counted once when using SortedNumericDocValuesFields + LUCENE-9967: Do not throw NullPointerException while trying to handle another exception in ReplicaNode.start + LUCENE-9988: Fix DrillSideways correctness bug introduced in LUCENE-9944 + LUCENE-9991: Fix edge case failure in TestStringValueFacetCounts + LUCENE-9999: CombinedFieldQuery can fail with an exception when document is missing some fields. + LUCENE-10008: Respect ignoreCase in CommonGramsFilterFactory + LUCENE-10020: DocComparator should not skip docs with the same docID on multiple sorts with search after + LUCENE-10026: Fix CombinedFieldQuery equals and hashCode, which ensures query rewrites don't drop CombinedFieldQuery clauses. + LUCENE-10039: Correct CombinedFieldQuery scoring when there is a single field. + LUCENE-10046: Counting bug fixed in StringValueFacetCounts. + LUCENE-10060: Ensure DrillSidewaysQuery instances never get cached. + LUCENE-10070 Skip deleted docs when accumulating facet counts for all docs + LUCENE-10081: KoreanTokenizer should check the max backtrace gap on whitespaces. + LUCENE-10106: Sort optimization can wrongly skip the first document of each segment + LUCENE-10110: MultiCollector now handles single leaf collector that wants to skip low-scoring hits but the combined score mode doesn't allow it + LUCENE-10111: Missing calculating the bytes used of DocsWithFieldSet in NormValuesWriter + LUCENE-10116: Missing calculating the bytes used of DocsWithFieldSet and currentValues in SortedSetDocValuesWriter + LUCENE-10119: Sort optimization with search_after can wrongly skip documents whose values are equal to the last value of the previous page + LUCENE-10126: Sort optimization with a chunked bulk scorer can wrongly skip documents + LUCENE-10134: ConcurrentSortedSetDocValuesFacetCounts shouldn't share liveDocs Bits across threads + LUCENE-10154: NumericLeafComparator to define getPointValues + LUCENE-10208: Ensure that the minimum competitive score does not decrease in concurrent search + LUCENE-10477: Highlighter: WeightedSpanTermExtractor.extractWeightedSpanTerms to Query#rewrite multiple times if necessary + LUCENE-10564: Make sure SparseFixedBitSet#or updates ramBytesUsed * Documentation + LUCENE-9424: Add a performance warning to AttributeSource.captureState javadocs * Changes in runtime behaviour + LUCENE-9539: SortingCodecReader now doesn't cache doc values fields anymore. Previously, SortingCodecReader used to cache all doc values fields after they were loaded into memory. This reader should only be used to sort segments after the fact using IndexWriter#addIndices. * Other + LUCENE-9257: Always keep FST off-heap. FSTLoadMode, Reader attributes and openedFromWriter removed. + LUCENE-9272: Checksums of the terms index are now verified when LeafReader#checkIntegrity is called rather than when opening the index. + LUCENE-9270: Update Javadoc about normalizeEntry in the Kuromoji DictionaryBuilder. + LUCENE-9275: Make TestLatLonMultiPolygonShapeQueries more resilient for CONTAINS queries. + LUCENE-9244: Adjust TestLucene60PointsFormat#testEstimatePointCount2Dims so it does not fail when a point is shared by multiple leaves. + LUCENE-9271: ByteBufferIndexInput was refactored to work on top of the ByteBuffer API. + LUCENE-9191: Make LineFileDocs's random seeking more efficient, making tests using LineFileDocs faster + LUCENE-9338: Refactors SimpleBindings to improve type safety and cycle detection + LUCENE-9358: Change the way the multi-dimensional BKD tree builder generates the intermediate tree representation to be equal to the one dimensional case to avoid unnecessary tree and leaves rotation. + LUCENE-9288: poll_mirrors.py release script can handle HTTPS mirrors. + LUCENE-9232: Fix or suppress 13 resource leak precommit warnings in lucene/replicator + LUCENE-9398: Always keep BKD index off-heap. BKD reader does not implement Accountable any more. + LUCENE-9292: Refactor BKD point configuration into its own class. + LUCENE-9470: Make TestXYMultiPolygonShapeQueries more resilient for CONTAINS queries. + LUCENE-9512: Move LockFactory stress test to be a unit/integration test. + LUCENE-9637: Removes some unused code and replaces the Point implementation on ShapeField/ShapeQuery random tests. + LUCENE-9836: Removed the pure Maven build. It is no longer possible to build artifacts using Maven (this feature was no longer working correctly). Due to migration to Gradle for Lucene/Solr 9.0, the maintenance of the Maven build was no longer reasonable. POM files are generated for deployment to Maven Central only. Please use "ant generate-maven-artifacts" to produce and deploy artifacts to any repository. + LUCENE-9836: Migrate Maven tasks to use "maven-resolver-ant-tasks" instead of the no longer maintained "maven-ant-tasks". + LUCENE-9985: Upgrade jetty to 9.4.41 + LUCENE-9976: Fix WANDScorer assertion error. + LUCENE-10098: Add docs/links to GermanAnalyzer describing how to decompound nouns + SOLR-14995: Update Jetty to 9.4.34 * Build + Upgrade forbiddenapis to version 3.0.1. + LUCENE-9376: Fix or suppress 20 resource leak precommit warnings in lucene/search + LUCENE-9380: Fix auxiliary class warnings in Lucene + LUCENE-9389: Enhance gradle logging calls validation: eliminate getMessage() + Upgrade forbiddenapis to version 3.1. + LUCENE-10104, SOLR-15631: Upgrade forbiddenapis to version 3.2 - Removed patch: * lucene-java8compat.patch + not needed in this version, since the compatibility is handled by --release option for javac versions that support it - Added patch: * lucene-timestamps.patch + use SOURCE_DATE_EPOCH for timestamps and for pseudo-random seeds + improves reproducibility of builds using lucene for indexing - Modified patches: * lucene-missing-dependencies.patch * lucene-nodoclint.patch * lucene-osgi-manifests.patch + rediff to changed context- Avoid xerces-j2 on classpath * fixes build after apache-ivy upgrade to 2.5.2- Do not depend on jtidy, since it is not used during build- Added patch: * lucene-nodoclint.patch + Do not abort compilation on html5 errors with javadoc 17- Upgrade to version 8.5.0 * API Changes: + LUCENE-9093: Change in behavior of the UnifiedHighlighter's LengthGoalBreakIterator that will yield Passages sized a little different due to the fact that the sizing pivot is now the center of the first match and not its left edge. + LUCENE-9116: PostingsWriterBase and PostingsReaderBase no longer support setting a field's metadata via a 'long[]'. + LUCENE-9116: The FSTOrd postings format has been removed. + LUCENE-8369: Remove obsolete spatial module. + LUCENE-8621: Refactor LatLonShape, XYShape, and all query and utility classes to core. + LUCENE-9218: XY geometries API works in float space. + LUCENE-9212: Intervals.multiterm() takes CompiledAutomaton rather than plain Automaton + LUCENE-9150: Restore support for dynamic PlanetModel in spatial3d. + LUCENE-9171: QueryBuilder.newTermQuery() and .newSynonymQuery() now take boost parameters. + LUCENE-9029: Deprecate SloppyMath toRadians/toDegrees in favor of Java Math. + LUCENE-8620: Add CONTAINS support for LatLonShape and XYShape. + LUCENE-9050: MultiTermIntervalsSource.visit() was not calling back to its visitor. + LUCENE-8909: IndexWriter#getFieldNames() method is used to get fields present in index. After LUCENE-8316, this method is no longer required. Hence, deprecate IndexWriter#getFieldNames() method. + LUCENE-8755: SpatialPrefixTreeFactory now consumes the "version" parsed with Lucene's Version class. The quad and packed quad prefix trees are sensitive to this. It's recommended to pass the version like you should do likewise for analysis components for tokenized text, or else changes to the encoding in future versions may be incompatible with older indexes. + LUCENE-8956: QueryRescorer now only sorts the first topN hits instead of all initial hits. + LUCENE-8921: IndexSearcher.termStatistics() no longer takes a TermStates; it takes the docFreq and totalTermFreq. And don't call if docFreq <= 0. The previous implementation survives as deprecated and final. It's removed in 9.0. + LUCENE-8990: PointValues#estimateDocCount(visitor) estimates the number of documents that would be matched by the given IntersectVisitor. THe method is used to compute the cost() of ScorerSuppliers instead of PointValues#estimatePointCount(visitor). + LUCENE-8865: IndexSearcher now uses Executor instead of ExecutorService. This change is fully backwards compatible since ExecutorService directly implements Executor. + LUCENE-8856: Intervals queries have moved from the sandbox to the queries module. + LUCENE-8893: Intervals.wildcard() and Intervals.prefix() methods now take BytesRef rather than String. + LUCENE-3041: A query introspection API has been added. Queries should implement a visit() method, taking a QueryVisitor, and either pass the visitor down to any child queries, or call a visitX() or consumeX() method on it. All locations in the code that called Weight.extractTerms() have been changed to use this API, and the extractTerms() method has been deprecated. + LUCENE-8735: Directory.getPendingDeletions is now abstract to ensure subclasses override it. FilterDirectory now delegates the call, ensuring correct default behaviour for subclasses. + LUCENE-8662: TermsEnum.seekExact(BytesRef) to abstract and delegate seekExact(BytesRef) in FilterLeafReader.FilterTermsEnum. + LUCENE-8469: Deprecated StringHelper.compare has been removed. + LUCENE-8039: Introduce a "delta distance" method set to GeoDistance. This allows distance calculations, especially for paths, to take into account an "excursion" to include the specified point. + LUCENE-8007: Index statistics Terms.getSumDocFreq(), Terms.getDocCount() are now required to be stored by codecs. Additionally, TermsEnum.totalTermFreq() and Terms.getSumTotalTermFreq() are now required: if frequencies are not stored they are equal to TermsEnum.docFreq() and Terms.getSumDocFreq(), respectively, because all freq() values equal 1. + LUCENE-8038: Deprecated PayloadScoreQuery constructors have been removed + LUCENE-8014: Similarity.computeSlopFactor() and Similarity.computePayloadFactor() have been removed + LUCENE-7996: Queries are now required to produce positive scores. + LUCENE-8099: CustomScoreQuery, BoostedQuery and BoostingQuery have been removed + LUCENE-8012: Explanation now takes Number rather than float + LUCENE-8116: SimScorer now only takes a frequency and a norm as per-document scoring factors. + LUCENE-8113: TermContext has been renamed to TermStates, and can now be constructed lazily if term statistics are not required + LUCENE-8242: Deprecated method IndexSearcher#createNormalizedWeight() has been removed + LUCENE-8267: Memory codecs removed from the codebase (MemoryPostings, MemoryDocValues). + LUCENE-8144: Moved QueryCachingPolicy.ALWAYS_CACHE to the test framework. + LUCENE-8356: StandardFilter and StandardFilterFactory have been removed + LUCENE-8373: StandardAnalyzer.ENGLISH_STOP_WORD_SET has been removed + LUCENE-8388: Unused PostingsEnum#attributes() method has been removed + LUCENE-8405: TopDocs.maxScore is removed. IndexSearcher and TopFieldCollector no longer have an option to compute the maximum score when sorting by field. + LUCENE-8411: TopFieldCollector no longer takes a fillFields option, it now always fills fields. + LUCENE-8412: TopFieldCollector no longer takes a trackDocScores option. Scores need to be set on top hits via TopFieldCollector#populateScores instead. + LUCENE-6228: A new Scorable abstract class has been added, containing only those methods from Scorer that should be called from Collectors. LeafCollector.setScorer() now takes a Scorable rather than a Scorer. + LUCENE-8475: Deprecated constants have been removed from RamUsageEstimator. + LUCENE-8483: Scorers may no longer take null as a Weight + LUCENE-8352: TokenStreamComponents is now final, and can take a Consumer in its constructor + LUCENE-8498: LowerCaseTokenizer has been removed, and CharTokenizer no longer takes a normalizer function. + LUCENE-7875: Moved MultiFields static methods out of the class. getLiveDocs is now in MultiBits which is now public. getMergedFieldInfos and getIndexedFields are now in FieldInfos. getTerms is now in MultiTerms. getTermPositionsEnum and getTermDocsEnum were collapsed and renamed to just getTermPostingsEnum and moved to MultiTerms. + LUCENE-8513: MultiFields.getFields is now removed. Please avoid this class, and Fields in general, when possible. + LUCENE-8497: MultiTermAwareComponent has been removed, and in its place TokenFilterFactory and CharFilterFactory now expose type-safe normalize() methods. This decouples normalization from tokenization entirely. + LUCENE-8597: IntervalIterator now exposes a gaps() method that reports the number of gaps between its component sub-intervals. This can be used in a new filter available via Intervals.maxgaps(). + LUCENE-8609: Remove IndexWriter#numDocs() and IndexWriter#maxDoc() in favor of IndexWriter#getDocStats(). * Changes in Runtime Behavior + LUCENE-8671: Load FST off-heap also for ID-like fields if reader is not opened from an IndexWriter. + LUCENE-8730: WordDelimiterGraphFilter always emits its original token first. This brings its behaviour into line with the deprecated WordDelimiterFilter, so that the only difference in output between the two is in the position length attribute. + LUCENE-7386: Disjunctions nested in disjunctions are now flattened. This might trigger changes in the produced scores due to changes to the order in which scores of sub clauses are summed up. + LUCENE-8756: MoreLikeThisQuery now respects custom term frequencies (TermFrequencyAttribute) at search time + LUCENE-8333: Switch MoreLikeThis.setMaxDocFreqPct to use maxDoc instead of numDocs. + LUCENE-7837: Indices that were created before the previous major version will now fail to open even if they have been merged with the previous major version. + LUCENE-8020: Similarities are no longer passed terms that don't exist by queries such as SpanOrQuery, so scoring formulas no longer require divide-by-zero hacks. IndexSearcher.termStatistics/collectionStatistics return null instead of returning bogus values for a non-existent term or field. + LUCENE-7996: FunctionQuery and FunctionScoreQuery now return a score of 0 when the function produces a negative value. + LUCENE-8116: Similarities now score fields that omit norms as if the norm was 1. This might change score values on fields that omit norms. + LUCENE-8134: Index options are no longer automatically downgraded. + LUCENE-8031: Length normalization correctly reflects omission of term frequencies. + LUCENE-7444: StandardAnalyzer no longer defaults to removing English stopwords + LUCENE-8060: IndexSearcher's search and searchAfter methods now only compute total hit counts accurately up to 1,000 in order to enable top-hits optimizations such as block-max WAND (LUCENE-8135). + LUCENE-8505: IndexWriter#addIndices will now fail if the target index is sorted but the candidate is not. + LUCENE-8535: Highlighter and FVH doesn't support ToParent and ToChildBlockJoinQuery out of the box anymore. In order to highlight on Block-Join Queries a custom WeightedSpanTermExtractor / FieldQuery should be used. + LUCENE-8563: BM25 scores don't include the (k1+1) factor in their numerator anymore. This doesn't affect ordering as this is a constant factor which is the same for every document. + LUCENE-8509: WordDelimiterGraphFilter will no longer set the offsets of internal tokens by default, preventing a number of bugs when the filter is chained with tokenfilters that change the length of their tokens + LUCENE-8633: IntervalQuery scores do not use term weighting any more, the score is instead calculated as a function of the sloppy frequency of the matching intervals. + LUCENE-8635: FSTs can now remain off-heap, accessed via IndexInput, and the default codec's term dictionary (BlockTreeTermsReader) will now leave the FST for the terms index off-heap for non-primary-key fields using MMapDirectory, reducing heap usage for such fields. * New Features: + LUCENE-8903: Add LatLonShape and XYShape point query. + LUCENE-8707: Add LatLonShape and XYShape distance query. + LUCENE-9238: New XYPointField field and Queries for indexing, searching and sorting cartesian points. + LUCENE-8936: Add SpanishMinimalStemFilter + LUCENE-8764 LUCENE-8945: Add "export all terms and doc freqs" feature to Luke with delimiters. + LUCENE-8747: Composite Matches from multiple subqueries now allow access to their submatches, and a new NamedMatches API allows marking of subqueries and a simple way to find which subqueries have matched on a given document + LUCENE-8769: Introduce Range Query For Multiple Connected Ranges + LUCENE-8960: Introduce LatLonDocValuesPointInPolygonQuery for LatLonDocValuesField + LUCENE-8753: New UniformSplitPostingsFormat (name "UniformSplit") primarily benefiting in simplicity and extensibility. New STUniformSplitPostingsFormat (name "SharedTermsUniformSplit") that shares a single internal term dictionary across fields. + LUCENE-8632: New XYShape Field and Queries for indexing and searching general cartesian geometries. + LUCENE-8891: Snowball stemmer/analyzer for the Estonian language. + LUCENE-8815: Provide a DoubleValues implementation for retrieving the value of features without requiring a separate numeric field. Note that as feature values are stored with only 8 bits of mantissa the values returned may have a delta from the original values indexed. + LUCENE-8803: Provide a FeatureSortfield to allow sorting search hits by descending value of a feature. This is exposed via the factory method FeatureField#newFeatureSort. + LUCENE-8784: The KoreanTokenizer now preserves punctuations if discardPunctuation is set to false (defaults to true). + LUCENE-8812: Add new KoreanNumberFilter that can change Hangul character to number and process decimal point. It is similar to the JapaneseNumberFilter. + LUCENE-8362: Add doc-value support to range fields. + LUCENE-8766: Add monitor subproject (previously Luwak monitoring library). This allows a stream of documents to be matched against a set of registered queries in an efficien manner, for use as a monitoring or classification tool. + LUCENE-7714: Add a numeric range query in sandbox that takes advantage of index sorting. + LUCENE-8859: The completion suggester's postings format now have an option to load its internal FST off-heap. + LUCENE-2562: The well-known graphical user interface for inspecting Lucene indexes "Luke" was added as a Lucene module. It can be started from the binary distribution by calling the shell scripts in the module folder or from the source checkout by using 'ant -f lucene/luke/build.xml run'. Luke provides a Swing-based user interface and can be used to open Lucene or Solr (or Elasticsearch) indexes, inspect documents, check index commits and segments, or test (custom) analyzers. It also has maintenance functions to check index structures and force merge indexes for archival. + LUCENE-8340: LongPoint#newDistanceFeatureQuery may be used to boost scores based on how close a value of a long field is from a configurable origin. This is typically useful to boost by recency. + LUCENE-8482: LatLonPoint#newDistanceFeatureQuery may be used to boost scores based on the haversine distance of a LatLonPoint field to a provided point. This is typically useful to boost by distance. + LUCENE-8216: Added a new BM25FQuery in sandbox to blend statistics across several fields using the BM25F formula. + LUCENE-8564: GraphTokenFilter is an abstract class useful for token filters that need to read-ahead in the token stream and take into account graph structures. This also changes FixedShingleFilter to extend GraphTokenFilter + LUCENE-8612: Intervals.extend() treats an interval as if it covered a wider span than it actually does, allowing users to force minimum gaps between intervals in a phrase. + LUCENE-8629: New interval functions: Intervals.before(), Intervals.after(), Intervals.within() and Intervals.overlapping(). + LUCENE-8622: Adds a minimum-should-match interval function that produces intervals spanning a subset of a set of sources. + LUCENE-8645: Intervals.fixField() allows you to report intervals from one field as if they came from another. + LUCENE-8646: New interval functions: Intervals.prefix() and Intervals.wildcard() + LUCENE-8655: Add a getter in FunctionScoreQuery class in order to access to the underlying DoubleValuesSource. + LUCENE-8697: GraphTokenStreamFiniteStrings correctly handles side paths containing gaps + LUCENE-8702: Simplify intervals returned from vararg Intervals factory methods * Improvements: + LUCENE-9149: Increase data dimension limit in BKD. + LUCENE-9102: Add maxQueryLength option to DirectSpellchecker. + LUCENE-9091: UnifiedHighlighter HTML escaping should only escape essentials + LUCENE-9105: UniformSplit postings format detects corrupted index and better handles IO exceptions. + LUCENE-9106: UniformSplit postings format allows extension of block/line serializers. + LUCENE-9093: UnifiedHighlighter's LengthGoalBreakIterator has a new fragmentAlignment option to better center the first match in the passage. Also the sizing point now pivots at the center of the first match term and not its left edge. This yields Passages that won't be identical to the previous behavior. + LUCENE-9153: Allow WhitespaceAnalyzer to set a maxTokenLength other than the default of 255 + LUCENE-9152: Improve line intersections with polygons when they are touching from the outside. + LUCENE-9123: Add new JapaneseTokenizer constructors with discardCompoundToken option that controls whether the tokenizer emits original (compound) tokens when the mode is not NORMAL. + UCENE-9253: KoreanTokenizer now supports custom dictionaries(system, unknown). + LUCENE-9171: QueryBuilder can now use BoostAttributes on input token streams to selectively boost particular terms or synonyms in parsed queries. + LUCENE-9002: Skip costly caching clause in LRUQueryCache if it makes the query many times slower. + LUCENE-9006: WordDelimiterGraphFilter's catenateAll token is now ordered before any token parts, like WDF did. + LUCENE-9028: introducing Intervals.multiterm() + LUCENE-9018: ConcatenateGraphFilter now has a configurable separator. + LUCENE-9036: ExitableDirectoryReader may interupt scaning over DocValues + LUCENE-9062: QueryVisitor now has a consumeTermsMatching() method, allowing queries that match a class of terms to pass a ByteRunAutomaton matching those that class back to the visitor. + LUCENE-9073: IntervalQuery to respond field on toString() and explain() + LUCENE-8874: Show SPI names instead of class names in Luke Analysis tab. + LUCENE-8894: Add APIs to find SPI names for Tokenizer/CharFilter/TokenFilter factory classes. + LUCENE-8914: move the logic for discarding inner modes in FloatPointNearestNeighbor to the IntersectVisitor so we take advantage of the change introduced in LUCENE-7862. + LUCENE-8955: move the logic for discarding inner modes in LatLonPoint NearestNeighbor to the IntersectVisitor so we take advantage of the change introduced in LUCENE-7862. + LUCENE-8918: PhraseQuery throws exceptions at construction time if it is passed null arguments. + LUCENE-8916: GraphTokenStreamFiniteStrings preserves all Token attributes through its finite strings TokenStreams + LUCENE-8933: Check kuromoji user dictionary beforehand to avoid unexpected runtime exceptions. (Tomoko Uchida + LUCENE-8906: Expose Lucene50PostingsFormat.IntBlockTermState as public so that other postings formats can re-use it. + LUCENE-8942: Remove redundant parameters and improve visibility strictness in LRUQueryCache + SOLR-13663: Introduce into XML Query Parser + LUCENE-8952: Use a sort key instead of true distance in NearestNeighbor + LUCENE-8620: Tessellator labels the edges of the generated triangles whether they belong to the original polygon. This information is added to the triangle encoding. + LUCENE-8964: Fix geojson shape parsing on string arrays in properties + LUCENE-8976: Use exact distance between point and bounding rectangle in FloatPointNearestNeighbor. + LUCENE-8966: The Korean analyzer now splits tokens on boundaries between digits and alphabetic characters. + LUCENE-8984: MoreLikeThis MLT is biased for uncommon fields + LUCENE-7840: Non-scoring BooleanQuery now removes SHOULD clauses before building the scorer supplier as opposed to eliminating them during scoring construction. + LUCENE-8770: BlockMaxConjunctionScorer now leverages two-phase iterators in order to avoid executing the second phase when scorers don't intersect. + LUCENE-8781: FST lookup performance has been improved in many cases by encoding Arcs using full-sized arrays with gaps. The new encoding is enabled for postings in the default codec and for suggesters. + LUCENE-8818: Fix smokeTestRelease.py encoding bug + LUCENE-8845: Allow Intervals.prefix() and Intervals.wildcard() to specify their maximum allowed expansions + LUCENE-8875: Introduce a Collector optimized for use cases when large number of hits are requested + LUCENE-8848 LUCENE-7757 LUCENE-8492: The UnifiedHighlighter now detects that parts of the query are not understood by it, and thus it should not make optimizations that result in no highlights or slow highlighting. This generally works best for WEIGHT_MATCHES mode. Consequently queries produced by ComplexPhraseQueryParser and the surround QueryParser will now highlight correctly. + LUCENE-8793: Luke enhanced UI for CustomAnalyzer: show detailed analysis steps. + LUCENE-8855: Add Accountable to some Query implementations + LUCENE-8673: Use radix partitioning when merging dimensional points instead of sorting all dimensions before hand. + LUCENE-8687: Optimise radix partitioning for points on heap. + LUCENE-8699: Change HeapPointWriter to use a single byte array instead to a list of byte arrays. In addition a new interface PointValue is added to abstract out the different formats between offline and on-heap writers. + LUCENE-8703: Build point writers in the BKD tree only when they are needed. + LUCENE-8652: SynonymQuery can now deboost the document frequency of each term when blending the score of the synonym. + LUCENE-8631: The Korean's user dictionary now picks the longest-matching word and discards the other matches. + LUCENE-8732: ConstantScoreQuery can now early terminate the query if the minimum score is greater than the constant score and total hits are not requested. + LUCENE-8750: Implements setMissingValue() on sort fields produced from DoubleValuesSource and LongValuesSource + LUCENE-8701: ToParentBlockJoinQuery now creates a child scorer that disallows skipping over non-competitive documents if the score of a parent depends on the score of multiple children (avg, max, min). Additionally the score mode 'none' that assigns a constant score to each parent can early terminate top scores's collection. + LUCENE-8751: Weight#matches now use the ScorerSupplier to build scorers with a lead cost of 1 (single document). + LUCENE-8752: Japanese new era name '令和' (Reiwa) is added to the dictionary used in JapaneseTokenizer so that the analyzer handles the era name correctly. Reiwa is set to replace the Heisei Era on May 1, 2019. + LUCENE-8671: Introduced reader attributes allows a per IndexReader configuration of codec internals. This enables a per reader configuration if FSTs are on- or off-heap on a per field basis + LUCENE-8787: spatial-extras DateRangePrefixTree used to only parse ISO-8601 timestamps with 0 or 3 digits of milliseconds precision but now parses other lengths (although > 3 not used). + LUCENE-7997: Add BaseSimilarityTestCase to sanity check similarities. SimilarityBase switches to 64-bit doubles internally to help avoid common numeric issues. Add missing range checks for similarity parameters. Improve BM25 and ClassicSimilarity's explanations. + LUCENE-8011: Improved similarity explanations. + LUCENE-4198: Codecs now have the ability to index score impacts. + LUCENE-8135: Boolean queries now implement the block-max WAND algorithm in order to speed up selection of top scored documents. + LUCENE-8279: CheckIndex now cross-checks terms with norms. + LUCENE-8660: TopDocsCollectors now return an accurate count (instead of a lower bound) if the total hit count is equal to the provided threshold. * Optimizations + LUCENE-9211: Add compression for Binary doc value fields. + LUCENE-4702: Better compression of terms dictionaries. + LUCENE-9228: Sort dvUpdates in the term order before applying if they all update a single field to the same value. This optimization can reduce the flush time by around 20% for the docValues update user cases. + LUCENE-9245: Reduce AutomatonTermsEnum memory usage. + LUCENE-9237: Faster UniformSplit intersect TermsEnum. + LUCENE-9068: FuzzyQuery builds its Automaton up-front + LUCENE-9113: Faster merging of SORTED/SORTED_SET doc values. + LUCENE-9125: Optimize Automaton.step() with binary search and introduce Automaton.next(). + LUCENE-9147: The index of stored fields and term vectors in now off-heap. + LUCENE-8928: When building a kd-tree for dimensions n > 2, compute exact bounds for an inner node every N splits to improve the quality of the tree. N is defined by SPLITS_BEFORE_EXACT_BOUNDS which is set to 4. + BaseDirectoryReader no longer sums up the 'LeafReader#numDocs' of its leaves eagerly. This especially helps when creating views of readers that hide documents, since computing the number of live documents is an expensive operation. + LUCENE-8992: TopFieldCollector and TopScoreDocCollector can now share minimum scores across leaves concurrently. + LUCENE-8932: BKDReader's index is now stored off-heap when the IndexInput is an instance of ByteBufferIndexInput. + LUCENE-9024: IntroSelector now falls back to the median of medians algorithm instead of sorting when the maximum recursion level is exceeded, providing better worst-case runtime. + LUCENE-8920: The denser arcs of FST now index labels with a bitset in order to provide near constant time access. + LUCENE-9027: Use SIMD instructions to decode postings. + LUCENE-9049: Remove FST cached root arcs now redundant with labels indexed by bitset. This frees some on-heap FST space. + LUCENE-9045: Do not use TreeMap/TreeSet in BlockTree and PerFieldPostingsFormat. + LUCENE-8922: DisjunctionMaxQuery more efficiently leverages impacts to skip non-competitive hits. + LUCENE-8935: BooleanQuery with no scoring clause can now early terminate the query when the total hits is not requested. + LUCENE-8941: Matches on wildcard queries will defer building their full disjunction until a MatchesIterator is pulled + LUCENE-8755: spatial-extras quad and packed quad prefix trees now index points faster. + LUCENE-8860: add additional leaf node level optimizations in LatLonShapeBoundingBoxQuery. + LUCENE-8968: Improve performance of WITHIN and DISJOINT queries for Shape queries by doing just one pass whenever possible. + LUCENE-8939: Introduce shared count based early termination across multiple slices + LUCENE-8980: Blocktree's seekExact now short-circuits false if the term isn't in the min-max range of the segment. Large perf gain for ID/time like data when populated sequentially. + LUCENE-8796: Use exponential search instead of binary search in IntArrayDocIdSet#advance method + LUCENE-8865: Use incoming thread for execution if IndexSearcher has an executor. Now caller threads execute at least one search on an index even if there is an executor provided to minimize thread context switching. + LUCENE-8868: New storing strategy for BKD tree leaves with low cardinality. It stores the distinct values once with the cardinality value reducing the storage cost. + LUCENE-8885: Optimise BKD reader by exploiting cardinality information stored on leaves. + LUCENE-8896: Override default implementation of IntersectVisitor#visit(DocIDSetBuilder, byte[]) for several queries. + LUCENE-8901: Load frequencies lazily only when needed in BlockDocsEnum and BlockImpactsEverythingEnum + LUCENE-8888: Optimize distribution of points with data dimensions in BKD tree leaves. + LUCENE-8311: Phrase queries now leverage impacts. + LUCENE-8040: Optimize IndexSearcher.collectionStatistics, avoiding MultiFields/MultiTerms + LUCENE-4100: Disjunctions now support faster collection of top hits when the total hit count is not required. + LUCENE-7993: Phrase queries are now faster if total hit counts are not required. + LUCENE-8109: Boolean queries propagate information about the minimum competitive score in order to make collection faster if there are disjunctions or phrase queries as sub queries, which know how to leverage this information to run faster. + LUCENE-8439: Disjunction max queries can skip blocks to select the top documents if the total hit count is not required. + LUCENE-8204: Boolean queries with a mix of required and optional clauses are now faster if the total hit count is not required. + LUCENE-8448: Boolean queries now propagates the mininum score to their sub-scorers. + LUCENE-8511: MultiFields.getIndexedFields is now optimized; does not call getMergedFieldInfos + LUCENE-8507: TopFieldCollector can now update the minimum competitive score if the primary sort is by relevancy and the total hit count is not required. + LUCENE-8464: ConstantScoreScorer now implements setMinCompetitveScore in order to early terminate the iterator if the minimum score is greater than the constant score. + LUCENE-8607: MatchAllDocsQuery can shortcut when total hit count is not required + LUCENE-8585: Index-time jump-tables for DocValues, for O(1) advance when retrieving doc values. * Bug Fixes + LUCENE-9084: Fix potential deadlock due to circular synchronization in AnalyzingInfixSuggester + LUCENE-9115: NRTCachingDirectory no longer caches files of unknown size. + LUCENE-9144: Fix error message on OneDimensionBKDWriter when too many points are added to the writer. + LUCENE-9135: Make UniformSplit FieldMetadata counters long. + LUCENE-9200: Fix TieredMergePolicy to use double (not float) math to make its merging decisions, fixing a corner-case bug uncovered by fun randomized tests + LUCENE-9099: Unordered and Ordered interval queries now correctly handle repeated subterms - ordered intervals could supply an 'extra' minimized interval, resulting in odd matches when combined with eg CONTAINS queries; and unordered intervals would match duplicate subterms on the same position, so an query for UNORDERED(foo, foo) would match a document containing 'foo' only once. + LUCENE-9250: Add support for Circle2d#intersectsLine around the dateline. + LUCENE-9243: Add fudge factor when creating a bounding box of a XYCircle. + LUCENE-9239: Circle2D#WithinTriangle detects properly if a triangle is Within distance. + LUCENE-9251: Fix bug in the polygon tessellator where edges with different value on #isEdgeFromPolygon were bot filtered out properly. + LUCENE-9263: Fix wrong transformation of distance in meters to radians in Geo3DPoint. + LUCENE-9001: Fix race condition in SetOnce. + LUCENE-9030: Fix WordnetSynonymParser behaviour so it behaves similar to SolrSynonymParser. + LUCENE-9054: Fix reproduceJenkinsFailures.py to not overwrite junit XML files when retrying + LUCENE-9031: UnsupportedOperationException on MatchesIterator.getQuery() + LUCENE-8996: maxScore was sometimes missing from distributed grouped responses. + LUCENE-9055: Fix the detection of lines crossing triangles through edge points. + LUCENE-9103: Disjunctions can miss some hits in some rare conditions. + LUCENE-8755: spatial-extras quad and packed quad prefix trees could throw a NullPointerException for certain cell edge coordinates + LUCENE-9005: BooleanQuery.visit() would pull subVisitors from its parent visitor, rather than from a visitor for its own specific query. This could cause problems when BQ was nested under another BQ. Instead, we now pull a MUST subvisitor, pass it to any MUST subclauses, and then pull SHOULD, MUST_NOT and FILTER visitors from it rather than from the parent. + LUCENE-8831: Fixed LatLonShapeBoundingBoxQuery .hashCode methods. + LUCENE-8775: Improve tessellator to handle better cases where a hole share a vertex with the polygon. + LUCENE-8785: Ensure new threadstates are locked before retrieving the number of active threadstates. This causes assertion errors and potentially broken field attributes in the IndexWriter when IndexWriter#deleteAll is called while actively indexing. + LUCENE-8804: Forbid calls to putAttribute on frozen FieldType instances. + LUCENE-8828: Removes the buggy 'disallow overlaps' boolean from Intervals.unordered(), and replaces it with a new Intervals.unorderedNoOverlaps() method + LUCENE-8843: Don't ignore exceptions that are thrown when trying to open a file in IOUtils#fsync. + LUCENE-8835: FileSwitchDirectory now respects the file extension when listing directory contents to ensure we don't expose pending deletes if both directory point to the same underlying filesystem directory. + LUCENE-8853: FileSwitchDirectory now applies best effort to place tmp files in the same directory as the target files. + LUCENE-8892: Add missing closing parentheses in MultiBoolFunction's description() + LUCENE-8736: LatLonShapePolygonQuery returns incorrect WITHIN results with shared boundaries. Point in Polygon now correctly includes boundary points. Box and Polygon relations with triangles have also been improved to correctly include boundary points. + LUCENE-8712: Polygon2D does not detect crossings through segment edges. + LUCENE-8720: NameIntCacheLRU (in the facets module) had an int overflow bug that disabled cleaning of the cache + LUCENE-8726: ValueSource.asDoubleValuesSource() could leak a reference to IndexSearcher + LUCENE-8719: FixedShingleFilter can miss shingles at the end of a token stream if there are multiple paths with different lengths. + LUCENE-8688: TieredMergePolicy#findForcedMerges now tries to create the cheapest merges that allow the index to go down to 'maxSegmentCount' segments or less. + LUCENE-8477: Interval disjunctions could miss valid hits if some of the clauses of the disjunction are minimized away. We now rewrite intervals if a source contains a disjunction and the internal gaps matter for matching. This behaviour can be disabled if users are more interested in speed rather than accuracy of matching. + LUCENE-8741: ValueSource.fromDoubleValuesSource() was casting to Scorer instead of Scorable, leading to ClassCastExceptions + LUCENE-8754: Fix ConcurrentModificationException in SegmentInfo if attributes are accessed in MergePolicy while the merge is running + LUCENE-8765: Fixed validation of the number of added points in KD trees. * Other + LUCENE-9109: Backport some changes from master (except StackWalker) to improve TestSecurityManager + LUCENE-9110: Backport refactored stack analysis in tests to use generalized LuceneTestCase methods + LUCENE-9141: Simplify LatLonShapeXQuery API by adding a new abstract class called LatLonGeometry. Queries are executed with input objects that extend such interface. + LUCENE-9194: Simplify XYShapeXQuery API by adding a new abstract class called XYGeometry. Queries are executed with input objects that extend such interface. + LUCENE-9096: Simplification of CompressingTermVectorsWriter#flushOffsets. + LUCENE-9225: Rectangle extends LatLonGeometry so it can be used in a geometry collection. + LUCENE-8979: Code Cleanup: Use entryset for map iteration wherever possible. - Part 2 + LUCENE-8746: Refactor EdgeTree - Introduce a Component tree that represents the tree of components (e.g polygons). Edge tree is now just a tree of edges. + LUCENE-8994: Code Cleanup - Pass values to list constructor instead of empty constructor followed by addAll(). + LUCENE-9046: Fix wrong example in Javadoc of TermInSetQuery + LUCENE-8983: Add sandbox PhraseWildcardQuery to control multi-terms expansions in a phrase. + LUCENE-9067: Polygon2D#contains() is now thread safe. + LUCENE-8778 LUCENE-8911 LUCENE-8957: Define analyzer SPI names as static final fields and document the names in Javadocs. + LUCENE-8758: QuadPrefixTree: removed levelS and levelN fields which weren't used. + LUCENE-8975: Code Cleanup: Use entryset for map iteration wherever possible. + LUCENE-8993, LUCENE-8807: Changed all repository and download references in build files to HTTPS. + LUCENE-8998: Fix OverviewImplTest.testIsOptimized reproducible failure. + LUCENE-8999: LuceneTestCase.expectThrows now propogates assert/assumption failures up to the test w/o wrapping in a new assertion failure unless the caller has explicitly expected them + LUCENE-8062: GlobalOrdinalsWithScoreQuery is no longer eligible for query caching. + LUCENE-8847: Code Cleanup: Remove StringBuilder.append with concatenated strings. + LUCENE-8861: Script to find open Github PRs that needs attention + LUCENE-8852: ReleaseWizard tool for release managers + LUCENE-8838: Remove support for Steiner points on Tessellator. + LUCENE-8879: Improve BKDRadixSelector tests. + LUCENE-8886: Fix TestMutablePointsReaderUtils tests. + LUCENE-8680: Refactor EdgeTree#relateTriangle method. + LUCENE-8685: Refactor LatLonShape tests. + LUCENE-8713: Add Line2D tests. + LUCENE-8729: Workaround: Disable accessibility doclints (Java 13+), so compilation with recent JDK succeeds. + LUCENE-8725: Make TermsQuery.SeekingTermSetTermsEnum a top level class and public * Build + Upgrade forbiddenapis to version 2.7; upgrade Groovy to 2.4.17. + LUCENE-9041: Upgrade ecj to 3.19.0 to fix sporadic precommit javadoc issues * Test Framework + LUCENE-8825: CheckHits now display the shard index in case of mismatch between top hits. - Modified patches: * 0001-Disable-ivy-settings.patch * 0002-Dependency-generation.patch * lucene-java8compat.patch * lucene-osgi-manifests.patch + rediff to changed context - Added patch: * lucene-missing-dependencies.patch + patch out dependencies that are not needed for modules that we distribute + patch out dependencies on jars that we don't build + add target for the new monitor jars- Modified patch: * lucene-osgi-manifests.patch + add the OSGi manifest to queryparser module too- Modified patch: * lucene-osgi-manifests.patch + add the OSGi manifests also to modules that are currently not built due to missing dependencies- Remove a bogus log4j build dependency- Fix property Provides and Obsoletes in order to make upgrade smooth - Added patch: * lucene-osgi-manifests.patch + Patch the build to produce OSGi manifests needed by eclipse - Install the artifacts to "lucene" subdirectory and create compatibility symlinks - Install lucene-misc as archful artifact, since it contains JNI code- Upgrade to version 7.1.0 - Added patches: * 0001-Disable-ivy-settings.patch * 0002-Dependency-generation.patch + Sync with Fedora's 7.1.0 * lucene-java8compat.patch + Avoid using java9+ only functions- Remove the parent references from the pom files, since we are not building lucene using maven. - Overhaul the packaging to distribute the artifacts and the corresponding metadata and pom files in the same package - Specify runtime dependencies of the different packages - Remove version information from the artifact names- Remove the JPP prefix from pom filenames- Remove dependency on jline, because nothing in the build uses it- Require the different apache-commons-* packages instead of jakarta-commons-*- Do not require asm to build. Nothing depends on it- Minimum supported java is 1.8- Remove unused "%package javadoc" declaration block. - Trim filler words from descriptions. Say a thing about features.- Update to version 6.6.0: + See https://lucene.apache.org/core/6_6_0/changes/Changes.html for a full list of changes. - Drop patches that are no longer applicable or needed: + lucene-no-classpath-in-manifest.patch + lucene-no-get.patch + lucene-2.3.0-db-javadoc.patch - Add BuildRequires: antlr-java, apache-commons-codec, apache-ivy, asm, fdupes, git - Replace SOURCE0 by full source URL. - Update to changed list of non-core modules: + Update source URL's for corresponding pom files. + Update %%install section to reflect changed list + Each module corresponds to a subpackage, named according to its jar file (except lucene which corresponds to the main jar file lucene-core-%{version}.jar). - Adapt file list to changes.- New build dependency: javapackages-local- Fix build with new javapackages-toolsh04-ch1b 17174795508.11.2-150200.4.7.18.11.28.11.28.11.2lucenelucene-queryparser.jarlucene-queryparser.jarlucene-queryparser.xmllucenelucene-queryparser.pom/usr/share/java//usr/share/java/lucene//usr/share/maven-metadata//usr/share/maven-poms//usr/share/maven-poms/lucene/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:Maintenance:34130/SUSE_SLE-15-SP2_Update/7b8c064d90394e0c56f1b107a812940b-lucene.SUSE_SLE-15-SP2_Updatedrpmxz5x86_64-suse-linuxdirectorygzip ERROR: Stdin has more than one entry--rest ignored (Zip archive data, at least v1.0 to extract Java archive data (JAR))ASCII textXML 1.0 document textPPPRRRRRB#1`6Qhutf-860a8d6455ec77be77f7e9db58e62b1aa192109f7f43267dfbf41bfceba81a939? 7zXZ !t/C]"k%w70 Zp M*1QhBB,CGt2h֩ǫ$Hv(,sA-5wK>"6rbir~>[jMt&js[5<>4nsRh3$W04Ȃ}RtXPZ?W_F8@)_lk/:.A#AlPm(Zj%SÌe^“T;1嚧f}2,k&;{ad׾jyI &tiCif ڦ8EGI:< #s+@k_!רtK& bߩ@  "CoC++~hg}W|9Фl %ĉ%cj OB~ u};v'8:Ji/)z"S߮yO&paVҁV`&Quf.Ń- F΢*.(xarX$ĄTn\Yshvy'O6em痪HM2 AvȋEa&~ՍL:u#5MȄ`0 UX3>a\;"eaCZ;'dyJVLoh| HO2t̸u$~C䊛"|i*s~kRJe&0w?A-/:'->wU296j|ZYzSLܯ;y.8-h5iJ^]ƌ#]}r<7_v)xLUӫPW ]a\_eDƲ `;Sn';Gʇ8Xf;4 )j,EsA4:N^Mڵd"c?RGGz(4@=gn >J{gD\먠_à ^_N5,L-vگsr|!pE4f B糊":%e y zq2~aTо"]NMҴc0#8+@G[ʓ6)Ԩw.m#^ z0QinйɳWd],k%#f Zt&2+Õ??H ѮB8v%?t}Kս;ҩ/zԔŞPs-E]O( ޼YM-DRn<,RE{=|lf$6DiuO#퓵fQq G찥<4xCHZlx['\>f<fc:a{4Z-/ln*%Z ,U,*4J6h3kx) IǨ5m?ZFu :aK )>lw$GQmqQyJ'FeBXyy*QC7JJ?Ahm<^xXψ8lf|e/UU*|-WK[w|Zx̏Df>fqOl #IM5 _F7dy!r( Ƶx((&k8XHM^~Z=ByES_ȁ:U6>,5r0NM!zp ͭ1žp"zLIT?q7?ox4NONc *+sÓgL.Q_O0c0Dz>m08 Hg+_(]p{#_%4 N2ddFVH^@ܻ {}X{7F8 tvܳazpi9> +A>s A͞Izէ~E WKʃewgFd]6JxU'N/%y`Ϛ 62NEWZru<;cSoe9Z$}o%P톓7kO[=|#!behAKӘogU2\ k9Pe!_ C3TO5YcXo׷^ר1g976©!1Cc[ʤ~7fk(CR)u#^tB7Z bdmAJ!!JOT Y~o*!%wQY8ES8tR@)Ye2?}УIB h\2t|D" dqu#q,dN|㒬SHɑd06im#YZ@"xV t4l#('MOVIÙt_3xF5 N4K N`g:Ja{u{]%Dx3@cXYuFcTkG򎔕6@f|xUa@l BϨ_qDaYSlgm5TJ-cO 8z /}A}y\߸r]@r7_$.R(?j͙Er'}Wb-?̈Btͪ JY]xgS;3K t w= xK2ݱfO콸uUҭiM-*Z=0o0uI)@BfYz[1$/K3?X nra~A(f]Gd~6Дк;L M6p8N*[>J3ɮd1c$?x^xJ>7JͭW}pj4UR֙sXOV EeCBP؍8#ed`O<; ^*mqim55aGx+'cGthe ~^ikpp+׌8tZ : 3.+1!o 0gSflt2%ufwA\H0B1ƹjqou t]P~m~O|OIgˁ(0!iGiŋt<J=|YK WӝE$X(v7g霙9Q sx(E;j+ *` $ 2.?Mu-2ځmEsdU9tl~`b݂DLw Bg.b^C9 p5Jw'[d2!FQH6}R0,APBz }nڭTwZ_m7 1á!"\kpɣR }ӫ[a2*JC%r+1+#xR5 /]3v?+xaͣF gwɤPnkeœ$ f ((Cyz\K/p>lY<`EV)ZՐ82 n4G9p0f~eic8zʥSe'b!BJY4H0@fwʫ3osyd m )e' F|ӳFlϹ "գI} CjQ`AiWx7ʅ^BP0Cf6FEk+*4`+ߢOV=^92rDFvC)mzFMqS5N} z:c/j?O4_"=۠VcԱU c&;h@~y>~ YnTs t_${:eif0imiOu(8=3OHX/c>+l`WRvv My/~ߏY.e&y.#DxmNha1oDŮa +'}MmZj œHDv'3nw^}ƋgG'XZs dzk/Lk—Or!T6DnnGTwCB$f ΃|F-ټ+ު UV㏬pI ..L[w~,Ɔri_.fH ;J`,fؠlzȮu_L N;q-GYp`:B-\ 'Y$%>:wEQ/ƅ&XO2WOB N.׳ w =e#WYKޘUڗr­jul%; /)@?~"9*r5+My1!66upl."1|!lcOGqy98ބ!3=U{ ķEyEB)S/-ZXۨFHϛ-Cl`d~)mKn:7u6N)3 V^6?|ȱؾGYBqH`I9Tvs99ZDbb_lCd+M^>M%/z'FݲW0R yҐZ_r)+ovτaNg ު3ω2t´tAV^ yn*J2 :1@4hk)t?n _g;@_lȘYLnOÆ3-1۽wٴKVw?ǟU^ѽEF`U Jmtz> 5MHūp뤪tFVG} XU?Gi=V|UyR#/!gJg*+Pil,zwIn%#ިbshBGrIL2Cݥ\ӹq9Z.SCkK9$Oɕԫ밻]I2rtt𢐀:4ʲYT+U7mԫǂo*|j1D+#SN) P?$ɐj[hm',kGֺ/6R` 6kt=Mn[jk h|tJRb*1;$Yt;3),i.=Ǻz 3tϡ}_FRCR2!5* ){l]S\cG5YWՌ ЛKȲv>A5V'-uZ~2"ߐF ^Jna-IbX t009EuòX @=z%Q:8Djt &U .A~]nce]H"kKۢ=bY^B<@ tV׀ߦ:7T {k`o¾+j}6G |S>̺ ̇Dk(+O~4nѯf}1=_St6a85|_XSav\?jl9a~R11D>MZ"Ne)cAc`e3*$wf( _5`E??@AskK)s[ފ}\ioU銉7SΪg8~Zq'󜛾K2r0y麯!RS3ʞQ4Ǡ +/K҇ vgS8yvhjie0t9v'$->-/ unci>O^kSEcBpʀ(M֙G.mXdgfAidssX6@#٩e`4 Iؕ|MSO[bzII +rEvR]%07>x2^SAkyoK] l9qѳ„bn6Xe~4Cg^ f%A$J(@OO ӽ$!L N+f2ޠ$sZyGp;NZ_ǡav@k Lb_{%U{83 RrB} $26I7RZ`8(-FT7;L Lߡ &PwlV#0UA9F%bq|!%|+J;$ /1j,t8^L ug!=l$E| ?HiVlAd ()@ ҋ&Y-3y nBzȏ-!KkerԥE-mi푀NB}n^yhjĂTnʘ󟫥K վ}$Aj^St҉+G++bqRrUM2*a<lzFH}ħ Wk96cb '8>'n*:`=N6^Թ5eWfSɲ_N^RrF[$pRB .M@4k8O7]\qkKNLv7lnɯȋݮcs1uQiw&&(JI8wAT<bS)"ic X4yTa iEWn]sw׭rQ/RTs-jjzns#J.Dmv3CL+IQ%emR?|}Y=-paG V|R'QW\Ί! jvXѭY[eT+=tĉFY;dU全F: 7ܩ׈K"Xy>g/_X}wT I5w=(<1pg^_jl9x0q4 [R[uuE&  ȴ?V]i"[\y).2NNR}iPb)zf`LrfN{It@T;=q1[ &Rέ8l c)\_#nirP yUxYmϟKezl_Y]/ssPl! vJc#}S)=˷G=l"gjhcKƇk}G@گ0,z@J~93JKW2J.QFM`%D?r%JՍ^>eh6%BFJLDEtYeّqp=}#0I OdjyU|sQrR"י^͵{D ÷cng'x1o-g_.eqp "=jHy:EKWMXX%0zp!v੧16^Ȇ6ֈ2<61<gG|g?@.}QR0x 'h|hNJO4Ԙh).^{KoC[K|Ƃ:caedNdF/60oiwXw/@#EiZe9 Qy^6tUA&7am9/㤹Mv$Oؕvpas{zTxq&8֤P36V~b]><\pF YA|rqJJZ%,Ks.oND1(zY[\5_yے56Pi'g8%x[ɳf@ɃR&_}=@$WфP |Ԙ.R q1uvBܔYࣿDQctIf&^>_őjXdt+ymw_E}7c^PEha݁Zvc(FJ&+)@DQMOG4!&vtCvZv ùMZHNuj]ΕZ{/D!5; 4+}3gCwYݸڰQ#9)ˇ[>\4HV1UŖDa݊ն溰>uh3ig`*܍N<zX7Ef=)S*6egI˹w:cQ-nAc<[inG:ߍbJdW/>n8ElU<@a@=8ߑ#Ё45K1Iӹxx糎 s~9J Ң>oF5`OQACt= OH&i!'\sl*c"?Jw#3Gk9Xig@m>hB^!tќ1<}ߙ#;X>ve[7Bs1D=띭tQK/ʲf(}y j3KHTaWb5ȫ@bp) H8$;ЈqV8QC= kp8nJF;[BukLUc&}'T!nDz,Mvܐ v7G!; 4|‘\ϙsN1x8{Ŭ#7?.U)ְfRx5@b՛O/*ٵ|욏y2$C޵ b3#rww3.{klY1ipigug|R#rC|OE+e%wS&0E"|6PHU \ dYBK ;40)Z'|X3t*3Ysۭ`;N s}EBڵO r7@JayZxMU{ݤ e~ nﺢp? Q;[M = ጥ[+SrE?7YfZ% C)@qL+V`+F1wO92yd̓{3^)hu:+ۋQDďm?L3S,1-^g+c:,wHd#ǩU$NJ^ޗ#ElT㌿bGHVjvDz[TI;>rc4-?_x;HG <톤 MQ廬5B>Q?ۥvgƠ@&ؑizW!|tƋ"lA_Ol'nu܆S J~#vZ4͘і1FЪyX,(p3lCB`/ rnCQMdfLde=Yd ؇;rQZSU\iudlŋ4f@_嘔 fD+~+D2[kB`&z*,czI3=[Dםh/LEBƙpzOsJKł3h!3ZxEr>Z:u'A$r'O` Q&BM៸R1߅C4ع8`{MKBLK>5=YIdϦ>K *3'0W䳏a~desPYg|b9 kOʫ'6NQ "T? (Fa̞ao%ƖL&j} Q*Ȓe槎LA^v ";>p+ yYC)"t":MEX)acXWO/>7ĭ쒎gsV>Ua ,zN]7`N# 9`y=Ș6U%eH>+cCb!PNE ےٖSJpxDBv7}6:;ozm|Ff'_ۖd=#!kN󹏭[?0#%x+Q^f}P̃3 #T1h+a*:_6ǵ?I:D\EiՐOfo}-,V1>q%KhH=p^d|ew. S\rqI㓊/mNr("p۴{qXe#@bUqjzKuӹZ\UW7uXc.f=KL@:7 +(Xwt''Ex tD/!8 "o >[mQn5exBOȌpWlZ X[^H'%wU͕.ihXm͂z;/S\#rjxþ!\0}@yM²(;](]p;Gz%zR_#:t?qY9(Np<*|qȬk7nPX!hYUTWT ꛅя aWjUޯ*lq~y(Qزȏx2 EbF pV$*1Fv~}%c/_$UzS%\*Z1 E o۞.Cq)D Ւ(a+/TPks@@@8)lJF|e+tH3*AswU3W~ Jyh;0X>xnNIOs!ڀ@9GwZ96D'c(.hXgL/!2pWf HԴy{B E~`^΃=|b2uOPpt@[~@!ae5zampS" uGPS>U5^!P^+'B"Y{502(C 4כ4~^KEUClQ)ro2;랾M`͵wBTKK /,QHͲnB"D,hGi5ᛧfw`\gs)lAz/u^!Xӗ=AK -1v[culxO~DvTFC(^ 9)ep״X;T n3X}U߽҃Gپw&ooirZhG'rxI*/^TC#/맾l}'\vQ.[1rro5 `Cध@'r 5zTw z8 `҈]fa'iIțlTiݸH.D$}νoZpu G~`0K.R9qleϧF=N=(SWs)\k@ r’'J<|E]v9v#wMdOhl?PMK44[;ƗLĺ*ϰ&!g2ز}s>͌ԛ-(+ Y8wͩy+G[* { P>4|eXZmE} G}AcWk`4_ g(,iDo*5J-0AIll8j{:6̈ -,PU+I7lFN%9yQ%w/;XW@<(y۰ ꈫ5 ] " x ѱ+z[/ ɋiY`/YZ?SBKuwտvlq[4ƌěi׻M8v..po[ɬ8n\NՏ*{@+%uɨcY;tBMYT#kSΖGd.8*Yļl7hi4t|4{}}:9c;XH5R'xʤA=C0&;q+*T=_-Fօ3q,C3 ډQuPI UR2;q5JFѤ_ .UJ[w8#^&PSFE&Ek,X(C7}#2@._$>&9Q{/W{9 ꈢ7c۞eԠ bυ${v"9]fyn^``j2$\(O/~/(Δ!WbnK!X Rx X.a%LÆ0E<[~ĚN0Tcbz+qyUuf+ڹ>+^|5=CpZ2 uT1lQ7,rguZ xu~ݎ@ {&s1粄~aeGGL<&W;h(IZН1&j7ZwdI֪~FJ4 b ɻ/P7dZF7˛_|VZ|wa|ZOqs}Uc+[~n3Rx'] [v3:o9ؾ$$85Kx |:.F#%eyYFt'94Zx]7(HėT(64q_j(vSbj rpnG>"\θO 3I{ #]ߩvtxOēwwUm↗-TՓW #q''10,DCdQG %<cPQAX|ڣ9 ޹s׼Gӈ-2z_:tX #b02Oa@GjX&a[JvC7遈GG А IeFBo6̶3v*jUNAB{];`4ՠXW9#wϺ1T"hpOՋ3gapkٳJOS'z۰GO3yN~DI㵚Ty?^UE]|DDi"֭ŏD?svڈR\ei8 Ҹ4g $`Ͱ/g⿯v+Vy]XLtԉcP}۴<Ɨ3q-e:mag^ҝu>n#/TtAByoE0#<ˀ7W#W'j4azfK;V u` FҨzɶG Q.]ǒⴢ0Pf|!FBG{L 8Lk垧F`!-'UM+ȋkINRA *zh.?ӓ,W&vDlq$ a^+ [H_(OERVD WR16J@"Ac-(Z"MO_QdIDYr2)Pi)PLJN a_4k૔ ~u&!uQj 2h*¥AkRV@.7j&0!vP7keOo5([&8)%xI]$\o-u8tKH%cxǜL߉K h|PCtّcO|Py"|)"ٳJC)(*ZRoJ)wl2 XC&bU E/5/'$[DRR8 >)vFңäwvGˠZpo9>A&մ*wTh7j*_X)<9 8Kt@P7`LsrݔrE'> a#lpdP]XRб:Ώ$Y_`zhL%oS[}qS4`Zػm})ܧz%(B0=sB>cX5Y6ґDA]ԵdOE6ܩ$8in򕹉* TS܈,zRgͽDxR92f_,!Tn1=Dyeiz_ "_}˪ ^~}+,IR|.@h6/5]\a{;œ: j-ɛrڸ/g[V+%y/4c\ͥ\;a{OeZ} R:I THKMf_&(?8io4")cx ?&9qt閛I9(l!gv[L.\J:Q\-TqPs{F뽵@üCdzq@m/6o6Cڣ[)?@7]1DHƶ>zNɭKF5K݅?M%wnw=D9,Z(9I<@p+!XxSSaFEm.$`U9yCߜ,#wid0A6̶xDz7m2FGW5T8)ox!ѿ^TBp%tߌPԬu$cEV?&cf 2muD/gfmm8J~;A^,*s:q<tfgN 2LF QT|$eFGWkIN %7j"n" O붘˩3GB[NVP-_2pWR},ӮpL(٩T]'4!l0"rܮ,to%D]l Vw ʽ: Q7YFG܈ϊ@tȢ~ bqx!~ɝ9faKE6)(q4l."ScaG-^r Cv4&yj4˃?ZTISf e¦9boMe&`كQ*S WI}E~9{!T ɓ-0YfgF)>\Y2-}SLшiycan)fY@eg$y`ؑObI7hj{8(=cL}N q7уuF%_В}b|NKoXt/nTrzM2Λ&!le~I Xr/'3Ufrʩ̵X~)>0|$l:/qou(>i3^-֥@ b5Xl=zOR;6cۻYVue)K$ M߬/%V[kU)xt1#6DEЦjS] Jɿ Ec4\;$S8u~_b38]1 MlEӴiiQSjg;!T7܏X&iUݻpQ܌1d%m r2vW;M[( tՂ>1P/L\mH*+gs]fJ1;ֱ(qІLeTt>2e񕦗?5Wu{xҀ?Gw\=hY !ك=cY{/D_pԵ F|2aQwaw>]XƆ0P@H9s:v{Ar `O4LS+R038,Lk,J6M-+J5 ]햟KɷJNqA("FSꃪ̐6M5 8$_{QdgLnډK(E_2|whp6DcUܙs[`j[!zMܯIhLgK8a3BLPoŝ@QjSp_#ri`3>j5N|$W'u*xCMGkxZMy5En0e5_"K ֍q+G.Rwض 'h\9_k˻7JlW% /<70I S*;Yp> nc6z/c2޳3!|j".~$k?mp[}㊉Hp9!P03QM)=7t5"Stjzb~-`[ߗۇZTW$$B](76aW雉B+jJ>H$u~ٳ̔c$i]_$y'udJ (Y_K z8bO2Jpx ǿY3z>ts(g^iV;N'Ă Ј \"@/#o#+v'`!tz*^?H3\\N#<xrD(6|i~}fhւlR L? @f[)qJA+fD̚  CFEQ:iNq$~9OW6&"*Z2OóZyc1q 㔇IFcMjђt,6G.qw6X%…<, h5$^>)8戱UpeRs[YW51ۧ25jt}׉(0IT-&o2h 8}Bdst`{~c%G4a-g/6QTp[  NgYYWc3^EKsl)Dz_վo}$BJOAzAЁ+"{Ie$& зGC'>xEZ`zTBS`BduO rh:Kxq14ZNLڬq CwZE ) |sw)'oBeꞦO\hX͊Пt^*J30E nX8Cl,ӉRkfӆҹPg8{ n@-?dKֹ\Iy1䰭GICғŘ߇~ ,-(Wi:T{6@܍Fsw!bBUz`tz(RJ⠡zQTЕgna&wk z<~R>޼nHלUY[9 b--5ݠW<6G+_NK -1xحcj~B ا\LU:=؉:Y&lu>]+8nNs. '6V!z<3"Ny4JL [^_9fj#R/"{#NXO̝Us=)zT|0y&qۘ9YԹpw> W 0@5btF+7 U24cHӮWչ7bzP,"W_>j8>[Z*YUm<#g2 k7:Q[Ig6ʪZ݌􃛑CTBqyV+̰9!YDP p4XH\ Mm{ e͒KW SDy./`Q9Qh &je[bBxTzkTE0N޿@N: E8NA"%kߞff`*kK {oz6+plΙ_ja@;oX$-D\$ol2;:-,,_s K IchfCpolS|a ć@76٬8@.7ҀjQ7yͣTD`"99^i zQ|&vK#O|XOuC\֦8fSw}ƨ EbK8CTɬq{SȪ%9h!4vjdwޱ#3sp-BZ7˔ė?yN&~g$S2E>;@ d׍:yy* e0459Ս,q9[|K3ؙvF7#^ v5@|eѻB!E123|%XK{$;{đVUxz[9DR]y6.G7B^s$0q4i K+urA -.d_+B6VaQ,.lV k%p9Rm>U1IwgOO^-s\nk-մjwBM. .UbpE"T)ׁ \Z/ezst?uA_ڂA0_QUjIK)nbW98̰禑Ll$?A,OXjBV(R`|?ݽg$q˿^qW.PweE]B|0##vm7t+Kdr/dmW ӴX%t͛X ڕO]x,u<1k=^37wV{bG[F4QLVUwç)Hw1R5@Ʋ1~t ;8ynewY%C[^B ܍]qzl#zzyEE@C" DI93A9Ύw|HA T^/7Yįoi=oyu^=f9ܓ`3t{I &"C=T(&: )rRsy \ P]'qryɉ?EEXT*_JLb3AX׍#W.ӭ?<[m̽$ 4#5fx\=i.'%&iN[9GFnܣ.zda #}Ne@g @eM*NMnJ>^ioRSR Ϛn K8*ICG'%|r"o5xS4; o3c?sY%> ɲα^B|s &,0㤴)862`!㵶p_֨K0%^VhlS GЍ%`[yJ,#e16zdihE[ُ /^$Njuaʥx% @E+d֖`B /F߫Ny<sTu8k+?bIGjƪV'({FuBUBxDCmdԱIx|7gtEDq\>e޾0BCh<ZeGF*2< S"JxAm3qm@/ɬ^;j y?w/߻Fڽ?lғP?[dz9}6q &j'S>,i7)P0#]o 4|ASKs|qfM:zEnbF3c4Sn`q<\G8,ӼH4Qr!&,kޛ+Qp3O-m8`N43,+؞k{~q M͔TuOZeԧgM}c6V|4BcB!. VZԕ8#3_p*F;Fk+ELoG2tF*)1B7275BRu\YY` }66 d+6;b [=`Cip#E2B~>^M7ض+7 6[^775dx0a]\ ϡR4V$M'G˺<+sgxKSGB0u%j)|a,6 _h# ԻV< Y!$w yXN"O,yZLig XN(uEJCo|Z*="nڟG$a"+/үSTA5,Ǘ)ih[7KM`Jbj+VѲN8k3٩u}|[x\mvk1j-{,bib*iE/q4<>:.v0c{ QLGiX_^yxg V4'--jB!p9K^Ļ bvu@X|9> 5֋@F|8ot^ =(&}>ęWCv?I݈__WP|*}l*|QY7v붰ŧaVms/s״[|dd쯦p>*2&2 /b-'ǢGz][ʼnLtHy',월u-9ٝ>ۥ.jpwKRdYD3*#gXe\2 W^⡐Sh ֞WRtL#j=;RT/M;PTLnD2"GTYcr'a\:tt>櫅 ;# Z疭`ʰ$ܻ› σoGN,'sqrqӃ# ;Fsmkgb%E>p&g>(`Xs)ۮhYb6Ea-V2'[jtKlrt5YG4-{Z⯸3+c[v9Nr8/TB.zuGuR+(a4[3 _ `bR_eQzϋ}Y" JN:%VP TK&!^щ:{/]YnHJPB)Mv_w!!cZc1ܽhߘZqڝ"y73Gȝc .3B߹+(,g/y r˰O':<1+vU7FRQ3p39+Pa]bB.M;+лѸDaA$:睻gSnSrKGaCߘ6L1"IAN;z{G"ZV2; :+hՏu6zӯۡ0J(ϧzPq7V@S>.p+a%?Ĩ!yuB/IFz]vJXcUua֑a)-yte%)1ll$~Hm}e` Ѕ`EhpNWr10HMN\rŢnfrR`<bOŒ1]9@<*Ы0![@mCF:.&oK$iV^6u\lIv=7 &o@n,PwK0<5ӧao]WPKw&- g^$ƷO! oNj40x1Y7M9m8Rq8ڏ mvnjb^YX:k D W5ܐ 63,R r -SFW 3C!OϕKhM) e2ߠ/[ÄT)("=릾sq5v8 &jF [PՔ )Xx|.R+xPRǁDLq+JYc3MxcꑓXS^.M@D#)A܈tH+ ֪żрW`ώmm17Ypq:"ýΘio Iwpn@ҝvsIkdRR}3ӊc)G1vX36իuH8Q+OV)9GvgwHdI(lAj Zx-XaL> ?MGG9c[1Q][ҷe-$V4a0 Ufa*y5X& MI\l w@*-Gxj3Rb fͰ$^YA/fVy 8N5~6ę'Ev6"L&tY3M tR{2P0 ]R0#Pv\^ L߅U7č$n?lL$Jm aIҮG. XF$l@eJp}RMОP98"܋~{w3>jsV75>aXIVxf1=Tn9F"ay<Q d鎵\H֪b3 f3ħ̕*(}PP#ehYA"SGt fp<`o$-yep|xPdjuIؖ8V] { :S#s){ '8)!.dL̅ Wʪ]jmWϲY<^Mb.4q:5>?9/ش*N_d(a_iTŨ_S޶]h\=@'/_L~[YK?5r ?xT_W%,yp`>4A9  c6VO{+4p:c"2URh\ 1qO/Â諂BkNq-ݨQ%"L_c|Vi}gq`hk`FOt?BAJO0z $1uR lֿ*"ZUbVdU.FQ̔S׷zN3VkLu25}dUn TX7@"B]k 7$fkV|Wœzhi[΄Yp/ _?qѰ3ܤ/|] +svh 6( ш:l#i]3:vMyצlR NAA@J/[hoJN4F\q ;4ъh8|kXbw/w#m%a B9cME'9D!g 0l/(Xպ{n( (LqndufKT=AaTwMgK_c ˉR}/>=:WZmQ.<pJDKXJTJ _3mzNt$GHY^*gy?6#iRRmMa_2Pބ0mB8Vu!|)^2 N>yk.K*ۅ88  II)8<:sMC#V];PA=Xs\чU .v_@Cϓ`O'~ gS5jad;?Uaqrs-(47!S 㨿(80gz6(0;`C%8Ty4'pd2E:?FU; :$LN.f}hP4T-o6.'{x%I5`G.~N`50`tpp%j[ N85 %, z1.XtO,58Ơ0V`ۘA>u(|C=)9@Ć'o, g|FX#1xa˽_}Y"41RGE#aX1Gsh7M%T܎W8ǚ)Ih|Fů,F#_.V32x 9vGgklww7Ԣ?944?]6+P2͢oK6A&xǺP0ԟ̾9ewGJNVzHmu3IzP{fOF@5I3*^~d0ç(49ۣ%sƲҕWV!Oᴯ5_mG礖LvnVޔl^UYj!3gJ5d'B6o@*)TT)mB1=e@G0*4 gT_91Ǿ&iɻ+Gb^FYbAcYl]]`:Jqs쿘/4muuMwoM /g":?H%.q8z?Uppud7k74 9Ӽ'-Y vLlˀ-6`#O]0 HdFNApkAq?ƶ#=-k?A.YXMnD[?nDuV4Ws%Ѻ\lDT{>Y#`Y%6?U17E2\:’-&grL4H MU/z./zOi+I1=JaPhȵU5la dSL?:OL$!}tQ kt9(y:䲦p4A //Fj⎾x}D,c(ݷ mķnb^$/^YA#ַE_A "Z?W}9 <6I#kPPEl\! ;42:%Y}9r7~{hVSB{Ype߰r/)!W8hxN[ޢ!y.EAz#$8=36햮soo|4qGfoϿN| +KbAn!V*䉷rj)0j$a' JE(B#VNɜnr;CAVв,qu k\.x[% n'O dIPa(xв7(Jl4(?{uR^03JNyB×npHx $q8kf)o¾ $v!rUz^1{pb>` eSģSWTow7bYxʇm^67k> ttFX:Pn. Z6>,Ic-u^ݭ[OK ȩT&%H{hWrˈJgY B}yM S:J.!_V2q<J!o[8 v.Y ~/] KTU4huvod+p& 륀,' (Ѓf2"*̍Y*XJʡv,C}K("Hysm蜵zGQ%ks҅-M[6+77ѭ+LXv#OV1((ۑ xđrn!~0H nN x$m,eK3?߉e|ErL}VxVOYFP_+(pH?U֏}w:G,] 7lFo h@:"eR{w-j ys'z$A)UHUdeUQmq_6DKW"G15odX{$1-\$X@(+Ñ1q*H{g:t B.Gw&})\eoV0 Cjb]:KtT@3~Շ엵5Gy;0O.\VXȾٰ@Ik5b{R4h`_V-yAQ \ H+\t>D 2O~S"*q>LYbBP|,s./`EKh+э1)[*r#) W;5;ЊoTdTJOF2Cg3xE7&Dk R~C7^bՀ,^Z2K( ׂW$b'ℹ$B6L` CZh4o:qmkfSa7kăө HGҕӢ%9)R+,O<ߖ9qth_,8PܣϮB=-HlL@H7D ZR@l<cmE+DB}(0nL#|d] b"M&erwEK}hJ-, ./!GM5lس x7{>dA95}F^JlZj{XԨj'΀T6(ShVJe'#2B1]B>/Ǔ6ewc24eBB}oYy-lC\l ]42R@֠{~=W$K1< %˜"f VFBMvAgd=K3".ꔑxԺPOpKƲ(P?coy⩞ U>"fLAqo!/o &Ρ4Ak \CA`/RP1&XwcnϏMy\3ҋRuh9oմ0> W5Α_NMQ1˜Q9i:H ^رEsXף3~!h1soi? jwI5",#el*٣dj5ߑz.]f|>{U1F2 ".[7$!G>}/bUR$t׽˼%13qsP1>27Ҹ`o85+RKm氙`pI"Z!պ7Xliv utE[(ֳ5g${;}_|p_<;Ct=97f%+9:()VWX=ӄFMW^'s+tp!tpTN/E#I]Zln3Y$r'cɵ+b_VS*``W][H6F 6S:ͯ]?op]B!7[7ehKdvY?,@wS\Zϯ^xo S7c(j^ xǃ; (o 5,繋RgI~l Xysn-WZ8K, {U)idȡ~B9:`Na`CmM ;Բ.{UKi_'FT9 A"-z?ϓU .b%'5D9+46B 蕥֘ҳ-޿D+^6RoU9V&[6{dd$;K=3wK?Y7Z-,s7uFudSէϝM)\M;Yo?%W/XZqq,zSkGu2]ynO04Հ^A&bOU'Ր2P:ޘm\9veQ^DS׭ٽӺ5X`m?g}R".ZFHoq~[0ЮQ>Ķәr x)!v*=i 8N.財b`re e\(! ^7z_ŝaP/5w4F&`|Gd] Y.0e U˶dc,4{WafxR&dF%_Yp t*b * w4%VvhQ T+,6H7oGd|lXva׻Z{v|<$go=dX˰(gj78g% PF@ ƢT4̒a mRg2͔& O~aVX<:{tLIϞuW:[:$np a,m.F+̅/8Hmw8fRA(lNU|MS͢zWhrFmI28& W--pjMbػOPS3'U\n9 ZCcB~nw)1Xs8X:,OaKD[]8zM3gr44 F$37pTyXGaY17uO;Y=_h qxQ۵o&yE,#3}|p`U Cf-"P9@dEgw;A3 ]1ҿsm>־նmSbsB)ؐo{vAņ_ 52lЊԖ-tb(AJiBļTJ:&wt-jiȾz_ w\)Y21/#6J(.^k*^X 9 fUJyt-?rJ Ǖ47p]V\$[1|=)f;^0poF(̋ "54&+hyOE7M/9U4e܋JwQg4i46?W :V<%*oO(*!Qʒ]~D~}-7I&Eѣg]dȝ""pr A^HW3]`^Pw~gmtinT6K/ڈ93?JNdu&^B3tAhr=i끽swfSm ѡO[rCEnCq4)[Y5t!G~,ԅ2DRmOQtHs-he-!2SF˨ N1&-d/C%q%-d$P\{~h"́lfC>@cI39큾i5M۳`! p EWC-!q&Ig1h \0~ /XZfY_RmC&% dDȕfi@Pꢸ|oӵ&D@~-KbeML?}f^2j*@֠)c#(\)qDw\[_Nȁgj937:E}btZ wֹl<7&YϊJFOe4# {!e %jk/P$M5T?*kD4Єg4ܘx'v껞v{mh_kN9ξ;;:aBU&V1}R j;E.zp4b&V]GqCvh':md@o/萩T&TIk形kE否-2E@N`LbcoRyP幵][8?k|ċ2Pm4f{M7:D1<),WiG)\*[ǚ~yܐݔbGŘaan2}XCAwVnxEmw Dz[=hk/ǰze? kR͇F6?iC6 .AV9nIgCLi)6%Y`D lxSjGҾڅq H7 X1d9fm??m>5T[W m2G'c>\t냹^+ŖFIyV^4#ϣFqۭ(0?B$;U^@g9"_R[(rI۫EOOh4/Z֍ l8+-e W2Zc~Ƞ2}>r@@AvL2]r :[EP$ɧ-AI3Q5=Y6WK!GLOmr[+,j*@D |@(E/gȳYJh3/!-PVL\ b.S/ Zv: .gJꇐ$Us4Adz5M3FBrͺLsQR/7^u /#)7seI^ d?t+m_Q5au$8DsUQֳ5*E$vSRIz: x݂jϝͤ3Yse= @*.ANn&v %n4tj:|tCnVQW!ذF[ r|əIO喲m*~;(y2FaA:^JJg`W7͞IX/Rs謸y,V"u̠/٦y_8WIld έvj!we6~>ŴM|8ix'./ln  !aH葸.(̠X? x8 =-,`T3H~asm kBrS=!I6#.Vfƫ_BixZ6,w%iXVm>MX]Ss|O3(b|“2.6֩Y B䖫bW@`Q%qiGLbF!pk/zu^vo;݃DМwk!8t~kG5բċفA Sa_1x+Sp7΂֦LppWW]OݵYr??a-|D$wqG8 ePoVjViGOra7mRE3XXG8H%ZU^¹ U`}Pa"5CU*IU%WQ+ (.cO+mk鉍IylkI fEWW[ixH5cު[.2Q)mqW$b_ŖheHpO^WpK:kWyk8s#g *b6j:2dAZL,@ɯ |$jiY0mS&ص.˂S:&5.8(?"!QIm_o0ko*kLɋ1o{ wK ?gkLVK|{w" Tq!!s:Nco@ ޥU5Vl+alf3#|^9iTe*XE BӈR?v s jN / ^[Q_epʚ֚]ָzUu"f 1I6rx45;+|XG?Q̣B#"paٺ^#uNm,`tD' OIc©f`h*7le D4l+[V!49x${ϛ1ϐhO)+! J_s,~@Nd}up. +EL=8W}}8FS8 VaTig_բq!xx#8t`эPa4~ o]/ ټ"TN냉{zm%y ZA[d & `F/V7қŢVfϽU;!kpmZA_#pU ezFx; ^Z r|Su >qH KgʰCpP;) bs/vcPH0GG?ڽh0\74]m'{.}M%!)XT\Bt:Q40Xق7t-)Uniݑ ygP@A B2TK~hـw+\*Idy`YGl4)un XMG4< ^Xk]ny &^pswt#ydfa~e!|h?+OC[Mz?B{IG>WAպ+^r֡CaX꛳K0q5zG?&ffS^, X;;4D]OO*N um mc65}dQcBd:N7ZPt7[b/Ej VMK0m"؋]oV`7;mA"h[\.UP;7})4k{%|GwۡjqTvBy\:Ag] L(^>6GC=2,wѴ[\۠-%k; '8w+m ,&vaxK<>Sںyt]3xȜ>=x&swuTA>Kv~F%Ann 7 ;gw23^uak#os _}Pe`"|Q;AQw^P=KN#o"F%=>.1qm.)D==;K>h^fژNR{ d<j6\EGk]aHgN% sSqOOZKЬms؁_K)E k_AS?N5 eO.#4U{PMg}ڠIArͤlB5=\KɢXuW]ojroNѮ}3WȪс42k^knUr/VT6Unb)u3#0!$[HF>]jZM!|a CS ne=3UqLH暒Mm鷢=j {vPAé|xІ$vRb,nb!3v31ބ,npx> .Q٣Nn~o1(XN\ C=ZK& T,;lE,w?qD.*8X;3'JYE esG.T9 զb#FW%cu2Y|skz`i b-<:iF_c]dUi*w9jtRU ֪;H6)pԘ^k1*ƽ353E(NImdRW^"޽f&D0>w/m'?fP1s8_PEm>/wzyJx{^MnnL00HŬe¯?L#Jj~$x+u0 2 61v,$.55X!$R O[`?܆@nAesr*1S2/!1柁!:KP!7XV3LR=8TMӭ1n]aXR@ $F`י. Xֲ\e2WD-&](w$b*{l|'*hѿ5B{"]."X <>XBuO,Q0?*ŲN+cMә2ҢPSa2O/zH_! L aR904 ж*BĂ\*7KXtjM/^:`v3?a\U[4oER<#ePQ^5`GجFY-/yMt :@TʪZ3GiRedlƾ4E4dkM/WT~1*]"0} +-aHTOXb(/|^$#Q'堛e(FCRo=*gㄳ)˜iefTKD{BOr~lp.'J#f5do $})ZA+HgEt)[+.?BϜҁ⑨E:'\( _|VEjhpseNbdܧKf5G2!o*+ &{Co/趗ӂ"@2Wgu]t̳4g8]p3g&y- h Iiʛ5bEϿ=g^ph\y?^adң'P=@U:kX2S_ٞ<"yAv' Qv׽O{ Aoy~0o;wrbR_q$[?ع |uVJ[H#WsøU#+6 O^񊛯ob8ao epL6wrʖ$msD2*-Խ u|,ԔB(tEsR.6ڊ.ݸhtdV(3?Pd`0p]Pq·'L>W҇T؋=FAvO8"V)ꛣT-eLT}ڞ0Ώy)f!O8{k}ő۶X֥tڗqX؁|M 5H'"ܤ'QҹeÜt6V{Z] Evl 4uwFШShKpjS 6+%XM!MBS\'n,$VgyIq{ȑK;ԑ7+@4EMhJGz==r.\%wR4؅:B\///CZྡྷ ,X09~X|F81 'N e^t4H"KYEDӨd1]k--_x[7i&J%!W3 pq&3=2(9j-3 N7Bz[lH2`Ey|ňXsHg P$9<́pcMd$AGD> E-SVQF7ܥoЙ4o LOiq >..94 tQ#8ZyG{(5v00^ķOU4:q6m?D#_^Qu{kP8I~w_"t_3DA0A<^ 0IYfxsSA$hd#ϥH( %`Op%쟣 X(69o[CD,>w]046|%96{X;* /"qL5883 P7cwQiStcM~ږfgIfp~Z)l%2!:~sQ4`R4`_cWtφu8uC-Fl<r=f7[YM{a1U)$r nPMv z ׭Qiz,,FumF}-(Ac "L6D:)VޜY^[I _X(F^eU,eF4T P=&v' ÅaBd ] ddfNm1=Jdo^bLw+V ?|_E^Я躊 ;εa1K.?S@hq#,l&d |9X1a5<֜Kz# !GȧQdzIX/-JӢ{qDΛ9?0'̞ߖ'79٢MJTwV>􇳪R1hsjo&NlWv] Okyq;$ͯ撓  r~d fYH/[P&  ^X^Go\2 JY+F"q0 W()Y>e*TJ=GmT:E i +̷;>jvsúw|qƂ+Jd6ċ2]vGA >x+c *6 R3zFM>AM'L@:SXr~ơ{<`9ViX6!ʧ[;3B8v1{(X,6Q!V-da7hUkmZ/>VS3m[ESKp7gvpS:$a*ސzC$V._Pg*]5nO.jEM68u}eA D|W6xF1"8H{IaYB%_:fXmأJ!&y@D){6qG|ip8ے*Լ|`Qzᷤ]'@)hq?C˅>Rqa3%sR3d/ D';̝LdOMe[-2$q.z4pC&L'9AkMyU#[EUi@QF%qQU5pBHzYfBvyc$пÌ 3@ԨvNh 﫫+0k6eP^n=zvߜ[aLߪ*PE<81@xՐWyj֬m'| B3't:y H"8瀟 G~t͸g"P;]$/%irTlMzપe(Ύk=2>r-{/()/ a9-lRHux&f̄.7;[ĺ"G)x2v. leE WC /lvBtvjL17Ф(UaMpLzAŖRYF-D: iLKOq. Gn$O7gJ#P:'Aci9#s<R廫B,̍U p5T AX6 nveB֪O,9!g&_^ ^3?I60B,{4Ҽq\*ν`waS}U}j{pTMe "JU:lÝk)0 YYܡ5 u>AQ 1{ fw@Y6h/rmɨ(%ڑmqO\N L `=:NLktI M)t 6" k5l0rR_gsQ6^䩧bLyfE;ȘLWV<(U rȿǷ5wAhH~@ _i*-3)G{pd&*J)P_oٴ9oBj^ӽEr*}eUͽ5D7]Hɤ8Q$MzUBOO bFip$%v2Qv55YlyGBy=K<5o v9UaS!G}neMͣIN%3Rfe!@f\39_S z;_[iG xC\oYo> `={[V^pBQ5Zye3}2ػEr(¾Qr  TT~}5"~HxW~:w_NTԣwj(V}e$'.ڝw`m>lX RU,y~Bi$K7s0%5ks"q ~;4&u ^dk8)ɲ p]z+\^18(Cz8ߔl<ɩP(Jﳍ-,󽰜[0{e)'aAZZuLows͖_a0-CYYH.np[]Zj^q~JJV`*&Dkm8 a䱲 |?4w[V!%>#[˳( &1Uo!MoRr姿T  TMs=kޜy,ݪ+`kHQ%wQXLkZSSW\ٝ~;:gOW~xjKЈ$NƲt{+nϷ>J^m%|>@C[415qʆMC xQ_o@(G| v(gl)ʬ)bZ`=mԸ3l7aHI9 DʆJ,:-ux՛ 8a&qb5ĭ͵J5e_nRbM+%^ /-%Cg$ӳ0ȎL⾟_DVbIC&08Q_aN:Tn@_LEZuIm77aZZŊtg [-bݵg{\ƥ@ ۺd>P@=uBbOVkr$?U20?-IRA1Inu$ko>p |uB?p!mDtD}aG!ncT٬~H ߶:RH.w-pG:$Co< pL6)wHEp$8*ٚ䠀⳨O녜~;t.*n<(ﳒeTW.\'*?+ɈMV=]ChvjTrrhFEڴPj:6}>a8EqP80J9~8 KT pPp2g(e 5A J=GuS[jxTA*}G%plM{mXa/t Lg usIXݒ{'il7L8@MGpSWw̉ )z%*QՕ{"oj44S*DL!Ѯ )0m!0͋b7zj=ńc7l=̇ze)fX"S16Cs.-WLGHpjpW;~o aV\-Hxq3GWo桦Kq^!:}6r &; KdjmhT5BSAކ}bm8W1m{esN6 ^M7J.9ƈG+SS#)8Ap߄ F.iJԇR{ }؛såX>Vu8H!/tdiP\w3t8jU VL!G-.S^c8D#rdUqsQPP/'l)Bf+Xě1w<+j[նQ'8o&B'@ fr6h((BN~+!4NCvF^1clϸQ~\Xi' 3Ϋ.]M;=4+J\M[l~_OURn'Bz]%ӡrC6.(3>G7M6䵂bD0RC9>E-Sw.l[#GKxRgbbX:A??p5{궰Q[`oZ} /V=_ a+07ʒAaxpƢn=S4X J3|'2:9s_34i@fw 7>1ll /Wߗϸ^ei[%pWSa0/ʊ]D l2QͿVlڮ6foxKL}ps5/&xK N&ѲZ9Oj_T̵qf'L%Otj#Hp$51wYA=8G828u-AnewY(q&Q߻'_btessvq}3TJ9@sՊQ@]7~UbwC{O4B$>.lv4+$2F`_C##hCBPKgJW_+/ɀ{ rGG\aaUbVk(Hbӕ  C)Q X\=uSU97bRcWkG$[n1zaF"Ҝ6I`zD ߏ Fk+SGO4[iiTE1U;.רjڛkZw]ֿ<⽪RHD`tյ4ˆH00͓4W0Xp[7 BT?7s֠g0~8\PoakSm$V ʃi'7cgy81: xȎS7O K);D5/7+\R(;gݮla9+iM"K?+ ےEx$xy/4*MC㭮I u fy-) ڣ\ga`W{tf".y' K *^0YLW=qV(If3Z*1_ym}пOfժ:S\B`y۞RfՄx癎7ԣY97 _HwJ@j ˏqk26 3I%P$ 3<[v^KWVijd몼Yjn(@,Hn@ TE#y4qҏ3|.W|=#cOBr6XQ%kHڍi46fz(S].ɛ&W wiQPg,}1h,9PwǾ 3u' 2)!i@߱V-lEUK2e*1|:kP˳2)=MMGԣC:tl%]pvihZZm?*V$>/hܒ.k=E8}-",cK!@٘K4'ּ[W "^':?>Z,W@R;b| S<1Q[-jVBlZhҊ䲁DEZrNJe4M};cy.=y1߄Sn箆VrPl4F(t+ s~;}s G.1-NB4BꊑՉpw$SOIz1gL)~eI (PbTk ~ư1^HtI ¦LNKdxwHpnZ(>_OŔC-/d6($`LuI]AVѨrt66#Pۈ$]dAb Z鼊/Vݎ~e9m{beLըkЄnHN x>$iIߏƿF,OA&L A*LIwx&=hk-Vd{gN$8SO33إ׹%'5AK"_8d9RZc>kl@32vZng34Vx["G N8Oǔm7-Ncpޤ0~Tr.#f̛ SN(=3r9@N{ߋ9yfFA)ppyg^Vľ5;9[TM!1A= (#VKЊo W+9"f ଵEL+B_I,A˓Sf|[:ӕW$Zo/+O(Ge0sǾC⃼ љ!1l1N+S\k4y*6!;Is?M7fv@K CJbS~j(B}*q R g_Fš ȿK>*jZo ı'Sw,xNXNi.? } ߈X6YZ:o]Ӛ} N8bVlo.s<ꚑ7t0rB}OWGg'z&H gGU}-u5tJy~lͽY*:#Rˎ ߺÁ hY$e} -[{ 0\e] u1 s4f6-ӄ!☽?jj27j=Y4'cO^mP?^ܧwz<'X&BHo-?0%̴ˉbA:L6^ OZ 6E}AT7X ~;ˑ"|j OZw #] S$0ë;eb%G Fn5ixw3QM6nҘ< wX!?O]ƭ[4$aFM5 b;x2d#C&^؟'l>rB/R;[cZ|b)hz my>VcBZ- D?>F&#ZHsvZrly=Xg հ1-Ԡ]9'U+D X);wUϴGq!bL ax gi ]#*#[yz!ZYe-_aJ!<B#Wi]0 ǼcûEGSkz):^J@d,~xCvMxYl"oZ? $q+ k^A(5?h=O+NmD['tϑ(t9Hcvllj9O^i sT,ĉCGHDF0@ H1?֫:+JZfܗ[z+>R" M_}}Q=I#cU6-fn+-12s2<X *h90# %lff "e<`/c. ^a_wGŒfƒa&n_ Nu3`)ya27TB)j=Ѵh#8@qB|.~'z0zdYI̱gg $ԉmjBmDýaYv){RBټkeLtB\p@`Mht1y {IլF*cGZ1vh91#pjTkwj2F:RG(j `N$C*ut",䡔ija<_fk7c߆9(+˂W+뱝1ݮyn;9RP,q5MIz  ʸl] x=nJdUtXnTٛ&o/wXfUsVJOJigKR_PLZc @NybA" ve499ݒdM^U. kHd+(Pյ!ʔ|4N!G`z@KRXLa߽d~[=aWX/UO<3GRRF"gfvo( xjZ/vHd8.Ia1M)~ۮlw/-L ybT0I?K+9Qu|Khv2leY@.aG@ܣTɄOLņ G,d߄]U? W k$ЏV$PZ)M}z@k7Pf9Pm:±qz}@>]B_GMN|<@"FȞ")i?RzD1 C ˠ9E&MnU\%˭g{]aUA9@MmN^%S7㈣&G@TKo󸗄+F`IOI<N%hS l["9 FP}/.W:=3M>,.&w\#3,@Nvk礦wшe4~S&R:,|Pi^)13nȚȤ192KNKxS?029"D,vGv%Є6UkbʇX3R2*܆u֡?s|V42i ?cK˯ \̳9fSw2?+5&Hi߁i ! G +#N|$I|E$'T.nU*y̴Yos%f) >@")Q9E:Q/s'-9}"ځR?ŇO3?͑VĈ22$>wضP~l4R痟j!tϭ~eiUqN=^ƴM: qj(as~c\x A'xClBtA_bz&E03~(S1]@Ljګ W:&ͮpR*'$TV u33z+Ma }'={Uq\꾆_,{gnN1,*Ĭ`ţt}|K{,*%m5>4##S@V9gLk;fkѶMsPH% Y%:<_g)"T2b=sq_%zjo;tA2+Y6LC1+ʖ9l a`p$2Ɇ{rX!B)T<)ǔ6? ;R׊iƐ KV?&yˋe/n0 uR.7ׇ\m-,[:ToZJidlÈeMH|H]`o(5}9?FpziiEa J0J2G0TZn>P0k7vj~n}DU8{,*OgՆM'PVgD>$_/#xi"F1ˈG5Zʏӿ2$Y.I|" /lQ\ B?_e]=!w UD sȿuSf.^iMn|*ȬV:'x{UM@` WhI<3Z^K|D6;cјU:fԕC8^|oG/;>"uu(I~ro+:@!x9Ia45T;?۩XYt`es(.G2@yܟ%2U@~@ ҝً(c"yvV](Qc6W9¸v6fHm-磗/.&a  cF N *xsH*: s7g8ǿs+=?F2'K^fZ|W( 1%T'J:%H /\v_B>>ڥ8'05h0&gZ~TZrDa{%J+y3Vgpʣkg1e6:QRE40:y[=(&Σ.clNK L !xϻ<3 &z]x!K,9!܀Nֽ=6g?Z[ nwF7Ͳbn-\ՄԐ, SFUh5C%~CklT7ntrs#MAI ; 0w9O؂@N#|{]8a/oS۽7`ja6~l˫d>"aD㬕[q!.#aJh%gF6(ee<]'r"ݢOq`hq3 iP[TRk)-Xsn39ĵJ6^_RuwmJl.p {8h$y/d)tiYɅ⃽$Ip~.鉍"~|'3# Ћ0@_Pj8 Yo5'Xh, cHI2[C gEužL -Jh:&*+~Er.yG*aXI}WAngv"]^3ȏ# sCʥ-9O y)C0.IfPڿY3Ѩ]cϮFŽd%đ8oj@pXR/lIN N6i?7BHO?4jnA]Qݻr٣E&U=z*,u[8q1f'߅h(Oq PX+Gn'ǡw%,; gG2yDߚ!J  x?|kU!B8':d+{. Dt@r !9 Umoj3o'ZЍj_%k5Y|ݍp,AF2=py6W]. ̓ĺIK:\  .IHg1˔.S)f'y*h/*(r><A%^pLHJr=\J1[:D]hÛ[ {NKSj?$"MGa45NJOO!/Fb(;t̷ t]EĒS"f@Zvx+/)bp["B&DW| ?x-G}vi ?5Ƒh[2NQ qTߨ2}Q6D!2G隮 PsS, D ;gS\NHYxO41(`xq)yZؐfCn"ȣkSe@zW06n̡K7|bI9V<'_jz3<E0gv $MÚ q,[ D\(h׽(o,]0@?y5By p}t[ԃ* l(~(ʼo_rY,_ "wݖ0:LX ?lXܵ8y4/QBR<=HNצsw. 8hC.S[{ c3Q58S G3xLqGyI[=]b^6A)vT:]li֓0eNу硎{(B 0ccUB/fGL?= n8@H<y&Bϻjm~])sG|X 1 ^o婅犭&7'2#ぞwΤ80k BJԐӴ9KčxUƓi׭XߧhV$;Aq burJ娲Inیb*uED ¼:);B* AW …ߧ&b'̣q(w׈ލV;]λ0wNDxVf5+&C9P;.t'&!sY>zxŃP|$mꗢK94 9IYLḚ_ "!`K#Mn"OMlU7Fܕ#Gۇ7[I~p5V0Z^P,:\zWzysXX+vZ1[# @贴iW$}#k8R W@1N $*~H7q'/21暘.YeUJ&VT `ctI= vnU ђ>h 6 qj{CQsH) e?b>AkI`;^oI]ʻOm`t:) b~n,22>y 0x=._RJ3z${S_fWP"ZA10Z>Uni mN%(DpOg W0.qAG&;nlNreM8p 5]jHG@˿Q`@KhRוO l䝒**Ξ t  0MzrKf=7+9o- $n=h UF,D -xBډV;$W?L&GYi&/J7e9̹ L0.p`7pD(9JGy$U N˽rw^kK@t9r"}*L? eHBi,=Ծa޿~D{zf ^Z/TMj2*Jmik5pU=aR'~<Td_r,Nl=n}oJsA~ 1w?! rcϒ/-)oz/Ƃwgl͎Hb^>Xׂz}TjB Taۨj[ȿ窠Ry]cy1/ْ6#{iݟXSYwΕk[dqh.60/QגsUoy,C{p'<(01ei]T-6UZ].),LK5y5NMH,!A%R4d`(^=oοPF5@ 7n8e t1XheTrQ:M g-zcM, H iC`gQ'&6}ꡞX(\'=Z-x6kx[Z֑ڕsbzCZ bX-3JT*_;g]yB?w g=5d7BUSɡNk`s1fB"qU)Zvfd ٤If&\p-$n/9T\}a<X"9wsWixHKCAd~_,gӐ<ۃ`YRs;^*f%Oκ;ҀMF[x\C˚X7׆ucf:'c5C_тO k/ Ei4V 'sԸ;}t)[ϳd~e8&ሠl$2vRwD:_ H"xdhzvup4YܘUGuc`3TBoŶZ4(e?&dsx)O+ٞS?֤u--R*PQ1.iN-$z8q\Ͽb#@䗏!_ؼntS@F%9_R(@j)T+f_3G^/&Μ $KUDЭt9r:A[!}ü+7jVFmm8>U* JsSl^VR>y2^.}mDȄf.ӯ nLd[f߀6uv$꺞d9YUOe49{E3V,;EsT@%^jo|@+|zF@MVWhQ Ო90%}ֆ..3M)/º[~ͳ.g.6Ƭj\ @'0B??jR yZP0kG:9Ȗ3>o2*xPW$ai-o|0(\6BՈ!$[a9T}\"뗈 p1bߘoְLk7lxݜK=[n5:|VRu2JJlݑjأG`JҗQUf8A-"khϱEwVHAt2}=_sSs1Um`ǜIလf(^U,ݒy|qk6 ZIĿm|FxR-;s_+pcQRmLM@sp-9,ov&kl_v44>Sl8&]P$ZJe#i@A5י kV!+um۞߃ǔfZ$4Fgs@r8ߧTCۑ ǗiDڛUqM\m>o>҆A8~%/> ) Y{8^v՜H-AJ ?ja OLm`Wถ=TDžLYP -3ٛdA̱/0pI)k6$(epź 6mJD|y<列E{#!Ы)1jKkʌQnw:WA MK(EϩP3 t"d9 u/A;I{sQ} MTJt[Y ĈH'{x{9J Yl^YRm׳Wh6`Gy-QWYǘ0H9 $u>5>&<|g[#/i ZSPwY6&QckTfЯB A cP+e0_npaE%?18iCsJLF#oT4X8.A~=!#JT*8Γ-rP`GWuM}$}鰼6>9Ȉv.:aFq&2.}%~ZFTՉICmo8![6}‚ܫ}ʰý{Y#kcAjQu+>0#q@p-DEh;8}]0ső4zե1wۛ./*GC2p4t,x&1(9'Yh.${]b+lBЀEϽ!v+ `jT0$km.{ @r?#/ѐ3Τ)Z$Y@4tKY nö~>& [m@' pjƨNA*i)'ZgJ_x2PDr"=Tm20B v4AY*CӂՅ0__Bh_ӏ;FK :'rM~e_PҜl iuMwXʽhKՐHFX*)]D,-[?*;e 4Nj=z.Ao0YQ?t@"/.A+沢G/rp `>Nέ3A_^'H"QIJL .TfF#dvIcom8oXCFQtr]y@<~Jm~.i @=!ҿVݥOx6xK5u8kB?ApTk8=fKn8$T}7bnn47q64kZx|cnןt?9J*fAȷ;-LSX\Fjƙ۲r#93-cX YZ