lucene-queryparser-8.5.0-150200.4.4.3<>,sc_p9|ef"omxP(BMlv&i\(3r=FAWa;yXFT\yd)3+0|*&~+UR/@cD8T?,=!2>^&W 1-oIHaKl:dYPtct?ᢏ)ܜG~>>?td ( F 3Niox     $<  c (89:F-G@HXIpXxY\]^2bcTdefluv wxyz$(.pClucene-queryparser8.5.0150200.4.4.3Queryparser module for luceneApache Lucene is a full-text search engine written entirely in Java. This package provides the "queryparser" module for lucene.c_goat16SUSE Linux Enterprise 15SUSE LLC Apache-2.0https://www.suse.com/Development/Libraries/Javahttps://lucene.apache.org/linuxnoarch  iAA큤cVcScTcTcWcTafb792873f5ed185ab8d100b0bdb71fd2ff96001d2dc1d8b8b2a1cf17e5b1bedfa0a6cbacc05de5ba0275dec2934e12ed27cace06a1240e8252196293f6d3ffed11a952c71422363d51d3ffc6880c918a792c4cbb11b15ba56d768083007e835lucene/lucene-queryparser.jarrootrootrootrootrootrootrootrootrootrootrootrootlucene-8.5.0-150200.4.4.3.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-core)mvn(org.apache.lucene:lucene-queries)mvn(org.apache.lucene:lucene-queries)mvn(org.apache.lucene:lucene-sandbox)mvn(org.apache.lucene:lucene-sandbox)rpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)8.5.08.5.08.5.03.0.4-14.6.0-14.0-15.2-14.14.1b7@^@^x]n]?]@]@]@]@\b@\'@[Y5Ycl@YTY@U hfstrba@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- 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-toolsgoat16 16773287358.5.0-150200.4.4.38.5.08.5.08.5.0lucenelucene-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:28016/SUSE_SLE-15-SP2_Update/cf27f6bc2a8a2e797691796ab9ed9cfd-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 textexported SGML document, ASCII textPPPRRRRREAKhl[utf-8419ab6f7e0403bc5cd69f6008e771027fbdba4f06688cd3c473a73647ce7ad2e? 7zXZ !t/]"k%w70 Zp M*1QhBB,CGt2h֩ǫH& kG~mWh-5q|p7F{<Ţ>kV]J>+9~Y.AU7ob07'`UZ{r~at,ϤKHF&o-Oܷhr29thF!qiKOޔ<Є%4`Fi{pe$T"_ E2LNqhHRf\VIl6:;aDj?%Qۭ=FT5KG'W YwZ/\tYg=)ۑ9Q$F6/ɾ#Hu>@a M"tݱ I<8qNeR2d7Gܗ'K\B v(E'C8՞q$€/2em';2Te9$mVÕSRxS)Q %{fTUef1Z"h :'OT4t#5)36{e7^fyOFb45-E78A')4ˑC:>ux* !q"8,ow~t45C"es|\j-NS2LTS!w1k7u^8ꐓrrngoR]r5[A觳$gۻV~˖D0dWV 1@?t8.3}9E?`&Os0(9|6g[ }B( M#|Ꮹr̀WME`ЄgiZBM;^ݺ?^91≑z _IhFcc9Տv/0"U89#t6`3݌-2٬kvWRVc+0e% BT1W$']NI4dK!cWpj$dIqܤ9jb7u(` $SzT l7 O3g}A.tl]j05$ 6Un55C em3:Ǹjyw.~h?:W6l.Rڸ%!GF6B0_Z0[ ' ~pV< PEEf]\HJ DUQ[;ad*E_9p(z6zYd+Flf"m'|iw\PSQS}qï;RS#Ŵ_02RkTn*-[48R /3Vs"> /py@DrWe'Vl8'\##Wh#\r|An rR ~D [GtVٲܶ;?%JOdaǣ2[UDR Tf)RA ulC;zrv. R*Y5HpE=LohVK;p 5!Ĩ}@c>ju^GʂObpKbؿDE_yU}׫. ɒAf<)#u*{8'-:a_rdq2 ~~,q2S< r {{jEohҹ6H6a4yu^Ǐœ3{J~ܿmUI)|s=ʐ ɬA9BGw=܏?:oD]3MC 澇jY6# pgY m_{37xW&|!Lɮ;5b-ݰһtZ96 T!'wŕN=.YexzNL)JIG{ M i?p4 )TJkmǼ-.z%7{6^tZ%ggLW@,|sjKNC a3ى,y)T.s<__`K9%H7"?1FW|$=')0 q_<[k:H7ֵ <Ch\T**GgX2f\S!⫪ y ?k5j+nµB>"hpF/Pl/k\| \vzVԥ\sb$./j:mUMF{ph#I>SQԵ?Vc@ 0v }bяl]ħ/DK\8.<Ϭhggy(/›c?mAEЪS2?˯OZb 54b {Kc^Kl9vXqQQ8RiiQk CUaЊȣjrՈ@ ?-ᴶ^~iZ̸-pDw.rA6gD;wu|7=~ųef aZX_ڦ.|՟0 ү8G""1'Df xzMOKnЁBώ8^NEs O@dbd T-Y Kkl 3})wW=•ZB zB܎Q#iez ZJVDME3#x-AHΡ39S~h4 j+P^U;caE/6F#.!(p A<{f0w<^KS)!̒3vb^<'`PsE;PxݡJ'TW+>e u hn~[{I$uS3mʺ1 dPl47Y[C/"08(OUiұ־؎?85s=}S{D,^<qAZ-_ch28$ފȁ1k29J^dTڊbmg>Vi41\86"5;Zx̱G't͔#540C תF/+u(1>(7wJfmo&_d_lXbyW VY 2,0%7~^ZuVujKS RKQxMsuXmӉaդK5gR}uq2-IK@.j$ F>gذ2ʓ]R\@Ixpbx^=GM_\,p~jf #Ml>.hg!cAlKWgs=^]^ lUݪY'0W=$\FOU[VRZC,F'H~?*&+Rjs'V;|pQk+y3Okt򌝭 'gpiRQ},RF j+TEQq2r7&PF^QF;,d?XFF>'(8QT"M]"IhC?mg2JuVyjaX0!1S2,7/p=QU~ф?2;x े )(bw.IԦ|> !(*c `9˦[٬[UUlߙLY?׷ăN3M09:()02[@jC Es?n~Km~*Aw֭RmDm8R#9.VxoE:42ML|9[ӣc7qWyok\l| ݝ6IyG  `4ߜW-X@Nn#oɚݾ~/Pd%$0̅[1{3Jд")N$ЦNhUz0Yjyn/̆f]S/KHM# Qܰܛᮾu1Eꣂ#fYDCU\eOJS\27y FLu7!,cx@dZy͍#z'4trynb8 `ZV:Mb;^t/9KnA8)GI796PNvghLTڵE1˛]txR:NYG*veQ8;̓b]jb%,Z֥[sg0]g-M1Ϥͬ53RY=;J%T2[ flY#9 ➿;䐇tK/oÏef$; (+6ҜˬgcwS5|ɯk0 :am&i!?<ˀh iTX?$YmcACpb_=\?ǵRnQs84a \F>>XNHir*{_̮-s,a19N6jߚ,CcLW]ɪ+{2B$rrTdInaI<؎v0چй&dK(rA _iKc2# ®!77-" ;@wdmETW{? wS+Xx.|ڒ>zwͪjFW*X9'x:`)&1e 0@ #߸[fb(: AAPFF{H;_y.:܂y,qw%J  ]Ԋs?O(="5l'NXӢJjRT\f}Onv״W@PZh\tiXuBC,Dc(8L ?mB1D|mάtrQߦCjtg`@>$Bwe¹JMh@Gox\ Tf?ePc~ar/KuU3vᜩF 0YGzw`iO5 @չ)cal#89-{t )Eqam^Sv#Osiwv n$at&b!cy.YRIz{mcڍl(W掺[,6R: sE)BR`_ۧ$o"ۮ~Ww<$_k^'kY@XpViSiIGs9{έj$}֥aɭSi+X(  35xiROnmTQ}##je׺+ 6(a/4}NN|ͳW +4F ,7#?|SUYV,5}aMY kGkfId&A `yOo5҂y5=|)JlsM_#f2y=%!қ%1! <Ǻc@e0~' ok$C\A dB\vďKF_ۦ{Ҭ5b|)%h0/U{\FB@ ~#r뼪0]T7.xHx?uz=R5!fI=L9ԍC N0ٖA,>ȅQWHHGLIfw &@[aevtE Eqe]enB`C3jaq𛝉u,xV$G*{yђm-go@ gю|[Fk%(1M;F^2 9lϽ<5KQG Q.y7dC:=:X 뇇&&+CF,EV`)Wʁ͜KVB{-Mv.;2})o(ۖ?w7y_Dħ[ lUhl{o-\ 2sSNJKИc6W2^U8B6e^!}B>F:`Y^HtTU{h18Zⷦ-_t„S}Mdnbx򧞢/KA;&yN ց2Dp&I;z;*<Њ0iмiKp>8ߕaBwpL[1xcθ-EOZ:oi{J‡bTͳ9uNw;xf1Sd$#Ie+n|)L(W9mhkj_mrWp<"]gYRmj&(M0Wʪ, :i !5fvļ#wtjp֏(w+q kGe2e?K2łnM{Z\NM~X0>.M8 Թ,Lwj][0|*3 E-o}VrMrnד ,?kO̦D@~(bθz{1hsS_5}vZTflSpɦ&WRE}kɄӛ?le#裫%Q_ .a0^|,s?µXtҷ}MuV7'H@Mg (Qğ\.$ k_|h$9 $(kvF?9?'yk;H&qՌJZO]/&^Fckhwmbc3&mNp?"dUX9`£ YY >PS3>ZKmR/;ub1)21OH1 I;"| b[I檗~R٧!tsWGAH&s9:nƶOQW^"h}~ 3PdRhE0l+-Dhmty'/؁ 8H!RyoA=!t'x Z6 ]e#aߘ6Z5,#WМo\ܭxlmD3 92.^rG,B5'*+ 9) 阽>DP)XXR`۰Q, a=3QcV AاPi$X'L(>Q,kՆ0U!_kY_M,:~&&i8֓! G?=2Rk:#M_s->Xhws"\w,X_˕l0ubo_RIDW")pimKg/sejHcx:E3 OI[ ΪJb_4_:2m\Ց>3RI 媕}Ⱥ$[Qz L3suNalUB9 [޺$( ^4(eGM9>wAM 6>:ԭfOR٥md”­QJw6{q್h(o#63D1LPjf=w!BЦͶyOKT&+ʲ5ʗTzgIKa)7ydkp腙HtmC(Cd虂 <^:0YJ[>Y4xnB~aNU"r0sQj&gfBF=$֏:ud`Oj]sd08cPMLF'~6o7".J4jVij%glV;0ܳE9R$6xqm0Y- ۟ @6#[۟)ꋦ ba7-Juj>,-Mx|-B"ԵDt@}<6x DŽ3b{y:; yrt[þ9I>OQth>PKY  Z@d&+ Ӽ7F_Nӯ)߹bjS D-Gb3i}1âe:U)D  Drgv#9Jئn$$]+v*?{#>ri. Bx RB>b#jb]kCKE>s+%4nR+Mo391A&;.N:|tª]:ufT6~C %y.RRgizݺ:<)p_7x?R%4MAȭW.xJN $⭑i^^v:SDWq _z-ӎ% ]Fy6}Yx9JE%V!3m<}f~ʔ7צHri4¬Hg}8biIr5ȟ2i⨝ NU>T*#ؖXeA)s㉎$nEn:.|`8:r zcT~h dz [q-Kc3Uj>W"Q f3"=\tcp౾͊KV'"|q\o@y%~Nq7(@=,il8-Ӣ,ښj z9%ۃh; B߮0 TΒRAjmmLp.7sM }6XuQ'WWT=P\X{:ޘ/:F|c 꿵ݙ(PB8M0= z(^-bAXb ? =hYnW1uc- NW]vX@Duh{*PڥtXMA3M/ fԓܹ*ɭJ ;FsF3t|}`D+ bo`B/z16ƬCClNE9$srH I2+@$gcTT3KDj| JzxGڄ9-aKKMƲ1Z = " XXrDf3ۆz=%9" ?,ia~^\sůa[wV68. <U}A)|+ṭ Bg}j;5;-=qWZ;UĭA]^IvJN:nJiSw y|r#Ҭ&3m aCei\ t075-+V/xMVu%IWW] ţèGП{- V!q"V"%.JtWHu{zca:_M#=4>Q\AWŬ9Cy-M3jV^kq_|"M*lTgwjQIYWL?uRA޿Kr|DȚps/H.aN42ǡ̇'Ss}B9\eF-r]\>ۉq3\"֟;SNtKڎh^oz͑Y_ |(9j)°g-BaIJf Q25Bc]&@noz}"SYЂ0X~PgfoR{vkЩ?i7(''8fښ͍Q9N=KN-K|KG}n^䰾0l?\ĉ%D J ?[X|x_y3qrCInyؒ9 jw*98lcp>Iױ@X8zx9l=YD%8^#'O@}pnSq'EvaQiQ y 'g]踞\UjOrApDA.#tb~\ ASȽ,|P촩dhrSe#bV\96]usq¯}nH>*j6 _"&<+#B֘;k2ETynB`8"E1Vե9e޼k>Uip^[j"ZK+u`%Pn|M-/W컒-qS(h]9s0!hi"$Q̊HRxtKaǠNr;5pc}6m T3Rv/7K fsݣw$>#~KVq:dZ-u-xl|LM}rׯ $ Ԫ}AH pp|'GE = ȼ}gjqggsCu +!AYKzJvdYQ_qm<8M};n2KW`CK΢x'ًyhqfyo5LZÕRom{%/k׈̢)=5,.Mn^iU9}^=ݐTK]=7v/*rBp~(iVw+,  I*cC\xq-vbu@2wd25vNȁ۰qKf1 iqڗ/? VO`p[@tpj枙E ItJ /~2idD/ArY?bMv6!eO i3Yq 9o^m|U@yN&-&K3vNз7 oܞĖ!mp-3d2\EЧt4}Z?=ZM+rXEcNP(Clc&9EzT80b4S|'?T. GIMt@# YIYH%GGMϐWzѦxĵlS&\)GfVE }`Nui#Ubui"d2~obZoéd}#[H !x1PK1IOV-F=LEݒ:A*Q5eM+#j\1۔)8p*cZ cE9eUf2+ݣf[0:DŽ(ϘgkgM!Fr2\Xtk93S MK)5]sk 0H[YiD5 2/nl8;Y0I4;jM׶ } E0YpHQ1١pt03@ɌAa&D16-\"yĠKxiUuM`-5>aJ74>/aY]Iq$ 3mwsjtdʻn6aCͬxzq>%[vi]E{5Qޔ@ ob5wN1R āon/ʢ~_XXvIr>(q:T֭)%'sGq쉍"J<]~90c󱵂e0(^m(oOТTkjL `wm ґ]! ;ËoH#fZ"5) B#?r]*_xѯ?WeJNpm럃r`s^YjT'AƴDOKIuw<bD6&QP&ֈ])WRGtWeJ=AOʈYRbȦ'Xca*={UDmJWCU3H*[%~ Wrˠ:Fӱ#Q[߆Z|MiFӾA(:",c޶_ɗ_H u`bPXyL~$ob&n9ծ}uQ-_CQqsb=ɇ+a=~=oF@o]bsiN+%#g' XX6E,/?vgR1MT|j zTXְ'u=Fh+ynntP1#<6ylm6ˉ˕VjlrT#?)KJjWUtۘ1*ޡl<͎J+}EZ\*^ ߒ Fƕ*+H5ې^ 4\)aoqsqDcN{1S>A}L"ZyT"| hX,%j?K&T4Q.QSukKປ܁[S ni,e]XjM۹SdNҬX57Ge].M:w)%:+fMx.#aj(ϨZ{dG@+HRN4S}۵0wjx:KY?).;Yc $"ciFt<ÿLg l ث=Uq㾴}ow8/ njnkYO "`P25KODEA4f"zFŎ ޠD'>g8ףZ;2H0;L1XϷcrNϰ 4?TzCMU؆Ap$$=S/b\l1YW9^(kUH%Hcׯ($'LJƧ. Yr}1vP((+UO=$\Y5z.j ?OC'p}.xLdtдdHjƟ@ieN\vXAa<hP4p7HPeg6|jnWV(gJ镍3 J־3cE"ly''KD0H )MJ`{,z.:F{ QA{Yz"ao0JV[ӻź܏E1xDix@.c'uJ)'uBP6-ߌM:WNcn0-Bg@G_nԙ'PIӴ;ݾi#*ٕ*(Ḷ(8$ #Z.q~1# W|h0إ' U# _A[$*ׂy; R,šm FK^vȂ=SwkaН[)<*[QuFY¤J>9)庑w^O2Daf/Gt!~lk(n4쩜͒b- $Jן.LOPl4:}D>o!Ww3&:`aw0޵q;Ox")'>KbW{2y Ze1'FOkxwF8O?疢al9@M%7UQa\=LJV{Bɜg԰?5tQ cm]Bڳ8g׭&Jm]mldp4 84L $o!\TZ:[]CϫO_dz<7pm=3Hm݅oB5l%ҕ7 KDee{e_ egKE uBCEd'o~Auewx ZGr *s>F\A#̃z28ʓnt##hMyFB]ȱ:HQm'&}K)Faz1c|NKdYfbt剝 `Gi!Ggh:=8jq617Sf|6APAĢ?dT[>WaPRͭ`&Y jRp)A]b0+Dɞj1<`Au*Vi[նhiD! *$F.FG'$?ѣu_W=h/*DP*׬cn}"@eȇ)ٓTNh >G"0YH[ ]yMV;n]ܾEG۪#5Edƅ-7Bh9RUMͺ]Y3%is5׏^(:֨ע8Q/q)b- HS.ySA K3Sji2['8/%Θ w#P(`wlvq8g1#"Usd vԁv {dʚ&@StɊ\RTGz52gtfi`YH2Ͽc&Mm &%cl0>TuE6MOMtWn3 S[CT~vBdszb ƒUl %[H<֎? OwlA\ qϽ$:/Zy y4iiZ6ឹуv K#cuHee68|3ˈn_I2I=V=P>xwBb5bhhtg2- UmRM=ט00`AVv~x0pxOWӥ6p]UÞJ^.K_wxQceT_ƃ{0D@7N3lD3}BXeК\*+-ݥ։^Xcîi*(rڧNQe>CD(G焆!qDsY/Kzj̾Cҿ8Έv`lAoFǞpBGR O5>; Aoup!ԧB t@;aO ¦K[. `hm[?#F}t4jP%;Utd댇)v 2mvxjLB[gM.a[g GiC4݊xs+ecN!D6 HE PAnrq pK8Ub5a gۨ>bn)V#G5u*ŸeGq?S3+|^]GC~d O^/6G,8-Yw-;Ys0H#wR TfxեuW++.&w1țSM0 ֲoO | w2 ..+v7ϵgyH`I5-j_ZӖ76t6UDo] ' wkP\:iP kYz)d7;e9@̥^_N hlt;G| iXIYK__YOmƹtRBC2/jKg>qr%U r43Se;ۗEҹ@=M:B+FuwRomKFp5cυm1/$6Ǐd ! lQ7Y9k3!ՅONtH}5(9ndN9Oلܔ3Ha(yݵcá8m,^ Ժ-(Pi*\듲2:,R ް}1Qu[ V J`:PT۩zIic+7qGΊקC8=9*#-'Li'٢= CC}`29;ttf{w}RS\ɋwPnѸ^2 z g:n].W8־{]$%E1xܮBJ1F@]i.S+ bL6'e%AߍaYѧ+_}w?$5u jj!8iJM۶"hVbXC^߳Gm]/Lٶ6&o**tA%;,K3WPc2ѧbJ~Uǔsi~c/!I(;[y@`%gBNhN)@hK⍙$#@v ,WY8AġٿoNš^nZ;痠zcq) cB 5-Z+bd0rvy&n2>rCe5$lIL4h=6P ^\M-^V~ vΏЄƳ"{~Ek[osXw2 cݿ  b?2rKh$! htZKXVfr<@ҽ?|n׏H-pfb:?frW5Fڑ误e?+uB?q/>*jpPӯf%%㼸9DFCQ5) }$,JFg(xEʆ'HC١ٝRIݓG)HӜ`YTfW36fq(j-!75P^b뗪N ;tXuFvlM׫˓-=: $uڮFp XH=+53}ҍ4=\كś{IC!x{ζ3׉(k^l6Q2Vo,;G&NWOOvgKEZgC2*2aM[5&ENӥ@yzelQXo>KFde QIiP_MG Z-+*\ulMYhZhX?u|0p):r!k%)۔RA$:^_zᴡ_5Azp?R}2a}f8AH͗& 2sQyO)R3> |-[Xpc-G!W}}ݕ|CaD4PKk^X1/L*]څ#u)֌^`ȊEDSo(Jf%%VЦϭ&¢@lRz" sK(6\!!/mar2ŒU0lsXhVᡄIאʻrR~j'Bo?>} =6+orS§9(lm J>ʽvoTe$evhGloQyx4(sAJ vN\bOV3@*w KѦ!C<(.MO0=@(1%s ڭ G : /%XKGտ1'՝o[1;O< #׍Ǥ(jrtU@習Vq"7>iJzdLPĿf/%4_Y*ٴDS:mr B?w) 33p?ܝNm+M?eAY90% H2'v,zy/T3Cvd n69)se@?udHm'H|-lQun'eh:ihO}5n)5qtGH0Uw# lbhvj>d͖Y{bb|ҟRU 8\χ0ox-{VUջ^Mw#>Z녅6U9"mq7gL ^>6AARFe^oG{lnDpaXÉ"@gYvt?^!9m9Q@`<9~ 4NQ˔l|!UtճC Y}Z#*W^o{P؅$$z%r *`{ bi+G #%#q,zlcի|$a~=b^æ캜N#rS_49<CrTNG{/9hF-bb;#6V%H78gҒ6gMRZVŪ4i? t:1L/ŒX:/D+`SC z;rd3k\Qzcxix]|ǯu+Uॖ2Ԃf/6QP609JDL~VA{꿮ZqqbZ&ǎ-vVRd2Qt8.6GovJ@@Vt$/,4( f];?{O_ 8e˹>>$ v'+Ԧ{rS.PbW"LB0?W9wwl{{ Z` F6]fiyt@Oi 7V6FZU]__Ѿ#nEGs0:q ? ,۫tcOIxz VOM(gA@5RQWBo˯hTήmP{hSE`05;Y.˿fuƗ;pe6jnA~3 RpO-/S'Iܖ FbB_uT*߽ ,iW(qe` (y }k4`|@׀=a*E w':㍗ϓLq թkAl=ew ӟI, fR`3'4;e|c.sy-^j֤\o'4(>5(e0/ߚ$@->LoJ/=NjBzOB G,-^gs25˦H=axd #܃s?& OAFYbx/X,-򩋖N"40Ĺ&)r^D/R_U4'9ƄۇeBOo'8VwEEIlغWmw6He9 xQ-:lCj),ozWx Ms+q{0iGOj@q ] 3ysv@mi$;to8dӶrw;Aqm;( g:PԏcDAH5q;e[}CE9Rq%hLyW J|h(TU\[/4dx.>06YBk}T>ޮfaǑFk7O %4b_` ϑ+D1rK,iS.Ee¥NCGIռ#tδ18eΡWxW~T0+Kw,BG=(k_!%Ln)s,m`q.iH˂Ϩsg[$AM8_ 䉈⼋%""u ? .v-/{(8Dg(^yӸ_5ZաOxx:>5tI+EUS6>}Me#h0׾!6_%xBZ%uZ7AFy= ):\gBpҧ}82g?QjN9CWFt}˖wQD9G D;aeε`yV$˻v}FBt%ɇ/NXwaXozj9R8UA_m95AȐ:Z O<>$ o\&w'9~;W9];B)w(4ˡ3(9~o.:SMt,yP3{Z}Tȹx1WUtILsygĤ rX 4\pyݹ|3%fveN?2[1wD_pG88@Pz Շ]4.R( D2,Y:]|q\/&{o/@&9 :NT :p3ӌhjv[`u ; T" z^ٟ y֌_lfuה2x jFG<`aU5Gl!c0ˁazċvdw7A/ ˡuj *yI{ ^7A6l!?^q5ak#JmPt.HFZPt]R)fYÇ8/UH8 Ύ{ނt ]ḤFT5_T3[\p .jcI]8;^&ƆH& %ZF<5ƴb1 <@r?bꮡjJJVz3ԭOm3z &o"He^EjLҲg2hQV6fq4S˂m{@k ĠL(i7Z;pa 9#Y85O3d~T_#s>/twc5^ =</ +zt3`Gڞϗ%S*zEoH \zϤC5zRRx.?joDe77~S_mcHHyB$NgD)bGts͑܉wk 0?bJ%ҳ?4R/ .E(}c}A83̫'8/S?4=H-}Uh\pMYTщWP:oG)Բ)ΊiO$Mp\3t}4; 9X.6 1E02~)Y} W]o0%Xf m#// 3xEo3BR}yL"QEzcx;j~:1S14E&R!KK簤"1Is7= 7<`w74_,fBQ^/٣:opDa5=_. σC:+C^;!q X&ez}⪝|O4z<]X Z֧C4=Tn^}6VM^k!Ά'RJF +1(4E9oeUj[c`gy"3x&X o{I7`CRaQsQbNa#4!Ӑlt6mC}ޠ{ \2çr92T1L1^laݣA!Bߦ.B/F$榪a1[ si^Q[ bYj% i(b}\l;[C G%cKT[u1/(6S,y(xI&U~vݬ<[h-&6{H)"; r5.zġƳP- G@=eNԽIHJj1Z ܰw"R~]397؝i}:\q{"ǮۋɦXM@'Do!kSs^:Rb~ ?AGWύ;i|pLfCny~B$.b2MPJxyE3g9 b-p&9&Pu$O`:%9lû\ +])΂SYýt+1hgF?E^/RCwf;#!eP6&z)IZp'G\hlF 9H.> `htӖBrfK=)2S2zڮ> 4˟w>-IԂ벘*VP4qdj N4q'n:G% yjx/َgt@Eq} Ұj~g[R )&QdV +!@eMΓȱ=)j0%ܞ$gi"Ig7H@`DĂո=S{_4e $27arϝUd}$6 G:?px]8)S6h=M PȌ5T<z!AGx|߬8Hҝ!#RY@M_6)98G,d%K%H~EXK ;uyhŶpl hȚ_iKar3Og\0<Ϙwfׂ_[g$pي$_bv$eIkyU4Y숖c#n5=Y(tUI@}HSQ%}']:9XBX< { Ǫa2ZZ& TuI)4T_AOuszcbU#cb Y$Sy.Aa>A猪k"vi `fƩԽbUdѥ北/Ѣf:c}TUI}-#$~.LL&[I=q\vTevJ*B_r|/%K8n@1RQ e]%(k8A GkUycP4U:o8WnNrܣ]#aV[00o@YǞVصdy= W!U-TXkJKO_77\ |.]솿Ș Xj0U" * Y¨0<ҾS$`v( 4-RQ }KЭq1%]lCJgв]1{QVWي g?*믊y;`22%,#|葙nHm':uʤ2!k,/ zqBM{.@y&X*A-!z⑬DiОy\d*=3`ޓZ'a fzz؁cucPWۮ!teԁHo ňȕ{= H1}u6ouEt*|Y* 0,"Ai8naӓ1hd&*p?9C60/'ʆk8;Ps]{bDKInBgejzwWGIw¿1ZtmA4fT*hONJF5yw m =0dtFJ^MI5A`*P`X=jHus͢ $ry̜8aQkVȜ;*۞z6xƸΣKW#/h󇵫ICܒ8mA6)@aj!A$iMFKئAalg Q/(٧2%=01&s/qX zS ޑY%F-A+?O5ZO0%,N$7ğ.zZ{N)b9̉Mc 6+:o8pK&6sAQa'o4$]kUaVȧ-"2謺pfaW^4?5}{4<>,7Nyf&b $1$Y45B+>c]n;]&XPO~\L5$,ūbv)1Zt/IgK~ BED4Y⨟=}ݖj(o쿭?3=~L/'ˬ|y|©Eέc=h[p)b^n~{s:pcņ K'M3p(yړ#U-H|L*~+m.Lwr('}@"l..ܔB-2o7ci8n]\ ӄ.C DqZSC&@7:8"ӀCSW!BE,IMg&8reUΩ'73[Z_({Os>k\n &.WrHɹlA}ݕ,6 [v#|whsԾajJ+ %iHtxc9#qͲXzdg/5 \flaUj`D¾٦N؋ܡVp8< NRb6梕ܨu!ex7VlS}0!Dgڲpa![W u6ghIS)q[X?/o芚2 5lf (ׄԡYzLTFd/ۑI<46*A8AK;HHc u]وZg$i0Y=LphrA$պS— +coq?a5 ځ5?p3&iK&>`H*%> yXS/hGP`$cd$S !/>j4)!c’QBN$ '}..|#Qώ3qKo8z1WZ=H'*:B?ٹ̞ly2Zk7?U#o3ʸ%WD"mTON ~X3c'9x|"+&p'uX/ˍ~ Eڹ(=ܷ(z6594fm*,P,9aQ@_.ws 7h*pI[\{1*v]DX##|!Wr뺾pNVN#;߉0 p1 |b,fBsAG 3b* 4 WMe~>Eg ýeM2{n{H,&Au8`EHT˘5Q8#Ew38e-XI.RboMr`S{EU{>h{ FL ;IMRbawO(zԧ)?v'UזL9*YV{KOtFOsdAdZcsꕸ pFF*(m0Y'DdE$zi͂MU7\C}/y6㜇vOr#X"}LTQ>k^* g@Ul9+n?h+"nݠ٭X8Oݣf,UWo9;3~dt9OktlII_ZXv5/X*/L̢W*$zWcf45\ue/RgLי{|JԬ;`@~V*GSq0U-<8#G)?+2BʀxSԅ%\`h1ݷ(ETTm:Q(?hP#r5b yY6K[Ms=CĴ2<;*5׏ǁgӹcDU.)ǶAwY ȃ7lg(lݪJl?Q|avrE6d%nX!Ј՛^ O=g;^".4Z7j>;®U@ql+^8_w(IƲwƁNi2LHg&>>ڤIRn͏8iL*U?5pԲg q52SجU']1yS(M9'7h飍/@Zx!a#zmy]WM8ZP`g8f^lKƈ:@0FjmI&L{|wuW?B./,J|dp|nx`>/{Gfw:hE5r34z>i +< Vf(G@X! 4RUav):tZ)}T6н˒@ A8jT)ߑ͕{ 881eb%"dPۉH5bDOE=!t83MkD[ ZFGIKEw@U0Vn6<=D:K 8$;Nt5؏6EGY~2ݪFvaEXG@ڼ!.%Y%ΚJe `zLỈqXZ*龴cDܱj.a,cdē`K(__E3mbѢf(<(ىkKyJ\$~%+::*d>{~ҫjӨ5s6]>J!.G,]VcH52| ,.וQ_&!fޔ$m(ҧ46@OֿYOЊ"rSO亿/WbX7*Uޣ/[ϖwNc͆7416wM$`M~;&k`)oxgT0o c"H+9u)џ' $+~sҎc Rݳ쭪OcVbmΠqKZ*pMh`w.>ih9Zf,ڦ sF;v%˽L=ҏRI_g77$50Bƞ&܅P qγ"GwL@ `uiGw8)c/ =eSUGI~xޛ!=O1&O n0yJ`y[WR tBVHQjPo%*k0c A .U&''Xx $㷌w25N 62+!7AI1B&Y&;t0LПt9Y)Q5HvfaJ#u5a [k揍;; \XRn 6ԴMYe}K~R&K̽٢P]pX_..ڝjtFVe24nb*s{D-–o?KRsZ[ |p' gIեg_fbF|[u>R{N$I?!qxG|g.uiA: O~<ą +1gZ(Iuŋt{A6QL(tZpVn9k  Rh,f!v3e 9IZמ%f~)Yv P)ҟr / A=6=([.$eT îks xM*,3=p_Al?뺭tˆ ?v#-G{|aKqlX}o9@D~I[8CzI)ToEX_>N^a CE)"ZpAzZxJ2e`G pmҝŵ bL*|ܫQӑY8~1^I@7űT I``jzfȅ|tP0r8m [b pzM+I5 1H$UfR, @oRNz$o 4CB…D=s 謣'b)bGPws|ZC0o=16{݂˞^ lD0ݚL(jꭶlœ4-_9sbc)Sk&WB\ a//KN[w*Č(3~Uk'_ 5fG bY!3{7s8P#Jm 0A#Xx &y0&bK2Y_ёL턛R )uBP~̻u(//8vpt("|)ᄎ12n+# `-B=]DVPdɴ,20k/@f|,%KN&Άn/cf#)Yۿ5N]7QO\lվKqahGv K*19. aʝ_&E-a(Ł}۾zGˍznd3lN=YԖ2r|fxp%tk|DfWE{Q:5XA׿3|opvc-NLԜ|E' |M?@D~Y!]Kp~Eի'1 w@DZ`%&90:|.( I5VS`p4?M lZ+ly),$I".t}75bQz3͑R1~^X2Ƿ.ѿOh O|cCǠ^?Etp:'P6bmA0ݭcjt1gKRE6҄21(co©4D(Hnn0``JQcM NU<[2'^bnqaIB}7) ))i&<ބ3 Okʘ=e,'`|4Pj8aپvUa&[;Эz#2w/ gCrW%I+!qgEIxx6$Hq=ZS7$*ڽ17K^2ildWN4%.kR\Bw #[ܽ> TcK%hyj¼HjqD.C5ǯ10zSE4b0H:06tx V56}OZ& mFa7 Ou56 "V5 0PnXAɌ;ei癊glQ?|[uKF1]5C9)4관'%gcձt'ј.x!ɴ)QLl\)s \)Vp}<"9^}jQ"l)L:&^K=(!-Ĝ"`Y$4~$ 7^{`Z}$k$߬BR+)Ȣ1_Mry 1"aaۍ,s8iް%/TlX] sa'<=K6]lp*({s8h̃b_?i{ x\|3|2p^]%U6\?kYDԞ} =--T6%*6/y=aYuAUQ˝ڭ"_y{CeD#-+MzGB^ŨBbOĊu0R\ka=-k2,-9;Y=Fef-P&( GJGӐge0&5|Y)Cj>~2OiT4@G2 TSi ܍>?{Px1뀟\U2bҴ9dL٩@5.di\Q-KMBePnb |pc98)./61q"Mz;v2{\[$X[ZY TꂠZHXCeUu WX+2H [uٯo&Dt ͰJsZSuYH ~Q1cc_3ЖiX?JnG@pV#ʁZ!U{8p"S;&3u]Ө ݂?P#a P32-J}NKs7SD;`r\&Cᅬd*h[㔀]\0|숃*wȯyY҅䎲R| mɎ&,j vBr%.Tw d\tnN6r BV4jR\zʽ0Ϋi%+9rR!D4h)}%'彦Zyg( r2VnƎ^ݤiCbm#rUKEw{r> >JcDn;v2 鱪i{@F} mg#;@ec1 1 ݤ`B;i.ȅ]툴k, Z&˫&nQءOemt>Y1a#SYow7Da$G>tʰERjw.?ispi.>wKn8X-;q wZ8}rsjk|pع)0gM8TpE%q>l|U kWINd(g 󰰰MƜwBo0U`S;(O@*Cc[1GB`b`bCVD;7"3NޯEJjP=d"c˂&Fj)4U"'8ddo!~4Ys0 yh#h)"mZb)SɥƖ0G]0J9zPVEtt*R:Qg?8Aη!7QCpk%p \lng}PYGiIlII[Zu +]+t9^7I+G ?S@QUSqm2µy뱙PM^cI,"ե XKlyckQ=σ?Ϟ*EAruk5Jfg/UƼ-λC\v7K \kfi%G]UoY ]ω;m':3QbZvP`H]lp ͉+]`wtPW Hcg.hpi)Չ4KnC.'ć* ]т9Xn}Uؗ(3!2N.B9 n WẊqGe @gH(wV Vm?*'勣[zZ.6umfҁ3ąF4 ϼiO52L|Ը6 { 7Zbwb 8\{OP|Kԗv^@H6r=B{d<*N#\z0w<`=pfƚ࿖:9sO{p~RHǤp.fgzk/;0LYyQ^o>Pߥf_bv= d0=1/ڏ I8@|Նl-·L([d"K}޺좿?~jKFQLu;S\J1iK@?/[MS k,eWw0Ej=1W|0y|>Ź}d'5HcǭytU[͆*D6h l7{ XE_nX JO\pLrn'g՝; HߍL$|) ?( z}S?][Mڽ[RZJ{FS<&h|w^a ($~E`OYe&_*mPbKV`_CٓKyf+߉բ˹ {_*w3/}JJ߈ >U@A`);]XTJXz8vBgibh_tpL=W#Bx{3l&Ux Eon ֬DL$\Jjcͭ%;3}fL&fғBˬr@BًBA9^MbūZ)Քl}>f3D2 i[|3bmjaIBC5ҍմ$cCZW5nT@xq&G섖h!ÚRa#iO ONhnU[ g .~ V窉āoj)ȏ V5jZq~m3sEyEX҃yI‬XeJ=68LĮziS!)D 2'iV؜{A"?ʴ,<|-".;'e`D։KF9Q@ae(5AMjI5}U:,9` {F\30`SM^G8XWMX[ ̸1@G3V 94LKG҅M48Jc /$`r FV%k 7EY!uHL'G [/QS!B#؃~2%p@k#0+P#RF|a8fh}O;juN|U,HZ2O s?:nIp]s3v aY/}ҏ\;#-.O\r/L`q1{ ӏŇR/~C+ ݲ5Ե\]C.Nolĺ=el VSdB9yo57ʻj$v3ٲ+x^ZA֛GCg95~*?vk{. [״dG>=*; ج0ǐ> ksLN̥C{c1 ?*InS?'Yʃ-w*ӄ^Q|<0M&7u-`yItB4qVِC"J?$xRŸJxR!^E10Tzn)EsИO 4uhT[Y^Lj31o4{neYB24!M\j|\iΧełph%ćLe-] xTj\fLΦLڡҟ#g*ժf3  2*O|ռy7&(jub-MO-(hӠ!nl"ߤU\Ii;oџP'5Y'U4@elsM0׫:?YMn" %rt4D=b'ޣLj۶g#TcCњ5 PE׳ކ,_uMX2}7p"K)Gލ(j\SĠ HFGǏ;{&PLuaz@PWA:+S?^3ӰG8C?*hG#8H3tG0Yq$Q邑e{)Zئdd%6_XWWye}==[cOm'3tP siD+[p'V6rt* ^`q¯qD|A,֒6ؤi铬 {l$P u[ޝt4qt=/>KHk.sn2J\9TLvٷ4ꀄ2ہDUQK)H~%-\ {j@EzFؒCg n O8F輬MCm_,HEt[JqWSkRdX(G_`{!I*Wp 84w,hA7/#X)p{[cWߨ niLjK"g cj(Kk,KR:Hp%-GƳQ_٧sq1P eՃ8]Is(ĀʛJFpn{*Ĭ.P6lk9@M1CF{ uǺ;1&M+> oD77 _0Z/|!ƦcC16|f+뱴~n>*80d#EHO!akKq9mQEq}ݒ.hsp wo{p(>7iTs2"b bD OJ-~*,nչ WAָ%AYJoey48#{h`.m"A) Rv#R v(BŖL#,p!䰖Ve"ơyfSٺN(Ɓl1 ZnKuNJwNMgG%wJ^TNxZV;ˏK)+, ֧ >i)\,j62ǖL*EBn,e7W[ v ^F *)Dg&Ƿ{=ή`U[܇p5,\jJ9HbQͫ_5x܍R{Ja&Zސs<_ɧAnN1MX #J켦jR# 4@-ADkcSM˾=َ魯)w΃cNV琟SN?I)_25oĸ2ϦR]idJšo(k-82$t6Eb+ش89*dI-Jjn;y!r;UY:b.l  35YW҄X[ñ XVX:_T-u{um rR%g ꖮ_$qVA{Y {*_)Zta^`k jz̺5 lqJ-qɚtlr.uU\c%-q*Cdb]4=)kźE)B[褤}E5FsoJIF]x,>FWBUIi䙊?DTqv0M}ۆS gI}C2 qg\KVD8;Y;9>eb@Sfy,Fڲԝ4>s<ކMgQs5d l qObĕ{$X3sI#F/|vc v\/VPD+\X oo`TȂI1[!JN/f~7/وwxQ a,3"kX61[=L3Lk'\/FA@͌nyq^=kEzQ\tnk#O[; ܾ:0:MzW(6Y>%_ m䃚ڀ0CEے7):M-u5;~J͐O?0u☂%,wbs @ +FO< d,qJ=5=Vcѭ?}&1ŧk\*sC"=!c:?(PHӆ\M9͐R'p=dfZ[=?@S:V;^@e,Ԩvb!/*'};>? AnJC= &*)'b{/o86Y#0Ut#z^uќp\ SN:eXoܑAf~b |[vPBCeL(ymxrJz2z3+f8ry[Ί3:cx(zFzcRri%7@ EV@;IϭCa2|L_)hxG wh|robRzh0 WF !ুr$C9ooFC_!Vfs(8se X}'$BBO pkàMuOcNm;-lz ,9OQ$w y)eS%ز)(6\}B=24Ә8T,1ÞK? l~]y1k{T6AG=Ay]qM;ARtHgxBmY;ꞔVh;xXsdMO:bcН5zg_/rnpy{T6#p u]"<Ÿ$F},xqXݓ74uGNE,#ga$=,g;L<P$πI+abF5șY+&9[0L-1)+.vV"by$=_!5W SG n0tT sdVHe\oD/UgX*sfH3 yR7߬M<&Yk Q&wv=9U Z2eDz!;Ehm0^o'fn 6蟑pοEӭg0lҧnMN{]Ka vw"xY)yo2ss %^V5xny! oFPjcA׆Xlr?<t:`+lerzېOV%n%xbu:cs*(a-H%1gXNtO[2^|f!\9ڣC⨫ٞ-Ez.ЄϯQݭ YZ