From 3fa3cfbeaecc9654e5176af5bae0ec0d54f36487 Mon Sep 17 00:00:00 2001 From: Chris Jenkins Date: Wed, 22 Mar 2023 11:13:57 -0600 Subject: [PATCH] updated literally everything --- build.gradle | 63 +--- deploy.gradle | 100 ------ fotoapparat-adapters/rxjava/README.md | 22 -- fotoapparat-adapters/rxjava/build.gradle | 41 --- .../rxjava/src/main/AndroidManifest.xml | 4 - .../adapter/rxjava/CompletableAdapter.kt | 27 -- .../adapter/rxjava/ObservableAdapter.kt | 27 -- .../result/adapter/rxjava/SingleAdapter.kt | 27 -- .../rxjava/CompletableAdapterTest.java | 56 ---- .../adapter/rxjava/ObservableAdapterTest.java | 56 ---- .../adapter/rxjava/SingleAdapterTest.java | 56 ---- fotoapparat-adapters/rxjava2/build.gradle | 41 --- .../rxjava2/src/main/AndroidManifest.xml | 4 - .../result/adapter/rxjava2/CallableFuture.kt | 44 --- .../{rxjava2 => rxjava3}/README.md | 0 fotoapparat-adapters/rxjava3/build.gradle | 37 +++ .../adapter/rxjava3}/CompletableAdapter.kt | 4 +- .../adapter/rxjava3}/FlowableAdapter.kt | 8 +- .../adapter/rxjava3}/ObservableAdapter.kt | 8 +- .../result/adapter/rxjava3}/SingleAdapter.kt | 10 +- .../result/adapter/rxjava3}/CallableFuture.kt | 2 +- .../rxjava3}/CompletableAdapterTest.java | 22 +- .../adapter/rxjava3}/FlowableAdapterTest.java | 24 +- .../rxjava3}/ObservableAdapterTest.java | 24 +- .../adapter/rxjava3}/SingleAdapterTest.java | 24 +- fotoapparat/build.gradle | 39 ++- fotoapparat/src/main/AndroidManifest.xml | 7 +- .../coroutines/AwaitBroadcastChannel.kt | 4 +- .../io/fotoapparat/hardware/CameraDevice.kt | 109 +++---- .../java/io/fotoapparat/hardware/Device.kt | 4 +- .../fotoapparat/hardware/display/Display.kt | 7 +- .../selector/PreviewFpsRangeSelectors.kt | 4 +- .../selector/ResolutionSelectors.kt | 4 +- .../java/io/fotoapparat/selector/Selectors.kt | 16 +- .../io/fotoapparat/util/StringExtensions.kt | 2 +- .../io/fotoapparat/FotoapparatBuilderTest.kt | 80 ++--- gradle/deps.versions.toml | 31 ++ gradle/wrapper/gradle-wrapper.jar | Bin 56177 -> 61574 bytes gradle/wrapper/gradle-wrapper.properties | 3 +- gradlew | 292 +++++++++++------- gradlew.bat | 56 ++-- sample/build.gradle | 27 +- sample/src/main/AndroidManifest.xml | 4 +- .../io/fotoapparat/sample/MainActivity.kt | 39 +-- settings.gradle | 6 - settings.gradle.kts | 31 ++ 46 files changed, 557 insertions(+), 939 deletions(-) delete mode 100644 deploy.gradle delete mode 100644 fotoapparat-adapters/rxjava/README.md delete mode 100644 fotoapparat-adapters/rxjava/build.gradle delete mode 100644 fotoapparat-adapters/rxjava/src/main/AndroidManifest.xml delete mode 100644 fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapter.kt delete mode 100644 fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapter.kt delete mode 100644 fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/SingleAdapter.kt delete mode 100644 fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapterTest.java delete mode 100644 fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapterTest.java delete mode 100644 fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/SingleAdapterTest.java delete mode 100644 fotoapparat-adapters/rxjava2/build.gradle delete mode 100644 fotoapparat-adapters/rxjava2/src/main/AndroidManifest.xml delete mode 100644 fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CallableFuture.kt rename fotoapparat-adapters/{rxjava2 => rxjava3}/README.md (100%) create mode 100644 fotoapparat-adapters/rxjava3/build.gradle rename fotoapparat-adapters/{rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3}/CompletableAdapter.kt (87%) rename fotoapparat-adapters/{rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3}/FlowableAdapter.kt (70%) rename fotoapparat-adapters/{rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3}/ObservableAdapter.kt (70%) rename fotoapparat-adapters/{rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3}/SingleAdapter.kt (69%) rename fotoapparat-adapters/{rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava => rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3}/CallableFuture.kt (95%) rename fotoapparat-adapters/{rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3}/CompletableAdapterTest.java (54%) rename fotoapparat-adapters/{rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3}/FlowableAdapterTest.java (51%) rename fotoapparat-adapters/{rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3}/ObservableAdapterTest.java (51%) rename fotoapparat-adapters/{rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2 => rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3}/SingleAdapterTest.java (51%) create mode 100644 gradle/deps.versions.toml delete mode 100644 settings.gradle create mode 100644 settings.gradle.kts diff --git a/build.gradle b/build.gradle index 8e5ea8c3..27fe6cb5 100644 --- a/build.gradle +++ b/build.gradle @@ -1,58 +1,21 @@ -// Top-level build file where you can add configuration options common to all sub-projects/modules. - -subprojects { - ext { - artifactVersion = '2.7.0' - } +plugins { + alias(deps.plugins.kotlin.android).apply(false) + alias(deps.plugins.android.library).apply(false) + alias(deps.plugins.android.application).apply(false) } -buildscript { +subprojects { ext { - versions = [ - kotlin : '1.3.50', - code : 1, - name : '1.0.0', - sdk : [ - minimum: 14, - target : 28 - ], - android: [ - buildTools: '28.0.3', - appcompat : '1.1.0', - annotation : '1.1.0', - exifinterface : '1.0.0' - ], - rx : [ - rxJava1: '1.3.8', - rxJava2: '2.2.12' - ], - test : [ - junit : '4.12', - mockito: '2.23.0' - ] - ] + artifactVersion = '2.8.0' } - repositories { - google() - jcenter() + tasks.withType(org.jetbrains.kotlin.gradle.tasks.KotlinCompile).configureEach { + kotlinOptions { + jvmTarget = "11" + } } - dependencies { - classpath 'com.android.tools.build:gradle:3.5.1' - classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:${versions.kotlin}" - - classpath 'com.github.dcendents:android-maven-gradle-plugin:2.1' - classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.8.4' + tasks.withType(JavaCompile).configureEach { + sourceCompatibility = "11" + targetCompatibility = "11" } } -allprojects { - repositories { - google() - jcenter() - } -} - -task clean(type: Delete) { - delete rootProject.buildDir -} - diff --git a/deploy.gradle b/deploy.gradle deleted file mode 100644 index daa57440..00000000 --- a/deploy.gradle +++ /dev/null @@ -1,100 +0,0 @@ -apply plugin: 'com.jfrog.bintray' -apply plugin: 'com.github.dcendents.android-maven' - -ext { - bintrayOrganisation = 'fotoapparat' - bintrayRepo = 'fotoapparat' - - publishedGroupId = 'io.fotoapparat' - - siteUrl = 'https://github.com/RedApparat/Fotoapparat' - gitUrl = 'https://github.com/RedApparat/Fotoapparat.git' - - developerId = 'fotoapparat' - developerName = 'Fotoapparat' - developerEmail = 'dmitry.zaicew@gmail.com' - - licenseName = 'The Apache Software License, Version 2.0' - licenseUrl = 'http://www.apache.org/licenses/LICENSE-2.0.txt' - allLicenses = ["Apache-2.0"] -} - -group = publishedGroupId -version = libraryVersion - -install { - repositories.mavenInstaller { - pom.project { - packaging 'aar' - groupId publishedGroupId - artifactId artifact - - name libraryName - description libraryDescription - url siteUrl - - licenses { - license { - name licenseName - url licenseUrl - } - } - developers { - developer { - id developerId - name developerName - email developerEmail - } - } - scm { - connection gitUrl - developerConnection gitUrl - url siteUrl - } - } - } -} - -task sourcesJar(type: Jar) { - classifier = 'sources' - from android.sourceSets.main.java.srcDirs -} - -task javadoc(type: Javadoc) { - source = android.sourceSets.main.java.srcDirs - classpath += project.files(android.getBootClasspath().join(File.pathSeparator)) - failOnError = false -} - -task javadocJar(type: Jar, dependsOn: javadoc) { - classifier = 'javadoc' - from javadoc.destinationDir -} - -artifacts { - archives javadocJar - archives sourcesJar -} - -bintray { - user = project.properties["bintray.user"] ?: System.getenv('BINTRAY_USER') - key = project.properties["bintray.apikey"] ?: System.getenv('BINTRAY_API_KEY') - - configurations = ['archives'] - pkg { - userOrg = bintrayOrganisation - repo = bintrayRepo - name = bintrayName - desc = libraryDescription - websiteUrl = siteUrl - vcsUrl = gitUrl - licenses = allLicenses - dryRun = false - publish = true - override = false - publicDownloadNumbers = true - version { - desc = libraryDescription - } - } -} \ No newline at end of file diff --git a/fotoapparat-adapters/rxjava/README.md b/fotoapparat-adapters/rxjava/README.md deleted file mode 100644 index d021fa3c..00000000 --- a/fotoapparat-adapters/rxjava/README.md +++ /dev/null @@ -1,22 +0,0 @@ -# RxJava 1.x Adapter - -An `Adapter` for adapting RxJava 1.x types. - -Available types: - - * `Observable` - * `Single` - * `Completable` - - -## Set up - -Add dependency to your `build.gradle` - -```groovy -repositories { - maven { url 'https://jitpack.io' } -} - -compile 'io.fotoapparat.fotoapparat:adapter-rxjava:x.y.z' -``` diff --git a/fotoapparat-adapters/rxjava/build.gradle b/fotoapparat-adapters/rxjava/build.gradle deleted file mode 100644 index 88b90df9..00000000 --- a/fotoapparat-adapters/rxjava/build.gradle +++ /dev/null @@ -1,41 +0,0 @@ -apply plugin: 'com.android.library' -apply plugin: 'com.github.dcendents.android-maven' -apply plugin: 'kotlin-android' - -group = 'io.fotoapparat' - -android { - buildToolsVersion versions.android.buildTools - compileSdkVersion versions.sdk.target - - defaultConfig { - minSdkVersion versions.sdk.minimum - targetSdkVersion versions.sdk.target - } - - archivesBaseName = 'adapter-rxjava' - compileOptions { - sourceCompatibility JavaVersion.VERSION_1_8 - targetCompatibility JavaVersion.VERSION_1_8 - } -} - -dependencies { - compileOnly project(':fotoapparat') - compileOnly "io.reactivex:rxjava:${versions.rx.rxJava1}" - implementation "org.jetbrains.kotlin:kotlin-stdlib:${versions.kotlin}" - testImplementation "io.reactivex:rxjava:${versions.rx.rxJava1}" - testImplementation "junit:junit:${versions.test.junit}" -} - -ext { - bintrayName = 'adapter-rxjava' - - libraryName = 'Fotoapparat Adapters - RxJava' - artifact = 'adapter-rxjava' - libraryVersion = artifactVersion - - libraryDescription = 'RxJava1 adapter for Fotoapparat.' -} - -apply from: '../../deploy.gradle' diff --git a/fotoapparat-adapters/rxjava/src/main/AndroidManifest.xml b/fotoapparat-adapters/rxjava/src/main/AndroidManifest.xml deleted file mode 100644 index 58eec1fe..00000000 --- a/fotoapparat-adapters/rxjava/src/main/AndroidManifest.xml +++ /dev/null @@ -1,4 +0,0 @@ - - - - \ No newline at end of file diff --git a/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapter.kt b/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapter.kt deleted file mode 100644 index 0bd0198b..00000000 --- a/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapter.kt +++ /dev/null @@ -1,27 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava - -import io.fotoapparat.result.PendingResult -import rx.Completable -import java.util.concurrent.Future - -/** - * Adapter for [Completable]. - */ -object CompletableAdapter { - - /** - * @return Adapter which adapts result to [Completable]. - */ - @JvmStatic - fun toCompletable(): Function1, Completable> { - return { future -> Completable.fromFuture(future) } - } - -} - -/** - * @return A [Completable] from the given [PendingResult]. - */ -fun PendingResult.toCompletable(): Completable { - return adapt { future -> Completable.fromFuture(future) } -} diff --git a/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapter.kt b/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapter.kt deleted file mode 100644 index b1d4f6c0..00000000 --- a/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapter.kt +++ /dev/null @@ -1,27 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava - -import io.fotoapparat.result.PendingResult -import rx.Observable -import java.util.concurrent.Future - -/** - * Adapter for [Observable]. - */ -object ObservableAdapter { - - /** - * @return Adapter which adapts result to [Observable]. - */ - @JvmStatic - fun toObservable(): Function1, Observable> { - return { future -> Observable.from(future) } - } - -} - -/** - * @return A [Observable] from the given [PendingResult]. - */ -fun PendingResult.toObservable(): Observable { - return adapt { future -> Observable.from(future) } -} diff --git a/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/SingleAdapter.kt b/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/SingleAdapter.kt deleted file mode 100644 index f6bc0676..00000000 --- a/fotoapparat-adapters/rxjava/src/main/java/io/fotoapparat/result/adapter/rxjava/SingleAdapter.kt +++ /dev/null @@ -1,27 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava - -import io.fotoapparat.result.PendingResult -import rx.Single -import java.util.concurrent.Future - -/** - * Adapter for [Single]. - */ -object SingleAdapter { - - /** - * @return Adapter which adapts result to [Single]. - */ - @JvmStatic - fun toSingle(): (Future) -> Single { - return { future -> Single.from(future) } - } - -} - -/** - * @return A [Single] from the given [PendingResult]. - */ -fun PendingResult.toSingle(): Single { - return adapt { future -> Single.from(future) } -} diff --git a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapterTest.java b/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapterTest.java deleted file mode 100644 index 0347d20c..00000000 --- a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CompletableAdapterTest.java +++ /dev/null @@ -1,56 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava; - -import org.junit.Test; - -import java.util.concurrent.Callable; -import java.util.concurrent.ExecutionException; -import java.util.concurrent.Future; - -import rx.observers.TestSubscriber; - -public class CompletableAdapterTest { - - private TestSubscriber subscriber = new TestSubscriber<>(); - - @Test - public void completed() throws Exception { - // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); - - // When - CompletableAdapter.toCompletable() - .invoke(future) - .subscribe(subscriber); - - // Then - subscriber.assertNoValues(); - subscriber.assertNoErrors(); - subscriber.assertCompleted(); - } - - @Test - public void error() throws Exception { - // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } - }); - - // When - CompletableAdapter.toCompletable() - .invoke(future) - .subscribe(subscriber); - - // Then - subscriber.assertNoValues(); - subscriber.assertError(ExecutionException.class); - } - -} \ No newline at end of file diff --git a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapterTest.java b/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapterTest.java deleted file mode 100644 index 0154359f..00000000 --- a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/ObservableAdapterTest.java +++ /dev/null @@ -1,56 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava; - -import org.junit.Test; - -import java.util.concurrent.Callable; -import java.util.concurrent.ExecutionException; -import java.util.concurrent.Future; - -import rx.observers.TestSubscriber; - -public class ObservableAdapterTest { - - private TestSubscriber subscriber = new TestSubscriber<>(); - - @Test - public void completed() throws Exception { - // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); - - // When - ObservableAdapter.toObservable() - .invoke(future) - .subscribe(subscriber); - - // Then - subscriber.assertValue("Hello"); - subscriber.assertNoErrors(); - subscriber.assertCompleted(); - } - - @Test - public void error() throws Exception { - // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } - }); - - // When - ObservableAdapter.toObservable() - .invoke(future) - .subscribe(subscriber); - - // Then - subscriber.assertNoValues(); - subscriber.assertError(ExecutionException.class); - } - -} \ No newline at end of file diff --git a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/SingleAdapterTest.java b/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/SingleAdapterTest.java deleted file mode 100644 index 8f0c47d4..00000000 --- a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/SingleAdapterTest.java +++ /dev/null @@ -1,56 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava; - -import org.junit.Test; - -import java.util.concurrent.Callable; -import java.util.concurrent.ExecutionException; -import java.util.concurrent.Future; - -import rx.observers.TestSubscriber; - -public class SingleAdapterTest { - - private TestSubscriber subscriber = new TestSubscriber<>(); - - @Test - public void completed() throws Exception { - // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); - - // When - SingleAdapter.toSingle() - .invoke(future) - .subscribe(subscriber); - - // Then - subscriber.assertValue("Hello"); - subscriber.assertNoErrors(); - subscriber.assertCompleted(); - } - - @Test - public void error() throws Exception { - // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } - }); - - // When - SingleAdapter.toSingle() - .invoke(future) - .subscribe(subscriber); - - // Then - subscriber.assertNoValues(); - subscriber.assertError(ExecutionException.class); - } - -} \ No newline at end of file diff --git a/fotoapparat-adapters/rxjava2/build.gradle b/fotoapparat-adapters/rxjava2/build.gradle deleted file mode 100644 index e8bfd202..00000000 --- a/fotoapparat-adapters/rxjava2/build.gradle +++ /dev/null @@ -1,41 +0,0 @@ -apply plugin: 'com.android.library' -apply plugin: 'com.github.dcendents.android-maven' -apply plugin: 'kotlin-android' - -group = 'io.fotoapparat' - -android { - buildToolsVersion versions.android.buildTools - compileSdkVersion versions.sdk.target - - defaultConfig { - minSdkVersion versions.sdk.minimum - targetSdkVersion versions.sdk.target - } - - archivesBaseName = 'adapter-rxjava2' - compileOptions { - sourceCompatibility JavaVersion.VERSION_1_8 - targetCompatibility JavaVersion.VERSION_1_8 - } -} - -dependencies { - compileOnly project(':fotoapparat') - compileOnly "io.reactivex.rxjava2:rxjava:${versions.rx.rxJava2}" - implementation "org.jetbrains.kotlin:kotlin-stdlib:${versions.kotlin}" - testImplementation "io.reactivex.rxjava2:rxjava:${versions.rx.rxJava2}" - testImplementation "junit:junit:${versions.test.junit}" -} - -ext { - bintrayName = 'adapter-rxjava2' - - libraryName = 'Fotoapparat Adapters - RxJava2' - artifact = 'adapter-rxjava2' - libraryVersion = artifactVersion - - libraryDescription = 'RxJava2 adapter for Fotoapparat.' -} - -apply from: '../../deploy.gradle' diff --git a/fotoapparat-adapters/rxjava2/src/main/AndroidManifest.xml b/fotoapparat-adapters/rxjava2/src/main/AndroidManifest.xml deleted file mode 100644 index 65b80bfd..00000000 --- a/fotoapparat-adapters/rxjava2/src/main/AndroidManifest.xml +++ /dev/null @@ -1,4 +0,0 @@ - - - - diff --git a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CallableFuture.kt b/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CallableFuture.kt deleted file mode 100644 index 55ede2f0..00000000 --- a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CallableFuture.kt +++ /dev/null @@ -1,44 +0,0 @@ -package io.fotoapparat.result.adapter.rxjava2 - -import java.util.concurrent.* - -/** - * Simply returns the value of the callable. - */ -class CallableFuture(private val callable: Callable) : Future { - - private val latch = CountDownLatch(1) - - override fun cancel(mayInterruptIfRunning: Boolean): Boolean { - return false - } - - override fun isCancelled(): Boolean { - return false - } - - override fun isDone(): Boolean { - return latch.count == 0L - } - - @Throws(InterruptedException::class, ExecutionException::class) - override fun get(): T { - return callCallable() - } - - @Throws(InterruptedException::class, ExecutionException::class, TimeoutException::class) - override fun get(timeout: Long, unit: TimeUnit): T { - return callCallable() - } - - @Throws(ExecutionException::class) - private fun callCallable(): T { - latch.countDown() - try { - return callable.call() - } catch (e: Exception) { - throw ExecutionException(e) - } - - } -} diff --git a/fotoapparat-adapters/rxjava2/README.md b/fotoapparat-adapters/rxjava3/README.md similarity index 100% rename from fotoapparat-adapters/rxjava2/README.md rename to fotoapparat-adapters/rxjava3/README.md diff --git a/fotoapparat-adapters/rxjava3/build.gradle b/fotoapparat-adapters/rxjava3/build.gradle new file mode 100644 index 00000000..1d96f8b8 --- /dev/null +++ b/fotoapparat-adapters/rxjava3/build.gradle @@ -0,0 +1,37 @@ +apply plugin: 'com.android.library' +apply plugin: 'kotlin-android' + +group = 'io.fotoapparat' + +android { + buildToolsVersion deps.versions.buildTools.get() + compileSdkVersion deps.versions.compileSdk.get().toInteger() + defaultConfig { + minSdkVersion deps.versions.minSdk.get() + targetSdkVersion deps.versions.compileSdk.get() + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_11 + targetCompatibility JavaVersion.VERSION_11 + } + namespace = "io.fotoapparat.rxjava3" + archivesBaseName = 'adapter-rxjava3' +} + +dependencies { + compileOnly project(':fotoapparat') + compileOnly deps.rx.java + implementation deps.kotlin.stdlib + testImplementation deps.rx.java + testImplementation deps.junit +} + +ext { + bintrayName = 'adapter-rxjava2' + + libraryName = 'Fotoapparat Adapters - RxJava2' + artifact = 'adapter-rxjava2' + libraryVersion = artifactVersion + + libraryDescription = 'RxJava2 adapter for Fotoapparat.' +} diff --git a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/CompletableAdapter.kt b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/CompletableAdapter.kt similarity index 87% rename from fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/CompletableAdapter.kt rename to fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/CompletableAdapter.kt index 026fd946..841d3919 100644 --- a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/CompletableAdapter.kt +++ b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/CompletableAdapter.kt @@ -1,8 +1,8 @@ -package io.fotoapparat.result.adapter.rxjava2 +package io.fotoapparat.result.adapter.rxjava3 import android.annotation.SuppressLint import io.fotoapparat.result.PendingResult -import io.reactivex.Completable +import io.reactivex.rxjava3.core.Completable import java.util.concurrent.Future /** diff --git a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/FlowableAdapter.kt b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/FlowableAdapter.kt similarity index 70% rename from fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/FlowableAdapter.kt rename to fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/FlowableAdapter.kt index 5f028bde..4d06047d 100644 --- a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/FlowableAdapter.kt +++ b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/FlowableAdapter.kt @@ -1,8 +1,8 @@ -package io.fotoapparat.result.adapter.rxjava2 +package io.fotoapparat.result.adapter.rxjava3 import android.annotation.SuppressLint import io.fotoapparat.result.PendingResult -import io.reactivex.Flowable +import io.reactivex.rxjava3.core.Flowable import java.util.concurrent.Future /** @@ -15,7 +15,7 @@ object FlowableAdapter { */ @JvmStatic @SuppressLint("CheckResult") - fun toFlowable(): Function1, Flowable> { + fun toFlowable(): Function1, Flowable> { return { future -> Flowable.fromFuture(future) } } @@ -25,6 +25,6 @@ object FlowableAdapter { * @return A [Flowable] from the given [PendingResult]. */ @SuppressLint("CheckResult") -fun PendingResult.toFlowable(): Flowable { +fun PendingResult.toFlowable(): Flowable { return adapt { future -> Flowable.fromFuture(future) } } diff --git a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/ObservableAdapter.kt b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/ObservableAdapter.kt similarity index 70% rename from fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/ObservableAdapter.kt rename to fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/ObservableAdapter.kt index da33aa25..51427ea3 100644 --- a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/ObservableAdapter.kt +++ b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/ObservableAdapter.kt @@ -1,8 +1,8 @@ -package io.fotoapparat.result.adapter.rxjava2 +package io.fotoapparat.result.adapter.rxjava3 import android.annotation.SuppressLint import io.fotoapparat.result.PendingResult -import io.reactivex.Observable +import io.reactivex.rxjava3.core.Observable import java.util.concurrent.Future /** @@ -15,7 +15,7 @@ object ObservableAdapter { */ @JvmStatic @SuppressLint("CheckResult") - fun toObservable(): Function1, Observable> { + fun toObservable(): Function1, Observable> { return { future -> Observable.fromFuture(future) } } @@ -25,6 +25,6 @@ object ObservableAdapter { * @return A [Observable] from the given [PendingResult]. */ @SuppressLint("CheckResult") -fun PendingResult.toObservable(): Observable { +fun PendingResult.toObservable(): Observable { return adapt { future -> Observable.fromFuture(future) } } diff --git a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/SingleAdapter.kt b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/SingleAdapter.kt similarity index 69% rename from fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/SingleAdapter.kt rename to fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/SingleAdapter.kt index e9645547..b3fd5c95 100644 --- a/fotoapparat-adapters/rxjava2/src/main/java/io/fotoapparat/result/adapter/rxjava2/SingleAdapter.kt +++ b/fotoapparat-adapters/rxjava3/src/main/java/io/fotoapparat/result/adapter/rxjava3/SingleAdapter.kt @@ -1,8 +1,10 @@ -package io.fotoapparat.result.adapter.rxjava2 +@file:Suppress("unused") + +package io.fotoapparat.result.adapter.rxjava3 import android.annotation.SuppressLint import io.fotoapparat.result.PendingResult -import io.reactivex.Single +import io.reactivex.rxjava3.core.Single import java.util.concurrent.Future /** @@ -15,7 +17,7 @@ object SingleAdapter { */ @JvmStatic @SuppressLint("CheckResult") - fun toSingle(): (Future) -> Single { + fun toSingle(): (Future) -> Single { return { future -> Single.fromFuture(future) } } @@ -25,6 +27,6 @@ object SingleAdapter { * @return A [Single] from the given [PendingResult]. */ @SuppressLint("CheckResult") -fun PendingResult.toSingle(): Single { +fun PendingResult.toSingle(): Single { return adapt { future -> Single.fromFuture(future) } } diff --git a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CallableFuture.kt b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/CallableFuture.kt similarity index 95% rename from fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CallableFuture.kt rename to fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/CallableFuture.kt index cf245894..f2a6b97b 100644 --- a/fotoapparat-adapters/rxjava/src/test/java/io/fotoapparat/result/adapter/rxjava/CallableFuture.kt +++ b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/CallableFuture.kt @@ -1,4 +1,4 @@ -package io.fotoapparat.result.adapter.rxjava +package io.fotoapparat.result.adapter.rxjava3 import java.util.concurrent.* diff --git a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CompletableAdapterTest.java b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/CompletableAdapterTest.java similarity index 54% rename from fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CompletableAdapterTest.java rename to fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/CompletableAdapterTest.java index c71d961a..cffa47bd 100644 --- a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/CompletableAdapterTest.java +++ b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/CompletableAdapterTest.java @@ -1,4 +1,4 @@ -package io.fotoapparat.result.adapter.rxjava2; +package io.fotoapparat.result.adapter.rxjava3; import org.junit.Test; @@ -6,21 +6,16 @@ import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; -import io.reactivex.observers.TestObserver; +import io.reactivex.rxjava3.observers.TestObserver; public class CompletableAdapterTest { - private TestObserver observer = new TestObserver<>(); + private final TestObserver observer = new TestObserver<>(); @Test - public void completed() throws Exception { + public void completed() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); + Future future = new CallableFuture<>(() -> "Hello"); // When CompletableAdapter.toCompletable() @@ -35,11 +30,8 @@ public String call() throws Exception { @Test public void error() throws Exception { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } + Future future = new CallableFuture<>(() -> { + throw new RuntimeException("What a failure"); }); // When diff --git a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/FlowableAdapterTest.java b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/FlowableAdapterTest.java similarity index 51% rename from fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/FlowableAdapterTest.java rename to fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/FlowableAdapterTest.java index b0e91f36..94800327 100644 --- a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/FlowableAdapterTest.java +++ b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/FlowableAdapterTest.java @@ -1,4 +1,4 @@ -package io.fotoapparat.result.adapter.rxjava2; +package io.fotoapparat.result.adapter.rxjava3; import org.junit.Test; @@ -6,21 +6,16 @@ import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; -import io.reactivex.subscribers.TestSubscriber; +import io.reactivex.rxjava3.subscribers.TestSubscriber; public class FlowableAdapterTest { - private TestSubscriber observer = new TestSubscriber<>(); + private final TestSubscriber observer = new TestSubscriber<>(); @Test - public void completed() throws Exception { + public void completed() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); + Future future = new CallableFuture<>(() -> "Hello"); // When FlowableAdapter.toFlowable() @@ -33,13 +28,10 @@ public String call() throws Exception { } @Test - public void error() throws Exception { + public void error() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } + Future future = new CallableFuture<>(() -> { + throw new RuntimeException("What a failure"); }); // When diff --git a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/ObservableAdapterTest.java b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/ObservableAdapterTest.java similarity index 51% rename from fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/ObservableAdapterTest.java rename to fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/ObservableAdapterTest.java index b445be34..0c6f9479 100644 --- a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/ObservableAdapterTest.java +++ b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/ObservableAdapterTest.java @@ -1,4 +1,4 @@ -package io.fotoapparat.result.adapter.rxjava2; +package io.fotoapparat.result.adapter.rxjava3; import org.junit.Test; @@ -6,21 +6,16 @@ import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; -import io.reactivex.observers.TestObserver; +import io.reactivex.rxjava3.observers.TestObserver; public class ObservableAdapterTest { - private TestObserver observer = new TestObserver<>(); + private final TestObserver observer = new TestObserver<>(); @Test - public void completed() throws Exception { + public void completed() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); + Future future = new CallableFuture<>(() -> "Hello"); // When ObservableAdapter.toObservable() @@ -33,13 +28,10 @@ public String call() throws Exception { } @Test - public void error() throws Exception { + public void error() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } + Future future = new CallableFuture<>(() -> { + throw new RuntimeException("What a failure"); }); // When diff --git a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/SingleAdapterTest.java b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/SingleAdapterTest.java similarity index 51% rename from fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/SingleAdapterTest.java rename to fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/SingleAdapterTest.java index f5f92a50..3854f693 100644 --- a/fotoapparat-adapters/rxjava2/src/test/java/io/fotoapparat/result/adapter/rxjava2/SingleAdapterTest.java +++ b/fotoapparat-adapters/rxjava3/src/test/java/io/fotoapparat/result/adapter/rxjava3/SingleAdapterTest.java @@ -1,4 +1,4 @@ -package io.fotoapparat.result.adapter.rxjava2; +package io.fotoapparat.result.adapter.rxjava3; import org.junit.Test; @@ -6,21 +6,16 @@ import java.util.concurrent.ExecutionException; import java.util.concurrent.Future; -import io.reactivex.observers.TestObserver; +import io.reactivex.rxjava3.observers.TestObserver; public class SingleAdapterTest { - private TestObserver observer = new TestObserver<>(); + private final TestObserver observer = new TestObserver<>(); @Test - public void completed() throws Exception { + public void completed() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - return "Hello"; - } - }); + Future future = new CallableFuture<>(() -> "Hello"); // When SingleAdapter.toSingle() @@ -33,13 +28,10 @@ public String call() throws Exception { } @Test - public void error() throws Exception { + public void error() { // Given - Future future = new CallableFuture<>(new Callable() { - @Override - public String call() throws Exception { - throw new RuntimeException("What a failure"); - } + Future future = new CallableFuture<>(() -> { + throw new RuntimeException("What a failure"); }); // When diff --git a/fotoapparat/build.gradle b/fotoapparat/build.gradle index 628043e7..ad49f090 100644 --- a/fotoapparat/build.gradle +++ b/fotoapparat/build.gradle @@ -1,41 +1,42 @@ -apply plugin: 'com.android.library' -apply plugin: 'com.github.dcendents.android-maven' -apply plugin: 'kotlin-android' +plugins { + alias(deps.plugins.android.library) + alias(deps.plugins.kotlin.android) +} group = 'io.fotoapparat' android { - buildToolsVersion versions.android.buildTools - compileSdkVersion versions.sdk.target + buildToolsVersion deps.versions.buildTools.get() + compileSdkVersion deps.versions.compileSdk.get().toInteger() defaultConfig { - minSdkVersion versions.sdk.minimum - targetSdkVersion versions.sdk.target + minSdkVersion deps.versions.minSdk.get() + targetSdkVersion deps.versions.compileSdk.get() } - buildTypes { release { minifyEnabled false } } - testOptions { unitTests.returnDefaultValues = true } compileOptions { - sourceCompatibility JavaVersion.VERSION_1_8 - targetCompatibility JavaVersion.VERSION_1_8 + sourceCompatibility JavaVersion.VERSION_11 + targetCompatibility JavaVersion.VERSION_11 } + namespace = "io.fotoapparat" } dependencies { - implementation "androidx.annotation:annotation:${versions.android.annotation}" - implementation "androidx.exifinterface:exifinterface:${versions.android.exifinterface}" - implementation "org.jetbrains.kotlin:kotlin-stdlib:${versions.kotlin}" - implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.0' - testImplementation "junit:junit:${versions.test.junit}" - testImplementation "org.jetbrains.kotlin:kotlin-test-junit:${versions.kotlin}" - testImplementation "org.mockito:mockito-core:${versions.test.mockito}" + implementation deps.kotlin.stdlib + implementation deps.kotlin.coroutines + implementation deps.androidx.annotation + implementation deps.androidx.exifinterface + + testImplementation deps.junit + testImplementation deps.kotlin.test + testImplementation deps.mockito.core } ext { @@ -47,5 +48,3 @@ ext { libraryDescription = 'Camera library for Android with a more user-friendly API.' } - -apply from: '../deploy.gradle' diff --git a/fotoapparat/src/main/AndroidManifest.xml b/fotoapparat/src/main/AndroidManifest.xml index 47506d04..50116418 100644 --- a/fotoapparat/src/main/AndroidManifest.xml +++ b/fotoapparat/src/main/AndroidManifest.xml @@ -1,8 +1,7 @@ - + - + - + diff --git a/fotoapparat/src/main/java/io/fotoapparat/coroutines/AwaitBroadcastChannel.kt b/fotoapparat/src/main/java/io/fotoapparat/coroutines/AwaitBroadcastChannel.kt index f22bbaf1..4488e1d8 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/coroutines/AwaitBroadcastChannel.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/coroutines/AwaitBroadcastChannel.kt @@ -1,3 +1,5 @@ +@file:Suppress("OPT_IN_USAGE", "OPT_IN_OVERRIDE", "OVERRIDE_DEPRECATION") + package io.fotoapparat.coroutines import kotlinx.coroutines.* @@ -23,7 +25,7 @@ internal class AwaitBroadcastChannel( override fun offer(element: T): Boolean { deferred.complete(true) - return channel.offer(element) + return channel.trySend(element).isSuccess } override suspend fun send(element: T) { diff --git a/fotoapparat/src/main/java/io/fotoapparat/hardware/CameraDevice.kt b/fotoapparat/src/main/java/io/fotoapparat/hardware/CameraDevice.kt index cc07f52f..bc357ae7 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/hardware/CameraDevice.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/hardware/CameraDevice.kt @@ -1,4 +1,4 @@ -@file:Suppress("DEPRECATION") +@file:Suppress("DEPRECATION", "OPT_IN_USAGE", "RemoveRedundantQualifierName", "unused") package io.fotoapparat.hardware @@ -32,6 +32,7 @@ import java.io.IOException import java.util.concurrent.CountDownLatch import java.util.concurrent.TimeUnit import java.util.concurrent.atomic.AtomicReference +import kotlinx.coroutines.ExperimentalCoroutinesApi typealias PreviewSize = io.fotoapparat.parameter.Resolution @@ -39,11 +40,12 @@ typealias PreviewSize = io.fotoapparat.parameter.Resolution * Camera. */ internal open class CameraDevice( - private val logger: Logger, - val characteristics: Characteristics + private val logger: Logger, + val characteristics: Characteristics, ) { private val capabilities = CompletableDeferred() + @OptIn(ExperimentalCoroutinesApi::class) private val cameraParameters = AwaitBroadcastChannel() private lateinit var previewStream: PreviewStream private lateinit var surface: Surface @@ -69,8 +71,8 @@ internal open class CameraDevice( previewStream = PreviewStream(camera) } catch (e: RuntimeException) { throw CameraException( - message = "Failed to open camera with lens position: $lensPosition and id: $cameraId", - cause = e + message = "Failed to open camera with lens position: $lensPosition and id: $cameraId", + cause = e ) } } @@ -94,9 +96,9 @@ internal open class CameraDevice( camera.startPreview() } catch (e: RuntimeException) { throw CameraException( - message = "Failed to start preview for camera with lens " + - "position: ${characteristics.lensPosition} and id: ${characteristics.cameraId}", - cause = e + message = "Failed to start preview for camera with lens " + + "position: ${characteristics.lensPosition} and id: ${characteristics.cameraId}", + cause = e ) } } @@ -168,8 +170,8 @@ internal open class CameraDevice( logger.log("New camera parameters are: $cameraParameters") cameraParameters.applyInto(cachedCameraParameters ?: camera.parameters) - .cacheLocally() - .setInCamera() + .cacheLocally() + .setInCamera() } /** @@ -188,30 +190,32 @@ internal open class CameraDevice( logger.recordMethod() imageOrientation = computeImageOrientation( - deviceOrientation = orientationState.deviceOrientation, - cameraOrientation = characteristics.cameraOrientation, - cameraIsMirrored = characteristics.isMirrored + deviceOrientation = orientationState.deviceOrientation, + cameraOrientation = characteristics.cameraOrientation, + cameraIsMirrored = characteristics.isMirrored ) displayOrientation = computeDisplayOrientation( - screenOrientation = orientationState.screenOrientation, - cameraOrientation = characteristics.cameraOrientation, - cameraIsMirrored = characteristics.isMirrored + screenOrientation = orientationState.screenOrientation, + cameraOrientation = characteristics.cameraOrientation, + cameraIsMirrored = characteristics.isMirrored ) previewOrientation = computePreviewOrientation( - screenOrientation = orientationState.screenOrientation, - cameraOrientation = characteristics.cameraOrientation, - cameraIsMirrored = characteristics.isMirrored + screenOrientation = orientationState.screenOrientation, + cameraOrientation = characteristics.cameraOrientation, + cameraIsMirrored = characteristics.isMirrored ) - logger.log("Orientations: $lineSeparator" + + logger.log( + "Orientations: $lineSeparator" + "Screen orientation (preview) is: ${orientationState.screenOrientation}. " + lineSeparator + "Camera sensor orientation is always at: ${characteristics.cameraOrientation}. " + lineSeparator + "Camera is " + if (characteristics.isMirrored) "mirrored." else "not mirrored." ) - logger.log("Orientation adjustments: $lineSeparator" + + logger.log( + "Orientation adjustments: $lineSeparator" + "Image orientation will be adjusted by: ${imageOrientation.degrees} degrees. " + lineSeparator + "Display orientation will be adjusted by: ${displayOrientation.degrees} degrees. " + lineSeparator + "Preview orientation will be adjusted by: ${previewOrientation.degrees} degrees." @@ -304,11 +308,11 @@ internal open class CameraDevice( private fun setZoomUnsafe(@FloatRange(from = 0.0, to = 1.0) level: Float) { (cachedCameraParameters ?: camera.parameters) - .apply { - zoom = (maxZoom * level).toInt() - } - .cacheLocally() - .setInCamera() + .apply { + zoom = (maxZoom * level).toInt() + } + .cacheLocally() + .setInCamera() } private fun Camera.Parameters.cacheLocally() = apply { @@ -341,8 +345,8 @@ internal open class CameraDevice( private suspend fun Camera.updateFocusingAreas(focalRequest: FocalRequest) { val focusingAreas = focalRequest.toFocusAreas( - displayOrientationDegrees = displayOrientation.degrees, - cameraIsMirrored = characteristics.isMirrored + displayOrientationDegrees = displayOrientation.degrees, + cameraIsMirrored = characteristics.isMirrored ) parameters = parameters.apply { @@ -377,17 +381,16 @@ private fun Camera.takePhoto(imageRotation: Int): Photo { val photoReference = AtomicReference() takePicture( - null, - null, - null, - Camera.PictureCallback { data, _ -> - photoReference.set( - Photo(data, imageRotation) - ) - - latch.countDown() - } - ) + null, + null, + null + ) { data, _ -> + photoReference.set( + Photo(data, imageRotation) + ) + + latch.countDown() + } latch.await() @@ -396,29 +399,29 @@ private fun Camera.takePhoto(imageRotation: Int): Photo { @Throws(IOException::class) private fun Camera.setDisplaySurface( - preview: Preview + preview: Preview, ): Surface = when (preview) { is Preview.Texture -> preview.surfaceTexture - .also(this::setPreviewTexture) - .let(::Surface) + .also(this::setPreviewTexture) + .let(::Surface) is Preview.Surface -> preview.surfaceHolder - .also(this::setPreviewDisplay) - .surface + .also(this::setPreviewDisplay) + .surface } private fun Camera.getPreviewResolution(previewOrientation: Orientation): Resolution { return parameters.previewSize - .run { - PreviewSize(width, height) - } - .run { - when (previewOrientation) { - is Orientation.Vertical -> this - is Orientation.Horizontal -> flipDimensions() - } + .run { + PreviewSize(width, height) + } + .run { + when (previewOrientation) { + is Orientation.Vertical -> this + is Orientation.Horizontal -> flipDimensions() } + } } private fun Capabilities.canSetFocusingAreas(): Boolean = - maxMeteringAreas > 0 || maxFocusAreas > 0 + maxMeteringAreas > 0 || maxFocusAreas > 0 diff --git a/fotoapparat/src/main/java/io/fotoapparat/hardware/Device.kt b/fotoapparat/src/main/java/io/fotoapparat/hardware/Device.kt index 452a8930..5f289c4d 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/hardware/Device.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/hardware/Device.kt @@ -1,4 +1,4 @@ -@file:Suppress("DEPRECATION") +@file:Suppress("DEPRECATION", "unused") package io.fotoapparat.hardware @@ -19,6 +19,7 @@ import io.fotoapparat.util.FrameProcessor import io.fotoapparat.view.CameraRenderer import io.fotoapparat.view.FocalPointSelector import kotlinx.coroutines.CompletableDeferred +import kotlinx.coroutines.ExperimentalCoroutinesApi /** * Phone. @@ -93,6 +94,7 @@ internal open class Device( * @throws IllegalStateException If no camera has been yet selected. * @throws UnsupportedLensException If no camera could get selected. */ + @OptIn(ExperimentalCoroutinesApi::class) open fun getSelectedCamera(): CameraDevice = try { selectedCameraDevice.getCompleted() } catch (e: IllegalStateException) { diff --git a/fotoapparat/src/main/java/io/fotoapparat/hardware/display/Display.kt b/fotoapparat/src/main/java/io/fotoapparat/hardware/display/Display.kt index d9b2866a..4c5e295b 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/hardware/display/Display.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/hardware/display/Display.kt @@ -14,12 +14,12 @@ import io.fotoapparat.hardware.orientation.Orientation.Vertical.ReversePortrait */ internal open class Display(context: Context) { - private val display = context.getDisplay() + private val display = context.getDefaultDisplay() /** * Returns the orientation of the screen. */ - open fun getOrientation(): Orientation = when (display.rotation) { + open fun getOrientation(): Orientation = when (display?.rotation) { Surface.ROTATION_0 -> Portrait Surface.ROTATION_90 -> Landscape Surface.ROTATION_180 -> ReversePortrait @@ -29,4 +29,5 @@ internal open class Display(context: Context) { } -private fun Context.getDisplay() = (getSystemService(Context.WINDOW_SERVICE) as WindowManager).defaultDisplay +@Suppress("DEPRECATION") +private fun Context.getDefaultDisplay() = (getSystemService(Context.WINDOW_SERVICE) as WindowManager).defaultDisplay diff --git a/fotoapparat/src/main/java/io/fotoapparat/selector/PreviewFpsRangeSelectors.kt b/fotoapparat/src/main/java/io/fotoapparat/selector/PreviewFpsRangeSelectors.kt index 033307bd..c050a510 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/selector/PreviewFpsRangeSelectors.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/selector/PreviewFpsRangeSelectors.kt @@ -77,8 +77,8 @@ fun lowestFixedFps(): FpsRangeSelector = filtered( predicate = { it.isFixed } ) -private fun highestRangeFps(): FpsRangeSelector = { maxWith(CompareFpsRangeByBounds) } +private fun highestRangeFps(): FpsRangeSelector = { maxWithOrNull(CompareFpsRangeByBounds) } -private fun lowestRangeFps(): FpsRangeSelector = { minWith(CompareFpsRangeByBounds) } +private fun lowestRangeFps(): FpsRangeSelector = { minWithOrNull(CompareFpsRangeByBounds) } private fun Float.toFpsIntRepresentation() = (this * 1000).toInt() \ No newline at end of file diff --git a/fotoapparat/src/main/java/io/fotoapparat/selector/ResolutionSelectors.kt b/fotoapparat/src/main/java/io/fotoapparat/selector/ResolutionSelectors.kt index 1d534b03..665d145f 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/selector/ResolutionSelectors.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/selector/ResolutionSelectors.kt @@ -7,9 +7,9 @@ typealias ResolutionSelector = Iterable.() -> Resolution? /** * @return Selector function which always provides the biggest resolution. */ -fun highestResolution(): ResolutionSelector = { maxBy(Resolution::area) } +fun highestResolution(): ResolutionSelector = { maxByOrNull(Resolution::area) } /** * @return Selector function which always provides the smallest resolution. */ -fun lowestResolution(): ResolutionSelector = { minBy(Resolution::area) } \ No newline at end of file +fun lowestResolution(): ResolutionSelector = { minByOrNull(Resolution::area) } \ No newline at end of file diff --git a/fotoapparat/src/main/java/io/fotoapparat/selector/Selectors.kt b/fotoapparat/src/main/java/io/fotoapparat/selector/Selectors.kt index 4a197211..c3fff647 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/selector/Selectors.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/selector/Selectors.kt @@ -19,12 +19,12 @@ fun single(preference: T): Iterable.() -> T? = { /** * @return Selector function which selects highest [Comparable] value. */ -fun > highest(): Iterable.() -> T? = Iterable::max +fun > highest(): Iterable.() -> T? = Iterable::maxOrNull /** * @return Selector function which selects lowest [Comparable] value. */ -fun > lowest(): Iterable.() -> T? = Iterable::min +fun > lowest(): Iterable.() -> T? = Iterable::minOrNull /** * @param functions functions in order of importance. @@ -33,7 +33,7 @@ fun > lowest(): Iterable.() -> T? = Iterable::min */ @SafeVarargs fun firstAvailable( - vararg functions: Input.() -> Output? + vararg functions: Input.() -> Output?, ): Input.() -> Output? = { functions.findNonNull { it(this) @@ -48,17 +48,15 @@ fun firstAvailable( * condition. */ fun filtered( - selector: Iterable.() -> T?, - predicate: (T) -> Boolean + selector: Iterable.() -> T?, + predicate: (T) -> Boolean, ): Iterable.() -> T? = { selector(filter(predicate = predicate)) } private fun Array.findNonNull(selector: (T) -> R?): R? { - forEach { - selector(it)?.let { - return it - } + forEach { outer -> + selector(outer)?.let { return it } } return null diff --git a/fotoapparat/src/main/java/io/fotoapparat/util/StringExtensions.kt b/fotoapparat/src/main/java/io/fotoapparat/util/StringExtensions.kt index 96c03c05..ac645725 100644 --- a/fotoapparat/src/main/java/io/fotoapparat/util/StringExtensions.kt +++ b/fotoapparat/src/main/java/io/fotoapparat/util/StringExtensions.kt @@ -3,7 +3,7 @@ package io.fotoapparat.util /** * System line separator. */ -internal val lineSeparator = System.getProperty("line.separator") +internal val lineSeparator = System.lineSeparator() /** * Prints a [Set] in logcat in a structured way. diff --git a/fotoapparat/src/test/java/io/fotoapparat/FotoapparatBuilderTest.kt b/fotoapparat/src/test/java/io/fotoapparat/FotoapparatBuilderTest.kt index 214c6bea..e65fe1fe 100644 --- a/fotoapparat/src/test/java/io/fotoapparat/FotoapparatBuilderTest.kt +++ b/fotoapparat/src/test/java/io/fotoapparat/FotoapparatBuilderTest.kt @@ -10,7 +10,9 @@ import io.fotoapparat.parameter.ScaleType import io.fotoapparat.selector.* import io.fotoapparat.util.FrameProcessor import io.fotoapparat.view.CameraRenderer -import junit.framework.Assert.* +import kotlin.test.assertEquals +import kotlin.test.assertNotNull +import kotlin.test.assertNull import org.junit.Before import org.junit.Test import org.junit.runner.RunWith @@ -55,7 +57,7 @@ class FotoapparatBuilderTest { @Before fun setUp() { given(context.getSystemService(Context.WINDOW_SERVICE)) - .willReturn(Mockito.mock(WindowManager::class.java)) + .willReturn(Mockito.mock(WindowManager::class.java)) } @Test @@ -94,12 +96,12 @@ class FotoapparatBuilderTest { fun `lens position is configurable`() { // When val builder = builderWithMandatoryArguments() - .lensPosition(lensPositionSelector) + .lensPosition(lensPositionSelector) // Then assertEquals( - lensPositionSelector, - builder.lensPositionSelector + lensPositionSelector, + builder.lensPositionSelector ) } @@ -116,12 +118,12 @@ class FotoapparatBuilderTest { fun `logger is configurable`() { // When val builder = builderWithMandatoryArguments() - .logger(logger) + .logger(logger) // Then assertEquals( - logger, - builder.logger + logger, + builder.logger ) } @@ -138,12 +140,12 @@ class FotoapparatBuilderTest { fun `focusMode is configurable`() { // When val builder = builderWithMandatoryArguments() - .focusMode(focusModeSelector) + .focusMode(focusModeSelector) // Then assertEquals( - focusModeSelector, - builder.configuration.focusMode + focusModeSelector, + builder.configuration.focusMode ) } @@ -160,12 +162,12 @@ class FotoapparatBuilderTest { fun `previewFpsRange is configurable`() { // When val builder = builderWithMandatoryArguments() - .previewFpsRange(previewFpsRangeSelector) + .previewFpsRange(previewFpsRangeSelector) // Then assertEquals( - previewFpsRangeSelector, - builder.configuration.previewFpsRange + previewFpsRangeSelector, + builder.configuration.previewFpsRange ) } @@ -182,12 +184,12 @@ class FotoapparatBuilderTest { fun `flashMode is configurable`() { // When val builder = builderWithMandatoryArguments() - .flash(flashSelector) + .flash(flashSelector) // Then assertEquals( - flashSelector, - builder.configuration.flashMode + flashSelector, + builder.configuration.flashMode ) } @@ -205,12 +207,12 @@ class FotoapparatBuilderTest { fun `sensorSensitivity is configurable`() { // When val builder = builderWithMandatoryArguments() - .sensorSensitivity(sensorSensitivitySelector) + .sensorSensitivity(sensorSensitivitySelector) // Then assertEquals( - sensorSensitivitySelector, - builder.configuration.sensorSensitivity + sensorSensitivitySelector, + builder.configuration.sensorSensitivity ) } @@ -227,12 +229,12 @@ class FotoapparatBuilderTest { fun `jpegQuality is configurable`() { // When val builder = builderWithMandatoryArguments() - .jpegQuality(jpegQualitySelector) + .jpegQuality(jpegQualitySelector) // Then assertEquals( - jpegQualitySelector, - builder.configuration.jpegQuality + jpegQualitySelector, + builder.configuration.jpegQuality ) } @@ -249,12 +251,12 @@ class FotoapparatBuilderTest { fun `frameProcessor is configurable`() { // When val builder = builderWithMandatoryArguments() - .frameProcessor(frameProcessor) + .frameProcessor(frameProcessor) // Then assertEquals( - frameProcessor, - builder.configuration.frameProcessor + frameProcessor, + builder.configuration.frameProcessor ) } @@ -262,12 +264,12 @@ class FotoapparatBuilderTest { fun `photoResolution is configurable`() { // When val builder = builderWithMandatoryArguments() - .photoResolution(photoResolutionSelector) + .photoResolution(photoResolutionSelector) // Then assertEquals( - photoResolutionSelector, - builder.configuration.pictureResolution + photoResolutionSelector, + builder.configuration.pictureResolution ) } @@ -284,12 +286,12 @@ class FotoapparatBuilderTest { fun `previewResolution is configurable`() { // When val builder = builderWithMandatoryArguments() - .previewResolution(previewResolutionSelector) + .previewResolution(previewResolutionSelector) // Then assertEquals( - previewResolutionSelector, - builder.configuration.previewResolution + previewResolutionSelector, + builder.configuration.previewResolution ) } @@ -306,12 +308,12 @@ class FotoapparatBuilderTest { fun `previewStyle is configurable`() { // When val builder = builderWithMandatoryArguments() - .previewScaleType(ScaleType.CenterInside) + .previewScaleType(ScaleType.CenterInside) // Then assertEquals( - ScaleType.CenterInside, - builder.scaleType + ScaleType.CenterInside, + builder.scaleType ) } @@ -328,17 +330,17 @@ class FotoapparatBuilderTest { fun `cameraErrorCallback is configurable`() { // When val builder = builderWithMandatoryArguments() - .cameraErrorCallback(cameraErrorCallback) + .cameraErrorCallback(cameraErrorCallback) // Then assertEquals( - cameraErrorCallback, - builder.cameraErrorCallback + cameraErrorCallback, + builder.cameraErrorCallback ) } private fun builderWithMandatoryArguments(): FotoapparatBuilder { return FotoapparatBuilder(context) - .into(cameraRenderer) + .into(cameraRenderer) } } \ No newline at end of file diff --git a/gradle/deps.versions.toml b/gradle/deps.versions.toml new file mode 100644 index 00000000..37f722dc --- /dev/null +++ b/gradle/deps.versions.toml @@ -0,0 +1,31 @@ +[versions] +kotlin = "1.8.10" +android-plugin = "7.4.2" +buildTools = "33.0.2" +compileSdk = "33" +minSdk = "21" + +junit = "4.13.2" +mockito = "4.11.0" +appcompat = "1.6.1" +annotation = "1.6.0" +exifinterface = "1.3.6" + + +[libraries] +rx-java = { module = "io.reactivex.rxjava3:rxjava", version = "3.1.6" } +rx-kotlin = { module = "io.reactivex.rxjava3:rxkotlin", version = "3.0.1" } +androidx-annotation = { module = "androidx.annotation:annotation", version.ref = "annotation" } +androidx-exifinterface = { module = "androidx.exifinterface:exifinterface", version.ref = "exifinterface" } +androidx-appcompat = { module = "androidx.appcompat:appcompat", version.ref = "appcompat" } +kotlin-stdlib = { module = "org.jetbrains.kotlin:kotlin-stdlib", version.ref = "kotlin" } +kotlin-coroutines = { module = "org.jetbrains.kotlinx:kotlinx-coroutines-core", version = "1.6.4" } +junit = { module = "junit:junit", version.ref = "junit" } +kotlin-test = { module = "org.jetbrains.kotlin:kotlin-test-junit", version.ref = "kotlin" } +mockito-core = { module = "org.mockito:mockito-core", version.ref = "mockito" } + +[plugins] +kotlin-android = { id = "org.jetbrains.kotlin.android", version.ref = "kotlin" } +android-library = { id = "com.android.library", version.ref = "android-plugin" } +android-application = { id = "com.android.application", version.ref = "android-plugin" } + diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar index 29953ea141f55e3b8fc691d31b5ca8816d89fa87..943f0cbfa754578e88a3dae77fce6e3dea56edbf 100644 GIT binary patch delta 53411 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

