Compare commits

..

4 commits

Author SHA1 Message Date
e8c4abc6a3
Day 8 2024-12-08 01:12:44 -07:00
f248ccde17
Day 7 2024-12-08 01:12:44 -07:00
f2497d4e3a
Day 6 optimized 2024-12-08 01:12:44 -07:00
3cb7439ebc
Add repo utils wip 2024-12-08 01:12:44 -07:00
67 changed files with 1433 additions and 20 deletions

2
.envrc
View file

@ -1 +1,3 @@
use flake use flake
PATH_add ./scripts

3
.gitignore vendored
View file

@ -1,2 +1,3 @@
**/input.txt **/input.txt
.direnv .direnv
node_modules

10
.idea/compiler.xml Normal file
View file

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="CompilerConfiguration">
<bytecodeTargetLevel>
<module name="kotlin" target="21" />
<module name="kotlin.main" target="21" />
<module name="kotlin.test" target="21" />
</bytecodeTargetLevel>
</component>
</project>

17
.idea/gradle.xml Normal file
View file

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="GradleMigrationSettings" migrationVersion="1" />
<component name="GradleSettings">
<option name="linkedExternalProjectsSettings">
<GradleProjectSettings>
<option name="externalProjectPath" value="$PROJECT_DIR$/entrypoints/kotlin" />
<option name="gradleHome" value="" />
<option name="modules">
<set>
<option value="$PROJECT_DIR$/entrypoints/kotlin" />
</set>
</option>
</GradleProjectSettings>
</option>
</component>
</project>

6
.idea/kotlinc.xml Normal file
View file

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="KotlinJpsPluginSettings">
<option name="version" value="2.0.21" />
</component>
</project>

View file

@ -0,0 +1,10 @@
<component name="libraryTable">
<library name="Gradle: org.apiguardian:apiguardian-api:1.1.2" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.apiguardian" artifactId="apiguardian-api" version="1.1.2" baseVersion="1.1.2" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.apiguardian/apiguardian-api/1.1.2/a231e0d844d2721b0fa1b238006d15c6ded6842a/apiguardian-api-1.1.2.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES />
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.jetbrains:annotations:13.0" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.jetbrains" artifactId="annotations" version="13.0" baseVersion="13.0" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/919f0dfe192fb4e063e7dacadee7f8bb9a2672a9/annotations-13.0.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/5991ca87ef1fb5544943d9abc5a9a37583fabe03/annotations-13.0-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.jetbrains.kotlin:kotlin-stdlib:2.0.21" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.jetbrains.kotlin" artifactId="kotlin-stdlib" version="2.0.21" baseVersion="2.0.21" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/2.0.21/618b539767b4899b4660a83006e052b63f1db551/kotlin-stdlib-2.0.21.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/2.0.21/4789c95c3f2037f6689c0786baf1684275734ad3/kotlin-stdlib-2.0.21-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.jetbrains.kotlin:kotlin-test:2.0.21" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.jetbrains.kotlin" artifactId="kotlin-test" version="2.0.21" baseVersion="2.0.21" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-test/2.0.21/c6ea143e356327ddfda57e53e829c553e3b45b64/kotlin-test-2.0.21.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-test/2.0.21/b78aebe27209f0422aa19c6e5f8b83dd32716b87/kotlin-test-2.0.21-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.jetbrains.kotlin:kotlin-test-junit5:2.0.21" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.jetbrains.kotlin" artifactId="kotlin-test-junit5" version="2.0.21" baseVersion="2.0.21" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-test-junit5/2.0.21/9eff871dcc7b7cbc6050945b906dfdd6d5b76f02/kotlin-test-junit5-2.0.21.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-test-junit5/2.0.21/e7609990cba72d2a3ce763011ae79e81b9904b51/kotlin-test-junit5-2.0.21-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.junit.jupiter:junit-jupiter-api:5.10.1" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.junit.jupiter" artifactId="junit-jupiter-api" version="5.10.1" baseVersion="5.10.1" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-api/5.10.1/eb90c7d8bfaae8fdc97b225733fcb595ddd72843/junit-jupiter-api-5.10.1.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-api/5.10.1/b281dbb5921ce56b37b6e07a2502f663ca6c8db6/junit-jupiter-api-5.10.1-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.junit.jupiter:junit-jupiter-engine:5.10.1" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.junit.jupiter" artifactId="junit-jupiter-engine" version="5.10.1" baseVersion="5.10.1" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-engine/5.10.1/6c9ff773f9aa842b91d1f2fe4658973252ce2428/junit-jupiter-engine-5.10.1.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.jupiter/junit-jupiter-engine/5.10.1/624f71a8d76185f2ac8d234c686bbdab0bd28ae0/junit-jupiter-engine-5.10.1-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.junit.platform:junit-platform-commons:1.10.1" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.junit.platform" artifactId="junit-platform-commons" version="1.10.1" baseVersion="1.10.1" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-commons/1.10.1/2bfcd4a4e38b10c671b6916d7e543c20afe25579/junit-platform-commons-1.10.1.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-commons/1.10.1/ba681bcc1df2c719bf3b8ddb297e65eadb9d7499/junit-platform-commons-1.10.1-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.junit.platform:junit-platform-engine:1.10.1" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.junit.platform" artifactId="junit-platform-engine" version="1.10.1" baseVersion="1.10.1" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-engine/1.10.1/f32ae4af74fde68414b8a3d2b7cf1fb43824a83a/junit-platform-engine-1.10.1.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-engine/1.10.1/886c197f5fcfe9eaf0d1dde20aa1bd3abd653f44/junit-platform-engine-1.10.1-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.junit.platform:junit-platform-launcher:1.10.1" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.junit.platform" artifactId="junit-platform-launcher" version="1.10.1" baseVersion="1.10.1" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-launcher/1.10.1/ce85bf5e38bee0989ded9bd468dd4ff78dc0cfa8/junit-platform-launcher-1.10.1.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.junit.platform/junit-platform-launcher/1.10.1/62c17608a285a6246ed1f6c8112eddd075c0a957/junit-platform-launcher-1.10.1-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -0,0 +1,12 @@
<component name="libraryTable">
<library name="Gradle: org.opentest4j:opentest4j:1.3.0" type="java-imported" external-system-id="GRADLE">
<properties groupId="org.opentest4j" artifactId="opentest4j" version="1.3.0" baseVersion="1.3.0" />
<CLASSES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.opentest4j/opentest4j/1.3.0/152ea56b3a72f655d4fd677fc0ef2596c3dd5e6e/opentest4j-1.3.0.jar!/" />
</CLASSES>
<JAVADOC />
<SOURCES>
<root url="jar://$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.opentest4j/opentest4j/1.3.0/afb8ff23cffb021c56f333953aebfe6e8818568e/opentest4j-1.3.0-sources.jar!/" />
</SOURCES>
</library>
</component>

