diff --git a/CT.rb b/CT.rb
deleted file mode 100644
index 2c49a9a..0000000
--- a/CT.rb
+++ /dev/null
@@ -1,58 +0,0 @@
-require "yaml"
-require 'erb'
-require 'open3'
-require 'pp'
-require 'benchmark'
-include Benchmark
-cli = { 'php' => 'php', 'ruby' => 'ruby', 'lua'=> 'lua', 'javascript'=>'node', 'js'=>'node', 'c' => 'tcc -run'}
-settings = YAML::load_file("settings.yml")
-
-problem = YAML::load_file(ARGV[0] + "/desc.yml")
-
-case ARGV[1]
- when 'test'
- if(problem['solutions'])
- problem['solutions'].each do |sol|
- if(cli[sol[1]['language']])
- puts "--------------\n|"+sol[0]+"\n--------------"
- puts sol[1]['desc']
- parameter = (sol[1]['parameters']) ? " " + sol[1]['parameters'] : ""
- stdin, stdout, stderr = Open3.popen3(cli[sol[1]['language']] + " "+ARGV[0]+"/"+sol[0] + parameter)
- puts "Result: " + stdout.readlines[0]
-
- end
- end
- else
- puts "No solutions for said problem"
- end
-
- when 'table'
-
- require 'terminal-table'
- files = Dir[ARGV[0]+"/**/*/desc.yml"]
- files.sort!
- entry = []
- files.each do |file|
- yaml = YAML::load_file(file)
- nested = file.split('/')
- count = 0
- if( yaml['solution'] and yaml['solutions'])
- yaml['solutions'].each do |sol|
- count += 1
- end
- end
- entry << {'title'=>yaml['title'],'code'=>nested[-2].to_s,'solved'=>count}
- end
-
- rows = []
- entry.each do |e|
- solvedstring = (e['solved'] == 0) ? "No" : "Yes("+e['solved'].to_s+")"
- row = [e['code'],e['title'],solvedstring]
- rows << row
- end
- table = Terminal::Table.new(:headings => ['Code','Title','Solved'],:rows => rows)
- puts table
- else
- output = ERB.new(IO.read('template.rt'))
- puts output.result()
-end
diff --git a/composer.json b/composer.json
new file mode 100644
index 0000000..c133d42
--- /dev/null
+++ b/composer.json
@@ -0,0 +1,13 @@
+{
+ "name": "furyfire/codingtests",
+ "description": "Solutions for online coding challenges. (Support library for PHP)",
+ "homepage": "https://jcktrue.dk",
+ "require": {
+ "php": "^8.1"
+ },
+ "autoload": {
+ "psr-4": {
+ "CodingTests\\": "src/"
+ }
+ }
+}
diff --git a/composer.lock b/composer.lock
new file mode 100644
index 0000000..2e861f4
--- /dev/null
+++ b/composer.lock
@@ -0,0 +1,20 @@
+{
+ "_readme": [
+ "This file locks the dependencies of your project to a known state",
+ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
+ "This file is @generated automatically"
+ ],
+ "content-hash": "1fec30c71407f68099d62f794946e565",
+ "packages": [],
+ "packages-dev": [],
+ "aliases": [],
+ "minimum-stability": "stable",
+ "stability-flags": [],
+ "prefer-stable": false,
+ "prefer-lowest": false,
+ "platform": {
+ "php": "^8.1"
+ },
+ "platform-dev": [],
+ "plugin-api-version": "2.6.0"
+}
diff --git a/ct.bat b/ct.bat
deleted file mode 100644
index f4c1d84..0000000
--- a/ct.bat
+++ /dev/null
@@ -1,2 +0,0 @@
-@ECHO OFF
-ruby CT.rb %1 %2
\ No newline at end of file
diff --git a/primes100.txt b/data/primes/primes100.txt
similarity index 100%
rename from primes100.txt
rename to data/primes/primes100.txt
diff --git a/primes1000.txt b/data/primes/primes1000.txt
similarity index 100%
rename from primes1000.txt
rename to data/primes/primes1000.txt
diff --git a/primes10000.txt b/data/primes/primes10000.txt
similarity index 100%
rename from primes10000.txt
rename to data/primes/primes10000.txt
diff --git a/primes1000000.txt b/data/primes/primes1000000.txt
similarity index 100%
rename from primes1000000.txt
rename to data/primes/primes1000000.txt
diff --git a/nbproject/private/private.properties b/nbproject/private/private.properties
deleted file mode 100644
index 27e91df..0000000
--- a/nbproject/private/private.properties
+++ /dev/null
@@ -1,5 +0,0 @@
-copy.src.files=false
-copy.src.target=
-index.file=
-run.as=SCRIPT
-url=http://localhost/codingtests/
diff --git a/nbproject/project.properties b/nbproject/project.properties
deleted file mode 100644
index 04e3d5e..0000000
--- a/nbproject/project.properties
+++ /dev/null
@@ -1,7 +0,0 @@
-include.path=${php.global.include.path}
-php.version=PHP_54
-source.encoding=UTF-8
-src.dir=.
-tags.asp=false
-tags.short=true
-web.root=.
diff --git a/nbproject/project.xml b/nbproject/project.xml
deleted file mode 100644
index 5848add..0000000
--- a/nbproject/project.xml
+++ /dev/null
@@ -1,9 +0,0 @@
-
-
- org.netbeans.modules.php.project
-
-
- codingtests
-
-
-
diff --git a/phpunit.xml b/phpunit.xml
new file mode 100644
index 0000000..4c1c94e
--- /dev/null
+++ b/phpunit.xml
@@ -0,0 +1,24 @@
+
+
+
+
+ ./tests/
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/settings.yml b/settings.yml
deleted file mode 100644
index e899d53..0000000
--- a/settings.yml
+++ /dev/null
@@ -1,16 +0,0 @@
-languages:
- javascript:
- command: node
- ext: [js,javascript]
- php:
- command: php
- ext: [php]
- ruby:
- command: ruby
- ext: [ruby,rb]
- tcc:
- command: tcc -run
- ext: [c]
- lua:
- command: lua
- ext: [lua]
\ No newline at end of file
diff --git a/CodeChef/easy/HS08TEST/solve.php b/solutions/CodeChef/easy/HS08TEST/solve.php
similarity index 100%
rename from CodeChef/easy/HS08TEST/solve.php
rename to solutions/CodeChef/easy/HS08TEST/solve.php
diff --git a/CodeChef/easy/TEST/solve.php b/solutions/CodeChef/easy/TEST/solve.php
similarity index 100%
rename from CodeChef/easy/TEST/solve.php
rename to solutions/CodeChef/easy/TEST/solve.php
diff --git a/CodeGolf/guns-and-zips/input.1 b/solutions/CodeGolf/guns-and-zips/input.1
similarity index 100%
rename from CodeGolf/guns-and-zips/input.1
rename to solutions/CodeGolf/guns-and-zips/input.1
diff --git a/CodeGolf/guns-and-zips/output.1 b/solutions/CodeGolf/guns-and-zips/output.1
similarity index 100%
rename from CodeGolf/guns-and-zips/output.1
rename to solutions/CodeGolf/guns-and-zips/output.1
diff --git a/CodeGolf/guns-and-zips/solve.php b/solutions/CodeGolf/guns-and-zips/solve.php
similarity index 100%
rename from CodeGolf/guns-and-zips/solve.php
rename to solutions/CodeGolf/guns-and-zips/solve.php
diff --git a/Generic/99Bottles/desc.yml b/solutions/Generic/99Bottles/desc.yml
similarity index 100%
rename from Generic/99Bottles/desc.yml
rename to solutions/Generic/99Bottles/desc.yml
diff --git a/Generic/99Bottles/solve.php b/solutions/Generic/99Bottles/solve.php
similarity index 100%
rename from Generic/99Bottles/solve.php
rename to solutions/Generic/99Bottles/solve.php
diff --git a/Generic/FIZZBUZZ/desc.yml b/solutions/Generic/FIZZBUZZ/desc.yml
similarity index 100%
rename from Generic/FIZZBUZZ/desc.yml
rename to solutions/Generic/FIZZBUZZ/desc.yml
diff --git a/Generic/FIZZBUZZ/solve.c b/solutions/Generic/FIZZBUZZ/solve.c
similarity index 100%
rename from Generic/FIZZBUZZ/solve.c
rename to solutions/Generic/FIZZBUZZ/solve.c
diff --git a/Generic/FIZZBUZZ/solve.php b/solutions/Generic/FIZZBUZZ/solve.php
similarity index 100%
rename from Generic/FIZZBUZZ/solve.php
rename to solutions/Generic/FIZZBUZZ/solve.php
diff --git a/Generic/FIZZBUZZ/solve.rb b/solutions/Generic/FIZZBUZZ/solve.rb
similarity index 100%
rename from Generic/FIZZBUZZ/solve.rb
rename to solutions/Generic/FIZZBUZZ/solve.rb
diff --git a/Generic/Fibonacci/a.exe b/solutions/Generic/Fibonacci/a.exe
similarity index 100%
rename from Generic/Fibonacci/a.exe
rename to solutions/Generic/Fibonacci/a.exe
diff --git a/Generic/Fibonacci/solve.c b/solutions/Generic/Fibonacci/solve.c
similarity index 100%
rename from Generic/Fibonacci/solve.c
rename to solutions/Generic/Fibonacci/solve.c
diff --git a/Generic/Fibonacci/solve.exe b/solutions/Generic/Fibonacci/solve.exe
similarity index 100%
rename from Generic/Fibonacci/solve.exe
rename to solutions/Generic/Fibonacci/solve.exe
diff --git a/Generic/HelloWorld/desc.yml b/solutions/Generic/HelloWorld/desc.yml
similarity index 100%
rename from Generic/HelloWorld/desc.yml
rename to solutions/Generic/HelloWorld/desc.yml
diff --git a/Generic/HelloWorld/solve.c b/solutions/Generic/HelloWorld/solve.c
similarity index 100%
rename from Generic/HelloWorld/solve.c
rename to solutions/Generic/HelloWorld/solve.c
diff --git a/Generic/HelloWorld/solve.js b/solutions/Generic/HelloWorld/solve.js
similarity index 100%
rename from Generic/HelloWorld/solve.js
rename to solutions/Generic/HelloWorld/solve.js
diff --git a/Generic/HelloWorld/solve.php b/solutions/Generic/HelloWorld/solve.php
similarity index 100%
rename from Generic/HelloWorld/solve.php
rename to solutions/Generic/HelloWorld/solve.php
diff --git a/Generic/HelloWorld/solve.rb b/solutions/Generic/HelloWorld/solve.rb
similarity index 100%
rename from Generic/HelloWorld/solve.rb
rename to solutions/Generic/HelloWorld/solve.rb
diff --git a/Generic/MultiTable/solve.c b/solutions/Generic/MultiTable/solve.c
similarity index 100%
rename from Generic/MultiTable/solve.c
rename to solutions/Generic/MultiTable/solve.c
diff --git a/Generic/Seive/desc.yml b/solutions/Generic/Seive/desc.yml
similarity index 100%
rename from Generic/Seive/desc.yml
rename to solutions/Generic/Seive/desc.yml
diff --git a/Generic/Seive/solve.c b/solutions/Generic/Seive/solve.c
similarity index 100%
rename from Generic/Seive/solve.c
rename to solutions/Generic/Seive/solve.c
diff --git a/Generic/desc.yml b/solutions/Generic/desc.yml
similarity index 100%
rename from Generic/desc.yml
rename to solutions/Generic/desc.yml
diff --git a/ProjectEuler/001/desc.yml b/solutions/ProjectEuler/001/desc.yml
similarity index 100%
rename from ProjectEuler/001/desc.yml
rename to solutions/ProjectEuler/001/desc.yml
diff --git a/ProjectEuler/001/solve.c b/solutions/ProjectEuler/001/solve.c
similarity index 100%
rename from ProjectEuler/001/solve.c
rename to solutions/ProjectEuler/001/solve.c
diff --git a/ProjectEuler/001/solve.js b/solutions/ProjectEuler/001/solve.js
similarity index 100%
rename from ProjectEuler/001/solve.js
rename to solutions/ProjectEuler/001/solve.js
diff --git a/ProjectEuler/001/solve.lua b/solutions/ProjectEuler/001/solve.lua
similarity index 100%
rename from ProjectEuler/001/solve.lua
rename to solutions/ProjectEuler/001/solve.lua
diff --git a/ProjectEuler/001/solve.php b/solutions/ProjectEuler/001/solve.php
similarity index 100%
rename from ProjectEuler/001/solve.php
rename to solutions/ProjectEuler/001/solve.php
diff --git a/ProjectEuler/001/solve.rb b/solutions/ProjectEuler/001/solve.rb
similarity index 100%
rename from ProjectEuler/001/solve.rb
rename to solutions/ProjectEuler/001/solve.rb
diff --git a/ProjectEuler/002/desc.yml b/solutions/ProjectEuler/002/desc.yml
similarity index 100%
rename from ProjectEuler/002/desc.yml
rename to solutions/ProjectEuler/002/desc.yml
diff --git a/ProjectEuler/002/solve.c b/solutions/ProjectEuler/002/solve.c
similarity index 100%
rename from ProjectEuler/002/solve.c
rename to solutions/ProjectEuler/002/solve.c
diff --git a/ProjectEuler/002/solve.js b/solutions/ProjectEuler/002/solve.js
similarity index 100%
rename from ProjectEuler/002/solve.js
rename to solutions/ProjectEuler/002/solve.js
diff --git a/ProjectEuler/002/solve.lua b/solutions/ProjectEuler/002/solve.lua
similarity index 100%
rename from ProjectEuler/002/solve.lua
rename to solutions/ProjectEuler/002/solve.lua
diff --git a/ProjectEuler/002/solve.php b/solutions/ProjectEuler/002/solve.php
similarity index 100%
rename from ProjectEuler/002/solve.php
rename to solutions/ProjectEuler/002/solve.php
diff --git a/ProjectEuler/002/solve.rb b/solutions/ProjectEuler/002/solve.rb
similarity index 100%
rename from ProjectEuler/002/solve.rb
rename to solutions/ProjectEuler/002/solve.rb
diff --git a/ProjectEuler/003/desc.yml b/solutions/ProjectEuler/003/desc.yml
similarity index 100%
rename from ProjectEuler/003/desc.yml
rename to solutions/ProjectEuler/003/desc.yml
diff --git a/ProjectEuler/003/solve.php b/solutions/ProjectEuler/003/solve.php
similarity index 100%
rename from ProjectEuler/003/solve.php
rename to solutions/ProjectEuler/003/solve.php
diff --git a/ProjectEuler/004/desc.yml b/solutions/ProjectEuler/004/desc.yml
similarity index 100%
rename from ProjectEuler/004/desc.yml
rename to solutions/ProjectEuler/004/desc.yml
diff --git a/ProjectEuler/004/solve.php b/solutions/ProjectEuler/004/solve.php
similarity index 100%
rename from ProjectEuler/004/solve.php
rename to solutions/ProjectEuler/004/solve.php
diff --git a/ProjectEuler/004/solve.rb b/solutions/ProjectEuler/004/solve.rb
similarity index 100%
rename from ProjectEuler/004/solve.rb
rename to solutions/ProjectEuler/004/solve.rb
diff --git a/ProjectEuler/005/desc.yml b/solutions/ProjectEuler/005/desc.yml
similarity index 100%
rename from ProjectEuler/005/desc.yml
rename to solutions/ProjectEuler/005/desc.yml
diff --git a/ProjectEuler/005/solve.js b/solutions/ProjectEuler/005/solve.js
similarity index 100%
rename from ProjectEuler/005/solve.js
rename to solutions/ProjectEuler/005/solve.js
diff --git a/ProjectEuler/005/solve.lua b/solutions/ProjectEuler/005/solve.lua
similarity index 100%
rename from ProjectEuler/005/solve.lua
rename to solutions/ProjectEuler/005/solve.lua
diff --git a/ProjectEuler/005/solve.php b/solutions/ProjectEuler/005/solve.php
similarity index 100%
rename from ProjectEuler/005/solve.php
rename to solutions/ProjectEuler/005/solve.php
diff --git a/ProjectEuler/005/solve.rb b/solutions/ProjectEuler/005/solve.rb
similarity index 100%
rename from ProjectEuler/005/solve.rb
rename to solutions/ProjectEuler/005/solve.rb
diff --git a/ProjectEuler/006/desc.yml b/solutions/ProjectEuler/006/desc.yml
similarity index 100%
rename from ProjectEuler/006/desc.yml
rename to solutions/ProjectEuler/006/desc.yml
diff --git a/ProjectEuler/006/solve.c b/solutions/ProjectEuler/006/solve.c
similarity index 100%
rename from ProjectEuler/006/solve.c
rename to solutions/ProjectEuler/006/solve.c
diff --git a/ProjectEuler/006/solve.js b/solutions/ProjectEuler/006/solve.js
similarity index 100%
rename from ProjectEuler/006/solve.js
rename to solutions/ProjectEuler/006/solve.js
diff --git a/ProjectEuler/006/solve.php b/solutions/ProjectEuler/006/solve.php
similarity index 100%
rename from ProjectEuler/006/solve.php
rename to solutions/ProjectEuler/006/solve.php
diff --git a/ProjectEuler/006/solve.rb b/solutions/ProjectEuler/006/solve.rb
similarity index 100%
rename from ProjectEuler/006/solve.rb
rename to solutions/ProjectEuler/006/solve.rb
diff --git a/ProjectEuler/007/desc.yml b/solutions/ProjectEuler/007/desc.yml
similarity index 100%
rename from ProjectEuler/007/desc.yml
rename to solutions/ProjectEuler/007/desc.yml
diff --git a/ProjectEuler/007/solve.c b/solutions/ProjectEuler/007/solve.c
similarity index 100%
rename from ProjectEuler/007/solve.c
rename to solutions/ProjectEuler/007/solve.c
diff --git a/ProjectEuler/007/solve.php b/solutions/ProjectEuler/007/solve.php
similarity index 100%
rename from ProjectEuler/007/solve.php
rename to solutions/ProjectEuler/007/solve.php
diff --git a/ProjectEuler/007/solve.rb b/solutions/ProjectEuler/007/solve.rb
similarity index 100%
rename from ProjectEuler/007/solve.rb
rename to solutions/ProjectEuler/007/solve.rb
diff --git a/ProjectEuler/008/desc.yml b/solutions/ProjectEuler/008/desc.yml
similarity index 100%
rename from ProjectEuler/008/desc.yml
rename to solutions/ProjectEuler/008/desc.yml
diff --git a/ProjectEuler/008/input b/solutions/ProjectEuler/008/input
similarity index 100%
rename from ProjectEuler/008/input
rename to solutions/ProjectEuler/008/input
diff --git a/ProjectEuler/008/solve.php b/solutions/ProjectEuler/008/solve.php
similarity index 100%
rename from ProjectEuler/008/solve.php
rename to solutions/ProjectEuler/008/solve.php
diff --git a/ProjectEuler/008/solve.rb b/solutions/ProjectEuler/008/solve.rb
similarity index 100%
rename from ProjectEuler/008/solve.rb
rename to solutions/ProjectEuler/008/solve.rb
diff --git a/ProjectEuler/009/desc.yml b/solutions/ProjectEuler/009/desc.yml
similarity index 100%
rename from ProjectEuler/009/desc.yml
rename to solutions/ProjectEuler/009/desc.yml
diff --git a/ProjectEuler/009/solve.c b/solutions/ProjectEuler/009/solve.c
similarity index 100%
rename from ProjectEuler/009/solve.c
rename to solutions/ProjectEuler/009/solve.c
diff --git a/ProjectEuler/009/solve.php b/solutions/ProjectEuler/009/solve.php
similarity index 100%
rename from ProjectEuler/009/solve.php
rename to solutions/ProjectEuler/009/solve.php
diff --git a/ProjectEuler/009/solve.rb b/solutions/ProjectEuler/009/solve.rb
similarity index 100%
rename from ProjectEuler/009/solve.rb
rename to solutions/ProjectEuler/009/solve.rb
diff --git a/ProjectEuler/010/desc.yml b/solutions/ProjectEuler/010/desc.yml
similarity index 100%
rename from ProjectEuler/010/desc.yml
rename to solutions/ProjectEuler/010/desc.yml
diff --git a/ProjectEuler/010/solve.c b/solutions/ProjectEuler/010/solve.c
similarity index 100%
rename from ProjectEuler/010/solve.c
rename to solutions/ProjectEuler/010/solve.c
diff --git a/ProjectEuler/010/solve.php b/solutions/ProjectEuler/010/solve.php
similarity index 100%
rename from ProjectEuler/010/solve.php
rename to solutions/ProjectEuler/010/solve.php
diff --git a/ProjectEuler/010/solve.rb b/solutions/ProjectEuler/010/solve.rb
similarity index 100%
rename from ProjectEuler/010/solve.rb
rename to solutions/ProjectEuler/010/solve.rb
diff --git a/ProjectEuler/011/desc.yml b/solutions/ProjectEuler/011/desc.yml
similarity index 100%
rename from ProjectEuler/011/desc.yml
rename to solutions/ProjectEuler/011/desc.yml
diff --git a/ProjectEuler/011/input b/solutions/ProjectEuler/011/input
similarity index 100%
rename from ProjectEuler/011/input
rename to solutions/ProjectEuler/011/input
diff --git a/ProjectEuler/011/solve.php b/solutions/ProjectEuler/011/solve.php
similarity index 100%
rename from ProjectEuler/011/solve.php
rename to solutions/ProjectEuler/011/solve.php
diff --git a/ProjectEuler/011/solve.rb b/solutions/ProjectEuler/011/solve.rb
similarity index 100%
rename from ProjectEuler/011/solve.rb
rename to solutions/ProjectEuler/011/solve.rb
diff --git a/ProjectEuler/012/desc.yml b/solutions/ProjectEuler/012/desc.yml
similarity index 100%
rename from ProjectEuler/012/desc.yml
rename to solutions/ProjectEuler/012/desc.yml
diff --git a/ProjectEuler/012/solve.c b/solutions/ProjectEuler/012/solve.c
similarity index 100%
rename from ProjectEuler/012/solve.c
rename to solutions/ProjectEuler/012/solve.c
diff --git a/ProjectEuler/012/solve.php b/solutions/ProjectEuler/012/solve.php
similarity index 100%
rename from ProjectEuler/012/solve.php
rename to solutions/ProjectEuler/012/solve.php
diff --git a/ProjectEuler/012/solve.rb b/solutions/ProjectEuler/012/solve.rb
similarity index 100%
rename from ProjectEuler/012/solve.rb
rename to solutions/ProjectEuler/012/solve.rb
diff --git a/ProjectEuler/013/desc.yml b/solutions/ProjectEuler/013/desc.yml
similarity index 100%
rename from ProjectEuler/013/desc.yml
rename to solutions/ProjectEuler/013/desc.yml
diff --git a/ProjectEuler/013/input b/solutions/ProjectEuler/013/input
similarity index 100%
rename from ProjectEuler/013/input
rename to solutions/ProjectEuler/013/input
diff --git a/ProjectEuler/013/solve.php b/solutions/ProjectEuler/013/solve.php
similarity index 100%
rename from ProjectEuler/013/solve.php
rename to solutions/ProjectEuler/013/solve.php
diff --git a/ProjectEuler/013/solve.rb b/solutions/ProjectEuler/013/solve.rb
similarity index 100%
rename from ProjectEuler/013/solve.rb
rename to solutions/ProjectEuler/013/solve.rb
diff --git a/ProjectEuler/014/desc.yml b/solutions/ProjectEuler/014/desc.yml
similarity index 100%
rename from ProjectEuler/014/desc.yml
rename to solutions/ProjectEuler/014/desc.yml
diff --git a/ProjectEuler/014/solve.c b/solutions/ProjectEuler/014/solve.c
similarity index 100%
rename from ProjectEuler/014/solve.c
rename to solutions/ProjectEuler/014/solve.c
diff --git a/ProjectEuler/014/solve.php b/solutions/ProjectEuler/014/solve.php
similarity index 100%
rename from ProjectEuler/014/solve.php
rename to solutions/ProjectEuler/014/solve.php
diff --git a/ProjectEuler/014/solve.rb b/solutions/ProjectEuler/014/solve.rb
similarity index 100%
rename from ProjectEuler/014/solve.rb
rename to solutions/ProjectEuler/014/solve.rb
diff --git a/ProjectEuler/015/desc.yml b/solutions/ProjectEuler/015/desc.yml
similarity index 100%
rename from ProjectEuler/015/desc.yml
rename to solutions/ProjectEuler/015/desc.yml
diff --git a/ProjectEuler/015/solve.php b/solutions/ProjectEuler/015/solve.php
similarity index 100%
rename from ProjectEuler/015/solve.php
rename to solutions/ProjectEuler/015/solve.php
diff --git a/ProjectEuler/015/solve.rb b/solutions/ProjectEuler/015/solve.rb
similarity index 100%
rename from ProjectEuler/015/solve.rb
rename to solutions/ProjectEuler/015/solve.rb
diff --git a/ProjectEuler/016/desc.yml b/solutions/ProjectEuler/016/desc.yml
similarity index 100%
rename from ProjectEuler/016/desc.yml
rename to solutions/ProjectEuler/016/desc.yml
diff --git a/ProjectEuler/016/solve.php b/solutions/ProjectEuler/016/solve.php
similarity index 100%
rename from ProjectEuler/016/solve.php
rename to solutions/ProjectEuler/016/solve.php
diff --git a/ProjectEuler/016/solve.rb b/solutions/ProjectEuler/016/solve.rb
similarity index 100%
rename from ProjectEuler/016/solve.rb
rename to solutions/ProjectEuler/016/solve.rb
diff --git a/ProjectEuler/017/desc.yml b/solutions/ProjectEuler/017/desc.yml
similarity index 100%
rename from ProjectEuler/017/desc.yml
rename to solutions/ProjectEuler/017/desc.yml
diff --git a/ProjectEuler/017/solve.php b/solutions/ProjectEuler/017/solve.php
similarity index 100%
rename from ProjectEuler/017/solve.php
rename to solutions/ProjectEuler/017/solve.php
diff --git a/ProjectEuler/018/desc.yml b/solutions/ProjectEuler/018/desc.yml
similarity index 100%
rename from ProjectEuler/018/desc.yml
rename to solutions/ProjectEuler/018/desc.yml
diff --git a/ProjectEuler/018/input b/solutions/ProjectEuler/018/input
similarity index 100%
rename from ProjectEuler/018/input
rename to solutions/ProjectEuler/018/input
diff --git a/ProjectEuler/018/solve.php b/solutions/ProjectEuler/018/solve.php
similarity index 100%
rename from ProjectEuler/018/solve.php
rename to solutions/ProjectEuler/018/solve.php
diff --git a/ProjectEuler/018/solve.rb b/solutions/ProjectEuler/018/solve.rb
similarity index 100%
rename from ProjectEuler/018/solve.rb
rename to solutions/ProjectEuler/018/solve.rb
diff --git a/ProjectEuler/019/desc.yml b/solutions/ProjectEuler/019/desc.yml
similarity index 100%
rename from ProjectEuler/019/desc.yml
rename to solutions/ProjectEuler/019/desc.yml
diff --git a/ProjectEuler/019/solve.php b/solutions/ProjectEuler/019/solve.php
similarity index 100%
rename from ProjectEuler/019/solve.php
rename to solutions/ProjectEuler/019/solve.php
diff --git a/ProjectEuler/019/solve.rb b/solutions/ProjectEuler/019/solve.rb
similarity index 100%
rename from ProjectEuler/019/solve.rb
rename to solutions/ProjectEuler/019/solve.rb
diff --git a/ProjectEuler/020/desc.yml b/solutions/ProjectEuler/020/desc.yml
similarity index 100%
rename from ProjectEuler/020/desc.yml
rename to solutions/ProjectEuler/020/desc.yml
diff --git a/ProjectEuler/020/solve.php b/solutions/ProjectEuler/020/solve.php
similarity index 100%
rename from ProjectEuler/020/solve.php
rename to solutions/ProjectEuler/020/solve.php
diff --git a/ProjectEuler/020/solve.rb b/solutions/ProjectEuler/020/solve.rb
similarity index 100%
rename from ProjectEuler/020/solve.rb
rename to solutions/ProjectEuler/020/solve.rb
diff --git a/ProjectEuler/021/desc.yml b/solutions/ProjectEuler/021/desc.yml
similarity index 100%
rename from ProjectEuler/021/desc.yml
rename to solutions/ProjectEuler/021/desc.yml
diff --git a/ProjectEuler/021/solve.c b/solutions/ProjectEuler/021/solve.c
similarity index 100%
rename from ProjectEuler/021/solve.c
rename to solutions/ProjectEuler/021/solve.c
diff --git a/ProjectEuler/021/solve.php b/solutions/ProjectEuler/021/solve.php
similarity index 100%
rename from ProjectEuler/021/solve.php
rename to solutions/ProjectEuler/021/solve.php
diff --git a/ProjectEuler/021/solve.rb b/solutions/ProjectEuler/021/solve.rb
similarity index 100%
rename from ProjectEuler/021/solve.rb
rename to solutions/ProjectEuler/021/solve.rb
diff --git a/ProjectEuler/022/desc.yml b/solutions/ProjectEuler/022/desc.yml
similarity index 100%
rename from ProjectEuler/022/desc.yml
rename to solutions/ProjectEuler/022/desc.yml
diff --git a/ProjectEuler/022/input b/solutions/ProjectEuler/022/input
similarity index 100%
rename from ProjectEuler/022/input
rename to solutions/ProjectEuler/022/input
diff --git a/ProjectEuler/022/solve.php b/solutions/ProjectEuler/022/solve.php
similarity index 100%
rename from ProjectEuler/022/solve.php
rename to solutions/ProjectEuler/022/solve.php
diff --git a/ProjectEuler/023/desc.yml b/solutions/ProjectEuler/023/desc.yml
similarity index 100%
rename from ProjectEuler/023/desc.yml
rename to solutions/ProjectEuler/023/desc.yml
diff --git a/ProjectEuler/023/solve.php b/solutions/ProjectEuler/023/solve.php
similarity index 100%
rename from ProjectEuler/023/solve.php
rename to solutions/ProjectEuler/023/solve.php
diff --git a/ProjectEuler/024/desc.yml b/solutions/ProjectEuler/024/desc.yml
similarity index 100%
rename from ProjectEuler/024/desc.yml
rename to solutions/ProjectEuler/024/desc.yml
diff --git a/ProjectEuler/024/solve.php b/solutions/ProjectEuler/024/solve.php
similarity index 100%
rename from ProjectEuler/024/solve.php
rename to solutions/ProjectEuler/024/solve.php
diff --git a/ProjectEuler/025/desc.yml b/solutions/ProjectEuler/025/desc.yml
similarity index 100%
rename from ProjectEuler/025/desc.yml
rename to solutions/ProjectEuler/025/desc.yml
diff --git a/ProjectEuler/025/solve.php b/solutions/ProjectEuler/025/solve.php
similarity index 100%
rename from ProjectEuler/025/solve.php
rename to solutions/ProjectEuler/025/solve.php
diff --git a/ProjectEuler/025/solve.rb b/solutions/ProjectEuler/025/solve.rb
similarity index 100%
rename from ProjectEuler/025/solve.rb
rename to solutions/ProjectEuler/025/solve.rb
diff --git a/ProjectEuler/026/desc.yml b/solutions/ProjectEuler/026/desc.yml
similarity index 100%
rename from ProjectEuler/026/desc.yml
rename to solutions/ProjectEuler/026/desc.yml
diff --git a/ProjectEuler/026/solve.php b/solutions/ProjectEuler/026/solve.php
similarity index 100%
rename from ProjectEuler/026/solve.php
rename to solutions/ProjectEuler/026/solve.php
diff --git a/ProjectEuler/026/solve.rb b/solutions/ProjectEuler/026/solve.rb
similarity index 100%
rename from ProjectEuler/026/solve.rb
rename to solutions/ProjectEuler/026/solve.rb
diff --git a/ProjectEuler/027/desc.yml b/solutions/ProjectEuler/027/desc.yml
similarity index 100%
rename from ProjectEuler/027/desc.yml
rename to solutions/ProjectEuler/027/desc.yml
diff --git a/ProjectEuler/027/problem27.php b/solutions/ProjectEuler/027/problem27.php
similarity index 100%
rename from ProjectEuler/027/problem27.php
rename to solutions/ProjectEuler/027/problem27.php
diff --git a/ProjectEuler/027/solve.php b/solutions/ProjectEuler/027/solve.php
similarity index 100%
rename from ProjectEuler/027/solve.php
rename to solutions/ProjectEuler/027/solve.php
diff --git a/ProjectEuler/027/solve.rb b/solutions/ProjectEuler/027/solve.rb
similarity index 100%
rename from ProjectEuler/027/solve.rb
rename to solutions/ProjectEuler/027/solve.rb
diff --git a/ProjectEuler/028/desc.yml b/solutions/ProjectEuler/028/desc.yml
similarity index 100%
rename from ProjectEuler/028/desc.yml
rename to solutions/ProjectEuler/028/desc.yml
diff --git a/ProjectEuler/028/solve.c b/solutions/ProjectEuler/028/solve.c
similarity index 100%
rename from ProjectEuler/028/solve.c
rename to solutions/ProjectEuler/028/solve.c
diff --git a/ProjectEuler/028/solve.js b/solutions/ProjectEuler/028/solve.js
similarity index 100%
rename from ProjectEuler/028/solve.js
rename to solutions/ProjectEuler/028/solve.js
diff --git a/ProjectEuler/028/solve.lua b/solutions/ProjectEuler/028/solve.lua
similarity index 100%
rename from ProjectEuler/028/solve.lua
rename to solutions/ProjectEuler/028/solve.lua
diff --git a/ProjectEuler/028/solve.php b/solutions/ProjectEuler/028/solve.php
similarity index 100%
rename from ProjectEuler/028/solve.php
rename to solutions/ProjectEuler/028/solve.php
diff --git a/ProjectEuler/028/solve.rb b/solutions/ProjectEuler/028/solve.rb
similarity index 100%
rename from ProjectEuler/028/solve.rb
rename to solutions/ProjectEuler/028/solve.rb
diff --git a/ProjectEuler/029/desc.yml b/solutions/ProjectEuler/029/desc.yml
similarity index 100%
rename from ProjectEuler/029/desc.yml
rename to solutions/ProjectEuler/029/desc.yml
diff --git a/ProjectEuler/029/solve.php b/solutions/ProjectEuler/029/solve.php
similarity index 100%
rename from ProjectEuler/029/solve.php
rename to solutions/ProjectEuler/029/solve.php
diff --git a/ProjectEuler/029/solve.rb b/solutions/ProjectEuler/029/solve.rb
similarity index 100%
rename from ProjectEuler/029/solve.rb
rename to solutions/ProjectEuler/029/solve.rb
diff --git a/ProjectEuler/030/desc.yml b/solutions/ProjectEuler/030/desc.yml
similarity index 100%
rename from ProjectEuler/030/desc.yml
rename to solutions/ProjectEuler/030/desc.yml
diff --git a/ProjectEuler/030/solve.php b/solutions/ProjectEuler/030/solve.php
similarity index 100%
rename from ProjectEuler/030/solve.php
rename to solutions/ProjectEuler/030/solve.php
diff --git a/ProjectEuler/031/desc.yml b/solutions/ProjectEuler/031/desc.yml
similarity index 100%
rename from ProjectEuler/031/desc.yml
rename to solutions/ProjectEuler/031/desc.yml
diff --git a/ProjectEuler/031/problem31.php b/solutions/ProjectEuler/031/problem31.php
similarity index 100%
rename from ProjectEuler/031/problem31.php
rename to solutions/ProjectEuler/031/problem31.php
diff --git a/ProjectEuler/031/solve.php b/solutions/ProjectEuler/031/solve.php
similarity index 100%
rename from ProjectEuler/031/solve.php
rename to solutions/ProjectEuler/031/solve.php
diff --git a/ProjectEuler/032/desc.yml b/solutions/ProjectEuler/032/desc.yml
similarity index 100%
rename from ProjectEuler/032/desc.yml
rename to solutions/ProjectEuler/032/desc.yml
diff --git a/ProjectEuler/032/solve.php b/solutions/ProjectEuler/032/solve.php
similarity index 100%
rename from ProjectEuler/032/solve.php
rename to solutions/ProjectEuler/032/solve.php
diff --git a/ProjectEuler/033/solve.php b/solutions/ProjectEuler/033/solve.php
similarity index 100%
rename from ProjectEuler/033/solve.php
rename to solutions/ProjectEuler/033/solve.php
diff --git a/ProjectEuler/034/desc.yml b/solutions/ProjectEuler/034/desc.yml
similarity index 100%
rename from ProjectEuler/034/desc.yml
rename to solutions/ProjectEuler/034/desc.yml
diff --git a/ProjectEuler/034/solve.php b/solutions/ProjectEuler/034/solve.php
similarity index 100%
rename from ProjectEuler/034/solve.php
rename to solutions/ProjectEuler/034/solve.php
diff --git a/ProjectEuler/035/desc.yml b/solutions/ProjectEuler/035/desc.yml
similarity index 100%
rename from ProjectEuler/035/desc.yml
rename to solutions/ProjectEuler/035/desc.yml
diff --git a/ProjectEuler/035/solve.php b/solutions/ProjectEuler/035/solve.php
similarity index 100%
rename from ProjectEuler/035/solve.php
rename to solutions/ProjectEuler/035/solve.php
diff --git a/ProjectEuler/036/desc.yml b/solutions/ProjectEuler/036/desc.yml
similarity index 100%
rename from ProjectEuler/036/desc.yml
rename to solutions/ProjectEuler/036/desc.yml
diff --git a/ProjectEuler/036/solve.php b/solutions/ProjectEuler/036/solve.php
similarity index 100%
rename from ProjectEuler/036/solve.php
rename to solutions/ProjectEuler/036/solve.php
diff --git a/ProjectEuler/036/solve.rb b/solutions/ProjectEuler/036/solve.rb
similarity index 100%
rename from ProjectEuler/036/solve.rb
rename to solutions/ProjectEuler/036/solve.rb
diff --git a/ProjectEuler/037/solve.php b/solutions/ProjectEuler/037/solve.php
similarity index 100%
rename from ProjectEuler/037/solve.php
rename to solutions/ProjectEuler/037/solve.php
diff --git a/ProjectEuler/038/desc.yml b/solutions/ProjectEuler/038/desc.yml
similarity index 100%
rename from ProjectEuler/038/desc.yml
rename to solutions/ProjectEuler/038/desc.yml
diff --git a/ProjectEuler/038/solve.php b/solutions/ProjectEuler/038/solve.php
similarity index 100%
rename from ProjectEuler/038/solve.php
rename to solutions/ProjectEuler/038/solve.php
diff --git a/ProjectEuler/039/desc.yml b/solutions/ProjectEuler/039/desc.yml
similarity index 100%
rename from ProjectEuler/039/desc.yml
rename to solutions/ProjectEuler/039/desc.yml
diff --git a/ProjectEuler/039/solve.c b/solutions/ProjectEuler/039/solve.c
similarity index 100%
rename from ProjectEuler/039/solve.c
rename to solutions/ProjectEuler/039/solve.c
diff --git a/ProjectEuler/039/solve.php b/solutions/ProjectEuler/039/solve.php
similarity index 100%
rename from ProjectEuler/039/solve.php
rename to solutions/ProjectEuler/039/solve.php
diff --git a/ProjectEuler/041/desc.yml b/solutions/ProjectEuler/041/desc.yml
similarity index 100%
rename from ProjectEuler/041/desc.yml
rename to solutions/ProjectEuler/041/desc.yml
diff --git a/ProjectEuler/041/solve.php b/solutions/ProjectEuler/041/solve.php
similarity index 100%
rename from ProjectEuler/041/solve.php
rename to solutions/ProjectEuler/041/solve.php
diff --git a/ProjectEuler/042/desc.yml b/solutions/ProjectEuler/042/desc.yml
similarity index 100%
rename from ProjectEuler/042/desc.yml
rename to solutions/ProjectEuler/042/desc.yml
diff --git a/ProjectEuler/042/solve.php b/solutions/ProjectEuler/042/solve.php
similarity index 100%
rename from ProjectEuler/042/solve.php
rename to solutions/ProjectEuler/042/solve.php
diff --git a/ProjectEuler/042/words.txt b/solutions/ProjectEuler/042/words.txt
similarity index 100%
rename from ProjectEuler/042/words.txt
rename to solutions/ProjectEuler/042/words.txt
diff --git a/ProjectEuler/043/solve.php b/solutions/ProjectEuler/043/solve.php
similarity index 100%
rename from ProjectEuler/043/solve.php
rename to solutions/ProjectEuler/043/solve.php
diff --git a/ProjectEuler/044/solve.php b/solutions/ProjectEuler/044/solve.php
similarity index 100%
rename from ProjectEuler/044/solve.php
rename to solutions/ProjectEuler/044/solve.php
diff --git a/ProjectEuler/045/solve.php b/solutions/ProjectEuler/045/solve.php
similarity index 100%
rename from ProjectEuler/045/solve.php
rename to solutions/ProjectEuler/045/solve.php
diff --git a/ProjectEuler/048/desc.yml b/solutions/ProjectEuler/048/desc.yml
similarity index 100%
rename from ProjectEuler/048/desc.yml
rename to solutions/ProjectEuler/048/desc.yml
diff --git a/ProjectEuler/048/solve.php b/solutions/ProjectEuler/048/solve.php
similarity index 100%
rename from ProjectEuler/048/solve.php
rename to solutions/ProjectEuler/048/solve.php
diff --git a/ProjectEuler/048/solve.rb b/solutions/ProjectEuler/048/solve.rb
similarity index 100%
rename from ProjectEuler/048/solve.rb
rename to solutions/ProjectEuler/048/solve.rb
diff --git a/ProjectEuler/104/desc.yml b/solutions/ProjectEuler/104/desc.yml
similarity index 100%
rename from ProjectEuler/104/desc.yml
rename to solutions/ProjectEuler/104/desc.yml
diff --git a/ProjectEuler/104/solve.php b/solutions/ProjectEuler/104/solve.php
similarity index 100%
rename from ProjectEuler/104/solve.php
rename to solutions/ProjectEuler/104/solve.php
diff --git a/ProjectEuler/desc.yml b/solutions/ProjectEuler/desc.yml
similarity index 100%
rename from ProjectEuler/desc.yml
rename to solutions/ProjectEuler/desc.yml
diff --git a/src/Numerical.php b/src/Numerical.php
new file mode 100644
index 0000000..2ec1c0a
--- /dev/null
+++ b/src/Numerical.php
@@ -0,0 +1,27 @@
+1,50=>1,51=>1,52=>1,53=>1,54=>1,55=>1,56=>1,57=>1)) {
+ return true;
+ } else {
+ return false;
+ }
+ }
+
+ function isPandigitalWithZero(int $input)
+ {
+ $array = count_chars($input,1);
+ ksort($array);
+ if($array == array(48=>0, 49=>1,50=>1,51=>1,52=>1,53=>1,54=>1,55=>1,56=>1,57=>1)) {
+ return true;
+ } else {
+ return false;
+ }
+ }
+}
\ No newline at end of file
diff --git a/src/Prime.php b/src/Prime.php
new file mode 100644
index 0000000..54b500b
--- /dev/null
+++ b/src/Prime.php
@@ -0,0 +1,46 @@
+
-<%= problem['url'] %>
-
-Desc:
-<%= problem['desc'] %>
-
-<% if( problem['solution'] and problem['solutions'] ) %>
-Solution:
-<%= problem['solution'] %>
- <% problem['solutions'].each do |sol| %>
- <%= sol[0] %>
- <%= sol[1]['desc'] %>
- <%= sol[1]['language'] %>
- <% end %>
-<% end %>
\ No newline at end of file
diff --git a/tests/PrimeTest.php b/tests/PrimeTest.php
new file mode 100644
index 0000000..80303b6
--- /dev/null
+++ b/tests/PrimeTest.php
@@ -0,0 +1,25 @@
+assertEquals(in_array($test, $primes), $ret, "Testing $test");
+
+ }
+ }
+}
\ No newline at end of file
diff --git a/vendor/autoload.php b/vendor/autoload.php
new file mode 100644
index 0000000..b19da2c
--- /dev/null
+++ b/vendor/autoload.php
@@ -0,0 +1,25 @@
+
+ * Jordi Boggiano
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Composer\Autoload;
+
+/**
+ * ClassLoader implements a PSR-0, PSR-4 and classmap class loader.
+ *
+ * $loader = new \Composer\Autoload\ClassLoader();
+ *
+ * // register classes with namespaces
+ * $loader->add('Symfony\Component', __DIR__.'/component');
+ * $loader->add('Symfony', __DIR__.'/framework');
+ *
+ * // activate the autoloader
+ * $loader->register();
+ *
+ * // to enable searching the include path (eg. for PEAR packages)
+ * $loader->setUseIncludePath(true);
+ *
+ * In this example, if you try to use a class in the Symfony\Component
+ * namespace or one of its children (Symfony\Component\Console for instance),
+ * the autoloader will first look for the class under the component/
+ * directory, and it will then fallback to the framework/ directory if not
+ * found before giving up.
+ *
+ * This class is loosely based on the Symfony UniversalClassLoader.
+ *
+ * @author Fabien Potencier
+ * @author Jordi Boggiano
+ * @see https://www.php-fig.org/psr/psr-0/
+ * @see https://www.php-fig.org/psr/psr-4/
+ */
+class ClassLoader
+{
+ /** @var \Closure(string):void */
+ private static $includeFile;
+
+ /** @var string|null */
+ private $vendorDir;
+
+ // PSR-4
+ /**
+ * @var array>
+ */
+ private $prefixLengthsPsr4 = array();
+ /**
+ * @var array>
+ */
+ private $prefixDirsPsr4 = array();
+ /**
+ * @var list
+ */
+ private $fallbackDirsPsr4 = array();
+
+ // PSR-0
+ /**
+ * List of PSR-0 prefixes
+ *
+ * Structured as array('F (first letter)' => array('Foo\Bar (full prefix)' => array('path', 'path2')))
+ *
+ * @var array>>
+ */
+ private $prefixesPsr0 = array();
+ /**
+ * @var list
+ */
+ private $fallbackDirsPsr0 = array();
+
+ /** @var bool */
+ private $useIncludePath = false;
+
+ /**
+ * @var array
+ */
+ private $classMap = array();
+
+ /** @var bool */
+ private $classMapAuthoritative = false;
+
+ /**
+ * @var array
+ */
+ private $missingClasses = array();
+
+ /** @var string|null */
+ private $apcuPrefix;
+
+ /**
+ * @var array
+ */
+ private static $registeredLoaders = array();
+
+ /**
+ * @param string|null $vendorDir
+ */
+ public function __construct($vendorDir = null)
+ {
+ $this->vendorDir = $vendorDir;
+ self::initializeIncludeClosure();
+ }
+
+ /**
+ * @return array>
+ */
+ public function getPrefixes()
+ {
+ if (!empty($this->prefixesPsr0)) {
+ return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
+ }
+
+ return array();
+ }
+
+ /**
+ * @return array>
+ */
+ public function getPrefixesPsr4()
+ {
+ return $this->prefixDirsPsr4;
+ }
+
+ /**
+ * @return list
+ */
+ public function getFallbackDirs()
+ {
+ return $this->fallbackDirsPsr0;
+ }
+
+ /**
+ * @return list
+ */
+ public function getFallbackDirsPsr4()
+ {
+ return $this->fallbackDirsPsr4;
+ }
+
+ /**
+ * @return array Array of classname => path
+ */
+ public function getClassMap()
+ {
+ return $this->classMap;
+ }
+
+ /**
+ * @param array $classMap Class to filename map
+ *
+ * @return void
+ */
+ public function addClassMap(array $classMap)
+ {
+ if ($this->classMap) {
+ $this->classMap = array_merge($this->classMap, $classMap);
+ } else {
+ $this->classMap = $classMap;
+ }
+ }
+
+ /**
+ * Registers a set of PSR-0 directories for a given prefix, either
+ * appending or prepending to the ones previously set for this prefix.
+ *
+ * @param string $prefix The prefix
+ * @param list|string $paths The PSR-0 root directories
+ * @param bool $prepend Whether to prepend the directories
+ *
+ * @return void
+ */
+ public function add($prefix, $paths, $prepend = false)
+ {
+ $paths = (array) $paths;
+ if (!$prefix) {
+ if ($prepend) {
+ $this->fallbackDirsPsr0 = array_merge(
+ $paths,
+ $this->fallbackDirsPsr0
+ );
+ } else {
+ $this->fallbackDirsPsr0 = array_merge(
+ $this->fallbackDirsPsr0,
+ $paths
+ );
+ }
+
+ return;
+ }
+
+ $first = $prefix[0];
+ if (!isset($this->prefixesPsr0[$first][$prefix])) {
+ $this->prefixesPsr0[$first][$prefix] = $paths;
+
+ return;
+ }
+ if ($prepend) {
+ $this->prefixesPsr0[$first][$prefix] = array_merge(
+ $paths,
+ $this->prefixesPsr0[$first][$prefix]
+ );
+ } else {
+ $this->prefixesPsr0[$first][$prefix] = array_merge(
+ $this->prefixesPsr0[$first][$prefix],
+ $paths
+ );
+ }
+ }
+
+ /**
+ * Registers a set of PSR-4 directories for a given namespace, either
+ * appending or prepending to the ones previously set for this namespace.
+ *
+ * @param string $prefix The prefix/namespace, with trailing '\\'
+ * @param list|string $paths The PSR-4 base directories
+ * @param bool $prepend Whether to prepend the directories
+ *
+ * @throws \InvalidArgumentException
+ *
+ * @return void
+ */
+ public function addPsr4($prefix, $paths, $prepend = false)
+ {
+ $paths = (array) $paths;
+ if (!$prefix) {
+ // Register directories for the root namespace.
+ if ($prepend) {
+ $this->fallbackDirsPsr4 = array_merge(
+ $paths,
+ $this->fallbackDirsPsr4
+ );
+ } else {
+ $this->fallbackDirsPsr4 = array_merge(
+ $this->fallbackDirsPsr4,
+ $paths
+ );
+ }
+ } elseif (!isset($this->prefixDirsPsr4[$prefix])) {
+ // Register directories for a new namespace.
+ $length = strlen($prefix);
+ if ('\\' !== $prefix[$length - 1]) {
+ throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
+ }
+ $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
+ $this->prefixDirsPsr4[$prefix] = $paths;
+ } elseif ($prepend) {
+ // Prepend directories for an already registered namespace.
+ $this->prefixDirsPsr4[$prefix] = array_merge(
+ $paths,
+ $this->prefixDirsPsr4[$prefix]
+ );
+ } else {
+ // Append directories for an already registered namespace.
+ $this->prefixDirsPsr4[$prefix] = array_merge(
+ $this->prefixDirsPsr4[$prefix],
+ $paths
+ );
+ }
+ }
+
+ /**
+ * Registers a set of PSR-0 directories for a given prefix,
+ * replacing any others previously set for this prefix.
+ *
+ * @param string $prefix The prefix
+ * @param list|string $paths The PSR-0 base directories
+ *
+ * @return void
+ */
+ public function set($prefix, $paths)
+ {
+ if (!$prefix) {
+ $this->fallbackDirsPsr0 = (array) $paths;
+ } else {
+ $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths;
+ }
+ }
+
+ /**
+ * Registers a set of PSR-4 directories for a given namespace,
+ * replacing any others previously set for this namespace.
+ *
+ * @param string $prefix The prefix/namespace, with trailing '\\'
+ * @param list|string $paths The PSR-4 base directories
+ *
+ * @throws \InvalidArgumentException
+ *
+ * @return void
+ */
+ public function setPsr4($prefix, $paths)
+ {
+ if (!$prefix) {
+ $this->fallbackDirsPsr4 = (array) $paths;
+ } else {
+ $length = strlen($prefix);
+ if ('\\' !== $prefix[$length - 1]) {
+ throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator.");
+ }
+ $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length;
+ $this->prefixDirsPsr4[$prefix] = (array) $paths;
+ }
+ }
+
+ /**
+ * Turns on searching the include path for class files.
+ *
+ * @param bool $useIncludePath
+ *
+ * @return void
+ */
+ public function setUseIncludePath($useIncludePath)
+ {
+ $this->useIncludePath = $useIncludePath;
+ }
+
+ /**
+ * Can be used to check if the autoloader uses the include path to check
+ * for classes.
+ *
+ * @return bool
+ */
+ public function getUseIncludePath()
+ {
+ return $this->useIncludePath;
+ }
+
+ /**
+ * Turns off searching the prefix and fallback directories for classes
+ * that have not been registered with the class map.
+ *
+ * @param bool $classMapAuthoritative
+ *
+ * @return void
+ */
+ public function setClassMapAuthoritative($classMapAuthoritative)
+ {
+ $this->classMapAuthoritative = $classMapAuthoritative;
+ }
+
+ /**
+ * Should class lookup fail if not found in the current class map?
+ *
+ * @return bool
+ */
+ public function isClassMapAuthoritative()
+ {
+ return $this->classMapAuthoritative;
+ }
+
+ /**
+ * APCu prefix to use to cache found/not-found classes, if the extension is enabled.
+ *
+ * @param string|null $apcuPrefix
+ *
+ * @return void
+ */
+ public function setApcuPrefix($apcuPrefix)
+ {
+ $this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null;
+ }
+
+ /**
+ * The APCu prefix in use, or null if APCu caching is not enabled.
+ *
+ * @return string|null
+ */
+ public function getApcuPrefix()
+ {
+ return $this->apcuPrefix;
+ }
+
+ /**
+ * Registers this instance as an autoloader.
+ *
+ * @param bool $prepend Whether to prepend the autoloader or not
+ *
+ * @return void
+ */
+ public function register($prepend = false)
+ {
+ spl_autoload_register(array($this, 'loadClass'), true, $prepend);
+
+ if (null === $this->vendorDir) {
+ return;
+ }
+
+ if ($prepend) {
+ self::$registeredLoaders = array($this->vendorDir => $this) + self::$registeredLoaders;
+ } else {
+ unset(self::$registeredLoaders[$this->vendorDir]);
+ self::$registeredLoaders[$this->vendorDir] = $this;
+ }
+ }
+
+ /**
+ * Unregisters this instance as an autoloader.
+ *
+ * @return void
+ */
+ public function unregister()
+ {
+ spl_autoload_unregister(array($this, 'loadClass'));
+
+ if (null !== $this->vendorDir) {
+ unset(self::$registeredLoaders[$this->vendorDir]);
+ }
+ }
+
+ /**
+ * Loads the given class or interface.
+ *
+ * @param string $class The name of the class
+ * @return true|null True if loaded, null otherwise
+ */
+ public function loadClass($class)
+ {
+ if ($file = $this->findFile($class)) {
+ $includeFile = self::$includeFile;
+ $includeFile($file);
+
+ return true;
+ }
+
+ return null;
+ }
+
+ /**
+ * Finds the path to the file where the class is defined.
+ *
+ * @param string $class The name of the class
+ *
+ * @return string|false The path if found, false otherwise
+ */
+ public function findFile($class)
+ {
+ // class map lookup
+ if (isset($this->classMap[$class])) {
+ return $this->classMap[$class];
+ }
+ if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
+ return false;
+ }
+ if (null !== $this->apcuPrefix) {
+ $file = apcu_fetch($this->apcuPrefix.$class, $hit);
+ if ($hit) {
+ return $file;
+ }
+ }
+
+ $file = $this->findFileWithExtension($class, '.php');
+
+ // Search for Hack files if we are running on HHVM
+ if (false === $file && defined('HHVM_VERSION')) {
+ $file = $this->findFileWithExtension($class, '.hh');
+ }
+
+ if (null !== $this->apcuPrefix) {
+ apcu_add($this->apcuPrefix.$class, $file);
+ }
+
+ if (false === $file) {
+ // Remember that this class does not exist.
+ $this->missingClasses[$class] = true;
+ }
+
+ return $file;
+ }
+
+ /**
+ * Returns the currently registered loaders keyed by their corresponding vendor directories.
+ *
+ * @return array
+ */
+ public static function getRegisteredLoaders()
+ {
+ return self::$registeredLoaders;
+ }
+
+ /**
+ * @param string $class
+ * @param string $ext
+ * @return string|false
+ */
+ private function findFileWithExtension($class, $ext)
+ {
+ // PSR-4 lookup
+ $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
+
+ $first = $class[0];
+ if (isset($this->prefixLengthsPsr4[$first])) {
+ $subPath = $class;
+ while (false !== $lastPos = strrpos($subPath, '\\')) {
+ $subPath = substr($subPath, 0, $lastPos);
+ $search = $subPath . '\\';
+ if (isset($this->prefixDirsPsr4[$search])) {
+ $pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
+ foreach ($this->prefixDirsPsr4[$search] as $dir) {
+ if (file_exists($file = $dir . $pathEnd)) {
+ return $file;
+ }
+ }
+ }
+ }
+ }
+
+ // PSR-4 fallback dirs
+ foreach ($this->fallbackDirsPsr4 as $dir) {
+ if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
+ return $file;
+ }
+ }
+
+ // PSR-0 lookup
+ if (false !== $pos = strrpos($class, '\\')) {
+ // namespaced class name
+ $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1)
+ . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR);
+ } else {
+ // PEAR-like class name
+ $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext;
+ }
+
+ if (isset($this->prefixesPsr0[$first])) {
+ foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) {
+ if (0 === strpos($class, $prefix)) {
+ foreach ($dirs as $dir) {
+ if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
+ return $file;
+ }
+ }
+ }
+ }
+ }
+
+ // PSR-0 fallback dirs
+ foreach ($this->fallbackDirsPsr0 as $dir) {
+ if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) {
+ return $file;
+ }
+ }
+
+ // PSR-0 include paths.
+ if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) {
+ return $file;
+ }
+
+ return false;
+ }
+
+ /**
+ * @return void
+ */
+ private static function initializeIncludeClosure()
+ {
+ if (self::$includeFile !== null) {
+ return;
+ }
+
+ /**
+ * Scope isolated include.
+ *
+ * Prevents access to $this/self from included files.
+ *
+ * @param string $file
+ * @return void
+ */
+ self::$includeFile = \Closure::bind(static function($file) {
+ include $file;
+ }, null, null);
+ }
+}
diff --git a/vendor/composer/InstalledVersions.php b/vendor/composer/InstalledVersions.php
new file mode 100644
index 0000000..51e734a
--- /dev/null
+++ b/vendor/composer/InstalledVersions.php
@@ -0,0 +1,359 @@
+
+ * Jordi Boggiano
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+namespace Composer;
+
+use Composer\Autoload\ClassLoader;
+use Composer\Semver\VersionParser;
+
+/**
+ * This class is copied in every Composer installed project and available to all
+ *
+ * See also https://getcomposer.org/doc/07-runtime.md#installed-versions
+ *
+ * To require its presence, you can require `composer-runtime-api ^2.0`
+ *
+ * @final
+ */
+class InstalledVersions
+{
+ /**
+ * @var mixed[]|null
+ * @psalm-var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array}|array{}|null
+ */
+ private static $installed;
+
+ /**
+ * @var bool|null
+ */
+ private static $canGetVendors;
+
+ /**
+ * @var array[]
+ * @psalm-var array}>
+ */
+ private static $installedByVendor = array();
+
+ /**
+ * Returns a list of all package names which are present, either by being installed, replaced or provided
+ *
+ * @return string[]
+ * @psalm-return list
+ */
+ public static function getInstalledPackages()
+ {
+ $packages = array();
+ foreach (self::getInstalled() as $installed) {
+ $packages[] = array_keys($installed['versions']);
+ }
+
+ if (1 === \count($packages)) {
+ return $packages[0];
+ }
+
+ return array_keys(array_flip(\call_user_func_array('array_merge', $packages)));
+ }
+
+ /**
+ * Returns a list of all package names with a specific type e.g. 'library'
+ *
+ * @param string $type
+ * @return string[]
+ * @psalm-return list
+ */
+ public static function getInstalledPackagesByType($type)
+ {
+ $packagesByType = array();
+
+ foreach (self::getInstalled() as $installed) {
+ foreach ($installed['versions'] as $name => $package) {
+ if (isset($package['type']) && $package['type'] === $type) {
+ $packagesByType[] = $name;
+ }
+ }
+ }
+
+ return $packagesByType;
+ }
+
+ /**
+ * Checks whether the given package is installed
+ *
+ * This also returns true if the package name is provided or replaced by another package
+ *
+ * @param string $packageName
+ * @param bool $includeDevRequirements
+ * @return bool
+ */
+ public static function isInstalled($packageName, $includeDevRequirements = true)
+ {
+ foreach (self::getInstalled() as $installed) {
+ if (isset($installed['versions'][$packageName])) {
+ return $includeDevRequirements || !isset($installed['versions'][$packageName]['dev_requirement']) || $installed['versions'][$packageName]['dev_requirement'] === false;
+ }
+ }
+
+ return false;
+ }
+
+ /**
+ * Checks whether the given package satisfies a version constraint
+ *
+ * e.g. If you want to know whether version 2.3+ of package foo/bar is installed, you would call:
+ *
+ * Composer\InstalledVersions::satisfies(new VersionParser, 'foo/bar', '^2.3')
+ *
+ * @param VersionParser $parser Install composer/semver to have access to this class and functionality
+ * @param string $packageName
+ * @param string|null $constraint A version constraint to check for, if you pass one you have to make sure composer/semver is required by your package
+ * @return bool
+ */
+ public static function satisfies(VersionParser $parser, $packageName, $constraint)
+ {
+ $constraint = $parser->parseConstraints((string) $constraint);
+ $provided = $parser->parseConstraints(self::getVersionRanges($packageName));
+
+ return $provided->matches($constraint);
+ }
+
+ /**
+ * Returns a version constraint representing all the range(s) which are installed for a given package
+ *
+ * It is easier to use this via isInstalled() with the $constraint argument if you need to check
+ * whether a given version of a package is installed, and not just whether it exists
+ *
+ * @param string $packageName
+ * @return string Version constraint usable with composer/semver
+ */
+ public static function getVersionRanges($packageName)
+ {
+ foreach (self::getInstalled() as $installed) {
+ if (!isset($installed['versions'][$packageName])) {
+ continue;
+ }
+
+ $ranges = array();
+ if (isset($installed['versions'][$packageName]['pretty_version'])) {
+ $ranges[] = $installed['versions'][$packageName]['pretty_version'];
+ }
+ if (array_key_exists('aliases', $installed['versions'][$packageName])) {
+ $ranges = array_merge($ranges, $installed['versions'][$packageName]['aliases']);
+ }
+ if (array_key_exists('replaced', $installed['versions'][$packageName])) {
+ $ranges = array_merge($ranges, $installed['versions'][$packageName]['replaced']);
+ }
+ if (array_key_exists('provided', $installed['versions'][$packageName])) {
+ $ranges = array_merge($ranges, $installed['versions'][$packageName]['provided']);
+ }
+
+ return implode(' || ', $ranges);
+ }
+
+ throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+ }
+
+ /**
+ * @param string $packageName
+ * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
+ */
+ public static function getVersion($packageName)
+ {
+ foreach (self::getInstalled() as $installed) {
+ if (!isset($installed['versions'][$packageName])) {
+ continue;
+ }
+
+ if (!isset($installed['versions'][$packageName]['version'])) {
+ return null;
+ }
+
+ return $installed['versions'][$packageName]['version'];
+ }
+
+ throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+ }
+
+ /**
+ * @param string $packageName
+ * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
+ */
+ public static function getPrettyVersion($packageName)
+ {
+ foreach (self::getInstalled() as $installed) {
+ if (!isset($installed['versions'][$packageName])) {
+ continue;
+ }
+
+ if (!isset($installed['versions'][$packageName]['pretty_version'])) {
+ return null;
+ }
+
+ return $installed['versions'][$packageName]['pretty_version'];
+ }
+
+ throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+ }
+
+ /**
+ * @param string $packageName
+ * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as reference
+ */
+ public static function getReference($packageName)
+ {
+ foreach (self::getInstalled() as $installed) {
+ if (!isset($installed['versions'][$packageName])) {
+ continue;
+ }
+
+ if (!isset($installed['versions'][$packageName]['reference'])) {
+ return null;
+ }
+
+ return $installed['versions'][$packageName]['reference'];
+ }
+
+ throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+ }
+
+ /**
+ * @param string $packageName
+ * @return string|null If the package is being replaced or provided but is not really installed, null will be returned as install path. Packages of type metapackages also have a null install path.
+ */
+ public static function getInstallPath($packageName)
+ {
+ foreach (self::getInstalled() as $installed) {
+ if (!isset($installed['versions'][$packageName])) {
+ continue;
+ }
+
+ return isset($installed['versions'][$packageName]['install_path']) ? $installed['versions'][$packageName]['install_path'] : null;
+ }
+
+ throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
+ }
+
+ /**
+ * @return array
+ * @psalm-return array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}
+ */
+ public static function getRootPackage()
+ {
+ $installed = self::getInstalled();
+
+ return $installed[0]['root'];
+ }
+
+ /**
+ * Returns the raw installed.php data for custom implementations
+ *
+ * @deprecated Use getAllRawData() instead which returns all datasets for all autoloaders present in the process. getRawData only returns the first dataset loaded, which may not be what you expect.
+ * @return array[]
+ * @psalm-return array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array}
+ */
+ public static function getRawData()
+ {
+ @trigger_error('getRawData only returns the first dataset loaded, which may not be what you expect. Use getAllRawData() instead which returns all datasets for all autoloaders present in the process.', E_USER_DEPRECATED);
+
+ if (null === self::$installed) {
+ // only require the installed.php file if this file is loaded from its dumped location,
+ // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
+ if (substr(__DIR__, -8, 1) !== 'C') {
+ self::$installed = include __DIR__ . '/installed.php';
+ } else {
+ self::$installed = array();
+ }
+ }
+
+ return self::$installed;
+ }
+
+ /**
+ * Returns the raw data of all installed.php which are currently loaded for custom implementations
+ *
+ * @return array[]
+ * @psalm-return list}>
+ */
+ public static function getAllRawData()
+ {
+ return self::getInstalled();
+ }
+
+ /**
+ * Lets you reload the static array from another file
+ *
+ * This is only useful for complex integrations in which a project needs to use
+ * this class but then also needs to execute another project's autoloader in process,
+ * and wants to ensure both projects have access to their version of installed.php.
+ *
+ * A typical case would be PHPUnit, where it would need to make sure it reads all
+ * the data it needs from this class, then call reload() with
+ * `require $CWD/vendor/composer/installed.php` (or similar) as input to make sure
+ * the project in which it runs can then also use this class safely, without
+ * interference between PHPUnit's dependencies and the project's dependencies.
+ *
+ * @param array[] $data A vendor/composer/installed.php data set
+ * @return void
+ *
+ * @psalm-param array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $data
+ */
+ public static function reload($data)
+ {
+ self::$installed = $data;
+ self::$installedByVendor = array();
+ }
+
+ /**
+ * @return array[]
+ * @psalm-return list}>
+ */
+ private static function getInstalled()
+ {
+ if (null === self::$canGetVendors) {
+ self::$canGetVendors = method_exists('Composer\Autoload\ClassLoader', 'getRegisteredLoaders');
+ }
+
+ $installed = array();
+
+ if (self::$canGetVendors) {
+ foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) {
+ if (isset(self::$installedByVendor[$vendorDir])) {
+ $installed[] = self::$installedByVendor[$vendorDir];
+ } elseif (is_file($vendorDir.'/composer/installed.php')) {
+ /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */
+ $required = require $vendorDir.'/composer/installed.php';
+ $installed[] = self::$installedByVendor[$vendorDir] = $required;
+ if (null === self::$installed && strtr($vendorDir.'/composer', '\\', '/') === strtr(__DIR__, '\\', '/')) {
+ self::$installed = $installed[count($installed) - 1];
+ }
+ }
+ }
+ }
+
+ if (null === self::$installed) {
+ // only require the installed.php file if this file is loaded from its dumped location,
+ // and not from its source location in the composer/composer package, see https://github.com/composer/composer/issues/9937
+ if (substr(__DIR__, -8, 1) !== 'C') {
+ /** @var array{root: array{name: string, pretty_version: string, version: string, reference: string|null, type: string, install_path: string, aliases: string[], dev: bool}, versions: array} $required */
+ $required = require __DIR__ . '/installed.php';
+ self::$installed = $required;
+ } else {
+ self::$installed = array();
+ }
+ }
+
+ if (self::$installed !== array()) {
+ $installed[] = self::$installed;
+ }
+
+ return $installed;
+ }
+}
diff --git a/vendor/composer/LICENSE b/vendor/composer/LICENSE
new file mode 100644
index 0000000..f27399a
--- /dev/null
+++ b/vendor/composer/LICENSE
@@ -0,0 +1,21 @@
+
+Copyright (c) Nils Adermann, Jordi Boggiano
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is furnished
+to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in all
+copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+
diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php
new file mode 100644
index 0000000..0fb0a2c
--- /dev/null
+++ b/vendor/composer/autoload_classmap.php
@@ -0,0 +1,10 @@
+ $vendorDir . '/composer/InstalledVersions.php',
+);
diff --git a/vendor/composer/autoload_namespaces.php b/vendor/composer/autoload_namespaces.php
new file mode 100644
index 0000000..15a2ff3
--- /dev/null
+++ b/vendor/composer/autoload_namespaces.php
@@ -0,0 +1,9 @@
+ array($baseDir . '/src'),
+);
diff --git a/vendor/composer/autoload_real.php b/vendor/composer/autoload_real.php
new file mode 100644
index 0000000..7b1ab6f
--- /dev/null
+++ b/vendor/composer/autoload_real.php
@@ -0,0 +1,38 @@
+register(true);
+
+ return $loader;
+ }
+}
diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php
new file mode 100644
index 0000000..2380c91
--- /dev/null
+++ b/vendor/composer/autoload_static.php
@@ -0,0 +1,36 @@
+
+ array (
+ 'CodingTests\\' => 12,
+ ),
+ );
+
+ public static $prefixDirsPsr4 = array (
+ 'CodingTests\\' =>
+ array (
+ 0 => __DIR__ . '/../..' . '/src',
+ ),
+ );
+
+ public static $classMap = array (
+ 'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
+ );
+
+ public static function getInitializer(ClassLoader $loader)
+ {
+ return \Closure::bind(function () use ($loader) {
+ $loader->prefixLengthsPsr4 = ComposerStaticInit1fec30c71407f68099d62f794946e565::$prefixLengthsPsr4;
+ $loader->prefixDirsPsr4 = ComposerStaticInit1fec30c71407f68099d62f794946e565::$prefixDirsPsr4;
+ $loader->classMap = ComposerStaticInit1fec30c71407f68099d62f794946e565::$classMap;
+
+ }, null, ClassLoader::class);
+ }
+}
diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json
new file mode 100644
index 0000000..87fda74
--- /dev/null
+++ b/vendor/composer/installed.json
@@ -0,0 +1,5 @@
+{
+ "packages": [],
+ "dev": true,
+ "dev-package-names": []
+}
diff --git a/vendor/composer/installed.php b/vendor/composer/installed.php
new file mode 100644
index 0000000..1ede649
--- /dev/null
+++ b/vendor/composer/installed.php
@@ -0,0 +1,23 @@
+ array(
+ 'name' => 'furyfire/codingtests',
+ 'pretty_version' => 'dev-master',
+ 'version' => 'dev-master',
+ 'reference' => 'f11b705ef016cd7ff5c1803bcbeb196dde7657dd',
+ 'type' => 'library',
+ 'install_path' => __DIR__ . '/../../',
+ 'aliases' => array(),
+ 'dev' => true,
+ ),
+ 'versions' => array(
+ 'furyfire/codingtests' => array(
+ 'pretty_version' => 'dev-master',
+ 'version' => 'dev-master',
+ 'reference' => 'f11b705ef016cd7ff5c1803bcbeb196dde7657dd',
+ 'type' => 'library',
+ 'install_path' => __DIR__ . '/../../',
+ 'aliases' => array(),
+ 'dev_requirement' => false,
+ ),
+ ),
+);
diff --git a/vendor/composer/platform_check.php b/vendor/composer/platform_check.php
new file mode 100644
index 0000000..4c3a5d6
--- /dev/null
+++ b/vendor/composer/platform_check.php
@@ -0,0 +1,26 @@
+= 80100)) {
+ $issues[] = 'Your Composer dependencies require a PHP version ">= 8.1.0". You are running ' . PHP_VERSION . '.';
+}
+
+if ($issues) {
+ if (!headers_sent()) {
+ header('HTTP/1.1 500 Internal Server Error');
+ }
+ if (!ini_get('display_errors')) {
+ if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
+ fwrite(STDERR, 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . implode(PHP_EOL, $issues) . PHP_EOL.PHP_EOL);
+ } elseif (!headers_sent()) {
+ echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL;
+ }
+ }
+ trigger_error(
+ 'Composer detected issues in your platform: ' . implode(' ', $issues),
+ E_USER_ERROR
+ );
+}