McVi0MeuVBtw|#z)vQqDx=C zi=or1a@$qR=?VS{80NT8L|SW1>y|rV0r2s@NB-;Xx%wAx!1w4qRMZ?TF8f_!5KLy( zU;b0~C-FgJUO7!n1@C6`Iy1LNTB-HdK|vK-U1mFNL7uRjbaZGAsQL)o0PXs0aSgqX zaen_aASSLf!Hl(sItJJJ;vvFx&Nw1T$6<9w;@Q0tRE7f#Kz6L0jDuFpSF0E3J{lx9V5pS{h`tm8gV;6P}&z)C?a zEV8^F)xH9Xa`Y`ruc@aF*iE{!zw-*2GfZO;vp0r+=+!di(hDOUFiqTy4J$3x_$QF0 zT5W>I3^#nA7s;_(#YT(tf;s9)S{9n2WW17f?}NWO2<>C>Me$LITheImRZ#KtpfBUF zB2j`BP!sLM_i;IQ`EfWpA7ymlr0(nn#Jj3nELO{{l+<-byO_TN(9CR(Yl9@07A@@@ zmpgQzur}*UEjAOuDfnhKi8tMYg-uT{Xd@bTzPQq>R?i(iguXk#pjNh^DRcHmovcGT^Ax{6>K9L(f(Aiw%Ch+y0^Z(7S1U0+}haDpE4=2G*(v zyHTC;rznstPL@yUFTpu)5GoteiTZpmZR1^Rz|bV5L#4h z%%|J~=MIV27Zi9?*fxe+2oUan07$b-_5Db5@8cmV+Ua8q2aFJhXp zK6*zI-V#XKB12XTZ6^L1u_ZJtTJ2Fc5t?lfG6TjuyCrn=TNm#IzmFczH5$2G+*tP_ zv*1Bz(dhGk^t6-6=ZaguY_`~7U!$4viwlpDpa6mfkTL()h>cPj`$|cm@y)fkG8YHl zi+Lsr>PuN#_i%)QtHud3&?&k4FUy=0r;TDu>_NYw;c^iD*#>>4>i>fZ4W;YC>`dr9 zxzPGFIikuT|m8u#JCIhSGv8kA zsX&hCkmb$=GR-if#CocH3q8|Vw=QISNo$p3eyk{FFGr;8b+RE`;Pvz;GO4`ZYCxy& zM^(t$ayPseh@##=&;N)FSc1@15Pta-$zT#LiLk#OG9Iv|jH-_HiSN8pOBc#a6Bh7C zSn3-pW20KFS`^hZI6a7M!z#lFaiyKxiCMw4)m2p|?~{M?2lONPGE3uJid!*|uy@bX zE+u8u(LKIWzxD8>%lXOw{?7cX;8{xi8!C%lA2>9oNNOSzxiQYw=(SK16RDw^I9!T} z&Y(BTVJv_?)DekexXjET>Q%KQFfPOeMT9fh5Lw9-G*CJ-Po^Bnk8vI zY83lTWwXtU@t7 zu~RcUzHXUImp#5qKDkyMg4b?r_)cjwKgZOXpqHwQt0CMfTB?iE7Y(t+Ak~8LhJ8t= z4Gsir{QfnO0+;PROAtfm&Pi!!Ta?`)S+SzrS0dFF;gs~3ub`^M2*t&T<4^h#ZM0pQ zDRgt`59u~dg~sqS{lg|)eITFQwd$+hr+0+0{P$oEem`*6COb{<9i?Md6`pkzAQfh% zK98L(1*JyG-)8lZtD?~gP+C(`1qbxE zrNQ-gtWOKQW?6$(5A(ZVx_S)ob*gaKB2?f&_O-#ccKidbZhjS?qlegRhXxQ{llD#1 z(lFig*8rBcO&ahA=ayOGT4d76y0aE_@)X%w3xhWgr)u^yhhduw;_8+Dzl`a}W#hI) z>l`gg1~blns3xf7#Hj?`B#+MXkOE5ka&A@U*GhL@l4RPHF4lapqoxyw6ayKR_H}I~ zM;2jRIJX>sZJeV}){|xm(8>^rqk`pI}-EfW3u<+l?0_1K=Pd|c?vD6|oRaG#gs#}!E$4JTHk^v3CkL>}HL zJhMd#kGx)pDM-)d$Rp~O>Mgy;1dh{96Fog4(KI=Om~Xr-d~h0?3(Al9DDkp{#keMxPo{r zBUQbxGX6#Ies+wz(*Lmzv8#%giv5nOTM+a9R}kj`-*=dxtq9#R6d6l_D@&z}YQZX2 zumt*%`8$npbiz7Oo1-v?6Ht@gD|h9f zuTbBA{Eg+mD_;x658wQ+QhD}kCH>F$rNcN>!U_cH_ePq8O9(;$`w$+n>q+lw2(=qW z1Y(ehh|JvEIc*(N3uRDy4a-)ni*7&{iGnA=@(i{hx~^+AlbCqCQdx&P&Uyrwvi#?d zk1=|+z?mMb6Amp8Mm}QOiWUsq1ZE2zX=HMH5qCP6l~#Gh25YFXs1vQ4^fj`jW@@V?h&jJ`9JC5&AzU#<+9 zf5oit)^88_tZuwdD1I(5T=)qit(;Hm&RtjSN9P;nQ-II+ZF-+P(y%A3>0oBV!Jv^7 zlgSWAp&_vjLLmSqrGL~EU!4iLhpd=wpWP>yG#pVRC7DRz2TUr)VRN(v}K&#BHXDrl)MOj(B**r)GdX-hEI_=a;l z=n8tlWtR(@1tFI^)~yMLT44xJh@C1jA}BD4bq}m}R2gn|!_!%4pk>FLXdvcJI0#p- zy4J!cX>36#s_KV6%p*x#{aO>WaRaQ=?RKtJWZ zx6BK%YHx!hoe+<=nAg(_16H=>(vBb=xf#Yb@|m3&r)giZ4^+x-7G>Id%1#+US?YUz+zj5X)+)O_kh^tAmU`%9>~%pR)&>yr0vn=dN%4nR z+mN4+>f!J3^w0RrZ$gp)3c)eu-b~2cEzl)}QGt>+w)|GARCwsJM zSI8~wy^OuL11inRKSZRW0YQ>`&<3%c4{S$fxcEEfUScS8sCiRs8&ovS@SOHaEEXurQPC>Z#cAyk1C{IG!vZos{wPb zSB@E!rHj?lbS1)VIA+-5d3y&X2e~rs=`gpBPi7JjIx{7jtX+|Y=n4Viw)rwUlE?cv zFv0<>$l}N)BnS;G=EVTJV&gzDrco^^VKi=xKC}pF>Z4Gd$YFD-(r~=aCGqQGIvGE8 zJ-u)vCkjz&B^9jEV{~}&K$jW#8P$1qiE>dF7Cpt+%ZGL61dGnQ1&nB0;+qY-6A=YQh6VY|L=q-ZlyS!|Ml_U_chh9{hz5Op%W4Z zP_=bd7DMxUq`0SO#>FuzQmIr4OD(jGC+V6dQBYD~^8I74pyhutA?J1DW#7^I=N|C| z8(&t@3{T($4)}!)sW6220V41mwsUT~Dm5z?p5^kCxp9=qcf@V}#P9VnH}y@fz+{_B zynro}V>-k=$%`WV>AEYPpXr)-5(ldfXo+@)$cI51kU-82#_-4~wUF#?3BODNM<5;lx`*FLL~zU5_^= zFvXO58Y;uc90+SC#d42EFCn+orIWB3piys0uIM6b$Ot{9In~(=a4X&| z742ykU+c#B>$~EepxY=`{p{W6!OvPh`?Y(?C=Dc!bL!O0H<-5~^o^*rd8qr)J4N3+ z|NA{GQknmDX;VS=9ao#{V7=o?Q!Y&q`TI-t$tv8;x4#-mXn@To<{_qXKFWUio^mj3 z*2`Jyj)h>28)HqdVlXOXE_S3R(0rJ78(x$eePLs&3V~O%!!^WwPg^$39E6QukC$T@ zZA<|B1A{x+L3ao~+H~FI*m~+sX`)Vgc2A>+20wX2Hfzt>)FWb#3KX#uSMrY8#FZ_0nBTbD$SMwRqdOR@xG)+Ksi!^gUk0s*jLdga1+V9tI2>&-1Ft>VEkGuelXzneR z@Dowr9ljSKOAe7Z^)Q9)e4<`fzk-A=GmxLb1b@yF_7NtGExCvH3a)+L545+iBoJz=RgG&wu#ayT+aDDL9F-iI_r}Xrv#ZNDRI!qM$&T z^vHaNQ0XA!9O*Wpm|Qn>tb(;utyoyBs$Q5~EV3~DEygh9&(T^+!t?4?j(1#W^6k`ZS)kuhUd-_mKrlYY%oOI2 zK6w|LfluHSo&|nxVC_{j24k6YFHEU z)3Z%u9H~!6C|Bh`b9de*$ronoW}26Oq|f=q1QGwp(+B;j%s1ahFZ_!k36uZ_IJ8UhR@tn)#Q@=x zw`f=rdGAm?uqAjU&#Acuhta1JTvP3mG}X;ZLEGHf;lEU0L2`$q;w`<79TiG)FYk~( zh#l<<7^=-BQ1lc%h)|6#$5UQW;jX^5b99L5^+w+uDr^ky6K|j{95ND*wEWOA7K{lQ zZ;a#HQ4qb_LW_a}#G^DS>9JVhiC8>AR@?1m*YQ|-&1&U2Nx#XRoh&cUv=$lvJ3Oow zv^IyFUUfTde^`wrAgF{-oiXsJ%`U5@Mu|@IT3)XV*$o~|VWQVqTdylFsq*%gaDMuV zP)Dt`Yp-SSc(*k-H#aplLZoMW+5I3=TNZ>GT2jk$|CAH~MXlD}xvti%f~Nf{4P_P1 zy6VnEwVjrH&kj(utgRw(JwiR#Qnqo&1{Ve@SBTh+-ubV?p~zLX2^j`bJ#8X{97yn~ zwjB9?49Lb+cv+;bPj#MrGP50=9c>5?`<6lSvC&qu%&5ujAVeB3UZG-dL3?^??FI`B zw#UymR1??%F6`M~JmI~;t&}Jm3;1{(B#x;0H88=y%|MlnSJ3Kmh93?x(lTY^{6ww^ z;BfJ8cJRd;w6~C10>emsy)5bp;KLi?UD8E_B)x7`M!!$Ve(FzZfm_$VlI(0K*crqZ zW2Tr=v34rz^N)OIXmLdI-?nP%Vy$P!kYu{%CBQVzTD%R^9!e89w$ogSme&{cBI zK4i4rFPAOv(;gCtdl!R1l&{u;oNqaT7*(HHf*8%M1epEhm&>YCX9WQnvP`G}Xf@;} z-}|ZIZfGm1TF-+VWqB4Tf`4P`iTlnB0j@+`p(>nz0)`{cs8A)X{!ZZijJuc_wrk|m zt$G{)dL(V7nM@=%XuW{HNZ+WLaM4Zkw?fl;YJJ@mA2q?8?>703MQwH+9OKQbm)Y_S z`2s<2Qjv98EtZpD96L$*nTW~-H=D$f5Qak9;d)H`v6&wfGLQ+_LRjorUK5Bmf6b@S zQOL%%5c$(V>;9@)NwaCr;|fMTGJwHj3C)fNHW5T$-LQ+Zc9h3Kr-)hoEPr-Sws50x z=6Q+`4!Y?vW&X5WwuLvhqha>#J`M|}IIgME+o474QreNH_DSkhr}dGA;T~qQ4=^01 zr1{*Z6Ex6Yo_{jC!NXii?DdNBqFd&iK^=9*@vDmug!On;vgV4Z)w1>=3TQG5Az)1g z7_AYWMs^!Z=_G8&7V^*#af)53R_#(nkW)S6AoS+3p!~I}8X(6(ZrTO)D>OUcjr#kN^_X2Qh;Oi+z^{+8(Gz}@kiLBP;}ZBL<*vM(~YlpH^8 zyCwZ2vz>0S6>Bl@`ijH=o1E$QLs@q6E%}t3LjAs@lj{Ilba#edq@SnU45eLs+scK~ zS8nGWM}KI^`ksj|e}>OR0d8t}U2Cao$ylUC$p&xs8KO&ZCxh*SZL9Kz-lt*^$k|y- zEk2?;!r7W^wtUlkRoLU{KbQN!!D64ys*SJB%n?A`;U<7ZTinVMeC#@_NhLzRjFu6q^EA(&aO~G5L_|>d8 z&U-L_U=(=Y!Ym{E2MXcz^Vl1D)L)w5p%>_=oc$8E4;(_3XUnLZof_*mx~+7!G|7;x zvRva^@}T>x8RL&!$@!V*P|N!zsM8QMISby=5O)6FDdxCdV;q4ghe*so!0iYSE*IaI zi%cK%U?MYaBa^}w{1jwkIbV7fo;kd>pPSu*&|tY08s!Z=ue zx=??nW=2ffefF9CgJJFipto-Op~bWK;%y{c_pq^%@y4?EuU@%JAb?`CCM54ZbtVL& zCuj0BK(em<)p7W*oLBK*!Y%^%%TU-%oX_G|e;>x^fdGXvfou}2QlV#9r#Opil=kix zdI~nL9KY(Dr{{k-e<$sUUSRXAMX8q9MsM?O9Q{!Jk{Mv2QlVeefxYHu+cki7ia|1q zsxDmEy`QCBma?9W>MeRuV4F}F;M<^Ipk@C+{^WvX^mOrx_UhTkobF`z4iRDJ3E25a zZ)_{e@Ni<&oFY9jCT;0%(6AOYCd>YTY4WOz&^h?#9dI~}<_0_Xwi9|1Gaw;OLNs>; zX+wDXg+4rVJKnGcOyh8PA~a5l*l=4$syTX#fc%?wl4{eJ(iK}w)Cs*6F{AWGJUNj> z$;!cUU4rqt?lw9~O8UqJhRByOjKR|b-~d}WYHKftgy%rgtIArr^LRx0pr8DBQNad`xz!Vs}tXB{EoHxU$VtOJB0GF4JcEJ1_ubh%S_H<%qipFPPGX@!t;u}9S5NJC~5mu1*J z>lj~0g#cDiMay{TeGi)4Z4vRC@onE^O0a3CdA}a=I$h?;n={3F+C${6a5lr{jg-lK2XRyFt7zH^i0X5~}Kw%9Zvq4qX0sv!B;C*8r~K#$ig(}lV- zU)91xqn}h=XB%atnTcNKRDtxMc+A^6`3S($kkDaS%epf`-RU3_Nh-cbw9wc|sqKC{ zmF8V!3ta2Jn4|1q=CDC>Z+{d;UJBKboTG6){I{Iy|6LflzqEo8EiCM*X&G+s^c2;r zb)^bWc?WyL6JkRK7%I63+y>^W<9`+^rM)m&=h_b=6-oB^_>!4v)yq=FJj!4$Vw4@P zw-ARrfE3d!`Z{QIRg23Fvpc{2xc_vMakvooIL=!JBa|w)s~D)PgzueB8;$Sw8oR3x z53y%Sf0qf05BywSqJIP1qkx7QpvYN1+UEl5ZD-TQwJG>k&4G1-L}a+D=<|U0$ zTjh2&8UffK_Dj|S#&BmTD!(AM=1NPNzo>d~etqqbBr}E^ncb=gI|7S4XD4Vhc|^>* zLIk%n>@M_&|H7zZs{3BO+K3yw;tr=}vCrgb?`Xb$ym43f6iE*Lj6ZzBLq zj%xwNo2y=&DTVQfZ|xzM10IBGYs0c~J|(IuPO1-vqdYRvicb9Wh`t~Nkox(o4mQ{u zF`7X^a){HvZ)-f~$Z+Y*1LAnOQ7gH~@$ z7`LdX=^F@>hN2QU!d9$)-Nh@I-uUev3Z2Jd%>PE6260!eWWQDARzseqDnFk@^$R<-2w)m%NKy$$BYJ*()hd%W!3+*`H=NRA}-Rga;A zvhhlsoM`S78` zb|KV1#O5ZMO+)lgiEGK&s>oh6fN`KGRW+9u6>6o&TUq`rFQP6>E-uuvk|sCnJzK}V zrJsnuI(zm^MpzLt*ly^iuJK4-_MSyf&wym4jjKpFIK`61E%59F(0PB}AtngWtHqh@ z=%h=7&=e4ibcxljn|(T-Bzii-N_w1?R?QMPX;75?oTi5U;VK=ZuxWWxTF=0b7(E;D zvY2>eru~lz|4-EuUewP1T|AaD)*WViKc06U^i9Z?bIb2Doum*;p#Y4<)*%bUD=hj; z@SQqEnyc$pR29V|ptAIy7(}JlN7Xfa>ZIzC8oK<3I}brWz$zhO&UX@wzRWo(apuk{ zi$+a4#rswrZNG-_Kzw*A$z@o(UYi7aES$e@=Q^Mh9Zk!U);9ksB0&OO$Q`vJ3nR%&Y=J6$p`AAyp@v z3(!{AtkE>@265+t%9+`LTh)NG1Z%BT-grr3gP;U zQrYrqane5pg||#|UL4O&1IYL#h!#=Lw>}pCK>5Y|=-pc|{p4JT@BNT{WFgfECkjAJ z;)%fmG3aTwwucO=-F z?jim{EiZIhv1ip;Qs#O-6xK1)yB3g_z4rZYh&DN{j(ol`U5N1LH%eYvo4?cZ86gHWSoQr>G z&Z%PCbT~d)hzoxvrScPK?gP>MKO`>CK(oBiS4A83g6U%Kq+k^sYssQN5UiT87;T(gBY=OabXH@1{0+UTd4$r4k3AS}52f&x$2KN8Bt9q&7Pw6C-5 zDrZ?8A@&j2d24VlTMBP@Ds1gZ-jy6plZ!3yMk=)=_)(wh?~Kf%i{uDZ_U~ul zu_}~YUd>&e|4R2W?W^^=f=J2CmcbzyV8VgYz10&SGW`d<9cJO^>V%N#OgR4q+^ko^ zPU_?pqfGsNN0Q`I@)L|8D43So9&aCiHVRqrFB&rvLC6!AGSN3OGzmYkzfF8E(3OGA z875Vcqgv3i4P&Nst>>jb#P8xHpL*lSu_7=+9k4}>6h>~DTk6V|0Sr^J;<13fu< zLO*?zL{X&v$tnNLra0MxTQ|L*s(Z-{A$t%Sbysi|$cLyn>pirOZKlhi{^Om_LsrqA zP}wwckZmLMSPT|7<~w4VrCiM@Ri*3XYiV`ysHax>Q=(@uQn02w2m3gv9o%b!Up-g- zrWLf)$~3omSvN?i3<0lr46!)<8$g?`7vf@X;D`6)v6E&{CKNSTy4(m)qRDou>k!a;_ zVqKyB-)@|Y@DeN7Y+c4 z@!bi+#$x(gPs`m!F2nb@;@ow&@ptR#;#L0h{hja|UQdk+Z@9Tu?w)2NFmB}`CxNCv z?;t0EH&xn~GJn|-3_IbWXDcg~sVpr-FV-jtkD0+-(**nDhr!9bn^d0>s|~)?K(?rq z1VMD0qif>Lftklo{UU6?@A7%&#%L+7bUQ!cPD?KOZ@`jo(BbtLuG#$`Z$|R|z>>b) z?7%9UONif2!MH^0voL080&6aZU*9C=+;{Kat3;}mZ)AsZm@mrFEN-geT`E3A#RT`k z-4b=zCV9H<88Vtk1|jK&ZeyVPSzdgeA_ZNB>6L12*PZsutSsgJ7gz7tT?w$Z-FA|W zZQEF}ZKGq`PCDj_ZQHhO+qRvKjXu5ic{QF-^#^KH-J|N7^YUCg$pR$vwHj=&l$e)0 zWn(>I(pinibnbY&?yy9*OwoIowbON9-6jX$a*6E)f+}cN-ePSE*I_6u5m|$C_+S>wCR)mlB;)P5RX*j*=UW0W3p`9VVT@ zV*cC2g(BU-;ERq$y3lZp5n{6JQG zFS4a)DFd$}Eup{_o9uOG2^X#HO}0gC5-b?RBRM;|@!#!=DWNylPkoQhf0>elsCVh; zP`(R&N`oJV=#lUt|Vcu^W{MBzO{BO#SKirf1+KnG%mldnK)yVt@MeLU8OYm0}FnKNCnRVG! z7Z!&huoi)sx(wAs89kDlmSDBPA-)C%D5c;8UAT1MBs&TIga;B3zEQbY?l|VGU3Po$ zUDR=D2Y8&rLbZ`CJ}jW%&s(U!qdz*El}Uk}n+Q?xda?}ef0W7+G_s+Qy}8F+ z(yE?iUrsCw;*XOw4~}PKUt9xuYUcLQ!qcZ#E~`;o>dNm9JBg+C`dawfgpj+VQ!&EB z>gID`%}Q18JY+SJU5qQE5fEoobviF57fX7H9R9k-DCWw~G~>Cl6?Bd+EqL2=$zJSq z{$2%^I)8*z$t1potJ+XcUL{YJHT3W#_Nu!UWW_$86xDWfuqtdURE@!hl%&x1&@t7= zoVUSj;E8LC!+b%RA#~*NlloB<#R+lz^mLCP@|R~5Y`alm37Vz4d5=5xOe@vAXD!F{ znS~F_(Iq5WX#4zz7p-cXiy3#lQphA@EMcVi4g+>@U8`z7`{;A@|E;M>zcD zn(2>--pY63k7M;A3mTtU(n@_vS3wac`&IG1%O?{D*8QSR=V7E_+ban%_$zF2?8 zK)G1=#n+`hORJuAbyW)6dSNqh+rem08ym)+_~N@E{XNZF5w0UsaU6@K(p2>PzR3yf z2spB_KLz8sHK0$4SdN<*R=&d_fWcD#n-Q@)RHG6FtIDd|8NPi}S0z@(c!Tq4FP&)n!an+?y$5Gn?3!&9cIT)0+Ob_t1EL1g|9= z;Yn0cRMgFZzbxnI*OMn|tb>g z?-d_}UU7t8Apze=kR__-03j{>kx|ZY;O*dD?kD#r=15(HBXWPy9A`B=++t=TNqE;< zuwp%?@xhN9fnaD)Hfn^#Q%3}=;B+U^U)Ze{*U%P^dE%K|3t^EEF>RNnF349v{#fIo zdEbj~P)oV7Fjr5uK1sRH=$>q%iilU(kXteVqflzQDyf)X_hi({bKil7I0c{EjS<-v z^Ldb?rNRXvMIpR|g?+t_1+xo`Efe$$EyrMi1cUC~u~;T^RHd(@>gwI4F+be|ALOof z!@-JotJ#!!^K#)641;)|`dpq==_@C5PgzhNk0dOv+k+*3?g%-5@+B0S*c7jq2YKrS}Tj1|M8ysUGIJjbzlskp7PXEsX6ciZYw4^(oDt*zp0BUF{aF`L3Gm_pU zCcu4EkY>oYsj;aeM{}aS90QQPH0slCMDldCg&ht8;9@|K*+=$x6l zD{pU$d!DW1yFJF_OxG?y%z-apy`lQACgwJJ+9nz&rxkBf-@qc8vH{Lk#x9=SxtK20 zUM=>yt=0I?y3UycY)Lj7pG?)IL1wSLDi#X$D(yM>EZv6A->dXv<`>}OvO&A{{!WJ1 zkaCTe1|acqMhR>NDVov>1E8*7ZzG=-6J?Kqz%likQG9?F!lTDvHJApw^#Z+Zk9jB~ zS}MYq#&dp@(NV#YtY}194O-#PA|Z-irF$S3#8Zjj{3~GIKDRu=Elv6E2ad?@b?kGw z)wcWh^rhqSLxXtH+5FQB_zoJPN!jY>Vbv9%Q^7> zi5VoG(jTJz->C}#QKhE~_2WkZO5zR!4ba0IO&$Ml&lS_838*DiKCT5Wb&CvEqTDl+oeA6A?yx>0un;)2NHWrilg#RK@u8TQj&SAjA(5!B!&_u-a0~4 zl6wp1y@y%Ru~ns6U9Bo}T!c_CwmSXdD-d^~ow$StO_oJnU6k*%gPoeKwdoc(JWFXG zWv57&oeuwV{)eb!GL6nGJ@iR*L@iz3K(o}8vH)5;8duACO--44I_BBa38+m>eHSXT z{0LW8xl(mKP6lqpYZ_ujQNSl^KoLfK26uK|Obd>Yy0~Cig1^j|W>;u;F=OV>L&AcL z0hzx=b8|_~!?t~4>IMF3tCm&3U#rZ~TqE0{-{@BPl@*#HFF&cbyyB6)`Pi5WDjjN> z;4UIp%BH2q7Dy?RIc_N+1uURbl}JgZP@m^(XaNDRlkF$gT$N`>k^vYxa9*Zj#nAvjKAKT0`Upl@5p6a_dsm5UsC^HI(sa zm&@_z;RgQ2A+M!Mok%yNn#kH(IGsn8-fovu=j`YZM$HbYFC3TFfO80J#|@INNkPge z1Vq-9atbn>00$5LG&^y(XGANe6~0mlg|v#qda3P{^Pk`lzg&ixTdLFLo1z28E+*DU zUo^0JN<4%nPD{eap;$Mk(hQ5CrFmG*`yymsn*t!2DhzP#RO*m3(QHokJ=%o&F>F-l zLR`T&XW}}I=uwAJ0ig~l_Zueg)UR;0t%r>;1S9|H=f3sW z`2g)H+mm^12&mnwMCmEnyW}k0!+k9Yl0fr@jiq^Iry%o|=>Nw(`U@&cH{*lvh^rG8}t`WEiBR{eF8L^9i86LCt* zzLh|3y)q^{bNtjBAVm8_R-k%C{jS<$c%?;71)(6Wn4ZA8^IZIW!E#dVS&;)%wo`9` zA_tmpCnu+EMl1D&%k$~>Dbk;qhE$drq31T@{8+?Jon$OVe|1E}kW;Q9VVg1k+LmfQYyKY-<;^r!V-x&wuRO~rCxoO z`EV=Fv6}^(W=nln`=#LJIz!6S`dA7eJ+$alG4}%n7LFKcWzbh7JFAkL`GBK$GDXg0 zDQ`|$sZSNPq$PHbKhzlQ+_%%sYG+J>n!Mo2@Zjhk^G~U41F?lLrGEVVF#UpAIAwpBaF1?|6;~WRupj2m-1G>u6OB(CLKl$GA*_*?9#5x zWy?DTI&E2!qtI(a_GNb(n1Q;z77S3Kh9svk+rnqII6jxS9Dz0Llla)t805bmoi39j z(?TFn5{ot~JoRiAq?$@;VhB55H)iS%@P6GPEl}d>+ZNsO?jnVY#Qa8Ost_htw8K|GToj|Ao@qvp2V%hJf3H< zGu)T-{S3&Hqp*el*i48XXVKGQ_(ml<7@?@b${I7Uiu4>iu#1EcMKXtk5JR%Y2yqSq zEU4;(wSYqrkX(edtSaV9@RN52`GaX)00}MteHQij8iHiNht6h>d|~a5gswTo1>0^9 zm%JlAUQl6153f0eTj<7c{oc@K^Yb#*T#+TfYy+w59Dj;%^q5C2%D5j&m~}aaJ35$E zKVB^D?9!7jpY28XKG$!zHGJjUk?ukZ$QzK4EvLb2DO@RVH5-m{*v2fO<%EvRYUap> zY^r#J&mTG*`ej}>6k4~N=qhKwbKpp4>!OfLJBI@WIkTtbk8E>Ld-;=(L8Q7Lg&bK4 z1tB3bhmA{Ye~&ZeDaYN6gpw;xOax<6lkjVCKVnNLxU}W&CqgrXw5WtskvTCeuvYUN z;L~pE6h8pkqH2Ro-Q}A=gg3UiU+7L(8dT?GC!Nx^vfy^jsiw@oa&)h_dTE!#9og*j z=`xJ9A}1IYNJ6djSh#azbZJMI?+8m0w2L8ZPr2V3%GezHYg55OdTxf%b&qrZ(p7j( zYAa~*Y@|^13Cnd6wGC6jF!vwE%3n|LF|3A%wCNDZ874vk9nD%kAl}q;i=fLJE_BBL7jAB#^3$OGl^-shm7WC92|Y~-{p3})@JR;bdR|bEE5awr{(w3R zy4ArK9YQ@TRQ5M?BwStxIpCxJ(?6|}&Cg4I;Q)(}ko2H&Esd}zHdKrR>~?bvE687v zXE}mhqa-HF|FE2@?hw-PBPDy(?*oNqg1#%AXQ#?P-)(yn(2!7>3!7F5Kv1{OM~d=3{?s zfk!XUf4N8Oe@{Sw#C-+=pp>1Hv!RWRh=r-K_5Y7hB`5v2t}gvkYCZdf z>t;QD`=8?e6ZBWVF_s_{CaMKOF+E_!UqyaMBNV84aC_b57pc4&ZML&xl{ z)1;*)ZVYYCT(It+HhcvenB7x&t$1j)wyyO$E8AI1c8g?!8Y4!1wl8+K?I%7%!m=jn zE|=7go?Gmdd-LUBt4V7Of9T7=(b$+E^WdZ{qUZ~Y%W8ZYW>uGr1D8_=ZFl>(mP(yw zn?EbD)gKSr>Pu@{5)N#%b6AQ5F^QW}99Js(7UV`>!th zT%9p%hG8eLH&{x|?5&9GZ;ES4{i>Ah#lO?@lX@9-8b}ByeFVio)kc575k}KnXa=l| zKxFd^joWEg)asSU;xwy`HU`se3K&G97#-l$WTp*~15qiIDB#HCwnp&rY2lnOolOoP z>?Ur*h__#!&Ajy2Y(vif8ZS{S#}{+Z2r=mW#6I^k!?p|^`FVVV;4Dn7?Jv&K_Zt3+ zLF*g%tyxa595u;fgQ0F=2T|#u$^^H5L?s*_O@t6qqqb(Q!FiOybNryK{8vzJTlVz2s+pr4@c-|YPW3o{E^yXXV z=846g3p@8&oAz1L{M;=D!o?psrR4PSRp8uK#bJ_e)*t5QG=gPe{gFWkCp0*TN}GZc zsGC2)Gm{7_#6%Uix^~z9#E*X%q9)I|w0+J?17uSoJag3=fmk+wJdTq<+5XQ$By$b`{B{i#BxG6<+JyXS@@GErPv{W8pkn`y zE;5GkF*?T+c(R3!h?VZ<>Sn;oc8ha;bs3pKg++6lwzXUJnwGWp<%+7UYR}(xdoyM! z0?==M$v-|f^yXi=PP3gJpMhRClm%R$HMy?$8kR7{*p$F&cT0++LTE`AMLo*5@*qlU z-eIxNNXXBl({g6F1Xdw|+^JGYr;6NC$N1cu)ANO?xwbV0<95-NR4bj6!`}ki)95&} zkBg!;kBfY~GU8^Fi+COxm3O=X;2sURrw^b4%eTTFx@6NvmcoN)MCxzu;UlHvk4geQ z38~|IquxLrz}Ihq)ms?C)rl$T_-|*;wh4v9_L`81 zRd&$&K$yYImYIZlaa5hfgY@p%m8GAxoIl5+)%|Pn8pGW zGNzeeva&|iII-28Il5r%WF!c&-$Wbiq6#pH zkR!5eDMB%wpOyO`=9PO<6K6Fs)3<2*I}uw z@}xW!J2n{TB5~;-W(20@w=VTC(U!gHtu~ zjl;~^%TWwQ#wZmK*>_2m9YBe>fMU{C1f7a`V}k`OyI5>B8jzF57$NI0wjW7Fmdman zUMW}(+38^+iBjP|hV~4sez7XlaT4>`1y0!L+T&EaGRtXI-z6mvR~mIQ=Y-*;6l1iJ zO8Vw4u1AUH7*Dx`w-p^9mpcrV1feF6!08gPocK9tWJYgPRQ+9!=>TGBP$*?Hdj3h+ zXOFWwm@h*X`8?M^Qz$BwKeRSnaQN-S8Db3A(GeljB3SL-(2ult+?s)`ykI-f&#zHN zu6*I{pXC0~>@1ia1Z@zzevw3}x0rAk0QbgqthU%AOLDu}*iRgwher$*vPOo^coo zlOSK~lqChA=E*oi$Y>|Mln$8A@})irN1K6k6^D_aU+1P3u>kfUY5hJ3`h8gkR}DT| z;xc8EoZtM*LNyDj8t|2gIex+tYy1#ycF|SS{-uKfn_7V?E^Nn%Ad{HEcNw%iYzHjl zCSIt|(Bn`}Ie$dst6tPUSIs8KgLHWZ>n>U(_7p9hT`1<(l}$ZclKF7yi0B0!p;URA zD5<@02G=cLGzB`hkLWLYaOl@QtiC}++b8{lE_%}K=ik(Nz}e11^L$#6I^|9`-*A5s ztBa6@kEkxAQ)M}SQvhMpN!-{e!-POO?g_qIW_I^)E zdOH6@E_yBpvpRMkHOOlBI(SNI zJ6&0GeAO`48#0Zd!1-7T|CyJ&FC4<9HxS=A%cpuaj8$xC;*4d!vpU!$;1uGyGwycH z!{8@sHW0DDXscdoqQoI`;-KF>b8*EW6XdidM+c2If(>LV#=1bMD$(i712U_Rjvw=1V0WjF7N|c5=r!KNRy+DJpRS=<|2Npas zL9AX@7+%_iM)}!cB^7Ya%~I3_%G__IN{5g>_lDd9@}wxxvr=lL#%X1Ci3Qyup{V+3 zzI!1$aF&8r^xpwRE{tYI{;ix*RTr~$D}7*iO%*;+sa&8^1U2!EikLF!Us?30m6vpj@&t0xxMitY0=8 z@9K&nDbV&#l#1%@R4f`;`#?Cvq{Yj{0t|^zJWO@|Che`d%XRh*{#*5+|5}^2W4M~i z-8%tXd}H&)C$BcfE?(6B44JWyAl*IaHK*e(a$R^MOz8Yu{?Pksn*A5>Cx>?p+Zqxr z5cT(>Mcv1*8wz8+tq46J~$11I|#@W(JPvpeMUXHrikMa;s z9lAo)TXtGt&4j8t%&(rN19@Uxm>9;9__b64qYXTZT$I1FALIX+!9avp_f$4qJn1jJ z*3)~*IgLxuuR&;Cw38z2Ut+aPqX)=k0C@F2jG zA?h(KI5+ok3XZT=MeXvcRBxMIJi@nli@CMoWvm$C*5V$TL=U8*+_e{x_vz{5t;^@Z z8jCx`@y&+SpLQwGF;=;Z#v*SjTq{KkwcR7Gj}kqV9H-}=)?v%;3$0I^wt(itEWa)G zO>CPM2Ucra<+9-}V6C9)t3?1;RK6{)xq#*m%NQg4ziv4^*gZd1T>2A5=u(~M$P{5(mDVj)jMMAnO~IU7VN+q=1?wLmzp7_B$ijb!-8B`d+mSb*(~>eqyVjL|SGx`YX#O zP{mS$k8fl;aiKIEQjFMq@#wXMC|cJxcg6WQG?~b@_Lz%a(*;*7L)a%s1TgeWu5@p2 z`2ZYuT%P{71mV}{^IYlOl<_i!f)+j9Z~zxE8DhIeB3e6z6KuM2CvaayIo!~l8`*RR zk^uJEB6-Wl6o%r7%}d8WqrCwZ@2Nw$#^B%@%zDC3Wm%Eup;`v>UUo4y(o{7h!AE$q zpTsQ!7q<~OHIZJXv|h#E17^7$_nEpM-#HQ=%J2|RfekPhk_(Nu5DiL`T%p0)LRKY1 zGwbJ#lh5N^wFF~W28z34jkDbaY2q>!-XdtgN2cqly}Q(9Hh72zE??n}Z#n7At0P2V zBU8iUlKwX3ps{R9PZyrwIgYk#wBG>xs>AyosFrSB27>7#G1zMkIYW^sUy`jNEJ^?~ zS9;DeZ%NHtJ zq$fBfPXlOAmHvHtLx!7tsh?Hm9fYds2PW&RX-jvWLs+mwd+tbb7%o$@rrV7qrrPz} zak%b8@V%C_KJ9lhoeWO7fTKPu8^{sL+0a}TOTpKG1OLnyo=Nn?mCj|mvB=dxxqDjN zgSzE^l#tpdL-N)LQ*oKj#;4MHT3iq;i0FAhxg(~$%t;Zu5rSuWo*%`HHuq_t!MEM? zMw>;Kkb=17yZs6NI8TbhnDabSc>%D}?P0T3hL+eOxSNz&Jdo?{I2~CUa(u}{aiNT8 zLV%~RzYT9FZU`0r)1dqL(LleG~-ub_NFmueE10O|xIR<_xbtFCq?C7qs#5R!Q9k#j=|p8Y9#iKqt}wbyy8JOcMJlK=*Of~{*k7O-h%r8N z1>{MFJBU0_ihb5P`!cog#s>$PR1$26=s~Eq&ujKOX#cU#Caq6yxMF4tQ&N?K(AVOT z_nUrO#;0!myzVoW@v`KDv6gmnV(Tjnbu*f5)eCLuY;Wkr0;fuXs0D zw5+44EA=F33mqlRskU^z@2qPY{DG}l4XA0HhzkablgW!7E!S63hJF7yKTzUVnu>wH zl_{28eSRHxmdOfNh6Ni7Ls2rA>om_$&}qr_L?xFR@I^v&K1$;cUl{y|ltXsDWYS!l zAF67UL<#aRX?5BRhN zzxFt?0^EzEGa?`Y3lnU7d*2Efn7008)zg7$>_*X9tn;I@A?FYwH$Q|aQ z(3msf!1;cajQOGkxGy~I>3rcM7Mh=lrkMIa$NHeWqn+ML@$=Xh7IN_9n9I*{naQ9* zp=g3p#6eMI@SU2gpBMu931^9~KEQ~a7ULffk2Ldy1BUfB9PKa9^RFch0kKa?PdIjG zg~xI`A7v%us&$}x3}wNy`|ruo-Oe4^-Ri_%qz_BiCCNTb9p$kz76~u!dRmJz@Wdt$ z&2>-QYjc|-=Ip`Vp%&hPv>Nsjl6|XdBGH-g=)*&}IL~t?nO79N2i|K6gut783hXr! z0+@rKxpxa%D&K;=Dgth8gRq*=ne%+77vW6dqN+*D!i!q5i#o%$;E{YEv=v{tXD`sx z<3x=+R-#vBn0c1Ev)Q_T7}O+#1@0G0=}m3@Uq-4gjPpNS?#GN}e6hd2@P!}2_b$YK zyubKe$V?Pw`(2u4KwHh0#Q|wSyUqKn154&+LF5TJt0AxTK>@_vfxh7H1izja?ECuR zJGgUllnsDXk^Z47jD-;5?_PTT-ALtkZklzg3A1iLy?w9=4@<=hk8!&5=B?l@gLVqb zu~3QHoG|0*Hp0j=Lm`Ep8JFr=4zS%5({Pjxu1Zfj%Zfv_E+=9Bc_6GhNxeWnmJt{(WRW`nro>AM9FK4l_wlmvUMsP)cH*j z{8nY`xHxJlV=rT5bi$f2>%DjI0~;nP4IVk_yrRYDFQHmEe(`ogQ+A0p-uC$I%s^;E zt9{4og?PaJDj4HB8UXevmEA_5bkkVh)4Vq_x2L&rw(pdJMt=_|?|{eizEvu9K)55_ z_|mm^#Bv`!B694}2`I#Q`L&EA8%-z&<-4k&9KM$PhK^YCjS%UMQ`h5;S0JO9fqW;t zDf}r+xsG=GoUklY9;a4u5qb?$o$4xS<9waJPn_!s^NR3?>mI1;aFxPLqE7(&CfQ-P z*A;CPM++e;of`}0i}|iww&ZH+wCs6=SMb;H+2@ERt3(n*EK34*U2JkquK6lo^{NnX zRm#4SKkpEcuaJLpfZUWQF<m_Xy%^)z z!-3x-ahTmjp8?j+;CxxVOT0^VW_*`BOb1IQ71lKW&iD$ca&qZM8dx-p5MG# zB#AEQdqQTMg$GY>GH3M+{YCoNCGz&Sm{*m|BsMJC;D!E+!$)*0jLF|}-hxBAJ%oA9 z_4gv^%c`ZQM=;GE{hHH}i=QJ6ih}xIrcx^9#VV{$$&9YHy7J-%} zc8sk)u>4AuPC6M%$O{_62ALHPxn-WMjlgAyim-Dnn?f^O?}RtOAshPQ88nlK-D~Z# zZr#f}lMUE6y@MxhPE=blp5?X)J({^ZY<&sJ{pME%hW~<3DQS+iXGdy;4@d9t)Zg}s z=XmW>WCFx{Ye@3WGg+nP*I2Dl_J$&q+Qz2bf#D~0H_4b4q&(qjd~=|L$;1n~r5Y*; zWLisqR*Vwz2(zm?WqK7vD(bxLuR|q-^Gy~z+J%4Og)cSw{@?z@XPHV+%>SD-I7cx^ zi}|NVyZKjr$N66vdPbfCsJJOT_@CT~Phh*{x-H(K`q!g@l>x-+3GtjZ`pLoE z$H#HZzSK3hw^6j^jvVJ?F6%~E%*}jSr6%p!W1L2}2nCX5+i|U00b1HQRs=xXK&`dPK1j_-1zeQ9~AUgB(9rtT3HHs8u=V!HUn;{~+0byP6 z;_nS6AJEy#p>q7{-Vn4ky!|va{QbU+DzkHV4K57{7VvNfC}2sNXLC@9AQTIS>EVyU zkw%1r+iV~nx-#g5hTA{{h0LR7>@ydf4lrzSU-He}akpODI6xE*PYADvPema0Lh{@H z0NC^PTX=r{`;?(Y_>cJdKSsM5dHBS=SqNaV+Bpz+8J*7=PRH{kp8aD+5@#||lEo-x=v*G!8W!-OB>j@|r-WQ70@nLxcj^AJo5gsX z{kK1Z{U0x5OI~1k zm^*J2d(~}3e+qWMumVpMQqBE68^MaG4q_qhF5IE^t1H&7VJK%0?!e2yD}N5uA&PI` zN+OBf?L#@^`yDIdY?!;+kP|U4;m8kPtby3IH*f;IBS8VPOG*+wn0-@redzsVBt6)D zmuH~JP$sBd=EB2oOC2_V$n<(jg*6bgD5`{dL_>;QZWyiZ@6}cMU3vI%aC`Xr@p$^x z(EZk@joEvZ-`JArTSXSlxE2%JKcwuS%G4r`X1)33J2}4DclqhGa zWfm<04s)4d8&cEQ^hfpxlNI<-1#2bNCwtWh`9Xefql8vqn?zyiluWlU*BrwxWZBW) zU6od%qcXBwV59~5u1l#rz8PYrt6@F!T{w4riaJdWztEyT zQ4p8RjQ;opdMy<zdkT&Q58i!oy3Eo)WA5gX)bb(wZ+pI-f(%M@R^!JtqoPB&0@w=9w z+5>)QO2^!=TxrQed}z$Ou%J*TfFTOvd}}XTS5WT0E;RG+C2&_IsZFc$JS-I78UEfr z2C4L*RFaha*F%7zX zhS$oVUPE2M*1;NCCS}X!w0XMXv85gJP{q$|%P*0>912sSyw-YdYwHv(wU(|c+{J4p z;)-)M=j00Z3M=%@hz=K)fqH?wrt!A$iXa?2saMKUUE{X1(_)}pww<|s@+~oYnMPNM z6x+nH1G6+ars{NAweI|*bqx34f^GN{7B0KA&6Ja_gXiHkS_I$zn^fVU5Lb+|9Qm?nxD$D#E=aVFA#E=CT(2(9a^BYx64knr1sUwHQonF9P!3Vq|t`nChYU&`q94i(j zmrRH3kf^erA_fpnwa@=#*GUA?@-pk-JJ#9<$$Muu-CfVzYjw8T2FtD0GEeR|hMClyj*hS% z#B;oBwb4GU*1?cs88aEZOACJNs7;^FbI^{?%k6B4nFSQXEAX0U>WF@u5A1XV1^tt+ z35&wo>o)0)g>2_+BGI-wuUzD|q+rpNYbJAaSZHqE1wowC7M|jMPvL#Tlc~V7`N>L< zcSod!ECwkAj8-f7!_Mo+;%CehwWk5MBvueSEbnE2s?Fl!svVA>H(Tv3YQ*GBH+m0Na+~ z^UpDW_gcMde&W4kBx#+a$2A|n zpWk7A%O%Pl8RHRw`AHQM3bgF!K^u?XzvM1I^I=%IODb@*^5#Z3LKlj#-W zkX6{D2jx4Ni|jPKc!a>G2{2|-EOFy0!Se)s&fY?GNqo4UN*0}BcsBlYA9YTcduN~P zJ)%^CwBlTIDT+ArbOi&Gi63-Uli+tGAuQOuCyrQ+y8*$OozvxyrkD2di$g?Zf9T94 zg8~*HvT!QA+LFz$GRb%$Ch~=PP-ez+e<0IwUSWrQ+!?rYs z=RZDngox^MZl6?{#&F(Rk}kQp+d`pCVXm8c6>GL#n(Vv>g;2+hp)sMx2fq+E&Rd4m zK@eY{H^!N~q)Ii|$0eK|odx_UR};U!Wq_)1Y;!M)BYAjWNx7ofu8Q)=6Zwu>-7XN_ z?r5>d;y=9Vuh0@j2{E1SxOB9LKQWP!Q_~Q1d3d>Jm9a4XsE`N;CD;?A{rv&B3?Fmw zInh2 z`NfFsr+{M&LglV3zXMFzND8n7XMr&Tvk+X0<>KlA40oa3{ZOHkeC2u47*gV+KZrn^ z{2kvGQ0d!++vnx3AAwlZMlnygVvLp%fbM_t`rDhB+sD?<*ENQO8@W^Xa4Ex81h$lo z1v`eP#gKv&6#g*fpZRl9b7_G~H}5&X5N9UMk8-JzY7f6v%@WARYnt{hYiBIhirJLh zM4zY$4d^ag56Qxe)}u5v0e>&0{ek5v+s5Wntke-6N5$t4m1` zV8`uFpJRzJOb0%CtULiI7OqU}L^!g4$C#ZbbF;FN&db_Wl)8;SN#?p7Ferz65Nbt|=x7PwJbuLW6GN%b#Y> z&NqU;q*-9Ti>LX*u-L8i*aX#8+-$j;nNG5EEdkgj_sn#M zxaye$3TfC4qz%i*_DD73s!3oagye_eZ7SNrlOh1#baNk9FM;N?+V^lYucE`Hud>6Z zZN&$$-oWw$TJP!uTyNSr4G&ij&E6YAoB*2!G|=@ZGG@EFl~kjwip8O|1OeMf21 z+>3-E{Y4+u$_*-D0Cr!^-V6sFq^-SwW9HDP4}lxQuhA$T)uy+jMa<$-mh0GG6!UtE z_!E_Md_vL5Z1)X!>n+(=3H!G_O)7`+wiR-hW=f!I%~%XR?5zoak=7t1Rp>i1(>wF; z&@&}d0#}VaZ}e9d^1cVCdwux5_I%$6V@z{4i&KR$^?-XgfMHBPVeJdS&<%Z2X2S{_ z1Q5AE1@^~dUaB$v`WvJxsWmkgGl z+$^BMGcz67$Mq?^REzaHJnKk(g1QNbZ48IxjOY(t^XAnAm#24>Z?HZeLp?&mgz*@0 zjPIxHC1WPi&<2Q?q(MmMS=Z@FWa)EuY`tgn;*$ z&@yF*J3?7rgOb(l6n&!*NA=Fn|8d-5`lo7Q{4>}6g8Hu#d2bFfF=`GK7@ef6{LgtE zGAnGkfpX^dhK7u`ktZtj3nX$5qgu^Ds}I{gEolVB29-j}bY%A^cxKIU1QzHgFmY#t zlDBPV-o<6!c-nQtzrOf5yQ|*|VgUXuj1)o%$_wAuNE9^?@*@*utzhz$)x>fQV-I|q zhxKY94wZ;O(BDsEk#2JdSOL&xaRx0cb~?Bl4c7*P-nA?Im$HBs2KwT*jtaXo^ZC2Ko(nWpRcLnShb8KkgCdA`P&mdj<(ndr0$5-ONdo_zn3hD%*!5gda49}lL%XAx3u_2Eb3I{=nib*b< z4FCOXCcc<4mAE&W_Jc47S@xl@Sb?g_z%bi0MIPd)ep_p=~R~P zhNongdMc<6e5^R@e=+a}J1`c)Xd{Y@JMn+jK!RqI@ew?$I_t-#594< znKdIy4uEMM1Vq&lUFyVrc*h}Qn1Hcm`UoZvjDgWh`hk!C7D{;|0>LoBWNYUqqDB-w z3HYfQ$45UV!Y>&I?h&2A;UhT08z;fprx&+h3pd8Wk7h7D5o|})7<{KZDs~I~8nZIjqF)uy4o&Vt1#J?Vojz4Jc?6Dc*?-r2sO7dVBQXOjp zh!CjafVVI^9>r1W!M9e}wTcdydX;$?kmytWAlS9ajF^yC;Sc=ZT{!}wuX|sg9$?D5 zSOb~v-Yhp=!RGex`?kFNeYvfnw+IBg<42GluAD(`cdtmm9sB_=ciw^AP!V^A*c;=W zLS8S?kq?pAAC=Bg9I><-!PIJ=8RnGk&;3XQK+{08w0#j~f&-Obf?0Y)<7 zEtkd?ZR=T!^}FXJTkQ3_W|Rx|^!2W4(`#F;k~|p=4Tw5Nk&4B@U-DO*jCIQ*I={qa zfwtR>UH280p~`{VC?_|P&+w%Xo*z84$b3oCZ80H|l z@O%vU>-GOYgY@T~1Aa|4{eul7ld-0MZ4``~9&&hWmMlDGQ8F4Urdo&BhbinC^P4Xk zS}`-t_HH9`0i_0(Erw?2zYfzZ>);ZWJ6pxC+)bOEo4*_p`Ls?aB=2?|?t z!cjMqZbL|%vavnj+NL)7&JsH}{!a7v-!?n1WzubnQo37|gZaOdGA6q2ezNP>+gzQ0 zKI0N}LerxdYzr+nigHsfSJvpKfekJ)L)3YihbFd#v2aQQ4n*Wl{Mmxg58~dpvx*o! z6~FxOTB=XT)_Fs>P9XxV4jayFj#J*wD?89TYbA`6mibR-FfCOG7h%#H<*L^qsoUwK zEaiKxXJn=j^tp&-dW!{h4U+O)C87S9c`)-!NJ(hgYq_?@&!Sq7V@pdH0o#^ z!6W19j)0gL>1Wj@(DN|9=IvX$HB?W+=sb5GDA(%mvLB#8JEc1@?{FO7@sn@i6?Tdz zBYbJeHf}NLy?7=iiiXF9&xNrvsmUr!iN|ggE!wgYX^n2utq~P(Y<)vZ{o)ztoZ{kx z^fUGOXae-^Gi9d!4l680;2oQHc2Jb(g?nMjs;W2Gu8JeAo%$UhMP+2ZbRCtZXBuzU z&?qrAEo1HsLI#~e)qAynt@glcs$|FNNC^#mJO0+Ezl}#wg3@4i@86 z=2LpO*5esB>Q^c*;Ia=J1DF}n>A1OW@_Q4oJ+ZTO&nky;r;Xk_c%%C1&q5xFj15$| zqx{qy(O3CI2P)tF<4{HfR6k+O$!yM;NDF94yx_b@8f11)izN63T_NeXMI7Ye;n-wQ0!|V_X8#-QXIl> z`!;i;MX@UCvr9gOENd?7IyB(4yK$7pdbfF?OaA-Xn~<{6=JvANx0Uxixi#3uw#Pn0 zGi0LR)@zg#n4Q?uzWQrJ#?00yD>&$^IjywDIJXccp)Kv3U^-tQ1V*b4JG*H^xRS|*sS0zR`&?6B@)DQ#lDw&BzOg51MK{L<&9KMAg5YFQBFY(mUPA$Rql85? zBcx?33_tCcf-Nb+Qic-|Tv>{oCgfm&!?qX~3)5x`e00G|HRAD6Jw?hP&$DJy`H2@w zXA!=JCj4UD4`&rRAic*lgzA$w3U2S;X4lh2%x2h>lmcP_1W%3c9no(pDn z8Z6_?4?^qfB-+f{4>LGB&E8nmvb=+A{=d4e1scjMjt>%x^&YQgFf(4`*@IPLYbtF> zCAB>~PLc?D_Oj~CenoX6+HN)^qOUqih}AlJ=pi~np-hnzm5!_)PPJ`%*#9>#-!;4U zobP-y-~4|6$G!J|XXd-#z5fG!92N($&%_E;c2!tv_6+KL@NK!7^L$kMXK_U;X-rm{7Ov*E zzA-P*I=C0^)~b{FyX{Zf~80Nn(oa^ zcZiC#9=LBsK zjZ^yh!VPKse-<|@J2Qk;ve-YM*Jrf- zS=0HuIj&V(Iks%ks;-awn^ZU=75&A}AHRF``jcf*g=g#zZMBSj@x@w+J99XDcC$XG z@xIo%5d$Me&6$5$@VT>;@~kW(`EUG*hy4ZiFQQFS9?tVMQ5`liHE1*+K2@zzdL>)P zGP3iq6m0orPTl0PrA|KuSc^YljEmL1xi7xAE zCKyM&>|IdbWN_kQiSuUfknUh!$~N2M&lye)8Bs2lRjULaOw%GBGs~>YFJ*)cogD28 zJYV7$r%@M@WOvPfVAyMU|It*h;uxo)j-erL|E=9)g=5Og{FIapRmNw`7{7hi^oHMr z(xS_FC7@pVd#?~U`7Buon}_50%@=<3nhStAaKO3*c_9fD(#%#?p;DKz;hvPVQ1Xt! zYbueMR1^TLG-aPNC_udwAkB0p$C)0!Gg*}a3{gK;9VeQycTlw57CZ?xW-#pK0vQaF zU@IXd4JHz{PDXvLMz%C}dm5b+T>v`+4j#tI)I^+idx-<{_}E8Zz+8!KPTP~h5)vYk zoD#y4!Zt@hwl$|XI43(NB*nw!Et?{e<<>LpbmUSfC%m<=d~V^fn`AYD4zzP7k;E1) zRM9?@ZmnofP4#N1%wh0ywpBr7D53j13F zXPZ!8p)aU8)LVT8MO&e%JY@_xlSG^qD!xCTuHfzFxB7md;0@I5LJWHg{uO}&=Lhz5 zJUrH9+zAzAqsL%)VfZZ$VtmO14jq5aOX(>I^4|jox20sd82^2jB^|#nR5|P{;2Qvs z%Rk`;cs|&Y1-dVvrFeS;c-WQ8O~yg>^O1(D_oq>|CAuOZto<0VA3jf??j zl5p?=5_h^};orpJ1xv_`(b|I0i5py$_ehh9t<#UF*y;&~YtFJ@JlsuP8{3Giy9E@6 zXrjkvXB0ZvJy$Z+@ToM9l0pphsDC0TCiA`Z&(IHJ06NP2=Gi~-fB%ZR=foa1jt^9D7;QD=Zo>e zRtu^__B+!%LJx&leE&{n$679**hp-6MA z6xZEO>>b$3M@&X*DahcWCvB>fCokHlPYziJeULyYIKV@9iI5b*roUR(I8{ zd%Dj#q5EKWtzZyJvS8q7Nk8Dw6L3&b(Lg|c{saL55eDhS9G4XNFVaj9l1Dcg8)(Tq z!^SzozH`2F{sHp;?Lh?pZ;6AmB_r7Xo=aFq|M9;PCV~IJ|35O4aLLnhK!AWSCjE8f z0CYVTC6NAMOlp{j{TzYj5;Bn@a%bQuNlpze{Y^}^2aY3J4qZa^yn#HXLNlr7-8=Wu z?RU_^=x1+;r=xIwZu>#|&iD?VlTy8hn|*Rrt-;#F`ryaPdvAyc_<-zz`2QpcW);4Y z&>6{&ek1aB;s|%~sMKi-%HJk~1ILXr8^LQ-}R z=v(nls{Qm^8n>ZZ&wKLN4%D8wH&mXOH^>||&B3~>!3JPCT*qBedT3p7h(CW*ArRXh zX!eJ-56*pQ`MSU1EJu2(-y#c?%J|3?yEaWhe8ULz=chTxko=+j(@MASq1JEts@ISC znh4VA731R-Ln*<4N}C#82cY@JIFu_ANE(!5wQ3w(4x4dhu+Vx7*rdCwmBluAEg9@9 zW9lwFVDtOg5m#d8a@8qgHy=mdBH{1o5-3o;V(dmN^;ly4%WF$C{z!UH`?X`LuHWdt z*;Oy}HIE;)YFM~FK5{X$LbphtYTbBcT^YAZxKGl?+BV6-$ZnuH3y3~IpVqp3WZO6e zQOIs((HRs|W}_UI)MC!mY3Y&oWjUkEa^3F?!W-*XNcBuzt7R1|VEV|kE95-4R5Ws~ z@GR(ntmJzQb8VbVsZ3_PE{-S*vHnV5tq4P0{cvU!398Ga+My{dJQ?~j!m`6*w@2bG zuaFNhm|D>4GT#{s1{@90S-TQ0pSX9o>55p%mrG%V34Av0JR^Q%$VEkG{%$3%fuDOC zv(I5%2=n3e>mSZTl$+wy2|J^gR+Lcu9>ZB5s2&w`h7J- z^~J#z?w>sX@^u@2026RrjJ!VEj=j=|*{K}O9S(yf85j@lm|`V`#2h4LESOtB1$E9j z`-4xmJY+V=6Ns%wSZ;T8n@#!)k@y(IUue`AJ;?IMT#oBIi6wT-GvQHHVFiv+ne2UH z$?7|+5oYdT%J0!aQgm~rzB_VkYb}U+m$*W5o_d2kS$iIYqQ5%j$%;N$??Cx=rzER z5`&l*?3-^5yhSz^+A$>V7E6+~<eqrc5kjHqx}fU`Ad_?HXp`I9vZ zW~nteru~4c+R3nVP?rM^8wOcK_wh)Ax=DR1i47o2zowwoSXA)Lm=xJ(5{8*}SN^D8 zq^It>hcr6Q3PTHQ9~$nFtrD5T>LSR$1aR*cgh;}be0R!)ZV{@h_T6XTvzmoP5Xb5K zo5`;l{vo{ASyw?SFG~Fes)-8HTQ;#d~%d2v$EW-IsnH!X~orB>e+0L#yWO^kL z7kNY{x-Ix}u=$vV_#2WT$!%P=C|tJQDTS`FV)y^8m;Wi3OXw5376cHGIQ*o3fD*{j zhBiW5_4?;;-NLF96RhP#kEI2-CQ{aqW#@!N#t=Xjj3Ep@@=O#{9I{-?#~T%&!$pzI zA&KivrXZrqtFXmmpN&>#93t;aX6=;O`gglo-n-b|`_K7ya}55mj|1Yh4DK>?KIhHr z?#Io|m!j`+Cu0}5QIZ~<(a$=_xfp;^v+?D!@-5QFUzEMKLIao_vi^q}|k?is>=W<>yqM)d!RKra;Ojer9|uvf-U z5A>dxZ|FVX4xo@&n(|nZb|}x_gzKsZeyg=9UH_>@T1l-c-(lm6CPgE62jwURrz)pP z0}l;e4`#?w5^30gCf#zeJSWje^czgYc4FW+c*#t%cqpBQs;r#0%>)bB4JR2|{Bh$z zvhGp^Exfk*n2qW{X*Kha2B5kEImdV@r|mFdf3dZhLiSW@$5hgvETNhyXU$PEoUGy2 zhaYOkW|l9L4xRt zcXq=~7Ox=eCP|X}c-8JP6~9<%#%^wuV75WS#rj+^hmpAEG|aBoF!Ks5;M{Fl`36t^U?6naGGjx= zT#D_CKwg!m=q!|;ji?&TlEv?#WJZo7zbe?#KH{70<;RKh=7qR^dI)FNOzdFAjfM8b zk06%m$*0Bf@K!M`1MpwU{dh{sTkrGp)8UW4JSe zj1l3f=do0Wi{WyJDbK|ZwGG&ZeXv1%W)XP~Z4$CAcPCwW zn)CKf$!xpyg}XA;AeRS%uXOXma99V)+!sD@ZE8D`@-LNfGo z7Yq0H$x;1ecWq={3W+UjwL+EO_hJ*MbmLVnT*onGd^p<;qwRVa$IruW%QLT2g%he> z)?*f;e_70;0AgME4qeM{el$L7MBcAoYV|g$^PE#0bo8j~#W5mtuh;G@JY1U%xH9kd zwHy;c0sWupJ(?@m(TJ4cq-EE|P38|fulWign-{XdS`|aJ_)c9@6m6S#5~yq!_nEmgPldW|gnr&?i=4!lU?88<>uxv=6_~`iWO z%a5ckv|l>HZ#fqKLsnr-T3BD84e=CA0ck>;h|idE5CT^>S#OJiK6J}+oVsH-9*WLO z$!_2`d71fKA~CmhL{aoF^w13QLC^6-4+(b5_1mrVkkh-se33UA>+y6Y zAX#?Q$KgNSHU`IhKMoZ77i`ATZ}7g-1ryF z&FVh{#5)-0qB7OUQt~Zam!Bv$x-1iDFlF~}r1a6;!wmZpgfoQ;3+u?cxsfBTGViPh z)R$y*zA&>oEVa$PQhKt91Hl#QKDuKZz{*0cQ^dNBw9L$WH|uZF;p*Eac_Yu9buVR%5{RlTX4|p}qgt|K zN5XWT*K)7rV|l?%c!UhaVMo1wrydOFhs-X6BVSnG-68 zHP8lx%~<}fpTY(jIgLkEbFolrvn1-GCk4;RO?OHA72K7%ezPn&xlQ=Lin2VgHxSMmzp z7edl?stW$xiAd7rxmhUdV-{=p&4^NC)UbyB=@wg7{j*eCP%8dUUnk$j7(Klro+mO& z^%j!kLytkw+T2#U12@H}Ngzp`XOeE+`yv4zP; zZ|J!7+!{UeMh~)Ms$dQ2mf04`5m$N6f2k(sf8|aQ+vLyp%H*%LoPpG;#^J_^(vvo| z7RwuB^#SiUTcz^~W$_Hx!K+L!U5bM!BTBY3I$fQ`o(a|U!c@23U_n~drM+7Y+k)L>?Pv^^HZy5N9;Xeg4y zDDPw40}VUrJpXW|+zVQh^Yp&a_rb-sZ;Vz;EM-i?Qz>tQ42BmT$hE&CSd>S=mKb)tqVm=hQ}9O;P&zkZxB| zy8^+MIzU|bfrrMS@B|VRj3uP;B?PI;tgDxFnVzO<2~d5d_*;es_R4X((v^bG$9`1Y9Set{>mgEGFjgDkA$Yo%dsVZ7SeyEPZIt!JAe|7&w9@k z63AtlgSbnWWpi;6pqW?O75-o&f0`vHIeI8QRNeAp0$pVZT?Sm^^Zd)?Mo zHbihYC!8_v7AJ5R=8nt?+$e0zT=3^6)S_flj$6W0S^Z}@UU2IfqwzVf;ymdRCTHJ? zBg3#bb(1?n=zh&qbwfHRcLjL?(h*4&d9-QPv9WB=uAC4rr45Yjy`SQEQbkQ=0JW!5 z4B{IX0acx-W^j{zj|H)?2M)hIIS!;r$vcEUtACq_^KSlp|2H)&P00@tGG!EQK z3DjCoPxCK|wZNcDehuxJr571LeP~dD@IsZ>*(qy(B{7(ocw=W#F7Tr9BqYCr$z533 zsVjyT=xd$E^i}es32c3T4Jxyhzc#Y?&B(HMSVqFq#}xthDtd)Y44C!VMZ+zj}OWb@CkG06$cY)ni@Z#*#^b2A`0}=>|57t21E;KZ+~*drnOkojZD$%v=I^S z!RoXjJtLi|`5{>l_(gQXvv zCmklP{2ydFwRiDg7bFNsMAB3eFQBpMf~$%Bjjz41anIwvHB^(i$s?^h9#PW_p<;%5 z(C!p(%4>a;{s&rmbs?hr&PKCZ!)dBUNea3Rv?PQhxpi(qfGNk?vOIAw;1-;fZ}1lL zb`8@YJ>bWShdcRbTX2P>fX|Fa&&SJ0&vx(UjRyd7`*TNOk2u@9KZvU;6=1aDN)tjm zW#`Kg!n0iJSL-~tKwD}mr&6KETw*Co)rQw#WvIN?1I4dLRa0NsV;ht=sxsM)bOtpH zF8f6T{aVg(n7F{X8$DU0)t83y%F>hAr+L?cwPg5_Fj(UWX}Ed|4?k=3S}HVp7Ey3` z8s<_YIeV&zhvwnfvi`J^%$&co-U00%6-PI(zR{hfw z7disxNYUS%;qG~4$Y>=Qfub9|M}!_y>Cp35A>uj0pk5QO;dbuQ$xPh|=C+qLpQTTK zECvAU{Q%M>X!zn%_IG-(z4M z{M2vU9?0%{j-M~s8K^$zTBrqw#2U_)N!B~ZM{U}GMbFSK$khKHB@D1IXH;wKXz<&* zKg+1nySSArJ4+pS1w>mv((H3|TqNCewl~ceFG;Xq5Ra~P^bTdEpS6B%6$*4qHs2+w4=?LtKTP*uE=p(!h`4&U!F$(w zg5#HVDdA*Y$RpAlrQ6iVw~;B)o|z_hG1fs?|0OP<+*0ho3Y6)$*@I&ev;5pi6*;7G zoQ34OqJm8Js4^%pc+vNeu+B?doe!(xc{c8iHMqi@)08MX$c^+lUio%)~PAOsIVzgS$m&~V->VpYdrw>&7vpvAhp@C64at2<&f9py*C z6>MMsi|$|pRw5jOvHn7c4&UQ!Zs((hXlt{b$WK~!1w0+cvJC8S_;NZ@*dnR&7>wcu zC&wBdRE8R!d!l;5JDk6=*EVXk6&WJC-;8F`T(z_SR%mNZny>7CZUnv>?9HMDWHs{c`5!2qyo!F-5RYs8av0q3tq{yVS zx7IkK5q%4ZWR#VwHsz_c`H4{Kb{OIh{s6V@yDT__>4lmoMGPN6kV_(!uPTr7mv@Bz^t8M&pMJ%{sJujlt*l~6%pxt{ojvFUhrxUB$Eg; zU!-ENAyNP~@>O!d&zHQRvN3Vigk9254k5nQ@Ux{J9FwSUMg6c5dlz{69B2miW`i(+ zoyko*Htd>$Ya9ZNS^2trb^gt|0v}|2Rk!t-X*3cKOVQ_CT@qZ>buQ8Mg$G@++H@#( zAi-X`^%FZNa;2pEl?H*qOOa$*kS# zYxPL|SFZM0%hsL4krIL9?)vx0f0u^yd3T5*z>Y*Z5Sgl2GeCjIb5n@r&Y;!JGDk5LOj;Gt3i?2i=!6)j5_b-#WKHl)y9!2NmXnVFz zwDL<4I;(Z6nRx$LPRsQ;#X6{3@-y zs79p<;4_kCZ7Mo+nW^>wzQ68J``|Fp9uFd-%U~#&sEKQdf`g-rwFIN`p=QbDsKb9M z$(ZSnz$TQDPf4YlW9e~dV0bL@hAdAV0L~j!R~9jH#`d;@Mso{LCk+*wrK&4U|G~}i z3mhq@Q^@tyN^8RUIOa+WpXh4hrJCR3olB|y;Sd1pV0UscciVNW^$%3khcChOCw&L` zdp@N-w{Mes^Jq7|%k0TOm@eCO_PMsnwpHk-U)4msRHuP9qmRY-$vfq2wOV@_PzO1= zP4lv{MVjlrJ*X2>?U9!C4%dAr<|j6}tVx%JT1tDFH9QF4gfb@OIZiZ-c^#@ue!0>` zf~gg%MVpblr#c_^qp#3oqk8dYq77QK#nG~XZ%{gxBFw?ma?$3$V6-wFw?DV;kyD{5gL}%8!%Fo#B#1%+@&JzZZdGH9))&S5o=((-OWCNJ0iGoXTKg7@NFdJ z?3mPK) ze0IK{+(cldEv+uir>lT)w-A-08opukEqC!rDpij#hWQ}#m^9R|F_qY6m~y14>+xt^ zFgaNT2Q!U6%INt*M)NK*KL3!tuIe+$xm96hZ6wqr7Z z0rfPdHHNSgxmbgQYlL4*$4ZPB6|f7aW?hJwudZdY&SF?7mH%UzSsUM+vdsm3E|>Lp zyVU2Vdo%jqZVs6(-ku?#b@SKnX7kc-6m^#Gk?MDgNmOJ_yX>$|mjXjw+T=FOUu9*Q z{u0liKu+&F3V?Bk&ci|ZPNQo&s?FyP0pdoDS=VHGr1NOMQ++Gyg{oaqJO<3aF4EpJ z@953H!&iubP|ZnjhQ?E1X`ewsKkVuLXB>uI54hKi@IYgE(}f1>#jbM zhp+HJIXlTAZv5EP`K=u@@Ae>xrt39%3()C5q!9?31u8v3^HlG=e1(TG@5mtxHEz+- zvu@SV4F^}dUqg%EN-=j;ZtdUR@x5M)`95pS9*Z$|lcIZWh7r*|l{TEy^!$&8ukYVX z8T|_n%3d=9^L*}Lr9WlSdk5-{?{U$4hi}wA2>_*ANp!H+B%$l)?(3X_TG5a9&S!#+ z`PD@?pxog_$iuMiH>0bXU;$K-w;kD0!P3E0&8mhV>)}eWKyV5et1`tZGJcJ z(sIVJYL3KuQ(dPm5v+bT6g>&eCQ5{Obqy%_6MPV8E`m$?f<+h!a}g)E`&u~SSy)l1 z+5+6=yf8mO!Ux-&X^aF4XqBjiFBuogYFLp3aBHSVNXU86fBo#<+jKck%8YZ2eW+^W z|J84jWPk4M8~jcADd@mp{=Tp5AYtP~N{-dDlKJN^3$!CMFb-Rl1B#{A<0P zKoQGVJE6*w3kTXg-PF|EP79}VbA-6)z8;%bSR&C#lvw!tJlH(?dM0whcrJmM6mb|2 zXd{Wvi;~ivaYVqMKP7`%TM&=+lcq(1R~RhGL8$Xna}VQ|;GHZy84Fi)PtZjZc_u!$ zC?nP{i*{UKiRfK`2LORoSD)32`UK`O9YO+z$AG@Z_fM;%8#5zy$>^fH1<=RP0j(K% z+ay|31wZ6W&WYsYNb^Nv3$1=XpH44;g33~wp#Ix+YC+LFCV_m#;e6ke|GhnD+CA!( zRl6hv5$7&=x|4#mBVS07>!(7BQh$2_Q_@}id@fOJK^*kdq|FvSuA&Y?dhy1-85vL4 z>QCGRC)y~Bro0u!e#14-wE*$b_iZMyenea1_h@$6B4Q_Gv-ttO7w^#^% zbx#MLv|W2pzFm1xd21}yt-)sTmh&?wm-dliaC8?hteIPS>O|QhHWb*)gZWpozx#^l z6bqY7peOs>{FvPQ|IahVqj2K$pS2h8bFaVX{?hqrR_X(zpCgKnF| zCMvXPbOcVCXQdtu_=R44oynoB*4Ef7)2O{^2n9`sSI4=q3;smv`408E2DM2m#YuQa z<}Gt!VP<6n&en*53;ZCyA+=J1EXhg4TVic0zc~eF011ZG03!yCNdg6c5k(%URT*JU zk{^DYsYT3Cu*jg){`lhBb0t4gJ(ixppKMcYhHYz-vb5?FY++;4QjWT|Q7~#!ijKu` z7RyW_LWH-B8sX&4;W!ixwQvFH*$o~$G~FPS&be>QZw!8+L4KigztDVht4wNVU1-22 z6%mtZm3Z(e+*zM>s9+A9zFEasSy=f@|BgYCDgtMb527J69ZXg^TzO%iCkf1KSJR`Y zPvBdqp+su(Q6ysi6-+8gGU7;t!i)Hg(TXZxJ=}7&&#)buaLJTZJo%zDLTT+qzp&;O zsZ|#NZ$dh$tXCT@pSc#ji8fDjd1%42-!(0!(q`_=gufNd^TrRbD2@lrw|gyQa8_!o zoQ(T5m@;c98J?)KD@XNqG1jVmmobEDFQ*0iUOf;34`jc*> z-Q#@1g@P?TVtrUy7^`m=-K8RXU13qW(jJS?ZRXy4RKj7R)zS7haB5qVFP!R}TY9e& zdyAP{Z%u6z2j&@YmXg)EZZv+sfOWFIij0b*QA;)N>UDH>#Myo?OfZ#bQtUB@&@^pW z-45I62x)}w{2Lg({WobUXWu*1gMSSaZLl@4l+bk&Q4@J4<=Fegy=2Xq!3qBhMt|;X zpz$_xr(Z2%Lbx)M+w%^)i7V)8Yx%I6m-6Izy}Qd2zDg5F8!W@%94Y#fZFvAqU{{%^ zjI|Bf_a`G^;d6a)4#De`i(`Q&s_iGQP}#XJX3dzIZeT-{Wc6ad2wtSVw=vu(;yvw5 z#^&n}ts%Gf{P<^N5{KIg#uSAQ1cpsUP=h_-d)xApIxHlJ@@~J z;}ov}#R3utdmKILesz>C0H#TryR2o&kjDD-oj->9RcDeydAsrzU1YLUNi^AudP=ci zWi|<-#-O*&3&p=fdrhau0wqdEy?28vWLWgyJvH6_g)UEoIqFY2*9RLN9Z3)Ne2f^aK#FQ$6z56^_Ib`)^N{7;0v}F9(U|mCKgCw0 z##R75R}ifu!gcG-2>v(HO*np6*c&sq43KIHirh2)n{RA(LOEG!#*ZtMs^PhB2+QR0 z?dj7pQ5KsUZ^&t=KuLpFazWXX+MZu9rat zqAXM5Tso`D6B;Bt+u2|%r-ov?j;Eo4bS=cucOB>0EPq3w-4Y@<>cww~Q8|8b(%B1j zHBgV&PkQiZCF=a+(pWX{3_EsEN*DFaW>8b(2xI$d``q#xNUg^cFbT8%bW~q8-FVpM zlevwiPx-W?9n(TxEoV&)zOF0zZeC8zt`UK1=fg? z$9yHVJA=-0r)iY>fokTom`@itFqEYstV0wzUQ^n|&;3|3B2={$OggjCxcQ+w2;y{l z>j9fPst+IZ;@kB*J2jsh-iH`Sp*q*REi6;2-CF@Mokp}CMQRAYqbHvrg1-aYisw42 z?wr&%CfvDkewi9LAhIh@qUX|>2O*eg&ysl;YOMlKsh4Ox-xjrM_t0Ss z-m2lqe{2a;c`i3SA|7p4Vc&sA^+&wM>;H_FDXQZO+4d+Jk@oxbTwJdy;fV6Z5+~#A zyj>_GO=rd|f4ZpB`4itwh6qC?I)r!8(~C~n2c>&Q%ttjIR`eRK zCxAaFdDnm?z>so$2Q4j7aZo@dfIjSshA4S=4q*Mc!|u4#roMJz=DGDkH&nV4M>j;V z60FtLPfePy8MN5vSY!dOl_6Y=yQE%}9)EKW&=^l*kJ|Zt4x^`^({Um;&Wi6d)nXH7 zHz*qu19v~iGM?&mRb)|nbdji-&wJh8p*FMJl$yY^e-RS+pYR{l(3_ibdKhCP@$fz} z4d_b9s)FJNu*kN#R4B8oaTA1ldNr-J7#OLu(g(TEFVf52Uo+V+Zjw71nlO*N30rYg zy?d`K&^Q12$p5`?V}|`yV!g-_Dyxbb>LZjF?{y|M*^IZOuR22;75S(F0=kiJuNqW> z83n0XYdDlq3;(EFz(i5WKfj&6o6f0T4wwrjr%3-|?gX!e#=`caWk17y9B>+E7;EXG zFm>GBNy08t8rQLt@t}m~L|V4Mm1yPK%dV%FoW0*OE-Wi2WQW9=FY;0#w#Vb7BZ=;5 zUZqw@($u-(iKVPJ@t0FTuXH-M<7zbRN$R93v|n0eO%nC)7aVw3zcWWSRK8PB1>ofC z-jvnu*u4$mlk@8RP)DPq+04evGn(A$j#SQbL*U#jkUldKFL7GaE-cSV7AQ1^C2|t8 zm;=MDQ-YslI803HavHKp5?IVUy(p^=qC@KradF)D*>N~bqe5#EyKpwy9*sLg@z*Mh zIeVnFpDNjWVe3%aTag3WQsroEfp#2%{x)`Bs5lgm?wR7yCg&d9IBQS5-DO9GMC=ZY z5ij&69ELsU07nO54}N&e6SJYjnYtTU5TH{r`SW zp?Qbe7D9uJw|I;B`)MjObxgw9a9FAP(!@igV3+M>RDV}J4gQmp{DXE`052Sap&PdU zK2}5kDj$l}m%{jj`$p`lcH<2*Y!0|e*{LH^H|RXFC?k(MA;h=xpJ&QX?Lot0=pYuY zDhyhxiCedW#w1=3WuWU@P45I(S9rkh&J+LgA21antUc1XYE+=^yc)6=lVy`_WZET>PL)dL4<(pN;ehrMLu_O7SRU4KO9$I)_nov(4>+p1jO$8$10xyw-d-DAY`eD=)X8_& zOVZ;6OX%`~q#w`44o-A3hm>I<$Q90lD=#jV4W+Qu;-@WG-bKRL zN@m0Ho9jser7RkdSyjca?an`{M8jzVnlDGIET#`a1%R|PcSA0Mp5K}IrxZhovk{B7UEzCmRzIviTfNkRC4~xMGyl zEcHq-H(Ho-qABOo4`?g+mkAik#tt#W1hpH;2PZgy1pgd5;w*`H!{zAVeiKrmVRSh2 zzhG5gxizixZy|Z4tj+LgHe|10t0|NSFOxgAgjb{n&sZtnP%YnFtT$Z6p5Px1I6lKV zTNH`y`j3YQ%zV-YtgZ+>1?TuEbaY%`OA=Y zgcKit^RdJE&&SU&_x(M9UyLoL_f~~AF4-cPt*8W>bb8H>&EGmUb=JuMm^d|MBe)^* z-zR4D@(Qe$Pqs)*d*Cw61ZBi@PDragGO?zx)jKF5<`aKbT=vWiEA#P!oL%xvO_R8_ zV7sXeFr z554UCnzAklcAp6&n6{s$jN)bv=>Q3oKaJkM zsY$_8*`o&(>@N{C=ZKLs7UU!YY=o@&`+Vf63}%Ymz{n7D+RD^AeI@NCU+v>h^hw$@ zwK{#BR$pXQg=HSVG)NhRZ9tx!U4sqjSLWnWFCR**w#1r_HTYp^7^A5(6sf$tMY6S- zI@yNW0vbC`pvCw|`TT;3gly#!iGnu{3GQHj_69Kwca|VT1z8>zT;fiCNsvG)pB`AR4yoR;61QeJce=9RsF`g6gw>W z{#Bstw>Ih&Ea*I%@;2Wk%-e-fl&@%NJ!+G9>@Zsos7=3#AK%ZrQe-}cI?Civxt&8R z4&4l{-@7tajmiPDF#Y5bo13NMc<+VSRz0eISJtNaFf{rpK1WUP&31CcY@Ac1Fgx@{1Q^oIYgKfF@a zM2rML%z|B`Y9XeoK_oMUK0ijarWQNA`dstZQnq@HNoelBLS}sir=@acJzbg>4rX}y zK?{(HIvUZN*}^t*T-3B9t6?PIM-3G{l{S9(Ti8ZvJ7mDy45K#7BW}I1X36ukDUjme zBUblP4V~>bv7r@Q`>3Xm9GPu$ld+V$Z&F`7CPuP^@6fy9ZS)npbhD3 zd|kDi%_)KGsVtOJn-*pqbgVIuyuKsVp;B8i>(wINOepZ!sU;j-K|eiyFRFyiw_`hKK0;I*KO3eg`6KfK*T8Qf#ai{XB`#Cd( z-Pg*84`|kZgZX-0WcAxD1&<>dBr)6cA+veMjiV#x;s0hEv2bm2y>6eXN4J-ymVzdf zlto&kF%u8OYfg$JK2Vh=l3h3bMS87vCmTwJu)=mnQY#>T*EH4PKRf~q^ zlT~AbR=r9Y)%+FUQ$@)0#tMsL`?P3LxEW!Qt)JpIaVz6hL|M8bJ<&i|EiZTA{hhnU zsoi@1NO!$@F8VH2#^0=21}tpy@XN%VKl=R(K@Te$BsW>{LG3ccDjo?#adE(e(XVeM9I$r7L#%d0MNj zrV*V9l@c(s`O4{d{|Im014GnIxEwU&aktI0JGklAlXfFoJgygL<=Z>M+pd3#uv78C z;4hS^kVA-uP`lv8*&QJ_@8_w_X9po-K~u<@>yN+};Mf6obsO{ELsHGGy^ z(32uPd7={?SoD=&_&~~|FFAKp^qD^ML4^KG1429BVAvEWp3jR2 zl>mdW;qn&o6lurc$aDe}$E+SWadG8<9P7}pRAifk;=j9C^_i54KdasaaPD=dLqkR$ z6(_X174O@`NV%+9-iXgR`ptE9oCX#sC|CMh4Q-47BFKHQ5J{?1;n>$0Dk)hp*0pev zG_Jo6(Gnv5gAU?{%n51wmhu=QpXclqge964fQX$47dFP13KuYu$e)ww=~oC&rydE4 z1!PnnzSEt3wrd@t@(7MAT7Ndr%!VK29e+vfY#TSx;jnLzxnF$ZbyqyxyuR>!3roz3 zT0VwqHMTJzDR}0m&%#QrK+y(zr|UN+dn|K?kx;4OHCfIqy~X(^3B4uF04Kfq8uM>; zCefm-tCsDrmcUr;bLI@={Vw>5?80X^lwrlY{At=7g_&=7_Hg zb!s#*zlccSUEsYG-&(#N<`cCZiFW?G?jKq;z?4kqBF*uxa-{D3lSeR^uZztJhnbnA zcPo8(KVP|BHD4KfO@h=eqH4H7GMaWDftF_fSci;*8;Dj>IOTkmkJ(*#%lmAd`9AQd zZ=J7wclA%(U3~NV2O@4Y!XsIx_$s=@!vm02esg|PR>TWDrOyzG27DSaM=N)`wH8Yj zaPaZ(lrl#A5kS87t1PNFThibGMpiFAxg8|;_&ob0@3OLy0f`dM>oJEVX)q-jIo1E7 z_SI4VSKj-MGvD$@AjzLN%g1;x9p(u(GS!H+pg+gc^J5Yp1K|VumB(EZGUt@|CyS6U z8e2g=&Vo#gy)T<1w+2}Y2C$(==Dvitgff5SY~zmTPj&gDj~+>M^-Wc-+%WqMu4KCt z?A}+^@H*`al#$dOy?|1;?_}bVd=u8st!NWHvG0~1`OyC zdR4swOB;Jp{vS84MB*jAbaW8x+n5La*rmj=|0%i?ohj=$N-!<+cFO$a zM=xH}=a}L2QmI}<{Z_yK#&SRU;3&ZX;EKl*TqqJhu$nV)GSl|Sg+qAKUDTvm^y9Y` zX*MKCjfkg7f6`tmM&%DKhzQM|j_zkLUIscizNj2nOIh$AV5(nyowk!UW(d?tp#)=4 z8tz6SE~Y0j%Ju~93?CyCFPMe>E{QNnwLUQJ&&z72<_(YzPVuNkXRi>fD5jqR)c@-L z=Yf0;wJE`se9w*MVoN5rxJ(=gYF8-nHjY}aoO!K2nv}(~nT5(J%8Xe%kXow#nMn*T zlWx~rzivY=;B#7+OlX6Y_62@|P}7#@;I|DqcRF24ma|GQs|wY`rs>B-qT*~X*2R8q zWmDoy;+zmSQ{WPD-uXIFc%vK(=#??gBy_f1IMHhG*N&Y*nci6Z`FS08>n1?NH6O=# zmVXtfaKCc$h%2V(8s8K2j*0e{s3zYEsslFCWA67g%;2zbQv?- zkD`c2(`vLergO?iRT6fTOs$yUN;-CwKX~b1*k5?8BGU@@iJ|@m#=Q6~0M>NhMc{`u z2xO2i*RIt1IW+dya~+Gt6Q0{7ksjieTr-1WY`1 zfIgINv^9mow?j3I>}WeXTE631%6kOmg92VRT7z#ih8ZGhVqM>}81v{)=$yFFd>!&D z>TC&O3v5|j=4+hRB07RzVFTgJ;G)TU5Ej`}s$ab7DD!4q1* zAzwpvsmh>`7JqEU;RL{N`9URd`fvmqRQSieQ)NNXRJQkUW$pWInoXQej(+@f=dol4 zTSS}hrT+B&)kRUET!Y{01;>;ZPBh4NXJOI}A;cBKK2Oh@{$w;CXEO|4u?KeU z!VPAC4_W(aU?kR`$i8sc4t#-0%b`x*2aMnHc(meK(9Pf@3sqaVO+Y6Y& zg4HngLU*|0+HZ1WQzgiBZA$>S`ffSXmIONPUxFEfVZqZo!@7M8KhXe^Q|BYd!=8KJjF{00Z!-- z!K&dTInO9^aiKL?u#P~TA6j(ZkHKH+^4>_D_WP!I@Ade!oDCB9+JcBQRpcc1M09NK zBW@ep)%Ew8!CA7qrB3UhfS)4Fae7NK4ZAqQvPJ0)p(Ta%RZLs#{z))AaJ?$nueVyH!rs_RDR8KYRRQ}G&|i_?WJ?1?E-MAQAc#>4kfAP= zAksgkI=m4pOL&~!&-38PI)XFrBhSB}W_5vcrZpT#!+QkFIN_u(*77+LnSh-pADs=Q zGT&&z<&raQN4Lz(>|HmngC&x<6Qvek9yx2Zj5XbIIRoh?}h z^bE=)-%}S-y&q>;a#I@?9wBl|OR^OWLTM;>&2=6$@oa((;*5oTTI%tr(&M$O0CRLb ze2k^d*_zRV`L?B;7x#oZ6TF1M7dwpD768=6vVUy4i7dd5MGlM$MwHJglvR6a<3Fau z*&Kv*`53dtLIZ!IE+q-p;-mr01rr}UpI{_S`@S$iuaE)F=(|4H3#*aW?y4h1((pmSl+^Isd@yCOI;4!ezVztZ_Sk07IhWPBC85KXCC{aeO{SfrA^E zHunW=H-13crmMnk+9qVl0B@OJo=hiiK4Sy)Bm1WihDxg2&)s5$X`J2?g+Qx&x><0% z;8v#5+0)F3BisA6QM}ITL&$UddkeBm?tM7{Yw;;ue(Q@)Hw%7TjZj{|g?cW4y)|o{ zU|n@9t8l~*$Nd?0;EkrzGZ$@08DBIADf`=u-WX6V)C`%l<2yEd{Q;72Ab@%WJ37~( ztiz72Eo?B(t1vpDG>%D`ONYZ7FQz^?D``K0mvEhncL1^uV8bor9^eI^1jLKT4U85< zFgTYQ@%_$wiktBb2{w{FzyZSjBYF!Q9dgGl$(4YIJ#nk}2?Mf0%{yJ;ie3;F@?-P{ z6A3tT0!j1%9bh)PO@Y?>Dno*8+13b>ADxSBhUS(Dvr0uo?IG!jusO5)qthK42Ineq ziwfm)ff2+luq|WUqFU5EtP9iRHlstM=d1WD>UDz<1N~2Zvnp`Cmm#;=!*=;Fh=U14 z#ChxW=l}yMB|nrDF-T@u^f5ljoOS$mkqPvne8jGMMMEk|L(Mh{bTSORHZ0sf1&E*i z0Xwzt@rJQ}H~8TV)8>aOJTm43jwYH*2HWAF*8vCq3YFvnLfy8L~j# z48L*s63*9*gw6J@yz@#XtM!z%pm<1|-w1fF4}5SKqm?RRI=4jWBY4XuiW6>qB-FAs zfBQ_5^_v>9mS+MAOf;PASJobc5M9XoK#SQA=f3|~*OW*%rd3v>Np}%gu~4r48&%+u&w4#ZzQmgWL1k+>AuE;lhvnX$2VmiB(^haB*4d20u*uvuXbrpaNh`` zZRR;Wq-``v*uw=62MUoIU+UDpVfelvuJm>YZrAEvuSfD9iY!Wt9j!YW zTV5TGUQF`rNZ6(IS8Q(R%3v$| zs3yzSSaIhviZI+pxd zp3q-ilJIc5wpW4KLUW2-T{EPI$IGyWEhFhDPm94dfWV!atE6sT3x(LM?M$I#ZUNpF z(_5(Y+Pzn;`e6HWjdbWX-=*Ep@lg)VfG%wV=B}OA!&K-_c}?dga4Drka!b|Omd2V- z?TXoajMRi%+76`wTn2<%c{9V+f|{jV%P|GSxyqxVBz+x)HJc+R5`UCE6Vq+iS76!DZNyr?AH!Ge|QlKmAfT$*4JE_C%0~zZhKMC6>TkD^Ca|8|^O? zlB2|{^GSE+(O891<#*~Pk5LaCpkIHXv_wqd+ypc5$GSBhMDE} z1YqVeRJqYZVoyIbn3fmH+w;Klj~8Z<#QPT^Z2ipMjOo@kz-7h6>2NfcYI+c|SW&x=vI| z6~5*!*66?%Q^-IiKYP3Prnc*&{p4Gy|0jRPpa21}fOg^V_r`ALKj(b=NVXq&^)tml z2=ltUu67{JPrSLCXseHzL-y`7W##{2bUZMugas`IYflQKg;P)t+s} z7HF|;K7N+Qn@k%?Tqk^MV@iUfma&towkGx99#K z{iAfE$B_KWX@?puQK^LDsTEd-vK4uZYg76BJ^4Z88g5z0mw$;iOYt{L&t%0O#PSIV z^c3A-+Ql^79F{juMIubIsuA~K$-N&h0hbW zg%Wz$x099crJ&tGD z6D1UAee`Gxeyjar3u_kxAn22jNeAKVweb^Z+H`sX^z z92)_d! zq4$i!5pfgopqJS{L}Qv{O2eZ0lvE!qpV_^NRyy{|NbFIdD!hUJW+cvYgO||^nhk0H zo6wG`um!Hh)xo%WH%`ab=i*{Z-{eEP(2 zNcr8oM995Fc$BYcTPTtgZkF#?a&vrKjU(wz07D3yQIF5%EhM9#CFHVU1c@ z&?Pz9^~*~@>niG5OwGz$8jc?T0*6rhIkHs1mC76qdwkY(OPYazIhF@ce{-2X$Bo4? zOxZdzjO;b5VftywhSc^4P~WH-`7vcy*IXpyE7x?nD%KMRyr*WhEbO8YhG$$YIYAbg zq;5rSrAu^9Eb55MwPgE}lJSq2XJA{hV^o~I4hcA2=nI^h+qkNAg2gPcg z@3=Bm?v5d>ybt1ZLnEFkP!Rb``|idblgovU;IzF^(E#>*9p0DAk#8u<(0D`5r$Wt( zyrFU(B7Dehy}n&*zHK$TuF-t0?N8FWUt(RBdg3r9t)@n$vB9_dxG0aCoS-KS-++n( zgTe5T@@F6{af7#uc~Bp`kjf3MklGDzm+}o|m+B2?m+_^#Z}b(^EAhuB+<9e{+mg73 zB=mwT-WBNZGF@(c$>uk@9T3}&T=JB+Ha5!=-qu#C8A~RyXNytoussFVh|ToSOeu+* zHIfkCp80o|eYvVo0q66at3S@xm9_*X0(~Q)v^Wr$4NG-4vp2Loa+x$k==Cu+EUM8M zWsAMfJ$7(W9i+v9Pg!-i_lh@bI8Rt!$iQ8h-NbskSU0+^=+NslXBYn9X_kS<-u5dA z%z|-fId`1-Q1*>qtgbD@QudwN828|KbuawrHrA-t%9J}-)H zhFA-C$lrhb3Es{%LyJPZ*5eR(#?wDa6bLkSoYCvq`nvO0ZCcymSs74mY&0{xs&qmC z`>H?hugmS!6C8^F#P!XgPfW-g)ndn(05D7vXNoh~5!c~MK$!ftI}F~KG|a_@Lje>t zt4hlSpF=zH%xW;6L!)Fxz%luQxKD@MDOn@DBl8|)c}*YJN-;I3hs+lVfA>z)28`ez zTje|_uMfXp^GyAW&#^$nqiVUssVYic+b8&V#-+X{P(vMf65t%eh)GUTYs@~dTlk1S z?2hJwp5ERkHH2n%D&LWSE+xUp>Vo{Fg|=+FERgA45yt5jQ`&dfGb#vgxMX-F{?E?h zQVt&`@k>YWH^E;S7&Hni_EeFFQLw`{(NRR8#lo`#W@Akd(E4pD#Ru zm~_ANF40r;hI&iu^dzK1YLd3%9%-<8$vnqjb=M4+ZT@*-6Pz=J#rTP_IhRh?zJzy^+%S+Q#v@hEYTQK)i@4mO zLD-7-Tf*O885i1){M1O}evVway_*-14NbOfT*A?26Te%f%d(K8O{lk;fQV<87@7l>~%Rf#`0gXHD z({01W6DO_P7#4oghernAK74Ii(BJ;mV`-nx@LII**qF{`fA}v0ANr2kbJZC=1G^>r zX@;z7nEz;T+bn)$djotv7nd^2!%)p|!lt`WK2tpL>PM_bT!CsklKr(|1ddrB(>1bM z1`N&>&US>)G(n%F0Z?SVWD=o;$Si`yr)1^F zrUnDSJg5Vsj)CuNtIh+Xab%Jz8EiW8svMzkV>Y`aWAcfXEkPA~Xu$$CgAZ5IeuBiQ zC_xC$@A?9giA^g$)OjKwMhs;te4Gb0w?hTSJe!nFlS9DM-$fyrZ7)XnCl<{Q$-;&7KhWEXqpBz%hF#2YrQ03o`P=F;tMsfr++o`BxumrlQnPCTPk!4^ zH`MnH7hV*k0bkJpYO!Yw`fF>8&zKPY zYm5q>{))SfS3B5T(+6gjehJhDfoay4mzV6QRwZcgEtbFpB>0o9sXN&X>~JA(Gg?_>Cq zBz9!l)dIS_--vmpM&;wd%8K%r_yQ-S)imTK-!Jhu>+RpHY|6BHZWAvLtZZt5c@;pk zS+U;%pxdwXPZi|^R{CS9G$?;ytuoZx+ z0`@6hAT-|tqIGkb)c9||!QZTlIO@P5?PaI<9L@T046*%A*AaJqm(kLqaLDvZ7B}ND z^|@j1ln&P#i}=*}iB5R!pa z7!@7)N0?%pHJCJ`Ls5u4W>yebQrs(jF6FC295a)>v?mhe2Jq{g@a95ZeT%?Sl0AB} zx_mlZ1Px-gdN=9{`d>xVa-zC%x4If7`VAv6o2|aHjqz}g6=Yphd+-vbqMV(0N#1U% zsW1?Gv!B$~;)^b@I<6Gn2d}z!VtBV?T#5qW1mGs5g-1ME&7Gon2Gjt-`mc(WF7K9W|si zr>r-~kfVn;BacRzx$TyVth`>T4zPmm?zDGp#+Tbv8Y1aZEcl4Zw%!Kr7)uYiK2ts1 zBuzpNX8l(9?eH5;nukw9b|=wUm8#y~-q??#aGt9)6ZL^YV_K3f6HW6IhnwjZ6yvzN z&T!4Y5a&=AVAcW4oazk5oa~IU$u^|3nP#j$(>`($rs4%@VRR?Kth3i;}l5W&2K*Te*wD2J|a?iMGKtsveKwxi( z5nKLNDKH70|G|XIlsBqf{U9V>3CVBl_Ehq5p~kGt?yLs)nftjaX8Y#v6Hc*V3axFi zj;5#X5Usq?ICiO{E|j-=C-1>2kl`4a?F(d3Ay2-sRE%PflmNa<3>n>UqXN@zkl)pM zx`YHx4t)b{xXkV6dgngsAC33Q zhzT2a+fi=$Blqo%wPDr{Jsr~95-bQ+6bdY9zv$IAtM75%&nVKC0N1a%boqxr_?3f= z=E-%U;ZqzZlYmw)KEwJCn9OLFB$#dsTIzni@vUe&dq0NN+ACHfTM0Mujbmu-|#*F*E2x6 z8$0cuEvIT|qZyWH^Ch;9EMTclWxCitL&kYS%A-yLpm|KFeNw1B zTL9zNpv_zDppd>PYxA0=?L`A%Y4z3B>TknFZLhmn*5(XX_{!m35fCbVk5!xy#_cC- zZ01M?=e?2(d+J>GspM+~ZZB8Vse8eOjPrJ&Pc6FIN@#dp=H(S-h#*gN`!&X(uyrfT z58#_QPe^~NoaM<7%g?Hn#Gs}<#NYM$ZHOA5qzN{t+vQj~p&mNPU$B zttna9SETV&)h=7gQ~EzX7}ieAz7(Yx)-3mm6T+%S+~$N2K6aEMv66BdDcMpBwNU=- z3(*u|+oA_u3+Rf+kSer;Wm`n(0XSQi`GCQgK~A3Y3|vN`7zmCT{i*$TEv75F4%z+9 zV-tTVF<+IH;FH;Gn+k(KIuAs@(16!GY`G+4di6F$>*1r29*;xl4J#tu*~cUgHye`R zRRuO>Vvwv{36V(E?^NZ)imSTtGK4aSpowo8nXD$KXm$5`hi1GrJUk0Nw9sF`5D-ZX zGCcB2k$Inmu*z9ONK*LK+sVcmVbaccL~+<4rO7vU7=d&c0isxAs&)Hv1Nru2Y#cpj zT;!=fu4BK30T<)oncD8O-2-}UFE*LbXR2M=T{$i>w?SJp2-ms7Z+vo@<+5}Fy;1|b zB!$x$!#V3xw&)SgMY{*^Bl+aM6L^SIJ3P9g%)kUyW<_s5;={&zAd9#QUIAj83;sR_ zE?VB4h~_U{LLIS8e)IRRvAmvz*o7sx$Y7?Ndd!3_XR;k4Hjuu|8gYW6nj}442Y}U7 z$3yuLqbz%X)d!I;ZFWf3hm3y9)~6q+rOMVBby6zeZwCNa|JToLcadK61naFX(qT)1 z%Oy#s%%8{@6&c1h@+|pmk^-R9wP?rL&>p17j{n{1!^rjm)8A`gf7e1Q%|Z$ryr%it z=0%U}U3y#s?g%|~a@qd@uqJtlt zZNA_Y90br6Ats0cnF+Y5g|C6~xoHLpHAkR8L&?WXSO_T+x0kccrzu_-3PVJq;p5cGQ#o-15x%}k)OE214fIPjmyj^Ccx_?5Z+`Etk& zcD1VqC)Pq~qS8m=aAz#jN9aqj%QWZv#%i<)O6aW*!K{4zi3H5O-%&Graq33MmAN+V zM8Frs={fdo7!8LZBXW6>BI`n_8$`*PN80>lc|E*$hS*o|YZ>R2tu4PQ`N=f{U^I#u zi8hs9uBxxakbQL~-n%+$A7+a?Pgew=n#62F+f-JH<10Et|ou`Esud=GdAWczyTrobh3E^Yy))IjPvyE5S zESF`o%_$&uv)tP5EVN!Cp|B40Gc&J>HdUd;lO%}JW0K{@#ea|MtVD6Ynv~o@r7ARF zHx(wff^D0EQx8FMbvF99c`*mRa9!y{io7g@oLbUjV?Pj3ti6;>tS6yd#nocOM5`MBb5{S~Mjw zoXRvP*RGJnBs}+o%-#GvpT@)}3>@UbR2WiYroF@cS%L^-{%wS(XPJ$T=b)e4O-uJZ z1$7w1po1Mi@A8I8reJI{s>9Wq?avTDuT-{cyB@f z(z5kKjNTK#J(G53mT79-{ zcUED9F?A+B^kM}bDaz&R&eFxby$a<$EjV#kG5;)Fkk}ltOGZsa`@oY zL7wYK*>SHpsTSoEMeZLfCLclEHjTtO#>wgR5W~Uh`+}e+p~wP>QDo z#6tOjLYSiHTf}|9NjC~HI`&`xEM7YzT+MCEA5}A<*C1=*d+j9S7U;X)k-vu~M4SQ1 zDfj#yVZ#0u72-2-gy~GQ=69}k|6n4X$5(rs=^nv|{<*#9{`@ zc+6{J{5#-DHI1ggL8G1!qlr^+TIZ0L=|?GP#0@Btfm2qtTSTR4PBagj^D4PZRq$ZM z$0{!E`C4i(tzde^ZabSkIi>x`sT{dgcWH}o+n#UV{2Te4Um9;J+2V%ZP zm z=`u1xE>eubW#z;sEt1qye_OH#_unh4v#aSZ)Gysn3S?{gD8}O0` zI5Uan8`g>l2afP%ZN1dwey66UqTtLmv~e#?FIjKaP zn&XH1dpMitT2aEl2{6~6T(55Ca~Snh6EztmDfp2eW1+xAZv&|OBdNw;{)Bf8$6OZL zAD2#nIAD{!(4G`@QE`KAqnBu_WG69w+)fc++Zp$*l$X5ZCIns4JCYQ-2 zHl=NkNT{>yRqnhPGl`brp*j2Gs7#Tjrx%A%3E`4acuu3oNvaO?MO>5^|Bgjr7`KHZ zk$Y_F1(#?uhr4FKS!YH5^%A=yP;o<}Q6fq!%vseu@h%WpgKSFDnRSvf(fEsgxPtyh ztleB+>LS5jOt?Jw6R-r#T4PkkJnz$6@Z;^1X{zm^f#))Ai1~xr5qtsP94S?^(ptP@ z&@n8cb}ckT^9)8TYgOYA788%*8>6(+#&(}>nCD-BbddKGCP#%OP6?9&#Z+ZF<*E$< z-f$>AD7zT>&?kl1VLv2j`nvV{L$o*TS+;kX>^`*=vpnee;N2X^DB+*DHg4+Gut(Ks z&fbuf=jTsVs)qmXw4pRk2KMh|?-abCXSM3DwwxIUmU3a+Zo2RqahVMOCj3t`&dDEy zb!!cxBYuGJ!dZ-@-zoI=&X0(UnW$(M4uxo31Csy7S%2VV;cUSf#>O2W2CIjlK;s({ zM7P@FHQ&PclYd47VM)jup&!HPiJ$yL4KLfmf$Bl_4V%7FA-5Y>&i^RSKin@bM2VN% zTVEj+uJ1ln-%*R6O`oTPMCT!&_k{~yz#$F^dFw**LT(J?tP-7I&a6Wy-lML?->IM9 zQuCf!e4a*gpCXT>lBVrpZ(AcPXx3&z6)UN)CUGcA_ZuaFUVAz@5qAS5eV%denIq2h zpO$~Ah3oqeaKP+r(H|3D4AU(IT?HyGO+Oc}^&@ z4rE)n5tf8kV3OSZ29LgHD#3NHMjAly4s`bO>;+^U>0N{N;Z!KV=gs;<&c76fhwaOz z=2*FrR;_h`yhwHP`_0w^-(8cHP%W4}27aYJ4Zmd!z-2dzGds zy*bdU4O|3yWQJy}VYoX9rP?2g&m<4tNqDpX9@tZ$quc0to6?5$_bNSoxCeK~mSCD- zfM2w7f#0~8+cecHRMnfqwc;ZbLsV`t9D4(7Z#(QCh95yK27lcl5NxyBZdaE=7^gp) zJNyzY{Bs9r!$(AFNY-p+1*Ue;k)TLRG^KAjrg(l1XT>!&#DP!kdL(>!>^im`Q>m$* z;VR7o*9ZqbnqB;=!l4e-{iOfyynRbxR|=MIX~T0OIc)g^C*!1@o;}WjQE=C2Y7i2a zLK=_|)h|b2y`VZGJRa#RcUD}+wS=o#09=;28NB%IE&sxBO20sKkF(xO))+tbE%bX}VP|33gZ zhSFqK@>Lq2d|fmkV@yI2G7$`DW)}u2G)CmV41**-t(tTZK*EH?K;I*v&_u`b+YMB$ zBmo&BDr!MP>uT1Y6q7y%b_H@kT@6QW5x_33sY9;Mt=fx|gYdLx4xfRcw#N89ZoMx+E1K#*n0w|9`WVftNmTVI52E-1MMiYmuZLu?RxSo~aMS#5>yT)CzT z7R*013saoZrn9#&`)Ez3MJeU~DtG(Ji|F6=E!JAw5e09w!YZd}yl17;*vzHB9e0$E zc^8miMzdMREaP9$aWz zzbd>SXqicv`LOD;7i~_;$Q(XrQF`Sr=Tb%_wK2C8oP1pn!}9-qLE`lLk6Z(3EJkFAIg*#G5!O{jmWQ~Z*op13mLWjPiAV>1 zr@l}o@CL;RW5XUbYODmalbSS=u*kN!4rOk2d%Y?ZOuymCtS_v7qYfj*)c_JQ*JqRrn9I~GLEsaSOjgDJc>4|*MloY{Lmw6%6! z^kagxI+uHnwGIR%g>K1N|7_#yEd5>T-)S(rpR(DX9Azh^#6W66)b#N|7`%&&pZj;Q zM*!sPqmvEsh0_PWpvkkltAbO=Z2Obqrr_}vhKyAL0z0BFwRsuI*A`&JctC66sJK9w zt=XigU%ci@=x?k{WeSx&#LJ*cmQ;tUgR}eU?t^^#cqAlWX858a^ zpvrij<;bntXdE(lE&9y}6Nq<4tU<^m{sb2(`kNN6)f zSnnQZ5yHI^(y)-OZqW!jE;6?N(`D~9{oE{;+MA@etN6>Oc|pu{Zo3X2an*;}Z`|j0 z=#K&Eq6R60YGVD8 z_@?vHmMFo@fr)?^U3ZUkquX*No;HuqYa=_<@_P@ci51;4$>Lf-WR@;8`p7BOHdj>HQ(hA>WAk$+;QV;uh@H^!ju9$@3R~`w}W~ARGMspuAY~ zXWlt&l6T&S5V;(&b-c8i)x^m;Sd@dWh)J$G^vC_BRFI~S6!Ln=P;&zLy3;(NR~7_> zj0rAKu#^=;6x%A4oH2UUiFn!1H^6zV{IX&x~OYbB{MbNCndJ! zcbj;l*5(Y>yq&r$Nztz!4eCqzxn9H(c0=-`u%dSij*s?7sjI5-&w!4pIZq~9V8Az~ zS?xU37mg1|q=_GINdI}5OMR-SV7}m-A_Oonf&a;M*L(QDLCp)*bx90CdIWK^L>%n- znbd`RssLdY9*SO^B#22ZXO=2ZBh^Qe`JhT|aSQ{uSE!KaHd(fHc#%Bl-^agL^*K(JE31CLi#_;o z8mLX$w4JPk=}ZE2OFr^F2B;9h7pqQoCS9soMv@UXrk&UaF6AqXr;YUHQv z({OqLg|b*gtL(Q`iCe?vGN@4HNE8B$->P6IfXuGdu%Xlq@9e|ExMAANXE+B1i;bLU z$XZ9z;nRr1P|&5U0wUoO#K{eN$Vhi!w(AztDVU><0{722! zf?Vy=_xHwX@KYvPg>>u`-<4`jv@!vkZq-7-+51$Isb*10JrkM55$33G z7ZuIQ{$;jtPzoZ@eAAw}yGd86OUSD;(ob+iX%xVl$#QY#fR1GPcnv*a*pu4GiJKb1 zO)g+75iP-Vq;Y5I+`?ILl7_-Oe(XvggF*G3;Ks2vv(`MTjdeMEhbRGyvRB35@BOVn z_w*c9!zz333-S>cDD+N}yy(Y(s84Wr;K|UK9*y8dO1qY#SPgl8o8nw$g}7WZ!jz8` zdy`f_xxvz{FR)t#_wmK}`4jgavkPcAGKxm9f$W~oG#`ceY60QL&SK6#!>ieoZ?TXI zbT2z@Jm>xzDJ(1|!8#NWspxS~-^{wHQLQ z|H9OYf0REX<`W`zZb-BYXcb8gYUNxB0JsNta{|Sk8lV8ErVQcE%^?(el5qyWUMfAn z?zB(OfAq%XmxVe$Kd|2^{u`K>B+73EPNITJ27b@=|PF1oCeKO0MwJRo^fMRvT*Z zf0c%kL59<~HmG=DKuse^AO|y@Dd?SSVG9e|SE`C`>=XPy!v?=!M~~`P4!r#e9g_bO zHgxwXfyHVHj`KfI{LXw^;JzbSs%I3cmD2{>Wt7D?T(W=5r|MuRdSg##ys%TQX z(RxO1b)rRs8TbVZp&@Q))=*c4MT5DTnCkLkckFn3c?*vR%b2>h9T0hHDfASQeaSvwRACku^RKAs}dQoY*$ z$>vGv7j}sCB(eSwdN%%pDB2;fh~LgDTuT3@M-5SP9S~~6yYU1~DRALwV}*=K%+q(t zKSy;=>H*XCSFYMOf2l;73wOf5rI2e$E*sK+!alrRj9-+Cn*5OK&{Hb#ej{v&9h`^% zYe>KxvbB45xM2fvkU#)TMM{L|DY!m zPRH`cgAe7(v=~}1Wrr9(K*Dwq1Uy|{B zf@Qd`lepgQGC1CfjSW_opkn+0^+UlJj{}^M*^DKTN9eTCKV)DQDgj;e9DO`GsC+Wb z%2nAUb)ENEzl-Z0L8ehuq9s9+wKZRJd}gcM+F#34x{++Aniq_DIGS`jbY9;cegb## zs?n!S7G`NFk8_nj@SQ)x-BL+1E7XNaH43kwPH&9F4+>noW}qAfDdI=)ZlG2M(P<gC!B>a!4|MT?4L-RA^d{tksUz*f{UrpM7 zd23s`7@OIdGlLv4k^gtQHnmRx+|)kxK-a+d?Bu#AIt?hEF^TRgtFoU@2||ck)K#Ig zR<4j32qndx4|FS;lGjDy-gv@H)KF0wz+7lncM`lD2KKuO{DUKk^S+v(FhG+&lj`pH z+Ma0d-0pnZOnZNQ!Zrf88XiT#Lt)MrK_HE3r=$>t&C8|bL(cSC=@Ux=hJzn*Q>2R^ z%C=C4Ap8vd8XQhR7ca*U!?7r-B3&@X2X4{tcA;SH1(FaU=EEU})qq_90L`5!Ykcf$AnmVz431OcVRH^$iOkzpU9yZrd~${*nQ_~v%cp`b)cZ=kWFp^ z(cG`v<76zRe03KM(7NQnk`yZiZ5x5#O+!iEwrRX9d3ZMw4p!V{sZ~0hphISCnnwoM zEZ{d4rLYz`Q}h7>vg*iZ3K2Bgdcwt7igPmS=}?^yka1wh(f zf!Dj9vta%EMaunOI5B`K7H##f=FYh{#d67lMPUz^3fEUad&vcGg8E6|=VeM;K0hIZ z@Y1nmt~tgnc`otEYT)V&HOdLwe#nx}1eyYp-CSknqJm68veZO+#9!2N_(x29F^3mR+AsWn9S_b93Wmtyvnz0){wH8LxV#_?cK|K5cu?ENo`9Zaz8?Dvgn zkuL-o_KkUwv2QL|AUQFb4cW~H8*KrK@nZ}*Sl_c_zU$KhO)0B)77YVm(7`Vn836d( zLLE&?L&e&pg{W0*YqjbnU5)ZXF8XAJFe-sV^KZ#hr5bvs8M#p7?-xfD7xY`u)eDPj z0NITNyFnJhL6tvNQ8qNEd{+5-t_9zh9M&oaM;bnOdM-Pe_K^rMv{$WZ)_U?97|BZz zE1KD?eu;Sl^`q%MGE>p`V^6W*9LGEn9LKezBVxoNzI=gI;I82Hv#@W8Hk)ZHIwtbT z-~Px-DDu7erZ-AXe(sgUJUNN?y|D@PgtH0tiIijF67QqqO7Y?l3jQuCR2#HtTpz2o zux4KZBIc@Ij6TP(J`<3u)jo|$4bk)qh3%saK_~kH2PyUuvQSzMgbnKm&OvL#8Y#L zO**OJ-y@4l+Fq*cXo}so6`2_$3#AB&i=Mt2Zfl5~X)b?xvqy_~v#j|S3Mn@Y2Q_?$ z8gHk7w6(_Hewsa<|ANpiA2P|XUuH1alJsy{jE@SeDB0}Kyk4Yy|AM@5`x{wSYB#$dB< znGgDUqVea<{!OG-guF#f!^FZ4U-rD+7RCjz6AxkHmnaFU96n1pTZ*PnNp11X-(XSU z$i90}1sqL20hq$> z5GqEejq87BIGFmm6%}IJi9cXAU;bgY~o3sue(}WmU zKIqSY3ZqPKC{^eQsf9l6f>G!1W{kO0y>bQNF_?qhM*k@I_2-T3_EJ~>_{}q+k_E^i z5H;7S?FMoCddnNg%u?d zGJwt>zNKBrvut38NFXa#%R`t<*&58I2qUR9&ogD(fZ51nw1cmYVsA$zF}Vx;cfGI> zr)Ea=Jf(QID6vXvQYHL8ebtDl5U{359nKT^vL`n->_}6-y~lJz7&iE{LhGOB@fN?r z>^~%PgV2TDy+?hM8Lb7A{|ETL>iP<(I+mqt2yVgM-Q7LG-5r9vyTb|YdeC6O-8~Qp z?hxGFgA)i&{*%1>?hW^Sf3G!b&79d))7?`ur>47l7qIReI?{#I-4NBjS3dYiy1Qn6 zY>_+?=85^x9PRvbtf2eQV0AYXmCf*BG}}2f4)Fyg}~^!=e5#Y8Y6}RFTfP z%D9G=cM;=oH4Pf$2w7OEF7?&Rq=2IJn!XTN7qO~RDbS`!Qn(G!0E$R}z$TdFD)H0)?s z+-fzf={sEn+$^i_J8@%TEDQ@{J*yNyj1_3sn@5WQ^D^M-F2icGn4AR43~}5I$OAbJ zq0VSzssQ(~XP1d%;`wUdDOwr#xpDIJxYYcq_1Ovtogix`!6(6&3~p3owOo3QN@f!7 zgbtE?ZdfECObI5v_NDq9Q{IeiqjH20u4xEA%dyhdsrq9J=E73Wm)!tz@_@s z9AxwjqX!Nzt7fH#aOx?*VYvuib^N-W<7CsHDZ*i7(& zX?O#5f%ri>T@8d7d|yuZX#yUpOT1T-Kr`!?HBk#Ri$hxumI2wt@Nt?P z4^fIKvI<~_G+BrO&qCp-Fw>l)iNpNuM_3mFsdRbGofyR!Z@t6w2n>EYMzc_&aTJ_fgV2TNXKIQ zjas7%c80kku)IL=D|&jb@Jna$b7k#C4alH}K?W`O_ovD_ClTPcIs2b#%vI9clZ|5g zcCnh;ele7Z$2NE$PO89>t{u33+Qdh%D{Id`nX|=w9!1Q7%9(fz@u=MIBHNWPh7n=l zeagGvI^p6y(RwmrunqvDG3E^A>E}3TA=TW*69myZ#81Z$6hzV@(ZSQ1bMz{yIjQzB zhI)?KH@2t)nA20b;+Yonlr3TP9q>YQrWpiwyIH^409a%ZQEv(lP0hVO@;k0ckWP*i znSJuWB{C1%?7Bq9gf<(iQmuuvL*XkjTlgTd5h68$z5YqK;r z%!J*cv$)H&dyO>0)~f^LkA2$`@`aB5bNazMAmeirz&f6K1p={0sp%@Rb1#Id884)c zUaq{B<06xER9qBmCAlDFVXnxI5Un>3vu!Dgsby>1?8kIo(^J}+C-qKDfJW1Do_R&a zWv|LR$Y~Wd$yd^Z7Od6z#1^hA{WXzLgi%^5wH4d1OU7IR`YPHTk!tPX2N;{n{XZDh zXlj+M0!-5QaQC|sl##C$G@Vy0(uB=)ajAapda75jyf+f?Twog1>&GrT*5_a4&g~5O zjgUYNbBwDfNn&%eQQCNx>W|@2xKV5=7!-X%5oWmbub##F%c41P`9voGpR6*Tp+yC% zPuZj>Eppfq)#Nf9xbb~f{7jCu3vkPLID3{j^;C~V3wJu%1w%*2a~=5HhpY(jsy6wV zM9XZKR~WTJ_nkx-GzgljX5X2tZ|RJ&advYd`WOUz*|iXPxTNyZaJSAaDSy)UlBj6*W2U!tIkwjRtJCRu(AR~ekOVsg_NgJrZ8Q3 zky>Q=tR;EN`!-7iI*3-FFErW$k$&FRS83!2D&CPj$|Ems2CeNTFJNqK*PX>yB9sA_ zhWKh692gsph#!63IBI#;Wlr64-YG zUF}O;(CVj0n%R_wMmTnH4%$hoZ?KCmitG02SC3a=6g2s%zfVEIJ7^Y5Fq&kq89%uO zK_3v(kWxv+x{EeUTLKD4LVB-gjfthhjnc9OMTRm)H(JBj`S6EW z_RVbC{e+3Z`w%OAkar4`U8e~YW=%A04@U0vrlk4>#TMg}+=jA0(F^dhj@SYzHpz`h)6^3BFcKsn$KgFz6r|k?zet7v- zQ~@lPk`Ann)J3iX&~!mzVRZPo;1>Il*N^V1i+Cdr?acPoTe99`flPjn3BgpK(-q;z zP6)?nMIp9@^G)L((Xk#X(I53{Q<hvMCLT`I)g5gT%o>!2gCgV@bbf6NYgN>} z60?na#q1pMf& z-zFJJD57c`Zji?f;0bnA60e`Is%e;_;m&IjTN=2MR4X>zBFnX8YpuUij`*^RqY6{H zQf(c3U3^Pp!BWg`_DoIrtawLUB1n^(`yJJ5egNJm!Z8b_aE1KkYwTTU7(_MbHP#OG z&x9Hb@Yh{^vj+`)5`+P$o+zLzqX>E|*O_U{FdF31Kt?ton9=6l21L%J;h@SXAwIX+ za+^7|Egv&U5cg4^GgG{Zpb~n2R^W8H8fcgSChUF+iYjHdFh701|Ncb%o|nNR4__58 z!U_pDDVP@+T55!4hUtQ*mK5B=*z1euA$I%@^G0pOLhAfuf4nYWag(_9(7D>YN-|)3 zmWa*uHfHcbPz8%{B7%rr4ohcSN3ahm)U>a92~m(f)}s1!uK9QaY2DdQd8oOitqVeO zLEeIG$z256PaZ4UXwY}l%U#LI3unm{G!gc8tOBb2+fvakpLt*Pe5)oVrT%x4hM>no zUuzQ8`g{w81;;zUzPf%fpI?Y^n?&0@xxJrfAAVwNBn;x=U|hAj5*UuYe#!NB+LT?- zB*l7>q>wa|K?91o+$h}?!qB_RM}|U8_*4R^<+VmP0C&yte(XZe8-(s?sYxd&Z9?8F z_}Y?u7;R&Hy2%n(fmffSyME@TdJr~S!|-JrN)Nz>;%Z3)2HX(KJ%^P(VYr1J3qLki z5-vxMx5Vc6j}w!Bz71S>k0l`x-tD2#F!pubytVJ<>f9^e$VWYIndxKS>~VS#pEnU| z^ps*+F0oc_#1xP8NCfS4dSZvZw~L>tU1IXb`T-u1?litPQ)xnA%c-SLY>d)pz-Q8; zk3hG!dMvOGXbxERLj>gV#@;20z$t^sV8Rr???K`ZMk$Ym! zq!a83eP}H6r*XYwWq%RpZzx)F$pTk6%|qMJesoC@&2;uteS>h|Kn2t^w%565S+3aR zhsE(KtSTC=LUVHZ`Jbc%Y~|#M-!2Mg#ICcghKnjdE94os^P*sS@uK9)Z(yM}{-+cA%fzt& zS!(OQzO0^4?V3dn4awxhVFF=G$$f_HR%p2|&$rt45G?I{3J*w+HW z6a+qZJtPigM3MdF)LSjnC&}IXK4BW<3?4q0>PWJP;pc)6jLEw*cSlg6hk&>2SMw)D z^xY{0efK%AjUvmefN_Vue2kw8IqV8;>K}Su-N|C(LxPS zcY_!~I{qqD`zh5p4@N{IlY<2ii70ySv4&XwvsF|xv9HG%r`28uQT6jrxFz%f=Zwv_ zSI(A;r#F#ZuLK3Nei*+eDuZW&k)0#arjpjdrGUrYIFs7M$z!L@(tG>Cl^l8lT7o1s zs(%{p88PJXi^c^(LiJafg|xH8at#r=m|S+P{f39^y_pay{=GFYLB zHUbTksF)eX^Hq>Q1j9T_&qMq+pNub+%y(C4mV;G0RP6|tCTM~Pe z)e5;hB@#v!2iKw|4ujD36;>nrnw3TJIsA}X?k(IB!PEHU{PT#M3TsG112w<&oYdv` zo5gF0vEKKx&v0^^;H&h#-0EAz##D**Ez-`>k54p)X$^3RQa8%nP@_i2{4ZbCtuPcd zFd#c_1I_!e{q1osi=qS89i~7QtU!x_-~!cL>Y}`&WN52)W6ttHii4GO8Eus4hkHP% z8*TGm6Z^gJ-BuKp&@IfZB<_UWqG=GM)l@d|P3D>Je&+Hz!2kJ`BiOtI7C)Es!ce~T zHe9w2Xx;*Rilza8gB@cQi)#1BAH+vXccYLUC8Y@V^( z(Ky%;lUy>zYh%><`dfV&MYmU|;zYzvpK|e9$tgnv_FunRKMCHhjTe1KI##Yw*bFzW z<$LI3TY7t7avYXeqkonirPz%WOwjsS>&|(`J`?TI-xW6z)w)1?ycbnNgg3<8C{;=3 z+NND`A0u7W-H9K-zA&1LGTfu2pXkS4om04vF};7U4VJ56fOy?r*=*4-2lzk_qB!xsOM+^``X>Qofwj~2Z(-d4a9}V zF)M0bni_pM2(7ADRP1kQ!RhMd-Y#XDSss}4eka_U$7ivD8EtO&qyB)mb} zcvuMTAV98K;6%?@&lqhgN>heEv>Xfr_F^-{Nb9l>jbr2-W9Bdrb`1T=P;g^Tk~B}*v$9X z3_e`Cq#`90MD4Bi`M>(7Rf9S``5nbpNHv&0}$Ew@%+YP0LA-+@hu3@~}0~Y%e8CC1SY` zb9%14C4ui&Ks3A!TGV+L7trN`)f}_(VgEzZTgi)V(iEdxn)(UVifw8s)2;@2hlIC^ z#1^&+U-d82-9pdnR13B~i4R*BHk7u--4zu^Ve>-SSGvptFdj&7eq?{3nEHbL(0bC| zKy2?-Wb%{J0)a9UvS{A}_mf9XYN}qo%9LH)jJyRG&GACgrg!;$Q!~X*ww%S%32f$-EYSH{N>1oe$}7fc5BrCPgWP>wVAmYs zX3MDQ{w-r6#yIlLOVPRJqF=raMfJ5UXOGOcs^|Iv@}2D7xE;$NPKMP438j!yh>Kb# zV=!I{x<&XxCR!59+X|n^G=SC%%`bpc*x4eJGPZ@)0Ju6}yuw~n6bu%TOh*HPM}^)R z~2tbA?bgHddUo)<+Ux`3rPa6LTH&9rL^D zejRZ(PMN%XClWu*n#uh*{xN)vI*aLoth&}Z33 z;t}LVlNUorSqqkWeOteZ#f++peMc;1t<~}}>WI*3RAEFw)V4HkMQf2VzcsDB97bzY zIT95+sZ-+|k<(^!vvy4&#ojk+)Y}4LhE}Nc$j+ve`>Ir5*`E(tU;6-JNNwafXuDE} zSYitjBtMQ?C!&eY-R(G=&3mKkng!v#+XPbWX2lfQCXN-^CeZuUsath_Zy8Q{Z~I-k zUdNWT7we5-C2ZKqL7fr_R=r7JZTa$cmsATY5mKmbsp%XXoKHUhkaS^63& zO$lLJ!x_qV+$UuSU)y>Ec@-9W_;zzH6=moYp}H0A^#qa0Zmc zda|ftHtL=Ts@uGBvc}A2#zA#TdbgCG#7Y+PN$9J>hn0Rq8y-*^#i{O3qq9)s6G|j2 zI=irGopfk+mDVxPIwJ1sE;L%nHFoMOw*15624d;?uX2@4J^UQwRudgl-*8R663lVZ z*Ta2RkVjqyU_|bJ1y~m0$~t(5f(Wx61zD9ib^Yq5PAaPMYF`0~u&rrv(k)UczLRc> z0JaiYEa;nu@f4v0g34u*qVl{GSMqg3dBR3_qCCV2;|cTI`o@Bx+~D@TjvNl^D4al@ z)oc*2EFWsuN+L%YrT}x{?boLIhHkhCcynZH)5-Td#TeCu_5dT>?}i#Iuw+A0s;|fL zI%KeWNIyugNf|q6zL6e;!(zprGL~HKdCbiDFwOx)omyM3VJJ=>^HgQ0VspOVD6+s4 zC_@_KFW#O(9MweHiu+p<#NSZj#K{4(e2Hr}JW_r#@BMod}K!aZ#AB?OS>&6>iO`RsGJ}WIahBe??W9a>u)XI2l8HvOsLBkE zS}SvvNt{h=TF7O%*m)L_gL}DFYcdm;9kP!yC|``W`aV;T{hnu^ZX6-BoA;xDbYxnw z*ezE4SSkEyzm#M{I%kT=SuF&Gyrwh5@qiG5$0ooY!9XeB=YrB$V;w6M(%5dLKmN6B zRl+J(M_@G^JWS9oI9r-{w1n&rDQfNn8+DhgkKSLGX>D>#TB^Bspk?ioGCb?Goa>Jp zcd%NMS*Cx2a@)(>7q`*VGu~yckd_d*PG7NUoVZbMw$wRKCnGc`={l#b*bl8YMnp%rWlkBgB&71?`wDG);hyotn&u&GKq3M znHupfJH%jcIz?bQP7rDSmqGc7i>szWbz4xKg#nFfEek zBk(F*4HHggcR6_nQj@YP8NTNf(x_cOw;Z22Rviadibm_hiKWod8o(=JnZ~`; zJJuV5Pc#Bw+bpN>bv}-PK%zHBs;Ro4XE~vT;B;}v;fx5W?q(9VX_)S|9iQCc`*x`o zQZxmk4Jr9_j(ml~eQWiv&i+jcBUlSeYomzSbCw19exgbzz?|&sZ{&fI^;SXDZe(N+ z0TP#U(>D6{8u;*j@O3PLasa$|?|`^rDT94r=;gdK{~Q4lRcBFSdGXH`1}fx9xV0?z zVu_tizo={QUBtLZ?oX@5og$Wa#LWh0z8UAv2V!C0-Ez+ev;4b*z?|=~!{HXunwe7s zmPH9`n|AspC%oFh!*D)CXkN8X6xf)LnnMX^*OZQQr=d$*sr&R}{{UdvieDc!DSl;3 z@s0^r-aDN6zn%@@-mG3V54ZIMoJqSU9JzupmNSLy? z{t*DSZv?{xvC+j__HCC&QZR+|ww-9bN4O*7+OzYUWUOW!|1*&Uo>0-^+JJ%V=2rNK zndAo3Q9$t_Y2DSW`_{KIgIT~oNptL?61h( zPY_@HnEe=NA1(MkK@exYKx=^8b*LxvhsSm%1W#C!KXSyxNq;b2_4;y51Vu|WB#@)a zwbNp!+g`5f2VW9Y0gYNi==%Bh)CamTAEI<7s%eZd*X$xUAG89DqZ?0ES71)xOb`u; z8)_*sSv5?bKpbWCjOg$x1^15Ap9zEM>^wwl>$nP-3Wk zFqn&R7S~&gfuB_@xw!LNEfIL{+sSOjq~5h^?d=^@%-2k!*;?@pWp9e^S;ZZ5E-jsG zELe)2(%HMmu61hGCl4X2G^(IHL+ecB!qA(ROqF;sI<$%%z)si3TEAsQNJ^KTEe^HZ zh%+IU7AY}fOsKKt+;oKc1^T!b^FR#UzFVTGhpKFeUdK35~y+Z~Dc*$fBNHW-_x)Zcd7T$8dLpY6RZ=t6SJ1jNs#J`&viK^a4Z9+C=>j)4f5R63i z9{*^bQZMt4fG?;`zKi>UF%7N9c#24bsd1@D({F{Fo0YCF!!z0y+Rf3^ui+T^U@H^5 z@$yy2SOU!MCAvT?^?~f3IvX-CU-%izP5+3)IYqWHAVnb=`Qn{#T>7mm+Xd$=JAvRx zIuwo<^e%KZ`+0jnPch5D8;{Lnt8Inc;QVQ=uDLG>sxv1PSXrie{(;|}6}m@^bUOHJ z+>*9UJW0V7TzK+XdT3mTL(40WW#o{EA1wQyIRx0y%wa9+BjdrzPV>Vb>cbbJh}sXr z<7JlY0gm?dBH83=>IQ2{UhPXKWj`=H;a9@aW}vdQIoBdh-Sy)|(arY_d+dnJzdT?L zuttg~J($N(Adh&bSvSLcuo1Y*Dr1$%2Fun&PPXf9d3p~?xKfz6)UzfHu1XJAGn+wrg zU9)=Vca>ksT~=hJqh~5x2x6YO&W>4jwb9MMcL-@3Nl z4{3jAguKUyHlZ(S^!jTO#-Nj+G&A!n-C-NMB{UYR0~tRF8__CKiuU zU?1StJ444RODhq?)McivGUyCnN*<0Ao1_P@7a8{Elv#l;>Mp0dAy3=7F$=0UX$kNC z#M0`}YPjKiX5w$~+$ZS-=aCCfpR_QaP;5pVoY0wwZV#wh7YLPo7wHd8F1adQo-`)I zUmb~8xk|w)V`+imiGiU(DDKx7=2W1C2MwreDAv-TXC~;u8>`|LZYBd%K2Yk-?WiEc z1oqokl9ThE2D-UXRguEiAG`-4hXy_Bub%{Byr6o6Xz) zh|TVlJG_hQm9nTda2ii=BBR_E^nPcynT4|^8`LG0CTv-0_@gIOkj8F49A(f9!pYbbU&^hd$tn6LBV|^+Iz|6{*kqHMH z`h`FbU&&gjn8CZR=rDVTqg4uh#Y~mW5#=OC{#e}qRa5n#xb>D%@P>a*8}P;bk-2Jr ziSZWw>Bb_jd!V;WG3}6A^=1~Q;qYNtRB^T9teha$;p=j<1@9<|{1GRtFb-}lP!tId^FILOW}wxN zXTi(!9R(N9ve>9A>CQKP&WxKrqch?UW={W10A}57SMZOZxEDDHNeeDoU&A|&TOJ?u zE3C1eGPS&$FtYYPpm7(3X*;{vQ{#0>W1L-*yn3vm>>dJs*kQJu2e1eQDt#6`(i(ZT z?x4*-HaXs}kE=g31R(XDn0JO{W*t|%WwgXTU1t&xJVXEBuIr3A>RDVL^=E$2UEys> zezGg*%zE0FYSwAL)pa=i`JZ*ke=kd}XE;T80*(EefX2P3UWV$M*jh0w83CVku>nU0 z1e&=1=FFpYacJ)@$)m!Y)rRk1Yut!dbU?=vC|3R zixXnyEktNqpY!UeUfkjNf>%qNgL2hJP92XZb8OMmb>NBPW0Bo{@B|13I)vYFhx9iG z?>5_<6Y8OloWZ|8E4}rHoXplZUtw6x>5!qp1pwGOO^v57 za(MJJ9U*udbaAo!ZQnnB4E!d|o;7G4R}B7L&{Pzc7*adf!wVTxBUnf2bB z&3ql*o5`U-qN0^oFawXhz8}|XYXc?0X5U3(ZE$H^qvP>hx~FKkXO~|HM&@HCs|6zt zEpo|Ri}n81rrswONniV!eX>K69fF2O1lynvIbS-1n>nA6qj+`|bc_n3BF%ack>> z2`PlYCZX>PHcBG3Y3h$+eTrErDl7-76?Si^ljpG~rY15G_>mQ)n+Y z4DkI^)V;8^-GbYtT{{o_{`tebcsKLy!CEKWbDSfm#U<9nQ3;Ne(7_delg|p%nY|xQRW4u; z{uZL!3Q6*u9qrTGDQQ9Bk=XgKQ4pBKp8S@c!mq7)qJ!Xx7H;`6M-HO`4Uvey!0=LY zv_w|SK4b67;lXw`HQ?KwO5feKqm=S4Xhq&C@Y zPOjJVFO2xi_JtiAz+4~CDG*Z3`3TPKC2Ysa@0m+sf@i-e9~;YrWWic$1X&a+yww!R zk0%74_&FML{2>vyOF{Z5Jx_C>dK`xdxs4#l_#NS0mDXIH3GFsoz9JzC?ns%ZY!98i zjVC@Wl1u;eFE zipKn7J%=ANsYZOA;_gXyNtN2k0%GImdaXujPd=kFi>D*5ilQnDI67mf?DUd_=B4?mX6f7HG}|i- zIhLez`{0Ky>W`AY5F>pY5cAm+7kLx2_m&+%96Pl|0a2$MCCM60r}qY%s3+`J(ljx= zhex7ac`I(iDfAgOJIMed@D;%T+#4BUs>ndqB+ibkEM=Ku+Gg?wg`SU*teD$$RPTKb z)SM*x0O)#8_*p+Gvqf)!4V%%MK+|ojd-AW|cpu82qf-tI0})H;7dUwd(Trm-dPJgO zFBluvl2`&?4>X8|9`MX=^AVr~O^jK@pV6IWy%WW+Ki}}Q92}Z?BX!Q;;;1EM|GL{p zUzB69#s}A@C=tnLx13Y24*oS`xvH5Z!T4 z#UPNvCy9T%LSnO4N}S-qDOM$o6O`E(8BS4fX~I}$iYRwil4VRPPcLVHU2aB#E_hCI zRgHtx6B&t4s3`unExfeloVelB3LsM^bC2n!7?g8TFXup8!d3=F(f9|HV~+_B9cFNG z96&lJgAih((;I6HWfMcs7kMFE_?X5>aUI4TnwC1IJqjW*(?0No*{Z(DID=DxVnH9- zK$6GR#Oi5v1Bsb`Y)3Om2fuYqv1)0^6k8iZlDcGCBCIzc@61I1!o%m(wdYG=-4-^# zRjLzGSDVt%kJA{koL%mW(eSYjI6)%>-D-HjNohY(a3=qMvRfBWbF(6HaKtiXQqK>Mk*9(!8D8^U6C6If4L9!8z$rsAUZFG1KfH-i%%eC zulfbcDR7E^Xb6#i_Gp5Rz(8&V7%^!3&+6O&JK=d&aPHwF7&dDbmOBF-|5HXWfQ*TpYnf1k)WMg3FJi+pk~6lE#=#((Le{GYCUk*w^6P@&RaLP$W}vlq7V zA|uNS88EHiGRMP&z|J$MKP&f7>VkjY7N&QLa0C95!TuBff{Nq?o+0oz{(Ot%Py7oGf*1IhP!L`U2-tpMQvY5x z{*Q=g#BcrM+oXT$f3XtoA24XIDgHN}cjrZYUMw_vfo}i;yLf1Ur91e4>VL6%;|0Dm z1%&7Qcl}=kzrVoGrUNJW`GB1}FWUPetoj9hI^%bJK+)A~|M$c2B3$*QX!c*CFPicq zEbs-sFZXv>EsLW5yLvAo!(PY`6#SN9ks$iF%!>$`7cx4;nBpDF*0QJ{1$Z+uMxh&}eDj&T4b)5A3*mnSUX2}ou_uJ&( z?#X{uf`KUx{pqZL92O%N7e^yk%RhXN|0?^h&+@0o@yloVr+fq{`{lvV{a-GOk}TBk TmlPWq8<+uzDd7 \(.*\)$'` - if expr "$link" : '/.*' > /dev/null; then - PRG="$link" - else - PRG=`dirname "$PRG"`"/$link" - fi +app_path=$0 + +# Need this for daisy-chained symlinks. +while + APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path + [ -h "$app_path" ] +do + ls=$( ls -ld "$app_path" ) + link=${ls#*' -> '} + case $link in #( + /*) app_path=$link ;; #( + *) app_path=$APP_HOME$link ;; + esac done -SAVED="`pwd`" -cd "`dirname \"$PRG\"`/" >/dev/null -APP_HOME="`pwd -P`" -cd "$SAVED" >/dev/null -APP_NAME="Gradle" -APP_BASE_NAME=`basename "$0"` +# This is normally unused +# shellcheck disable=SC2034 +APP_BASE_NAME=${0##*/} +APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. -DEFAULT_JVM_OPTS="" +DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' # Use the maximum available, or set MAX_FD != -1 to use that value. -MAX_FD="maximum" +MAX_FD=maximum warn () { echo "$*" -} +} >&2 die () { echo echo "$*" echo exit 1 -} +} >&2 # OS specific support (must be 'true' or 'false'). cygwin=false msys=false darwin=false nonstop=false -case "`uname`" in - CYGWIN* ) - cygwin=true - ;; - Darwin* ) - darwin=true - ;; - MINGW* ) - msys=true - ;; - NONSTOP* ) - nonstop=true - ;; +case "$( uname )" in #( + CYGWIN* ) cygwin=true ;; #( + Darwin* ) darwin=true ;; #( + MSYS* | MINGW* ) msys=true ;; #( + NONSTOP* ) nonstop=true ;; esac CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + # Determine the Java command to use to start the JVM. if [ -n "$JAVA_HOME" ] ; then if [ -x "$JAVA_HOME/jre/sh/java" ] ; then # IBM's JDK on AIX uses strange locations for the executables - JAVACMD="$JAVA_HOME/jre/sh/java" + JAVACMD=$JAVA_HOME/jre/sh/java else - JAVACMD="$JAVA_HOME/bin/java" + JAVACMD=$JAVA_HOME/bin/java fi if [ ! -x "$JAVACMD" ] ; then die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME @@ -81,7 +132,7 @@ Please set the JAVA_HOME variable in your environment to match the location of your Java installation." fi else - JAVACMD="java" + JAVACMD=java which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. Please set the JAVA_HOME variable in your environment to match the @@ -89,84 +140,105 @@ location of your Java installation." fi # Increase the maximum file descriptors if we can. -if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then - MAX_FD_LIMIT=`ulimit -H -n` - if [ $? -eq 0 ] ; then - if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then - MAX_FD="$MAX_FD_LIMIT" - fi - ulimit -n $MAX_FD - if [ $? -ne 0 ] ; then - warn "Could not set maximum file descriptor limit: $MAX_FD" - fi - else - warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" - fi +if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then + case $MAX_FD in #( + max*) + # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC3045 + MAX_FD=$( ulimit -H -n ) || + warn "Could not query maximum file descriptor limit" + esac + case $MAX_FD in #( + '' | soft) :;; #( + *) + # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked. + # shellcheck disable=SC3045 + ulimit -n "$MAX_FD" || + warn "Could not set maximum file descriptor limit to $MAX_FD" + esac fi -# For Darwin, add options to specify how the application appears in the dock -if $darwin; then - GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" -fi +# Collect all arguments for the java command, stacking in reverse order: +# * args from the command line +# * the main class name +# * -classpath +# * -D...appname settings +# * --module-path (only if needed) +# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables. + +# For Cygwin or MSYS, switch paths to Windows format before running java +if "$cygwin" || "$msys" ; then + APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) + CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) + + JAVACMD=$( cygpath --unix "$JAVACMD" ) -# For Cygwin, switch paths to Windows format before running java -if $cygwin ; then - APP_HOME=`cygpath --path --mixed "$APP_HOME"` - CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` - JAVACMD=`cygpath --unix "$JAVACMD"` - - # We build the pattern for arguments to be converted via cygpath - ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` - SEP="" - for dir in $ROOTDIRSRAW ; do - ROOTDIRS="$ROOTDIRS$SEP$dir" - SEP="|" - done - OURCYGPATTERN="(^($ROOTDIRS))" - # Add a user-defined pattern to the cygpath arguments - if [ "$GRADLE_CYGPATTERN" != "" ] ; then - OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" - fi # Now convert the arguments - kludge to limit ourselves to /bin/sh - i=0 - for arg in "$@" ; do - CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` - CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option - - if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition - eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` - else - eval `echo args$i`="\"$arg\"" + for arg do + if + case $arg in #( + -*) false ;; # don't mess with options #( + /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath + [ -e "$t" ] ;; #( + *) false ;; + esac + then + arg=$( cygpath --path --ignore --mixed "$arg" ) fi - i=$((i+1)) + # Roll the args list around exactly as many times as the number of + # args, so each arg winds up back in the position where it started, but + # possibly modified. + # + # NB: a `for` loop captures its iteration list before it begins, so + # changing the positional parameters here affects neither the number of + # iterations, nor the values presented in `arg`. + shift # remove old arg + set -- "$@" "$arg" # push replacement arg done - case $i in - (0) set -- ;; - (1) set -- "$args0" ;; - (2) set -- "$args0" "$args1" ;; - (3) set -- "$args0" "$args1" "$args2" ;; - (4) set -- "$args0" "$args1" "$args2" "$args3" ;; - (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; - (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; - (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; - (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; - (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; - esac fi -# Escape application args -save () { - for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done - echo " " -} -APP_ARGS=$(save "$@") - -# Collect all arguments for the java command, following the shell quoting and substitution rules -eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" - -# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong -if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then - cd "$(dirname "$0")" +# Collect all arguments for the java command; +# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of +# shell script including quotes and variable substitutions, so put them in +# double quotes to make sure that they get re-expanded; and +# * put everything else in single quotes, so that it's not re-expanded. + +set -- \ + "-Dorg.gradle.appname=$APP_BASE_NAME" \ + -classpath "$CLASSPATH" \ + org.gradle.wrapper.GradleWrapperMain \ + "$@" + +# Stop when "xargs" is not available. +if ! command -v xargs >/dev/null 2>&1 +then + die "xargs is not available" fi +# Use "xargs" to parse quoted args. +# +# With -n1 it outputs one arg per line, with the quotes and backslashes removed. +# +# In Bash we could simply go: +# +# readarray ARGS < <( xargs -n1 <<<"$var" ) && +# set -- "${ARGS[@]}" "$@" +# +# but POSIX shell has neither arrays nor command substitution, so instead we +# post-process each arg (as a line of input to sed) to backslash-escape any +# character that might be a shell metacharacter, then use eval to reverse +# that process (while maintaining the separation between arguments), and wrap +# the whole thing up as a single "set" statement. +# +# This will of course break if any of these variables contains a newline or +# an unmatched quote. +# + +eval "set -- $( + printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" | + xargs -n1 | + sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' | + tr '\n' ' ' + )" '"$@"' + exec "$JAVACMD" "$@" diff --git a/gradlew.bat b/gradlew.bat index e95643d6..6689b85b 100644 --- a/gradlew.bat +++ b/gradlew.bat @@ -1,4 +1,20 @@ -@if "%DEBUG%" == "" @echo off +@rem +@rem Copyright 2015 the original author or authors. +@rem +@rem Licensed under the Apache License, Version 2.0 (the "License"); +@rem you may not use this file except in compliance with the License. +@rem You may obtain a copy of the License at +@rem +@rem https://www.apache.org/licenses/LICENSE-2.0 +@rem +@rem Unless required by applicable law or agreed to in writing, software +@rem distributed under the License is distributed on an "AS IS" BASIS, +@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +@rem See the License for the specific language governing permissions and +@rem limitations under the License. +@rem + +@if "%DEBUG%"=="" @echo off @rem ########################################################################## @rem @rem Gradle startup script for Windows @@ -9,19 +25,23 @@ if "%OS%"=="Windows_NT" setlocal set DIRNAME=%~dp0 -if "%DIRNAME%" == "" set DIRNAME=. +if "%DIRNAME%"=="" set DIRNAME=. +@rem This is normally unused set APP_BASE_NAME=%~n0 set APP_HOME=%DIRNAME% +@rem Resolve any "." and ".." in APP_HOME to make it shorter. +for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi + @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. -set DEFAULT_JVM_OPTS= +set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" @rem Find java.exe if defined JAVA_HOME goto findJavaFromJavaHome set JAVA_EXE=java.exe %JAVA_EXE% -version >NUL 2>&1 -if "%ERRORLEVEL%" == "0" goto init +if %ERRORLEVEL% equ 0 goto execute echo. echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. @@ -35,7 +55,7 @@ goto fail set JAVA_HOME=%JAVA_HOME:"=% set JAVA_EXE=%JAVA_HOME%/bin/java.exe -if exist "%JAVA_EXE%" goto init +if exist "%JAVA_EXE%" goto execute echo. echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% @@ -45,38 +65,26 @@ echo location of your Java installation. goto fail -:init -@rem Get command-line arguments, handling Windows variants - -if not "%OS%" == "Windows_NT" goto win9xME_args - -:win9xME_args -@rem Slurp the command line arguments. -set CMD_LINE_ARGS= -set _SKIP=2 - -:win9xME_args_slurp -if "x%~1" == "x" goto execute - -set CMD_LINE_ARGS=%* - :execute @rem Setup the command line set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + @rem Execute Gradle -"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* :end @rem End local scope for the variables with windows NT shell -if "%ERRORLEVEL%"=="0" goto mainEnd +if %ERRORLEVEL% equ 0 goto mainEnd :fail rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of rem the _cmd.exe /c_ return code! -if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 -exit /b 1 +set EXIT_CODE=%ERRORLEVEL% +if %EXIT_CODE% equ 0 set EXIT_CODE=1 +if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE% +exit /b %EXIT_CODE% :mainEnd if "%OS%"=="Windows_NT" endlocal diff --git a/sample/build.gradle b/sample/build.gradle index 4d4096c5..13e1c9f3 100644 --- a/sample/build.gradle +++ b/sample/build.gradle @@ -1,15 +1,16 @@ -apply plugin: 'com.android.application' -apply plugin: 'kotlin-android' -apply plugin: 'kotlin-android-extensions' +plugins { + alias(deps.plugins.android.application) + alias(deps.plugins.kotlin.android) +} android { - buildToolsVersion versions.android.buildTools - compileSdkVersion versions.sdk.target + buildToolsVersion deps.versions.buildTools.get() + compileSdkVersion deps.versions.compileSdk.get().toInteger() defaultConfig { applicationId "io.fotoapparat.sample" - minSdkVersion versions.sdk.minimum - targetSdkVersion versions.sdk.target + minSdkVersion deps.versions.minSdk.get() + targetSdkVersion deps.versions.compileSdk.get() versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" @@ -20,10 +21,18 @@ android { proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } + buildFeatures { + viewBinding true + } + compileOptions { + sourceCompatibility JavaVersion.VERSION_11 + targetCompatibility JavaVersion.VERSION_11 + } + namespace = "io.fotoapparat.sample" } dependencies { implementation project(':fotoapparat') - implementation "org.jetbrains.kotlin:kotlin-stdlib:${versions.kotlin}" - implementation "androidx.appcompat:appcompat:${versions.android.appcompat}" + implementation deps.kotlin.stdlib + implementation deps.androidx.appcompat } diff --git a/sample/src/main/AndroidManifest.xml b/sample/src/main/AndroidManifest.xml index 8db8e5da..662d0e62 100644 --- a/sample/src/main/AndroidManifest.xml +++ b/sample/src/main/AndroidManifest.xml @@ -1,7 +1,6 @@ + xmlns:tools="http://schemas.android.com/tools"> diff --git a/sample/src/main/java/io/fotoapparat/sample/MainActivity.kt b/sample/src/main/java/io/fotoapparat/sample/MainActivity.kt index 0410994b..5efe9b0c 100644 --- a/sample/src/main/java/io/fotoapparat/sample/MainActivity.kt +++ b/sample/src/main/java/io/fotoapparat/sample/MainActivity.kt @@ -13,14 +13,15 @@ import io.fotoapparat.log.logcat import io.fotoapparat.parameter.Flash import io.fotoapparat.parameter.Zoom import io.fotoapparat.result.transformer.scaled +import io.fotoapparat.sample.databinding.ActivityMainBinding import io.fotoapparat.selector.* -import kotlinx.android.synthetic.main.activity_main.* import java.io.File import kotlin.math.roundToInt class MainActivity : AppCompatActivity() { private val permissionsDelegate = PermissionsDelegate(this) + private lateinit var binding: ActivityMainBinding private var permissionsGranted: Boolean = false private var activeCamera: Camera = Camera.Back @@ -37,24 +38,24 @@ class MainActivity : AppCompatActivity() { permissionsGranted = permissionsDelegate.hasCameraPermission() if (permissionsGranted) { - cameraView.visibility = View.VISIBLE + binding.cameraView.visibility = View.VISIBLE } else { permissionsDelegate.requestCameraPermission() } fotoapparat = Fotoapparat( context = this, - view = cameraView, - focusView = focusView, + view = binding.cameraView, + focusView = binding.focusView, logger = logcat(), lensPosition = activeCamera.lensPosition, cameraConfiguration = activeCamera.configuration, cameraErrorCallback = { Log.e(LOGGING_TAG, "Camera error: ", it) } ) - capture onClick takePicture() - switchCamera onClick changeCamera() - torchSwitch onCheckedChanged toggleFlash() + binding.capture onClick takePicture() + binding.switchCamera onClick changeCamera() + binding.torchSwitch onCheckedChanged toggleFlash() } private fun takePicture(): () -> Unit = { @@ -97,7 +98,7 @@ class MainActivity : AppCompatActivity() { adjustViewsVisibility() - torchSwitch.isChecked = false + binding.torchSwitch.isChecked = false Log.i(LOGGING_TAG, "New camera position: ${if (activeCamera is Camera.Back) "back" else "front"}") } @@ -140,7 +141,7 @@ class MainActivity : AppCompatActivity() { permissionsGranted = true fotoapparat.start() adjustViewsVisibility() - cameraView.visibility = View.VISIBLE + binding.cameraView.visibility = View.VISIBLE } } @@ -152,21 +153,21 @@ class MainActivity : AppCompatActivity() { (it.zoom as? Zoom.VariableZoom) ?.let { cameraZoom = it - focusView.scaleListener = this::scaleZoom - focusView.ptrListener = this::pointerChanged + binding.focusView.scaleListener = this::scaleZoom + binding.focusView.ptrListener = this::pointerChanged } ?: run { - zoomLvl?.visibility = View.GONE - focusView.scaleListener = null - focusView.ptrListener = null + binding.zoomLvl.visibility = View.GONE + binding.focusView.scaleListener = null + binding.focusView.ptrListener = null } - torchSwitch.visibility = if (it.flashModes.contains(Flash.Torch)) View.VISIBLE else View.GONE + binding.torchSwitch.visibility = if (it.flashModes.contains(Flash.Torch)) View.VISIBLE else View.GONE } ?: Log.e(LOGGING_TAG, "Couldn't obtain capabilities.") } - switchCamera.visibility = if (fotoapparat.isAvailable(front())) View.VISIBLE else View.GONE + binding.switchCamera.visibility = if (fotoapparat.isAvailable(front())) View.VISIBLE else View.GONE } //When zooming slowly, the values are approximately 0.9 ~ 1.1 @@ -182,13 +183,13 @@ class MainActivity : AppCompatActivity() { val value = cameraZoom.zoomRatios[progress] val roundedValue = ((value.toFloat()) / 10).roundToInt().toFloat() / 10 - zoomLvl.visibility = View.VISIBLE - zoomLvl.text = String.format("%.1f×", roundedValue) + binding.zoomLvl.visibility = View.VISIBLE + binding.zoomLvl.text = String.format("%.1f×", roundedValue) } private fun pointerChanged(fingerCount: Int){ if(fingerCount == 0) { - zoomLvl?.visibility = View.GONE + binding.zoomLvl.visibility = View.GONE } } } diff --git a/settings.gradle b/settings.gradle deleted file mode 100644 index d16de12d..00000000 --- a/settings.gradle +++ /dev/null @@ -1,6 +0,0 @@ -include ':fotoapparat' - -include ':fotoapparat-adapters:rxjava' -include ':fotoapparat-adapters:rxjava2' - -include ':sample' \ No newline at end of file diff --git a/settings.gradle.kts b/settings.gradle.kts new file mode 100644 index 00000000..081f4096 --- /dev/null +++ b/settings.gradle.kts @@ -0,0 +1,31 @@ +@file:Suppress("UnstableApiUsage") + +import org.gradle.api.initialization.resolve.RepositoriesMode + +pluginManagement { + repositories { + google(); mavenCentral(); gradlePluginPortal() + } +} + +dependencyResolutionManagement { + repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) + repositories { + // uncomment if you published local changes to test + // DO NOT MERGE THIS UNCOMMENTED + // mavenLocal() + google() + mavenCentral() + gradlePluginPortal() + } + versionCatalogs { + create("deps") { + from(files("gradle/deps.versions.toml")) + // Update versions and dependencies not used in tooling here. + } + } +} + +include(":fotoapparat") +include(":fotoapparat-adapters:rxjava3") +include(":sample") \ No newline at end of file