View file

@ -1,5 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<project version="4"> <project version="4">
<component name="FrameworkDetectionExcludesConfiguration">
<file type="web" url="file://$PROJECT_DIR$/entrypoints/kotlin" />
</component>
<component name="ProjectRootManager" version="2" languageLevel="JDK_21" default="true" project-jdk-name="21" project-jdk-type="JavaSDK"> <component name="ProjectRootManager" version="2" languageLevel="JDK_21" default="true" project-jdk-name="21" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/out" /> <output url="file://$PROJECT_DIR$/out" />
</component> </component>

View file

@ -4,6 +4,9 @@
<modules> <modules>
<module fileurl="file://$PROJECT_DIR$/.idea/aoc2024.iml" filepath="$PROJECT_DIR$/.idea/aoc2024.iml" /> <module fileurl="file://$PROJECT_DIR$/.idea/aoc2024.iml" filepath="$PROJECT_DIR$/.idea/aoc2024.iml" />
<module fileurl="file://$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/development/development.iml" filepath="$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/development/development.iml" /> <module fileurl="file://$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/development/development.iml" filepath="$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/development/development.iml" />
<module fileurl="file://$PROJECT_DIR$/.idea/modules/kotlin.iml" filepath="$PROJECT_DIR$/.idea/modules/kotlin.iml" />
<module fileurl="file://$PROJECT_DIR$/.idea/modules/kotlin.main.iml" filepath="$PROJECT_DIR$/.idea/modules/kotlin.main.iml" />
<module fileurl="file://$PROJECT_DIR$/.idea/modules/kotlin.test.iml" filepath="$PROJECT_DIR$/.idea/modules/kotlin.test.iml" />
<module fileurl="file://$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/nixos/nixos.iml" filepath="$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/nixos/nixos.iml" /> <module fileurl="file://$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/nixos/nixos.iml" filepath="$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/nixos/nixos.iml" />
<module fileurl="file://$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/pkgs-lib/pkgs-lib.iml" filepath="$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/pkgs-lib/pkgs-lib.iml" /> <module fileurl="file://$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/pkgs-lib/pkgs-lib.iml" filepath="$PROJECT_DIR$/.direnv/flake-inputs/ab78nf3ad8ly49zfyd3igw3f2n5q7fz4-source/pkgs/pkgs-lib/pkgs-lib.iml" />
</modules> </modules>

12
.idea/modules/kotlin.iml Normal file
View file

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<module external.linked.project.id="kotlin" external.linked.project.path="$MODULE_DIR$/../../entrypoints/kotlin" external.root.project.path="$MODULE_DIR$/../../entrypoints/kotlin" external.system.id="GRADLE" external.system.module.group="xyz.myriation.aoc2024.entrypoints" external.system.module.version="1.0-SNAPSHOT" type="JAVA_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$/../../entrypoints/kotlin">
<excludeFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/.gradle" />
<excludeFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/build" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

View file

@ -0,0 +1,49 @@
<?xml version="1.0" encoding="UTF-8"?>
<module external.linked.project.id="kotlin:main" external.linked.project.path="$MODULE_DIR$/../../entrypoints/kotlin" external.root.project.path="$MODULE_DIR$/../../entrypoints/kotlin" external.system.id="GRADLE" external.system.module.group="xyz.myriation.aoc2024.entrypoints" external.system.module.type="sourceSet" external.system.module.version="1.0-SNAPSHOT" type="JAVA_MODULE" version="4">
<component name="FacetManager">
<facet external-system-id="GRADLE" type="kotlin-language" name="Kotlin">
<configuration version="5" platform="JVM 21" allPlatforms="JVM [21]" useProjectSettings="false" pureKotlinSourceFolders="$MODULE_DIR$/../../entrypoints/kotlin/src/main/kotlin;/home/ty/Dev/aoc2024/entrypoints/kotlin/src/test/kotlin">
<compilerSettings />
<compilerArguments>
<flagArguments>
<flagArg name="allowNoSourceFiles" arg="true" />
<flagArg name="noReflect" arg="true" />
<flagArg name="noStdlib" arg="true" />
</flagArguments>
<stringArguments>
<stringArg name="destination" arg="$MODULE_DIR$/../../entrypoints/kotlin/build/classes/kotlin/main" />
<stringArg name="jvmTarget" arg="21" />
<stringArg name="moduleName" arg="kotlin" />
<stringArg name="apiVersion" arg="2.0" />
<stringArg name="languageVersion" arg="2.0" />
</stringArguments>
<arrayArguments>
<arrayArg name="pluginClasspaths">
<args>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-scripting-jvm/2.0.21/939d8b644308f8d97c60317df76ee40299475831/kotlin-scripting-jvm-2.0.21.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-scripting-common/2.0.21/2aeb50e2df2ef94f6b90b7ab2c56d5e18d3687c1/kotlin-scripting-common-2.0.21.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/2.0.21/618b539767b4899b4660a83006e052b63f1db551/kotlin-stdlib-2.0.21.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/919f0dfe192fb4e063e7dacadee7f8bb9a2672a9/annotations-13.0.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-script-runtime/2.0.21/c9b044380ad41f89aa89aa896c2d32a8c0b2129d/kotlin-script-runtime-2.0.21.jar</arg>
</args>
</arrayArg>
<arrayArg name="pluginOptions" />
</arrayArguments>
</compilerArguments>
</configuration>
</facet>
</component>
<component name="NewModuleRootManager">
<output url="file://$MODULE_DIR$/../../entrypoints/kotlin/build/classes/java/main" />
<exclude-output />
<content url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/main">
<sourceFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/main/java" isTestSource="false" />
<sourceFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/main/resources" type="java-resource" />
<sourceFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/main/kotlin" isTestSource="false" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
<orderEntry type="library" name="Gradle: org.jetbrains.kotlin:kotlin-stdlib:2.0.21" level="project" />
<orderEntry type="library" name="Gradle: org.jetbrains:annotations:13.0" level="project" />
</component>
</module>

View file

@ -0,0 +1,61 @@
<?xml version="1.0" encoding="UTF-8"?>
<module external.linked.project.id="kotlin:test" external.linked.project.path="$MODULE_DIR$/../../entrypoints/kotlin" external.root.project.path="$MODULE_DIR$/../../entrypoints/kotlin" external.system.id="GRADLE" external.system.module.group="xyz.myriation.aoc2024.entrypoints" external.system.module.type="sourceSet" external.system.module.version="1.0-SNAPSHOT" type="JAVA_MODULE" version="4">
<component name="FacetManager">
<facet external-system-id="GRADLE" type="kotlin-language" name="Kotlin">
<configuration version="5" platform="JVM 21" allPlatforms="JVM [21]" useProjectSettings="false" pureKotlinSourceFolders="$MODULE_DIR$/../../entrypoints/kotlin/src/main/kotlin;/home/ty/Dev/aoc2024/entrypoints/kotlin/src/test/kotlin">
<additionalVisibleModuleNames>kotlin:main</additionalVisibleModuleNames>
<compilerSettings />
<compilerArguments>
<flagArguments>
<flagArg name="allowNoSourceFiles" arg="true" />
<flagArg name="noReflect" arg="true" />
<flagArg name="noStdlib" arg="true" />
</flagArguments>
<stringArguments>
<stringArg name="destination" arg="$MODULE_DIR$/../../entrypoints/kotlin/build/classes/kotlin/test" />
<stringArg name="jvmTarget" arg="21" />
<stringArg name="moduleName" arg="kotlin_test" />
<stringArg name="apiVersion" arg="2.0" />
<stringArg name="languageVersion" arg="2.0" />
</stringArguments>
<arrayArguments>
<arrayArg name="pluginClasspaths">
<args>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-scripting-jvm/2.0.21/939d8b644308f8d97c60317df76ee40299475831/kotlin-scripting-jvm-2.0.21.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-scripting-common/2.0.21/2aeb50e2df2ef94f6b90b7ab2c56d5e18d3687c1/kotlin-scripting-common-2.0.21.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-stdlib/2.0.21/618b539767b4899b4660a83006e052b63f1db551/kotlin-stdlib-2.0.21.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains/annotations/13.0/919f0dfe192fb4e063e7dacadee7f8bb9a2672a9/annotations-13.0.jar</arg>
<arg>$USER_HOME$/.gradle/caches/modules-2/files-2.1/org.jetbrains.kotlin/kotlin-script-runtime/2.0.21/c9b044380ad41f89aa89aa896c2d32a8c0b2129d/kotlin-script-runtime-2.0.21.jar</arg>
</args>
</arrayArg>
<arrayArg name="pluginOptions" />
</arrayArguments>
</compilerArguments>
</configuration>
</facet>
</component>
<component name="NewModuleRootManager">
<output-test url="file://$MODULE_DIR$/../../entrypoints/kotlin/build/classes/java/test" />
<exclude-output />
<content url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/test">
<sourceFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/test/java" isTestSource="true" />
<sourceFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/test/resources" type="java-test-resource" />
<sourceFolder url="file://$MODULE_DIR$/../../entrypoints/kotlin/src/test/kotlin" isTestSource="true" />
</content>
<orderEntry type="inheritedJdk" />
<orderEntry type="sourceFolder" forTests="false" />
<orderEntry type="module" module-name="kotlin.main" />
<orderEntry type="library" name="Gradle: org.jetbrains.kotlin:kotlin-test:2.0.21" level="project" />
<orderEntry type="library" name="Gradle: org.jetbrains.kotlin:kotlin-stdlib:2.0.21" level="project" />
<orderEntry type="library" name="Gradle: org.jetbrains.kotlin:kotlin-test-junit5:2.0.21" level="project" />
<orderEntry type="library" name="Gradle: org.jetbrains:annotations:13.0" level="project" />
<orderEntry type="library" name="Gradle: org.junit.jupiter:junit-jupiter-api:5.10.1" level="project" />
<orderEntry type="library" name="Gradle: org.junit.platform:junit-platform-commons:1.10.1" level="project" />
<orderEntry type="library" name="Gradle: org.opentest4j:opentest4j:1.3.0" level="project" />
<orderEntry type="library" scope="PROVIDED" name="Gradle: org.apiguardian:apiguardian-api:1.1.2" level="project" />
<orderEntry type="library" scope="RUNTIME" name="Gradle: org.junit.platform:junit-platform-launcher:1.10.1" level="project" />
<orderEntry type="library" scope="RUNTIME" name="Gradle: org.junit.jupiter:junit-jupiter-engine:5.10.1" level="project" />
<orderEntry type="library" scope="RUNTIME" name="Gradle: org.junit.platform:junit-platform-engine:1.10.1" level="project" />
</component>
<component name="TestModuleProperties" production-module="kotlin.main" />
</module>

9
aoc
View file

@ -1,9 +0,0 @@
#!/usr/bin/env zsh
setopt extendedglob
cd "day$1"
# Handle deno days
if [[ -n *.ts(#qN) ]]; then
deno eval --ext=ts "await import('./part$2.ts').then(m => m.solve()).then(s => console.log('The solution is', s))"
fi

31
cli/secrets.ts Normal file
View file

@ -0,0 +1,31 @@
export async function saveToken(token: string) {
const process = new Deno.Command("secret-tool", {
args: [
"store",
"--label",
"Advent Of Code Session Token",
"aoc-deno",
"token"
],
stdin: "piped"
}).spawn();
const stdin = process.stdin.getWriter();
await stdin.write(new TextEncoder().encode(token));
await stdin.close();
}
export async function readToken() {
const process = new Deno.Command("secret-tool", {
args: [
"lookup",
"aoc-deno",
"token"
],
stdout: "piped"
}).spawn();
const decoderStream = new TextDecoderStream();
const stdout = process.stdout.pipeTo(decoderStream.writable);
for await (const v of decoderStream.readable.values()) {
console.log(v);
}
}

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
return await Deno.readTextFile("./input.txt").then( return await Deno.readTextFile(import.meta.dirname + "/input.txt").then(
(f) => (f) =>
f.split("\n").reduce<[number[], number[]]>( f.split("\n").reduce<[number[], number[]]>(
( (

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
return await Deno.readTextFile("./input.txt").then( return await Deno.readTextFile(import.meta.dirname + "/input.txt").then(
(f) => (f) =>
f.split("\n").reduce<[number[], number[]]>( f.split("\n").reduce<[number[], number[]]>(
( (

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
return await Deno.readTextFile("./input.txt").then((f) => return await Deno.readTextFile(import.meta.dirname + "/input.txt").then((f) =>
f.split("\n").filter((l) => { f.split("\n").filter((l) => {
const report = l.split(" ").map((s) => +s); const report = l.split(" ").map((s) => +s);
const increasing = report[0] < report[1]; const increasing = report[0] < report[1];

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
return await Deno.readTextFile("./input.txt").then((f) => return await Deno.readTextFile(import.meta.dirname + "/input.txt").then((f) =>
f.split("\n").filter((l) => { f.split("\n").filter((l) => {
const report = l.split(" ").map((s) => +s); const report = l.split(" ").map((s) => +s);
for (let i = 0; i < report.length; i++) { for (let i = 0; i < report.length; i++) {

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
const input = await Deno.readTextFile("./input.txt"); const input = await Deno.readTextFile(import.meta.dirname + "/input.txt");
let sum = 0; let sum = 0;
for (const match of input.matchAll(/mul\((\d{1,3}),(\d{1,3})\)/g)) { for (const match of input.matchAll(/mul\((\d{1,3}),(\d{1,3})\)/g)) {
sum += +match[1] * +match[2]; sum += +match[1] * +match[2];

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
const input = await Deno.readTextFile("./input.txt"); const input = await Deno.readTextFile(import.meta.dirname + "/input.txt");
let sum = 0; let sum = 0;
for (const part of input.split("do()").slice(1).map(e => e.split("don't()")[0])) { for (const part of input.split("do()").slice(1).map(e => e.split("don't()")[0])) {
for (const match of part.matchAll(/mul\((\d{1,3}),(\d{1,3})\)/g)) { for (const match of part.matchAll(/mul\((\d{1,3}),(\d{1,3})\)/g)) {

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
const grid = await Deno.readTextFile("./input.txt").then(i => i.split("\n").map(l => l.split(""))); const grid = await Deno.readTextFile(import.meta.dirname + "/input.txt").then(i => i.split("\n").map(l => l.split("")));
let sum = 0; let sum = 0;
for (const [y, line] of grid.map((e, i) => [i, e] as const)) { for (const [y, line] of grid.map((e, i) => [i, e] as const)) {

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
const grid = await Deno.readTextFile("./input.txt").then(i => i.split("\n").map(l => l.split(""))); const grid = await Deno.readTextFile(import.meta.dirname + "/input.txt").then(i => i.split("\n").map(l => l.split("")));
let sum = 0; let sum = 0;
for (const [y, line] of grid.map((e, i) => [i, e] as const)) { for (const [y, line] of grid.map((e, i) => [i, e] as const)) {

View file

@ -1,5 +1,5 @@
export async function solve() { export async function solve() {
const [rules, pages] = await Deno.readTextFile("./input.txt") const [rules, pages] = await Deno.readTextFile(import.meta.dirname + "/input.txt")
.then(i => i .then(i => i
.split("\n\n") .split("\n\n")
).then(([rules, pages]) => [ ).then(([rules, pages]) => [

View file

@ -22,7 +22,7 @@ function validate(rules: [string, string][], pageGroup: string[]): [boolean, nul
} }
export async function solve() { export async function solve() {
const [rules, pages] = await Deno.readTextFile("./input.txt") const [rules, pages] = await Deno.readTextFile(import.meta.dirname + "/input.txt")
.then(i => i .then(i => i
.split("\n\n") .split("\n\n")
).then(([rules, pages]) => [ ).then(([rules, pages]) => [

60
day6/part2-optimized.kts Normal file
View file

@ -0,0 +1,60 @@
#!/usr/bin/env kotlin
import java.io.File
fun MutableList<MutableList<Char>>.clone(): MutableList<MutableList<Char>> {
val grid = mutableListOf<MutableList<Char>>()
var i = 0;
this.forEach {
grid.add(MutableList(it.size) { j ->
this[i][j]
})
i++
}
return grid
}
enum class Direction {
UP,
DOWN,
RIGHT,
LEFT;
fun rotate90(): Direction {
return when (this) {
UP -> RIGHT
DOWN -> LEFT
RIGHT -> DOWN
LEFT -> UP
}
}
}
var originalGrid = mutableListOf<MutableList<Char>>()
var originalGuy = Pair(0, 0);
var originalDirection = Direction.UP
var i = 0
File("./input.txt").forEachLine {
val iter = it.chars().iterator()
var j = 0
originalGrid.add(MutableList(it.length) {
var next = iter.next().toChar()
if (next == '^') {
originalGuy = Pair(i, j)
next = '.'
}
j++
next
})
i++
}
println("\n" + sum)

38
day7/part1.kts Executable file
View file

@ -0,0 +1,38 @@
#!/usr/bin/env kotlin
import java.io.File
import java.time.Instant
import java.util.*
val start = Instant.now()
val tests = File("./input.txt").readLines().map {
Pair(it.split(": ")[0], it.split(": ")[1])
}.map {
Pair(it.first.toLong(), it.second.split(" ").map { n -> n.toLong() })
}
var finalResult = 0L
tests.forEach { (test, values) ->
var results = LinkedList<Long>()
results.add(values[0])
for (i in 1..<values.size) {
val iter = results.listIterator();
while (iter.hasNext()) {
val result = iter.next()
iter.set(result * values[i])
iter.add(result + values[i])
}
}
if (test in results) {
finalResult += test
}
}
val time = (Instant.now().toEpochMilli() - start.toEpochMilli())
println("Result: ${finalResult}\nTime: ${time}ms")

43
day7/part2.kts Executable file
View file

@ -0,0 +1,43 @@
#!/usr/bin/env kotlin
import java.io.File
import java.time.Instant
import java.util.*
import kotlin.math.*
infix fun Long.`||`(other: Long)
= ((this * 10.0.pow(floor(log10(other.toDouble())) + 1)) + other).toLong()
val start = Instant.now()
val tests = File("./input.txt").readLines().map {
Pair(it.split(": ")[0], it.split(": ")[1])
}.map {
Pair(it.first.toLong(), it.second.split(" ").map { n -> n.toLong() })
}
var finalResult = 0L
tests.forEach { (test, values) ->
var results = LinkedList<Long>()
results.add(values[0])
for (i in 1..<values.size) {
val iter = results.listIterator();
while (iter.hasNext()) {
val result = iter.next()
iter.set(result * values[i])
iter.add(result + values[i])
iter.add(result `||` values[i])
}
}
if (test in results) {
finalResult += test
}
}
val time = (Instant.now().toEpochMilli() - start.toEpochMilli())
println("Result: ${finalResult}\nTime: ${time}ms")

52
day8/part1.kts Executable file
View file

@ -0,0 +1,52 @@
#!/usr/bin/env kotlin
import java.io.File
val frequencies = mutableMapOf<Char, MutableList<Pair<Int, Int>>>()
var gridWidth = 0
var gridHeight = 0
File("./input.txt").readLines().also {
gridHeight = it.size
}.forEachIndexed { i, line ->
line.also { gridWidth = it.length }.forEachIndexed chars@{ j, freq ->
if (freq == '.') return@chars
val curValue = frequencies.putIfAbsent(
freq, mutableListOf(Pair(i, j))
)
if (curValue !== null) {
curValue.add(Pair(i, j))
}
}
}
val antiNodes = hashSetOf<Pair<Int, Int>>()
frequencies.forEach { (_, points) ->
points.forEach outer@{ point1 ->
points.forEach { point2 ->
if (point1 == point2) return@outer
val dRow = (point1.first - point2.first)
val dCol = (point1.second - point2.second)
val antiNode1 = Pair(point1.first + dRow, point1.second + dCol)
val antiNode2 = Pair(point2.first - dRow, point2.second - dCol)
if (
antiNode1.first >= 0
&& antiNode1.second >= 0
&& antiNode1.first < gridHeight
&& antiNode1.second < gridWidth) {
antiNodes.add(antiNode1)
}
if (
antiNode2.first >= 0
&& antiNode2.second >= 0
&& antiNode2.first < gridHeight
&& antiNode2.second < gridWidth) {
antiNodes.add(antiNode2)
}
}
}
}
println(antiNodes.size)

49
day8/part2.kts Executable file
View file

@ -0,0 +1,49 @@
#!/usr/bin/env kotlin
import java.io.File
val frequencies = mutableMapOf<Char, MutableList<Pair<Int, Int>>>()
var gridWidth = 0
var gridHeight = 0
File("./input.txt").readLines().also {
gridHeight = it.size
}.forEachIndexed { i, line ->
line.also { gridWidth = it.length }.forEachIndexed chars@{ j, freq ->
if (freq == '.') return@chars
val curValue = frequencies.putIfAbsent(
freq, mutableListOf(Pair(i, j))
)
if (curValue !== null) {
curValue.add(Pair(i, j))
}
}
}
val antiNodes = hashSetOf<Pair<Int, Int>>()
frequencies.forEach { (_, points) ->
points.forEach outer@{ point1 ->
points.forEach { point2 ->
if (point1 == point2) return@outer
val dRow = (point1.first - point2.first)
val dCol = (point1.second - point2.second)
var curRow = point1.first
var curCol = point1.second
while (curRow in 0..<gridHeight && curCol in 0..<gridWidth) {
antiNodes.add(Pair(curRow, curCol))
curRow += dRow
curCol += dCol
}
curRow = point2.first
curCol = point2.second
while (curRow in 0..<gridHeight && curCol in 0..<gridWidth) {
antiNodes.add(Pair(curRow, curCol))
curRow -= dRow
curCol -= dCol
}
}
}
}
println(antiNodes.size)

10
deno.json Normal file
View file

@ -0,0 +1,10 @@
{
"imports": {
"@cliffy/command": "jsr:@cliffy/command@^1.0.0-rc.7",
"@cliffy/prompt": "jsr:@cliffy/prompt@^1.0.0-rc.7",
"@cross/dir": "jsr:@cross/dir@^1.1.0",
"@db/sqlite": "jsr:@db/sqlite@^0.12.0",
"@std/ini": "jsr:@std/ini@^0.225.2",
"@std/path": "jsr:@std/path@^1.0.8"
}
}

195
deno.lock Normal file
View file

@ -0,0 +1,195 @@
{
"version": "4",
"specifiers": {
"jsr:@cliffy/ansi@1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cliffy/command@^1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cliffy/flags@1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cliffy/internal@1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cliffy/keycode@1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cliffy/prompt@^1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cliffy/table@1.0.0-rc.7": "1.0.0-rc.7",
"jsr:@cross/deepmerge@1": "1.0.0",
"jsr:@cross/dir@^1.1.0": "1.1.0",
"jsr:@cross/env@1": "1.0.2",
"jsr:@cross/runtime@1": "1.1.0",
"jsr:@cross/utils@0.7": "0.7.1",
"jsr:@db/sqlite@0.12": "0.12.0",
"jsr:@denosaurs/plug@1": "1.0.6",
"jsr:@std/assert@0.217": "0.217.0",
"jsr:@std/assert@0.221": "0.221.0",
"jsr:@std/assert@~1.0.6": "1.0.9",
"jsr:@std/encoding@0.221": "0.221.0",
"jsr:@std/encoding@~1.0.5": "1.0.5",
"jsr:@std/fmt@0.221": "0.221.0",
"jsr:@std/fmt@~1.0.2": "1.0.3",
"jsr:@std/fs@0.221": "0.221.0",
"jsr:@std/ini@~0.225.2": "0.225.2",
"jsr:@std/path@0.217": "0.217.0",
"jsr:@std/path@0.221": "0.221.0",
"jsr:@std/path@^1.0.8": "1.0.8",
"jsr:@std/path@~1.0.6": "1.0.8",
"jsr:@std/text@~1.0.7": "1.0.8"
},
"jsr": {
"@cliffy/ansi@1.0.0-rc.7": {
"integrity": "f71c921cce224c13d322e5cedba4f38e8f7354c7d855c9cb22729362a53f25aa",
"dependencies": [
"jsr:@cliffy/internal",
"jsr:@std/encoding@~1.0.5"
]
},
"@cliffy/command@1.0.0-rc.7": {
"integrity": "1288808d7a3cd18b86c24c2f920e47a6d954b7e23cadc35c8cbd78f8be41f0cd",
"dependencies": [
"jsr:@cliffy/flags",
"jsr:@cliffy/internal",
"jsr:@cliffy/table",
"jsr:@std/fmt@~1.0.2",
"jsr:@std/text"
]
},
"@cliffy/flags@1.0.0-rc.7": {
"integrity": "318d9be98f6a6417b108e03dec427dea96cdd41a15beb21d2554ae6da450a781",
"dependencies": [
"jsr:@std/text"
]
},
"@cliffy/internal@1.0.0-rc.7": {
"integrity": "10412636ab3e67517d448be9eaab1b70c88eba9be22617b5d146257a11cc9b17"
},
"@cliffy/keycode@1.0.0-rc.7": {
"integrity": "5b3f6c33994e81a76b79f108b1989642ac22705840da33781f7972d7dff05503"
},
"@cliffy/prompt@1.0.0-rc.7": {
"integrity": "a9cbd13acd8073558447cae8ca4cf593c09d23bcbe429cc63346920c21187b83",
"dependencies": [
"jsr:@cliffy/ansi",
"jsr:@cliffy/internal",
"jsr:@cliffy/keycode",
"jsr:@std/assert@~1.0.6",
"jsr:@std/fmt@~1.0.2",
"jsr:@std/path@~1.0.6",
"jsr:@std/text"
]
},
"@cliffy/table@1.0.0-rc.7": {
"integrity": "9fdd9776eda28a0b397981c400eeb1aa36da2371b43eefe12e6ff555290e3180",
"dependencies": [
"jsr:@std/fmt@~1.0.2"
]
},
"@cross/deepmerge@1.0.0": {
"integrity": "1e1318a74e31ba1959b9aa0acae8bd417b806f74ffd25ac07c90e12f83ad6b1d"
},
"@cross/dir@1.1.0": {
"integrity": "41eb779daf160f53bc33ef91f593f332fffc52ec9b81f87178db564718534e59",
"dependencies": [
"jsr:@cross/env",
"jsr:@cross/runtime",
"jsr:@cross/utils"
]
},
"@cross/env@1.0.2": {
"integrity": "28501ad1043c218a5b00fe5db27ec62c01ab16371bbe1b9d738496f0a7c5eeb8",
"dependencies": [
"jsr:@cross/deepmerge",
"jsr:@cross/runtime"
]
},
"@cross/runtime@1.1.0": {
"integrity": "f35a3b768a9de125277329483b684062ffc9ee86f4449cb8b3d614adcad64ffb"
},
"@cross/utils@0.7.1": {
"integrity": "6cc50ad31b0904364188c43d10e3d4888d817a3d415528b014c27deb8a35564e",
"dependencies": [
"jsr:@cross/runtime"
]
},
"@db/sqlite@0.12.0": {
"integrity": "dd1ef7f621ad50fc1e073a1c3609c4470bd51edc0994139c5bf9851de7a6d85f",
"dependencies": [
"jsr:@denosaurs/plug",
"jsr:@std/path@0.217"
]
},
"@denosaurs/plug@1.0.6": {
"integrity": "6cf5b9daba7799837b9ffbe89f3450510f588fafef8115ddab1ff0be9cb7c1a7",
"dependencies": [
"jsr:@std/encoding@0.221",
"jsr:@std/fmt@0.221",
"jsr:@std/fs",
"jsr:@std/path@0.221"
]
},
"@std/assert@0.217.0": {
"integrity": "c98e279362ca6982d5285c3b89517b757c1e3477ee9f14eb2fdf80a45aaa9642"
},
"@std/assert@0.221.0": {
"integrity": "a5f1aa6e7909dbea271754fd4ab3f4e687aeff4873b4cef9a320af813adb489a"
},
"@std/assert@1.0.9": {
"integrity": "a9f0c611a869cc791b26f523eec54c7e187aab7932c2c8e8bea0622d13680dcd"
},
"@std/encoding@0.221.0": {
"integrity": "d1dd76ef0dc5d14088411e6dc1dede53bf8308c95d1537df1214c97137208e45"
},
"@std/encoding@1.0.5": {
"integrity": "ecf363d4fc25bd85bd915ff6733a7e79b67e0e7806334af15f4645c569fefc04"
},
"@std/fmt@0.221.0": {
"integrity": "379fed69bdd9731110f26b9085aeb740606b20428ce6af31ef6bd45ef8efa62a"
},
"@std/fmt@1.0.3": {
"integrity": "97765c16aa32245ff4e2204ecf7d8562496a3cb8592340a80e7e554e0bb9149f"
},
"@std/fs@0.221.0": {
"integrity": "028044450299de8ed5a716ade4e6d524399f035513b85913794f4e81f07da286",
"dependencies": [
"jsr:@std/assert@0.221",
"jsr:@std/path@0.221"
]
},
"@std/ini@0.225.2": {
"integrity": "c70f6560dacb7e333c2f868aa09aaa4117e6618cc66c60d0b4ca716c135c8e67"
},
"@std/path@0.217.0": {
"integrity": "1217cc25534bca9a2f672d7fe7c6f356e4027df400c0e85c0ef3e4343bc67d11",
"dependencies": [
"jsr:@std/assert@0.217"
]
},
"@std/path@0.221.0": {
"integrity": "0a36f6b17314ef653a3a1649740cc8db51b25a133ecfe838f20b79a56ebe0095",
"dependencies": [
"jsr:@std/assert@0.221"
]
},
"@std/path@1.0.8": {
"integrity": "548fa456bb6a04d3c1a1e7477986b6cffbce95102d0bb447c67c4ee70e0364be"
},
"@std/text@1.0.8": {
"integrity": "40ba34caa095f393e78796e5eda37b8b4e2cc6cfd6f51f34658ad7487b1451e4"
}
},
"remote": {
"https://deno.land/x/sqlite@v3.9.1/build/sqlite.js": "2afc7875c7b9c85d89730c4a311ab3a304e5d1bf761fbadd8c07bbdf130f5f9b",
"https://deno.land/x/sqlite@v3.9.1/build/vfs.js": "7f7778a9fe499cd10738d6e43867340b50b67d3e39142b0065acd51a84cd2e03",
"https://deno.land/x/sqlite@v3.9.1/mod.ts": "e09fc79d8065fe222578114b109b1fd60077bff1bb75448532077f784f4d6a83",
"https://deno.land/x/sqlite@v3.9.1/src/constants.ts": "90f3be047ec0a89bcb5d6fc30db121685fc82cb00b1c476124ff47a4b0472aa9",
"https://deno.land/x/sqlite@v3.9.1/src/db.ts": "03d0c860957496eadedd86e51a6e650670764630e64f56df0092e86c90752401",
"https://deno.land/x/sqlite@v3.9.1/src/error.ts": "f7a15cb00d7c3797da1aefee3cf86d23e0ae92e73f0ba3165496c3816ab9503a",
"https://deno.land/x/sqlite@v3.9.1/src/function.ts": "bc778cab7a6d771f690afa27264c524d22fcb96f1bb61959ade7922c15a4ab8d",
"https://deno.land/x/sqlite@v3.9.1/src/query.ts": "d58abda928f6582d77bad685ecf551b1be8a15e8e38403e293ec38522e030cad",
"https://deno.land/x/sqlite@v3.9.1/src/wasm.ts": "e79d0baa6e42423257fb3c7cc98091c54399254867e0f34a09b5bdef37bd9487"
},
"workspace": {
"dependencies": [
"jsr:@cliffy/command@^1.0.0-rc.7",
"jsr:@cliffy/prompt@^1.0.0-rc.7",
"jsr:@cross/dir@^1.1.0",
"jsr:@db/sqlite@0.12",
"jsr:@std/ini@~0.225.2",
"jsr:@std/path@^1.0.8"
]
}
}

View file

@ -0,0 +1,2 @@
// Redirect `deno bench` to the main entrypoint file
import "./deno.ts"

34
entrypoints/deno.ts Normal file
View file

@ -0,0 +1,34 @@
import * as path from "@std/path"
// Parse all modules
const parentDir = path.resolve(path.join(import.meta.dirname!, ".."));
const dayFolderRegex = /^day(\d{1,2})$/;
const days: { day: number, part: 1|2, solve: () => Promise<number> }[] = [];
for await (const folder of Deno.readDir(parentDir)) {
const regex = folder.name.match(dayFolderRegex);
if (!regex) {
continue;
}
const dayNum = regex[1];
for (let i = 1; i <= 2; i++) {
if (await Deno.stat(path.join(parentDir, "day" + dayNum, `part${i}.ts`)).then(s => s.isFile).catch(_ => false)) {
const module = await import(path.join(parentDir, "day" + dayNum, `part${i}.ts`));
days.push({
day: +dayNum,
part: i as 1|2,
solve: module.solve
})
}
}
}
// Create deno benchmark entries
for (const { day, part, solve } of days) {
Deno.bench(
`Day ${day} Part ${part}`,
// Group each day and say how much faster p1 is than p2
{ group: `Day ${day}`, baseline: part == 1, permissions: { "read": true } },
() => solve().then(_ => undefined)
)
}

View file

@ -0,0 +1,2 @@
#Sat Dec 07 19:12:33 MST 2024
gradle.version=8.10

Binary file not shown.

View file

@ -0,0 +1,21 @@
plugins {
kotlin("jvm") version "2.0.21"
}
group = "xyz.myriation.aoc2024.entrypoints"
version = "1.0-SNAPSHOT"
repositories {
mavenCentral()
}
dependencies {
testImplementation(kotlin("test"))
}
tasks.test {
useJUnitPlatform()
}
kotlin {
jvmToolchain(21)
}

Binary file not shown.

View file

@ -0,0 +1,7 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.10-bin.zip
networkTimeout=10000
validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

252
entrypoints/kotlin/gradlew vendored Executable file
View file

@ -0,0 +1,252 @@
#!/bin/sh
#
# Copyright © 2015-2021 the original authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# SPDX-License-Identifier: Apache-2.0
#
##############################################################################
#
# Gradle start up script for POSIX generated by Gradle.
#
# Important for running:
#
# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
# noncompliant, but you have some other compliant shell such as ksh or
# bash, then to run this script, type that shell name before the whole
# command line, like:
#
# ksh Gradle
#
# Busybox and similar reduced shells will NOT work, because this script
# requires all of these POSIX shell features:
# * functions;
# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
# * compound commands having a testable exit status, especially «case»;
# * various built-in commands including «command», «set», and «ulimit».
#
# Important for patching:
#
# (2) This script targets any POSIX shell, so it avoids extensions provided
# by Bash, Ksh, etc; in particular arrays are avoided.
#
# The "traditional" practice of packing multiple parameters into a
# space-separated string is a well documented source of bugs and security
# problems, so this is (mostly) avoided, by progressively accumulating
# options in "$@", and eventually passing that to Java.
#
# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
# see the in-line comments for details.
#
# There are tweaks for specific operating systems such as AIX, CygWin,
# Darwin, MinGW, and NonStop.
#
# (3) This script is generated from the Groovy template
# https://github.com/gradle/gradle/blob/HEAD/platforms/jvm/plugins-application/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
# within the Gradle project.
#
# You can find Gradle at https://github.com/gradle/gradle/.
#
##############################################################################
# Attempt to set APP_HOME
# Resolve links: $0 may be a link
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
# This is normally unused
# shellcheck disable=SC2034
APP_BASE_NAME=${0##*/}
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
APP_HOME=$( cd -P "${APP_HOME:-./}" > /dev/null && printf '%s
' "$PWD" ) || exit
# Use the maximum available, or set MAX_FD != -1 to use that value.
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 ;; #(
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
else
JAVACMD=$JAVA_HOME/bin/java
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD=java
if ! command -v java >/dev/null 2>&1
then
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
location of your Java installation."
fi
fi
# Increase the maximum file descriptors if we can.
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=SC2039,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=SC2039,SC3045
ulimit -n "$MAX_FD" ||
warn "Could not set maximum file descriptor limit to $MAX_FD"
esac
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" )
# Now convert the arguments - kludge to limit ourselves to /bin/sh
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
# 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
fi
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
# Collect all arguments for the java command:
# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
# and any embedded shellness will be escaped.
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
# treated as '${Hostname}' itself on the command line.
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" "$@"

94
entrypoints/kotlin/gradlew.bat vendored Normal file
View file

@ -0,0 +1,94 @@
@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
@rem SPDX-License-Identifier: Apache-2.0
@rem
@if "%DEBUG%"=="" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@rem
@rem ##########################################################################
@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal
set DIRNAME=%~dp0
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="-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% equ 0 goto execute
echo. 1>&2
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. 1>&2
goto fail
:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto execute
echo. 1>&2
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. 1>&2
goto fail
: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 %*
:end
@rem End local scope for the variables with windows NT shell
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!
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
:omega

View file

@ -0,0 +1,2 @@
rootProject.name = "kotlin"

View file

@ -0,0 +1,5 @@
package xyz.myriation.aoc2024.entrypoints
fun main() {
println("Hello World!")
}

View file

@ -10,6 +10,7 @@
packages = with pkgs; [ packages = with pkgs; [
deno deno
kotlin kotlin
libsecret
]; ];
}; };
}); });

226
main.ts Executable file
View file

@ -0,0 +1,226 @@
#!/usr/bin/env deno
import * as path from "@std/path";
import * as ini from "@std/ini";
import { Command } from "@cliffy/command";
import { HelpCommand } from "@cliffy/command/help";
import { Select } from "@cliffy/prompt";
import { dir, DirectoryTypes } from "@cross/dir";
import { Database } from "@db/sqlite";
type ProfileData = {
Default: "0" | "1";
IsRelative: "0" | "1";
Name: string;
Path: string;
};
type ProfilesIni = {
General: {
StartWithLastProfile: string;
Verstion: string;
};
} & Record<string, ProfileData>;
interface FirefoxContainer {
color: string;
icon: string;
name: string;
public: boolean;
userContextId: number;
};
interface ContainersJson {
identities: FirefoxContainer[];
lastUserContextId: number;
version: number;
}
if (import.meta.main) {
await new Command()
.name("aoc")
.version("0.1.0")
.description("My AoC utility command for 2024")
.help({
types: true,
hints: true,
colors: true
})
.default("help")
.command("help", new HelpCommand().global())
.command(
"login",
new Command()
.description("Stores your advent of code session token")
.default("help")
.command(
"firefox [profile:string] [container:string]",
"Imports an advent of code session token from firefox"
)
.action(async (_: unknown, profileArg: string | undefined, containerArg: string | undefined) => {
try {
// Discover firefox profiles
const firefoxProfilesPath = path.join(await dir(DirectoryTypes.home), ".mozilla", "firefox");
const profiles =
ini.parse(await Deno.readTextFile(path.join(firefoxProfilesPath, "profiles.ini"))) as ProfilesIni;
const parsedProfiles = Object.entries(profiles).reduce((acc, [k, v]) => ({
list: [
...acc.list,
...(
k !== "General"
? [{
...(v as ProfileData),
IsRelative: "0" as const,
Path: path.resolve(
path.join(...(
(v as ProfileData).IsRelative == "0"
? [(v as ProfileData).Path]
: [firefoxProfilesPath, (v as ProfileData).Path]
))
)
}]
: []
)
],
default: k !== "General" && (v as ProfileData).Default == "1"
? acc.list.length
: acc.default,
}), { default: undefined, list: [] } as { default: number | undefined; list: ProfileData[] });
// If the profile we need is ambigous, prompt the user for it
let profile: ProfileData;
if (profileArg !== undefined && parsedProfiles.list.find(d => d.Name == profileArg) !== undefined) {
profile = parsedProfiles.list.find(d => d.Name == profileArg)!;
} else {
let message: string
if (profileArg !== undefined) {
message = "Unable to find the specified profile name, please select the correct one";
} else {
message = "Please select the correct profile to import session token from";
}
const options = parsedProfiles.list.map(p =>
[
`${p.Name} (${path.resolve(
path.join(...(
p.IsRelative == "0"
? [p.Path]
: [firefoxProfilesPath, p.Path]
))
)})`,
p
] as const
);
const selection = await Select.prompt({
message,
default: parsedProfiles.default !== undefined ? options[parsedProfiles.default][0] : undefined,
options: options.map(([e,]) => e)
});
profile = options.find(([e,]) => e == selection)![1];
}
// If necessary, differentiate between containers
let container: FirefoxContainer | null = null;
const containerFile = await Deno.readTextFile(
path.join(profile.Path, "containers.json")
).then(t => JSON.parse(t) as ContainersJson).catch(_ => null);
if (containerFile === null && containerArg) {
console.error("Container was specified, but the selected profile has no containers");
Deno.exit(1);
} else if (containerFile !== null) {
const matchingContainer = containerArg === undefined
? undefined
: containerFile.identities.find(
i => i.name.toLowerCase() == containerArg.toLowerCase()
);
if (matchingContainer === undefined) {
const message = containerArg === undefined
? "Please select the container to import cookies from"
: "The specified container could not be found, please";
const choice = await Select.prompt({
message,
options: containerFile.identities.filter(c => c.public).map(c => c.name),
default: containerFile.identities.find(c => c.userContextId == containerFile.lastUserContextId)!.name
});
container = containerFile.identities.find(c => c.name == choice)!;
} else {
container = matchingContainer;
}
}
// Import the cookies
const tmpFile = await Deno.makeTempFile({ prefix: "aoc-firefox-cookies" });
await Deno.copyFile(path.join(profile.Path, "cookies.sqlite"), tmpFile);
const cookies = new Database(tmpFile, {
create: false,
readonly: true
});
let rows: { value: string }[];
try {
rows = container === null
? cookies.sql`
SELECT value
FROM moz_cookies
WHERE name='session' AND host='.adventofcode.com';
`
: cookies.sql`
SELECT value
FROM moz_cookies
WHERE (
originAttributes LIKE ${`%userContextId=${container.userContextId}`}
OR originAttributes LIKE ${`%userContextId=${container.userContextId}&%`}
) AND name='session' AND host='.adventofcode.com';
`;
} catch (_) {
rows = [];
}
if (rows.length < 1) {
console.error("No advent of code session cookie was found, make sure you are logged in!");
Deno.exit(1);
} else if (rows.length > 1) {
console.error("Multiple advent of code session cookies were found??");
Deno.exit(1);
} else {
const process = new Deno.Command("secret-tool", {
args: [
"store",
"--label",
"Advent Of Code Session Token",
"token",
"value"
],
stdin: "piped"
}).spawn();
const stdin = process.stdin.getWriter();
await stdin.write(new TextEncoder().encode(rows[0].value));
await stdin.close();
console.log("Token saved!");
}
await Deno.remove(tmpFile);
} catch (e) {
console.log(e)
}
})
)
.reset()
.command(
"input [day:number]",
"Fetches the input for one day (or all if day # omitted) and writes to input.txt files"
)
.action((_: unknown, day: number | undefined) => {
if (day != undefined) {
}
})
.parse(Deno.args);
}

4
scripts/aoc Executable file
View file

@ -0,0 +1,4 @@
#!/usr/bin/env sh
cd "$(dirname "${BASH_SOURCE[0]}")/.."
deno run -A ./main.ts $@